/* Marquee — bold-statement homepage (v2) */

.mq {
  background: var(--neutral-25);
  color: var(--text-primary);
  font-family: var(--font-sans);
}

/* ── Ticker ─────────────────────────────────────────────────── */
.mq-tick {
  background: var(--navy-700);
  color: rgba(255,255,255,0.78);
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mq-tick__inner {
  display: inline-flex;
  align-items: center;
  gap: 64px;
  white-space: nowrap;
  padding: 14px 0;
  font: var(--fw-medium) 12px/1 var(--font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  animation: mq-scroll 60s linear infinite;
}
.mq-tick__inner span { display: inline-flex; align-items: center; gap: 12px; }
.mq-tick__inner b { color: #fff; font-weight: 700; }
.mq-tick__inner .dot { width: 4px; height: 4px; border-radius: 999px; background: var(--orange-500); }
.mq-tick__inner em { font-style: normal; color: var(--orange-300); }
@keyframes mq-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .mq-tick__inner { animation: none; }
}

/* ── Nav ────────────────────────────────────────────────────── */
.mq-nav {
  position: absolute; top: 56px; left: 0; right: 0; z-index: 5;
  display: flex; align-items: center;
  padding: 0 64px;
  gap: 40px;
}
.mq-nav .logo {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none;
  font: var(--fw-bold) 16px/1 var(--font-display);
  color: #fff;
  letter-spacing: -0.01em;
}
.mq-nav .logo img { height: 26px; width: auto; filter: brightness(0) invert(1); }
.mq-nav .links { display: flex; gap: 28px; margin-left: auto; }
.mq-nav .links a {
  font: var(--fw-medium) 13px/1 var(--font-sans);
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  padding: 6px 0;
}
.mq-nav .links a:hover { color: #fff; }
.mq-nav .cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--orange-500); color: #fff;
  padding: 12px 18px; border-radius: 999px;
  font: var(--fw-semibold) 13px/1 var(--font-sans);
  text-decoration: none;
}
.mq-nav .cta:hover { background: var(--orange-600); }

/* ── Hero ───────────────────────────────────────────────────── */
.mq-hero {
  position: relative;
  background: var(--navy-800);
  color: #fff;
  min-height: 100vh;
  display: grid;
  grid-template-columns: 64px 1fr;
  align-items: end;
  padding: 200px 64px 88px;
  overflow: hidden;
}
.mq-hero::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(1200px 600px at 90% 20%, rgba(240,88,40,0.18), transparent 60%),
    radial-gradient(800px 400px at 10% 80%, rgba(32,168,224,0.12), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
/* Connected-network canvas — sits behind nav/content, ahead of the radial gradient */
.mq-hero__network {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: screen;
  opacity: 0.85;
}

/* Same network on the anti-list (dark) section */
.mq-anti {
  position: relative;
  overflow: hidden;
}
.mq-anti__network {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: screen;
  opacity: 0.75;
}
.mq-anti__inner {
  position: relative;
  z-index: 1;
}
.mq-hero__vol,
.mq-hero__inner,
.mq-hero__foot {
  position: relative;
  z-index: 2;
}
/* vertical volume mark */
.mq-hero__vol {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.36em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  align-self: center;
  justify-self: start;
}
.mq-hero__vol b { color: var(--orange-300); font-weight: 600; }

.mq-hero__inner { position: relative; z-index: 2; min-width: 0; }

.mq-hero__giant {
  font: var(--fw-bold) clamp(72px, 12vw, 196px)/0.9 var(--font-display);
  letter-spacing: -0.05em;
  margin: 0;
  text-wrap: balance;
  max-width: 1180px;
}
.mq-hero__giant em {
  font-style: normal;
  color: var(--orange-500);
  display: inline-block;
  position: relative;
}
.mq-hero__giant em::after {
  /* Underline retired by design directive — no underline on hero accent words. */
  content: none;
  display: none;
}

.mq-hero__foot {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: flex-end;
  gap: 40px;
  margin-top: 80px;
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.mq-hero__foot p {
  font: 400 20px/1.5 var(--font-sans);
  color: rgba(255,255,255,0.75);
  margin: 0;
  max-width: 540px;
}
.mq-hero__foot .actions {
  display: flex; gap: 10px;
}
.mq-hero__foot .actions a {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 22px; border-radius: 999px;
  font: var(--fw-semibold) 14px/1 var(--font-sans);
  text-decoration: none;
}
.mq-hero__foot .actions a.p { background: #fff; color: var(--navy-800); }
.mq-hero__foot .actions a.s { color: #fff; border: 1px solid rgba(255,255,255,0.3); }

/* ── Statement bands ────────────────────────────────────────── */
.mq-band {
  padding: 140px 64px;
  border-bottom: 1px solid var(--neutral-100);
  background: var(--neutral-25);
}
.mq-band__grid {
  display: grid;
  grid-template-columns: 200px 1fr 280px;
  gap: 56px;
  align-items: start;
  max-width: 1440px;
  margin: 0 auto;
}
.mq-band__num {
  font: var(--fw-bold) 88px/0.9 var(--font-display);
  letter-spacing: -0.04em;
  color: var(--orange-500);
}
.mq-band__num small {
  display: block;
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.18em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-top: 14px;
}
.mq-band__statement {
  font: var(--fw-bold) clamp(40px, 4.8vw, 72px)/1.05 var(--font-display);
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--text-primary);
  text-wrap: balance;
}
.mq-band__statement em {
  font-style: normal;
  color: var(--orange-500);
}
.mq-band__support {
  font: 400 16px/1.6 var(--font-sans);
  color: var(--text-secondary);
  margin: 0;
  padding-top: 14px;
  border-top: 2px solid var(--navy-600);
}
.mq-band--alt {
  background: var(--neutral-50);
}

/* Poster band — single full-bleed statement, no number */
.mq-poster {
  background: var(--neutral-25);
  padding: 180px 64px;
  border-bottom: 1px solid var(--neutral-100);
}
.mq-poster__inner {
  max-width: 1440px; margin: 0 auto;
  position: relative;
}
.mq-poster .mark {
  position: absolute; top: -32px; left: 0;
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--orange-600);
}
.mq-poster h2 {
  font: var(--fw-bold) clamp(56px, 8.4vw, 144px)/0.92 var(--font-display);
  letter-spacing: -0.045em;
  margin: 0;
  text-wrap: balance;
  max-width: 1200px;
}
.mq-poster h2 em {
  font-style: italic;
  font-weight: 400;
  color: var(--orange-500);
}

/* "We don't" anti-list */
.mq-anti {
  background: var(--navy-700);
  color: #fff;
  padding: 140px 64px;
  border-bottom: 1px solid var(--navy-800);
}
.mq-anti__inner {
  max-width: 1440px; margin: 0 auto;
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 80px;
  align-items: start;
}
.mq-anti h2 {
  font: var(--fw-bold) clamp(36px, 4vw, 56px)/1.05 var(--font-display);
  letter-spacing: -0.025em;
  margin: 0 0 16px;
  color: #fff;
}
.mq-anti .sub {
  font: 400 15px/1.6 var(--font-sans);
  color: rgba(255,255,255,0.65);
  margin: 0;
  padding-top: 14px;
  border-top: 2px solid var(--orange-500);
}
.mq-anti__list { display: flex; flex-direction: column; }
.mq-anti__row {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: 32px;
  align-items: center;
  padding: 32px 0;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.mq-anti__row:last-child { border-bottom: 1px solid rgba(255,255,255,0.12); }
.mq-anti__row .x {
  font: var(--fw-bold) 32px/1 var(--font-display);
  color: var(--orange-500);
  text-align: center;
}
.mq-anti__row h3 {
  font: var(--fw-bold) clamp(28px, 2.6vw, 40px)/1.1 var(--font-display);
  letter-spacing: -0.02em;
  margin: 0;
  color: #fff;
}
.mq-anti__row h3 small {
  display: block;
  font: 400 14px/1.5 var(--font-sans);
  letter-spacing: 0;
  color: rgba(255,255,255,0.62);
  margin-top: 8px;
  text-transform: none;
}
.mq-anti__row .ref {
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}

/* ── Portfolio — poster typography list ─────────────────────── */
.mq-folio {
  background: var(--neutral-25);
  padding: 120px 0 80px;
}
.mq-folio__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 0 64px;
  gap: 40px;
  margin-bottom: 24px;
  max-width: 1440px;
  margin-left: auto; margin-right: auto;
}
.mq-folio__head h2 {
  font: var(--fw-bold) clamp(48px, 5.2vw, 80px)/1.0 var(--font-display);
  letter-spacing: -0.03em;
  margin: 0;
  max-width: 720px;
}
.mq-folio__head .lede {
  font: 400 18px/1.55 var(--font-sans);
  color: var(--text-secondary);
  margin: 16px 0 0;
  max-width: 560px;
}
.mq-folio__head .meta {
  font: var(--fw-medium) 12px/1.5 var(--font-mono);
  letter-spacing: 0.1em;
  color: var(--text-muted);
  text-transform: uppercase;
  text-align: right;
}
.mq-folio__head .meta b { display: block; font: var(--fw-bold) 36px/1 var(--font-display); color: var(--text-primary); letter-spacing: -0.01em; margin-bottom: 4px; text-transform: none; }

/* ── Scrolly story sections — one brief per company ─────────── */
.mq-story {
  border-top: 1px solid var(--neutral-200);
  background: var(--neutral-25);
  padding: 96px 64px;
  scroll-margin-top: 80px;
}
.mq-story__inner {
  max-width: 1440px; margin: 0 auto;
  display: grid;  grid-template-columns: 1.25fr 0.85fr;
  gap: 80px;
  align-items: center;
}
.mq-story.flip .mq-story__copy { order: 2; }
.mq-story.flip .mq-story__visual { order: 1; }
.mq-story.flip .mq-story__inner { grid-template-columns: 0.85fr 1.25fr; }

/* Copy column */
.mq-story__copy {
  /* Grid items default to min-content min-width; with long unbreakable
     tokens (e.g. "Cap-table-of-record") that pushes the column past its
     fr ratio and crushes the visual column. Allow shrinkage instead. */
  min-width: 0;
}
.mq-story__eyebrow {
  display: inline-flex; gap: 16px; align-items: center;
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 32px;
}
.mq-story__eyebrow .num {
  color: var(--c, var(--orange-500));
  font-weight: 700;
}
.mq-story__eyebrow .sep {
  width: 24px; height: 1px; background: currentColor; opacity: 0.4;
}
.mq-story__name {
  font: var(--fw-bold) clamp(72px, 9vw, 136px)/0.92 var(--font-display);
  letter-spacing: -0.045em;
  margin: 0 0 28px;
  color: var(--text-primary);
}
.mq-story__pitch {
  font: var(--fw-medium) 24px/1.4 var(--font-sans);
  color: var(--text-primary);
  margin: 0 0 24px;
  max-width: 600px;
  text-wrap: balance;
}
.mq-story__brief {
  font: 400 16px/1.7 var(--font-sans);
  color: var(--text-secondary);
  margin: 0 0 36px;
  max-width: 580px;
}
.mq-story__stats {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 36px;
  margin: 0 0 36px;
  padding-top: 24px;
  border-top: 2px solid var(--c, var(--orange-500));
  max-width: 600px;
}
.mq-story__stats > div b {
  display: block;
  font: var(--fw-bold) 28px/1 var(--font-mono);
  color: var(--text-primary);
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}
.mq-story__stats > div b.dash { color: var(--text-faint); font-weight: 500; }
.mq-story__stats > div span {
  font: var(--fw-medium) 10px/1.3 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-muted);
}
.mq-story__link {
  display: inline-flex; align-items: center; gap: 12px;
  font: var(--fw-semibold) 15px/1 var(--font-sans);
  color: var(--c, var(--orange-600));
  text-decoration: none;
  padding-bottom: 8px;
  border-bottom: 2px solid currentColor;
  transition: gap 180ms cubic-bezier(.2,.7,.2,1);
}
.mq-story__link:hover { gap: 18px; }
.mq-story__link[aria-disabled="true"] {
  color: var(--text-muted);
  cursor: not-allowed;
  pointer-events: none;
}
.mq-story__specs {
  margin-top: 28px;
  display: flex; gap: 24px; flex-wrap: wrap;
  font: 400 13px/1.4 var(--font-sans);
  color: var(--text-muted);
}
.mq-story__specs span b {
  display: block;
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 6px;
}
.mq-story__specs span {
  display: flex; flex-direction: column;
}
.mq-story__specs span em {
  font-style: normal; color: var(--text-primary); font-weight: 500;
}

/* Visual placeholder — now a link to the company's portfolio page */
.mq-story__visual {
  position: relative;
  aspect-ratio: 4 / 5;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  overflow: hidden;
  background:
    radial-gradient(80% 60% at 30% 20%, color-mix(in oklab, var(--c) 18%, transparent) 0%, transparent 70%),
    var(--cb, var(--orange-50));
  display: grid; place-items: center;
  isolation: isolate;
}
.mq-story__visual::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--c) 1px, transparent 1px),
    linear-gradient(90deg, var(--c) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity: 0.05;
  pointer-events: none;
}
.mq-story__visual .letter {
  font: var(--fw-bold) clamp(160px, 22vw, 260px)/1 var(--font-display);
  color: var(--c, var(--orange-500));  letter-spacing: -0.06em;
  opacity: 0.22;
  display: block;
  text-align: center;
}
.mq-story__visual .tag {
  position: absolute; top: 20px; left: 20px;
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--c, var(--orange-700));
  padding: 8px 12px; border-radius: 999px;
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.6);
  display: inline-flex; align-items: center; gap: 8px;
}
.mq-story__visual .tag::before {
  content: ""; width: 6px; height: 6px; border-radius: 999px; background: currentColor;
}
.mq-story__visual .caption {
  position: absolute; bottom: 20px; left: 20px; right: 20px;
  font: 400 13px/1.5 var(--font-sans);
  color: var(--text-secondary);
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(6px);
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.6);
}
a.mq-story__visual {
  text-decoration: none;
  color: inherit;
  display: grid;
  place-items: center;
}

/* Mark (logo/icon) — replaces the giant letter for branded entries */
.mq-story__mark {
  position: relative;
  z-index: 1;
  width: 81%;
  max-width: 402px;
  height: auto;
  display: block;
  margin: 0 auto;
  filter: drop-shadow(0 6px 18px rgba(45,56,72,0.18));
  transition: transform 480ms cubic-bezier(.16,.85,.3,1);
}
/* FR mark on the "coming next" card — 50% larger per design intent */
#next .mq-story__mark {
  width: 84%;
  max-width: 420px;
}
.mq-story:hover .mq-story__mark {
  transform: translateY(-4px) scale(1.04);
}

.mq-story__visual .caption b {
  display: block;
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--c, var(--orange-700));
  margin-bottom: 6px;
}

/* The list */
.mq-folio__list {
  max-width: 1440px; margin: 0 auto;
  padding: 0 64px;
}
.mq-folio__row {
  display: grid;
  grid-template-columns: 64px 1fr 1.1fr 180px;
  gap: 40px;
  padding: 36px 0;
  border-top: 1px solid var(--neutral-200);
  align-items: baseline;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: padding 220ms cubic-bezier(.2,.7,.2,1), background 220ms ease;
}
.mq-folio__row:last-child { border-bottom: 1px solid var(--neutral-200); }
.mq-folio__row:hover { padding-left: 20px; background: rgba(240,88,40,0.025); }

/* the brand color is the only "color" — as a left rule + tiny dot */
.mq-folio__row .rule {
  position: absolute; left: 0; top: 36px; bottom: 36px;
  width: 4px; border-radius: 2px;
  background: var(--c, var(--neutral-300));
}
.mq-folio__row .num {
  font: var(--fw-semibold) 12px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-muted);
  padding-top: 12px;
}
.mq-folio__row .name {
  font: var(--fw-bold) clamp(40px, 4.6vw, 72px)/0.95 var(--font-display);
  letter-spacing: -0.035em;
  margin: 0;
  color: var(--text-primary);
}
.mq-folio__row .name .sector {
  display: block;
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 14px;
}
.mq-folio__row .pitch {
  font: 400 18px/1.5 var(--font-sans);
  color: var(--text-secondary);
  margin: 0;
  text-wrap: balance;
  padding-top: 8px;
}
.mq-folio__row .stat {
  text-align: right;
  display: flex; flex-direction: column; gap: 8px; align-items: flex-end;
  padding-top: 8px;
}
.mq-folio__row .stat .arr {
  font: var(--fw-bold) clamp(24px, 2.4vw, 36px)/1 var(--font-mono);
  color: var(--text-primary);
  letter-spacing: -0.01em;
}
.mq-folio__row .stat .arr.dash { color: var(--text-faint); font-weight: 500; }
.mq-folio__row .stat .stage {
  font: var(--fw-medium) 11px/1 var(--font-sans);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-muted);
  display: inline-flex; align-items: center; gap: 8px;
}
.mq-folio__row .stat .stage::before {
  content: ""; width: 7px; height: 7px; border-radius: 999px; background: var(--c, var(--neutral-300));
}

/* ── Numbers band (navy) ───────────────────────────────────── */
.mq-numbers {
  background: var(--navy-800);
  color: #fff;
  padding: 120px 64px;
}
.mq-numbers__head {
  max-width: 1440px; margin: 0 auto 64px;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 40px;
}
.mq-numbers__head h2 {
  font: var(--fw-bold) clamp(36px, 3.6vw, 48px)/1.1 var(--font-display);
  letter-spacing: -0.02em;
  margin: 0;
  max-width: 600px;
}
.mq-numbers__head .meta {
  font: var(--fw-medium) 12px/1.5 var(--font-mono);
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.1em; text-transform: uppercase;
  text-align: right;
}
.mq-numbers__grid {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.12);
}
.mq-numbers__cell {
  background: var(--navy-800);
  padding: 56px 40px;
  display: flex; flex-direction: column; gap: 18px;
}
.mq-numbers__cell .v {
  font: var(--fw-bold) clamp(64px, 7vw, 112px)/0.9 var(--font-display);
  letter-spacing: -0.035em;
  color: var(--orange-300);
}
.mq-numbers__cell .l {
  font: var(--fw-semibold) 13px/1 var(--font-sans);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-top: auto;
}
.mq-numbers__cell .desc {
  font: 400 15px/1.55 var(--font-sans);
  color: rgba(255,255,255,0.78);
  margin: 0;
  max-width: 320px;
}

/* CTA link beneath the numbers grid — sends users to the full services page */
.mq-numbers__foot {
  max-width: 1440px;
  margin: 48px auto 0;
  display: flex; justify-content: flex-end;
}
.mq-numbers__cta {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 18px 26px 18px 30px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.16);
  color: #fff;
  font: var(--fw-semibold) 14px/1 var(--font-sans);
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: background 220ms ease, border-color 220ms ease, transform 220ms ease, gap 220ms ease;
}
.mq-numbers__cta em {
  font-style: normal;
  font: var(--fw-bold) 18px/1 var(--font-display);
  color: var(--orange-300);
  transition: transform 220ms cubic-bezier(.16,.85,.3,1);
}
.mq-numbers__cta:hover {
  background: var(--orange-500);
  border-color: var(--orange-500);
  transform: translateY(-2px);
  gap: 18px;
}
.mq-numbers__cta:hover em { color: #fff; transform: translateX(4px); }

/* ── CTA strip ─────────────────────────────────────────────── */
.mq-cta {
  background: var(--orange-500);
  color: #fff;
  padding: 140px 64px;
  position: relative;
  overflow: hidden;
}
.mq-cta__inner {
  max-width: 1440px; margin: 0 auto;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 36px;
}
.mq-cta h2 {
  font: var(--fw-bold) clamp(56px, 7vw, 120px)/0.95 var(--font-display);
  letter-spacing: -0.04em;
  margin: 0;
  text-wrap: balance;
  max-width: 1100px;
}
.mq-cta p {
  font: 400 20px/1.5 var(--font-sans);
  color: rgba(255,255,255,0.88);
  margin: 0;
  max-width: 600px;
}
.mq-cta .actions {
  display: flex; gap: 12px;
  margin-top: 8px;
}
.mq-cta .actions a {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 18px 28px; border-radius: 999px;
  font: var(--fw-semibold) 15px/1 var(--font-sans);
  text-decoration: none;
}
.mq-cta .actions .p { background: var(--navy-800); color: #fff; }
.mq-cta .actions .s { color: #fff; border: 1.5px solid rgba(255,255,255,0.5); }

/* ── Foot ───────────────────────────────────────────────────── */
.mq-foot {
  background: var(--navy-900);
  color: rgba(255,255,255,0.7);
  padding: 56px 64px 36px;
  font: 400 13px/1.6 var(--font-sans);
}
.mq-foot__inner {
  max-width: 1440px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 40px;
}
.mq-foot__inner .brand img { height: 28px; filter: brightness(0) invert(1); margin-bottom: 12px; }
.mq-foot__inner b { color: #fff; font-weight: 600; }
.mq-foot__inner .meta { text-align: right; font: var(--fw-medium) 12px/1.6 var(--font-mono); letter-spacing: 0.08em; color: rgba(255,255,255,0.5); text-transform: uppercase; }

/* ═══════════════════════════════════════════════════════════════════════════
   ANIMATION LAYER
   ═══════════════════════════════════════════════════════════════════════════
   data-reveal       — base fade-up
   data-reveal-hero  — reveals immediately (above the fold)
   data-reveal-visual — bigger lift + slight scale (Apple-y product reveal)
   data-reveal-name   — clip-style reveal for the giant brand name
   --d                — per-element transition-delay
   --p                — scroll parallax progress, set by JS, 0..1
*/
[data-js]:not([data-fallback]) [data-reveal],
[data-js]:not([data-fallback]) [data-reveal-hero] {
  opacity: 0;
  transform: translateY(48px);
  transition:
    opacity 800ms cubic-bezier(.2,.7,.2,1),
    transform 1000ms cubic-bezier(.16,.85,.3,1);
  transition-delay: var(--d, 0ms);
  will-change: transform, opacity;
}
[data-js] [data-reveal][data-revealed],
[data-js] [data-reveal-hero][data-revealed] {
  opacity: 1;
  transform: none;
}

/* Dramatic product-reveal for the story visuals */
[data-js]:not([data-fallback]) .mq-story__visual[data-reveal-visual] {
  opacity: 0;
  transform: translateY(80px) scale(0.86);
  transition:
    opacity 1000ms cubic-bezier(.16,.85,.3,1),
    transform 1400ms cubic-bezier(.16,.85,.3,1),
    box-shadow 1400ms cubic-bezier(.16,.85,.3,1);
  transition-delay: var(--d, 0ms);
  box-shadow: 0 0 0 rgba(45, 56, 72, 0);
  will-change: transform, opacity, box-shadow;
}
[data-js] .mq-story__visual[data-reveal-visual][data-revealed] {
  opacity: 1;
  transform: none;
  box-shadow:
    0 30px 60px -20px rgba(45, 56, 72, 0.25),
    0 12px 24px -12px rgba(45, 56, 72, 0.15);
}

/* Per-line stagger for the hero giant headline */
[data-js]:not([data-fallback]) .mq-hero__giant .line {
  display: block;
  opacity: 0;
  transform: translateY(60px);
  transition:
    opacity 900ms cubic-bezier(.2,.7,.2,1),
    transform 1100ms cubic-bezier(.16,.85,.3,1);
  transition-delay: var(--d, 0ms);
  will-change: transform, opacity;
}
[data-js] .mq-hero[data-revealed] .mq-hero__giant .line { opacity: 1; transform: none; }
.mq-hero__giant .line em::after { transition: opacity 600ms ease-out 1100ms; opacity: 0; }
.mq-hero[data-revealed] .mq-hero__giant .line em::after { opacity: 0.55; }

/* Story brand letter — subtle scroll-tied scale & drift (Apple-y depth) */
.mq-story__visual .letter {
  transform: translateY(calc(var(--p, 0) * -16px)) scale(calc(1 + var(--p, 0) * 0.06));
  transition: transform 120ms linear;
  will-change: transform;
}

/* Subtle breathing glow on the orange word — slow, almost imperceptible */
.mq-hero__giant em {
  animation: mq-breath 6s ease-in-out infinite;
}
/* Baseline display:block so lines stack even in the data-fallback case
 * (above the data-js-gated reveal rule that ALSO sets display:block). */
.mq-hero__giant .line { display: block; }
@keyframes mq-breath {
  0%, 100% { filter: brightness(1); }
  50% { filter: brightness(1.08); }
}

/* ── Rotating word ("work / people / talent / clients / services") ─── */
.mq-hero__giant .mq-rotate {
  position: relative;
  display: inline-block;
  vertical-align: baseline;
  text-align: left;
}
.mq-hero__giant .mq-rotate .ghost {
  visibility: hidden;
  display: inline-block;
  white-space: nowrap;
  color: var(--orange-500);
}
.mq-hero__giant .mq-rotate em {
  position: absolute;
  left: 0; top: 0;
  white-space: nowrap;
  opacity: 0;
  animation: mq-rotate-word 14s cubic-bezier(.45, .05, .45, .95) infinite;
  will-change: opacity, transform, filter;
}
.mq-hero__giant .mq-rotate em:nth-of-type(1) { animation-delay: 0s;    }
.mq-hero__giant .mq-rotate em:nth-of-type(2) { animation-delay: 2.8s;  }
.mq-hero__giant .mq-rotate em:nth-of-type(3) { animation-delay: 5.6s;  }
.mq-hero__giant .mq-rotate em:nth-of-type(4) { animation-delay: 8.4s;  }
.mq-hero__giant .mq-rotate em:nth-of-type(5) { animation-delay: 11.2s; }

/* Each word visible during its 20% window, with soft enter/exit */
@keyframes mq-rotate-word {
  0%   { opacity: 0; transform: translateX(-28px); filter: blur(6px); }
  3%   { opacity: 1; transform: translateX(0);    filter: blur(0);   }
  17%  { opacity: 1; transform: translateX(0);    filter: blur(0);   }
  20%  { opacity: 0; transform: translateX(28px); filter: blur(6px); }
  100% { opacity: 0; transform: translateX(-28px); filter: blur(6px); }
}

/* No underline on the rotating words — they enter/exit horizontally */
.mq-hero__giant .mq-rotate em::after { display: none; }

@media (prefers-reduced-motion: reduce) {
  .mq-hero__giant .mq-rotate em { animation: none; }
  .mq-hero__giant .mq-rotate em:nth-of-type(1) { opacity: 1; transform: none; filter: none; }
}

/* Anti-list rows — slide in from left with stagger when revealed */
[data-js]:not([data-fallback]) .mq-anti__row[data-reveal] {
  transform: translateX(-32px);
}
[data-js] .mq-anti__row[data-reveal][data-revealed] { transform: none; }

/* Numbers band — orange digits get a subtle pop-in scale */
[data-js]:not([data-fallback]) .mq-numbers__cell[data-reveal] .v {
  transform: scale(0.9);
  opacity: 0;
  transition: transform 900ms cubic-bezier(.16,.85,.3,1), opacity 700ms ease-out;
  transition-delay: calc(var(--d, 0ms) + 200ms);
  display: inline-block;
}
[data-js] .mq-numbers__cell[data-reveal][data-revealed] .v {
  transform: scale(1);
  opacity: 1;
}

/* Honor reduced motion */
@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  [data-reveal-hero],
  [data-reveal-visual],
  .mq-hero__giant .line,
  .mq-numbers__cell[data-reveal] .v {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .mq-hero__giant em { animation: none !important; }
  .mq-story__visual .letter { transform: none !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   GET IN TOUCH — contact section (replaces the old CTA strip)
   ═══════════════════════════════════════════════════════════════════════════ */
.mq-contact {
  background: var(--navy-800);
  color: #fff;
  padding: 140px 64px;
  position: relative;
  overflow: hidden;
}
.mq-contact::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(900px 500px at 0% 100%, rgba(240,88,40,0.16), transparent 60%),
    radial-gradient(700px 400px at 100% 0%, rgba(32,168,224,0.08), transparent 60%);
  pointer-events: none;
}
.mq-contact__inner {
  position: relative; z-index: 1;
  max-width: 1280px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

/* Left column — the pitch */
.mq-contact__lead .eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font: var(--fw-semibold) 11px/1 var(--font-mono);
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--orange-300);
  padding: 8px 14px; border-radius: 999px;
  background: rgba(240,88,40,0.12);
  border: 1px solid rgba(240,88,40,0.3);
}
.mq-contact__lead .eyebrow::before {
  content: ""; width: 6px; height: 6px; border-radius: 999px;
  background: var(--orange-500);
  box-shadow: 0 0 0 3px rgba(240,88,40,0.25);
  animation: mq-pulse 2.4s ease-in-out infinite;
}
@keyframes mq-pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(240,88,40,0.25); }
  50% { box-shadow: 0 0 0 8px rgba(240,88,40,0); }
}
.mq-contact__lead h2 {
  font: var(--fw-bold) clamp(56px, 7vw, 112px)/0.95 var(--font-display);
  letter-spacing: -0.04em;
  margin: 28px 0 24px;
  color: #fff;
  text-wrap: balance;
}
.mq-contact__lead h2 em {
  font-style: normal;
  color: var(--orange-400);
}
.mq-contact__lead p {
  font: 400 19px/1.55 var(--font-sans);
  color: rgba(255,255,255,0.78);
  margin: 0 0 36px;
  max-width: 520px;
}
.mq-contact__notes {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.mq-contact__notes > div {
  display: flex; flex-direction: column; gap: 6px;
}
.mq-contact__notes > div b {
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.mq-contact__notes > div span {
  font: var(--fw-medium) 15px/1.4 var(--font-sans);
  color: #fff;
}

/* Right column — the form panel */
.mq-form {
  background: #fff;
  color: var(--text-primary);
  border-radius: 24px;
  padding: 40px;
  display: grid;
  gap: 18px;
  box-shadow:
    0 40px 80px -20px rgba(10, 14, 22, 0.5),
    0 16px 32px -12px rgba(10, 14, 22, 0.3);
  position: relative;
  overflow: hidden;
  transition: opacity 400ms ease, transform 400ms ease;
}
.mq-form__head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
  margin-bottom: 4px;
}
.mq-form__head h3 {
  font: var(--fw-bold) 22px/1.2 var(--font-display);
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--text-primary);
}
.mq-form__head small {
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-muted);
}

.mq-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.mq-form__field { display: flex; flex-direction: column; gap: 6px; }
.mq-form__field label {
  font: var(--fw-semibold) 11px/1 var(--font-sans);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-muted);
}
.mq-form__field label .req { color: var(--orange-500); }
.mq-form__field input,
.mq-form__field select,
.mq-form__field textarea {
  font: 400 15px/1.45 var(--font-sans);
  color: var(--text-primary);
  border: 1px solid var(--border-default);
  border-radius: 10px;
  padding: 12px 14px;
  background: #fff;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
  width: 100%;
  outline: none;
  font-family: var(--font-sans);
}
.mq-form__field textarea {
  min-height: 120px;
  resize: vertical;
  font-family: var(--font-sans);
}
.mq-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='8' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%232D3848' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
}
.mq-form__field input:focus,
.mq-form__field select:focus,
.mq-form__field textarea:focus {
  border-color: var(--orange-500);
  box-shadow: 0 0 0 3px rgba(240,88,40,0.18);
}
.mq-form__field input::placeholder,
.mq-form__field textarea::placeholder { color: var(--text-faint); }

.mq-form__foot {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding-top: 8px;
}
.mq-form__legal {
  font: 400 12px/1.45 var(--font-sans);
  color: var(--text-muted);
  max-width: 280px;
}
.mq-form__submit {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--navy-800);
  color: #fff;
  border: 0;
  font: var(--fw-semibold) 15px/1 var(--font-sans);
  padding: 16px 24px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 180ms ease, transform 180ms ease, opacity 180ms ease;
  position: relative;
  min-width: 184px; justify-content: center;
}
.mq-form__submit:hover { background: var(--orange-500); transform: translateY(-1px); }
.mq-form__submit:disabled { opacity: 0.7; cursor: progress; transform: none; }
.mq-form__submit .spinner {
  width: 14px; height: 14px; border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  animation: mq-spin 0.8s linear infinite;
  display: none;
}
.mq-form__submit[data-state="sending"] .spinner { display: inline-block; }
@keyframes mq-spin { to { transform: rotate(360deg); } }

.mq-form__status {
  font: 400 13px/1.5 var(--font-sans);
  color: var(--text-secondary);
  margin: 0;
  min-height: 18px;
}
.mq-form__status[data-state="error"] {
  color: var(--text-danger);
  padding: 10px 14px;
  background: var(--danger-50);
  border-radius: 8px;
  border: 1px solid color-mix(in oklab, var(--danger-500) 25%, #fff);
}

/* Success state — flips the form to a quiet confirmation */
.mq-form__success {
  display: none;
  flex-direction: column; align-items: flex-start; gap: 16px;
  padding: 12px 0;
}
.mq-form__success .check {
  width: 56px; height: 56px;
  border-radius: 999px;
  background: var(--success-50);
  color: var(--success-700);
  display: grid; place-items: center;
  border: 2px solid color-mix(in oklab, var(--success-500) 40%, #fff);
}
.mq-form__success .check svg { width: 28px; height: 28px; }
.mq-form__success h3 {
  font: var(--fw-bold) 24px/1.2 var(--font-display);
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--text-primary);
}
.mq-form__success p {
  font: 400 15px/1.55 var(--font-sans);
  color: var(--text-secondary);
  margin: 0;
}
.mq-form__success a {
  font: var(--fw-semibold) 13px/1 var(--font-sans);
  color: var(--text-link);
  text-decoration: none;
  border-bottom: 1.5px solid currentColor;
  padding-bottom: 4px;
}

.mq-form[data-state="sent"] .mq-form__head,
.mq-form[data-state="sent"] .mq-form__row,
.mq-form[data-state="sent"] .mq-form__field,
.mq-form[data-state="sent"] .mq-form__foot,
.mq-form[data-state="sent"] .mq-form__status { display: none; }
.mq-form[data-state="sent"] .mq-form__success { display: flex; }

/* ═════════════════════════════════════════════════════════════════
   WIZARD — 3-step contact form (with captcha gate)
   ═════════════════════════════════════════════════════════════════ */
.mq-wiz { gap: 22px; }

/* Progress rail */
.mq-wiz__rail {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  list-style: none;
  padding: 0 0 6px;
  margin: 0;
  border-bottom: 1px solid var(--neutral-200);
}
.mq-wiz__rail li {
  display: flex; flex-direction: column; align-items: flex-start; gap: 6px;
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-faint);
  position: relative;
}
.mq-wiz__rail li span {
  display: block; width: 100%; height: 3px; border-radius: 999px;
  background: var(--neutral-200);
  position: relative; overflow: hidden;
}
.mq-wiz__rail li span::after {
  content: "";
  position: absolute; inset: 0;
  background: var(--orange-500);
  transform: scaleX(0); transform-origin: left;
  transition: transform 380ms cubic-bezier(.16,.85,.3,1);
}
.mq-wiz__rail li[data-rail-state="done"] span::after { transform: scaleX(1); }
.mq-wiz__rail li[data-rail-state="active"] span::after { transform: scaleX(0.55); background: var(--navy-700); }
.mq-wiz__rail li[data-rail-state="done"] b,
.mq-wiz__rail li[data-rail-state="active"] b { color: var(--text-primary); }
.mq-wiz__rail b { font-weight: inherit; font-family: inherit; }

/* Step panels */
.mq-wiz__step {
  display: flex; flex-direction: column; gap: 18px;
  animation: mq-wiz-fade-in 380ms cubic-bezier(.16,.85,.3,1);
}
.mq-wiz__step[hidden] { display: none; }
@keyframes mq-wiz-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}
.mq-wiz__step-head h4 {
  font: var(--fw-bold) 22px/1.2 var(--font-display);
  letter-spacing: -0.015em;
  margin: 0 0 8px;
  color: var(--text-primary);
}
.mq-wiz__step-head p {
  font: 400 14px/1.55 var(--font-sans);
  color: var(--text-secondary);
  margin: 0;
  max-width: 56ch;
}

/* Topic choice cards */
.mq-wiz__choices {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.mq-wiz__choice { cursor: pointer; }
.mq-wiz__choice input { position: absolute; opacity: 0; pointer-events: none; }
.mq-wiz__choice-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 16px 14px;
  border: 1.5px solid var(--neutral-200);
  border-radius: 12px;
  background: var(--neutral-25);
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease, box-shadow 180ms ease;
  position: relative;
  height: 100%;
}
.mq-wiz__choice-card .num {
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.18em;
  color: var(--text-muted);
  margin-bottom: 2px;
}
.mq-wiz__choice-card b {
  font: var(--fw-semibold) 14px/1.3 var(--font-sans);
  color: var(--text-primary);
}
.mq-wiz__choice-card small {
  font: 400 12px/1.45 var(--font-sans);
  color: var(--text-secondary);
}
.mq-wiz__choice:hover .mq-wiz__choice-card {
  border-color: var(--orange-300);
  background: #fff;
  transform: translateY(-1px);
}
.mq-wiz__choice input:checked + .mq-wiz__choice-card {
  border-color: var(--orange-500);
  background: var(--orange-50);
  box-shadow: 0 0 0 3px rgba(240,88,40,0.15);
}
.mq-wiz__choice input:checked + .mq-wiz__choice-card .num { color: var(--orange-600); }
.mq-wiz__choice input:focus-visible + .mq-wiz__choice-card { outline: 2px solid var(--orange-500); outline-offset: 2px; }

/* Urgency chips */
.mq-wiz__chips {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.mq-wiz__chips label { cursor: pointer; }
.mq-wiz__chips input { position: absolute; opacity: 0; pointer-events: none; }
.mq-wiz__chips span {
  display: inline-block;
  font: var(--fw-medium) 13px/1 var(--font-sans);
  padding: 10px 14px;
  border-radius: 999px;
  border: 1.5px solid var(--neutral-200);
  color: var(--text-secondary);
  background: var(--neutral-25);
  transition: all 180ms ease;
}
.mq-wiz__chips label:hover span { border-color: var(--orange-300); }
.mq-wiz__chips input:checked + span {
  border-color: var(--orange-500);
  background: var(--orange-50);
  color: var(--orange-700);
}

/* Char counter */
.mq-form__hint {
  font: var(--fw-medium) 11px/1 var(--font-mono);
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-top: 4px;
  align-self: flex-end;
}
.mq-form__hint[data-state="ok"] { color: var(--success-600); }

/* Honeypot — fully hidden but not display:none (bots fill display:none too) */
.mq-form__hp {
  position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden;
}

/* Nav row at the bottom of each step */
.mq-wiz__nav {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding-top: 16px; margin-top: 4px;
  border-top: 1px solid var(--neutral-200);
}
.mq-wiz__nav .mq-wiz__count {
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-muted);
}
.mq-wiz__back {
  background: transparent; border: none; cursor: pointer;
  font: var(--fw-semibold) 13px/1 var(--font-sans);
  color: var(--text-secondary);
  padding: 8px 4px;
  transition: color 180ms ease, transform 180ms ease;
}
.mq-wiz__back:hover { color: var(--text-primary); transform: translateX(-2px); }
.mq-wiz__next:disabled { opacity: 0.4; cursor: not-allowed; transform: none !important; }
.mq-wiz__next:disabled:hover { background: var(--navy-800); }

/* Hide the empty Step-0 left slot so the Begin button stays right-aligned */
.mq-wiz__step[data-step-panel="gate"] .mq-wiz__nav { justify-content: space-between; }

/* ─────────────────────────────────────────────────────────────────
   CAPTCHA — find the orange node
   ───────────────────────────────────────────────────────────────── */
.mq-captcha {
  position: relative;
  background: linear-gradient(135deg, var(--navy-800), var(--navy-700));
  border-radius: 14px;
  overflow: hidden;
  height: 220px;
  border: 1px solid var(--navy-700);
  box-shadow: inset 0 0 60px rgba(0,0,0,0.3);
}
.mq-captcha__board {
  position: absolute; inset: 0; width: 100%; height: 100%;
  cursor: crosshair;
  display: block;
}
.mq-captcha__board .node {
  cursor: pointer;
  transform-origin: center;
  transform-box: fill-box;
  transition: transform 180ms ease;
}
.mq-captcha__board .node:hover { transform: scale(1.25); }
.mq-captcha__board .node[data-target="1"] {
  filter: drop-shadow(0 0 6px var(--orange-500));
  animation: mq-cap-pulse 1.8s ease-in-out infinite;
}
@keyframes mq-cap-pulse {
  0%, 100% { filter: drop-shadow(0 0 4px var(--orange-500)); }
  50%      { filter: drop-shadow(0 0 12px var(--orange-500)) drop-shadow(0 0 4px var(--orange-400)); }
}
.mq-captcha__board .link {
  stroke: rgba(255,255,255,0.18);
  stroke-width: 1;
}
.mq-captcha__hint {
  position: absolute; left: 14px; bottom: 12px; right: 60px;
  font: var(--fw-medium) 12px/1.3 var(--font-mono);
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.75);
  pointer-events: none;
}
.mq-captcha__hint .ok,
.mq-captcha__hint .err { display: none; }
.mq-captcha[data-state="ok"]  .label { display: none; }
.mq-captcha[data-state="ok"]  .ok    { display: inline; color: var(--success-500); }
.mq-captcha[data-state="err"] .label { display: none; }
.mq-captcha[data-state="err"] .err   { display: inline; color: var(--orange-400); }
.mq-captcha[data-state="ok"] {
  border-color: var(--success-500);
  box-shadow: inset 0 0 60px rgba(0,0,0,0.3), 0 0 0 3px rgba(34,184,116,0.25);
}
.mq-captcha[data-state="err"] .mq-captcha__board {
  animation: mq-cap-shake 320ms cubic-bezier(.36,.07,.19,.97);
}
@keyframes mq-cap-shake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(3px); }
  30%, 50%, 70% { transform: translateX(-5px); }
  40%, 60% { transform: translateX(5px); }
}
.mq-captcha__refresh {
  position: absolute; right: 10px; bottom: 10px;
  width: 32px; height: 32px; border-radius: 999px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  color: rgba(255,255,255,0.8);
  font: 600 16px/1 var(--font-mono);
  cursor: pointer;
  display: grid; place-items: center;
  transition: background 180ms ease, transform 180ms ease;
}
.mq-captcha__refresh:hover { background: rgba(255,255,255,0.18); transform: rotate(60deg); }

/* Once verified, swap the form's step-label to "Topic" etc. */
.mq-form[data-step="gate"] [data-wiz-step-label]::before { content: "§ Step 0 · Proof of life"; }
.mq-form[data-step="topic"] [data-wiz-step-label]::before { content: "§ Step 1 · Topic"; }
.mq-form[data-step="details"] [data-wiz-step-label]::before { content: "§ Step 2 · Details"; }
.mq-form[data-step="contact"] [data-wiz-step-label]::before { content: "§ Step 3 · Contact"; }
[data-wiz-step-label] { font-size: 0; }
[data-wiz-step-label]::before {
  font: var(--fw-semibold) 10px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--orange-500);
}

/* When form is "sent", hide all wizard chrome */
.mq-form[data-state="sent"] .mq-wiz__rail,
.mq-form[data-state="sent"] .mq-wiz__step { display: none; }

/* Subtle entrance for the success block */
.mq-form__success .check {
  animation: mq-check-in 600ms cubic-bezier(.16,.85,.3,1);
}
@keyframes mq-check-in {
  0% { transform: scale(0.6); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   AMBIENT MOTION — the whole page is alive
   ═══════════════════════════════════════════════════════════════════════════
   Continuous low-amplitude motion that doesn't compete with content.
   All gated behind `prefers-reduced-motion: no-preference` via the media query
   at the bottom of this file.
*/

/* Hero radial gradients drift slowly — very subtle parallax effect */
.mq-hero::before {
  animation: mq-hero-drift 22s ease-in-out infinite;
  will-change: transform;
}
@keyframes mq-hero-drift {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50%      { transform: translate3d(-2%, 1.5%, 0) scale(1.06); }
}

/* Nav CTA — no animation per design intent */
.mq-nav .cta {
  position: relative;
}

/* Hero foot buttons — slide effect on hover */
.mq-hero__foot .actions a {
  transition: transform 240ms cubic-bezier(.2,.7,.2,1), background 200ms ease, color 200ms ease, gap 200ms ease;
  position: relative;
  overflow: hidden;
}
.mq-hero__foot .actions a:hover { transform: translateY(-2px); gap: 12px; }
.mq-hero__foot .actions a.p:hover { background: var(--orange-500); color: #fff; }
.mq-hero__foot .actions a.s:hover { border-color: rgba(255,255,255,0.7); }

/* Vol mark text shimmers gently — barely there */
.mq-hero__vol {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0.35) 0%,
    rgba(255,255,255,0.7) 50%,
    rgba(255,255,255,0.35) 100%
  );
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-size: 200% 100%;
  animation: mq-shimmer 8s ease-in-out infinite;
}
.mq-hero__vol b { color: var(--orange-300); -webkit-text-fill-color: var(--orange-300); }
@keyframes mq-shimmer {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

/* Statement bands — section number floats infinitesimally */
.mq-band__num {
  animation: mq-band-float 9s ease-in-out infinite;
  will-change: transform;
}
@keyframes mq-band-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* Poster mark dot blinks */
.mq-poster .mark {
  position: relative;
}
.mq-poster .mark::before {
  content: "";
  display: inline-block;
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--orange-500);
  margin-right: 10px;
  vertical-align: middle;
  animation: mq-blink 2.8s ease-in-out infinite;
}
@keyframes mq-blink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.35; transform: scale(0.85); }
}

/* ── Story hover — Apple-y depth on hover ───────────────────────────── */
.mq-story__inner { isolation: isolate; }
.mq-story:hover .mq-story__visual {
  transform: translateY(-6px) scale(1.012);
  box-shadow:
    0 50px 90px -30px rgba(45, 56, 72, 0.35),
    0 20px 40px -16px rgba(45, 56, 72, 0.2);
}
.mq-story:hover .mq-story__visual .letter {
  opacity: 0.34;
}
.mq-story__visual {
  transition:
    opacity 1000ms cubic-bezier(.16,.85,.3,1),
    transform 600ms cubic-bezier(.16,.85,.3,1),
    box-shadow 600ms cubic-bezier(.16,.85,.3,1);
}
.mq-story__visual .letter {
  transition: opacity 400ms ease, transform 120ms linear;
}
.mq-story:hover .mq-story__name {
  background: linear-gradient(135deg, var(--text-primary) 0%, var(--c) 70%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.mq-story__name {
  transition: color 240ms ease;
}

/* Story link — arrow keeps moving slightly even without hover */
.mq-story__link span {
  display: inline-block;
  transition: transform 220ms cubic-bezier(.2,.7,.2,1);
  animation: mq-arrow-tap 4s ease-in-out infinite;
}
@keyframes mq-arrow-tap {
  0%, 88%, 100% { transform: translateX(0); }
  92%           { transform: translateX(4px); }
  96%           { transform: translateX(0); }
}
.mq-story__link:hover span { transform: translateX(6px); animation: none; }

/* Stats top rule — fills in from left when section reveals */
[data-js]:not([data-fallback]) .mq-story__stats {
  position: relative;
  border-top-color: transparent;
}
[data-js]:not([data-fallback]) .mq-story__stats::before {
  content: "";
  position: absolute; left: 0; top: -2px;
  height: 2px; width: 0;
  background: var(--c, var(--orange-500));
  transition: width 900ms cubic-bezier(.16,.85,.3,1);
  transition-delay: calc(var(--d, 0ms) + 200ms);
}
[data-js]:not([data-fallback]) .mq-story__stats[data-revealed]::before {
  width: 100%;
}

/* Each stat number "pops" individually after the strip reveals */
.mq-story__stats > div b {
  transition: transform 240ms cubic-bezier(.16,.85,.3,1);
  display: inline-block;
}
.mq-story:hover .mq-story__stats > div b {
  transform: scale(1.06);
}

/* Anti-list × marker rotates on hover of the row */
.mq-anti__row {
  transition: background 240ms ease;
}
.mq-anti__row:hover { background: rgba(240,88,40,0.05); }
.mq-anti__row .x {
  transition: transform 360ms cubic-bezier(.16,.85,.3,1), color 200ms ease;
}
.mq-anti__row:hover .x { transform: rotate(90deg); color: var(--orange-400); }

/* Numbers band cells — gentle hover */
.mq-numbers__cell {
  transition: background 240ms ease;
}
.mq-numbers__cell:hover { background: var(--navy-700); }

/* CTA — glowing orange pulse echo on the .actions arrow */

/* Form fields — focus brings a glow + subtle lift */
.mq-form__field input,
.mq-form__field select,
.mq-form__field textarea {
  transition: border-color 200ms ease, box-shadow 200ms ease, transform 200ms cubic-bezier(.16,.85,.3,1);
}
.mq-form__field input:focus,
.mq-form__field select:focus,
.mq-form__field textarea:focus {
  transform: translateY(-1px);
}

/* Submit button — orange flash on hover with arrow slide */
.mq-form__submit .label {
  display: inline-block;
  transition: transform 220ms cubic-bezier(.2,.7,.2,1);
}
.mq-form__submit:hover .label { transform: translateX(3px); }

/* Footer — link hover (no links yet, but logo lifts) */
.mq-foot .brand img {
  transition: transform 280ms cubic-bezier(.2,.7,.2,1);
}
.mq-foot:hover .brand img { transform: translateY(-2px) rotate(-2deg); }

/* Honor reduced motion: kill ALL ambient animations */
@media (prefers-reduced-motion: reduce) {
  .mq-hero::before,
  .mq-nav .cta::after,
  .mq-hero__vol,
  .mq-band__num,
  .mq-poster .mark::before,
  .mq-story__link span,
  .mq-hero__giant em {
    animation: none !important;
  }
}
