/* ─────────────────────────────────────────────────────────────────────────
   Lateral Space — Site components
   Page-specific layouts and components, built on brand.css tokens.
   ───────────────────────────────────────────────────────────────────────── */

/* ════════════════════════════════════════════════════════════════════════
   NAV
   ════════════════════════════════════════════════════════════════════════ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  padding: 18px 0;
  transition: padding 0.4s var(--ease-out), background 0.4s var(--ease-out), backdrop-filter 0.4s var(--ease-out), border-color 0.4s var(--ease-out);
  border-bottom: 1px solid transparent;
}
.nav.is-stuck {
  padding: 12px 0;
  background: rgba(242,238,229,0.72);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  backdrop-filter: blur(20px) saturate(1.4);
  border-bottom-color: rgba(19,18,14,0.08);
}
.nav-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 36px;
}
.nav-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
}
.nav-brand .ls-wordmark { font-size: 17px; }
.nav-brand .ls-mark svg { transition: transform 0.6s var(--ease-out); }
.nav-brand:hover .ls-mark svg { transform: translateX(3px); }

.nav-links {
  display: flex;
  gap: 4px;
  justify-self: center;
}
.nav-link {
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 14px;
  color: var(--graphite);
  transition: color 0.3s var(--ease-out), background 0.3s var(--ease-out);
}
.nav-link:hover { color: var(--ink); background: rgba(19,18,14,0.04); }
.nav-link.active { color: var(--ink); }
.nav-link.active::after {
  content: "";
  display: block;
  width: 18px;
  height: 1px;
  margin: 4px auto 0;
  background: var(--signal-deep);
}

.nav-end {
  display: flex;
  align-items: center;
  gap: 14px;
}

.lang-toggle {
  display: inline-flex;
  border: 1px solid rgba(19,18,14,0.12);
  border-radius: 999px;
  padding: 3px;
  background: rgba(255,255,255,0.4);
  position: relative;
}
.lang-toggle button {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  color: var(--graphite-2);
  z-index: 1;
  transition: color 0.3s var(--ease-out);
}
.lang-toggle button.active { color: var(--ink); }
.lang-thumb {
  position: absolute;
  top: 3px;
  bottom: 3px;
  background: var(--bone);
  border-radius: 999px;
  transition: transform 0.5s var(--ease-out), width 0.5s var(--ease-out);
  z-index: 0;
  border: 1px solid rgba(19,18,14,0.06);
}

.nav-cta { padding: 9px 16px; font-size: 13px; }

.nav-menu-btn {
  display: none;
  width: 40px; height: 40px;
  border-radius: 999px;
  align-items: center; justify-content: center;
  border: 1px solid rgba(19,18,14,0.14);
}
.nav-menu-btn svg { width: 16px; height: 16px; }

/* Mobile nav */
@media (max-width: 880px) {
  .nav-links { display: none; }
  .nav-end .lang-toggle { display: none; }
  .nav-menu-btn { display: inline-flex; }
  .nav-cta { display: none; }
  .nav-inner { grid-template-columns: auto 1fr auto; gap: 16px; }
}

.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--bone);
  z-index: 49;
  padding: 96px var(--shell-pad) 48px;
  display: none;
  flex-direction: column;
  gap: 8px;
  transform: translateY(-12px);
  opacity: 0;
  transition: transform 0.5s var(--ease-out), opacity 0.5s var(--ease-out);
  overflow-y: auto;
}
.mobile-menu.open {
  display: flex;
  transform: translateY(0);
  opacity: 1;
}
.mobile-menu a {
  display: block;
  padding: 18px 0;
  border-bottom: 1px solid rgba(19,18,14,0.08);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.mobile-menu .mobile-cta {
  margin-top: 24px;
  padding: 16px 24px;
  width: fit-content;
}
.mobile-menu .mobile-lang {
  margin-top: 24px;
}

/* ════════════════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 140px 0 96px;
  overflow: hidden;
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-bg .tactile { position: absolute; inset: 0; }
.hero-bg-lines {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.85;
}
.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 980px) {
  .hero-inner { grid-template-columns: 1fr; gap: 48px; }
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 6px 14px 6px 6px;
  border-radius: 999px;
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(19,18,14,0.08);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--ink);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.hero-eyebrow .signal-dot { margin-right: 4px; }
.hero h1 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(52px, 7vw, 104px);
  line-height: 0.94;
  letter-spacing: -0.045em;
  margin: 28px 0 28px;
  color: var(--ink);
  text-wrap: balance;
}
.hero h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--graphite);
  letter-spacing: -0.015em;
}
.hero-sub {
  font-size: clamp(17px, 1.5vw, 22px);
  line-height: 1.5;
  color: var(--ink);
  max-width: 56ch;
  margin: 0 0 36px;
  text-wrap: pretty;
}
.hero-sub strong { font-weight: 500; }
.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.hero-card {
  position: relative;
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(19,18,14,0.08);
  padding: 28px;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
}
.hero-card-row {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid rgba(19,18,14,0.08);
  align-items: flex-start;
}
.hero-card-row:first-of-type { border-top: 0; padding-top: 0; }
.hero-card-row-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--graphite-2);
  padding-top: 4px;
}
.hero-card-row-title { font-weight: 500; color: var(--ink); }
.hero-card-row-body { font-size: 14px; color: var(--graphite); line-height: 1.55; margin-top: 4px; }

.scroll-hint {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
  margin-top: 64px;
}
.scroll-hint::after {
  content: "";
  display: block;
  width: 48px; height: 1px;
  background: linear-gradient(to right, var(--graphite-2), transparent);
}

/* Animated lateral lines (the brand graphic — offset planes) */
.lateral-lines line {
  stroke: rgba(19,18,14,0.14);
  stroke-width: 1;
}
.lateral-lines line.accent {
  stroke: rgba(94,106,83,0.6);
  stroke-width: 1.2;
}

/* ════════════════════════════════════════════════════════════════════════
   AUDIENCE — dual-track CTA
   ════════════════════════════════════════════════════════════════════════ */
.audience {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 880px) {
  .audience { grid-template-columns: 1fr; }
}
.audience-side {
  background: var(--bone);
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  transition: background 0.4s var(--ease-out);
}
.audience-side:hover { background: var(--bone-2); }
.audience-side .eyebrow { color: var(--signal-deep); }
.audience-side h3 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(24px, 2.6vw, 32px);
  line-height: 1.12;
  letter-spacing: -0.025em;
  margin: 0;
}
.audience-side h3 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--graphite); }
.audience-side p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--graphite);
  margin: 0;
  max-width: 46ch;
}
.audience-list {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 8px;
}
.audience-list li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.5;
  color: var(--graphite);
}
.audience-list li::before {
  content: "";
  display: block;
  width: 8px; height: 8px;
  margin-top: 7px;
  background: var(--signal-deep);
  border-radius: 1px;
}
.audience-side a.btn { margin-top: 12px; align-self: flex-start; }

/* ════════════════════════════════════════════════════════════════════════
   PROBLEM — the open loops
   ════════════════════════════════════════════════════════════════════════ */
.problem-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 880px) { .problem-grid { grid-template-columns: 1fr; } }
.problem-cell {
  background: var(--bone);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 200px;
}
.problem-cell-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.problem-cell-title {
  font-weight: 500;
  font-size: 20px;
  letter-spacing: -0.015em;
}
.problem-cell-body { font-size: 14px; color: var(--graphite); line-height: 1.55; }

.org-diagram {
  margin: 48px 0 0;
  padding: 28px;
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  background: var(--bone-soft);
  overflow: hidden;
}
.org-tier { display: flex; justify-content: center; align-items: center; }
.org-leader {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 28px;
  border: 1px solid rgba(19,18,14,0.18);
  border-radius: var(--radius);
  background: var(--bone);
}
.org-leader-label { font-weight: 500; }
.org-leader-sub { font-size: 12px; color: var(--graphite-2); margin-top: 4px; }
.org-connector {
  width: 1px;
  height: 36px;
  background: rgba(19,18,14,0.20);
  margin: 0 auto;
}
.org-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 8px;
}
@media (max-width: 880px) {
  .org-row { grid-template-columns: repeat(2, 1fr); }
}
.org-team {
  background: var(--bone);
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius);
  padding: 16px;
}
.org-team-name {
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 4px;
}
.org-team-role { font-size: 11px; color: var(--graphite-2); }
.org-tools {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 12px;
}
.org-tool {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(19,18,14,0.04);
  color: var(--graphite-2);
}
.org-flag-row {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-top: 28px;
  justify-content: center;
}
.org-flag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(19,18,14,0.14);
  background: var(--bone);
  color: var(--graphite-2);
}
.org-flag.accent {
  color: var(--amber-deep);
  border-color: rgba(154,116,64,0.30);
  background: rgba(216,178,122,0.10);
}

/* ════════════════════════════════════════════════════════════════════════
   AI SHIFT — before / after
   ════════════════════════════════════════════════════════════════════════ */
.shift-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 880px) { .shift-grid { grid-template-columns: 1fr; } }
.shift-side {
  background: var(--bone);
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.shift-side.after { background: var(--bone-2); }
.shift-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.shift-side.after .shift-label { color: var(--signal-deep); }
.shift-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.1;
  letter-spacing: -0.025em;
}
.shift-list {
  display: flex; flex-direction: column; gap: 10px;
  margin-top: 8px;
}
.shift-list li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.55;
  color: var(--graphite);
}
.shift-list li::before {
  content: "";
  display: block;
  width: 8px; height: 1px;
  margin-top: 11px;
  background: var(--graphite-3);
}
.shift-side.after .shift-list li::before {
  background: var(--signal-deep);
  width: 12px;
}

/* ════════════════════════════════════════════════════════════════════════
   BRAIN — 8 regions
   ════════════════════════════════════════════════════════════════════════ */
.brain-section { position: relative; }
.brain-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 1024px) { .brain-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .brain-grid { grid-template-columns: 1fr; } }

.brain-cell {
  background: var(--bone);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 230px;
  text-align: left;
  transition: background 0.4s var(--ease-out);
  position: relative;
  overflow: hidden;
}
.brain-cell:hover { background: var(--bone-2); }
.brain-cell-icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(19,18,14,0.18);
  border-radius: 50%;
  font-size: 17px;
  color: var(--ink);
}
.brain-cell-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.brain-cell-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.02em;
  margin-top: -4px;
}
.brain-cell-line { font-size: 14px; line-height: 1.5; color: var(--graphite); }
.brain-cell-arrow {
  position: absolute;
  bottom: 22px;
  right: 22px;
  color: var(--graphite-2);
  transition: transform 0.4s var(--ease-out), color 0.3s var(--ease-out);
}
.brain-cell:hover .brain-cell-arrow {
  transform: translate(3px, -3px);
  color: var(--signal-deep);
}

/* ════════════════════════════════════════════════════════════════════════
   BODY — 9 departments × the loop with the brain
   ════════════════════════════════════════════════════════════════════════ */

/* Loop legend — explains the visual grammar that recurs in every card */
.loop-legend {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin: 0 auto 28px;
  padding: 8px 18px;
  border-radius: 999px;
  border: 1px solid rgba(19,18,14,0.10);
  background: var(--bone-soft);
  position: relative;
}
.loop-legend-step {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graphite);
}
.loop-legend-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--ink);
}
.loop-legend-dot.signal { background: var(--signal-deep); }
.loop-legend-rule {
  width: 22px; height: 1px;
  background: rgba(19,18,14,0.30);
}
.loop-legend-return {
  margin-left: 8px;
  color: var(--signal-deep);
  font-size: 14px;
  animation: signal-pulse 3.2s var(--ease-in-out) infinite;
}
.body-grid + .loop-legend,
.section-head + .loop-legend {
  display: inline-flex;
}
.section-head + .loop-legend {
  display: inline-flex;
  margin: -16px auto 36px;
}

.body-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 980px) { .body-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .body-grid { grid-template-columns: 1fr; } }

.dept-cell {
  background: var(--bone);
  padding: 28px 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 340px;
  text-align: left;
  position: relative;
  transition: background 0.4s var(--ease-out);
}
.dept-cell:hover { background: var(--bone-soft); }
.dept-cell:hover .dept-loop-accent { stroke-opacity: 1; }
.dept-cell:hover .dept-loop-dot.signal { transform: scale(1.18); }

.dept-cell-head {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  align-items: flex-start;
}
.dept-cell-head-text { padding-top: 2px; }
.dept-icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(19,18,14,0.20);
  border-radius: 50%;
  font-size: 17px;
  color: var(--ink);
  background: var(--bone-soft);
  transition: border-color 0.4s var(--ease-out), color 0.4s var(--ease-out);
}
.dept-cell:hover .dept-icon { border-color: var(--signal-deep); color: var(--signal-deep); }
.dept-tag {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
  margin-bottom: 2px;
}
.dept-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.025em;
  line-height: 1.1;
}
.dept-line {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 17px;
  line-height: 1.4;
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.01em;
}

/* Applicazioni — mono small list with dot bullets */
.dept-apps {
  margin-top: 6px;
}
.dept-apps-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graphite-2);
  margin-bottom: 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.dept-apps-label::before {
  content: "";
  display: inline-block;
  width: 14px; height: 1px;
  background: var(--graphite-2);
  opacity: 0.55;
}
.dept-apps ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column;
  gap: 6px;
}
.dept-apps li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 8px;
  align-items: baseline;
  font-size: 13px;
  line-height: 1.45;
  color: var(--graphite);
}
.dept-apps li::before {
  content: "";
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--graphite-3);
  margin-left: 4px;
  transition: background 0.4s var(--ease-out);
}
.dept-cell:hover .dept-apps li::before { background: var(--signal-deep); }

/* The loop graphic — brand-inspired: two offset strokes + moss signal dot + return arc */
.dept-loop {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid rgba(19,18,14,0.08);
}
.dept-loop svg {
  width: 100%;
  height: auto;
  display: block;
}
.dept-loop-stroke {
  stroke: rgba(19,18,14,0.18);
  stroke-width: 1.2;
  fill: none;
  stroke-linecap: square;
  transition: stroke 0.4s var(--ease-out), stroke-opacity 0.4s var(--ease-out);
}
.dept-loop-accent {
  stroke: var(--signal-deep);
  stroke-width: 1.4;
  fill: none;
  stroke-opacity: 0.85;
  transition: stroke-opacity 0.4s var(--ease-out);
}
.dept-loop-return {
  stroke: rgba(19,18,14,0.20);
  stroke-width: 1;
  fill: none;
  stroke-dasharray: 2 4;
}
.dept-loop-dot {
  fill: var(--ink);
  transition: transform 0.4s var(--ease-out);
  transform-origin: center;
  transform-box: fill-box;
}
.dept-loop-dot.signal {
  fill: var(--signal-deep);
}
.dept-loop-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graphite-2);
}
.dept-loop-labels .signal { color: var(--signal-deep); }

/* Pulse on the moss signal dot — slow brand-pulse */
@keyframes dept-loop-pulse {
  0%, 100% { opacity: 0.55; r: 3; }
  50%      { opacity: 1; r: 4.2; }
}
.dept-loop-dot.signal {
  animation: dept-loop-pulse 3.4s var(--ease-in-out) infinite;
}

/* Legacy KPI styles — hidden if any markup still uses them */
.dept-kpi { display: none; }

/* ════════════════════════════════════════════════════════════════════════
   PILLAR icons — brand iconography (24/1.4/round) on home pillars
   ════════════════════════════════════════════════════════════════════════ */
.pillar { position: relative; }
.pillar-icon {
  display: inline-flex;
  width: 44px; height: 44px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(19,18,14,0.18);
  border-radius: 50%;
  color: var(--ink);
  background: var(--bone-soft);
  margin-bottom: 4px;
  transition: border-color 0.4s var(--ease-out), color 0.4s var(--ease-out), background 0.4s var(--ease-out), transform 0.4s var(--ease-out);
}
.pillar-icon svg {
  width: 22px; height: 22px;
}
.pillar:hover .pillar-icon {
  border-color: var(--signal-deep);
  color: var(--signal-deep);
  background: rgba(94,106,83,0.06);
  transform: translateX(2px);
}

/* ════════════════════════════════════════════════════════════════════════
   SECTION ACCENTS — brand pattern systems used as subtle backdrops
   so sections stop feeling flat. Three variants below.
   ════════════════════════════════════════════════════════════════════════ */
.section-accent {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

/* Chladni standing-wave field — bleeds in from the right edge */
.section-accent-chladni {
  top: 10%;
  right: -8%;
  width: min(520px, 42vw);
  height: min(520px, 42vw);
  opacity: 0.18;
  mask-image: radial-gradient(closest-side, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(closest-side, #000 30%, transparent 80%);
}
.section-accent-chladni svg {
  width: 100%; height: 100%;
}

/* Lateral-rain pattern — vertical signature stripes fading from the left */
.section-accent-rain {
  top: 0;
  left: -4%;
  bottom: 0;
  width: min(360px, 26vw);
  opacity: 0.42;
  mask-image: linear-gradient(to right, #000 0%, #000 40%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, #000 0%, #000 40%, transparent 100%);
}
.section-accent-rain svg {
  width: 100%; height: 100%;
}

/* Signal-field — fine dot mesh, for dark sections */
.section-accent-field {
  inset: 0;
  opacity: 0.20;
  mix-blend-mode: screen;
}

/* ════════════════════════════════════════════════════════════════════════
   AUDIENCE PATHS — tactile gradient backdrop per path (moss vs amber)
   ════════════════════════════════════════════════════════════════════════ */
.audience-side {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.audience-tactile {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.10;
  pointer-events: none;
}
.audience-side > *:not(.audience-tactile) { position: relative; z-index: 1; }
.audience-side:hover .audience-tactile { opacity: 0.18; transition: opacity 0.6s var(--ease-out); }

/* Path-01 / Path-02 small accent dot on the eyebrow */
.audience-side.path-01 .eyebrow::after {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--signal-deep);
  margin-left: 4px;
}
.audience-side.path-02 .eyebrow::after {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--amber-deep);
  margin-left: 4px;
}

/* ════════════════════════════════════════════════════════════════════════
   COOKIE BANNER — minimal, brand-aligned, dismissable
   ════════════════════════════════════════════════════════════════════════ */
.cookie-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  max-width: 560px;
  margin: 0 auto;
  background: var(--ink);
  color: var(--bone);
  border-radius: var(--radius-lg);
  padding: 18px 22px;
  display: none;
  align-items: center;
  gap: 16px;
  z-index: 60;
  box-shadow: 0 20px 60px -20px rgba(19,18,14,0.45);
  transform: translateY(20px);
  opacity: 0;
  transition: transform 0.5s var(--ease-out), opacity 0.5s var(--ease-out);
  flex-wrap: wrap;
}
.cookie-banner.visible {
  display: flex;
  transform: translateY(0);
  opacity: 1;
}
.cookie-banner-text {
  flex: 1;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(242,238,229,0.85);
  min-width: 240px;
}
.cookie-banner-text a {
  color: var(--signal);
  text-decoration: underline;
  text-decoration-color: rgba(168,176,147,0.36);
  text-underline-offset: 3px;
}
.cookie-banner-actions {
  display: inline-flex;
  gap: 8px;
}
.cookie-banner .btn {
  padding: 9px 14px;
  font-size: 12px;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.cookie-banner .btn-bone {
  background: var(--bone);
  color: var(--ink);
}
.cookie-banner .btn-bone:hover { background: var(--bone-3); }
.cookie-banner .btn-ghost-dark {
  background: transparent;
  color: var(--bone);
  border: 1px solid rgba(242,238,229,0.20);
}
.cookie-banner .btn-ghost-dark:hover { background: rgba(242,238,229,0.06); border-color: rgba(242,238,229,0.36); }

/* ════════════════════════════════════════════════════════════════════════
   LEGAL PAGES — Privacy + Cookie
   ════════════════════════════════════════════════════════════════════════ */
.legal-shell {
  max-width: 760px;
  margin: 0 auto;
  padding: 140px var(--shell-pad) 80px;
}
.legal-shell .eyebrow { margin-bottom: 16px; }
.legal-shell h1 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 56px);
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin: 0 0 16px;
}
.legal-shell h1 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--graphite); }
.legal-shell .legal-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
  margin: 0 0 48px;
}
.legal-shell h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(20px, 2.4vw, 24px);
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin: 56px 0 16px;
  padding-top: 24px;
  border-top: 1px solid rgba(19,18,14,0.10);
}
.legal-shell h2:first-of-type { padding-top: 0; border-top: none; margin-top: 0; }
.legal-shell h3 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: -0.015em;
  margin: 28px 0 10px;
  color: var(--ink);
}
.legal-shell p, .legal-shell ul, .legal-shell ol {
  font-size: 15px;
  line-height: 1.65;
  color: var(--graphite);
  margin: 0 0 14px;
}
.legal-shell ul, .legal-shell ol {
  padding-left: 22px;
}
.legal-shell li { margin-bottom: 8px; }
.legal-shell strong { color: var(--ink); font-weight: 500; }
.legal-shell a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: rgba(19,18,14,0.24);
  text-underline-offset: 3px;
}
.legal-shell a:hover { text-decoration-color: var(--signal-deep); }
.legal-shell .legal-block {
  padding: 22px 24px;
  background: var(--bone-soft);
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius);
  margin: 14px 0 24px;
}
.legal-shell .legal-block dt {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graphite-2);
  margin-bottom: 4px;
}
.legal-shell .legal-block dd { margin: 0 0 14px; font-size: 15px; color: var(--ink); }
.legal-shell .legal-block dd:last-child { margin-bottom: 0; }
.legal-shell table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0 28px;
  font-size: 13.5px;
}
.legal-shell table th,
.legal-shell table td {
  text-align: left;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(19,18,14,0.08);
  vertical-align: top;
}
.legal-shell table th {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graphite-2);
  font-weight: 400;
  background: var(--bone-soft);
}

/* ════════════════════════════════════════════════════════════════════════
   SENSORS — human signal quotes
   ════════════════════════════════════════════════════════════════════════ */
.sensors-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 720px) { .sensors-grid { grid-template-columns: 1fr; } }
.sensor-card {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  padding: 22px;
  border-radius: var(--radius);
  border: 1px solid rgba(19,18,14,0.10);
  background: var(--bone);
  text-align: left;
  transition: background 0.4s var(--ease-out), border-color 0.4s var(--ease-out), transform 0.4s var(--ease-out);
}
.sensor-card:hover {
  background: var(--bone-2);
  border-color: rgba(19,18,14,0.18);
  transform: translateY(-1px);
}
.sensor-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bone);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
}
.sensor-meta {
  font-size: 13px;
  font-weight: 500;
}
.sensor-role {
  color: var(--graphite-2);
  font-weight: 400;
  margin-left: 6px;
}
.sensor-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  line-height: 1.4;
  color: var(--ink);
  margin-top: 8px;
  letter-spacing: -0.01em;
}

/* ════════════════════════════════════════════════════════════════════════
   RHYTHM — day / night
   ════════════════════════════════════════════════════════════════════════ */
.rhythm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 880px) { .rhythm-grid { grid-template-columns: 1fr; } }
.rhythm-col {
  position: relative;
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 44px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 360px;
}
.rhythm-col.day { background: var(--bone-2); color: var(--ink); }
.rhythm-col.night {
  background: var(--ink);
  color: var(--bone);
}
.rhythm-col.night .lede { color: rgba(242,238,229,0.7); }
.rhythm-icon {
  font-size: 28px;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid currentColor;
  opacity: 0.7;
}
.rhythm-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 32px;
  letter-spacing: -0.025em;
}
.rhythm-line {
  font-size: 16px;
  line-height: 1.55;
  opacity: 0.85;
}
.rhythm-list {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid currentColor;
  opacity: 0.85;
}
.rhythm-list li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 10px;
  font-size: 14px;
  line-height: 1.5;
}
.rhythm-list li::before {
  content: "";
  display: block;
  width: 8px; height: 1px;
  margin-top: 11px;
  background: currentColor;
  opacity: 0.6;
}
.rhythm-col.night .lateral-rule { background: linear-gradient(to right, transparent, rgba(242,238,229,0.18), transparent); }

/* ════════════════════════════════════════════════════════════════════════
   FLOW — procurement example, 8 steps
   ════════════════════════════════════════════════════════════════════════ */
.flow-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid rgba(19,18,14,0.10);
}
.flow-step {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 28px;
  padding: 28px 0;
  border-bottom: 1px solid rgba(19,18,14,0.10);
  transition: background 0.3s var(--ease-out);
}
.flow-step:hover { background: rgba(19,18,14,0.015); }
@media (max-width: 720px) {
  .flow-step { grid-template-columns: 1fr; gap: 12px; }
}
.flow-marker {
  display: flex; align-items: baseline; gap: 14px;
  position: sticky;
  top: 96px;
  align-self: flex-start;
  height: fit-content;
}
.flow-marker-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--graphite-2);
}
.flow-marker-icon {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(19,18,14,0.18);
  font-size: 14px;
  color: var(--ink);
}
.flow-content { display: flex; flex-direction: column; gap: 10px; }
.flow-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal-deep);
}
.flow-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.flow-body {
  font-size: 15px;
  line-height: 1.6;
  color: var(--graphite);
  max-width: 64ch;
}
.flow-body em { font-family: var(--font-serif); font-style: italic; color: var(--ink); font-weight: 400; }
.flow-pills {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 4px;
}
.flow-pill {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(19,18,14,0.14);
  background: var(--bone);
  color: var(--graphite);
}
.flow-pill.brain { color: var(--signal-deep); border-color: rgba(94,106,83,0.3); }
.flow-pill.skill { color: var(--amber-deep); border-color: rgba(154,116,64,0.3); }
.flow-pill.agent { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.flow-pill.policy { background: rgba(94,106,83,0.10); border-color: rgba(94,106,83,0.18); color: var(--signal-deep); }
.flow-pill.person { background: rgba(19,18,14,0.04); }

/* ════════════════════════════════════════════════════════════════════════
   METABOLISM — stats
   ════════════════════════════════════════════════════════════════════════ */
.metab-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 32px;
}
@media (max-width: 880px) { .metab-stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .metab-stats { grid-template-columns: 1fr; } }
.metab-stat {
  background: var(--bone-2);
  border-radius: var(--radius-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 180px;
}
.metab-stat-icon {
  width: 28px; height: 28px;
  color: var(--signal-deep);
}
.metab-stat-icon svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.5; }
.metab-stat-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.metab-stat-value {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3vw, 38px);
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1;
}
.metab-stat-detail { font-size: 13px; line-height: 1.5; color: var(--graphite); margin-top: auto; }

.metab-optims {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 720px) { .metab-optims { grid-template-columns: 1fr; } }
.metab-optim {
  background: var(--bone);
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.metab-optim-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal-deep);
}
.metab-optim-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 20px;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.metab-optim-body { font-size: 14px; line-height: 1.55; color: var(--graphite); }
.metab-optim-metric {
  display: flex; align-items: baseline; gap: 10px;
  margin-top: 8px;
  padding-top: 16px;
  border-top: 1px solid rgba(19,18,14,0.08);
}
.metab-optim-metric-value {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.metab-optim-metric-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}

/* ════════════════════════════════════════════════════════════════════════
   PRINCIPLES — six manifesto principles
   ════════════════════════════════════════════════════════════════════════ */
.principles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 980px) { .principles { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .principles { grid-template-columns: 1fr; } }
.principle {
  background: var(--bone);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 260px;
}
.principle-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--graphite-2);
}
.principle-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
}
.principle-line { font-size: 14px; line-height: 1.6; color: var(--graphite); margin-top: auto; }

/* ════════════════════════════════════════════════════════════════════════
   TEAM
   ════════════════════════════════════════════════════════════════════════ */
.team-section {
  background: var(--bone-2);
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 960px) { .team-grid { grid-template-columns: 1fr; } }
.team-card {
  background: var(--bone);
  min-height: 520px;
  display: flex;
  flex-direction: column;
}
.team-photo {
  min-height: 280px;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(19,18,14,0.16), rgba(168,176,147,0.22)),
    radial-gradient(70% 60% at 50% 20%, rgba(242,238,229,0.74), transparent 68%),
    var(--bone-3);
  filter: blur(10px);
  transform: scale(1.04);
}
.team-photo::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 42%;
  width: 34%;
  aspect-ratio: 1;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: rgba(19,18,14,0.22);
}
.team-photo::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -18%;
  width: 68%;
  height: 52%;
  border-radius: 46% 46% 0 0;
  transform: translateX(-50%);
  background: rgba(19,18,14,0.18);
}
.photo-design {
  background:
    linear-gradient(135deg, rgba(216,178,122,0.22), rgba(19,18,14,0.14)),
    radial-gradient(70% 60% at 50% 20%, rgba(247,244,236,0.78), transparent 68%),
    var(--bone-3);
}
.photo-engineering {
  background:
    linear-gradient(135deg, rgba(94,106,83,0.24), rgba(19,18,14,0.14)),
    radial-gradient(70% 60% at 50% 20%, rgba(242,238,229,0.74), transparent 68%),
    var(--bone-3);
}
.team-card-body {
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.team-name {
  font-size: 24px;
  line-height: 1.1;
  letter-spacing: -0.025em;
  font-weight: 500;
}
.is-blurred {
  display: inline-block;
  color: transparent;
  text-shadow: 0 0 12px rgba(19,18,14,0.55);
  user-select: none;
}
.team-role {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal-deep);
}
.team-card p {
  margin: auto 0 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--graphite);
}
.team-note {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid rgba(19,18,14,0.10);
  color: var(--graphite);
  font-size: 15px;
  max-width: 58ch;
}

/* ════════════════════════════════════════════════════════════════════════
   CTA BAND
   ════════════════════════════════════════════════════════════════════════ */
.cta-band {
  position: relative;
  padding: clamp(72px, 10vw, 140px) 0;
  background: var(--ink);
  color: var(--bone);
  overflow: hidden;
}
.cta-band::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 40% at 78% 22%, rgba(168,176,147,0.32) 0%, transparent 60%),
    radial-gradient(40% 35% at 22% 78%, rgba(154,116,64,0.20) 0%, transparent 60%);
  pointer-events: none;
}
.cta-band .shell { position: relative; z-index: 1; }
.cta-band .h-headline { color: var(--bone); }
.cta-band .h-headline em { color: var(--signal); }
.cta-band .lede { color: rgba(242,238,229,0.72); }
.cta-band .btn-primary { background: var(--bone); color: var(--ink); }
.cta-band .btn-ghost { color: var(--bone); border-color: rgba(242,238,229,0.18); }
.cta-band .btn-ghost:hover { background: rgba(242,238,229,0.06); border-color: rgba(242,238,229,0.36); }
.cta-band .eyebrow { color: rgba(242,238,229,0.6); }

/* Mobile: stack the CTA band */
@media (max-width: 880px) {
  .cta-band .shell {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }
}

/* Hero CTA cluster on mobile */
@media (max-width: 980px) {
  .hero-ctas { flex-wrap: wrap; }
  .hero-card { padding: 22px; }
}

/* Stretch the lang toggle layout */
.mobile-menu .lang-toggle { width: fit-content; }

/* ════════════════════════════════════════════════════════════════════════
   PATTERN BACKGROUNDS — lateral rain · sliding planes · signal field
   Ported from brand-graphic.jsx. Used sparingly as section accents.
   ════════════════════════════════════════════════════════════════════════ */
.pattern-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.55;
}
.pattern-bg.fade-bottom {
  mask-image: linear-gradient(to bottom, #000 0%, #000 60%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 60%, transparent 100%);
}
.pattern-bg.fade-top {
  mask-image: linear-gradient(to top, #000 0%, #000 60%, transparent 100%);
  -webkit-mask-image: linear-gradient(to top, #000 0%, #000 60%, transparent 100%);
}

/* ════════════════════════════════════════════════════════════════════════
   BRAIN MAP — proper brain silhouette with 8 nodes + live connections
   ════════════════════════════════════════════════════════════════════════ */
.brain-stage {
  position: relative;
  border-radius: var(--radius-xl);
  background: var(--ink);
  color: var(--bone);
  padding: clamp(28px, 4vw, 56px);
  overflow: hidden;
  isolation: isolate;
}
.brain-stage::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(50% 50% at 30% 40%, rgba(168,176,147,0.16) 0%, transparent 60%),
    radial-gradient(40% 40% at 70% 60%, rgba(216,178,122,0.10) 0%, transparent 60%);
  pointer-events: none;
}
.brain-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.12 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
  opacity: 0.4;
  pointer-events: none;
}

.brain-map-wrap {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  justify-items: center;
  padding: 16px 0;
}
.brain-map {
  width: 100%;
  max-width: 860px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.brain-outline {
  fill: none;
  stroke: rgba(242,238,229,0.10);
  stroke-width: 1.2;
  stroke-dasharray: 2 7;
}
.brain-axis {
  fill: none;
  stroke: rgba(242,238,229,0.06);
  stroke-width: 1;
  stroke-dasharray: 2 6;
}
.brain-conn {
  fill: none;
  stroke: rgba(242,238,229,0.10);
  stroke-width: 1;
  transition: stroke 0.6s var(--ease-out), stroke-opacity 0.6s var(--ease-out);
}
.brain-conn.firing {
  stroke: var(--signal);
  stroke-width: 1.4;
}

.brain-node-g { cursor: pointer; }
.brain-node-circle {
  fill: rgba(20,19,15,0.5);
  stroke: rgba(242,238,229,0.18);
  stroke-width: 1.2;
  transition: stroke 0.4s var(--ease-out), fill 0.4s var(--ease-out);
}
.brain-node-g:hover .brain-node-circle,
.brain-node-g:focus-visible .brain-node-circle,
.brain-node-g.active .brain-node-circle {
  stroke: var(--signal);
  fill: rgba(94,106,83,0.18);
}
.brain-node-g[data-state="memory"] .brain-node-circle {
  stroke: var(--signal);
  fill: rgba(94,106,83,0.32);
  filter: drop-shadow(0 0 14px rgba(168,176,147,0.35));
}
.brain-node-g[data-state="processing"] .brain-node-circle {
  stroke: var(--bone);
  fill: rgba(242,238,229,0.12);
}
.brain-node-g[data-state="agents"] .brain-node-circle {
  stroke: var(--amber);
  fill: rgba(216,178,122,0.18);
  filter: drop-shadow(0 0 12px rgba(216,178,122,0.35));
}
.brain-node-g[data-state="settled"] .brain-node-circle {
  stroke: rgba(168,176,147,0.55);
  fill: rgba(94,106,83,0.08);
}

.brain-node-icon {
  font-family: var(--font-sans);
  font-size: 22px;
  fill: var(--bone);
  text-anchor: middle;
  dominant-baseline: middle;
  pointer-events: none;
}
.brain-node-label {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: -0.01em;
  fill: var(--bone);
  text-anchor: middle;
  pointer-events: none;
}
.brain-node-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  fill: rgba(242,238,229,0.5);
  text-anchor: middle;
  pointer-events: none;
}
.brain-pulse {
  fill: var(--signal);
}
.brain-pulse.amber { fill: var(--amber); }
.brain-pulse.bone  { fill: var(--bone); }

.brain-hint {
  text-align: center;
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}

/* Detail panel below the brain — shows region info on click */
.brain-detail {
  margin-top: clamp(28px, 4vw, 44px);
  padding: 28px 32px;
  border-radius: var(--radius-lg);
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.10);
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 32px;
  align-items: start;
  min-height: 180px;
  transition: opacity 0.4s var(--ease-out), transform 0.4s var(--ease-out);
}
@media (max-width: 720px) { .brain-detail { grid-template-columns: 1fr; gap: 16px; } }
.brain-detail-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal);
}
.brain-detail-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-top: 6px;
}
.brain-detail-body {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(242,238,229,0.78);
  max-width: 62ch;
}
.brain-detail-body strong { color: var(--bone); font-weight: 500; }
.brain-detail-body em { font-family: var(--font-serif); font-style: italic; color: var(--signal); font-weight: 400; }

/* ════════════════════════════════════════════════════════════════════════
   HOW IT WORKS — interactive process visualisation
   ════════════════════════════════════════════════════════════════════════ */
.hiw {
  position: relative;
  border-radius: var(--radius-xl);
  background: var(--ink);
  color: var(--bone);
  overflow: hidden;
  isolation: isolate;
}
.hiw::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 22% 25%, rgba(168,176,147,0.10) 0%, transparent 60%),
    radial-gradient(50% 40% at 80% 80%, rgba(216,178,122,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.hiw > * { position: relative; z-index: 1; }

.hiw-picker {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(242,238,229,0.08);
  border-bottom: 1px solid rgba(242,238,229,0.08);
}
@media (max-width: 720px) { .hiw-picker { grid-template-columns: 1fr; } }
.hiw-proc {
  background: rgba(20,19,15,0.6);
  padding: 22px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
  text-align: left;
  transition: background 0.4s var(--ease-out);
  cursor: pointer;
  border: none;
  color: var(--bone);
}
.hiw-proc:hover { background: rgba(28,27,22,0.85); }
.hiw-proc.active { background: rgba(94,106,83,0.16); border-bottom: 2px solid var(--signal); }
.hiw-proc-icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(242,238,229,0.18);
  font-size: 16px;
  flex-shrink: 0;
}
.hiw-proc.active .hiw-proc-icon { border-color: var(--signal); color: var(--signal); }
.hiw-proc-name { font-weight: 500; font-size: 15px; letter-spacing: -0.01em; }
.hiw-proc-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.6);
  margin-top: 2px;
}

.hiw-stage {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: 24px;
  padding: clamp(24px, 3vw, 36px);
  align-items: start;
}
@media (max-width: 1024px) { .hiw-stage { grid-template-columns: 1fr; } }

.hiw-side { display: flex; flex-direction: column; gap: 16px; }
.hiw-side-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}

.hiw-input-card {
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.12);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color 0.5s var(--ease-out), background 0.5s var(--ease-out);
}
.hiw-input-card.firing {
  border-color: var(--signal);
  background: rgba(94,106,83,0.10);
}
.hiw-input-head { display: flex; align-items: center; gap: 12px; }
.hiw-input-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--bone);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}
.hiw-input-avatar.signal { background: var(--signal); }
.hiw-input-avatar.brain {
  background: rgba(94,106,83,0.4);
  color: var(--signal);
  font-family: var(--font-sans);
  font-size: 16px;
}
.hiw-input-name { font-weight: 500; font-size: 14px; letter-spacing: -0.01em; }
.hiw-input-role { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(242,238,229,0.55); margin-top: 2px; }
.hiw-input-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.5;
  color: var(--bone);
  border-top: 1px solid rgba(242,238,229,0.08);
  padding-top: 12px;
  letter-spacing: -0.005em;
}
.hiw-autonomous-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(168,176,147,0.16);
  color: var(--signal);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.hiw-emotion {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  padding: 14px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.03);
  border: 1px solid rgba(242,238,229,0.08);
  align-items: center;
  --emo-color: rgba(242,238,229,0.4);
  --emo-glow: rgba(242,238,229,0.1);
  transition: border-color 0.5s var(--ease-out);
}
.hiw-emotion.active {
  border-color: var(--emo-color);
}
.hiw-emo-orb {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--emo-color);
  box-shadow: 0 0 18px var(--emo-glow);
  transition: background 0.6s var(--ease-out), box-shadow 0.6s var(--ease-out);
  animation: signal-pulse 3.4s var(--ease-in-out) infinite;
}
.hiw-emo-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}
.hiw-emo-name {
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--bone);
  margin-top: 2px;
}
.hiw-emo-meaning {
  font-size: 12px;
  color: rgba(242,238,229,0.6);
  line-height: 1.5;
  margin-top: 4px;
}

.hiw-brain-wrap {
  position: relative;
  background: rgba(20,19,15,0.5);
  border-radius: var(--radius-lg);
  padding: 18px;
  border: 1px solid rgba(242,238,229,0.08);
  min-height: 460px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hiw-brain-svg { width: 100%; height: auto; max-height: 480px; }
.hiw-brainwave {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.6s var(--ease-out);
}
.hiw-brainwave.active { opacity: 1; }
.hiw-wave-line {
  fill: none;
  stroke: var(--signal);
  stroke-width: 1;
  opacity: 0.6;
}
.hiw-brain-wrap.is-night { background: rgba(20,19,15,0.85); }

.hiw-output-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 200px;
}
.hiw-output-item {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.10);
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.5s var(--ease-out), transform 0.5s var(--ease-out);
}
.hiw-output-item.visible { opacity: 1; transform: translateX(0); }
.hiw-output-icon {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: rgba(94,106,83,0.30);
  color: var(--signal);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
}
.hiw-output-text { font-weight: 500; font-size: 13px; letter-spacing: -0.005em; color: var(--bone); }
.hiw-output-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
  margin-top: 2px;
}

.hiw-phase {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  padding: 14px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.03);
  border: 1px solid rgba(242,238,229,0.08);
  align-items: center;
}
.hiw-phase.is-night { background: rgba(94,106,83,0.10); border-color: rgba(168,176,147,0.20); }
.hiw-phase-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(242,238,229,0.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  color: var(--bone);
}
.hiw-phase.is-night .hiw-phase-icon { background: rgba(168,176,147,0.18); color: var(--signal); }
.hiw-phase-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(242,238,229,0.5); }
.hiw-phase-name { font-weight: 500; font-size: 14px; letter-spacing: -0.01em; margin-top: 2px; }
.hiw-phase-detail { font-size: 12px; color: rgba(242,238,229,0.6); margin-top: 2px; line-height: 1.5; }

/* Timeline */
.hiw-timeline {
  padding: 24px clamp(24px, 3vw, 36px);
  border-top: 1px solid rgba(242,238,229,0.08);
}
.hiw-timeline-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  gap: 16px;
  flex-wrap: wrap;
}
.hiw-step-counter {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.6);
}
.hiw-step-counter strong { color: var(--bone); font-weight: 500; }
.hiw-controls { display: flex; gap: 8px; }
.hiw-ctrl {
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(242,238,229,0.18);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--bone);
  background: transparent;
  transition: background 0.3s var(--ease-out), border-color 0.3s var(--ease-out);
}
.hiw-ctrl:hover { background: rgba(242,238,229,0.06); border-color: rgba(242,238,229,0.36); }
.hiw-ctrl.primary {
  background: var(--bone);
  color: var(--ink);
  border-color: var(--bone);
}
.hiw-ctrl.primary:hover { background: var(--bone-3); }

.hiw-progress {
  height: 2px;
  background: rgba(242,238,229,0.08);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 16px;
}
.hiw-progress-bar {
  height: 100%;
  width: 0%;
  background: var(--signal);
  transition: width 0.6s var(--ease-out);
}

.hiw-steps {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
}
@media (max-width: 1024px) { .hiw-steps { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 520px) { .hiw-steps { grid-template-columns: repeat(2, 1fr); } }
.hiw-step {
  padding: 12px 12px 14px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.03);
  border: 1px solid rgba(242,238,229,0.08);
  text-align: left;
  cursor: pointer;
  transition: background 0.3s var(--ease-out), border-color 0.3s var(--ease-out), transform 0.3s var(--ease-out);
}
.hiw-step:hover { background: rgba(242,238,229,0.06); }
.hiw-step.active {
  border-color: var(--signal);
  background: rgba(94,106,83,0.16);
  transform: translateY(-1px);
}
.hiw-step.done { background: rgba(94,106,83,0.06); border-color: rgba(94,106,83,0.24); }
.hiw-step-num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: rgba(242,238,229,0.45);
}
.hiw-step.active .hiw-step-num,
.hiw-step.done .hiw-step-num { color: var(--signal); }
.hiw-step-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
  margin-top: 4px;
}
.hiw-step-title {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--bone);
  margin-top: 4px;
  line-height: 1.3;
}

.hiw-step-detail {
  margin-top: 18px;
  padding: 18px 22px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.04);
  border-left: 2px solid var(--signal);
  font-size: 14px;
  line-height: 1.6;
  color: rgba(242,238,229,0.85);
}
.hiw-step-detail em { font-family: var(--font-serif); font-style: italic; color: var(--signal); font-weight: 400; }

/* Comparison */
.hiw-compare {
  margin-top: 0;
  padding: clamp(24px, 3vw, 40px) clamp(24px, 3vw, 36px);
  border-top: 1px solid rgba(242,238,229,0.08);
}
.hiw-compare-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 12px; }
.hiw-compare-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); text-transform: uppercase; color: rgba(242,238,229,0.5); }
.hiw-compare-title { font-family: var(--font-sans); font-weight: 500; font-size: clamp(20px, 2vw, 26px); letter-spacing: -0.02em; margin-top: 4px; }
.hiw-compare-sub { font-size: 13px; color: rgba(242,238,229,0.6); }
.hiw-compare-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 720px) { .hiw-compare-grid { grid-template-columns: 1fr; } }
.hiw-compare-col {
  padding: 22px;
  border-radius: var(--radius-lg);
  background: rgba(242,238,229,0.03);
  border: 1px solid rgba(242,238,229,0.08);
}
.hiw-compare-col.ai { background: rgba(94,106,83,0.12); border-color: rgba(168,176,147,0.30); }
.hiw-compare-col-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
}
.hiw-compare-col.ai .hiw-compare-col-tag { color: var(--signal); }
.hiw-compare-col-head {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: -0.015em;
  line-height: 1.3;
  margin-top: 8px;
  margin-bottom: 16px;
}
.hiw-compare-rows { display: flex; flex-direction: column; gap: 12px; }
.hiw-compare-row { display: grid; grid-template-columns: 96px 1fr; gap: 14px; padding-top: 10px; border-top: 1px solid rgba(242,238,229,0.06); font-size: 13px; line-height: 1.5; }
.hiw-compare-row-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: rgba(242,238,229,0.5); }
.hiw-compare-row-value { color: rgba(242,238,229,0.85); }
.hiw-compare-divider {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--signal);
  font-size: 22px;
  align-self: center;
}
@media (max-width: 720px) { .hiw-compare-divider { display: none; } }

.hiw-skill {
  margin: 24px clamp(24px, 3vw, 36px) clamp(24px, 3vw, 36px);
  padding: 22px;
  border-radius: var(--radius-lg);
  background: rgba(168,176,147,0.10);
  border: 1px solid rgba(168,176,147,0.28);
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 16px;
  align-items: start;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out);
}
.hiw-skill.visible { opacity: 1; transform: translateY(0); }
.hiw-skill-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(168,176,147,0.20);
  color: var(--signal);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.hiw-skill-tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); text-transform: uppercase; color: var(--signal); }
.hiw-skill-name { font-family: var(--font-sans); font-weight: 500; font-size: 18px; letter-spacing: -0.015em; margin-top: 4px; line-height: 1.3; }
.hiw-skill-detail { font-size: 13px; line-height: 1.6; color: rgba(242,238,229,0.75); margin-top: 6px; }
.hiw-skill-detail em { font-family: var(--font-serif); font-style: italic; color: var(--signal); font-weight: 400; }

/* Explainers */
.hiw-explainers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 40px;
}
@media (max-width: 880px) { .hiw-explainers { grid-template-columns: 1fr; } }
.hiw-explainer {
  padding: 28px;
  border-radius: var(--radius-lg);
  background: var(--bone-2);
  border: 1px solid rgba(19,18,14,0.10);
}
.hiw-explainer-tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); text-transform: uppercase; color: var(--signal-deep); }
.hiw-explainer-title { font-family: var(--font-sans); font-weight: 500; font-size: clamp(22px, 2.4vw, 28px); letter-spacing: -0.025em; line-height: 1.15; margin-top: 8px; margin-bottom: 16px; }
.hiw-explainer-body p { font-size: 14px; line-height: 1.7; color: var(--graphite); margin: 0 0 12px; }
.hiw-explainer-body em { font-family: var(--font-serif); font-style: italic; color: var(--ink); font-weight: 400; }
.hiw-emo-legend { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 16px; }
.hiw-emo-pill { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: 999px; background: var(--bone); border: 1px solid rgba(19,18,14,0.10); font-size: 12px; }
.hiw-emo-pill .dot { width: 8px; height: 8px; border-radius: 50%; }
.hiw-emo-pill .name { font-weight: 500; color: var(--ink); }
.hiw-emo-pill .line { color: var(--graphite-2); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.05em; text-transform: uppercase; }

/* ════════════════════════════════════════════════════════════════════════
   METABOLISM 24h CHART
   ════════════════════════════════════════════════════════════════════════ */
.metab-chart-wrap {
  margin: 32px 0;
  padding: 28px;
  border-radius: var(--radius-lg);
  background: var(--ink);
  color: var(--bone);
  position: relative;
  overflow: hidden;
}
.metab-chart-wrap::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(50% 50% at 18% 30%, rgba(168,176,147,0.12) 0%, transparent 60%);
  pointer-events: none;
}
.metab-chart-wrap > * { position: relative; z-index: 1; }
.metab-chart-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 18px;
}
.metab-chart-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); text-transform: uppercase; color: rgba(242,238,229,0.5); }
.metab-chart-title { font-family: var(--font-sans); font-weight: 500; font-size: clamp(20px, 2.4vw, 28px); letter-spacing: -0.025em; line-height: 1.2; margin-top: 4px; max-width: 36ch; }
.metab-chart-legend { display: flex; gap: 18px; flex-wrap: wrap; }
.metab-legend-item { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: rgba(242,238,229,0.65); }
.metab-legend-dot { width: 8px; height: 8px; border-radius: 50%; }

.metab-chart { width: 100%; height: auto; display: block; }
.metab-chart-axis-line { stroke: rgba(242,238,229,0.08); }
.metab-chart-axis-label { font-family: var(--font-mono); font-size: 10px; fill: rgba(242,238,229,0.5); text-anchor: middle; letter-spacing: 0.06em; }
.metab-chart-window-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; text-anchor: middle; fill: rgba(168,176,147,0.85); }
.metab-bar.op { fill: rgba(242,238,229,0.55); }
.metab-bar.consol { fill: var(--signal); }
.metab-bar.idle { fill: rgba(242,238,229,0.18); }
.metab-price-line { stroke: var(--amber); fill: none; stroke-width: 1.4; }
.metab-price-area { fill: rgba(216,178,122,0.10); }

/* ════════════════════════════════════════════════════════════════════════
   CHLADNI FIELD — section divider
   ════════════════════════════════════════════════════════════════════════ */
.chladni-divider {
  position: relative;
  padding: 80px 0;
  background: var(--bone);
  overflow: hidden;
}
.chladni-divider .chladni-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.45;
}
.chladni-divider .shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
@media (max-width: 880px) { .chladni-divider .shell { grid-template-columns: 1fr; } }
.chladni-divider h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3.6vw, 44px);
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin: 0;
}
.chladni-divider h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--graphite); }
.chladni-divider p { font-size: 15px; line-height: 1.6; color: var(--graphite); margin-top: 16px; max-width: 52ch; }

/* ════════════════════════════════════════════════════════════════════════
   KINETIC TYPOGRAPHY BAND — "futures" hero block
   ════════════════════════════════════════════════════════════════════════ */
.kinetic-band {
  position: relative;
  border-radius: var(--radius-xl);
  background: var(--ink);
  color: var(--bone);
  overflow: hidden;
  isolation: isolate;
  min-height: 420px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
}
@media (max-width: 880px) { .kinetic-band { grid-template-columns: 1fr; } }
.kinetic-band .kinetic-viz {
  position: relative;
  min-height: 340px;
}
.kinetic-band .kinetic-viz svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  font-family: var(--font-mono);
}
.kinetic-band .kinetic-tactile {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.kinetic-band .kinetic-tactile.deep {
  background:
    radial-gradient(55% 45% at 75% 22%, rgba(94,106,83,0.45) 0%, transparent 60%),
    radial-gradient(50% 40% at 20% 70%, rgba(154,116,64,0.40) 0%, transparent 60%),
    radial-gradient(40% 35% at 88% 82%, rgba(216,178,122,0.25) 0%, transparent 55%),
    #1A1813;
}
.kinetic-content {
  padding: clamp(28px, 4vw, 56px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
  position: relative;
  z-index: 1;
}
.kinetic-content .eyebrow { color: rgba(242,238,229,0.6); }
.kinetic-content h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin: 0;
}
.kinetic-content h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--signal); }
.kinetic-content p { font-size: 15px; line-height: 1.6; color: rgba(242,238,229,0.78); max-width: 50ch; }

/* Y mark for futures band */
.ls-y-mark {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
}
.ls-y-mark svg { width: 24px; height: 24px; }

/* ════════════════════════════════════════════════════════════════════════
   TEAM SECTION (kept from existing index.html)
   ════════════════════════════════════════════════════════════════════════ */
.team-section { background: var(--bone); }
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.team-card {
  padding: 24px;
  background: var(--bone-2);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(19,18,14,0.08);
  min-height: 200px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.team-card-tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); text-transform: uppercase; color: var(--graphite-2); }
.team-card-name { font-family: var(--font-sans); font-weight: 500; font-size: 22px; letter-spacing: -0.02em; }
.team-card-role { font-size: 14px; color: var(--graphite); }
.team-card-line { font-size: 13px; line-height: 1.55; color: var(--graphite); margin-top: 6px; }

/* ════════════════════════════════════════════════════════════════════════
   Constructed-emotion color tokens (used by HIW explainer pills)
   ════════════════════════════════════════════════════════════════════════ */
.emo-calm        { background: var(--signal); }
.emo-vigilance   { background: var(--amber); }
.emo-urgency     { background: var(--amber-deep); }
.emo-anticipation{ background: var(--signal-deep); }


/* ════════════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════════════ */
.footer {
  padding: 72px 0 56px;
  border-top: 1px solid rgba(19,18,14,0.10);
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 36px;
  margin-bottom: 56px;
}
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-col h4 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
  margin: 0 0 16px;
  font-weight: 400;
}
.footer-col ul { display: flex; flex-direction: column; gap: 10px; }
.footer-col a { font-size: 14px; color: var(--ink); transition: color 0.3s var(--ease-out); }
.footer-col a:hover { color: var(--signal-deep); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-top: 32px;
  border-top: 1px solid rgba(19,18,14,0.08);
  flex-wrap: wrap;
  gap: 24px;
}
.footer-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--graphite);
  max-width: 460px;
  line-height: 1.3;
}
.footer-legal {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}

/* ════════════════════════════════════════════════════════════════════════
   MANIFESTO PAGE — editorial layout
   ════════════════════════════════════════════════════════════════════════ */
.manifesto-hero {
  padding: 180px 0 80px;
  position: relative;
  overflow: hidden;
}
.manifesto-hero .tactile {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.6;
}
.manifesto-hero .shell { position: relative; z-index: 1; }
.manifesto-text {
  margin: 56px 0;
  max-width: 820px;
}
.manifesto-text p {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.4;
  letter-spacing: -0.02em;
  color: var(--graphite);
  margin: 0 0 16px;
  text-wrap: pretty;
}
.manifesto-text p.lead {
  color: var(--ink);
  font-weight: 500;
}
.manifesto-text .ms-pause { display: block; height: 24px; }
.manifesto-text em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--ink);
  font-weight: 400;
}
.manifesto-signature {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--graphite);
  display: flex;
  align-items: center;
  gap: 16px;
}
.manifesto-signature::before {
  content: "—";
  font-style: normal;
  color: var(--graphite-2);
}

.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 880px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .values-grid { grid-template-columns: 1fr; } }
.value {
  background: var(--bone);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 200px;
}
.value-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--graphite-2);
}
.value-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 28px;
  letter-spacing: -0.025em;
}
.value-body { font-size: 14px; line-height: 1.55; color: var(--graphite); margin-top: auto; }

/* ════════════════════════════════════════════════════════════════════════
   APPROACH PAGE — two-track + brain dictionary
   ════════════════════════════════════════════════════════════════════════ */
.approach-paths {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 880px) { .approach-paths { grid-template-columns: 1fr; } }
.approach-path {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  padding: clamp(28px, 4vw, 44px);
  min-height: 520px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  background: var(--bone-2);
}
.approach-path.dark {
  background: var(--ink);
  color: var(--bone);
}
.approach-path .approach-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  opacity: 0.6;
}
.approach-path h3 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 40px);
  letter-spacing: -0.03em;
  line-height: 1.05;
}
.approach-path h3 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  opacity: 0.65;
}
.approach-path p { font-size: 16px; line-height: 1.55; opacity: 0.85; }
.approach-list { display: flex; flex-direction: column; gap: 14px; margin-top: 12px; }
.approach-list li {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 14px;
  align-items: flex-start;
}
.approach-list .approach-step-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--signal-deep);
  padding-top: 4px;
}
.approach-path.dark .approach-step-num { color: var(--signal); }
.approach-list .approach-step-title { font-weight: 500; font-size: 15px; }
.approach-list .approach-step-body { font-size: 13px; line-height: 1.5; opacity: 0.7; margin-top: 4px; }
.approach-path .btn { margin-top: auto; align-self: flex-start; }

/* ════════════════════════════════════════════════════════════════════════
   CONTACT FORM
   ════════════════════════════════════════════════════════════════════════ */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(36px, 6vw, 96px);
  align-items: start;
}
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-side h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 56px);
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin: 24px 0 24px;
}
.contact-side h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--graphite); }
.contact-side .lede { font-size: 17px; }
.contact-side-meta {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid rgba(19,18,14,0.10);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.contact-side-meta div { font-size: 14px; }
.contact-side-meta dt {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
  margin-bottom: 6px;
}
.contact-side-meta dd { color: var(--ink); margin: 0; }

.form {
  background: var(--bone-soft);
  border: 1px solid rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.form-row { display: grid; gap: 22px; }
.form-row.cols-2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 520px) { .form-row.cols-2 { grid-template-columns: 1fr; } }

.form-field { display: flex; flex-direction: column; gap: 8px; }
.form-field label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.form-field input,
.form-field textarea,
.form-field select {
  background: var(--bone);
  border: 1px solid rgba(19,18,14,0.14);
  border-radius: var(--radius);
  padding: 14px 16px;
  font-size: 15px;
  color: var(--ink);
  transition: border-color 0.3s var(--ease-out), background 0.3s var(--ease-out);
  width: 100%;
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
  outline: none;
  border-color: var(--ink);
  background: var(--bone-soft);
}
.form-field textarea { min-height: 140px; resize: vertical; }
.form-field input::placeholder,
.form-field textarea::placeholder { color: var(--graphite-3); }
.form-field select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M3 5l3 3 3-3' fill='none' stroke='%23514B41' stroke-width='1.4' stroke-linecap='square'/></svg>");
  background-repeat: no-repeat;
  background-position: right 18px center;
  padding-right: 40px;
}

.maturity-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 480px) { .maturity-grid { grid-template-columns: 1fr; } }
.maturity-option {
  position: relative;
  border: 1px solid rgba(19,18,14,0.14);
  border-radius: var(--radius);
  padding: 16px;
  cursor: pointer;
  transition: border-color 0.3s var(--ease-out), background 0.3s var(--ease-out);
  background: var(--bone);
}
.maturity-option:hover { border-color: rgba(19,18,14,0.36); }
.maturity-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.maturity-option .m-title {
  font-weight: 500;
  font-size: 14px;
  margin-bottom: 4px;
  display: flex; align-items: center; gap: 10px;
}
.maturity-option .m-title::before {
  content: "";
  width: 12px; height: 12px;
  border-radius: 50%;
  border: 1px solid rgba(19,18,14,0.30);
  flex-shrink: 0;
}
.maturity-option .m-body { font-size: 12px; color: var(--graphite); }
.maturity-option:has(input:checked) {
  border-color: var(--ink);
  background: var(--bone-2);
}
.maturity-option:has(input:checked) .m-title::before {
  background: var(--ink);
  border-color: var(--ink);
  box-shadow: inset 0 0 0 3px var(--bone-2);
}

.form-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.form-fine { font-size: 12px; color: var(--graphite-2); max-width: 36ch; }
.form-fine a { color: var(--ink); text-decoration: underline; text-decoration-color: rgba(19,18,14,0.20); text-underline-offset: 3px; }

.form-status {
  display: none;
  padding: 16px 18px;
  border-radius: var(--radius);
  font-size: 14px;
  line-height: 1.5;
  align-items: flex-start;
  gap: 12px;
}
.form-status.show { display: flex; }
.form-status.success { background: rgba(94,106,83,0.08); border: 1px solid rgba(94,106,83,0.22); color: var(--signal-deep); }
.form-status.error { background: rgba(154,116,64,0.08); border: 1px solid rgba(154,116,64,0.22); color: var(--amber-deep); }
.form-status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-top: 6px;
  background: currentColor;
  flex-shrink: 0;
}

.btn-submit { padding: 14px 26px; }
.btn-submit[disabled] { opacity: 0.6; cursor: progress; }

/* ════════════════════════════════════════════════════════════════════════
   PAGE-INNER PADDING for non-hero pages
   ════════════════════════════════════════════════════════════════════════ */
.page-header {
  padding: 140px 0 64px;
  position: relative;
  overflow: hidden;
}
.page-header .tactile {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.55;
}
.page-header .shell { position: relative; z-index: 1; }
.page-header h1 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(48px, 7vw, 92px);
  line-height: 0.96;
  letter-spacing: -0.045em;
  margin: 24px 0 24px;
  text-wrap: balance;
}
.page-header h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--graphite);
}

/* ════════════════════════════════════════════════════════════════════════
   STAT STRIP (used on multiple pages)
   ════════════════════════════════════════════════════════════════════════ */
.stat-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-top: 1px solid rgba(19,18,14,0.10);
  border-bottom: 1px solid rgba(19,18,14,0.10);
}
@media (max-width: 720px) { .stat-strip { grid-template-columns: repeat(2, 1fr); } }
.stat-cell {
  background: var(--bone);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.stat-cell .stat-value {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3vw, 40px);
  letter-spacing: -0.03em;
  line-height: 1;
}
.stat-cell .stat-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.stat-cell .stat-body { font-size: 13px; color: var(--graphite); margin-top: 8px; line-height: 1.5; }

/* ════════════════════════════════════════════════════════════════════════
   NUDGE — interactive secondary nav (e.g. on Approach page)
   ════════════════════════════════════════════════════════════════════════ */
.nudge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(94,106,83,0.10);
  border: 1px solid rgba(94,106,83,0.20);
  color: var(--signal-deep);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
}

/* ════════════════════════════════════════════════════════════════════════
   v2 — DEFENSIVE OVERRIDES & NEW COMPONENTS (signals-live, trust strip,
   brain stage, HIW, lateral mesh). All styles below are authoritative.
   ════════════════════════════════════════════════════════════════════════ */

/* Brand-aware eyebrow with leading dash, matches brand book */
.eyebrow-rule {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.eyebrow-rule::before {
  content: "";
  width: 28px;
  height: 1px;
  background: currentColor;
  opacity: 0.7;
}

/* ─── Hero refinements ─────────────────────────────────────────────────── */
.hero-eyebrow {
  background: rgba(255,255,255,0.6);
  border: 1px solid rgba(19,18,14,0.08);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

/* ─── SIGNALS · LIVE panel — hero right ─────────────────────────────────── */
.signals-live {
  position: relative;
  width: 100%;
  min-height: 460px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  isolation: isolate;
}
.signals-live-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 480px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  isolation: isolate;
  background: var(--bone-soft);
  border: 1px solid rgba(19,18,14,0.10);
  box-shadow: 0 24px 60px -32px rgba(19,18,14,0.14), 0 2px 8px rgba(19,18,14,0.04);
}
/* Lateral hairline grid — calm geometric backdrop, NO distortion */
.signals-live-grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(19,18,14,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19,18,14,0.04) 1px, transparent 1px);
  background-size: 28px 28px;
  background-position: -1px -1px;
  mask-image: linear-gradient(135deg, #000 30%, transparent 95%);
  -webkit-mask-image: linear-gradient(135deg, #000 30%, transparent 95%);
  pointer-events: none;
}
.signals-live-grid::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 18% 24%, rgba(168,176,147,0.16) 0%, transparent 60%),
    radial-gradient(50% 40% at 82% 80%, rgba(216,178,122,0.10) 0%, transparent 60%);
  pointer-events: none;
}

.signals-live-inner {
  position: relative;
  z-index: 2;
  padding: 28px 28px 22px;
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 480px;
}
.signals-live-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
  margin-bottom: 24px;
}
.signals-live-head-left {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.signals-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--signal-deep);
  animation: signal-pulse 2.4s var(--ease-in-out) infinite;
}
.signals-live-title { color: var(--ink); font-weight: 400; }
.signals-live-clock {
  color: var(--graphite);
  letter-spacing: 0.06em;
}

.signals-live-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.signal-row {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  background: transparent;
  animation: lateral-slide-in 0.6s var(--ease-out) both;
  transition: background 0.35s var(--ease-out), border-color 0.35s var(--ease-out);
}
.signal-row.accent {
  background: var(--bone);
  border-color: rgba(94,106,83,0.30);
  box-shadow: 0 6px 18px -8px rgba(19,18,14,0.08);
}

/* Tag dots — color follows the brain concept */
.signal-row-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--graphite-3);
  flex-shrink: 0;
}
.signal-row-dot[data-tag="signal"] { background: var(--signal-deep); }
.signal-row-dot[data-tag="memory"] { background: var(--ink); }
.signal-row-dot[data-tag="agent"]  { background: var(--amber-deep); }
.signal-row-dot[data-tag="skill"]  { background: var(--signal); }
.signal-row.accent .signal-row-dot {
  animation: signal-pulse 2.4s var(--ease-in-out) infinite;
}

.signal-row-text {
  font-size: 13px;
  line-height: 1.45;
  color: var(--ink);
  letter-spacing: -0.005em;
}

.signal-row-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(19,18,14,0.04);
  color: var(--graphite-2);
  border: 1px solid rgba(19,18,14,0.06);
}
.signal-row-tag[data-tag="signal"] {
  color: var(--signal-deep);
  background: rgba(94,106,83,0.10);
  border-color: rgba(94,106,83,0.22);
}
.signal-row-tag[data-tag="memory"] {
  color: var(--ink);
  background: rgba(19,18,14,0.06);
  border-color: rgba(19,18,14,0.14);
}
.signal-row-tag[data-tag="agent"] {
  color: var(--amber-deep);
  background: rgba(216,178,122,0.14);
  border-color: rgba(154,116,64,0.26);
}
.signal-row-tag[data-tag="skill"] {
  color: var(--signal-deep);
  background: rgba(168,176,147,0.18);
  border-color: rgba(94,106,83,0.26);
}

.signals-live-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 14px;
  margin-top: 14px;
  border-top: 1px solid rgba(19,18,14,0.10);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--graphite-2);
}
.signals-live-foot-stats {
  display: inline-flex;
  align-items: center;
  gap: 18px;
}
.signals-live-foot-stats strong {
  color: var(--ink);
  font-weight: 500;
  font-family: var(--font-sans);
  letter-spacing: 0;
  margin-right: 4px;
}
.signals-live-foot-side { color: var(--signal-deep); }

/* Hide the now-unused legacy classes */
.signals-live-tactile,
.signals-live-chladni { display: none; }
.signal-dot-row { display: none; }
/* Trust band removed — hide the legacy markup if any page still has it */
.trust-band { display: none !important; }

/* ─── PILLARS — 3 statements grid (home positioning) ────────────────────── */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-top: 1px solid rgba(19,18,14,0.10);
  border-bottom: 1px solid rgba(19,18,14,0.10);
  margin-top: 48px;
}
@media (max-width: 880px) {
  .pillars { grid-template-columns: 1fr; }
}
.pillar {
  background: var(--bone);
  padding: clamp(32px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 240px;
  position: relative;
  transition: background 0.4s var(--ease-out);
}
.pillar:hover { background: var(--bone-soft); }
.pillar-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal-deep);
}
.pillar-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 0;
  color: var(--ink);
}
.pillar-title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--graphite);
}
.pillar-body {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--graphite);
  margin-top: auto;
}

/* ─── BRAIN TEASER — 8-region preview + CTA to /brain.html ─────────────── */
.brain-teaser-section { padding-top: clamp(80px, 10vw, 120px); padding-bottom: clamp(80px, 10vw, 120px); }

.brain-teaser {
  position: relative;
  border-radius: var(--radius-xl);
  background: #14130F;
  color: #F2EEE5;
  overflow: hidden;
  isolation: isolate;
  margin-top: 48px;
}
.brain-teaser-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 40% at 18% 25%, rgba(168,176,147,0.16) 0%, transparent 60%),
    radial-gradient(40% 35% at 82% 80%, rgba(216,178,122,0.10) 0%, transparent 60%);
  pointer-events: none;
}
.brain-teaser::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.10 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
  opacity: 0.32;
  pointer-events: none;
}
.brain-teaser-inner {
  position: relative; z-index: 1;
  padding: clamp(32px, 5vw, 56px);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}
@media (max-width: 880px) {
  .brain-teaser-inner { grid-template-columns: 1fr; gap: 32px; }
}

.brain-teaser-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(242,238,229,0.10);
  border: 1px solid rgba(242,238,229,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 720px) { .brain-teaser-grid { grid-template-columns: repeat(2, 1fr); } }

.teaser-region {
  background: rgba(20,19,15,0.65);
  padding: 22px 16px 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  min-height: 110px;
  transition: background 0.4s var(--ease-out);
  cursor: default;
}
.teaser-region:hover {
  background: rgba(94,106,83,0.18);
}
.teaser-region-icon {
  width: 32px; height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(242,238,229,0.24);
  font-size: 14px;
  color: var(--bone);
  transition: border-color 0.4s var(--ease-out), color 0.4s var(--ease-out);
}
.teaser-region:hover .teaser-region-icon {
  border-color: var(--signal);
  color: var(--signal);
}
.teaser-region-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--bone);
}

.brain-teaser-cta {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
}
.brain-teaser-note {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(242,238,229,0.78);
  margin: 0;
  max-width: 38ch;
}
.brain-teaser-note em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--signal);
}
.brain-teaser-cta .btn { padding: 14px 24px; font-size: 14px; }

/* ─── TRUST BAND — partners + hairline rule ────────────────────────────── */
.trust-band {
  padding: 56px 0 40px;
  position: relative;
  background: var(--bone);
}
.trust-band::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(820px, calc(100% - 2 * var(--shell-pad)));
  height: 1px;
  background: linear-gradient(to right, transparent 0%, rgba(19,18,14,0.16) 18%, rgba(19,18,14,0.16) 82%, transparent 100%);
}
.trust-band-inner {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: center;
}
.trust-band-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.trust-band-rule {
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--graphite-2);
  opacity: 0.6;
}
.trust-band-logos {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 32px;
}
.trust-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.14em;
  color: var(--graphite);
  transition: color 0.4s var(--ease-out);
  position: relative;
}
.trust-logo + .trust-logo::before {
  content: "·";
  position: absolute;
  left: -19px;
  color: var(--graphite-3);
  font-weight: 400;
  letter-spacing: 0;
}
.trust-logo-mark {
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--signal-deep);
  opacity: 0.75;
}
.trust-logo-word {
  font-family: var(--font-sans);
}
.trust-logo:hover { color: var(--ink); }
.trust-logo:hover .trust-logo-mark { opacity: 1; background: var(--ink); }
.trust-logo-more {
  letter-spacing: 0.06em;
  font-weight: 400;
  font-style: italic;
  font-family: var(--font-serif);
  font-size: 15px;
  color: var(--graphite-2);
}
.trust-logo-more + .trust-logo::before,
.trust-logo-more::before { content: none !important; }
.trust-strip-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.trust-logo {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.10em;
  color: var(--graphite-2);
  transition: color 0.3s var(--ease-out);
}
.trust-logo:hover { color: var(--ink); }

/* ─── PROBLEM — Org diagram (brand-styled, ported from company-brain) ──── */
.org-diagram {
  position: relative;
  margin: 56px 0;
  padding: clamp(36px, 5vw, 64px) clamp(28px, 4vw, 48px);
  border-radius: var(--radius-xl);
  background: #14130F;
  color: #F2EEE5;
  overflow: hidden;
  isolation: isolate;
}
.org-diagram-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 40% at 50% 0%, rgba(168,176,147,0.16) 0%, transparent 60%),
    radial-gradient(40% 35% at 18% 95%, rgba(216,178,122,0.10) 0%, transparent 60%);
  pointer-events: none;
}
.org-diagram::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.10 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
  opacity: 0.35;
  pointer-events: none;
}
.org-diagram > * { position: relative; z-index: 1; }

.org-tier { display: flex; justify-content: center; }
.org-leader {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 18px 36px;
  border: 1px solid rgba(168,176,147,0.45);
  border-radius: 999px;
  background: rgba(94,106,83,0.16);
  box-shadow: 0 0 32px rgba(168,176,147,0.18);
  position: relative;
}
.org-leader-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal);
}
.org-leader-sub {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: -0.015em;
  color: #F2EEE5;
}
.org-leader-tag {
  position: absolute;
  left: 50%;
  bottom: -16px;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(216,178,122,0.16);
  border: 1px solid rgba(216,178,122,0.36);
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.org-leader-tag .signal-dot {
  width: 6px; height: 6px;
  background: var(--amber);
  border-radius: 50%;
}

.org-flow {
  display: flex;
  justify-content: center;
  gap: 32px;
  margin: 38px 0 24px;
}
.org-arrow {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.org-arrow-down,
.org-arrow-up {
  position: relative;
  width: 1px;
  height: 36px;
  background: rgba(242,238,229,0.30);
}
.org-arrow-down::after,
.org-arrow-up::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 7px;
  height: 7px;
  border-right: 1px solid rgba(242,238,229,0.55);
  border-bottom: 1px solid rgba(242,238,229,0.55);
  transform: translateX(-50%) rotate(45deg);
}
.org-arrow-down::after { bottom: -1px; }
.org-arrow-up::after { top: -1px; transform: translateX(-50%) rotate(-135deg); }
.org-arrow-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
}

.org-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 8px;
}
@media (max-width: 880px) { .org-row { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .org-row { grid-template-columns: 1fr; } }
.org-team {
  background: rgba(242,238,229,0.05);
  border: 1px solid rgba(242,238,229,0.10);
  border-radius: var(--radius-lg);
  padding: 20px;
  transition: background 0.4s var(--ease-out), border-color 0.4s var(--ease-out);
}
.org-team:hover {
  background: rgba(242,238,229,0.08);
  border-color: rgba(242,238,229,0.18);
}
.org-team-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: -0.015em;
  color: #F2EEE5;
  margin-bottom: 4px;
}
.org-team-role {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
  margin-bottom: 14px;
}
.org-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.org-tool {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(242,238,229,0.06);
  border: 1px solid rgba(242,238,229,0.10);
  color: rgba(242,238,229,0.75);
}
.org-tool .dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: rgba(242,238,229,0.45);
}

.org-flag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 28px;
}
.org-flag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.14);
  color: rgba(242,238,229,0.62);
}
.org-flag.accent {
  background: rgba(216,178,122,0.12);
  border-color: rgba(216,178,122,0.36);
  color: var(--amber);
}

/* problem-mesh-wrap (legacy, hidden now) */
.problem-mesh-wrap { display: none; }
.problem-mesh-wrap-legacy {
  margin-top: 48px;
  padding: clamp(28px, 4vw, 48px);
  background: var(--bone-soft);
  border: 1px solid rgba(19,18,14,0.08);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}
.problem-mesh-wrap::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(40% 35% at 92% 8%, rgba(168,176,147,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.problem-mesh-wrap .shell-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.problem-mesh-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
}
.problem-mesh-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.problem-mesh-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(20px, 2.2vw, 26px);
  letter-spacing: -0.02em;
}
.problem-mesh-title em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--graphite);
}
#lateralMeshTarget {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  display: block;
}

/* ─── BRAIN STAGE — defensive dark ─────────────────────────────────────── */
section.brain-section { padding-bottom: clamp(48px, 8vw, 96px); }
.brain-stage {
  position: relative;
  padding: clamp(32px, 5vw, 64px);
  border-radius: var(--radius-xl);
  background: #14130F;
  color: #F2EEE5;
  overflow: hidden;
  isolation: isolate;
}
.brain-stage::before {
  content: "";
  position: absolute; inset: -10%;
  background:
    radial-gradient(45% 45% at 30% 35%, rgba(168,176,147,0.18) 0%, transparent 60%),
    radial-gradient(40% 40% at 70% 65%, rgba(216,178,122,0.12) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.brain-stage::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.10 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
  opacity: 0.4;
  pointer-events: none;
}
.brain-stage > * { position: relative; z-index: 1; }
.brain-map-wrap {
  display: block;
  width: 100%;
}
.brain-map-wrap svg {
  width: 100%;
  height: auto;
  display: block;
  max-width: 880px;
  margin: 0 auto;
}
.brain-hint {
  text-align: center;
  margin-top: 18px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.45);
}
.brain-detail {
  margin-top: 32px;
  padding: 26px 32px;
  border-radius: var(--radius-lg);
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.10);
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 32px;
  align-items: start;
  min-height: 140px;
}
@media (max-width: 720px) { .brain-detail { grid-template-columns: 1fr; gap: 14px; } }
.brain-detail-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal);
}
.brain-detail-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-top: 8px;
  color: var(--bone);
}
.brain-detail-body {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(242,238,229,0.78);
  max-width: 62ch;
}
.brain-detail-body em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--signal);
  font-weight: 400;
}

/* Override the old brain-section text colors */
.brain-section .section-head h2,
.brain-section .section-head h2 em { color: inherit; }
.brain-section .section-head { margin-bottom: clamp(40px, 5vw, 64px); }

/* ─── HIW STAGE — defensive dark ───────────────────────────────────────── */
.hiw {
  background: #14130F;
  color: #F2EEE5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  position: relative;
  isolation: isolate;
}
.hiw::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 18% 18%, rgba(168,176,147,0.12) 0%, transparent 60%),
    radial-gradient(50% 40% at 82% 78%, rgba(216,178,122,0.08) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.hiw > * { position: relative; z-index: 1; }

.hiw-picker {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: 1px solid rgba(242,238,229,0.10);
}
@media (max-width: 720px) { .hiw-picker { grid-template-columns: 1fr; } }
.hiw-proc {
  background: transparent;
  padding: 24px 28px;
  display: flex;
  align-items: center;
  gap: 14px;
  text-align: left;
  border: none;
  border-right: 1px solid rgba(242,238,229,0.08);
  color: #F2EEE5;
  cursor: pointer;
  transition: background 0.35s var(--ease-out);
  position: relative;
}
.hiw-proc:last-child { border-right: none; }
.hiw-proc:hover { background: rgba(242,238,229,0.04); }
.hiw-proc.active { background: rgba(94,106,83,0.16); }
.hiw-proc.active::after {
  content: "";
  position: absolute;
  left: 28px; right: 28px; bottom: -1px; height: 2px;
  background: var(--signal);
}
.hiw-proc-icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(242,238,229,0.20);
  font-size: 16px;
  flex-shrink: 0;
}
.hiw-proc.active .hiw-proc-icon {
  border-color: var(--signal);
  color: var(--signal);
}
.hiw-proc-name { font-weight: 500; font-size: 15px; letter-spacing: -0.01em; line-height: 1.2; }
.hiw-proc-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
  margin-top: 3px;
}

.hiw-stage {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: 24px;
  padding: clamp(24px, 3vw, 36px);
  align-items: stretch;
}
@media (max-width: 1024px) { .hiw-stage { grid-template-columns: 1fr; } }

.hiw-side {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.hiw-side-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
  margin-top: 4px;
}
.hiw-side-label:first-child { margin-top: 0; }

.hiw-input-card {
  background: rgba(242,238,229,0.05);
  border: 1px solid rgba(242,238,229,0.12);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color 0.5s var(--ease-out), background 0.5s var(--ease-out);
}
.hiw-input-card.firing {
  border-color: var(--signal);
  background: rgba(94,106,83,0.14);
}
.hiw-input-head {
  display: flex;
  align-items: center;
  gap: 12px;
}
.hiw-input-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: #F2EEE5;
  color: #13120E;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}
.hiw-input-avatar.signal {
  background: var(--signal);
  color: #14130F;
}
.hiw-input-avatar.brain {
  background: rgba(94,106,83,0.4);
  color: var(--signal);
  font-family: var(--font-sans);
  font-size: 16px;
}
.hiw-input-name {
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: #F2EEE5;
}
.hiw-input-role {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.55);
  margin-top: 2px;
}
.hiw-autonomous-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(168,176,147,0.16);
  color: var(--signal);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.hiw-input-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.5;
  color: #F2EEE5;
  border-top: 1px solid rgba(242,238,229,0.10);
  padding-top: 12px;
  letter-spacing: -0.005em;
}

.hiw-emotion {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  padding: 14px 16px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.03);
  border: 1px solid rgba(242,238,229,0.10);
  align-items: center;
  --emo-color: rgba(242,238,229,0.36);
  --emo-glow:  rgba(242,238,229,0.10);
  transition: border-color 0.5s var(--ease-out), background 0.5s var(--ease-out);
}
.hiw-emotion.active {
  border-color: var(--emo-color);
  background: rgba(94,106,83,0.10);
}
.hiw-emotion::before {
  content: "";
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--emo-color);
  box-shadow: 0 0 18px var(--emo-glow);
  transition: background 0.6s var(--ease-out), box-shadow 0.6s var(--ease-out);
  animation: signal-pulse 3.4s var(--ease-in-out) infinite;
}
.hiw-emo-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}
.hiw-emo-name {
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: #F2EEE5;
  margin-top: 2px;
}
.hiw-emo-meaning {
  font-size: 12px;
  color: rgba(242,238,229,0.62);
  line-height: 1.5;
  margin-top: 4px;
}

.hiw-brain-wrap {
  position: relative;
  background: rgba(20,19,15,0.5);
  border-radius: var(--radius-lg);
  padding: 18px;
  border: 1px solid rgba(242,238,229,0.10);
  min-height: 460px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hiw-brain-wrap.is-night { background: rgba(20,19,15,0.85); }
.hiw-brain-wrap #hiwBrainTarget {
  width: 100%;
}
.hiw-brain-wrap #hiwBrainTarget svg {
  width: 100%;
  height: auto;
  max-height: 480px;
  display: block;
}

.hiw-output-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 200px;
}
.hiw-output-item {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.05);
  border: 1px solid rgba(242,238,229,0.12);
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.5s var(--ease-out), transform 0.5s var(--ease-out);
}
.hiw-output-item.visible { opacity: 1; transform: translateX(0); }
.hiw-output-icon {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: rgba(94,106,83,0.30);
  color: var(--signal);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
}
.hiw-output-text {
  font-weight: 500;
  font-size: 13px;
  letter-spacing: -0.005em;
  color: #F2EEE5;
}
.hiw-output-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
  margin-top: 2px;
}

.hiw-phase {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  padding: 14px 16px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.03);
  border: 1px solid rgba(242,238,229,0.10);
  align-items: center;
}
.hiw-phase.is-night {
  background: rgba(94,106,83,0.14);
  border-color: rgba(168,176,147,0.30);
}
.hiw-phase-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(242,238,229,0.10);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  color: #F2EEE5;
}
.hiw-phase.is-night .hiw-phase-icon {
  background: rgba(168,176,147,0.22);
  color: var(--signal);
}
.hiw-phase-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}
.hiw-phase-name {
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: #F2EEE5;
  margin-top: 2px;
}
.hiw-phase-detail {
  font-size: 12px;
  color: rgba(242,238,229,0.62);
  margin-top: 2px;
  line-height: 1.5;
}

/* ─── HIW TIMELINE ─────────────────────────────────────────────────────── */
.hiw-timeline {
  padding: 28px clamp(24px, 3vw, 36px);
  border-top: 1px solid rgba(242,238,229,0.10);
}
.hiw-timeline-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  gap: 16px;
  flex-wrap: wrap;
}
.hiw-step-counter {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.62);
}
.hiw-step-counter strong { color: #F2EEE5; font-weight: 500; }
.hiw-controls {
  display: flex;
  gap: 8px;
}
.hiw-ctrl {
  padding: 9px 16px;
  border-radius: 999px;
  border: 1px solid rgba(242,238,229,0.20);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #F2EEE5;
  background: transparent;
  transition: background 0.3s var(--ease-out), border-color 0.3s var(--ease-out);
  cursor: pointer;
}
.hiw-ctrl:hover {
  background: rgba(242,238,229,0.06);
  border-color: rgba(242,238,229,0.40);
}
.hiw-ctrl.primary {
  background: #F2EEE5;
  color: #13120E;
  border-color: #F2EEE5;
}
.hiw-ctrl.primary:hover { background: var(--bone-3); }

.hiw-progress {
  height: 2px;
  background: rgba(242,238,229,0.10);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 18px;
}
.hiw-progress-bar {
  height: 100%;
  width: 0%;
  background: var(--signal);
  transition: width 0.6s var(--ease-out);
}

.hiw-steps {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
}
@media (max-width: 1024px) { .hiw-steps { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 520px)  { .hiw-steps { grid-template-columns: repeat(2, 1fr); } }
.hiw-step {
  padding: 12px 12px 14px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.10);
  text-align: left;
  cursor: pointer;
  transition: background 0.3s var(--ease-out), border-color 0.3s var(--ease-out), transform 0.3s var(--ease-out);
}
.hiw-step:hover { background: rgba(242,238,229,0.07); }
.hiw-step.active {
  border-color: var(--signal);
  background: rgba(94,106,83,0.18);
  transform: translateY(-1px);
}
.hiw-step.done {
  background: rgba(94,106,83,0.08);
  border-color: rgba(94,106,83,0.30);
}
.hiw-step-num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: rgba(242,238,229,0.45);
}
.hiw-step.active .hiw-step-num,
.hiw-step.done   .hiw-step-num { color: var(--signal); }
.hiw-step-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: rgba(242,238,229,0.6);
  margin-top: 4px;
}
.hiw-step-title {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: #F2EEE5;
  margin-top: 4px;
  line-height: 1.3;
}

.hiw-step-detail {
  margin-top: 20px;
  padding: 20px 24px;
  border-radius: var(--radius);
  background: rgba(242,238,229,0.04);
  border-left: 2px solid var(--signal);
  font-size: 14.5px;
  line-height: 1.6;
  color: rgba(242,238,229,0.85);
}
.hiw-step-detail em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--signal);
  font-weight: 400;
}

/* ─── HIW COMPARISON ───────────────────────────────────────────────────── */
.hiw-compare {
  padding: clamp(24px, 3vw, 40px) clamp(24px, 3vw, 36px);
  border-top: 1px solid rgba(242,238,229,0.10);
}
.hiw-compare-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 22px;
  flex-wrap: wrap;
  gap: 14px;
}
.hiw-compare-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}
.hiw-compare-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 28px);
  letter-spacing: -0.025em;
  line-height: 1.15;
  margin-top: 6px;
  color: #F2EEE5;
}
.hiw-compare-sub {
  font-size: 13px;
  color: rgba(242,238,229,0.62);
}
.hiw-compare-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: stretch;
}
@media (max-width: 720px) { .hiw-compare-grid { grid-template-columns: 1fr; } }
.hiw-compare-col {
  padding: 24px;
  border-radius: var(--radius-lg);
  background: rgba(242,238,229,0.04);
  border: 1px solid rgba(242,238,229,0.10);
}
.hiw-compare-col.ai {
  background: rgba(94,106,83,0.14);
  border-color: rgba(168,176,147,0.30);
}
.hiw-compare-col-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.6);
}
.hiw-compare-col.ai .hiw-compare-col-tag { color: var(--signal); }
.hiw-compare-col-head {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: -0.015em;
  line-height: 1.3;
  margin-top: 8px;
  margin-bottom: 18px;
  color: #F2EEE5;
}
.hiw-compare-rows {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.hiw-compare-row {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 14px;
  padding-top: 10px;
  border-top: 1px solid rgba(242,238,229,0.08);
  font-size: 13px;
  line-height: 1.5;
}
.hiw-compare-row-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}
.hiw-compare-row-value {
  color: rgba(242,238,229,0.88);
}
.hiw-compare-divider {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--signal);
  font-size: 22px;
  align-self: center;
}
@media (max-width: 720px) { .hiw-compare-divider { display: none; } }

.hiw-skill {
  margin: 0 clamp(24px, 3vw, 36px) clamp(24px, 3vw, 36px);
  padding: 22px;
  border-radius: var(--radius-lg);
  background: rgba(168,176,147,0.10);
  border: 1px solid rgba(168,176,147,0.32);
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 16px;
  align-items: start;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out);
}
.hiw-skill.visible { opacity: 1; transform: translateY(0); }
.hiw-skill-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(168,176,147,0.24);
  color: var(--signal);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
}
.hiw-skill-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal);
}
.hiw-skill-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.015em;
  margin-top: 4px;
  line-height: 1.3;
  color: #F2EEE5;
}
.hiw-skill-detail {
  font-size: 13.5px;
  line-height: 1.6;
  color: rgba(242,238,229,0.78);
  margin-top: 6px;
}
.hiw-skill-detail em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--signal);
  font-weight: 400;
}

/* ─── HIW EXPLAINERS ───────────────────────────────────────────────────── */
.hiw-explainers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
}
@media (max-width: 880px) { .hiw-explainers { grid-template-columns: 1fr; } }
.hiw-explainer {
  padding: 32px;
  border-radius: var(--radius-lg);
  background: var(--bone-2);
  border: 1px solid rgba(19,18,14,0.10);
}
.hiw-explainer-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--signal-deep);
}
.hiw-explainer-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 28px);
  letter-spacing: -0.025em;
  line-height: 1.15;
  margin-top: 8px;
  margin-bottom: 18px;
}
.hiw-explainer-title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--graphite);
}
.hiw-explainer-body p {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--graphite);
  margin: 0 0 12px;
}
.hiw-explainer-body em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--ink);
  font-weight: 400;
}
.hiw-emo-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.hiw-emo-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--bone);
  border: 1px solid rgba(19,18,14,0.10);
  font-size: 12px;
}
.hiw-emo-pill .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
}
.hiw-emo-pill .name { font-weight: 500; color: var(--ink); }
.hiw-emo-pill .line {
  color: var(--graphite-2);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-left: 4px;
}
.emo-calm        { background: var(--signal); }
.emo-vigilance   { background: var(--amber); }
.emo-urgency     { background: var(--amber-deep); }
.emo-anticipation{ background: var(--signal-deep); }

/* ─── METAB CHART (v2 polish) ──────────────────────────────────────────── */
.metab-chart-wrap {
  margin: 40px 0 32px;
  padding: 36px 32px 28px;
  border-radius: var(--radius-lg);
  background: #14130F;
  color: #F2EEE5;
  position: relative;
  overflow: hidden;
}
.metab-chart-wrap::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 14% 28%, rgba(168,176,147,0.16) 0%, transparent 60%),
    radial-gradient(45% 40% at 86% 78%, rgba(216,178,122,0.10) 0%, transparent 60%);
  pointer-events: none;
}
.metab-chart-wrap::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
  opacity: 0.35;
  pointer-events: none;
}
.metab-chart-wrap > * { position: relative; z-index: 1; }
.metab-chart-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 20px;
}
.metab-chart-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: rgba(242,238,229,0.5);
}
.metab-chart-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(20px, 2.4vw, 28px);
  letter-spacing: -0.025em;
  line-height: 1.2;
  margin-top: 6px;
  max-width: 36ch;
  color: #F2EEE5;
}
.metab-chart-legend {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}
.metab-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(242,238,229,0.7);
}
.metab-legend-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
}
#metabChartTarget svg {
  width: 100%;
  height: auto;
  display: block;
}

/* ─── TEAM (v2 brand-integrated) ───────────────────────────────────────── */
.team-section {
  background: var(--bone);
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1px;
  background: rgba(19,18,14,0.10);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.team-card {
  position: relative;
  background: var(--bone);
  padding: 32px 28px;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background 0.4s var(--ease-out);
  overflow: hidden;
}
.team-card:hover { background: var(--bone-2); }
.team-card::before {
  content: "";
  position: absolute;
  top: 0; left: 28px; right: 28px; height: 1px;
  background: linear-gradient(to right, transparent 0%, var(--signal-deep) 50%, transparent 100%);
  opacity: 0.4;
}
.team-card-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bone);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
}
.team-card-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--graphite-2);
}
.team-card-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.team-card-role {
  font-size: 14px;
  color: var(--graphite-2);
}
.team-card-line {
  font-size: 14px;
  line-height: 1.55;
  color: var(--graphite);
  margin-top: 6px;
}

/* ─── REMOVE LEGACY SECTIONS — superseded ──────────────────────────────── */
.chladni-divider,
.kinetic-band,
section#futures { display: none !important; }

