/* ============================================================
   Malca Consulting — Website prototype styles
   Editorial, hairline, generous whitespace.
   ============================================================ */

@import url("assets/colors_and_type.css");

* { box-sizing: border-box; }

html, body, #root { background: var(--bg-page); margin: 0; }
/* Safety belt against any rogue child causing horizontal scroll on mobile */
html, body { overflow-x: clip; max-width: 100%; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-weight: 300;
  color: var(--fg-body);
  font-size: var(--fs-body);
  line-height: 1.6;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; border-bottom: 1px solid currentColor; padding-bottom: 1px; transition: opacity 160ms var(--ease-quiet); }
a:hover { opacity: 0.55; }

/* ---- container ---- */
.mc-shell {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 56px;
}
.mc-wide { max-width: 1240px; margin: 0 auto; padding: 0 56px; }
@media (max-width: 720px) {
  .mc-shell, .mc-wide { padding: 0 24px; }
}

/* ---- eyebrow ---- */
.mc-eyebrow {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
  margin: 0 0 20px;
}
.mc-eyebrow .dot { color: var(--mc-pearl); margin: 0 .5em; }

/* ===========  HEADER  =========== */
.mc-header-wrap {
  position: sticky;
  top: 0;
  z-index: 30;
  background: color-mix(in oklab, var(--bg-page) 92%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--rule);
}
.mc-shell { position: relative; }
.mc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
  gap: 24px;
  flex-wrap: nowrap;
  min-width: 0;
}
.mc-mark {
  display: inline-flex; align-items: center;
  border: 0; padding: 0; cursor: pointer; background: none;
  color: var(--mc-ink);
}
.mc-mark:hover { opacity: 0.55; }
.mc-mark-img { height: 54px; width: auto; display: block; margin-left: -8px; }
@media (max-width: 720px) { .mc-mark-img { height: 39px; } }

.mc-nav { display: flex; gap: 30px; align-items: center; }
.mc-nav-link {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-ink);
  border: 0;
  background: none;
  cursor: pointer;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: opacity var(--dur-fast) var(--ease-quiet), border-color var(--dur-fast) var(--ease-quiet);
}
.mc-nav-link:hover { opacity: 0.55; }
.mc-nav-link.is-current { border-bottom-color: var(--mc-burgundy); color: var(--mc-burgundy); }

.mc-lang {
  display: flex; gap: 6px;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--mc-stone);
}
.mc-lang span { padding-bottom: 1px; }
.mc-lang .is-current { color: var(--mc-ink); }
@media (max-width: 860px) { .mc-lang { display: none; } .mc-nav { gap: 18px; } }
/* On phones, collapse the nav into a hamburger toggle. */
@media (max-width: 720px) {
  .mc-nav { display: none; }
  .mc-nav.is-open {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    padding: 16px 24px 24px;
    background: var(--bg-page);
    border-bottom: 1px solid var(--rule);
    gap: 14px;
  }
  .mc-nav-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: 0;
    padding: 4px 0;
    cursor: pointer;
    font-family: var(--font-mono);
    font-weight: 400;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--mc-ink);
  }
  .mc-nav-toggle .bars {
    display: inline-flex;
    flex-direction: column;
    gap: 4px;
    width: 18px;
  }
  .mc-nav-toggle .bars span {
    display: block;
    height: 1px;
    background: var(--mc-ink);
  }
}
@media (min-width: 721px) {
  .mc-nav-toggle { display: none; }
}

/* ===========  HERO — full-bleed background  =========== */
.mc-hero-bleed {
  position: relative;
  width: 100%;
  min-height: clamp(560px, 78vh, 820px);
  overflow: hidden;
  isolation: isolate;
}
.mc-hero-bleed image-slot {
  position: absolute !important;
  inset: 0;
  z-index: 0;
}
/* Soft left-side cream wash so the type column sits on calm negative space.
   Gradient is anchored to the left, where the empty wall is. */
.mc-hero-bleed-grad {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    /* warm scrim on the left column to keep type legible */
    linear-gradient(
      90deg,
      rgba(245, 242, 236, 0.98) 0%,
      rgba(245, 242, 236, 0.92) 22%,
      rgba(245, 242, 236, 0.45) 40%,
      transparent 55%,
      transparent 100%
    ),
    /* subtle bottom darken for the CTA region */
    linear-gradient(
      180deg,
      transparent 60%,
      rgba(11, 19, 32, 0.06) 100%
    );
}
.mc-hero-bleed-inner {
  position: relative;
  z-index: 2;
  height: 100%;
  min-height: clamp(560px, 78vh, 820px);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-top: 56px;
  padding-bottom: 80px;
}
.mc-hero-bleed-text {
  width: 100%;
  max-width: 540px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.mc-hero-bleed-text .mc-eyebrow { margin: 0; }
.mc-hero-bleed-text .mc-hero-h {
  font-size: clamp(40px, 5vw, 68px);
  line-height: 1.02;
  letter-spacing: -0.022em;
  color: var(--mc-ink);
  margin: 0;
  max-width: 14ch;
  text-wrap: balance;
}
.mc-hero-bleed-text .mc-hero-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.4;
  color: var(--mc-ink);
  max-width: 30ch;
  margin: 0;
}
.mc-hero-bleed-text .mc-hero-sub {
  font-size: 16px;
  color: var(--mc-ink);
  max-width: 36ch;
  margin: 0;
  line-height: 1.5;
}
.mc-hero-bleed-text .mc-hero-cta {
  display: flex; flex-direction: column; gap: 12px; align-items: flex-start;
  margin-top: 8px;
}
.mc-hero-bleed-text .mc-hero-note { color: var(--mc-charcoal); }

@media (max-width: 900px) {
  /* On mobile, keep the cinematic overlay: photo fills the viewport,
     a warm cream + dark scrim sits on top so the headline reads
     cleanly. Text stays first in flow so screen readers + SEO
     parse the message before the image. */
  .mc-hero-bleed {
    min-height: 88vh;
    display: block;
  }
  .mc-hero-bleed image-slot {
    position: absolute !important;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    z-index: 0;
  }
  /* Full-image scrim on mobile — warmer + slightly darker so type
     pops over any photo content (chairs, windows, etc.) */
  .mc-hero-bleed-grad {
    display: block;
    inset: 0;
    background:
      linear-gradient(
        180deg,
        rgba(245, 242, 236, 0.92) 0%,
        rgba(245, 242, 236, 0.78) 38%,
        rgba(245, 242, 236, 0.55) 62%,
        rgba(11, 19, 32, 0.20) 100%
      );
  }
  .mc-hero-bleed-inner {
    position: relative;
    z-index: 2;
    min-height: 88vh;
    padding-top: 56px;
    padding-bottom: 64px;
    background: transparent;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
  }
  .mc-hero-bleed-text { max-width: none; }
  .mc-hero-bleed-text .mc-hero-h { max-width: 16ch; }
  /* Slight text-shadow on body copy to hold against any photo */
  .mc-hero-bleed-text .mc-hero-sub,
  .mc-hero-bleed-text .mc-hero-lede {
    text-shadow: 0 1px 0 rgba(245, 242, 236, 0.6);
  }
}
.mc-hero-h {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(44px, 6vw, 88px);
  line-height: 1.0;
  letter-spacing: -0.024em;
  color: var(--mc-ink);
  margin: 0;
  text-wrap: balance;
  max-width: 18ch;
}
.mc-hero-h em {
  font-style: italic;
  font-weight: 300;
  color: var(--mc-burgundy);
}
.mc-hero-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.38;
  color: var(--mc-ink);
  max-width: 40ch;
  margin: 0;
}
.mc-hero-sub {
  font-size: 17px;
  color: var(--mc-charcoal);
  max-width: 44ch;
  margin: 0;
}
.mc-hero-cta { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.mc-hero-note {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}

.mc-hero-fig { margin: 0; display: flex; flex-direction: column; gap: 14px; width: 100%; }
.mc-hero-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  background-size: cover;
  background-position: center;
  filter: saturate(0.92) brightness(1.0);
}
.mc-hero-cap {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}

/* ===========  GENERIC SECTION  =========== */
.mc-section {
  border-top: 1px solid var(--rule);
  padding: 112px 0;
}
.mc-section.tight { padding: 80px 0; }
.mc-section.warm { background: var(--mc-bone); }
.mc-section.soft { background: color-mix(in oklab, var(--mc-bone) 50%, var(--mc-paper)); }
.mc-section.ink  { background: var(--mc-ink); color: var(--mc-cream); }
.mc-section.ink h1, .mc-section.ink h2, .mc-section.ink h3 { color: var(--mc-cream); }
.mc-section.ink .mc-eyebrow { color: rgba(237,234,230,0.55); }
.mc-section.ink .mc-eyebrow .dot { color: rgba(237,234,230,0.25); }

.mc-section.burgundy { background: var(--mc-burgundy); color: var(--mc-cream); }
.mc-section.burgundy h1, .mc-section.burgundy h2, .mc-section.burgundy h3 { color: var(--mc-cream); }

@media (max-width: 720px) { .mc-section { padding: 72px 0; } }

/* Section number rail */
.mc-snum {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-snum strong { color: var(--mc-ink); font-weight: 400; }
.mc-section.ink .mc-snum strong { color: var(--mc-cream); }

/* Two-column grid: marginalia + body */
.mc-grid-2 {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 64px;
}
@media (max-width: 900px) { .mc-grid-2 { grid-template-columns: 1fr; gap: 24px; } }

/* Big editorial statement */
.mc-statement {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(34px, 4.4vw, 60px);
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: var(--mc-ink);
  max-width: 22ch;
  margin: 0 0 32px;
  text-wrap: balance;
}
.mc-statement em { font-style: italic; color: var(--mc-burgundy); }
.mc-section.ink .mc-statement { color: var(--mc-cream); }

.mc-body-col p {
  font-size: 18px;
  line-height: 1.6;
  color: var(--mc-charcoal);
  max-width: 48ch;
  margin: 0 0 1.1em;
}
.mc-section.ink .mc-body-col p { color: rgba(237,234,230,0.82); }

.mc-body-col .quiet {
  color: var(--mc-stone);
  font-style: italic;
}
.mc-body-col p em { font-style: italic; color: var(--mc-burgundy); }

/* Inline list used inside body columns — keeps editorial rhythm */
.mc-body-col .mc-inline-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1.1em;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mc-body-col .mc-inline-list li {
  /* match .mc-body-col p exactly so list + paragraphs read as one block */
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.6;
  color: var(--mc-charcoal);
  display: grid;
  grid-template-columns: 20px 1fr;
  column-gap: 8px;
  align-items: start;
}
.mc-body-col .mc-inline-list li::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--mc-burgundy);
  margin-top: 0.62em;
  justify-self: end;
}

/* ===========  SECTION 2 — manifesto inline ============ */
.mc-section .mc-manifesto {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--mc-ink);
  max-width: 28ch;
  margin: 0 0 24px;
}
.mc-section.ink .mc-manifesto { color: var(--mc-cream); }

/* ===========  SECTION 3 — Fit (asymmetric, editorial) =========== */
.mc-fit-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  column-gap: 96px;
  align-items: start;
}
@media (max-width: 900px) {
  .mc-fit-grid { grid-template-columns: 1fr; gap: 56px; }
}

.mc-fit-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 36px;
}
.mc-fit-label .rule {
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--mc-burgundy);
}
.mc-fit-label.is-quiet { color: var(--mc-stone); }
.mc-fit-label.is-quiet .rule { background: var(--mc-stone); }

.mc-fit-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mc-fit-list li {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: baseline;
  column-gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule);
}
.mc-fit-list li:first-child { border-top: 1px solid var(--rule); }
.mc-fit-list .idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
}
.mc-fit-list .text {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(20px, 1.7vw, 26px);
  line-height: 1.3;
  letter-spacing: -0.012em;
  color: var(--mc-ink);
}

.mc-fit-aside {
  background: var(--mc-bone);
  padding: 44px 40px;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 96px;
}
@media (max-width: 900px) {
  .mc-fit-aside { position: static; }
}
.mc-fit-not {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.55;
  color: var(--mc-ink);
  margin: 0;
}
.mc-pair {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.mc-pair-col {
  padding: 72px 56px;
  border-bottom: 1px solid var(--rule);
  display: block;
}
.mc-pair-col:last-child { border-bottom: 0; }
@media (max-width: 900px) {
  .mc-pair-col { grid-template-columns: 1fr; gap: 24px; padding: 48px 24px; }
}
.mc-pair-col.is-warm { background: var(--mc-bone); }
.mc-pair-col > .mc-pair-list-wrap { grid-column: auto; }
.mc-pair-lede {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin: 0 0 28px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.mc-pair-lede::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--mc-burgundy);
}
.mc-pair-col:not(.is-warm) .mc-pair-lede { color: var(--mc-stone); }
.mc-pair-col:not(.is-warm) .mc-pair-lede::before { background: var(--mc-stone); }
.mc-pair-col-head { display: flex; flex-direction: column; gap: 18px; }
.mc-pair h3 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 2.8vw, 38px);
  line-height: 1.05;
  letter-spacing: -0.014em;
  color: var(--mc-ink);
  margin: 0;
  max-width: 18ch;
}
.mc-pair h3 em { font-style: italic; color: var(--mc-burgundy); }
.mc-pair p.lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: 19px;
  line-height: 1.4;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 36ch;
}
.mc-pair-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
}
.mc-pair-list li {
  display: grid;
  grid-template-columns: 32px 1fr;
  align-items: baseline;
  padding: 14px 0;
  border-top: 1px solid var(--rule);
  font-size: 16px;
  color: var(--mc-charcoal);
}
.mc-pair-list li:last-child { border-bottom: 1px solid var(--rule); }
.mc-pair-list .marker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-pair-list .marker-x { color: var(--mc-burgundy); }

/* ===========  SECTION 6 — diagnose/rebuild/transfer =========== */
.mc-triad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
}
@media (max-width: 900px) { .mc-triad { grid-template-columns: 1fr; } }
.mc-triad-cell {
  padding: 48px 40px 56px;
  border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 14px;
}
.mc-triad-cell:last-child { border-right: 0; }
@media (max-width: 900px) { .mc-triad-cell { border-right: 0; border-bottom: 1px solid var(--rule); padding: 40px 24px; } .mc-triad-cell:last-child { border-bottom: 0; } }
.mc-triad-num {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
}
.mc-triad-h {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 2.6vw, 36px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--mc-ink);
  margin: 0 0 8px;
}
.mc-triad-tags {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.7;
  color: var(--mc-charcoal);
  max-width: 32ch;
}
.mc-triad-tags .sep { color: var(--mc-pearl); margin: 0 .35em; }

/* ===========  SECTION 7 — outcomes =========== */
.mc-outcomes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-flow: column;
  grid-template-rows: repeat(4, auto);
  gap: 0 56px;
  border-top: 1px solid var(--rule);
}
@media (max-width: 720px) { .mc-outcomes { grid-template-columns: 1fr; grid-template-rows: none; grid-auto-flow: row; } }
.mc-outcomes li {
  display: grid;
  grid-template-columns: 48px 1fr;
  align-items: baseline;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(20px, 1.8vw, 26px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--mc-ink);
  list-style: none;
}
.mc-outcomes .idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--mc-stone);
  text-transform: uppercase;
}

/* Closing line under the outcomes list — sits centered below the grid */
.mc-outcomes-close {
  margin: 8px auto 0;
  max-width: 56ch;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.32;
  letter-spacing: -0.012em;
  color: var(--mc-charcoal);
  text-wrap: balance;
}
.mc-outcomes-close em {
  font-style: italic;
  color: var(--mc-burgundy);
}

/* ===========  SECTION 06 — Diagnostic preview =========== */
.mc-diag-preview-aside .mc-eyebrow { margin: 0; }
.mc-diag-preview-list { margin-bottom: 28px; }
.mc-diag-preview-note + .mc-diag-preview-note { margin-top: 0.7em; }
.mc-diag-preview-note {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.5;
  letter-spacing: -0.005em;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 50ch;
  text-wrap: balance;
}
.mc-diag-preview-note em {
  font-style: italic;
  color: var(--mc-burgundy);
  background-image: linear-gradient(to right,
    color-mix(in oklab, var(--mc-burgundy) 35%, transparent),
    color-mix(in oklab, var(--mc-burgundy) 35%, transparent));
  background-position: 0 100%;
  background-repeat: no-repeat;
  background-size: 100% 1px;
  padding-bottom: 4px;
}

/* ===========  MID-CTA — after method animation =========== */
.mc-midcta {
  background: var(--mc-bone);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 80px 0;
}
.mc-midcta-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}
@media (max-width: 900px) {
  .mc-midcta-inner { grid-template-columns: 1fr; gap: 32px; }
}

/* Stacked variant — title + CTA + image, all centered in a single column */
.mc-midcta-stacked .mc-midcta-inner {
  grid-template-columns: 1fr;
  gap: 32px;
  text-align: center;
  justify-items: center;
}
.mc-midcta-stacked .mc-midcta-text { display: flex; flex-direction: column; align-items: center; }
.mc-midcta-stacked .mc-midcta-h,
.mc-midcta-stacked .mc-midcta-p { max-width: 36ch; }
.mc-midcta-stacked .mc-midcta-action { align-items: center; }
.mc-midcta-h {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: var(--mc-ink);
  margin: 18px 0 14px;
  max-width: 26ch;
  text-wrap: balance;
}
.mc-midcta-h em {
  font-style: italic;
  color: var(--mc-burgundy);
}
.mc-midcta-p {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.5;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 44ch;
}
.mc-midcta-action {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}
@media (max-width: 900px) {
  .mc-midcta-action { align-items: flex-start; }
}
.mc-midcta-note {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
}

/* ===========  SECTION 5 — outcomes (single-column editorial list) =========== */
.mc-outcomes-grid {
  list-style: none;
  margin: 0 0 64px;
  padding: 0;
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule);
}
.mc-outcomes-grid li {
  display: grid;
  grid-template-columns: 56px 1fr;
  align-items: baseline;
  column-gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid var(--rule);
}
.mc-outcomes-grid .idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
}
.mc-outcomes-grid .lbl {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: clamp(16px, 1.15vw, 19px);
  line-height: 1.5;
  letter-spacing: 0;
  color: var(--mc-ink);
  max-width: 60ch;
}
@media (max-width: 720px) {
  .mc-outcomes-grid li {
    grid-template-columns: 40px 1fr;
    column-gap: 14px;
    padding: 16px 0;
  }
}
.mc-scope {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 900px) { .mc-scope { grid-template-columns: 1fr; gap: 32px; } }
.mc-scope-list {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 32px;
  border-top: 1px solid var(--rule);
}
@media (max-width: 540px) { .mc-scope-list { grid-template-columns: 1fr; } }
.mc-scope-list li {
  display: grid;
  grid-template-columns: 36px 1fr;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  font-size: 15px;
  color: var(--mc-ink);
  line-height: 1.5;
}
.mc-scope-list .n {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--mc-stone);
  text-transform: uppercase;
  padding-top: 2px;
}

/* ===========  SECTION 10 — how it begins =========== */
.mc-begin {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
}
@media (max-width: 900px) { .mc-begin { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .mc-begin { grid-template-columns: 1fr; } }

/* 5-column variant for the "next step" sequence */
.mc-begin-5 { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 1100px) { .mc-begin-5 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .mc-begin-5 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .mc-begin-5 { grid-template-columns: 1fr; } }
.mc-begin-5 .mc-begin-cell { padding: 32px 24px 40px; }
.mc-begin-5 .mc-begin-cell:last-child { border-right: 0; }
@media (max-width: 1100px) {
  .mc-begin-5 .mc-begin-cell { border-bottom: 1px solid var(--rule); }
  .mc-begin-5 .mc-begin-cell:nth-child(3n) { border-right: 0; }
}
@media (max-width: 720px) {
  .mc-begin-5 .mc-begin-cell:nth-child(3n) { border-right: 1px solid var(--rule); }
  .mc-begin-5 .mc-begin-cell:nth-child(2n) { border-right: 0; }
}
@media (max-width: 540px) {
  .mc-begin-5 .mc-begin-cell { border-right: 0; }
}
.mc-begin-cell {
  padding: 40px 32px 48px;
  border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 12px;
  position: relative;
}
.mc-begin-cell:last-child { border-right: 0; }
@media (max-width: 900px) {
  .mc-begin-cell:nth-child(even) { border-right: 0; }
  .mc-begin-cell { border-bottom: 1px solid var(--rule); }
}
@media (max-width: 540px) {
  .mc-begin-cell { border-right: 0; }
}

/* CTA row anchored under the 5-step "next step" sequence */
.mc-begin-cta {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: 48px;
  padding: 0 clamp(24px, 5vw, 96px);
}
.mc-begin-num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 44px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--mc-burgundy);
}
.mc-begin-label {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-begin-title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--mc-ink);
  margin: 0;
}
.mc-begin-text {
  font-size: 14.5px;
  color: var(--mc-charcoal);
  margin: 0;
  line-height: 1.5;
}

/* ===========  FINAL CTA  =========== */
.mc-final {
  padding: 140px 0;
  border-top: 1px solid var(--rule);
  background: var(--mc-bone);
  color: var(--mc-ink);
  text-align: left;
}
.mc-final h2 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(32px, 3.6vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.018em;
  color: var(--mc-ink);
  margin: 0 0 32px;
  max-width: 18ch;
  text-wrap: balance;
}
.mc-final h2 em { font-style: italic; color: var(--mc-burgundy); }
.mc-final p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(15px, 1.1vw, 18px);
  line-height: 1.45;
  color: var(--mc-charcoal);
  max-width: 42ch;
  margin: 0 0 28px;
}
.mc-final .mc-btn-primary {
  background: var(--mc-burgundy); color: var(--mc-cream);
}
.mc-final .mc-btn-primary:hover { background: var(--mc-burgundy-deep); }
.mc-final .mc-hero-note { color: var(--mc-stone); }
.mc-final-row { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }

/* Final CTA — two-column layout with image on the right */
.mc-final-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 72px;
  align-items: center;
}
.mc-final-fig {
  margin: 0;
}
.mc-final-fig img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: saturate(0.95);
}
@media (max-width: 900px) {
  .mc-final-grid { grid-template-columns: 1fr; gap: 48px; }
  .mc-final-fig img { aspect-ratio: 4 / 3; }
}

/* ===========  FAQ  =========== */
.mc-faq {
  padding: 112px 0;
  border-top: 1px solid var(--rule);
}
.mc-faq-h {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--mc-ink);
  margin: 0 0 56px;
  max-width: 16ch;
}
.mc-faq-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--rule); }
.mc-faq-item { border-bottom: 1px solid var(--rule); }
.mc-faq-q {
  width: 100%;
  background: none;
  border: 0;
  text-align: left;
  cursor: pointer;
  padding: 28px 0;
  display: grid;
  grid-template-columns: 56px 1fr 32px;
  align-items: center;
  gap: 24px;
  color: var(--mc-ink);
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(20px, 1.8vw, 26px);
  line-height: 1.2;
  letter-spacing: -0.01em;
  transition: opacity var(--dur-fast) var(--ease-quiet);
}
.mc-faq-q:hover { opacity: 0.6; }
.mc-faq-q .idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-faq-q .glyph {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 18px;
  color: var(--mc-burgundy);
  justify-self: end;
  transition: transform var(--dur-med) var(--ease-quiet);
}
.mc-faq-item.is-open .mc-faq-q .glyph { transform: rotate(45deg); }
.mc-faq-a {
  display: grid;
  grid-template-columns: 56px 1fr 32px;
  gap: 24px;
  overflow: hidden;
  max-height: 0;
  transition: max-height var(--dur-slow) var(--ease-quiet), opacity var(--dur-med) var(--ease-quiet);
  opacity: 0;
}
.mc-faq-item.is-open .mc-faq-a { max-height: 600px; opacity: 1; padding-bottom: 28px; }
.mc-faq-a .body {
  grid-column: 2 / 3;
  font-size: 17px;
  line-height: 1.6;
  color: var(--mc-charcoal);
  max-width: 56ch;
}
.mc-faq-a .body p { margin: 0 0 .8em; }
.mc-faq-a .body p:last-child { margin: 0; }

/* ===========  BUTTONS  =========== */
.mc-btn {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  border: 0;
  padding: 16px 26px;
  border-radius: 0;
  transition: opacity var(--dur-fast) var(--ease-quiet), transform var(--dur-fast) var(--ease-quiet);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  line-height: 1;
}
.mc-btn:hover { opacity: 0.6; }
.mc-btn:active { transform: translateY(1px); }
.mc-btn-primary { background: var(--mc-burgundy); color: var(--mc-cream); }
.mc-btn-primary:hover { background: var(--mc-burgundy-deep); opacity: 1; }
.mc-btn-burgundy { background: var(--mc-burgundy); color: var(--mc-cream); }
.mc-btn-burgundy:hover { background: var(--mc-burgundy-deep); opacity: 1; }
.mc-btn-secondary { background: transparent; color: var(--mc-ink); border: 1px solid var(--mc-ink); }
.mc-btn-text { background: transparent; color: var(--mc-ink); padding: 4px 0; border-bottom: 1px solid var(--mc-ink); }
.mc-btn .arr { font-family: var(--font-mono); font-weight: 300; }

/* ===========  ABOUT PAGE  =========== */
.mc-about-hero {
  padding-top: 88px;
  padding-bottom: 64px;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 80px;
  align-items: end;
}
@media (max-width: 900px) {
  .mc-about-hero { grid-template-columns: 1fr; gap: 24px; padding-top: 64px; padding-bottom: 40px; }
}
.mc-about-hero h1 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(32px, 3.6vw, 52px);
  line-height: 1.08;
  letter-spacing: -0.018em;
  color: var(--mc-ink);
  max-width: 22ch;
  margin: 12px 0 0;
  text-wrap: balance;
}
.mc-about-hero-locale {
  display: block;
  margin-top: 10px;
  font-size: 0.55em;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.005em;
  color: var(--mc-charcoal);
}
.mc-about-hero .lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.5;
  color: var(--mc-charcoal);
  max-width: 36ch;
  margin: 0;
  padding-left: 18px;
  border-left: 1px solid var(--rule);
}
@media (max-width: 900px) {
  .mc-about-hero .lede { padding-left: 0; border-left: 0; padding-top: 12px; border-top: 1px solid var(--rule); }
}
.mc-about-section {
  padding-top: 72px;
  padding-bottom: 72px;
  border-top: 1px solid var(--rule);
}
.mc-about-grid {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 900px) { .mc-about-grid { grid-template-columns: 1fr; gap: 32px; } }
.mc-about-fig { margin: 0; display: flex; flex-direction: column; gap: 14px; }
.mc-about-fig figcaption {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-about-img {
  width: 100%;
  aspect-ratio: 4 / 5;
  background-size: cover;
  background-position: center;
  filter: saturate(0.82) brightness(1.02);
}

/* image-slot — quiet beige empty state that matches the brand */
image-slot {
  background: var(--mc-bone);
  border: 1px solid var(--rule);
  color: var(--mc-stone);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

/* Force image-slots inside figures to fill the figure's aspect-ratio
   box instead of the component's default 160px host height. */
.mc-hero-fig { aspect-ratio: 16 / 9; }
.mc-about-fig { aspect-ratio: 4 / 5; }
.mc-hero-fig image-slot,
.mc-about-fig image-slot {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
/* Drop the figure's own aspect-ratio when the slot reframes, so
   the spill area can extend beyond the mask. */
.mc-hero-fig:has(image-slot[data-reframe]),
.mc-about-fig:has(image-slot[data-reframe]) { aspect-ratio: auto; }
.mc-about-col h2 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1.18;
  letter-spacing: -0.012em;
  margin: 0 0 22px;
  color: var(--mc-ink);
  max-width: 26ch;
  text-wrap: balance;
}
.mc-about-col h2 em { font-style: italic; color: var(--mc-burgundy); }
.mc-about-col p {
  font-size: 16px;
  line-height: 1.65;
  color: var(--mc-charcoal);
  max-width: 56ch;
  margin: 0 0 1em;
}
.mc-about-col p em { font-style: italic; color: var(--mc-burgundy); }

/* Tighter mc-statement scale inside About sections so headlines don't dwarf the body */
.mc-about-section .mc-statement {
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1.18;
  letter-spacing: -0.012em;
  max-width: 26ch;
}
.mc-about-section .mc-body-col p {
  font-size: 16px;
  line-height: 1.65;
  max-width: 56ch;
}

/* ===========  CONTACT PAGE  =========== */
.mc-contact { padding-top: 96px; padding-bottom: 96px; }
.mc-contact-h {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: 1.0;
  letter-spacing: -0.022em;
  color: var(--mc-ink);
  margin: 0 0 28px;
  max-width: 16ch;
  text-wrap: balance;
}
.mc-contact-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(18px, 1.4vw, 22px);
  color: var(--mc-ink);
  max-width: 44ch;
  margin: 0 0 16px;
}
.mc-contact-sub {
  font-size: 16px; color: var(--mc-charcoal); max-width: 52ch; margin: 0 0 56px;
}
.mc-contact-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 80px;
  align-items: start;
}
@media (max-width: 900px) { .mc-contact-grid { grid-template-columns: 1fr; gap: 32px; } }

.mc-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px 36px;
  border-top: 1px solid var(--rule);
  padding-top: 32px;
}
.mc-field { display: flex; flex-direction: column; gap: 8px; }
.mc-field-full { grid-column: span 2; }
.mc-field label {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-field input,
.mc-field textarea,
.mc-field select {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 16px;
  color: var(--mc-ink);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--mc-ink);
  padding: 8px 0;
  outline: none;
  resize: none;
  border-radius: 0;
}
.mc-field input::placeholder,
.mc-field textarea::placeholder { color: var(--mc-stone); font-style: italic; }
.mc-field input:focus,
.mc-field textarea:focus,
.mc-field select:focus { border-bottom-color: var(--mc-burgundy); }
.mc-field textarea { min-height: 100px; }
.mc-field-radio { display: flex; gap: 18px; align-items: center; padding-top: 4px; }
.mc-field-radio label {
  display: inline-flex; gap: 8px; align-items: center; cursor: pointer;
  font-family: var(--font-body); font-size: 14px; color: var(--mc-ink); text-transform: none; letter-spacing: 0;
}
.mc-field-radio input { accent-color: var(--mc-burgundy); }

.mc-contact-aside {
  border-top: 1px solid var(--rule);
  padding-top: 32px;
  display: flex; flex-direction: column; gap: 28px;
}
.mc-contact-aside .block .eyebrow {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
  margin-bottom: 10px;
}
.mc-contact-aside .block p {
  font-size: 15px; line-height: 1.55; color: var(--mc-ink); margin: 0;
}
.mc-contact-aside .block p em { color: var(--mc-stone); font-style: italic; }

.mc-contact-sent {
  padding-top: 64px;
  padding-bottom: 32px;
}
.mc-contact-sent h3 {
  font-family: var(--font-display); font-weight: 300;
  font-size: clamp(28px, 3vw, 40px); line-height: 1.1; letter-spacing: -0.015em;
  color: var(--mc-ink); margin: 0 0 16px; max-width: 22ch;
}
.mc-contact-sent p { font-size: 17px; color: var(--mc-charcoal); max-width: 48ch; }

/* ===========  FOOTER  =========== */
.mc-footer {
  padding-top: 80px;
  margin-top: 0;
  border-top: 1px solid var(--rule);
  background: var(--mc-bone);
}
.mc-footer-inner { padding-bottom: 32px; }
.mc-footer-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 56px;
}
@media (max-width: 900px) { .mc-footer-row { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 540px) { .mc-footer-row { grid-template-columns: 1fr; gap: 24px; } }
.mc-footer-col { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; font-size: 14px; color: var(--mc-ink); }
.mc-footer-col img { max-width: 100%; height: auto; }
.mc-footer-col a { border-bottom: 0; color: var(--mc-ink); }
.mc-footer-col a:hover { opacity: 0.55; border-bottom: 1px solid currentColor; }
.mc-footer-col .eyebrow {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
  margin-bottom: 14px;
}
.mc-footer-meta {
  padding: 24px 0;
  border-top: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
  display: flex; gap: 16px; flex-wrap: wrap;
  align-items: center;
}
.mc-footer-meta .dot { color: var(--mc-pearl); }

/* ===========  Quiet animations  =========== */
@keyframes mc-rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.mc-rise { animation: mc-rise var(--dur-slow) var(--ease-quiet) both; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}


/* ============================================================
   DIAGNOSTIC — 7-step qualifier funnel
   Modelled after PurpleFire flow; retranslated to Malca brand.
   ============================================================ */

/* Diagnostic — private surface chrome (no global header/footer) */
.mc-diag-page {
  min-height: 100vh;
  background: var(--mc-bone);
}
.mc-diag-topbar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding-top: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--rule);
}
.mc-diag-return {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: none;
  border: 0;
  padding: 6px 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
  cursor: pointer;
  transition: opacity 240ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mc-diag-return:hover { opacity: 0.55; }
.mc-diag-mark {
  justify-self: center;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: opacity 240ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mc-diag-mark:hover { opacity: 0.55; }
.mc-diag-mark img { height: 32px; width: auto; display: block; }
.mc-diag-topbar-meta {
  justify-self: end;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
@media (max-width: 640px) {
  .mc-diag-topbar-meta { display: none; }
  .mc-diag-topbar { grid-template-columns: 1fr auto; }
}

.mc-diag-hero {
  padding-top: 56px;
  padding-bottom: 56px;
  text-align: center;
}
.mc-diag-stats {
  display: inline-flex;
  align-items: center;
  gap: 28px;
  padding: 18px 28px;
  background: var(--mc-bone);
  border: 1px solid var(--rule);
  border-radius: 999px;
}
.mc-diag-stats > div {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.mc-diag-stat-n {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 28px;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--mc-ink);
}
.mc-diag-stat-l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-diag-stat-sep {
  width: 1px; height: 28px; background: var(--rule);
}

.mc-diag-h1 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(40px, 5.4vw, 76px);
  line-height: 1.03;
  letter-spacing: -0.022em;
  color: var(--mc-ink);
  margin: 32px auto 24px;
  max-width: 18ch;
  text-wrap: balance;
}
.mc-diag-h1 em { font-style: italic; color: var(--mc-burgundy); }

.mc-diag-hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  border: 1px solid var(--mc-burgundy);
  color: var(--mc-burgundy);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.mc-diag-hero-pill .dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--mc-burgundy);
}
.mc-diag-hero-sub {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(17px, 1.3vw, 20px);
  color: var(--mc-stone);
  margin: 18px auto 0;
  max-width: 44ch;
}

/* ===== CARD ===== */
.mc-diag-card {
  background: var(--mc-paper);
  border: 1px solid var(--rule);
  padding: 48px 56px 56px;
  max-width: 920px;
  margin: 0 auto;
  scroll-margin-top: 96px;
}
@media (max-width: 720px) { .mc-diag-card { padding: 32px 24px; } }

.mc-diag-progress-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.mc-diag-progress-label { color: var(--mc-stone); }
.mc-diag-progress-pct { color: var(--mc-burgundy); }
.mc-diag-progress-track {
  height: 3px;
  background: var(--mc-pearl);
  margin-top: 10px;
  position: relative;
  overflow: hidden;
}
.mc-diag-progress-fill {
  position: absolute; inset: 0 auto 0 0;
  background: var(--mc-burgundy);
  transition: width 480ms var(--ease-quiet);
}

/* ===== STEP CONTENT ===== */
.mc-diag-step {
  padding-top: 44px;
  display: flex; flex-direction: column;
}

.mc-diag-overline {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 18px;
  display: inline-flex; gap: 8px; align-items: center;
}

.mc-diag-q {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.018em;
  color: var(--mc-ink);
  margin: 0 0 14px;
  max-width: 24ch;
  text-wrap: balance;
}
.mc-diag-q em { font-style: italic; color: var(--mc-burgundy); }

.mc-diag-q-sub {
  font-size: 16px;
  color: var(--mc-stone);
  margin: 0 0 28px;
  max-width: 56ch;
  line-height: 1.55;
}

/* options */
.mc-diag-options {
  list-style: none; padding: 0; margin: 0 0 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.mc-diag-option {
  width: 100%;
  display: grid;
  grid-template-columns: 44px 1fr 32px;
  align-items: center;
  gap: 18px;
  padding: 18px 22px;
  background: var(--mc-paper);
  border: 1px solid var(--rule);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-quiet), background var(--dur-fast) var(--ease-quiet), transform var(--dur-fast) var(--ease-quiet);
  font: inherit;
}
.mc-diag-option:hover { border-color: var(--mc-ink); background: var(--mc-bone); }
.mc-diag-option.is-selected { border-color: var(--mc-burgundy); background: color-mix(in oklab, var(--mc-burgundy) 6%, var(--mc-paper)); }
.mc-diag-option .letter {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--rule);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--mc-stone);
  transition: border-color var(--dur-fast) var(--ease-quiet), color var(--dur-fast) var(--ease-quiet);
}
.mc-diag-option:hover .letter,
.mc-diag-option.is-selected .letter { border-color: var(--mc-burgundy); color: var(--mc-burgundy); }
.mc-diag-option .body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.mc-diag-option .label { font-size: 17px; color: var(--mc-ink); font-weight: 400; }
.mc-diag-option .sub { font-size: 13.5px; color: var(--mc-stone); }
.mc-diag-option .arr { font-family: var(--font-mono); color: var(--mc-stone); justify-self: end; transition: color var(--dur-fast) var(--ease-quiet), transform var(--dur-fast) var(--ease-quiet); }
.mc-diag-option:hover .arr { color: var(--mc-burgundy); transform: translateX(4px); }

/* testimonial card */
.mc-diag-testimonial {
  margin: 8px 0 24px;
  padding: 24px 26px;
  background: var(--mc-bone);
  border: 1px solid var(--rule);
}
.mc-diag-testimonial .stars {
  color: var(--mc-brass);
  font-size: 14px;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}
.mc-diag-testimonial blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: 19px;
  line-height: 1.45;
  color: var(--mc-ink);
  margin: 0 0 14px;
}
.mc-diag-testimonial figcaption {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  font-size: 14px;
}
.mc-diag-testimonial figcaption strong { display: block; color: var(--mc-ink); font-weight: 500; }
.mc-diag-testimonial figcaption span { color: var(--mc-stone); }
.mc-diag-testimonial .pill {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  border: 1px solid var(--mc-burgundy);
  padding: 6px 12px;
  border-radius: 999px;
  white-space: nowrap;
}

.mc-diag-pullquote {
  margin: 0 0 28px;
  padding: 22px 26px;
  background: var(--mc-bone);
  border-left: 2px solid var(--mc-burgundy);
}
.mc-diag-pullquote blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: 18px;
  line-height: 1.45;
  color: var(--mc-ink);
  margin: 0 0 10px;
}
.mc-diag-pullquote .meta {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  font-size: 13px; color: var(--mc-stone);
}
.mc-diag-pullquote .pill {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  border: 1px solid var(--mc-burgundy);
  padding: 5px 10px;
  border-radius: 999px;
}

/* insight box — dark ink with cream text */
.mc-diag-insight {
  background: var(--mc-ink);
  color: var(--mc-cream);
  padding: 22px 26px;
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 14px;
  margin-top: 8px;
}
.mc-diag-insight .ic {
  color: var(--mc-burgundy);
  font-size: 16px;
  line-height: 1.4;
}
.mc-diag-insight p {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(237,234,230,0.86);
}
.mc-diag-insight .mc-diag-insight-title {
  margin: 0 0 8px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.3;
  color: var(--mc-cream);
}

.mc-diag-back {
  margin-top: 24px;
  align-self: flex-start;
  background: none;
  border: 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
  cursor: pointer;
  padding: 6px 0;
}
.mc-diag-back:hover { color: var(--mc-ink); }

/* ===== PROJECTION — modern luxury card ===== */
.mc-diag-projection {
  background: var(--mc-paper);
  color: var(--mc-ink);
  border: 1px solid var(--rule);
  padding: 40px 44px;
  margin: 8px 0 40px;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02), 0 24px 60px -42px rgba(28,24,20,0.22);
}
@media (max-width: 720px) {
  .mc-diag-projection { padding: 28px 24px; }
}
.mc-diag-projection .head {
  display: inline-flex; gap: 10px; align-items: center;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 28px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--rule);
  width: 100%;
}
.mc-diag-projection .head .ic { color: var(--mc-burgundy); font-size: 13px; }
.mc-diag-projection .row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: var(--mc-charcoal);
}
.mc-diag-projection .row strong {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 17px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.005em;
  color: var(--mc-ink);
}
.mc-diag-projection .row.total {
  border-bottom: 0;
  padding: 18px 0 4px;
  border-top: 1px solid color-mix(in oklab, var(--mc-burgundy) 22%, var(--mc-pearl));
  margin-top: 18px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-charcoal);
}
.mc-diag-projection .row.total + .row.total {
  border-top: 0;
  margin-top: 0;
  padding-top: 0;
  padding-bottom: 4px;
}
.mc-diag-projection .row.total .rev {
  font-family: var(--font-body);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.015em;
  color: var(--mc-burgundy);
  font-size: clamp(22px, 2.2vw, 30px);
  text-transform: none;
}
.mc-diag-projection .foot {
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
}

/* ===== HOW WE GET HERE ===== */
.mc-diag-reasons {
  padding: 12px 0 12px;
}
.mc-diag-reasons-h {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(26px, 2.8vw, 36px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--mc-ink);
  margin: 0 0 28px;
  max-width: 22ch;
  text-wrap: balance;
}
.mc-diag-reasons-h em { font-style: italic; color: var(--mc-burgundy); }

.mc-diag-author {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  padding: 22px 24px;
  background: var(--mc-bone);
  border-left: 2px solid var(--mc-burgundy);
  margin: 0 0 28px;
}
.mc-diag-author .avatar {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--mc-ink); color: var(--mc-cream);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 18px;
  letter-spacing: 0.02em;
}
.mc-diag-author .quote p {
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--mc-charcoal);
  margin: 0 0 10px;
  max-width: 56ch;
}
.mc-diag-author .quote em { font-style: italic; color: var(--mc-burgundy); }
.mc-diag-author .quote .who {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-stone);
  margin: 8px 0 0;
}

.mc-diag-reason-list {
  display: grid; grid-template-columns: 1fr; gap: 10px;
  margin-bottom: 28px;
}
.mc-diag-reason {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 18px;
  padding: 18px 22px;
  background: var(--mc-paper);
  border: 1px solid var(--rule);
}
.mc-diag-reason .ic {
  width: 36px; height: 36px;
  border-radius: 6px;
  background: var(--mc-bone);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--mc-burgundy);
  font-size: 16px;
}
.mc-diag-reason h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--mc-ink);
  margin: 0 0 6px;
}
.mc-diag-reason p {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 60ch;
}

/* yellow-ish callout — translate to soft burgundy-tinted cream */
.mc-diag-callout {
  background: color-mix(in oklab, var(--mc-burgundy) 7%, var(--mc-bone));
  border: 1px solid color-mix(in oklab, var(--mc-burgundy) 30%, var(--mc-pearl));
  padding: 22px 26px;
  margin: 8px 0 0;
}
.mc-diag-callout .head {
  display: inline-flex; gap: 8px; align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 12px;
}
.mc-diag-callout p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--mc-charcoal);
  margin: 0 0 14px;
  max-width: 60ch;
}
.mc-diag-callout p em { font-style: italic; color: var(--mc-burgundy); }
.mc-diag-callout .pill {
  display: inline-flex; gap: 8px; align-items: center;
  background: var(--mc-paper);
  border: 1px solid color-mix(in oklab, var(--mc-burgundy) 30%, var(--mc-pearl));
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--mc-burgundy);
  line-height: 1.4;
}
.mc-diag-callout .pill .ic { color: var(--mc-burgundy); }

/* ===== CTA ROW ===== */
.mc-diag-cta-row {
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
  margin-top: 32px;
}

/* ===== BOOKING ===== */
.mc-diag-tags {
  display: flex; gap: 10px; flex-wrap: wrap; margin: 18px 0 0;
}
.mc-diag-tags .tag {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mc-ink);
}
.mc-diag-tags .tag.is-light {
  background: color-mix(in oklab, var(--mc-burgundy) 8%, var(--mc-paper));
  border-color: color-mix(in oklab, var(--mc-burgundy) 30%, var(--mc-pearl));
  color: var(--mc-burgundy);
}
.mc-diag-tags .tag .ic { color: var(--mc-burgundy); }

.mc-diag-exclusivity {
  background: color-mix(in oklab, var(--mc-burgundy) 6%, var(--mc-paper));
  border: 1px solid color-mix(in oklab, var(--mc-burgundy) 25%, var(--mc-pearl));
  padding: 22px 26px;
  margin: 28px 0 32px;
}
.mc-diag-exclusivity .head {
  display: inline-flex; gap: 8px; align-items: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 17px;
  color: var(--mc-burgundy);
  margin-bottom: 8px;
}
.mc-diag-exclusivity p {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 60ch;
}

.mc-diag-form {
  display: flex; flex-direction: column; gap: 20px;
  margin-top: 8px;
}
.mc-diag-form .field { display: flex; flex-direction: column; gap: 8px; }
.mc-diag-form .field label {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 14px;
  color: var(--mc-ink);
  letter-spacing: 0;
  text-transform: none;
}
.mc-diag-form .field .ipt {
  display: grid;
  grid-template-columns: 36px 1fr;
  align-items: center;
  border: 1px solid var(--rule);
  background: var(--mc-paper);
  padding: 0 12px;
  transition: border-color var(--dur-fast) var(--ease-quiet);
}
.mc-diag-form .field .ipt:focus-within { border-color: var(--mc-burgundy); }
.mc-diag-form .field .ipt .ic { color: var(--mc-stone); font-size: 14px; }
.mc-diag-form .field input {
  border: 0; background: transparent; outline: none;
  padding: 14px 0;
  font-family: var(--font-body); font-weight: 300; font-size: 16px;
  color: var(--mc-ink);
}
.mc-diag-form .field input::placeholder { color: var(--mc-stone); }
.mc-diag-form .field .hint {
  font-size: 12.5px; color: var(--mc-stone);
}
.mc-diag-submit {
  margin-top: 8px;
  align-self: stretch;
  justify-content: center;
  padding: 18px;
  font-size: 12px;
}
.mc-diag-submit:disabled {
  background: var(--mc-stone);
  border-color: var(--mc-stone);
  cursor: not-allowed;
  opacity: 0.45;
}
.mc-diag-submit:disabled .arr { transform: none; }

/* Gate form (step 6) — collects name/practice/email before projection */
.mc-diag-gate { max-width: 520px; }

/* Confirm card on booking step — shows the data we already collected */
.mc-diag-confirmcard {
  background: var(--mc-bone);
  border: 1px solid var(--rule);
  padding: 22px 24px;
  margin: 28px 0 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.mc-diag-confirmcard .head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
}
.mc-diag-confirmcard .edit {
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: var(--mc-burgundy);
  cursor: pointer;
  letter-spacing: 0.16em;
  transition: opacity 240ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mc-diag-confirmcard .edit:hover { opacity: 0.6; }
.mc-diag-confirmcard .row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 16px;
  align-items: baseline;
}
.mc-diag-confirmcard .row .k {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-diag-confirmcard .row .v {
  font-size: 15px;
  color: var(--mc-ink);
  word-break: break-word;
}
.mc-diag-foot {
  margin: 4px 0 0;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
}

.mc-diag-expect {
  background: var(--mc-ink);
  color: var(--mc-cream);
  padding: 24px 28px;
  margin-top: 32px;
}
.mc-diag-expect .head {
  display: inline-flex; gap: 8px; align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 18px;
}
.mc-diag-expect ol {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 14px;
}
.mc-diag-expect li {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 14px;
  font-size: 15px;
  line-height: 1.55;
  color: rgba(237,234,230,0.86);
}
.mc-diag-expect .n {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  color: var(--mc-cream);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
}

/* ===== SENT ===== */
.mc-diag-sent .mc-diag-summary {
  background: var(--mc-bone);
  border: 1px solid var(--rule);
  padding: 24px 28px;
  margin: 20px 0 0;
}
.mc-diag-sent .mc-diag-summary .row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 12px 0;
  border-bottom: 1px solid var(--rule);
  font-size: 14.5px;
  color: var(--mc-charcoal);
}
.mc-diag-sent .mc-diag-summary .row:last-of-type { border-bottom: 0; }
.mc-diag-sent .mc-diag-summary .row strong {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(20px, 1.8vw, 26px);
  color: var(--mc-ink);
}
.mc-diag-sent .mc-diag-summary .foot {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
}


/* ===== RESULT CARDS (final results screen) ===== */
.mc-diag-results {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 32px 0 8px;
}
@media (max-width: 760px) {
  .mc-diag-results { grid-template-columns: 1fr; }
}
.mc-diag-resultcard {
  background: var(--mc-paper);
  border: 1px solid var(--rule);
  padding: 28px 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.mc-diag-resultcard.is-negative {
  background: var(--mc-bone);
  border-color: color-mix(in oklab, var(--mc-ink) 12%, var(--mc-pearl));
}
.mc-diag-resultcard-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
}
.mc-diag-resultcard.is-negative .mc-diag-resultcard-eyebrow {
  color: var(--mc-charcoal);
}
.mc-diag-resultcard-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(20px, 1.6vw, 24px);
  line-height: 1.2;
  letter-spacing: -0.005em;
  margin: 0;
  color: var(--mc-ink);
  text-wrap: balance;
}
.mc-diag-resultcard-intro {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--mc-charcoal);
  margin: 0;
}
.mc-diag-resultcard-list {
  list-style: none;
  padding: 0;
  margin: 4px 0 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mc-diag-resultcard-list li {
  display: grid;
  grid-template-columns: 18px 1fr;
  align-items: baseline;
  gap: 6px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--mc-ink);
}
.mc-diag-resultcard-list .mk {
  font-family: var(--font-mono);
  color: var(--mc-burgundy);
  font-size: 14px;
  line-height: 1.55;
}
.mc-diag-resultcard.is-negative .mc-diag-resultcard-list .mk {
  color: color-mix(in oklab, var(--mc-ink) 60%, var(--mc-stone));
}
.mc-diag-resultcard-insight {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 15.5px;
  line-height: 1.5;
  color: var(--mc-burgundy);
}
.mc-diag-resultcard-insight em { font-style: italic; }

/* ===== BOOKING (final results screen) ===== */
.mc-diag-booking {
  margin-top: 48px;
  padding-top: 40px;
  border-top: 1px solid var(--rule);
}


/* === Debora feedback round =========================================== */

/* heavier helper / sub-question text */
.mc-diag-q-sub {
  font-size: 17px;
  font-weight: 500;
  color: var(--mc-ink);
  line-height: 1.55;
}

/* answer options — much more evident */
.mc-diag-option {
  border: 1.5px solid var(--mc-pearl);
  background: var(--mc-paper);
  padding: 22px 24px;
}
.mc-diag-option:hover {
  border-color: var(--mc-burgundy);
  background: var(--mc-paper);
  box-shadow: 0 1px 0 var(--mc-burgundy);
}
.mc-diag-option.is-selected {
  border-color: var(--mc-burgundy);
  background: color-mix(in oklab, var(--mc-burgundy) 8%, var(--mc-paper));
  box-shadow: inset 4px 0 0 var(--mc-burgundy);
}
.mc-diag-option .letter {
  border: 1.5px solid var(--mc-ink);
  color: var(--mc-ink);
  font-weight: 600;
  font-size: 12px;
}
.mc-diag-option .label {
  font-size: 18px;
  font-weight: 600;
  color: var(--mc-ink);
}
.mc-diag-option .sub {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--mc-ink);
}
.mc-diag-option.is-selected .label { color: var(--mc-burgundy); }

/* insight box — burgundy fill, cream text */
.mc-diag-insight {
  background: var(--mc-burgundy);
  color: var(--mc-paper);
  border: 0;
  padding: 22px 26px;
}
.mc-diag-insight .ic {
  color: var(--mc-paper);
  font-size: 18px;
  line-height: 1.3;
}
.mc-diag-insight p {
  color: var(--mc-paper);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
}

/* hero stat numbers in our burgundy */
.mc-diag-stat-n { color: var(--mc-burgundy); }

/* === FACT CARD (replaces fake testimonial) =========================== */
.mc-diag-fact {
  margin: 8px 0 24px;
  padding: 26px 28px;
  background: var(--mc-paper);
  border: 1.5px solid var(--mc-pearl);
  border-left: 3px solid var(--mc-burgundy);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.mc-diag-fact-label {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
}
.mc-diag-fact-row {
  display: grid;
  grid-template-columns: minmax(160px, 200px) 1fr;
  gap: 32px;
  align-items: baseline;
}
@media (max-width: 600px) {
  .mc-diag-fact-row { grid-template-columns: 1fr; gap: 12px; }
}
.mc-diag-fact-figure {
  display: flex; flex-direction: column; gap: 4px;
}
.mc-diag-fact-figure .n {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(40px, 4.6vw, 56px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--mc-burgundy);
}
.mc-diag-fact-figure .u {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
}
.mc-diag-fact-body {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 56ch;
}
.mc-diag-fact-source {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}

/* === Founder card — flip so name is first (less testimonial-y) === */
.mc-diag-author .quote .who {
  margin: 0 0 10px;
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
}
.mc-diag-author .quote p:not(.who) {
  font-size: 16px;
  font-weight: 400;
  color: var(--mc-charcoal);
}


/* ============================================================
   SECTION FIGURES — editorial photo placement
   .mc-section-fig         : portrait image inside content column
   .mc-section-fig-wide    : landscape full-width inside .mc-wide
   .mc-section-fig-shifted : aligns flush right within .mc-shell
   ============================================================ */
.mc-section-fig {
  margin: 64px 0 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 560px;
}
.mc-section-fig img {
  display: block;
  width: 100%;
  height: auto;
  background: var(--mc-bone);
  filter: saturate(0.95);
}
.mc-section-fig figcaption {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
}

/* Wide variant — used inside .mc-wide rows (full content width) */
.mc-section-fig-wide {
  margin: 80px auto 0;
  max-width: 100%;
}
.mc-section-fig-wide img {
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

/* Shifted variant — pushes the image to the right column line
   so it visually balances the snum/text grid above it */
.mc-section-fig-shifted {
  margin-left: auto;
  margin-right: 0;
  max-width: 560px;
}

/* Centered variant — narrower than wide, sits in the middle of the column. */
.mc-section-fig-centered {
  margin: 56px auto 0;
  max-width: 720px;
  width: 100%;
  align-items: center;
}
.mc-section-fig-centered img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
.mc-section-fig-centered figcaption { text-align: center; }
@media (max-width: 720px) {
  .mc-section-fig-centered { margin-top: 40px; max-width: 100%; }
}

@media (max-width: 720px) {
  .mc-section-fig,
  .mc-section-fig-shifted { margin-top: 40px; max-width: 100%; }
  .mc-section-fig-wide { margin-top: 56px; }
}


/* Paired outcomes/scope layout: list-left, photo-right */
.mc-outcomes-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 900px) {
  .mc-outcomes-row { grid-template-columns: 1fr; gap: 32px; }
}

.mc-outcomes-single {
  list-style: none; padding: 0; margin: 0;
  border-top: 1px solid var(--rule);
}
.mc-outcomes-single li {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0;
  color: var(--mc-ink);
}
.mc-outcomes-single .idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--mc-stone);
  text-transform: uppercase;
}

.mc-scope-single {
  list-style: none; padding: 0; margin: 0;
  border-top: 1px solid var(--rule);
}
.mc-scope-single li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  font-size: 16px;
  color: var(--mc-ink);
  line-height: 1.5;
}
.mc-scope-single .n {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--mc-stone);
  text-transform: uppercase;
  padding-top: 4px;
}

/* Paired image inside a 2-col row — no top margin, fills column */
.mc-section-fig-paired {
  margin: 0;
  max-width: 100%;
  position: sticky;
  top: 96px;
}
.mc-section-fig-paired img {
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
}
@media (max-width: 900px) {
  .mc-section-fig-paired { position: static; }
  .mc-section-fig-paired img { aspect-ratio: 4 / 3; }
}


/* ============================================================
   SECTION 03 — HIGHLIGHT (For/Not-for is the visual peak)
   Subtle warm tint that reads as "this is the moment to pay
   attention" without breaking the quiet rhythm.
   ============================================================ */
.mc-section.highlight {
  background: color-mix(in oklab, var(--mc-burgundy) 4%, var(--mc-bone));
}

/* ============================================================
   SECTION 04 — METHOD: editorial visual system
   Three movements unfold in sequence. Each cell is its own quiet
   composition: a vertical hairline draws down on the left, the
   numeral lifts up through a mask, the mono label fades right,
   the italic intent line and body settle in last. A faint
   connecting arrow links each step to the next.
   ============================================================ */

/* Triad sits without a top/bottom border — the verticals do the work. */
.method-animated .mc-triad {
  position: relative;
  border-top: 0;
  border-bottom: 1px solid var(--rule);
}

.method-animated .mc-triad-cell {
  position: relative;
  padding: 64px 44px 64px 36px;
  border-right: 0; /* replaced by a precise hairline pseudo */
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: transparent;
  isolation: isolate;
}

/* Vertical hairline on the left of every cell — burgundy, animates
   from height 0 to 100% as the section comes into view. */
.method-animated .mc-triad-cell::before {
  content: "";
  position: absolute;
  left: 0; top: 0;
  width: 1px;
  height: 100%;
  background: var(--mc-burgundy);
  transform: scaleY(0);
  transform-origin: top center;
  transition: transform 1100ms var(--ease-quiet), background 280ms var(--ease-quiet);
  z-index: 1;
}
/* Last cell gets a hairline on the right too, so the row closes cleanly. */
.method-animated .mc-triad-cell:last-child::after {
  content: "";
  position: absolute;
  right: 0; top: 0;
  width: 1px;
  height: 100%;
  background: var(--rule);
  transform: scaleY(0);
  transform-origin: top center;
  transition: transform 900ms var(--ease-quiet) 600ms;
}
/* Inner cells get a softer divider on the right */
.method-animated .mc-triad-cell:not(:last-child) {
  box-shadow: 1px 0 0 var(--rule);
}

/* Entrance choreography — left hairline draws down */
.method-animated.is-in .mc-triad-cell:nth-child(1)::before { transform: scaleY(1); transition-delay: 80ms; }
.method-animated.is-in .mc-triad-cell:nth-child(2)::before { transform: scaleY(1); transition-delay: 340ms; }
.method-animated.is-in .mc-triad-cell:nth-child(3)::before { transform: scaleY(1); transition-delay: 600ms; }
.method-animated.is-in .mc-triad-cell:last-child::after   { transform: scaleY(1); }

/* ---------- Numeral: lifts up through a mask ---------- */
.mc-triad-big-num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(56px, 6.2vw, 96px);
  line-height: 0.92;
  letter-spacing: -0.028em;
  color: var(--mc-burgundy);
  margin: 0 0 8px;
  font-variant-numeric: lining-nums;
  /* mask reveal */
  clip-path: inset(105% 0 0 0);
  transition: clip-path 1100ms var(--ease-quiet), color 320ms var(--ease-quiet);
  will-change: clip-path;
}
.method-animated.is-in .mc-triad-cell:nth-child(1) .mc-triad-big-num { clip-path: inset(0 0 0 0); transition-delay: 200ms; }
.method-animated.is-in .mc-triad-cell:nth-child(2) .mc-triad-big-num { clip-path: inset(0 0 0 0); transition-delay: 460ms; }
.method-animated.is-in .mc-triad-cell:nth-child(3) .mc-triad-big-num { clip-path: inset(0 0 0 0); transition-delay: 720ms; }

/* ---------- Mono label: slides 6px right + fades ---------- */
.method-animated .mc-triad-num {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--mc-ink);
  margin: 0;
  position: relative;
  padding-left: 0;
  opacity: 0;
  translate: -8px 0;
  transition: opacity 700ms var(--ease-quiet), translate 700ms var(--ease-quiet);
}
.method-animated .mc-triad-num::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--mc-burgundy);
  vertical-align: middle;
  margin-right: 10px;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 600ms var(--ease-quiet);
}
.method-animated.is-in .mc-triad-cell:nth-child(1) .mc-triad-num { opacity: 1; translate: 0 0; transition-delay: 460ms; }
.method-animated.is-in .mc-triad-cell:nth-child(2) .mc-triad-num { opacity: 1; translate: 0 0; transition-delay: 720ms; }
.method-animated.is-in .mc-triad-cell:nth-child(3) .mc-triad-num { opacity: 1; translate: 0 0; transition-delay: 980ms; }
.method-animated.is-in .mc-triad-cell:nth-child(1) .mc-triad-num::before { transform: scaleX(1); transition-delay: 560ms; }
.method-animated.is-in .mc-triad-cell:nth-child(2) .mc-triad-num::before { transform: scaleX(1); transition-delay: 820ms; }
.method-animated.is-in .mc-triad-cell:nth-child(3) .mc-triad-num::before { transform: scaleX(1); transition-delay: 1080ms; }

/* ---------- Italic intent line ---------- */
.method-animated .mc-triad-h {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(20px, 1.9vw, 26px);
  line-height: 1.22;
  letter-spacing: -0.008em;
  color: var(--mc-ink);
  margin: 4px 0 6px;
  max-width: 22ch;
  text-wrap: balance;
  opacity: 0;
  translate: 0 8px;
  transition: opacity 700ms var(--ease-quiet), translate 700ms var(--ease-quiet);
}
.method-animated.is-in .mc-triad-cell:nth-child(1) .mc-triad-h { opacity: 1; translate: 0 0; transition-delay: 600ms; }
.method-animated.is-in .mc-triad-cell:nth-child(2) .mc-triad-h { opacity: 1; translate: 0 0; transition-delay: 860ms; }
.method-animated.is-in .mc-triad-cell:nth-child(3) .mc-triad-h { opacity: 1; translate: 0 0; transition-delay: 1120ms; }

/* ---------- Body tags ---------- */
.method-animated .mc-triad-tags {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--mc-charcoal);
  margin: 8px 0 0;
  max-width: 36ch;
  opacity: 0;
  transition: opacity 800ms var(--ease-quiet);
}
.method-animated.is-in .mc-triad-cell:nth-child(1) .mc-triad-tags { opacity: 1; transition-delay: 760ms; }
.method-animated.is-in .mc-triad-cell:nth-child(2) .mc-triad-tags { opacity: 1; transition-delay: 1020ms; }
.method-animated.is-in .mc-triad-cell:nth-child(3) .mc-triad-tags { opacity: 1; transition-delay: 1280ms; }

/* ---------- Connector arrows between cells (desktop only) ---------- */
.mc-triad-line {
  position: absolute;
  left: 33.333%;
  right: auto;
  top: 64px; /* aligns to the numeral baseline-ish */
  transform: translate(-50%, 0);
  width: 28px;
  height: 1px;
  background: var(--mc-burgundy);
  opacity: 0;
  pointer-events: none;
  transition: opacity 600ms var(--ease-quiet);
}
.mc-triad-line::before,
.mc-triad-line::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  width: 7px;
  height: 1px;
  background: var(--mc-burgundy);
  transform-origin: right center;
}
.mc-triad-line::before { transform: translateY(-50%) rotate(40deg); }
.mc-triad-line::after  { transform: translateY(-50%) rotate(-40deg); }
.method-animated .mc-triad { grid-template-columns: 1fr 1fr 1fr; }
.method-animated.is-in .mc-triad-line { opacity: 1; transition-delay: 900ms; }
/* second arrow, between cells 2 and 3 */
.mc-triad-line.second { left: 66.666%; }

/* ---------- Hover lift ---------- */
.method-animated .mc-triad-cell {
  transition: background 320ms var(--ease-quiet);
}
.method-animated .mc-triad-cell:hover {
  background: color-mix(in oklab, var(--mc-burgundy) 3%, var(--mc-paper));
}
.method-animated .mc-triad-cell:hover::before {
  background: var(--mc-burgundy-deep);
  width: 2px;
}
.method-animated .mc-triad-cell:hover .mc-triad-big-num { color: var(--mc-burgundy-deep); }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .method-animated .mc-triad-cell::before,
  .method-animated .mc-triad-cell:last-child::after { transform: scaleY(1); transition: none; }
  .method-animated .mc-triad-big-num { clip-path: inset(0 0 0 0); transition: none; }
  .method-animated .mc-triad-num,
  .method-animated .mc-triad-h,
  .method-animated .mc-triad-tags { opacity: 1; translate: 0 0; transition: none; }
  .method-animated .mc-triad-num::before { transform: scaleX(1); transition: none; }
  .mc-triad-line { opacity: 1; transition: none; }
}

/* ---------- Mobile: stack cells, drop arrows ---------- */
@media (max-width: 900px) {
  .method-animated .mc-triad { grid-template-columns: 1fr; border-bottom: 0; }
  .method-animated .mc-triad-cell {
    padding: 44px 24px 44px 28px;
    border-right: 0;
    border-bottom: 1px solid var(--rule);
    box-shadow: none;
  }
  .method-animated .mc-triad-cell:last-child { border-bottom: 0; }
  .method-animated .mc-triad-cell:last-child::after { display: none; }
  .mc-triad-line { display: none; }
}

/* ============================================================
   MANIFESTO BAND — full-bleed burgundy statement section
   Sits between Section 03 (Fit) and Section 04 (Method).
   ============================================================ */

/* ============================================================
   METHOD WHEEL — auto-cycling circular diagram (Section 04)
   ============================================================ */

/* Scroll-pinned container: total height is generous so each phase has time
   to breathe even when scrolling quickly. */
.mc-method-scroll {
  position: relative;
  /* Big scroll budget so each phase has real room to dwell.
     ~400vh per phase + extra tail on phase 3 + 100vh pin = 1400vh total.
     This makes even a fast scroll feel deliberate. */
  height: calc(100vh + 1400vh);
}
.mc-method-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.mc-method-sticky .mc-method-wheel-wrap {
  padding: 0 clamp(24px, 5vw, 96px);
  max-width: 1280px;
  width: 100%;
  position: relative;
}
@media (max-width: 720px) {
  /* Mobile keeps the scroll-pin variant active, but with a shorter scroll
     budget and a 100svh sticky (so iOS URL bar resize doesn't crop). */
  .mc-method-scroll {
    height: calc(100svh + 700vh);
  }
  .mc-method-sticky {
    height: 100svh;
    padding: 24px 0;
  }
  .mc-method-sticky .mc-method-wheel-wrap {
    padding: 0 20px;
  }
}

/* ===== Mobile variant: three stacked phase cards ===== */
.mc-method-mobile {
  display: flex;
  flex-direction: column;
  gap: 32px;
  padding: 8px 0 24px;
}
.mc-mm-card {
  background: var(--mc-paper);
  border-top: 1px solid var(--rule);
  padding: 32px 0 24px;
}
.mc-mm-card:first-child { border-top: 0; padding-top: 8px; }
.mc-mm-head {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  align-items: start;
  margin-bottom: 22px;
}
.mc-mm-num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 52px;
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--mc-burgundy);
  width: 56px;
  flex-shrink: 0;
}
.mc-mm-titles { min-width: 0; }
.mc-mm-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 10px;
}
.mc-mm-label .rule {
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--mc-burgundy);
}
.mc-mm-title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 7vw, 36px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--mc-ink);
  margin: 0 0 10px;
}
.mc-mm-verb {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: 16px;
  line-height: 1.4;
  color: var(--mc-charcoal);
  margin: 0;
  max-width: 36ch;
  text-wrap: balance;
}
.mc-mm-layers {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.mc-mm-layers li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--mc-charcoal);
  border-bottom: 1px dotted var(--rule);
}
.mc-mm-layers li:last-child { border-bottom: 0; }
.mc-mm-layers li .bullet {
  display: inline-block;
  width: 12px;
  height: 1px;
  background: var(--mc-burgundy);
  flex-shrink: 0;
}
@media (prefers-reduced-motion: reduce) {
  .mc-method-scroll { height: auto; }
  .mc-method-sticky { position: relative; height: auto; padding: 40px 0; }
}

/* === CURTAIN: the visible "page-turn" that announces each phase change === */
.mc-mw-curtain {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
  overflow: hidden;
}
.mc-mw-curtain .curtain-band {
  position: absolute;
  inset: 100% 0 0 0;        /* starts fully below view */
  background: var(--mc-burgundy);
  animation: mwCurtain 1100ms cubic-bezier(0.7, 0, 0.3, 1) both;
}
.mc-mw-curtain.is-reverse .curtain-band {
  animation-name: mwCurtainReverse;
}
.mc-mw-curtain .curtain-marker {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: baseline;
  gap: 22px;
  color: var(--mc-cream);
  opacity: 0;
  animation: mwCurtainText 1100ms cubic-bezier(0.7, 0, 0.3, 1) both;
  white-space: nowrap;
}
.mc-mw-curtain .curtain-marker .word {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--mc-cream) 65%, transparent);
}
.mc-mw-curtain .curtain-marker .num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(56px, 7vw, 92px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--mc-cream);
}
.mc-mw-curtain .curtain-marker .rule {
  display: inline-block;
  width: 32px;
  height: 1px;
  background: color-mix(in oklab, var(--mc-cream) 55%, transparent);
  align-self: center;
}
.mc-mw-curtain .curtain-marker .name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1;
  letter-spacing: -0.012em;
  color: var(--mc-cream);
}

/* Forward (scroll down): band rises from the bottom, covers, exits at the top */
@keyframes mwCurtain {
  0%   { inset: 100% 0 0 0; }   /* off-screen below */
  35%  { inset: 0 0 0 0; }      /* fully covering */
  60%  { inset: 0 0 0 0; }      /* hold */
  100% { inset: 0 0 100% 0; }   /* exits to the top */
}
/* Reverse (scroll up): band drops from the top, exits to the bottom */
@keyframes mwCurtainReverse {
  0%   { inset: 0 0 100% 0; }
  35%  { inset: 0 0 0 0; }
  60%  { inset: 0 0 0 0; }
  100% { inset: 100% 0 0 0; }
}
@keyframes mwCurtainText {
  0%, 25%  { opacity: 0; transform: translate(-50%, calc(-50% + 24px)); }
  45%, 60% { opacity: 1; transform: translate(-50%, -50%); }
  80%, 100%{ opacity: 0; transform: translate(-50%, calc(-50% - 24px)); }
}

@media (prefers-reduced-motion: reduce) {
  .mc-mw-curtain { display: none; }
}

.mc-method-wheel-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 88px;
  align-items: center;
  padding: 24px 0 56px;
  max-width: 1200px;
  margin: 0 auto;
}

/* Until the first curtain has wiped, the wheel stays invisible so the
   introduction is a proper reveal. The curtain itself is rendered
   regardless and sits above this. */
.mc-method-wheel-wrap.is-scroll-driven .mc-method-wheel,
.mc-method-wheel-wrap.is-scroll-driven .mc-mw-text {
  opacity: 0;
  transition: opacity 600ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mc-method-wheel-wrap.is-scroll-driven.is-revealed .mc-method-wheel,
.mc-method-wheel-wrap.is-scroll-driven.is-revealed .mc-mw-text {
  opacity: 1;
}
@media (max-width: 960px) {
  .mc-method-wheel-wrap {
    grid-template-columns: 1fr;
    gap: 56px;
    padding: 0 0 40px;
  }
}
@media (max-width: 720px) {
  .mc-method-wheel-wrap {
    gap: 24px;
    padding: 0 0 16px;
  }
  .mc-method-wheel { max-width: 240px; }
  .mc-mw-text .label { font-size: 10px; margin-bottom: 14px; }
  .mc-mw-text h3 { font-size: 26px; margin-bottom: 10px; }
  .mc-mw-text .verb { font-size: 15px; margin-bottom: 14px; }
  .mc-mw-text .layers li {
    font-size: 14px;
    padding: 7px 10px;
  }
  .mc-mw-progress { gap: 6px; margin-top: 14px; }
  .mc-mw-progress .lbl { font-size: 9.5px; letter-spacing: 0.14em; }
}

.mc-method-wheel {
  position: relative;
  aspect-ratio: 1;
  max-width: 540px;
  width: 100%;
  margin: 0 auto;
}
.mc-method-wheel svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}

/* phase numerals on the rim */
.mc-mw-num {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  fill: var(--mc-stone);
  transition: fill 600ms ease, font-weight 600ms ease;
}
.mc-mw-num.is-past {
  fill: var(--mc-burgundy);
  opacity: 0.7;
}
.mc-mw-num.is-active {
  fill: var(--mc-burgundy);
  font-weight: 500;
  opacity: 1;
}

/* center label overlay */
.mc-mw-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  pointer-events: none;
  gap: 8px;
}
.mc-mw-center .overline {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--mc-stone);
  margin-bottom: 6px;
}
.mc-mw-center .num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(64px, 8vw, 104px);
  line-height: 1;
  color: var(--mc-burgundy);
  letter-spacing: -0.03em;
  animation: mwFadeUp 900ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
  animation-delay: 380ms;
}
.mc-mw-center .title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--mc-charcoal);
  margin-top: 2px;
  animation: mwFadeUp 900ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
  animation-delay: 440ms;
}

/* right-column text pane */
.mc-mw-text {
  max-width: 480px;
}
.mc-mw-text .label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mc-burgundy);
  margin-bottom: 28px;
}
.mc-mw-text .label .rule {
  width: 28px;
  height: 1px;
  background: var(--mc-burgundy);
  display: inline-block;
}
.mc-mw-text h3 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.022em;
  color: var(--mc-ink);
  margin: 0 0 18px;
}
.mc-mw-text .verb {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.42;
  color: var(--mc-charcoal);
  margin: 0 0 36px;
  max-width: 36ch;
  text-wrap: balance;
}
.mc-mw-text .layers {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 16px;
  row-gap: 6px;
}
@media (max-width: 540px) {
  .mc-mw-text .layers { grid-template-columns: 1fr; }
}
.mc-mw-text .layers li {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px 10px 14px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--mc-charcoal);
  line-height: 1.4;
  border-radius: 2px;
  transition: background-color 360ms cubic-bezier(0.22, 0.61, 0.36, 1),
              color 360ms cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 360ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mc-mw-text .layers li .bullet {
  display: inline-block;
  width: 14px;
  height: 1px;
  background: var(--mc-burgundy);
  flex-shrink: 0;
  transition: background-color 360ms cubic-bezier(0.22, 0.61, 0.36, 1),
              width 360ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mc-mw-text .layers li .text {
  transition: color 360ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* Highlighted bullet: burgundy ground, cream text, slight rightward nudge */
.mc-mw-text .layers li.is-highlight {
  background: var(--mc-burgundy);
  transform: translateX(2px);
}
.mc-mw-text .layers li.is-highlight .text {
  color: var(--mc-cream);
}
.mc-mw-text .layers li.is-highlight .bullet {
  background: var(--mc-cream);
  width: 18px;
}

/* When scroll-driven mode is off (timer mode), no per-bullet highlight is
   shown — the bullets just sit at rest. */

.mc-mw-pane {
  animation: mwPaneIn 900ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
  animation-delay: 350ms; /* wait for the curtain to start clearing */
}
@keyframes mwPaneIn {
  0%   { opacity: 0; transform: translateY(28px); }
  60%  { opacity: 0; transform: translateY(28px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes mwFadeUp {
  0%   { opacity: 0; transform: translateY(20px); }
  55%  { opacity: 0; transform: translateY(20px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* phase progress bar row */
.mc-mw-progress {
  display: flex;
  gap: 24px;
  margin-top: 40px;
  flex-wrap: wrap;
}
.mc-mw-dot {
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  font: inherit;
  text-align: left;
  flex: 1 1 0;
  min-width: 110px;
  transition: opacity 300ms ease;
}
.mc-mw-dot:hover { opacity: 0.75; }
.mc-mw-dot .bar {
  display: block;
  width: 100%;
  height: 1px;
  background: var(--rule);
  position: relative;
  overflow: hidden;
}
.mc-mw-dot .bar-fill {
  position: absolute;
  inset: 0 100% 0 0;
  background: var(--mc-burgundy);
  opacity: 0;
  transition: opacity 200ms ease;
}
.mc-mw-dot.is-active .bar-fill {
  opacity: 1;
  animation: mwBarFill 5400ms linear forwards;
}
@keyframes mwBarFill {
  from { right: 100%; }
  to { right: 0; }
}
.mc-mw-dot .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mc-stone);
  transition: color 300ms ease;
}
.mc-mw-dot.is-active .lbl { color: var(--mc-burgundy); }

@media (prefers-reduced-motion: reduce) {
  .mc-mw-pane,
  .mc-mw-center .num,
  .mc-mw-center .title { animation: none; }
  .mc-mw-dot.is-active .bar-fill { animation: none; right: 0; }
}

/* ============================================================
   MANIFESTO BAND — full-bleed burgundy statement section
   Sits between Section 03 (Fit) and Section 04 (Method).
   ============================================================ */
.mc-manifesto-band {
  padding: 128px 0;
  background: var(--mc-burgundy);
  color: var(--mc-cream);
  position: relative;
  overflow: hidden;
}
/* Variant: bottle-green band (used for the "goal" statement after outcomes).
   Uses the reserve accent, intentionally different from the burgundy promise. */
.mc-manifesto-band.is-bottle {
  background: var(--mc-bottle);
  padding: 96px 0;
}
/* Compact variant — shorter band, smaller type, for secondary statements */
.mc-manifesto-band.is-compact {
  padding: 72px 0;
}
.mc-manifesto-band.is-compact .mc-manifesto-overline {
  margin-bottom: 28px;
}
.mc-manifesto-band.is-compact .mc-manifesto-statement {
  font-size: clamp(20px, 2.2vw, 30px);
  line-height: 1.35;
  max-width: 40ch;
}
.mc-manifesto-band.is-compact .mc-manifesto-statement + .mc-manifesto-statement {
  margin-top: 14px;
}
/* When two manifesto-statement <p>s sit in the same band, stack them with
   a small breathing space and let the second one carry the emphasis. */
.mc-manifesto-band .mc-manifesto-statement + .mc-manifesto-statement {
  margin-top: 24px;
}
.mc-manifesto-band::before,
.mc-manifesto-band::after {
  /* hairline rules top and bottom, slightly inset */
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  height: 1px;
  background: color-mix(in oklab, var(--mc-cream) 22%, transparent);
}
.mc-manifesto-band::before { top: 0; }
.mc-manifesto-band::after { bottom: 0; }

.mc-manifesto-overline {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--mc-cream) 65%, transparent);
  margin-bottom: 40px;
}
.mc-manifesto-overline .rule {
  display: inline-block;
  width: 36px;
  height: 1px;
  background: color-mix(in oklab, var(--mc-cream) 55%, transparent);
}

.mc-manifesto-statement {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.35;
  letter-spacing: -0.008em;
  color: var(--mc-cream);
  margin: 0;
  max-width: 36ch;
  text-wrap: balance;
}
.mc-manifesto-statement em {
  font-style: italic;
  color: var(--mc-cream);
}

.mc-manifesto-foot {
  margin-top: 48px;
  text-align: left;
}
.mc-manifesto-foot .asterism {
  font-family: var(--font-display);
  font-size: 24px;
  line-height: 1;
  color: color-mix(in oklab, var(--mc-cream) 55%, transparent);
  letter-spacing: 0.2em;
}

@media (max-width: 720px) {
  .mc-manifesto-band { padding: 88px 0; }
  .mc-manifesto-overline { margin-bottom: 28px; }
  .mc-manifesto-foot { margin-top: 36px; }
}
