/*
 * NEXONOMY · COMPONENT STYLES
 * Nav, hero, section patterns, DR card, logo wall, proof blocks.
 * Import after base.css. Tokens are already in scope via base.css → tokens.css.
 */


/* ─── NAV (structured dropdown) ──────────────────────────────────────────── */

.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  justify-content: center;
  padding: 20px var(--section-px);
  pointer-events: none;
}

.nav__pill {
  position: relative;
  display: flex;
  align-items: center;
  gap: 22px;
  width: 100%;
  max-width: var(--container-max);
  background: var(--color-nav);
  backdrop-filter: var(--blur-glass);
  -webkit-backdrop-filter: var(--blur-glass);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  padding: var(--nav-py) var(--nav-px);
  pointer-events: all;
}

.nav__logo {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
  letter-spacing: -0.3px;
  flex-shrink: 0;
}

.nav__menu { display: flex; align-items: center; gap: 2px; }
.nav__group { position: relative; }

.nav__link, .nav__trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: var(--weight-medium);
  color: var(--color-text-secondary);
  padding: 7px 12px;
  border-radius: var(--radius-card);
  background: none;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-out);
}
/* the open/hovered trigger becomes a tab in the panel's own material, so the
   panel reads as belonging to it (the through-line the bar was missing) */
.nav__link:hover, .nav__trigger:hover,
.nav__group:hover .nav__trigger,
.nav__group.is-open .nav__trigger {
  color: var(--color-text-primary);
  background: rgba(255,255,255,0.06);
}
.nav__chev { width: 11px; height: 11px; opacity: 0.7; transition: transform var(--duration-fast) var(--ease-out); }
.nav__group:hover .nav__chev, .nav__group.is-open .nav__chev { transform: rotate(180deg); }

/* dropdown panel — springs out from its trigger; the motion carries the
   connection, so it stays clean and minimal (no caret). transform-origin sits
   under the trigger so the panel grows from it. */
.nav__panel {
  position: absolute;
  top: calc(100% + 8px);
  left: -10px;
  min-width: 320px;
  background: var(--color-surface-1);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05),
              0 18px 44px -16px rgba(0,0,0,0.8);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0;
  visibility: hidden;
  transform-origin: top left;
  transform: translateY(-8px) scale(0.96);
  transition: transform 0.34s cubic-bezier(0.34, 1.56, 0.64, 1),
              opacity 0.18s ease-out,
              visibility 0.34s;
}
/* invisible bridge across the gap so hover doesn't drop */
.nav__group::after { content: ''; position: absolute; top: 100%; left: 0; right: 0; height: 16px; }
.nav__group:hover .nav__panel,
.nav__group.is-open .nav__panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.nav__dd {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 12px;
  border-radius: 8px;
  transition: background var(--duration-fast) var(--ease-out);
}
.nav__dd:hover { background: var(--color-surface-2); }
.nav__dd b { font-size: 13px; font-weight: var(--weight-medium); color: var(--color-text-primary); }
.nav__dd span { font-size: 11.5px; line-height: 16px; color: var(--color-text-muted); }

/* small honest relevance note at the top of the Use Cases panel */
.nav__panel-note {
  display: block; padding: 6px 12px 10px; margin-bottom: 4px;
  border-bottom: 1px solid var(--color-border);
  font-family: var(--font-mono); font-size: 10px; line-height: 1.5;
  letter-spacing: 0.04em; color: var(--color-text-muted);
}

/* Featured "new here?" entry — sits at the bottom of the Platform menu, set apart */
.nav__dd--feature {
  margin-top: 10px;
  padding-top: 12px;
  background: rgba(140, 101, 247, 0.12);
  box-shadow: inset 0 0 0 1px rgba(140, 101, 247, 0.22);
}
.nav__dd--feature:hover { background: rgba(140, 101, 247, 0.18); }

/* ─── NAV LOGO: one-time entrance on load (non-blocking; page paints instantly) ─ */
@keyframes logoIn {
  from { opacity: 0; transform: scale(0.9); }
  to   { opacity: 1; transform: scale(1); }
}
.nav__logo img { animation: logoIn 0.5s var(--ease-out) 0.08s both; }
@media (prefers-reduced-motion: reduce) { .nav__logo img { animation: none; } }

.nav__cta {
  margin-left: auto;
  flex-shrink: 0;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: var(--weight-medium);
  color: var(--color-white);
  background: var(--color-accent-deep);
  padding: 7px 16px;
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-cta);
  transition: opacity var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
.nav__cta:hover { opacity: 0.88; transform: translateY(-1px); }

/* burger (mobile only) */
.nav__burger {
  display: none;
  flex-direction: column;
  gap: 4px;
  padding: 8px;
  background: none;
  cursor: pointer;
  flex-shrink: 0;
}
.nav__burger span {
  display: block;
  width: 18px; height: 1.5px;
  background: var(--color-text-secondary);
  transition: transform var(--duration-fast) var(--ease-out),
              opacity var(--duration-fast) var(--ease-out);
}
.nav--open .nav__burger span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.nav--open .nav__burger span:nth-child(2) { opacity: 0; }
.nav--open .nav__burger span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

@media (max-width: 900px) {
  .nav__pill { gap: 12px; }
  .nav__burger { display: flex; }
  .nav__cta { margin-left: auto; padding: 6px 13px; }
  /* the menu becomes a drawer below the pill */
  .nav__menu {
    position: absolute;
    top: calc(100% + 10px); left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    background: var(--color-surface-1);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    padding: 12px;
    box-shadow: 0 24px 48px -20px rgba(0,0,0,0.7);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity var(--duration-base) var(--ease-out),
                transform var(--duration-base) var(--ease-out),
                visibility var(--duration-base);
  }
  .nav--open .nav__menu { opacity: 1; visibility: visible; transform: translateY(0); }
  .nav__group { position: static; }
  .nav__trigger {
    width: 100%;
    justify-content: flex-start;
    pointer-events: none;
    color: var(--color-text-muted);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 10px 12px 4px;
  }
  .nav__chev { display: none; }
  /* panels render expanded inline on mobile — no floating surface, no caret, no tab highlight */
  .nav__panel {
    position: static;
    opacity: 1; visibility: visible; transform: none;
    min-width: 0;
    background: none; border: none; box-shadow: none;
    padding: 0 0 6px;
  }
  .nav__trigger:hover, .nav__group:hover .nav__trigger,
  .nav__group.is-open .nav__trigger { background: none; }
  .nav__link { width: 100%; padding: 10px 12px; }
}


/* ─── HERO ───────────────────────────────────────────────────────────────── */

.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1.18fr;
  align-items: center;
  gap: 56px;
  padding-top: 96px;
  padding-bottom: 64px;
  padding-inline: var(--section-px);
  max-width: var(--container-max);
  margin-inline: auto;
}

.hero__copy {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.hero__heading {
  font-family: var(--font-display);
  font-size: 72px;
  line-height: 76px;
  letter-spacing: -3.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}

.hero__heading em {
  font-style: italic;
  color: var(--color-accent);
}

.hero__sub {
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 26px;
  letter-spacing: -0.3px;
  color: var(--color-text-secondary);
  max-width: 400px;
}

.hero__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.hero__learn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--color-text-muted);
  transition: color var(--duration-fast) var(--ease-out);
}
.hero__learn:hover { color: var(--color-accent); }
.hero__learn .icon { width: 13px; height: 13px; }

.hero__visual {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}

/* Ambient glow behind the record card */
.hero__visual::before {
  content: '';
  position: absolute;
  inset: -40px;
  background: var(--gradient-accent-glow);
  opacity: 0.4;
  pointer-events: none;
  border-radius: 50%;
  filter: blur(40px);
}


/* ─── DECISION RECORD CARD ───────────────────────────────────────────────── */

.dr-card {
  position: relative;
  background: var(--color-surface-0);
  border: 1px solid var(--color-border);
  border-left: 2px solid var(--color-accent);
  border-radius: var(--radius-card);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  z-index: 1;
}

.dr-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.dr-card__id {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-accent);
  letter-spacing: 0.06em;
}

.dr-card__status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.dr-card__status::before {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-affirm);
}

.dr-card__divider {
  height: 1px;
  background: var(--color-border);
  margin: 0 -24px;
}

.dr-card__row {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 12px;
  align-items: baseline;
}

.dr-card__label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding-top: 2px;
}

.dr-card__value {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 19px;
  color: var(--color-text-primary);
}

.dr-card__value--muted {
  color: var(--color-text-secondary);
  font-size: 12px;
}

.dr-card__options {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.dr-card__option {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--color-text-secondary);
}

.dr-card__option--selected {
  color: var(--color-text-primary);
}

.dr-card__option-marker {
  width: 14px;
  height: 14px;
  border-radius: 3px;
  border: 1px solid var(--color-border);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dr-card__option--selected .dr-card__option-marker {
  background: var(--color-accent);
  border-color: var(--color-accent);
}

.dr-card__option-tick {
  display: none;
  width: 8px;
  height: 8px;
}

.dr-card__option--selected .dr-card__option-tick {
  display: block;
}

.dr-card__hash-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 8px;
  border-top: 1px solid var(--color-border);
}

.dr-card__hash {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--color-text-muted);
  letter-spacing: 0.06em;
}

.dr-card__signoffs {
  display: flex;
  gap: 4px;
}

.dr-card__avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--color-text-muted);
}

/* Secondary record — slightly faded, behind the main */
.dr-card--secondary {
  opacity: 0.5;
  transform: scale(0.97) translateY(-8px);
  transform-origin: bottom center;
}


/* ─── CONCESSION SECTION ─────────────────────────────────────────────────── */

.concession {
  background: var(--color-surface-1);
  padding-block: var(--section-py);
}

.concession__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

.concession__left {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.concession__headline {
  font-family: var(--font-display);
  font-size: 42px;
  line-height: 50px;
  letter-spacing: -1.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}

.concession__body {
  font-size: 15px;
  line-height: 24px;
  color: var(--color-text-secondary);
}

.concession__right {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-top: 8px;
}

.type-chip {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 20px;
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  background: var(--color-surface-0);
}

.type-chip__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.type-chip--conceded .type-chip__label  { color: var(--color-text-muted); }
.type-chip--claimed  .type-chip__label  { color: var(--color-accent); }

.type-chip__text {
  font-size: 13px;
  line-height: 20px;
  color: var(--color-text-secondary);
}

.type-chip__examples {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}

.type-chip__example {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-surface-2);
  color: var(--color-text-muted);
}

.type-chip--claimed .type-chip__example {
  background: rgba(140,101,247,0.10);
  color: var(--color-accent);
}


/* ─── PILLARS ────────────────────────────────────────────────────────────── */

.pillars {
  padding-block: var(--section-py);
}

.pillars__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
}

.pillars__header {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 56px;
  max-width: 680px;
  margin-inline: auto;
  align-items: center;
  text-align: center;
}

.pillars__heading {
  font-family: var(--font-display);
  font-size: 42px;
  line-height: 50px;
  letter-spacing: -1.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}

.pillars__heading em {
  font-style: italic;
  color: var(--color-accent);
}

.pillars__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

.pillar {
  padding: 32px;
  background: var(--color-surface-0);
  display: flex;
  flex-direction: column;
  gap: 16px;
  border: 1px solid var(--color-border);
}

.pillar:first-child { border-radius: var(--radius-card) 0 0 var(--radius-card); }
.pillar:last-child  { border-radius: 0 var(--radius-card) var(--radius-card) 0; }

.pillar__number {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  color: var(--color-accent);
}

.pillar__title {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 28px;
  letter-spacing: -0.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}

.pillar__body {
  font-size: 14px;
  line-height: 22px;
  color: var(--color-text-secondary);
}

.pillar__detail {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  padding-top: 16px;
  border-top: 1px solid var(--color-border);
}


/* ─── DEPLOYMENT ─────────────────────────────────────────────────────────── */

.deployment {
  background: var(--gradient-section);
  padding-block: var(--section-py);
}

.deployment__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.deployment__heading {
  font-family: var(--font-display);
  font-size: 42px;
  line-height: 50px;
  letter-spacing: -1.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  margin-bottom: 20px;
}

.deployment__body {
  font-size: 15px;
  line-height: 24px;
  color: var(--color-text-secondary);
  margin-bottom: 32px;
}

.deployment__facts {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.deployment__fact {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 14px;
  line-height: 22px;
  color: var(--color-text-secondary);
}

.deployment__fact::before {
  content: '';
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-accent);
  flex-shrink: 0;
  position: relative;
  top: -1px;
  margin-top: 9px;
}

.deployment__visual {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.deploy-layer {
  padding: 14px 20px;
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.deploy-layer--customer {
  background: rgba(140,101,247,0.08);
  border-color: rgba(140,101,247,0.20);
}

.deploy-layer__name {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-primary);
}

.deploy-layer--customer .deploy-layer__name {
  color: var(--color-accent);
}

.deploy-layer__tag {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--color-text-muted);
}

.deploy-connector {
  width: 1px;
  height: 12px;
  background: var(--color-border);
  margin-left: 20px;
}


/* ─── DEPLOYMENT · INTERACTIVE BOUNDARY DIAGRAM (homepage, .deployment--arch) ─
 * The Core is the accent hero; the customer's stack and owned outputs are neutral
 * nodes inside a sealed perimeter. Click a node to read what it is and what stays.
 * No-JS shows the full diagram + the default (Core) detail. */
.deployment--arch .deployment__inner {
  grid-template-columns: 1fr;
  gap: 44px;
}
.deployment__head { max-width: 760px; }

.deparch {
  border: 1px solid rgba(140,101,247,0.28);
  border-radius: 16px;
  background: var(--color-surface-1);
  padding: 16px 18px 20px;
}

/* boundary header: the environment label + the seal */
.deparch__bound {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 6px 6px 14px;
  border-bottom: 1px dashed var(--color-border);
  margin-bottom: 18px;
}
.deparch__env {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-accent);
}
.deparch__env .icon { width: 14px; height: 14px; }
.deparch__env-sub { color: var(--color-text-muted); text-transform: none; letter-spacing: 0.02em; }
.deparch__seal {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-affirm);
  border: 1px solid rgba(16,185,129,0.30);
  border-radius: 6px;
  padding: 4px 9px;
}
.deparch__seal .icon { width: 12px; height: 12px; color: var(--color-affirm); }

/* the flow: your stack → Core → owned outputs */
.deparch__flow {
  display: grid;
  grid-template-columns: 1fr auto 1.18fr auto 1fr;
  align-items: center;
  gap: 14px;
}
.deparch__col { display: flex; flex-direction: column; gap: 10px; }
.deparch__col-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding-left: 2px;
}
.deparch__arrow { color: var(--color-text-muted); display: grid; place-items: center; }
.deparch__arrow .icon { width: 20px; height: 20px; }

/* the customer's nodes (neutral) and the loop are all .dep-node */
.dep-node {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-surface-0);
  font-size: 13px;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              background var(--duration-fast) var(--ease-out);
}
.dep-node .icon { width: 16px; height: 16px; color: var(--color-text-muted); flex: none; }
.dep-node:hover { border-color: var(--color-border-accent); color: var(--color-text-primary); }
.dep-node:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.dep-node--active { border-color: var(--color-accent); color: var(--color-text-primary); background: rgba(140,101,247,0.06); }
.dep-node--active .icon { color: var(--color-accent); }

/* the Core: the accent hero, deliberately dominant */
.deparch__col--core { align-items: stretch; }
.dep-core {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 18px 18px 16px;
  border: 1.5px solid var(--color-accent);
  border-radius: 12px;
  background: rgba(140,101,247,0.08);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out);
}
.dep-core:hover { background: rgba(140,101,247,0.12); }
.dep-core.dep-node--active { background: rgba(140,101,247,0.13); }
.dep-core:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.dep-core__brand {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-accent);
}
.dep-core__name {
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: -0.3px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}
.dep-core__name .icon { width: 18px; height: 18px; color: var(--color-accent); flex: none; }
.dep-core__fns { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.02em; color: var(--color-text-dim); }
.dep-core__badge {
  margin-top: 5px;
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-caution);
  border: 1px solid rgba(245,165,36,0.28);
  border-radius: 5px;
  padding: 3px 8px;
}

/* the learning loop: full-width, dashed (signals, not data), kept inside the boundary */
.deparch__loop {
  margin-top: 16px;
  justify-content: flex-start;
  border-style: dashed;
  background: transparent;
  font-size: 12.5px;
  line-height: 18px;
  color: var(--color-text-muted);
}
.deparch__loop .icon { color: var(--color-accent); }
.deparch__loop.dep-node--active { background: rgba(140,101,247,0.05); border-color: var(--color-border-accent); }

/* the detail panel: the Decision Record left-rule motif */
.deparch__detail {
  margin-top: 16px;
  padding: 14px 16px;
  border-left: 2px solid var(--color-accent);
  background: var(--color-surface-0);
  border-radius: 0 8px 8px 0;
}
.deparch__detail-label {
  display: block;
  margin-bottom: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-accent);
}
.deparch__detail-body { font-size: 13.5px; line-height: 20px; color: var(--color-text-secondary); }

/* narrow: stack the flow vertically, arrows point down */
@media (max-width: 859px) {
  .deparch__flow { grid-template-columns: 1fr; gap: 10px; }
  .deparch__arrow { transform: rotate(90deg); }
  .deparch__bound { flex-direction: column; align-items: flex-start; gap: 10px; }
}


/* ─── PROOF SECTION ──────────────────────────────────────────────────────── */

.proof {
  padding-block: var(--section-py);
  background: var(--color-surface-1);
}

.proof__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
  display: flex;
  flex-direction: column;
  gap: 64px;
}

/* Anchor block */
.anchor {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  padding: 40px;
  background: var(--color-surface-0);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  position: relative;
}

.anchor__mark {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-card);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  margin-bottom: 20px;
}

.anchor__line {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 36px;
  letter-spacing: -0.8px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  margin-bottom: 12px;
}

.anchor__detail {
  font-size: 14px;
  line-height: 22px;
  color: var(--color-text-secondary);
}

/* Metrics */
.metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  position: relative;
}

.metric {
  padding: 28px;
  background: var(--color-surface-0);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.metric:first-child { border-radius: var(--radius-card) 0 0 var(--radius-card); }
.metric:last-child  { border-radius: 0 var(--radius-card) var(--radius-card) 0; }

.metric__value {
  font-family: var(--font-display);
  font-size: 36px;
  line-height: 40px;
  letter-spacing: -1.5px;
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
}

.metric__label {
  font-size: 13px;
  line-height: 20px;
  color: var(--color-text-secondary);
}

.metric__who {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
}

/* Logo wall */
.logo-wall {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.logo-wall__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  text-align: center;
}

.logo-wall__row {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2px;
}

.logo-wall__item {
  padding: 14px 24px;
  background: var(--color-surface-0);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  letter-spacing: -0.2px;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--ease-out);
}

.logo-wall__item:hover {
  color: var(--color-text-secondary);
}

/* Reserved empty slots */
.logo-wall__item--reserved {
  border-style: dashed;
  color: transparent;
  pointer-events: none;
  min-width: 100px;
}

/* Testimonials */
.testimonials {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.testimonial {
  padding: 32px;
  background: var(--color-surface-0);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.testimonial__quote {
  font-family: var(--font-display);
  font-size: 17px;
  line-height: 26px;
  letter-spacing: -0.3px;
  color: var(--color-text-primary);
  font-style: italic;
}

.testimonial__quote::before { content: '\201C'; }
.testimonial__quote::after  { content: '\201D'; }

.testimonial__attribution {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--color-border);
}

.testimonial__name {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: var(--weight-medium);
  color: var(--color-text-secondary);
}

.testimonial__company {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}

.testimonial__outcome {
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--color-affirm);
}


/* ─── CLOSE CTA ──────────────────────────────────────────────────────────── */

.close-cta {
  padding-block: 120px;
  text-align: center;
}

.close-cta__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}

.close-cta__heading {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 62px;
  letter-spacing: -2.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  max-width: 640px;
}

.close-cta__heading em {
  font-style: italic;
  color: var(--color-accent);
}

.close-cta__sub {
  font-size: 15px;
  line-height: 24px;
  color: var(--color-text-secondary);
  max-width: 400px;
}

.close-cta__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}


/* ─── FOOTER ─────────────────────────────────────────────────────────────── */

.footer {
  border-top: 1px solid var(--color-border);
  padding: 56px var(--section-px) 40px;
}

.footer__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.footer__top { display: grid; grid-template-columns: 1.3fr 2.7fr; gap: 40px; }
.footer__brand { display: flex; flex-direction: column; gap: 14px; max-width: 300px; }
.footer__logo { display: block; }
.footer__tagline { font-size: 13px; line-height: 20px; color: var(--color-text-muted); }

.footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.footer__col { display: flex; flex-direction: column; gap: 10px; }
.footer__col-h {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--color-text-muted); margin-bottom: 2px;
}
.footer__col a {
  font-size: 13px; color: var(--color-text-secondary); text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}
.footer__col a:hover { color: var(--color-text-primary); }

.footer__bottom {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  flex-wrap: wrap; padding-top: 26px; border-top: 1px solid var(--color-border);
}
.footer__copy {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--color-text-muted);
}
.footer__legal-link {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--color-text-muted); text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}
.footer__legal-link:hover { color: var(--color-text-secondary); }

@media (max-width: 720px) {
  .footer__top { grid-template-columns: 1fr; gap: 32px; }
  .footer__cols { grid-template-columns: 1fr 1fr; gap: 24px 20px; }
}


/* ─── THE LIFE OF A DECISION (owned-verb spine + lifecycle ledger) ───────── */

.lifecycle { padding-block: var(--section-py); }
.lifecycle__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
}
.lifecycle__head {
  max-width: 640px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 48px;
}
.lifecycle__heading {
  font-family: var(--font-display);
  font-size: 42px;
  line-height: 50px;
  letter-spacing: -1.5px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}
.lifecycle__heading em { font-style: italic; color: var(--color-accent); }
.lifecycle__intro { font-size: 15px; line-height: 24px; color: var(--color-text-secondary); }

/* The ledger: five columns, hairline-ruled like a register */
.lifecycle__track {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.life-step {
  position: relative;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 230px;
}
.life-step:first-child { padding-left: 0; }
.life-step:last-child { padding-right: 0; }
.life-step + .life-step { border-left: 1px solid var(--color-border); }

.life-step__top { display: flex; align-items: center; justify-content: space-between; }
.life-step__icon {
  width: 38px; height: 38px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  background: rgba(140,101,247,0.10);
  border: 1px solid rgba(140,101,247,0.22);
  color: var(--color-accent);
}
.life-step__icon .icon { width: 19px; height: 19px; }
.life-step__num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}
.life-step__verb {
  font-family: var(--font-display);
  font-size: 25px;
  line-height: 1.1;
  letter-spacing: -0.6px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}
.life-step__def { font-size: 13px; line-height: 20px; color: var(--color-text-secondary); }
.life-step__state {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-accent);
  padding-top: 14px;
  border-top: 1px solid var(--color-border);
}
.life-step__state::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--color-accent);
}
/* the payoff state seals affirm-green */
.life-step--final .life-step__state { color: var(--color-affirm); }
.life-step--final .life-step__state::before { background: var(--color-affirm); }
.life-step--final .life-step__icon {
  background: rgba(16,185,129,0.10);
  border-color: rgba(16,185,129,0.24);
  color: var(--color-affirm);
}

.lifecycle__moat {
  margin-top: 40px;
  padding-top: 26px;
  border-top: 1px solid var(--color-border);
  font-family: var(--font-display);
  font-size: 23px;
  line-height: 32px;
  letter-spacing: -0.4px;
  color: var(--color-text-primary);
  max-width: 720px;
}
.lifecycle__moat em { font-style: italic; color: var(--color-accent); }


/* ─── PINNED LIFE-OF-A-DECISION SCRUB ─────────────────────────────────────
 * The five owned verbs become a scroll-driven assembly of one real record.
 * Progressive disclosure is JS-applied (.is-scrubbing); the no-JS / reduced-
 * motion / narrow baseline shows the fully assembled, sealed record and the
 * full spine. Pin + scrub are desktop-only.
 */
.lifescroll { --life-progress: 1; margin-top: 40px; }
.lifescroll__head {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 760px;
  margin-bottom: 34px;
}
.lifescroll__grid {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 56px;
  align-items: center;
}

/* LEFT — the owned-verb spine, ruled like a register with a fill rail */
.lifescroll__rail {
  position: relative;
  padding-left: 28px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  list-style: none;
  margin: 0;
}
.lifescroll__rail::before {
  content: '';
  position: absolute;
  left: 0; top: 6px; bottom: 6px;
  width: 1px;
  background: var(--color-border);
}
.lifescroll__rail::after {
  content: '';
  position: absolute;
  left: 0; top: 6px;
  width: 1px; height: calc(100% - 12px);
  background: var(--color-accent);
  transform: scaleY(var(--life-progress));
  transform-origin: top;
  transition: transform 0.18s linear;
}
.lifescroll__step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
}
.lifescroll__num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  padding-top: 5px;
}
.lifescroll__verb {
  display: flex;
  align-items: center;
  gap: 11px;
  font-family: var(--font-display);
  font-size: 23px;
  line-height: 1.1;
  letter-spacing: -0.6px;
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  margin-bottom: 7px;
}
.lifescroll__verb-ic {
  display: inline-grid;
  place-items: center;
  width: 30px; height: 30px;
  border-radius: 8px;
  background: rgba(140,101,247,0.10);
  border: 1px solid rgba(140,101,247,0.22);
  color: var(--color-accent);
}
.lifescroll__verb-ic .icon { width: 16px; height: 16px; }
.lifescroll__def { font-size: 13px; line-height: 20px; color: var(--color-text-secondary); }

/* RIGHT — the record, assembling */
.lifescroll__stage { position: relative; }
.lifecard { width: 100%; }
.lifecard .pf-main.lifecard__main {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 22px 24px 26px;
  min-height: 0;
}
/* per-block layout (the generic .lifecard__block only carries the reveal hook) */
.lifecard__options { display: flex; flex-direction: column; gap: 8px; }
.lifecard__replay,
.lifecard__compound { display: flex; gap: 12px; align-items: center; font-size: 13px; line-height: 19px; color: var(--color-text-secondary); }
.lifecard__replay b,
.lifecard__compound b { color: var(--color-text-primary); font-weight: var(--weight-medium); }
.lifecard__defend { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lifecard__line-ic {
  flex: none;
  display: inline-grid; place-items: center;
  width: 26px; height: 26px;
  border-radius: 7px;
  background: rgba(140,101,247,0.10);
  border: 1px solid rgba(140,101,247,0.20);
  color: var(--color-accent);
}
.lifecard__line-ic .icon { width: 14px; height: 14px; }

/* the mini graph, inline */
.lifecard__links { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lifecard__node {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
  border-radius: 5px;
  padding: 3px 7px;
  background: var(--color-surface-1);
}
.lifecard__node--cur { color: var(--color-accent); border-color: var(--color-border-accent); }
.lifecard__edge { width: 16px; height: 1px; background: var(--color-text-muted); opacity: 0.45; }
.lifecard__links-note { font-size: 12px; color: var(--color-text-muted); margin-left: 4px; }

/* the sign-offs hold */
.lifecard__defend-note {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12.5px; color: var(--color-affirm); margin-left: 4px;
}
.lifecard__defend-note .icon { width: 14px; height: 14px; color: var(--color-affirm); }

/* status pills: default = Sealed (final). Draft surfaces only while scrubbing pre-seal.
   .lifecard prefix raises specificity above .pf-pill (product.css loads later). */
.lifecard .lifecard__pill-draft { display: none; color: var(--color-caution); }
.lifecard .lifecard__pill-draft .icon { color: var(--color-caution); opacity: 0.85; }

/* ── SCRUB (desktop + JS): pin the stage and disclose the record by step ── */
@media (min-width: 901px) {
  .lifescroll.is-scrubbing { height: 360vh; }
  .lifescroll.is-scrubbing .lifescroll__sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0;
  }

  /* dim the non-active verbs */
  .lifescroll.is-scrubbing .lifescroll__step { opacity: 0.34; transition: opacity 0.45s var(--ease-out); }
  .lifescroll.is-scrubbing[data-step="0"] .lifescroll__step:nth-child(1),
  .lifescroll.is-scrubbing[data-step="1"] .lifescroll__step:nth-child(2),
  .lifescroll.is-scrubbing[data-step="2"] .lifescroll__step:nth-child(3),
  .lifescroll.is-scrubbing[data-step="3"] .lifescroll__step:nth-child(4),
  .lifescroll.is-scrubbing[data-step="4"] .lifescroll__step:nth-child(5) { opacity: 1; }

  /* progressive disclosure of the record (space is reserved, so no reflow) */
  .lifescroll.is-scrubbing .lifecard__block {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.55s var(--ease-out), transform 0.55s var(--ease-out);
  }
  .lifescroll.is-scrubbing .lifecard__options { opacity: 1; transform: none; }
  .lifescroll.is-scrubbing.is-sealed     .lifecard__seal     { opacity: 1; transform: none; }
  .lifescroll.is-scrubbing.is-replayable .lifecard__replay   { opacity: 1; transform: none; }
  .lifescroll.is-scrubbing.is-linked     .lifecard__compound { opacity: 1; transform: none; }
  .lifescroll.is-scrubbing.is-defended   .lifecard__defend   { opacity: 1; transform: none; }

  /* the seal flips the status pill and reveals the sealed time */
  .lifescroll.is-scrubbing .lifecard__time { opacity: 0; transition: opacity 0.5s var(--ease-out); }
  .lifescroll.is-scrubbing.is-sealed .lifecard__time { opacity: 1; }
  .lifescroll.is-scrubbing:not(.is-sealed) .lifecard__pill-sealed { display: none; }
  .lifescroll.is-scrubbing:not(.is-sealed) .lifecard__pill-draft  { display: inline-flex; }
}

/* ── NARROW: stack the spine over the record, no pin ── */
@media (max-width: 900px) {
  .lifescroll { margin-top: 28px; }
  .lifescroll__grid { grid-template-columns: 1fr; gap: 32px; }
}


/* ─── PINNED GRAPH COMPOUND ────────────────────────────────────────────────
 * Reuses the .lifescroll pin (data-graphscroll drives a separate build). The
 * graph assembles node by node as you scroll; the static baseline (no-JS /
 * reduced-motion / narrow) shows the whole graph. */
[data-graphscroll] .lifescroll__grid { grid-template-columns: 1fr; }
[data-graphscroll] .graphscroll__stage { max-width: 820px; }
[data-graphscroll] .graph-node { cursor: default; }

@media (min-width: 901px) {
  /* armed while scrubbing: hide everything past the first node, reveal cumulatively */
  [data-graphscroll].is-scrubbing .graph-node,
  [data-graphscroll].is-scrubbing .graph-edge {
    opacity: 0;
    transition: opacity 0.5s var(--ease-out);
  }
  [data-graphscroll].is-scrubbing .graph-edge--supersedes,
  [data-graphscroll].is-scrubbing .graph-edge--reconciles {
    stroke-dasharray: 1;
    stroke-dashoffset: 1;
    transition: opacity 0.35s linear, stroke-dashoffset 0.7s var(--ease-out);
  }
  [data-graphscroll].is-scrubbing .graph-legend-item {
    opacity: 0.3;
    transition: opacity 0.4s var(--ease-out);
  }

  /* the baseline record is always present */
  [data-graphscroll].is-scrubbing .graph-node[data-n="0"] { opacity: 1; }

  /* one record (and its relationships) joins per step */
  [data-graphscroll].is-scrubbing.g-n1 .graph-node[data-n="1"],
  [data-graphscroll].is-scrubbing.g-n1 .graph-edge[data-e="1"],
  [data-graphscroll].is-scrubbing.g-n1 .graph-legend-item--references { opacity: 1; }
  [data-graphscroll].is-scrubbing.g-n2 .graph-node[data-n="2"],
  [data-graphscroll].is-scrubbing.g-n2 .graph-edge[data-e="2"] { opacity: 1; }
  [data-graphscroll].is-scrubbing.g-n3 .graph-node[data-n="3"],
  [data-graphscroll].is-scrubbing.g-n3 .graph-edge[data-e="3"],
  [data-graphscroll].is-scrubbing.g-n3 .graph-legend-item--supersedes { opacity: 1; }
  [data-graphscroll].is-scrubbing.g-n4 .graph-node[data-n="4"],
  [data-graphscroll].is-scrubbing.g-n4 .graph-edge[data-e="4"],
  [data-graphscroll].is-scrubbing.g-n4 .graph-legend-item--reconciles { opacity: 1; }

  /* solid edges stroke-draw when their step is reached */
  [data-graphscroll].is-scrubbing.g-n3 .graph-edge[data-e="3"],
  [data-graphscroll].is-scrubbing.g-n4 .graph-edge[data-e="4"] { stroke-dashoffset: 0; }
}

@media (max-width: 900px) {
  .lifecycle__track { grid-template-columns: 1fr; }
  .life-step { padding: 22px 0; min-height: 0; }
  .life-step:first-child { padding-top: 0; }
  .life-step + .life-step { border-left: none; border-top: 1px solid var(--color-border); }
  .life-step__state { margin-top: 10px; }
  .lifecycle__heading { font-size: 32px; line-height: 38px; }
  .lifecycle__moat { font-size: 19px; line-height: 27px; }
}


/* ─── EDGE-CASE CARDS (shared across use-case pages) ─────────────────────── */

.edgecases { padding-block: var(--section-py); }
.edgecases__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--section-px);
}
.edgecases__head { max-width: 700px; margin: 0 auto 40px; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center; }
.edgecases__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.edgecase {
  padding: 28px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-surface-0);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.edgecase__icon {
  width: 38px; height: 38px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  background: rgba(140,101,247,0.10);
  border: 1px solid rgba(140,101,247,0.22);
  color: var(--color-accent);
}
.edgecase__title {
  font-family: var(--font-display);
  font-size: 20px;
  line-height: 26px;
  letter-spacing: -0.4px;
  color: var(--color-text-primary);
  font-weight: var(--weight-medium);
}
.edgecase__body { font-size: 14px; line-height: 22px; color: var(--color-text-secondary); }
.edgecase__tag {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding-top: 14px;
  border-top: 1px solid var(--color-border);
}


/* ─── SCROLL REVEAL ──────────────────────────────────────────────────────── */

/* Hidden state applies only when JS is active. No-JS users see everything. */
.js .reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity  var(--duration-slow) var(--ease-out),
    transform var(--duration-slow) var(--ease-out);
}

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

.reveal--delay-1 { transition-delay: 100ms; }
.reveal--delay-2 { transition-delay: 200ms; }
.reveal--delay-3 { transition-delay: 300ms; }


/* ─── RESPONSIVE ─────────────────────────────────────────────────────────── */

@media (max-width: 900px) {
  .hero,
  .concession__inner,
  .deployment__inner,
  .anchor,
  .testimonials {
    grid-template-columns: minmax(0, 1fr);
    gap: 48px;
  }

  .hero__heading { font-size: 44px; line-height: 49px; letter-spacing: -2px; overflow-wrap: break-word; }
  .pillars__grid { grid-template-columns: 1fr; }
  .pillar:first-child, .pillar:last-child { border-radius: var(--radius-card); }
  .edgecases__grid { grid-template-columns: 1fr; }
  .metrics { grid-template-columns: 1fr; }
  .metric:first-child, .metric:last-child { border-radius: var(--radius-card); }
  .close-cta__heading { font-size: 40px; line-height: 46px; }

  :root {
    --section-px: 24px;
    --section-py: 64px;
  }

  .nav { padding-inline: 16px; }
}
