@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400..800&display=swap");
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/7.0.1/css/all.min.css");

:root {
  --ink: #15171d;
  --paper: #ffffff;
  --ivory: #f7f8f4;
  --stone: #59616d;
  --line: #dde3ea;
  --blue: #2f63ff;
  --blue-deep: #13284b;
  --blue-soft: #e8eefc;
  --coral: #f05a3d;
  --coral-strong: #c93f37;
  --coral-soft: #f9e1de;
  --teal: #00b8b2;
  --teal-deep: #007d7e;
  --teal-soft: #def5f2;
  --mist: #eef2f6;
  --paper-warm: #fbfaf4;
  --wash-blue: #edf3ff;
  --wash-coral: #fff0eb;
  --wash-teal: #eaf8f4;
  --wash-amber: #f6f1e6;
  --wash-violet: #f3f1f7;
  --wash-neutral: #f4f6f2;
  --surface-transition: 76px;
  --grain-texture: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.24'/%3E%3C/svg%3E");
  --schema-ink: #262a31;
  --schema-muted: #68707a;
  --schema-soft: #f1f2f3;
  --schema-line: rgba(38, 42, 49, 0.13);
  --schema-line-soft: rgba(38, 42, 49, 0.07);
  --schema-dark-soft: rgba(38, 42, 49, 0.09);
  --max: 1180px;
  --radius: 8px;
  --header: 76px;
  --shadow: 0 24px 80px rgba(19, 40, 75, 0.12);
  --ease-schema: cubic-bezier(0.16, 1, 0.3, 1);
  --duration-schema: 980ms;
  --stagger-schema: 90ms;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 10% 0%, rgba(47, 99, 255, 0.045), transparent 34rem),
    radial-gradient(circle at 92% 12%, rgba(240, 90, 61, 0.038), transparent 30rem),
    linear-gradient(180deg, var(--ivory), var(--paper-warm) 58%, var(--ivory));
  color: var(--ink);
  font-family: Manrope, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.56;
  letter-spacing: 0;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 40;
  pointer-events: none;
  background-image: var(--grain-texture);
  background-size: 180px 180px;
  opacity: 0.035;
  mix-blend-mode: multiply;
}

body::selection {
  background: var(--coral-soft);
  color: var(--ink);
}

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

p,
h1,
h2,
h3,
h4 {
  margin: 0;
}

p {
  color: var(--stone);
}

ul,
ol {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

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

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

:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 4px;
}

.skip-link {
  position: absolute;
  left: 16px;
  top: 12px;
  z-index: 100;
  transform: translateY(-140%);
  background: var(--blue-deep);
  color: #fff;
  padding: 10px 14px;
  border-radius: var(--radius);
  transition: transform 180ms ease;
}

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

.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  min-height: var(--header);
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}

.nav {
  width: min(var(--max), calc(100% - 32px));
  min-height: var(--header);
  margin: 0 auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  color: var(--blue-deep);
  font-size: 19px;
  font-weight: 800;
  letter-spacing: 0;
}

.brand-text {
  display: inline-flex;
  align-items: center;
  font-weight: 800;
  font-size: 18px;
}

.nav-menu {
  display: none;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 13px;
  border: 1px solid rgba(19, 40, 75, 0.22);
  border-radius: 4px;
  background: var(--paper);
  color: var(--blue-deep);
  font-size: 14px;
  font-weight: 760;
  cursor: pointer;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.nav-menu:hover,
.nav-menu[aria-expanded="true"] {
  background: var(--blue-soft);
  border-color: rgba(19, 40, 75, 0.38);
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 24px;
  color: #45423c;
  font-size: 14px;
}

.nav-links a {
  padding: 8px 0;
  position: relative;
  transition: color 180ms ease;
}

.nav-links a:hover,
.nav-links a[aria-current="page"] {
  color: var(--ink);
}

.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 3px;
  width: 100%;
  height: 2px;
  background: var(--coral);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 220ms ease;
}

.nav-links a:hover::after,
.nav-links a[aria-current="page"]::after {
  transform: scaleX(1);
  transform-origin: left;
}

.nav-cta,
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 4px;
  border: 1px solid var(--blue-deep);
  background: var(--blue-deep);
  color: #fff;
  font-size: 15px;
  font-weight: 720;
  white-space: nowrap;
  transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease;
}

.nav-cta {
  min-height: 42px;
  font-size: 14px;
}

.nav-cta:hover,
.button:hover {
  transform: translateY(-2px);
  background: var(--coral-strong);
  border-color: var(--coral-strong);
  color: #fff;
}

.nav-cta:active,
.button:active,
.nav-menu:active {
  transform: translateY(0);
}

.button.secondary {
  background: transparent;
  color: var(--blue-deep);
  border-color: rgba(19, 40, 75, 0.28);
}

.button.secondary:hover {
  background: var(--blue-soft);
  border-color: var(--blue-deep);
  color: var(--blue-deep);
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}

.actions--center {
  justify-content: center;
}

.hero {
  position: relative;
  min-height: min(720px, calc(100svh - var(--header)));
  display: grid;
  align-items: center;
  overflow: clip;
  border-bottom: 0;
  background:
    radial-gradient(ellipse at 14% 20%, rgba(47, 99, 255, 0.07), transparent 34%),
    radial-gradient(ellipse at 86% 26%, rgba(240, 90, 61, 0.055), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(247, 248, 244, 0.94));
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    var(--grain-texture),
    linear-gradient(90deg, rgba(38, 42, 49, 0.07), transparent 28%),
    linear-gradient(180deg, transparent 64%, rgba(38, 42, 49, 0.045));
  background-size: 180px 180px, auto, auto;
  opacity: 0.55;
  pointer-events: none;
}

.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 1;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, rgba(246, 241, 230, 0.56) 62%, var(--wash-amber) 100%);
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 2;
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  padding: 84px 0 76px;
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(390px, 0.78fr);
  gap: 80px;
  align-items: center;
}

.hero-copy {
  max-width: 660px;
}

h1 {
  font-size: clamp(2.35rem, 5.3vw, 4rem);
  line-height: 1.02;
  font-weight: 760;
  letter-spacing: 0;
  max-width: 760px;
  text-wrap: balance;
}

h2 {
  font-size: clamp(2rem, 4.2vw, 3.1rem);
  line-height: 1.06;
  font-weight: 760;
  letter-spacing: 0;
  text-wrap: balance;
}

h3 {
  font-size: 1.25rem;
  line-height: 1.22;
  font-weight: 720;
}

.hero-lead,
.page-lead,
.section-lead {
  max-width: 710px;
  margin-top: 24px;
  color: #3f4856;
  font-size: 1.18rem;
  line-height: 1.58;
}

.hero-lead {
  max-width: 590px;
}

.art-visual {
  position: relative;
  margin: 0;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: 14px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(245, 247, 246, 0.92)),
    var(--paper);
  overflow: hidden;
  box-shadow: 0 28px 84px rgba(19, 40, 75, 0.12);
  isolation: isolate;
}

.art-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), transparent 32%),
    var(--grain-texture);
  background-size: auto, 180px 180px;
  opacity: 0.16;
  mix-blend-mode: multiply;
}

.art-visual picture,
.art-visual img {
  position: relative;
  z-index: 0;
  width: 100%;
  display: block;
}

.art-visual img {
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.scrolly__visual.art-visual {
  min-height: auto;
  align-items: stretch;
}

.shader-stage {
  position: relative;
  min-height: 500px;
  border: 1px solid rgba(19, 40, 75, 0.18);
  border-radius: var(--radius);
  background: var(--paper);
  overflow: hidden;
  box-shadow: var(--shadow);
  isolation: isolate;
}

.shader-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(19, 40, 75, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19, 40, 75, 0.08) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.92), rgba(0, 0, 0, 0.22));
}

.shader-stage::after {
  content: "";
  position: absolute;
  inset: 26px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
}

.diamond {
  position: absolute;
  width: 128px;
  height: 128px;
  border-radius: 20px;
  opacity: 1;
  transform: rotate(45deg) scale(1);
  transition: opacity 640ms ease, transform 780ms cubic-bezier(0.16, 1, 0.3, 1);
  animation: drift 9s ease-in-out infinite;
}

.js-enabled .diamond {
  opacity: 1;
  transform: rotate(45deg) scale(1);
}

.shader-stage.is-visible .diamond {
  opacity: 1;
  transform: rotate(45deg) scale(1);
}

.diamond span {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  transform: rotate(-45deg);
  font-weight: 790;
  font-size: 13px;
  text-align: center;
  color: var(--ink);
}

.d1 {
  left: 52px;
  top: 70px;
  background: var(--coral);
  transition-delay: 120ms;
}

.d2 {
  right: 68px;
  top: 122px;
  background: var(--blue-soft);
  animation-delay: -2s;
  transition-delay: 260ms;
}

.d3 {
  left: 110px;
  bottom: 100px;
  background: var(--teal-soft);
  animation-delay: -4s;
  transition-delay: 400ms;
}

.d4 {
  right: 105px;
  bottom: 78px;
  background: var(--blue);
  animation-delay: -6s;
  transition-delay: 540ms;
}

.d4 span {
  color: #fff;
}

.system-line {
  position: absolute;
  height: 2px;
  background: var(--blue-deep);
  opacity: 0.72;
  transform-origin: left center;
  transform: rotate(var(--line-rotate)) scaleX(1);
  transition: opacity 420ms ease, transform 900ms cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .system-line {
  opacity: 0.72;
  transform: rotate(var(--line-rotate)) scaleX(1);
}

.shader-stage.is-visible .system-line {
  opacity: 0.72;
  transform: rotate(var(--line-rotate)) scaleX(1);
}

.system-caption {
  position: absolute;
  left: 30px;
  right: 30px;
  bottom: 24px;
  z-index: 2;
  color: #334052;
  font-size: 14px;
  font-weight: 720;
  text-align: center;
}

.sl1 {
  left: 176px;
  top: 172px;
  width: 176px;
  --line-rotate: 11deg;
  transition-delay: 260ms;
}

.sl2 {
  left: 184px;
  bottom: 190px;
  width: 206px;
  --line-rotate: -25deg;
  transition-delay: 420ms;
}

.sl3 {
  right: 164px;
  bottom: 165px;
  width: 170px;
  --line-rotate: 28deg;
  transition-delay: 580ms;
}

.home-flow-visual {
  position: relative;
  min-height: 500px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 52% 50%, rgba(201, 63, 55, 0.10), transparent 28%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(246, 247, 248, 0.92) 58%, rgba(238, 240, 242, 0.86)),
    var(--paper);
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 24px 80px rgba(38, 42, 49, 0.10);
}

.home-flow-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(90deg, transparent 0 18%, var(--schema-line-soft) 18% calc(18% + 1px), transparent calc(18% + 1px) 82%, var(--schema-line-soft) 82% calc(82% + 1px), transparent calc(82% + 1px)),
    linear-gradient(180deg, transparent 0 28%, var(--schema-line-soft) 28% calc(28% + 1px), transparent calc(28% + 1px) 72%, var(--schema-line-soft) 72% calc(72% + 1px), transparent calc(72% + 1px));
  opacity: 0.52;
  mask-image: radial-gradient(circle at 52% 50%, rgba(0, 0, 0, 0.76), transparent 72%);
}

.home-flow-visual__svg {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.home-flow-path {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

.home-flow-path--base {
  stroke: rgba(38, 42, 49, 0.18);
  stroke-width: 16;
}

.home-flow-path--accent {
  stroke: rgba(201, 63, 55, 0.76);
  stroke-width: 4;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
}

.home-flow-visual.is-visible .home-flow-path--accent {
  animation: schema-draw 1300ms var(--ease-schema) 160ms forwards;
}

.home-flow-node,
.home-flow-focus {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 16px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: #262a31;
  font-size: 14px;
  font-weight: 830;
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  transition:
    opacity 480ms ease,
    transform 760ms var(--ease-schema),
    border-color 240ms ease;
  transition-delay: calc(var(--i, 0) * 120ms + 300ms);
}

.js-enabled .home-flow-node,
.js-enabled .home-flow-focus {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.82);
}

.home-flow-visual.is-visible .home-flow-node,
.home-flow-visual.is-visible .home-flow-focus {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.home-flow-node b {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: currentColor;
}

.home-flow-node.node-a {
  left: 14%;
  top: 55%;
  color: var(--coral);
}

.home-flow-node.node-b {
  left: 40%;
  top: 32%;
}

.home-flow-node.node-c {
  left: 63%;
  top: 62%;
  color: var(--teal-deep);
}

.home-flow-node.node-d {
  left: 86%;
  top: 45%;
  background: #262a31;
  color: #fff;
}

.home-flow-focus {
  left: 50%;
  top: 50%;
  min-height: 86px;
  padding: 0 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 16px 44px rgba(38, 42, 49, 0.10);
  color: #262a31;
}

.post-hero {
  position: relative;
  overflow: clip;
  border-bottom: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(19, 40, 75, 0.045), transparent 42%),
    linear-gradient(180deg, var(--paper), rgba(255, 255, 255, 0.86));
}

.post-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, rgba(246, 241, 230, 0.56) 62%, var(--wash-amber) 100%);
  pointer-events: none;
}

.post-hero-inner {
  position: relative;
  z-index: 1;
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  padding: 28px 0;
  display: grid;
  grid-template-columns: minmax(0, 0.52fr) minmax(0, 1fr);
  gap: 36px;
  align-items: center;
}

.post-hero-inner > p {
  max-width: 500px;
  color: #334052;
  font-size: 1rem;
  line-height: 1.54;
}

.post-hero-inner--bridge {
  display: grid;
  grid-template-columns: minmax(90px, 0.24fr) minmax(0, 0.76fr);
  gap: 56px;
  padding: 50px 0 62px;
  align-items: start;
}

.post-hero-inner--bridge::before {
  content: "";
  width: 100%;
  height: 2px;
  margin-top: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--coral), rgba(0, 167, 165, 0.44), transparent);
}

.post-hero-inner--bridge > p {
  max-width: 840px;
  margin: 0;
  color: #334052;
  font-size: clamp(1.08rem, 1.55vw, 1.34rem);
  line-height: 1.56;
  font-weight: 520;
  text-align: left;
}

.system-strip {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  background: rgba(19, 40, 75, 0.14);
  overflow: hidden;
}

.system-strip::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  top: 50%;
  height: 2px;
  background: rgba(201, 63, 55, 0.46);
  transform: translateY(-50%);
}

.system-strip span {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  min-height: 74px;
  padding: 16px 12px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--blue-deep);
  font-weight: 800;
  text-align: center;
}

.section {
  position: relative;
  overflow: clip;
  border-bottom: 0;
  background: var(--ivory);
}

.section[id] {
  scroll-margin-top: calc(var(--header) + 20px);
}

.section-inner {
  position: relative;
  z-index: 1;
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  padding: 96px 0;
}

.section--paper {
  --section-bg: var(--paper);
  background: var(--section-bg);
}

.section--wash-blue,
.section.alt-blue {
  --section-bg: var(--wash-blue);
  --section-accent: rgba(47, 99, 255, 0.10);
  background:
    radial-gradient(ellipse at 16% 0%, var(--section-accent), transparent 44%),
    radial-gradient(ellipse at 86% 24%, rgba(0, 184, 178, 0.06), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.42), transparent 42%),
    var(--section-bg);
}

.section--wash-teal,
.section.alt-teal {
  --section-bg: var(--wash-teal);
  --section-accent: rgba(0, 184, 178, 0.12);
  background:
    radial-gradient(ellipse at 18% 8%, var(--section-accent), transparent 42%),
    radial-gradient(ellipse at 82% 12%, rgba(47, 99, 255, 0.052), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.48), transparent 44%),
    var(--section-bg);
}

.section--wash-amber,
.section.alt-amber {
  --section-bg: var(--wash-amber);
  --section-accent: rgba(240, 90, 61, 0.075);
  background:
    radial-gradient(ellipse at 20% 0%, var(--section-accent), transparent 42%),
    radial-gradient(ellipse at 92% 20%, rgba(47, 99, 255, 0.045), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.48), transparent 48%),
    var(--section-bg);
}

.section--wash-coral,
.section.alt-coral {
  --section-bg: var(--wash-coral);
  --section-accent: rgba(240, 90, 61, 0.10);
  background:
    radial-gradient(ellipse at 16% 8%, var(--section-accent), transparent 38%),
    radial-gradient(ellipse at 88% 18%, rgba(0, 184, 178, 0.055), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.52), transparent 44%),
    var(--section-bg);
}

.section--wash-violet,
.section.alt-violet {
  --section-bg: var(--wash-violet);
  --section-accent: rgba(47, 99, 255, 0.065);
  background:
    radial-gradient(ellipse at 18% 0%, var(--section-accent), transparent 42%),
    radial-gradient(ellipse at 88% 24%, rgba(240, 90, 61, 0.052), transparent 42%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.54), transparent 48%),
    var(--section-bg);
}

.section--organic-top,
.section--organic-bottom,
.section.alt-blue,
.section.alt-teal,
.section.alt-amber,
.section.alt-coral,
.section.alt-violet {
  border-bottom: 0;
}

.section.alt-blue::before,
.section.alt-teal::before,
.section.alt-amber::before,
.section.alt-coral::before,
.section.alt-violet::before,
.section--wash-blue::before,
.section--wash-teal::before,
.section--wash-amber::before,
.section--wash-coral::before,
.section--wash-violet::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    var(--grain-texture),
    linear-gradient(90deg, rgba(38, 42, 49, 0.035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(38, 42, 49, 0.028) 1px, transparent 1px);
  background-size: 180px 180px, 112px 112px, 112px 112px;
  opacity: 0.38;
  mask-image: linear-gradient(180deg, transparent, #000 14%, #000 86%, transparent);
}

.section.alt-blue::after,
.section.alt-teal::after,
.section.alt-amber::after,
.section.alt-coral::after,
.section.alt-violet::after,
.section--organic-bottom::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 0;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, var(--edge-next, var(--ivory)) 100%);
  pointer-events: none;
}

.section.alt-amber,
.section.alt-violet,
.section.alt-blue,
.section.alt-teal,
.section.alt-coral {
  --edge-next: var(--ivory);
}

#bitacora.section.alt-amber {
  --edge-next: var(--ivory);
}

.section-tight .section-inner {
  padding: 72px 0;
}

.section-head {
  display: grid;
  gap: 0;
  max-width: 860px;
  align-items: start;
}

.story-head {
  display: grid;
  gap: 18px;
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
  justify-items: center;
}

.story-head .section-lead,
.story-head p {
  max-width: 720px;
  margin-top: 0;
}

.story-head .note {
  max-width: 680px;
  text-align: left;
}

.story-head + .art-visual {
  margin-top: clamp(40px, 5vw, 76px);
}

.split {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1fr);
  gap: 68px;
  align-items: start;
}

.visual-split {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(360px, 1fr);
  gap: 70px;
  align-items: center;
}

.stack {
  display: grid;
  gap: 18px;
}

.check-list--columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: 860px;
  margin-right: auto;
  margin-left: auto;
}

.note--center {
  margin-right: auto;
  margin-left: auto;
}

.values-visual {
  position: relative;
  min-height: 330px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 50% 48%, rgba(201, 63, 55, 0.10), transparent 30%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(241, 242, 243, 0.78));
  box-shadow: 0 24px 80px rgba(19, 40, 75, 0.10);
  overflow: hidden;
}

.values-visual::before,
.values-visual::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border: 1px solid rgba(38, 42, 49, 0.10);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.values-visual::before {
  width: 62%;
  aspect-ratio: 1;
}

.values-visual::after {
  width: 38%;
  aspect-ratio: 1;
}

.values-visual__center,
.values-visual__chip {
  position: absolute;
  z-index: 1;
  left: 50%;
  top: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-weight: 820;
  transform: translate(-50%, -50%);
}

.values-visual__center {
  width: 128px;
  height: 128px;
  border-radius: 50%;
  background: #262a31;
  color: #fff;
  box-shadow: 0 18px 48px rgba(38, 42, 49, 0.18);
}

.values-visual__chip {
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #262a31;
  font-size: 14px;
  opacity: 1;
  transition:
    opacity 520ms ease,
    transform 720ms cubic-bezier(0.16, 1, 0.3, 1),
    border-color 220ms ease;
  transition-delay: calc(var(--i, 0) * 90ms + 140ms);
}

.js-enabled .values-visual__chip {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.92);
}

.values-visual.is-visible .values-visual__chip {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.values-visual__chip--a {
  left: 50%;
  top: 19%;
  color: var(--coral);
}

.values-visual__chip--b {
  left: 78%;
  top: 38%;
}

.values-visual__chip--c {
  left: 69%;
  top: 76%;
  color: var(--teal-deep);
}

.values-visual__chip--d {
  left: 31%;
  top: 76%;
}

.values-visual__chip--e {
  left: 22%;
  top: 38%;
  color: var(--blue-deep);
}

.founder-section {
  background: var(--paper);
}

.founder-profile {
  display: grid;
  grid-template-columns: minmax(280px, 0.44fr) minmax(0, 1fr);
  gap: 72px;
  align-items: center;
}

.founder-photo {
  position: relative;
  min-height: 430px;
  margin: 0;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(241, 242, 243, 0.88), rgba(255, 255, 255, 0.94));
  overflow: hidden;
  box-shadow: 0 24px 70px rgba(19, 40, 75, 0.08);
}

.founder-photo img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  object-position: 50% 28%;
  filter: saturate(0.92);
}

.founder-copy {
  max-width: 760px;
}

.founder-copy h2 {
  margin-top: 12px;
}

.founder-role {
  margin-top: 10px;
  color: #566171;
  font-size: 1rem;
  font-weight: 760;
}

.founder-copy p:not(.section-lead) {
  max-width: 700px;
  margin-top: 18px;
  color: #3f4856;
  font-size: 1.02rem;
  line-height: 1.72;
}

.journal-visual {
  position: relative;
  min-height: 330px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 68% 22%, rgba(201, 63, 55, 0.12), transparent 26%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(241, 242, 243, 0.78));
  box-shadow: 0 24px 80px rgba(19, 40, 75, 0.10);
  overflow: hidden;
}

.journal-visual::before {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  top: 20%;
  bottom: 20%;
  border: 1px solid rgba(38, 42, 49, 0.10);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.58);
}

.journal-visual__line,
.journal-visual__marker,
.journal-visual__note {
  position: absolute;
  z-index: 1;
}

.journal-visual__line {
  left: 25%;
  right: 25%;
  height: 1px;
  background: rgba(38, 42, 49, 0.14);
  transform-origin: left center;
}

.journal-visual.is-visible .journal-visual__line {
  animation: journal-line 1600ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.journal-visual .line-a {
  top: 38%;
}

.journal-visual .line-b {
  top: 51%;
  animation-delay: 120ms;
}

.journal-visual .line-c {
  top: 64%;
  animation-delay: 240ms;
}

.journal-visual__marker {
  left: 50%;
  top: 50%;
  display: grid;
  place-items: center;
  width: 132px;
  height: 132px;
  border-radius: 50%;
  background: #262a31;
  color: #fff;
  font-weight: 860;
  transform: translate(-50%, -50%);
  box-shadow: 0 20px 58px rgba(38, 42, 49, 0.22);
}

.journal-visual__note {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #262a31;
  font-size: 13px;
  font-weight: 820;
}

.journal-visual .note-a {
  left: 16%;
  top: 30%;
  color: var(--coral);
}

.journal-visual .note-b {
  right: 13%;
  top: 49%;
}

.journal-visual .note-c {
  left: 19%;
  bottom: 24%;
  color: var(--teal-deep);
}

.journal-feature {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(320px, 0.54fr);
  gap: 72px;
  align-items: center;
}

.journal-feature__content {
  max-width: 820px;
}

.journal-kicker,
.journal-card__tag {
  display: inline-flex;
  color: var(--coral);
  font-size: 13px;
  font-weight: 840;
  text-transform: uppercase;
}

.journal-feature h2 {
  margin-top: 12px;
}

.journal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
  color: #566171;
  font-size: 14px;
  font-weight: 720;
}

.journal-meta span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.journal-meta span:not(:last-child)::after {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(86, 97, 113, 0.5);
}

.journal-feature__media {
  position: relative;
  min-height: 360px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(241, 242, 243, 0.78)),
    var(--paper);
  overflow: hidden;
  box-shadow: 0 22px 70px rgba(19, 40, 75, 0.08);
}

.journal-feature__media span {
  position: absolute;
  left: 18%;
  right: 18%;
  height: 76px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
}

.journal-feature__media span:nth-child(1) {
  top: 22%;
  border-left: 4px solid var(--coral);
}

.journal-feature__media span:nth-child(2) {
  top: 44%;
  transform: translateX(18px);
}

.journal-feature__media span:nth-child(3) {
  top: 66%;
  border-left: 4px solid var(--teal-deep);
  transform: translateX(-12px);
}

.journal-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 42px;
}

.journal-card {
  position: relative;
  display: grid;
  align-content: start;
  grid-template-rows: auto auto 1fr auto auto;
  min-height: 326px;
  gap: 14px;
  padding: 24px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  text-decoration: none;
  transition: border-color 180ms ease, box-shadow 220ms ease, transform 220ms ease, background-color 180ms ease;
}

.journal-card:hover,
.journal-card:focus-visible {
  background: var(--paper);
  border-color: rgba(19, 40, 75, 0.28);
  box-shadow: 0 22px 60px rgba(19, 40, 75, 0.10);
  transform: translateY(-3px);
}

.journal-card:focus-visible {
  outline: 3px solid rgba(201, 63, 55, 0.26);
  outline-offset: 4px;
}

.journal-card h3 {
  font-size: clamp(1.28rem, 1.9vw, 1.48rem);
  line-height: 1.14;
}

.journal-card p {
  color: #3f4856;
  font-size: 15.5px;
  line-height: 1.55;
}

.journal-card__meta {
  align-self: end;
  margin-top: auto;
  padding-top: 18px;
  color: #68707a;
  font-size: 13px;
  font-weight: 760;
}

.journal-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: fit-content;
  padding: 8px 10px 8px 13px;
  border: 1px solid rgba(19, 40, 75, 0.18);
  border-radius: 999px;
  background: rgba(238, 242, 246, 0.78);
  color: var(--blue-deep);
  font-size: 13.5px;
  font-weight: 820;
  transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease, transform 220ms ease;
}

.journal-card__cta::after {
  content: "\f061";
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--coral);
  color: #fff;
  font: var(--fa-font-solid);
  font-size: 10px;
  line-height: 1;
  transition: transform 220ms ease, background-color 180ms ease;
}

.journal-card:hover .journal-card__cta,
.journal-card:focus-visible .journal-card__cta {
  border-color: rgba(240, 90, 61, 0.46);
  background: rgba(240, 90, 61, 0.10);
  color: var(--ink);
}

.journal-card:hover .journal-card__cta::after,
.journal-card:focus-visible .journal-card__cta::after {
  transform: translateX(2px);
}

.article-shell {
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
}

.article-hero {
  max-width: 920px;
  padding: 92px 0 64px;
}

.article-hero h1 {
  margin-top: 14px;
  max-width: 860px;
}

.article-hero p {
  max-width: 760px;
  margin-top: 24px;
  color: #3f4856;
  font-size: 1.22rem;
  line-height: 1.62;
}

.article-back {
  display: flex;
  width: fit-content;
  margin-bottom: 34px;
  color: var(--blue-deep);
  font-size: 14px;
  font-weight: 820;
  text-decoration: none;
}

.article-back:hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}

.article-layout {
  display: grid;
  grid-template-columns: minmax(220px, 0.32fr) minmax(0, 0.78fr);
  gap: 72px;
  align-items: start;
  padding-bottom: 96px;
}

.article-aside {
  position: sticky;
  top: calc(var(--header) + 28px);
  padding: 22px;
  border-left: 4px solid var(--coral);
  background: var(--mist);
}

.article-aside p {
  margin-bottom: 10px;
  color: var(--coral);
  font-size: 13px;
  font-weight: 840;
  text-transform: uppercase;
}

.article-aside strong {
  display: block;
  color: var(--ink);
  line-height: 1.5;
}

.article-content {
  max-width: 760px;
}

.article-content > p,
.article-content li {
  color: #303846;
  font-size: 1.08rem;
  line-height: 1.82;
}

.article-content > p + p {
  margin-top: 22px;
}

.article-content h2 {
  margin-top: 52px;
  margin-bottom: 16px;
  font-size: clamp(1.65rem, 3vw, 2.2rem);
}

.article-content blockquote {
  margin: 46px 0;
  padding: 28px;
  border-left: 4px solid var(--coral);
  background: var(--mist);
}

.article-content blockquote p {
  color: var(--ink);
  font-size: 1.28rem;
  line-height: 1.58;
}

.article-cta {
  margin-top: 56px;
  padding: 32px;
  border-radius: var(--radius);
  background: #262a31;
  color: #fff;
}

.article-cta h2 {
  margin: 0;
  color: #fff;
}

.article-cta p {
  margin-top: 16px;
  color: rgba(255, 255, 255, 0.74);
}

.article-cta .button {
  margin-top: 24px;
  background: #fff;
  color: #262a31;
  border-color: #fff;
}

.diagram-panel {
  position: relative;
  min-height: 360px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.90), rgba(232, 238, 252, 0.72)),
    var(--paper);
  overflow: hidden;
  box-shadow: 0 22px 70px rgba(19, 40, 75, 0.08);
}

.diagram-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(19, 40, 75, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19, 40, 75, 0.07) 1px, transparent 1px);
  background-size: 36px 36px;
  opacity: 0.7;
}

.system-map {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 24px;
}

.map-node {
  position: relative;
  z-index: 2;
  min-height: 138px;
  display: grid;
  align-content: center;
  gap: 6px;
  padding: 20px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.88);
}

.map-node strong {
  color: var(--ink);
  font-size: 1.1rem;
}

.map-node span {
  color: var(--stone);
  font-size: 14px;
  line-height: 1.42;
}

.map-node-a {
  border-color: rgba(201, 63, 55, 0.34);
}

.map-node-b {
  border-color: rgba(38, 87, 232, 0.30);
}

.map-node-c {
  border-color: rgba(0, 167, 165, 0.30);
}

.map-node-d {
  border-color: rgba(19, 40, 75, 0.26);
}

.map-path {
  position: absolute;
  z-index: 1;
  height: 2px;
  background: rgba(19, 40, 75, 0.28);
  transform-origin: left center;
}

.path-a {
  left: 31%;
  top: 31%;
  width: 38%;
}

.path-b {
  left: 49%;
  top: 48%;
  width: 2px;
  height: 22%;
}

.path-c {
  left: 31%;
  bottom: 31%;
  width: 38%;
}

.modular-map {
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  gap: 12px;
  padding: 32px;
}

.modular-map span {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 54px;
  padding: 0 18px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.86);
  color: var(--blue-deep);
  font-weight: 800;
}

.modular-map span:nth-child(1),
.modular-map span:nth-child(5) {
  background: rgba(249, 225, 222, 0.92);
  color: var(--coral);
}

.modular-map span:nth-child(2),
.modular-map span:nth-child(6) {
  background: rgba(222, 245, 242, 0.92);
  color: var(--teal-deep);
}

.modular-map span:nth-child(4),
.modular-map span:nth-child(8) {
  background: rgba(232, 238, 252, 0.92);
  color: var(--blue);
}

.plain-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  margin-top: 42px;
  background: var(--line);
  border: 1px solid var(--line);
}

.plain-grid.cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.plain-grid.cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.plain-item {
  position: relative;
  min-height: 190px;
  padding: 28px;
  background: rgba(255, 255, 255, 0.84);
  transition: background-color 180ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.card-icon {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  margin-bottom: 20px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: 50%;
  background: rgba(238, 242, 246, 0.78);
  color: var(--blue-deep);
  font-size: 0.96rem;
  line-height: 1;
}

.plain-item .card-icon {
  color: var(--coral);
}

.plain-item:hover {
  background: var(--paper);
  box-shadow: 0 18px 48px rgba(19, 40, 75, 0.08);
  transform: translateY(-3px);
  z-index: 1;
}

.plain-item h3 {
  margin-bottom: 12px;
}

.plain-item p {
  font-size: 15.5px;
}

.service-entry-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 46px;
}

.service-entry-card {
  position: relative;
  display: grid;
  grid-template-rows: auto auto auto minmax(84px, 1fr) auto;
  min-height: 330px;
  align-content: start;
  gap: 18px;
  padding: 28px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  text-decoration: none;
  overflow: hidden;
  transition:
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 220ms ease,
    transform 220ms ease;
}

.service-entry-card .card-icon {
  width: 42px;
  height: 42px;
  margin-bottom: 2px;
  background: rgba(249, 225, 222, 0.64);
  color: var(--coral);
}

.service-entry-card:hover,
.service-entry-card:focus-visible {
  background: var(--paper);
  border-color: rgba(19, 40, 75, 0.28);
  box-shadow: 0 22px 60px rgba(19, 40, 75, 0.10);
  transform: translateY(-3px);
}

.service-entry-card:focus-visible {
  outline: 3px solid rgba(201, 63, 55, 0.26);
  outline-offset: 4px;
}

.service-entry-card__eyebrow {
  color: var(--coral);
  font-size: 13px;
  font-weight: 820;
  line-height: 1.35;
  text-transform: uppercase;
}

.service-entry-card h3 {
  max-width: 300px;
  font-size: 1.55rem;
}

.service-entry-card p {
  max-width: 320px;
  color: #3f4856;
  font-size: 15.5px;
}

.service-entry-card__cta {
  display: inline-flex;
  align-self: end;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: fit-content;
  margin-top: 6px;
  padding: 9px 10px 9px 14px;
  border: 1px solid rgba(19, 40, 75, 0.18);
  border-radius: 999px;
  background: rgba(238, 242, 246, 0.78);
  color: var(--blue-deep);
  font-size: 14px;
  font-weight: 820;
  transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease, transform 220ms ease;
}

.service-entry-card__cta::after {
  content: "\f061";
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--coral);
  color: #fff;
  font: var(--fa-font-solid);
  font-size: 11px;
  line-height: 1;
  transition: transform 220ms ease, background-color 180ms ease;
}

.service-entry-card:hover .service-entry-card__cta,
.service-entry-card:focus-visible .service-entry-card__cta {
  border-color: rgba(240, 90, 61, 0.46);
  background: rgba(240, 90, 61, 0.10);
  color: var(--ink);
}

.service-entry-card:hover .service-entry-card__cta::after,
.service-entry-card:focus-visible .service-entry-card__cta::after {
  transform: translateX(2px);
}

.route-output-section {
  background:
    radial-gradient(ellipse at 16% 0%, rgba(47, 99, 255, 0.082), transparent 42%),
    radial-gradient(ellipse at 92% 24%, rgba(0, 184, 178, 0.05), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.44), transparent 46%),
    var(--wash-blue);
  --edge-next: var(--paper-warm);
}

.route-output-section::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 0;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, var(--edge-next) 100%);
  pointer-events: none;
}

.diagnostic-path-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 44px;
}

.diagnostic-path-card {
  position: relative;
  display: grid;
  min-height: 300px;
  align-content: start;
  gap: 16px;
  padding: 28px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  transition:
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 220ms ease,
    transform 260ms cubic-bezier(0.16, 1, 0.3, 1);
  transition-delay: calc(var(--i, 0) * 90ms);
}

.diagnostic-path-card::after {
  content: "";
  position: absolute;
  left: 28px;
  top: 0;
  width: 0;
  height: 3px;
  border-radius: 0 0 999px 999px;
  background: var(--coral);
  transition: width 240ms ease;
}

.diagnostic-path-card:hover,
.diagnostic-path-card.reveal.is-visible:hover {
  background: var(--paper);
  border-color: rgba(19, 40, 75, 0.24);
  box-shadow: 0 24px 70px rgba(19, 40, 75, 0.12);
  transform: translateY(-6px);
  transition-delay: 0ms;
}

.diagnostic-path-card:hover::after,
.diagnostic-path-card.reveal.is-visible:hover::after {
  width: 72px;
}

.js-enabled .diagnostic-path-card.reveal {
  transform: translateY(28px);
}

.diagnostic-path-card.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.diagnostic-path-card .card-icon {
  margin-bottom: 0;
  background: rgba(232, 238, 252, 0.68);
  color: var(--blue-deep);
  transition: background-color 180ms ease, color 180ms ease, transform 220ms ease;
}

.diagnostic-path-card:hover .card-icon,
.diagnostic-path-card.reveal.is-visible:hover .card-icon {
  background: rgba(240, 90, 61, 0.10);
  color: var(--coral);
  transform: translateY(-2px) scale(1.04);
}

.diagnostic-path-card h3 {
  max-width: 300px;
  font-size: 1.45rem;
}

.diagnostic-path-card p {
  color: #3f4856;
  font-size: 15.5px;
}

.diagnostic-path-card .text-link {
  margin-top: auto;
}

.ads-ready-section {
  background:
    radial-gradient(circle at 86% 18%, rgba(222, 245, 242, 0.72), transparent 28%),
    radial-gradient(circle at 10% 90%, rgba(249, 225, 222, 0.76), transparent 34%),
    linear-gradient(135deg, var(--wash-blue), #ffffff 58%, var(--paper-warm));
  --edge-next: var(--ivory);
}

.ads-ready-section::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 0;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, var(--edge-next) 100%);
  pointer-events: none;
}

.ads-ready-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.44fr) minmax(0, 1fr);
  gap: 42px;
  align-items: start;
}

.ads-ready-copy {
  position: sticky;
  top: calc(var(--header) + 28px);
  display: grid;
  gap: 18px;
}

.ads-ready-copy p {
  max-width: 460px;
  color: #3f4856;
  font-size: 1.04rem;
  line-height: 1.58;
}

.ads-ready-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(19, 40, 75, 0.12);
  box-shadow: 0 24px 70px rgba(19, 40, 75, 0.08);
}

.ads-ready-grid article {
  display: grid;
  min-height: 220px;
  align-content: start;
  gap: 12px;
  padding: 24px;
  background: rgba(255, 255, 255, 0.84);
  transition: background-color 180ms ease, transform 220ms ease;
}

.ads-ready-grid article:nth-child(1),
.ads-ready-grid article:nth-child(2),
.ads-ready-grid article:nth-child(3) {
  grid-column: span 2;
}

.ads-ready-grid article:nth-child(4),
.ads-ready-grid article:nth-child(5) {
  grid-column: span 3;
}

.ads-ready-grid article:hover {
  background: var(--paper);
  transform: translateY(-2px);
}

.ads-ready-grid .card-icon {
  margin-bottom: 4px;
  color: var(--teal-deep);
}

.ads-ready-grid h3 {
  font-size: 1.1rem;
}

.ads-ready-grid p {
  color: #3f4856;
  font-size: 14.5px;
}

.route-list {
  position: relative;
  display: grid;
  margin-top: 44px;
}

.route-list::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 18px;
  bottom: 18px;
  width: 2px;
  background: rgba(201, 63, 55, 0.42);
  transform: scaleY(1);
  transform-origin: top;
  transition: transform 1100ms cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .route-list::before {
  transform: scaleY(0);
}

.route-list.is-visible::before {
  transform: scaleY(1);
}

.route-item {
  position: relative;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) auto;
  gap: 28px;
  align-items: start;
  padding: 24px 0;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 680ms ease, transform 760ms cubic-bezier(0.16, 1, 0.3, 1), border-color 680ms ease;
  transition-delay: calc(var(--i, 0) * 130ms);
}

.route-item::after {
  content: "";
  position: absolute;
  left: 76px;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(19, 40, 75, 0.12);
}

.route-item:last-child::after {
  display: none;
}

.js-enabled .route-item {
  opacity: 1;
  transform: translateY(28px);
}

.route-list.is-visible .route-item {
  opacity: 1;
  transform: translateY(0);
}

.route-item .num {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(201, 63, 55, 0.42);
  border-radius: 50%;
  background: var(--ivory);
  color: var(--coral);
  font-weight: 800;
  font-size: 1rem;
  line-height: 1;
}

.route-item p {
  max-width: 670px;
}

.text-link {
  display: inline-flex;
  color: var(--blue-deep);
  font-weight: 760;
  white-space: nowrap;
}

.text-link:hover {
  color: var(--coral);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.process {
  position: relative;
  counter-reset: step;
  display: grid;
  margin-top: 44px;
}

.process::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 18px;
  bottom: 18px;
  width: 2px;
  background: rgba(38, 87, 232, 0.42);
  transform: scaleY(1);
  transform-origin: top;
  transition: transform 1200ms cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .process::before {
  transform: scaleY(0);
}

.process.is-visible::before {
  transform: scaleY(1);
}

.process-step {
  position: relative;
  counter-increment: step;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 28px;
  padding: 24px 0;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 680ms ease, transform 760ms cubic-bezier(0.16, 1, 0.3, 1), border-color 680ms ease;
  transition-delay: calc(var(--i, 0) * 130ms);
}

.process-step::after {
  content: "";
  position: absolute;
  left: 76px;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(19, 40, 75, 0.12);
}

.process-step:last-child::after {
  display: none;
}

.js-enabled .process-step {
  opacity: 1;
  transform: translateY(30px);
}

.process.is-visible .process-step {
  opacity: 1;
  transform: translateY(0);
}

.process-step::before {
  content: "0" counter(step);
  position: relative;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(38, 87, 232, 0.48);
  border-radius: 50%;
  background: var(--paper);
  color: var(--blue);
  font-weight: 800;
  font-size: 1.8rem;
  line-height: 1;
  z-index: 1;
}

.process-step h3 {
  margin-bottom: 7px;
}

.check-list {
  display: grid;
  gap: 14px;
  margin-top: 28px;
}

.check-list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 14px;
  align-items: start;
  color: #303846;
}

.check-list li::before {
  content: "";
  width: 11px;
  height: 11px;
  margin-top: 8px;
  background: var(--coral);
  transform: rotate(45deg);
  border-radius: 2px;
}

.check-list--ads {
  max-width: 760px;
}

.check-list--ads li {
  grid-template-columns: 28px 1fr;
  gap: 16px;
}

.check-list--ads li::before {
  content: "\f00c";
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  margin-top: 1px;
  background: transparent;
  color: var(--teal-deep);
  font: var(--fa-font-solid);
  transform: none;
}

.check-list strong {
  color: var(--blue-deep);
  font-weight: 840;
}

.note {
  margin-top: 28px;
  padding: 18px 20px;
  border-left: 4px solid var(--coral);
  background: var(--paper);
  color: #3f4856;
}

.logos {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1px;
  margin-top: 36px;
  background: var(--line);
  border: 1px solid var(--line);
}

.proof-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  margin-top: 42px;
  background: var(--line);
  border: 1px solid var(--line);
}

.proof-card,
.proof-method {
  background: var(--paper);
  padding: 28px;
}

.proof-card h3,
.proof-method h3 {
  margin-top: 10px;
  margin-bottom: 14px;
}

.proof-label {
  display: inline-flex;
  color: var(--coral);
  font-size: 13px;
  font-weight: 800;
}

.proof-points {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.proof-points li {
  position: relative;
  padding-left: 18px;
  color: #303846;
  font-size: 15px;
}

.proof-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 8px;
  height: 8px;
  background: var(--coral);
  transform: rotate(45deg);
}

.proof-method {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 0.62fr) minmax(0, 1fr);
  gap: 34px;
  align-items: start;
  background:
    radial-gradient(ellipse at 18% 0%, rgba(47, 99, 255, 0.08), transparent 42%),
    var(--wash-blue);
}

.logo-item {
  min-height: 76px;
  background: var(--paper);
  display: grid;
  place-items: center;
  padding: 12px;
  color: #4f5966;
  font-weight: 760;
  text-align: center;
}

.cta-band {
  position: relative;
  overflow: hidden;
  background: #262a31;
  color: #fff;
}

.cta-band::before,
.footer::before {
  content: "";
  position: absolute;
  inset: -40%;
  pointer-events: none;
  background-image:
    var(--grain-texture),
    repeating-linear-gradient(115deg, rgba(255, 255, 255, 0.065) 0 1px, transparent 1px 28px),
    repeating-linear-gradient(25deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 42px);
  background-size: 180px 180px, 96px 96px, 140px 140px;
  opacity: 0.36;
  animation: dark-pattern-drift 32s linear infinite;
}

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

.cta-band::after {
  display: none;
}

.cta-band p,
.cta-band .section-lead {
  color: rgba(255, 255, 255, 0.76);
}

.cta-band .button {
  background: var(--coral-strong);
  color: #fff;
  border-color: var(--coral-strong);
}

.cta-band .button:hover {
  background: #fff;
  border-color: #fff;
  color: #262a31;
}

.page-hero {
  position: relative;
  min-height: min(720px, calc(100svh - var(--header)));
  display: grid;
  align-items: center;
  border-bottom: 0;
  overflow: clip;
  background:
    radial-gradient(ellipse at 16% 14%, rgba(47, 99, 255, 0.052), transparent 40%),
    radial-gradient(ellipse at 92% 22%, rgba(240, 90, 61, 0.045), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.64), rgba(247, 248, 244, 0.94));
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    var(--grain-texture),
    linear-gradient(90deg, rgba(38, 42, 49, 0.034) 1px, transparent 1px);
  background-size: 180px 180px, 132px 132px;
  opacity: 0.34;
  mask-image: linear-gradient(180deg, #000, transparent 82%);
}

.page-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 1;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, rgba(247, 248, 244, 0.58) 58%, var(--ivory) 100%);
  pointer-events: none;
}

.page-hero-inner {
  position: relative;
  z-index: 2;
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  padding: 84px 0 76px;
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(390px, 0.78fr);
  gap: 80px;
  align-items: center;
}

.page-hero-inner > .reveal:first-child {
  max-width: 660px;
}

.page-hero-visual {
  position: relative;
  min-height: 330px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background:
    radial-gradient(ellipse at 74% 18%, rgba(255, 255, 255, 0.96), transparent 36%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(238, 242, 246, 0.72)),
    var(--paper);
  overflow: hidden;
  box-shadow: 0 22px 70px rgba(19, 40, 75, 0.10);
}

.page-hero-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(19, 40, 75, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19, 40, 75, 0.07) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: 0.72;
}

.page-hero-visual span {
  position: absolute;
  z-index: 1;
  display: block;
  border: 1px solid rgba(19, 40, 75, 0.16);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 16px 42px rgba(19, 40, 75, 0.10);
}

.diagnostic-hero-visual span:nth-child(1) {
  left: 12%;
  top: 18%;
  width: 58%;
  height: 18%;
  border-left: 4px solid var(--coral);
}

.diagnostic-hero-visual span:nth-child(2) {
  left: 24%;
  top: 44%;
  width: 64%;
  height: 18%;
  border-left: 4px solid var(--blue);
}

.diagnostic-hero-visual span:nth-child(3) {
  left: 18%;
  bottom: 16%;
  width: 48%;
  height: 18%;
  border-left: 4px solid var(--teal);
}

.capture-hero-visual span:nth-child(1) {
  left: 14%;
  top: 18%;
  width: 18%;
  height: 64%;
  background: rgba(249, 225, 222, 0.88);
}

.capture-hero-visual span:nth-child(2) {
  left: 42%;
  top: 30%;
  width: 18%;
  height: 42%;
  background: rgba(232, 238, 252, 0.88);
}

.capture-hero-visual span:nth-child(3) {
  right: 14%;
  top: 42%;
  width: 18%;
  height: 20%;
  background: rgba(222, 245, 242, 0.88);
}

.operation-hero-visual span {
  border-radius: 50%;
}

.operation-hero-visual span:nth-child(1) {
  left: 14%;
  top: 22%;
  width: 94px;
  height: 94px;
  background: rgba(222, 245, 242, 0.90);
}

.operation-hero-visual span:nth-child(2) {
  left: 42%;
  top: 32%;
  width: 128px;
  height: 128px;
  background: rgba(232, 238, 252, 0.90);
}

.operation-hero-visual span:nth-child(3) {
  right: 12%;
  bottom: 16%;
  width: 84px;
  height: 84px;
  background: rgba(249, 225, 222, 0.90);
}

.contact-hero-visual span:nth-child(1) {
  left: 15%;
  top: 22%;
  width: 70%;
  height: 18%;
  border-left: 4px solid var(--coral);
}

.contact-hero-visual span:nth-child(2) {
  left: 23%;
  top: 48%;
  width: 58%;
  height: 18%;
  border-left: 4px solid var(--blue);
}

.contact-hero-visual span:nth-child(3) {
  left: 31%;
  bottom: 16%;
  width: 44%;
  height: 18%;
  border-left: 4px solid var(--teal);
}

.page-hero[data-tone="blue"] {
  background:
    radial-gradient(ellipse at 16% 8%, rgba(47, 99, 255, 0.10), transparent 42%),
    radial-gradient(ellipse at 90% 18%, rgba(0, 184, 178, 0.052), transparent 38%),
    linear-gradient(90deg, var(--wash-blue), var(--ivory) 66%);
}

.page-hero[data-tone="teal"] {
  background:
    radial-gradient(ellipse at 16% 8%, rgba(0, 184, 178, 0.11), transparent 42%),
    radial-gradient(ellipse at 88% 20%, rgba(47, 99, 255, 0.052), transparent 38%),
    linear-gradient(90deg, var(--wash-teal), var(--ivory) 66%);
}

.page-hero[data-tone="coral"] {
  background:
    radial-gradient(ellipse at 16% 8%, rgba(240, 90, 61, 0.105), transparent 40%),
    radial-gradient(ellipse at 90% 18%, rgba(0, 184, 178, 0.052), transparent 38%),
    linear-gradient(90deg, var(--wash-coral), var(--ivory) 66%);
}

.contact-hero {
  background:
    radial-gradient(circle at 86% 18%, rgba(222, 245, 242, 0.72), transparent 28%),
    radial-gradient(circle at 12% 78%, rgba(249, 225, 222, 0.92), transparent 34%),
    linear-gradient(120deg, #fff8f6, #eef2f6 64%, #ffffff);
}

.contact-hero .page-lead {
  max-width: 680px;
}

.contact-hero .schema {
  min-height: 286px;
}

.page-aside {
  position: relative;
  padding-left: 28px;
  border-left: 1px solid rgba(19, 40, 75, 0.18);
}

.page-aside p {
  font-size: 15.5px;
}

.aside-number {
  display: grid;
  gap: 4px;
  margin-top: 26px;
}

.aside-number strong {
  color: var(--ink);
  font-size: 3rem;
  line-height: 0.9;
}

.aside-number span {
  color: var(--stone);
  font-size: 14px;
}

.page-aside.hero-evidence {
  padding: 24px;
  border: 1px solid rgba(19, 40, 75, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.72);
}

.page-summary {
  grid-template-columns: minmax(300px, 0.58fr) minmax(0, 1fr);
  padding: 34px 0;
}

.page-summary .page-aside {
  padding: 24px;
  border: 1px solid rgba(19, 40, 75, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.76);
}

.page-summary .page-aside p {
  font-size: 1rem;
  line-height: 1.54;
}

.page-summary .aside-number strong {
  font-size: 2.25rem;
  line-height: 1;
}

.summary-visual {
  position: relative;
  min-height: 240px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(238, 242, 246, 0.72)),
    var(--paper);
  overflow: hidden;
}

.summary-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(19, 40, 75, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19, 40, 75, 0.07) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: 0.72;
}

.summary-visual span {
  position: absolute;
  z-index: 1;
  display: block;
  border: 1px solid rgba(19, 40, 75, 0.16);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 16px 42px rgba(19, 40, 75, 0.10);
}

.diagnostic-visual span:nth-child(1) {
  left: 10%;
  top: 18%;
  width: 34%;
  height: 24%;
  border-left: 4px solid var(--coral);
}

.diagnostic-visual span:nth-child(2) {
  left: 34%;
  top: 42%;
  width: 42%;
  height: 18%;
  border-left: 4px solid var(--blue);
}

.diagnostic-visual span:nth-child(3) {
  right: 10%;
  bottom: 18%;
  width: 30%;
  height: 24%;
  border-left: 4px solid var(--teal);
}

.capture-visual span:nth-child(1) {
  left: 10%;
  top: 18%;
  width: 20%;
  height: 64%;
  background: rgba(249, 225, 222, 0.88);
}

.capture-visual span:nth-child(2) {
  left: 39%;
  top: 29%;
  width: 20%;
  height: 42%;
  background: rgba(232, 238, 252, 0.88);
}

.capture-visual span:nth-child(3) {
  right: 10%;
  top: 39%;
  width: 20%;
  height: 22%;
  background: rgba(222, 245, 242, 0.88);
}

.operation-visual span {
  border-radius: 50%;
}

.operation-visual span:nth-child(1) {
  left: 12%;
  top: 22%;
  width: 92px;
  height: 92px;
  background: rgba(222, 245, 242, 0.90);
}

.operation-visual span:nth-child(2) {
  left: 42%;
  top: 30%;
  width: 120px;
  height: 120px;
  background: rgba(232, 238, 252, 0.90);
}

.operation-visual span:nth-child(3) {
  right: 12%;
  bottom: 18%;
  width: 82px;
  height: 82px;
  background: rgba(249, 225, 222, 0.90);
}

.contact-visual span:nth-child(1) {
  left: 12%;
  top: 22%;
  width: 64%;
  height: 18%;
  border-left: 4px solid var(--coral);
}

.contact-visual span:nth-child(2) {
  left: 22%;
  top: 48%;
  width: 56%;
  height: 18%;
  border-left: 4px solid var(--blue);
}

.contact-visual span:nth-child(3) {
  left: 32%;
  bottom: 16%;
  width: 46%;
  height: 18%;
  border-left: 4px solid var(--teal);
}

.schema {
  position: relative;
  min-height: 360px;
  border: 1px solid var(--schema-line);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 72% 22%, rgba(255, 255, 255, 0.98), transparent 38%),
    radial-gradient(circle at 16% 88%, rgba(47, 99, 255, 0.04), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(246, 247, 248, 0.92) 58%, rgba(238, 240, 242, 0.86)),
    var(--paper);
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 24px 80px rgba(38, 42, 49, 0.10);
}

.hero .schema {
  min-height: 500px;
}

.post-hero .schema {
  min-height: 168px;
  box-shadow: none;
}

.page-hero .schema {
  min-height: 330px;
}

.page-summary .schema {
  min-height: 240px;
}

.schema--compact {
  min-height: 220px;
}

.schema::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(90deg, transparent 0 18%, var(--schema-line-soft) 18% calc(18% + 1px), transparent calc(18% + 1px) 82%, var(--schema-line-soft) 82% calc(82% + 1px), transparent calc(82% + 1px)),
    linear-gradient(180deg, transparent 0 30%, var(--schema-line-soft) 30% calc(30% + 1px), transparent calc(30% + 1px) 70%, var(--schema-line-soft) 70% calc(70% + 1px), transparent calc(70% + 1px)),
    radial-gradient(circle at 50% 50%, rgba(38, 42, 49, 0.045), transparent 48%);
  opacity: 0.74;
  mask-image: radial-gradient(circle at 52% 50%, rgba(0, 0, 0, 0.82), transparent 72%);
}

.schema::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background-image: var(--grain-texture);
  background-size: 180px 180px;
  opacity: 0.045;
  mix-blend-mode: multiply;
}

.schema__svg {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.schema__path,
.schema__scan-frame,
.schema__scan-line {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

.schema__path {
  stroke: rgba(38, 42, 49, 0.38);
  stroke-width: 2.5;
  stroke-dasharray: 1;
  stroke-dashoffset: 0;
  opacity: 1;
}

.schema__path--accent {
  stroke: rgba(201, 63, 55, 0.62);
  stroke-width: 3;
}

.js-enabled .schema__path {
  stroke-dashoffset: 0;
  opacity: 1;
}

.schema.is-visible .schema__path {
  animation: schema-draw var(--duration-schema) var(--ease-schema) forwards;
}

.schema.is-visible .schema__path--accent {
  animation-delay: 260ms;
}

.schema__node,
.schema__chip,
.schema__step,
.router-source,
.router-option,
.schema__module,
.schema__flag,
.schema__drop,
.schema__dot,
.schema__bubble,
.schema__result {
  position: absolute;
  z-index: 2;
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  transition:
    opacity 480ms ease,
    transform 760ms var(--ease-schema),
    background-color 240ms ease,
    border-color 240ms ease;
  transition-delay: calc(var(--i, 0) * var(--stagger-schema) + 160ms);
}

.js-enabled .schema__node,
.js-enabled .schema__chip,
.js-enabled .schema__step,
.js-enabled .router-source,
.js-enabled .router-option,
.js-enabled .schema__module,
.js-enabled .schema__flag,
.js-enabled .schema__drop,
.js-enabled .schema__dot,
.js-enabled .schema__bubble,
.js-enabled .schema__result {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.schema.is-visible .schema__node,
.schema.is-visible .schema__chip,
.schema.is-visible .schema__step,
.schema.is-visible .router-source,
.schema.is-visible .router-option,
.schema.is-visible .schema__module,
.schema.is-visible .schema__flag,
.schema.is-visible .schema__drop,
.schema.is-visible .schema__dot,
.schema.is-visible .schema__bubble,
.schema.is-visible .schema__result {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.schema__node,
.schema__chip,
.schema__step,
.router-source,
.router-option,
.schema__module,
.schema__bubble,
.schema__dot {
  display: grid;
  place-items: center;
  min-width: 88px;
  min-height: 48px;
  padding: 0 16px;
  border: 1px solid var(--schema-line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.9);
  color: var(--schema-ink);
  font-weight: 830;
  line-height: 1;
  text-align: center;
}

.schema__core {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background: var(--schema-dark-soft);
  border: 1px solid var(--schema-line);
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  transition: opacity 520ms ease, transform 760ms var(--ease-schema);
}

.schema__core::before,
.schema__core::after {
  content: "";
  position: absolute;
  inset: 16px;
  border-radius: inherit;
  background: var(--schema-ink);
}

.schema__core::after {
  inset: 28px;
  background: var(--coral);
}

.js-enabled .schema__core {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.schema.is-visible .schema__core {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.schema.is-active .schema__core::before {
  animation: schema-pulse 2200ms ease-in-out infinite;
}

.schema--system-loop .node-a {
  left: 24%;
  top: 30%;
  background: var(--coral);
  color: #fff;
}

.schema--system-loop .node-b {
  left: 76%;
  top: 38%;
  background: rgba(241, 242, 243, 0.94);
  color: var(--schema-ink);
}

.schema--system-loop .node-c {
  left: 72%;
  top: 72%;
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--system-loop .node-d {
  left: 28%;
  top: 70%;
  background: var(--schema-ink);
  color: #fff;
}

.schema--system-loop.is-active .schema__node {
  animation: schema-node-breathe 3200ms ease-in-out infinite;
  animation-delay: calc(var(--i, 0) * 220ms);
}

.schema--fragmented-to-system {
  min-height: 150px;
}

.schema--fragmented-to-system .chip-a {
  left: 15%;
  top: 50%;
}

.schema--fragmented-to-system .chip-b {
  left: 38%;
  top: 50%;
}

.schema--fragmented-to-system .chip-c {
  left: 62%;
  top: 50%;
}

.schema--fragmented-to-system .chip-d {
  left: 85%;
  top: 50%;
}

.schema--journey-map .node-a {
  left: 15%;
  top: 51%;
  background: rgba(249, 225, 222, 0.94);
  color: var(--coral);
}

.schema--journey-map .node-b {
  left: 43%;
  top: 29%;
  border-color: rgba(38, 42, 49, 0.22);
  background: rgba(241, 242, 243, 0.94);
  color: var(--schema-ink);
}

.schema--journey-map .node-c {
  left: 58%;
  top: 71%;
  border-color: rgba(0, 167, 165, 0.34);
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--journey-map .node-d {
  left: 84%;
  top: 34%;
  background: rgba(38, 42, 49, 0.94);
  color: #fff;
}

.schema--route-progress,
.schema--decision-router,
.schema--evidence-chain {
  margin-top: 42px;
}

.schema--route-progress {
  min-height: 270px;
}

.schema__step {
  min-width: 132px;
  min-height: 72px;
  gap: 7px;
  padding: 12px 16px;
}

.schema__step b {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--schema-ink);
  color: #fff;
  font-size: 12px;
}

.schema--route-progress .step-a,
.schema--evidence-chain .step-a {
  left: 10%;
  top: 51%;
  background: rgba(249, 225, 222, 0.96);
  color: var(--coral);
}

.schema--route-progress .step-b {
  left: 36%;
  top: 38%;
  border-color: rgba(38, 42, 49, 0.22);
  background: rgba(241, 242, 243, 0.96);
  color: var(--schema-ink);
}

.schema--route-progress .step-c {
  left: 63%;
  top: 62%;
  border-color: rgba(0, 167, 165, 0.34);
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--route-progress .step-d {
  left: 90%;
  top: 51%;
  background: var(--schema-ink);
  color: #fff;
}

.schema--decision-router {
  min-height: 360px;
}

.router-source {
  left: 17%;
  top: 50%;
  min-width: 128px;
  min-height: 128px;
  border-radius: 50%;
  background: rgba(38, 42, 49, 0.94);
  color: #fff;
}

.router-option {
  min-width: 170px;
  min-height: 64px;
}

.router-option:hover {
  border-color: var(--schema-ink);
  transform: translate(-50%, -50%) scale(1.03);
}

.router-option.option-a {
  left: 82%;
  top: 26%;
  background: rgba(249, 225, 222, 0.96);
  color: var(--coral);
}

.router-option.option-b {
  left: 82%;
  top: 50%;
  background: rgba(241, 242, 243, 0.96);
  color: var(--schema-ink);
}

.router-option.option-c {
  left: 82%;
  top: 74%;
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--modular-board {
  min-height: 360px;
}

.schema__base {
  position: absolute;
  left: 12%;
  right: 12%;
  bottom: 18%;
  height: 48%;
  z-index: 1;
  border: 1px solid var(--schema-line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.58);
}

.schema__module {
  min-width: 118px;
}

.schema--modular-board .module-a {
  left: 27%;
  top: 37%;
  background: rgba(249, 225, 222, 0.96);
  color: var(--coral);
}

.schema--modular-board .module-b {
  left: 51%;
  top: 36%;
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--modular-board .module-c {
  left: 72%;
  top: 43%;
}

.schema--modular-board .module-d {
  left: 39%;
  top: 63%;
  background: rgba(241, 242, 243, 0.96);
  color: var(--schema-ink);
}

.schema--modular-board .module-e {
  left: 65%;
  top: 66%;
  background: var(--schema-ink);
  color: #fff;
}

.schema--evidence-chain {
  min-height: 280px;
}

.schema--evidence-chain .step-a {
  left: 14%;
}

.schema--evidence-chain .step-b {
  left: 50%;
  top: 50%;
  background: rgba(241, 242, 243, 0.96);
  color: var(--schema-ink);
}

.schema--evidence-chain .step-c {
  left: 86%;
  top: 50%;
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema__scan-frame,
.schema__scan-line {
  stroke: rgba(38, 42, 49, 0.20);
  stroke-width: 2;
}

.schema__scan-line {
  stroke: var(--coral);
  stroke-width: 4;
  stroke-dasharray: 1;
  stroke-dashoffset: 0;
}

.js-enabled .schema__scan-line {
  stroke-dashoffset: 0;
}

.schema.is-visible .schema__scan-line {
  animation: schema-draw 840ms var(--ease-schema) 180ms forwards, schema-scan 2600ms ease-in-out 1100ms infinite;
}

.schema__flag {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--coral);
  box-shadow: 0 0 0 12px rgba(201, 63, 55, 0.11);
}

.schema--scanner .flag-a {
  left: 26%;
  top: 31%;
}

.schema--scanner .flag-b {
  left: 64%;
  top: 49%;
  background: var(--schema-ink);
  box-shadow: 0 0 0 12px var(--schema-dark-soft);
}

.schema--scanner .flag-c {
  left: 40%;
  top: 66%;
  background: var(--teal);
  box-shadow: 0 0 0 12px rgba(0, 167, 165, 0.11);
}

.schema__drop {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--coral);
}

.schema--funnel-flow .drop-a {
  left: 23%;
  top: 20%;
}

.schema--funnel-flow .drop-b {
  left: 50%;
  top: 20%;
  background: var(--schema-ink);
}

.schema--funnel-flow .drop-c {
  left: 77%;
  top: 20%;
  background: var(--teal);
}

.schema__result {
  left: 50%;
  top: 78%;
  width: 128px;
  height: 42px;
  border-radius: var(--radius);
  background: var(--schema-ink);
}

.schema.is-active .schema__drop {
  animation: schema-drop 2400ms ease-in-out infinite;
  animation-delay: calc(var(--i, 0) * 160ms);
}

.schema__dot {
  min-width: 96px;
  min-height: 54px;
  border-radius: 999px;
  font-size: 13px;
}

.schema--operation-cycle .dot-a {
  left: 50%;
  top: 21%;
  background: rgba(249, 225, 222, 0.96);
  color: var(--coral);
}

.schema--operation-cycle .dot-b {
  left: 76%;
  top: 50%;
  background: rgba(241, 242, 243, 0.96);
  color: var(--schema-ink);
}

.schema--operation-cycle .dot-c {
  left: 50%;
  top: 79%;
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--operation-cycle .dot-d {
  left: 24%;
  top: 50%;
}

.schema.is-active.schema--operation-cycle .schema__path--main {
  animation: schema-draw 1200ms var(--ease-schema) forwards, schema-cycle-fade 3200ms ease-in-out 1400ms infinite;
}

.schema__bubble {
  min-width: 126px;
  min-height: 60px;
}

.schema--intake-flow .bubble-a {
  left: 18%;
  top: 50%;
  background: rgba(249, 225, 222, 0.96);
  color: var(--coral);
}

.schema--intake-flow .bubble-b {
  left: 50%;
  top: 50%;
  background: rgba(241, 242, 243, 0.96);
  color: var(--schema-ink);
}

.schema--intake-flow .bubble-c {
  left: 82%;
  top: 50%;
  background: rgba(222, 245, 242, 0.96);
  color: var(--teal-deep);
}

.schema--compact .schema__node,
.schema--compact .schema__chip,
.schema--compact .schema__step,
.schema--compact .schema__bubble,
.schema--compact .schema__dot {
  min-height: 44px;
  font-size: 13px;
}

.scrolly-section {
  background:
    radial-gradient(ellipse at 20% 6%, rgba(19, 40, 75, 0.044), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), var(--paper-warm) 56%, rgba(255, 255, 255, 0.94));
  border-bottom: 0;
  --edge-next: var(--ivory);
}

.scrolly-section::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 0;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, var(--edge-next) 100%);
  pointer-events: none;
}

.scrolly-section--home {
  border-top: 0;
  border-bottom: 0;
  --edge-next: var(--wash-blue);
}

.scrolly {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(0, 0.82fr);
  gap: 72px;
  align-items: start;
}

.scrolly__visual {
  position: sticky;
  top: calc(var(--header) + 28px);
  min-height: 520px;
  display: grid;
  align-items: center;
}

.scrolly__steps {
  display: grid;
  gap: 112px;
  padding: 70px 0;
}

.scrolly__panel {
  max-width: 560px;
  opacity: 0.45;
  transform: translateY(18px);
  transition: opacity 320ms ease, transform 420ms var(--ease-schema);
}

.scrolly__panel.is-active {
  opacity: 1;
  transform: translateY(0);
}

.scrolly__panel > span {
  display: inline-grid;
  place-items: center;
  min-width: 42px;
  height: 28px;
  margin-bottom: 18px;
  border: 1px solid var(--schema-line);
  border-radius: 999px;
  color: var(--schema-muted);
  font-size: 12px;
  font-weight: 820;
  font-variant-numeric: tabular-nums;
}

.scrolly__panel h2 {
  font-size: clamp(1.65rem, 3vw, 2.35rem);
  line-height: 1.08;
}

.scrolly__panel p {
  max-width: 520px;
  margin-top: 16px;
  font-size: 1.04rem;
}

.scrolly-diagram {
  position: relative;
  min-height: 430px;
  border: 1px solid var(--schema-line);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 50% 44%, rgba(38, 42, 49, 0.05), transparent 42%),
    radial-gradient(circle at 78% 20%, rgba(255, 255, 255, 0.92), transparent 36%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(246, 247, 248, 0.92));
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(38, 42, 49, 0.10);
}

.scrolly-diagram::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    var(--grain-texture),
    linear-gradient(90deg, transparent 0 22%, var(--schema-line-soft) 22% calc(22% + 1px), transparent calc(22% + 1px) 78%, var(--schema-line-soft) 78% calc(78% + 1px), transparent calc(78% + 1px)),
    linear-gradient(180deg, transparent 0 34%, var(--schema-line-soft) 34% calc(34% + 1px), transparent calc(34% + 1px) 66%, var(--schema-line-soft) 66% calc(66% + 1px), transparent calc(66% + 1px));
  background-size: 180px 180px, auto, auto;
  opacity: 0.46;
}

.scan-window,
.scan-line,
.signal,
.priority-card,
.capture-line,
.capture-node,
.capture-result,
.operation-orbit,
.operation-arrow,
.operation-node {
  position: absolute;
  z-index: 1;
}

.scan-window {
  left: 17%;
  top: 18%;
  width: 66%;
  height: 50%;
  border: 1px solid rgba(38, 42, 49, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.46);
}

.scan-line {
  left: 23%;
  top: 32%;
  width: 54%;
  height: 4px;
  border-radius: 999px;
  background: var(--coral);
  transform-origin: left center;
  transform: scaleX(0.3);
  opacity: 0.75;
}

.scrolly.is-active .scan-line {
  animation: schema-scan 2600ms ease-in-out infinite;
}

.signal {
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background: var(--coral);
  box-shadow: 0 0 0 12px rgba(201, 63, 55, 0.10);
  opacity: 0.35;
  transform: scale(0.82);
  transition: opacity 260ms ease, transform 360ms var(--ease-schema), background-color 220ms ease;
}

.signal-a {
  left: 30%;
  top: 38%;
}

.signal-b {
  left: 62%;
  top: 50%;
  background: var(--schema-ink);
  box-shadow: 0 0 0 12px var(--schema-dark-soft);
}

.signal-c {
  left: 45%;
  top: 62%;
  background: var(--teal);
  box-shadow: 0 0 0 12px rgba(0, 167, 165, 0.10);
}

.priority-card {
  display: grid;
  place-items: center;
  min-width: 118px;
  min-height: 50px;
  padding: 0 16px;
  border: 1px solid var(--schema-line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.92);
  color: var(--schema-ink);
  font-weight: 820;
  opacity: 0.38;
  transform: translate(-50%, -50%) scale(0.94);
  transition: opacity 320ms ease, transform 420ms var(--ease-schema), background-color 220ms ease;
}

.priority-a {
  left: 30%;
  top: 78%;
}

.priority-b {
  left: 50%;
  top: 78%;
}

.priority-c {
  left: 70%;
  top: 78%;
}

.scrolly[data-active-step="0"] .priority-a,
.scrolly[data-active-step="1"] .priority-b,
.scrolly[data-active-step="2"] .priority-c {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.scrolly[data-active-step="0"] .signal-a,
.scrolly[data-active-step="1"] .signal-a,
.scrolly[data-active-step="1"] .signal-b,
.scrolly[data-active-step="2"] .signal-a,
.scrolly[data-active-step="2"] .signal-b,
.scrolly[data-active-step="2"] .signal-c {
  opacity: 1;
  transform: scale(1);
}

.scrolly[data-active-step="0"] .signal-a,
.scrolly[data-active-step="1"] .signal-b,
.scrolly[data-active-step="2"] .signal-c {
  transform: scale(1.12);
}

.capture-line {
  left: 14%;
  right: 14%;
  top: 50%;
  height: 3px;
  border-radius: 999px;
  background: rgba(38, 42, 49, 0.26);
}

.capture-line::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--progress, 18%);
  height: 100%;
  border-radius: inherit;
  background: var(--coral);
  transition: width 520ms var(--ease-schema);
}

.capture-node,
.operation-node {
  display: grid;
  place-items: center;
  min-width: 110px;
  min-height: 54px;
  padding: 0 16px;
  border: 1px solid var(--schema-line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.92);
  color: var(--schema-ink);
  font-weight: 820;
  transform: translate(-50%, -50%);
  opacity: 0.45;
  transition: opacity 260ms ease, transform 420ms var(--ease-schema), background-color 220ms ease;
}

.node-offer {
  left: 18%;
  top: 50%;
  background: var(--coral);
  color: #fff;
}

.node-trust {
  left: 40%;
  top: 50%;
}

.node-contact {
  left: 62%;
  top: 50%;
  background: var(--teal-soft);
  color: var(--teal-deep);
}

.node-measure {
  left: 84%;
  top: 50%;
  background: var(--schema-ink);
  color: #fff;
}

.capture-result {
  left: 50%;
  bottom: 20%;
  display: grid;
  place-items: center;
  width: 136px;
  height: 44px;
  border-radius: var(--radius);
  background: var(--schema-ink);
  color: #fff;
  font-size: 13px;
  font-weight: 850;
  opacity: 0.18;
  transform: translateX(-50%) scaleX(0.64);
  transition: opacity 320ms ease, transform 520ms var(--ease-schema);
}

.scrolly[data-active-step="0"] .capture-line {
  --progress: 18%;
}

.scrolly[data-active-step="1"] .capture-line {
  --progress: 45%;
}

.scrolly[data-active-step="2"] .capture-line {
  --progress: 70%;
}

.scrolly[data-active-step="3"] .capture-line {
  --progress: 100%;
}

.scrolly[data-active-step="0"] .node-offer,
.scrolly[data-active-step="1"] .node-offer,
.scrolly[data-active-step="1"] .node-trust,
.scrolly[data-active-step="2"] .node-offer,
.scrolly[data-active-step="2"] .node-trust,
.scrolly[data-active-step="2"] .node-contact,
.scrolly[data-active-step="3"] .capture-node,
.scrolly[data-active-step="3"] .capture-result {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.04);
}

.scrolly[data-active-step="3"] .capture-result {
  transform: translateX(-50%) scaleX(1);
}

.operation-orbit {
  left: 16%;
  top: 18%;
  width: 68%;
  height: 62%;
  border: 3px solid rgba(38, 42, 49, 0.26);
  border-radius: 50%;
}

.operation-arrow {
  right: 20%;
  top: 28%;
  width: 54px;
  height: 54px;
  border-top: 4px solid var(--coral);
  border-right: 4px solid var(--coral);
  transform: rotate(22deg);
}

.node-review {
  left: 50%;
  top: 20%;
  background: var(--coral-soft);
  color: var(--coral);
}

.node-prioritize {
  left: 77%;
  top: 50%;
}

.node-execute {
  left: 50%;
  top: 80%;
  background: var(--teal-soft);
  color: var(--teal-deep);
}

.node-report {
  left: 23%;
  top: 50%;
}

.scrolly[data-active-step="0"] .node-review,
.scrolly[data-active-step="1"] .node-prioritize,
.scrolly[data-active-step="2"] .node-execute,
.scrolly[data-active-step="3"] .node-report {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.08);
  box-shadow: 0 18px 46px rgba(38, 42, 49, 0.14);
}

.scrolly.is-active .operation-arrow {
  animation: schema-cycle-fade 2600ms ease-in-out infinite;
}

.evidence-kicker {
  color: var(--blue-deep);
  font-size: 14px;
  font-weight: 800;
}

.evidence-list,
.flow-mini {
  display: grid;
  gap: 14px;
  margin-top: 20px;
}

.evidence-list li,
.flow-mini li {
  display: grid;
  gap: 3px;
  padding-top: 13px;
  border-top: 1px solid rgba(19, 40, 75, 0.14);
}

.evidence-list strong,
.flow-mini strong {
  color: var(--ink);
  font-size: 15.5px;
  line-height: 1.24;
}

.evidence-list span,
.flow-mini span {
  color: var(--stone);
  font-size: 14px;
  line-height: 1.45;
}

.comparison-section {
  background:
    radial-gradient(ellipse at 18% 0%, rgba(0, 184, 178, 0.07), transparent 40%),
    radial-gradient(ellipse at 88% 18%, rgba(47, 99, 255, 0.045), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), var(--paper-warm));
  --edge-next: var(--wash-blue);
}

.comparison-section::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 0;
  height: var(--surface-transition);
  background:
    linear-gradient(180deg, transparent 0%, var(--edge-next) 100%);
  pointer-events: none;
}

.comparison-head {
  max-width: 780px;
}

.comparison-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 72px minmax(0, 1fr);
  align-items: stretch;
  max-width: 1080px;
  margin: 48px auto 0;
}

.comparison-card {
  position: relative;
  display: grid;
  align-content: start;
  gap: 18px;
  min-height: 470px;
  padding: 30px;
  border: 1px solid rgba(19, 40, 75, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 58px rgba(19, 40, 75, 0.06);
}

.comparison-card--operation {
  border-color: rgba(0, 125, 126, 0.30);
  background:
    radial-gradient(ellipse at 84% 0%, rgba(0, 184, 178, 0.12), transparent 38%),
    rgba(255, 255, 255, 0.92);
  box-shadow: 0 28px 80px rgba(0, 125, 126, 0.11);
}

.comparison-kicker {
  width: fit-content;
  padding: 7px 10px;
  border: 1px solid rgba(19, 40, 75, 0.12);
  border-radius: 999px;
  background: rgba(238, 242, 246, 0.82);
  color: var(--blue-deep);
  font-size: 12px;
  font-weight: 820;
}

.comparison-card--operation .comparison-kicker {
  background: rgba(222, 245, 242, 0.88);
  color: var(--teal-deep);
}

.comparison-card h3 {
  font-size: clamp(1.65rem, 3vw, 2.25rem);
}

.comparison-card > p {
  max-width: 420px;
  color: #3f4856;
  font-size: 1.02rem;
}

.comparison-list {
  display: grid;
  margin-top: 8px;
  border-top: 1px solid rgba(19, 40, 75, 0.12);
}

.comparison-list li {
  display: grid;
  grid-template-columns: 116px minmax(0, 1fr);
  gap: 20px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(19, 40, 75, 0.10);
}

.comparison-list strong {
  color: var(--ink);
  font-size: 14px;
  font-weight: 840;
}

.comparison-list span {
  color: #4d5664;
  font-size: 14.5px;
  line-height: 1.48;
}

.comparison-divider {
  position: relative;
  display: grid;
  place-items: center;
  min-width: 72px;
}

.comparison-divider::before {
  content: "";
  position: absolute;
  top: 28px;
  bottom: 28px;
  left: 50%;
  width: 1px;
  background: rgba(19, 40, 75, 0.16);
  transform: translateX(-50%);
}

.comparison-divider span {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(19, 40, 75, 0.16);
  border-radius: 50%;
  background: var(--paper);
  color: var(--blue-deep);
  font-size: 13px;
  font-weight: 860;
  text-transform: uppercase;
}

.comparison-note {
  max-width: 760px;
  margin: 34px auto 0;
  padding: 18px 20px;
  border-left: 4px solid var(--teal);
  background: rgba(255, 255, 255, 0.74);
  color: #303846;
  font-size: 1.04rem;
  font-weight: 650;
  line-height: 1.48;
}

.levels {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-top: 42px;
  background: rgba(19, 40, 75, 0.18);
  border: 1px solid rgba(19, 40, 75, 0.18);
}

.level {
  position: relative;
  background: rgba(255, 255, 255, 0.84);
  padding: 26px;
  min-height: 250px;
  transition: background-color 180ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.level:hover {
  background: var(--paper);
  box-shadow: 0 18px 48px rgba(19, 40, 75, 0.08);
  transform: translateY(-3px);
  z-index: 1;
}

.level h3 {
  margin-bottom: 12px;
}

.level ul {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.level li {
  color: var(--stone);
  font-size: 14.5px;
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  margin-top: 42px;
  background: var(--line);
  border: 1px solid var(--line);
}

.faq {
  position: relative;
  padding: 26px;
  background: var(--paper);
  transition: background-color 180ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.faq:hover {
  background: #fff;
  box-shadow: 0 18px 48px rgba(19, 40, 75, 0.08);
  transform: translateY(-3px);
  z-index: 1;
}

.faq h3 {
  margin-bottom: 10px;
}

.form-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.76fr) minmax(420px, 1fr);
  gap: 60px;
  align-items: start;
}

.contact-intake {
  background:
    radial-gradient(ellipse at 16% 0%, rgba(240, 90, 61, 0.072), transparent 38%),
    radial-gradient(ellipse at 88% 18%, rgba(47, 99, 255, 0.045), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 241, 230, 0.76)),
    var(--wash-amber);
  border-bottom: 0;
}

.contact-intake .section-inner {
  padding: 72px 0;
}

.contact-form-layout {
  display: grid;
  max-width: 880px;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: start;
}

.form-panel {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
}

.contact-form-panel {
  box-shadow: 0 24px 70px rgba(19, 40, 75, 0.10);
}

.form-panel-head {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}

.form-panel-head p {
  max-width: 620px;
  color: #3f4856;
  font-size: 1rem;
}

.form {
  display: grid;
  gap: 18px;
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

label {
  display: grid;
  gap: 7px;
  color: var(--ink);
  font-weight: 720;
}

.field-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.field-mark {
  color: var(--coral);
  font-size: 12px;
  font-weight: 800;
}

.field-mark.optional {
  color: var(--stone);
}

input,
select,
textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid #aab4c0;
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  padding: 12px 13px;
}

textarea {
  min-height: 150px;
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--blue);
  outline: 3px solid rgba(36, 88, 230, 0.20);
}

.help {
  color: var(--stone);
  font-size: 13px;
  font-weight: 450;
}

.optional-fields {
  display: grid;
  gap: 18px;
  margin-top: 4px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}

.optional-fields summary {
  width: fit-content;
  cursor: pointer;
  color: var(--blue-deep);
  font-size: 14px;
  font-weight: 820;
}

.optional-fields summary:hover {
  color: var(--coral);
}

.optional-title {
  color: var(--blue-deep);
  font-size: 14px;
  font-weight: 800;
}

.legal-consent {
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--ivory);
  color: #3f4856;
  font-weight: 520;
  line-height: 1.45;
}

.legal-consent input {
  min-height: auto;
  width: 18px;
  height: 18px;
  margin: 3px 0 0;
  accent-color: var(--blue-deep);
}

.legal-consent a {
  color: var(--blue-deep);
  font-weight: 780;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.info-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 30px;
}

.company-list {
  display: grid;
  gap: 22px;
  margin: 0;
}

.company-list div {
  display: grid;
  gap: 6px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}

.company-list div:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.company-list dt {
  color: var(--stone);
  font-size: 13px;
  font-weight: 820;
}

.company-list dd {
  margin: 0;
  color: var(--ink);
  font-weight: 720;
}

.company-list a {
  color: var(--blue-deep);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-content {
  max-width: 900px;
}

.legal-content h2 {
  margin-top: 48px;
  font-size: clamp(1.55rem, 3vw, 2.2rem);
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content p {
  max-width: 760px;
  margin-top: 16px;
}

.legal-content a {
  color: var(--blue-deep);
  font-weight: 780;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-grid {
  margin-top: 28px;
}

.footer {
  position: relative;
  overflow: hidden;
  background: #202329;
  color: #fff;
}

.footer-inner {
  position: relative;
  z-index: 1;
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  padding: 54px 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) repeat(2, minmax(160px, 220px));
  gap: 46px;
  align-items: start;
}

.footer .brand-text {
  color: #fff;
}

.footer-brand p {
  max-width: 520px;
  margin-top: 14px;
  color: rgba(255, 255, 255, 0.72);
}

.footer-meta {
  color: rgba(255, 255, 255, 0.54);
  font-size: 13px;
}

.footer-group {
  display: grid;
  gap: 10px;
  align-content: start;
  color: rgba(255, 255, 255, 0.76);
  font-size: 14px;
}

.footer-group h2 {
  margin-bottom: 8px;
  color: rgba(255, 255, 255, 0.96);
  font-size: 13px;
  font-weight: 840;
}

.footer-group a,
.footer-group button {
  justify-self: start;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.76);
  font-size: 14px;
  line-height: 1.4;
  cursor: pointer;
}

.footer-group a:hover,
.footer-group button:hover {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.consent-banner {
  position: fixed;
  left: 20px;
  bottom: 20px;
  z-index: 120;
  width: min(480px, calc(100% - 40px));
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius);
  background: rgba(38, 42, 49, 0.98);
  color: #fff;
  box-shadow: 0 24px 80px rgba(15, 22, 34, 0.26);
}

.consent-banner[hidden],
.consent-modal[hidden] {
  display: none;
}

.consent-banner__inner {
  display: grid;
  gap: 16px;
  padding: 20px;
}

.consent-banner h2,
.consent-modal h2 {
  color: inherit;
  font-size: 1.08rem;
  line-height: 1.22;
}

.consent-banner p,
.consent-modal p {
  color: rgba(255, 255, 255, 0.76);
  font-size: 14px;
}

.consent-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.consent-button {
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid rgba(255, 255, 255, 0.30);
  border-radius: 4px;
  background: transparent;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  cursor: pointer;
}

.consent-button:hover {
  border-color: rgba(255, 255, 255, 0.74);
}

.consent-button.primary {
  border-color: #fff;
  background: #fff;
  color: #202631;
}

.consent-modal {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(15, 22, 34, 0.54);
}

.consent-modal__panel {
  width: min(640px, 100%);
  max-height: min(720px, calc(100dvh - 40px));
  overflow: auto;
  border-radius: var(--radius);
  background: #262a31;
  color: #fff;
  box-shadow: 0 30px 90px rgba(15, 22, 34, 0.34);
}

.consent-modal__content {
  display: grid;
  gap: 20px;
  padding: 26px;
}

.consent-option {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius);
}

.consent-option h3 {
  color: #fff;
  font-size: 1rem;
}

.consent-option p {
  margin-top: 6px;
}

.consent-option input {
  width: 22px;
  height: 22px;
  min-height: auto;
  accent-color: var(--coral);
}

.consent-option input:disabled {
  opacity: 0.7;
}

.hero-copy.reveal {
  opacity: 1;
  transform: none;
}

.hero-copy > * {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 760ms ease, transform 820ms cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .hero-copy > * {
  opacity: 1;
  transform: translateY(0);
}

.hero-copy > :nth-child(1) {
  transition-delay: 80ms;
}

.hero-copy > :nth-child(2) {
  transition-delay: 220ms;
}

.hero-copy > :nth-child(3) {
  transition-delay: 360ms;
}

.hero-copy.is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

.reveal {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 680ms ease, transform 760ms cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .reveal {
  opacity: 1;
  transform: translateY(22px);
}

.js-enabled .hero-copy.reveal {
  opacity: 1;
  transform: none;
}

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

@keyframes drift {
  0%,
  100% {
    translate: 0 0;
  }

  50% {
    translate: 0 -12px;
  }
}

@keyframes dark-pattern-drift {
  0% {
    transform: translate3d(0, 0, 0);
  }

  100% {
    transform: translate3d(96px, 64px, 0);
  }
}

@keyframes schema-draw {
  from {
    opacity: 0;
    stroke-dashoffset: 1;
  }

  to {
    opacity: 1;
    stroke-dashoffset: 0;
  }
}

@keyframes schema-pulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.42);
    opacity: 0.34;
  }
}

@keyframes schema-node-breathe {
  0%,
  100% {
    translate: 0 0;
  }

  50% {
    translate: 0 -8px;
  }
}

@keyframes schema-scan {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(116px);
  }
}

@keyframes schema-drop {
  0% {
    transform: translate(-50%, -90%) scale(0.72);
    opacity: 0;
  }

  26%,
  72% {
    transform: translate(-50%, 0) scale(1);
    opacity: 1;
  }

  100% {
    transform: translate(-50%, 150px) scale(0.72);
    opacity: 0;
  }
}

@keyframes schema-cycle-fade {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.48;
  }
}

@media (max-width: 1080px) {
  .hero-inner,
  .page-hero-inner,
  .split,
  .visual-split,
  .post-hero-inner,
  .page-summary,
  .founder-profile,
  .journal-feature,
  .article-layout,
  .form-layout {
    grid-template-columns: 1fr;
  }

  .plain-grid,
  .plain-grid.cols-2,
  .plain-grid.cols-4,
  .service-entry-grid,
  .diagnostic-path-grid,
  .journal-grid,
  .levels {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .article-aside {
    position: relative;
    top: auto;
  }

  .ads-ready-layout,
  .contact-form-layout {
    grid-template-columns: 1fr;
  }

  .ads-ready-copy {
    position: relative;
    top: auto;
  }

  .comparison-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 720px;
  }

  .comparison-card {
    min-height: auto;
  }

  .comparison-divider {
    min-height: 42px;
  }

  .comparison-divider::before {
    left: 0;
    right: 0;
    top: 50%;
    bottom: auto;
    width: auto;
    height: 1px;
    transform: translateY(-50%);
  }

  .scrolly {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .scrolly__visual {
    position: relative;
    top: auto;
    min-height: auto;
  }

  .scrolly__visual.art-visual {
    min-height: auto;
  }

  .scrolly__steps {
    gap: 28px;
    padding: 0;
  }

  .scrolly__panel {
    max-width: none;
    opacity: 1;
    transform: none;
    padding-top: 24px;
    border-top: 1px solid var(--line);
  }

  .route-item {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .route-list::before {
    left: 23px;
  }

  .route-item .text-link {
    grid-column: 2;
  }

  .page-aside {
    border-left: 0;
    padding-left: 0;
    border-top: 1px solid rgba(19, 40, 75, 0.18);
    padding-top: 24px;
  }
}

@media (max-width: 760px) {
  :root {
    --header: 70px;
  }

  .nav {
    gap: 10px;
  }

  /* En móvil: logo a la izquierda; "Menú" y "Revisar mi caso" agrupados a la derecha. */
  .brand {
    margin-right: auto;
  }

  .nav-menu {
    display: inline-flex;
  }

  .nav-links {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 1px);
    z-index: 55;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 0 0 var(--radius) var(--radius);
    background: var(--paper);
    box-shadow: 0 28px 70px rgba(19, 40, 75, 0.16);
    color: var(--blue-deep);
    align-items: stretch;
    gap: 2px;
  }

  .nav.is-open .nav-links {
    display: grid;
  }

  .nav-links a {
    padding: 12px;
  }

  .nav-links a::after {
    display: none;
  }

  .nav-cta {
    min-height: 40px;
    padding: 0 13px;
  }

  .hero,
  .page-hero {
    min-height: auto;
  }

  .hero-inner,
  .page-hero-inner,
  .post-hero-inner,
  .section-inner {
    padding: 58px 0;
  }

  .hero-inner,
  .page-hero-inner {
    gap: 44px;
  }

  .story-head {
    text-align: left;
    justify-items: start;
    margin-left: 0;
  }

  .check-list--columns {
    grid-template-columns: 1fr;
  }

  .comparison-grid {
    margin-top: 32px;
  }

  .comparison-card {
    gap: 14px;
    padding: 22px;
  }

  .comparison-list li {
    grid-template-columns: 1fr;
    gap: 5px;
    padding: 14px 0;
  }

  .comparison-note {
    margin-top: 24px;
    padding: 16px;
    font-size: 0.98rem;
  }

  .scrolly-diagram {
    min-height: 330px;
  }

  .capture-node,
  .operation-node,
  .priority-card {
    min-width: 90px;
    min-height: 44px;
    padding: 0 12px;
    font-size: 12px;
  }

  .capture-line {
    left: 10%;
    right: 10%;
  }

  .node-offer {
    left: 20%;
    top: 36%;
  }

  .node-trust {
    left: 62%;
    top: 36%;
  }

  .node-contact {
    left: 28%;
    top: 64%;
  }

  .node-measure {
    left: 72%;
    top: 64%;
  }

  .capture-result {
    bottom: 9%;
  }

  .priority-a {
    left: 26%;
  }

  .priority-b {
    left: 50%;
  }

  .priority-c {
    left: 74%;
  }

  .schema {
    min-height: 280px;
  }

  .hero .schema {
    min-height: 360px;
  }

  .home-flow-visual {
    min-height: 340px;
  }

  .home-flow-node,
  .home-flow-focus {
    min-height: 40px;
    padding: 0 12px;
    font-size: 12px;
  }

  .home-flow-focus {
    min-height: 66px;
    padding: 0 16px;
  }

  .home-flow-node.node-a {
    left: 18%;
    top: 58%;
  }

  .home-flow-node.node-b {
    left: 38%;
    top: 31%;
  }

  .home-flow-node.node-c {
    left: 62%;
    top: 68%;
  }

  .home-flow-node.node-d {
    left: 80%;
    top: 44%;
  }

  .page-hero .schema {
    min-height: 240px;
  }

  .post-hero .schema {
    min-height: 150px;
  }

  .schema__node,
  .schema__chip,
  .schema__step,
  .router-source,
  .router-option,
  .schema__module,
  .schema__bubble,
  .schema__dot {
    min-width: 78px;
    min-height: 42px;
    padding: 0 12px;
    font-size: 13px;
  }

  .post-hero-inner,
  .visual-split {
    gap: 28px;
  }

  .post-hero-inner--bridge {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 34px 0 46px;
  }

  .post-hero-inner--bridge::before {
    width: 88px;
    margin-top: 0;
  }

  .system-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .system-strip::before {
    display: none;
  }

  .system-strip span {
    min-height: 64px;
  }

  .shader-stage {
    min-height: 370px;
  }

  .diamond {
    width: 96px;
    height: 96px;
  }

  .d1 {
    left: 28px;
    top: 72px;
  }

  .d2 {
    right: 34px;
    top: 112px;
  }

  .d3 {
    left: 42px;
    bottom: 92px;
  }

  .d4 {
    right: 54px;
    bottom: 78px;
  }

  .system-line {
    display: none;
  }

  .plain-grid,
  .plain-grid.cols-2,
  .plain-grid.cols-4,
  .service-entry-grid,
  .diagnostic-path-grid,
  .journal-grid,
  .levels,
  .faq-grid,
  .logos,
  .system-map,
  .form-row,
  .footer-inner {
    grid-template-columns: 1fr;
  }

  .service-entry-grid {
    gap: 14px;
    margin-top: 32px;
  }

  .ads-ready-grid {
    grid-template-columns: 1fr;
  }

  .ads-ready-grid article:nth-child(1),
  .ads-ready-grid article:nth-child(2),
  .ads-ready-grid article:nth-child(3),
  .ads-ready-grid article:nth-child(4),
  .ads-ready-grid article:nth-child(5) {
    grid-column: auto;
  }

  .ads-ready-grid article,
  .diagnostic-path-card {
    min-height: auto;
    padding: 22px;
  }

  .contact-intake .section-inner {
    padding: 54px 0;
  }

  .service-entry-card {
    min-height: 260px;
    padding: 22px;
  }

  .service-entry-card__cta {
    padding: 9px 10px 9px 14px;
  }

  .consent-banner {
    left: 12px;
    bottom: 12px;
    width: calc(100% - 24px);
  }

  .consent-banner__inner {
    gap: 12px;
    padding: 14px;
  }

  .consent-banner h2 {
    font-size: 1rem;
  }

  .consent-banner p {
    font-size: 13px;
  }

  .consent-actions {
    gap: 8px;
  }

  .consent-button {
    flex: 1 1 132px;
    min-height: 38px;
    padding: 0 10px;
    font-size: 13px;
  }

  .consent-button.primary {
    flex-basis: 100%;
  }

  .consent-modal {
    padding: 12px;
  }

  .consent-modal__panel {
    max-height: calc(100dvh - 24px);
  }

  .consent-modal__content {
    padding: 20px;
  }

  .consent-option {
    grid-template-columns: 1fr;
  }

  .diagram-panel {
    min-height: 300px;
  }

  .page-hero-visual {
    min-height: 220px;
  }

  .values-visual {
    min-height: 260px;
  }

  .founder-profile {
    gap: 34px;
  }

  .founder-photo {
    min-height: 280px;
  }

  .founder-photo img {
    object-position: 50% 24%;
  }

  .values-visual__center {
    width: 104px;
    height: 104px;
    font-size: 14px;
  }

  .values-visual__chip {
    min-height: 36px;
    padding: 0 12px;
    font-size: 12px;
  }

  .values-visual__chip--a {
    top: 17%;
  }

  .values-visual__chip--b {
    left: 76%;
    top: 35%;
  }

  .values-visual__chip--c {
    left: 70%;
    top: 79%;
  }

  .values-visual__chip--d {
    left: 30%;
    top: 79%;
  }

  .values-visual__chip--e {
    left: 24%;
    top: 35%;
  }

  .operation-hero-visual span:nth-child(1),
  .operation-visual span:nth-child(1) {
    width: 72px;
    height: 72px;
  }

  .operation-hero-visual span:nth-child(2),
  .operation-visual span:nth-child(2) {
    width: 92px;
    height: 92px;
  }

  .operation-hero-visual span:nth-child(3),
  .operation-visual span:nth-child(3) {
    width: 64px;
    height: 64px;
  }

  .system-map {
    padding: 18px;
  }

  .map-node {
    min-height: 108px;
  }

  .map-path {
    display: none;
  }

  .modular-map {
    min-height: auto;
    padding: 22px;
  }

  .modular-map span {
    min-height: 46px;
    padding: 0 14px;
  }

  .summary-visual {
    min-height: 190px;
  }

  .schema--fragmented-to-system .chip-a {
    left: 26%;
    top: 34%;
  }

  .schema--fragmented-to-system .chip-b {
    left: 74%;
    top: 34%;
  }

  .schema--fragmented-to-system .chip-c {
    left: 26%;
    top: 68%;
  }

  .schema--fragmented-to-system .chip-d {
    left: 74%;
    top: 68%;
  }

  .schema--journey-map .node-a {
    left: 25%;
    top: 25%;
  }

  .schema--journey-map .node-b {
    left: 74%;
    top: 35%;
  }

  .schema--journey-map .node-c {
    left: 28%;
    top: 66%;
  }

  .schema--journey-map .node-d {
    left: 74%;
    top: 76%;
  }

  .schema--route-progress,
  .schema--decision-router,
  .schema--evidence-chain {
    min-height: 360px;
  }

  .schema--decision-router .schema__svg {
    display: none;
  }

  .schema--decision-router::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 30%;
    bottom: 12%;
    z-index: 1;
    width: 2px;
    background: rgba(19, 40, 75, 0.28);
    transform: translateX(-50%);
  }

  .schema--route-progress .step-a,
  .schema--evidence-chain .step-a {
    left: 26%;
    top: 20%;
  }

  .schema--route-progress .step-b {
    left: 74%;
    top: 38%;
  }

  .schema--route-progress .step-c {
    left: 26%;
    top: 58%;
  }

  .schema--route-progress .step-d {
    left: 74%;
    top: 78%;
  }

  .router-source {
    left: 50%;
    top: 18%;
    min-width: 96px;
    min-height: 96px;
  }

  .router-option.option-a {
    left: 50%;
    top: 45%;
  }

  .router-option.option-b {
    left: 50%;
    top: 63%;
  }

  .router-option.option-c {
    left: 50%;
    top: 81%;
  }

  .schema--modular-board .module-a {
    left: 30%;
    top: 34%;
  }

  .schema--modular-board .module-b {
    left: 70%;
    top: 36%;
  }

  .schema--modular-board .module-c {
    left: 33%;
    top: 57%;
  }

  .schema--modular-board .module-d {
    left: 72%;
    top: 60%;
  }

  .schema--modular-board .module-e {
    left: 50%;
    top: 78%;
  }

  .schema--evidence-chain .step-b {
    left: 74%;
    top: 50%;
  }

  .schema--evidence-chain .step-c {
    left: 50%;
    top: 80%;
  }

  .route-item {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 16px;
    padding: 20px 0;
  }

  .route-list::before {
    left: 20px;
    top: 16px;
    bottom: 16px;
  }

  .route-item::after {
    left: 58px;
  }

  .route-item .num {
    width: 42px;
    height: 42px;
    font-size: 0.92rem;
  }

  .route-item .text-link {
    grid-column: 2;
    justify-self: start;
    margin-top: 2px;
  }

  .process-step {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 16px;
    padding: 20px 0;
  }

  .process::before {
    left: 20px;
    top: 16px;
    bottom: 16px;
  }

  .process-step::after {
    left: 58px;
  }

  .process-step::before {
    width: 42px;
    height: 42px;
    font-size: 1.25rem;
  }

  .footer-inner {
    grid-template-columns: 1fr;
  }

  .proof-layout,
  .proof-method {
    grid-template-columns: 1fr;
  }

  .page-aside.hero-evidence {
    padding: 20px;
  }

  .field-label {
    align-items: flex-start;
    flex-direction: column;
    gap: 3px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }

  .hero-copy > *,
  .process-step,
  .route-item,
  .scrolly__panel,
  .signal,
  .priority-card,
  .capture-node,
  .capture-result,
  .operation-node,
  .schema__node,
  .schema__chip,
  .schema__step,
  .router-source,
  .router-option,
  .schema__module,
  .schema__flag,
  .schema__drop,
  .schema__dot,
  .schema__bubble,
  .schema__result,
  .schema__core,
  .diamond,
  .system-line {
    opacity: 1 !important;
    transform: none !important;
  }

  .capture-line::after {
    width: 100% !important;
  }

  .schema__node,
  .schema__chip,
  .schema__step,
  .router-source,
  .router-option,
  .schema__module,
  .schema__flag,
  .schema__drop,
  .schema__dot,
  .schema__bubble,
  .schema__result,
  .schema__core {
    transform: translate(-50%, -50%) scale(1) !important;
  }

  .schema__path,
  .schema__scan-line {
    opacity: 1 !important;
    stroke-dashoffset: 0 !important;
  }

  .diamond {
    transform: rotate(45deg) scale(1) !important;
  }

  .system-line {
    transform: rotate(var(--line-rotate)) scaleX(1) !important;
  }
}
