
    *, *::before, *::after {
      box-sizing: border-box;
    }

    :root {
      --ink: oklch(15% 0.022 188);
      --ink-soft: oklch(34% 0.018 188);
      --muted: oklch(46% 0.017 188);
      --paper: oklch(96% 0.014 84);
      --paper-low: oklch(92.5% 0.018 86);
      --paper-deep: oklch(88% 0.022 86);
      --forest: oklch(20% 0.052 164);
      --forest-strong: oklch(14% 0.044 174);
      --forest-soft: oklch(27% 0.05 164);
      --moss: oklch(46% 0.09 150);
      --lime: oklch(85% 0.12 116);
      --lime-low: oklch(90% 0.055 116);
      --clay: oklch(58% 0.12 34);
      --blue: oklch(47% 0.12 218);
      --line: oklch(82% 0.018 86);
      --line-dark: oklch(35% 0.034 164);
      --shadow: oklch(18% 0.03 164 / 0.22);
      --serif: "EB Garamond", Georgia, serif;
      --sans: "Bricolage Grotesque", system-ui, sans-serif;
      --max: 1248px;
      --pad: clamp(20px, 5vw, 56px);
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: var(--sans);
      color: var(--ink);
      background: var(--paper);
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
      padding-bottom: calc(72px + env(safe-area-inset-bottom));
    }

    body.menu-open {
      overflow: hidden;
    }

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

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

    button {
      font: inherit;
    }

    :focus-visible {
      outline: 2px solid var(--lime);
      outline-offset: 4px;
    }

    .wrap {
      width: min(100%, var(--max));
      margin: 0 auto;
      padding-inline: var(--pad);
    }

    .site-archive {
      display: none !important;
    }

    .site-header {
      position: sticky;
      top: 0;
      z-index: 50;
      background: color-mix(in oklch, var(--forest-strong) 94%, var(--paper) 6%);
      border-bottom: 1px solid var(--line-dark);
    }

    .nav {
      width: min(100%, var(--max));
      height: 74px;
      margin: 0 auto;
      padding-inline: var(--pad);
      display: flex;
      align-items: center;
      gap: 24px;
      color: var(--paper);
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      min-width: max-content;
    }

    .brand-mark {
      width: 44px;
      height: 44px;
      display: grid;
      place-items: center;
      color: var(--lime);
    }

    .brand-word {
      display: grid;
      gap: 3px;
      line-height: 1;
    }

    .brand-word strong {
      font-size: 21px;
      font-weight: 700;
      letter-spacing: -0.025em;
    }

    .brand-word span {
      font-size: 21px;
      font-weight: 400;
      letter-spacing: -0.025em;
      color: color-mix(in oklch, var(--paper) 80%, var(--forest));
      text-transform: none;
    }

    .nav-links {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 4px;
      list-style: none;
      margin: 0 auto;
      padding: 0;
    }

    .nav-links a {
      display: inline-flex;
      align-items: center;
      min-height: 38px;
      padding: 0 13px;
      border-radius: 8px;
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
      font-size: 14px;
      font-weight: 600;
      transition: color 160ms ease, background 160ms ease;
    }

    .nav-links a:hover {
      color: var(--paper);
      background: color-mix(in oklch, var(--paper) 9%, transparent);
    }

    .nav-actions {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .phone-link {
      font-size: 13px;
      font-weight: 700;
      color: color-mix(in oklch, var(--paper) 70%, var(--forest));
      white-space: nowrap;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 9px;
      min-height: 44px;
      padding: 0 18px;
      border: 1px solid transparent;
      border-radius: 8px;
      font-size: 13px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      cursor: pointer;
      transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease;
    }

    .btn:hover {
      transform: translateY(-1px);
    }

    .btn:active {
      transform: translateY(0);
    }

    .btn-lime {
      background: var(--lime);
      color: var(--forest-strong);
      border-color: var(--lime);
    }

    .btn-lime:hover {
      background: color-mix(in oklch, var(--lime) 88%, var(--paper));
    }

    .btn-outline-dark {
      color: var(--paper);
      border-color: color-mix(in oklch, var(--paper) 24%, transparent);
      background: transparent;
    }

    .btn-outline-dark:hover {
      border-color: var(--lime);
      color: var(--lime);
    }

    .btn-ink {
      background: var(--forest-strong);
      color: var(--paper);
      border-color: var(--forest-strong);
    }

    .btn-ink:hover {
      background: var(--forest);
    }

    .menu-toggle {
      display: none;
      width: 44px;
      height: 44px;
      padding: 0;
      border: 1px solid color-mix(in oklch, var(--paper) 20%, transparent);
      border-radius: 8px;
      background: transparent;
      color: var(--paper);
      align-items: center;
      justify-content: center;
      cursor: pointer;
    }

    .menu-toggle svg {
      width: 20px;
      height: 20px;
    }

    .hero {
      position: relative;
      overflow: hidden;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        var(--forest-strong);
      background-size: 80px 80px;
      color: var(--paper);
      min-height: calc(100vh - 74px);
      display: flex;
      flex-direction: column;
    }

    .hero-grid {
      width: min(100%, var(--max));
      flex: 1 0 auto;
      margin: 0 auto;
      min-height: calc(100vh - 130px);
      padding: 44px var(--pad) 36px;
      display: grid;
      grid-template-columns: minmax(0, 0.98fr) minmax(420px, 0.78fr);
      gap: 48px;
      align-items: center;
    }

    .eyebrow {
      margin: 0 0 8px;
      font-family: var(--serif);
      font-style: italic;
      font-weight: 500;
      font-size: clamp(28px, 2.8vw, 40px);
      line-height: 1;
      color: var(--moss);
    }

    .eyebrow.light {
      color: var(--lime);
    }

    .hero-copy {
      grid-column: 1;
      grid-row: 1;
      padding-bottom: 0;
      max-width: 720px;
      position: relative;
      z-index: 3;
    }

    .hero h1 {
      margin: 0;
      max-width: 720px;
      font-size: 82px;
      line-height: 0.92;
      letter-spacing: 0;
      font-weight: 800;
    }

    .hero h1 span {
      color: var(--lime);
    }

    .hero-lede {
      margin: 28px 0 0;
      max-width: 630px;
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
      font-size: 20px;
      line-height: 1.45;
    }

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

    .hero-alumni {
      margin: 42px 0 0;
      padding: 14px 20px;
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: 20px;
      background: color-mix(in oklch, var(--paper) 92%, var(--lime-low));
      border: 1px solid var(--line-dark);
      border-radius: 10px;
    }

    .hero-alumni-label {
      flex: 0 0 auto;
      white-space: nowrap;
      color: var(--moss);
      font-size: 11px;
      font-weight: 900;
      letter-spacing: 0.13em;
      line-height: 1.25;
      text-transform: uppercase;
      padding-right: 20px;
      border-right: 1px solid var(--line-dark);
    }

    .hero-logo-row {
      flex: 1 1 0;
      min-width: 0;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }

    .hero-logo-slot {
      flex: 1 1 0;
      min-width: 0;
      display: grid;
      place-items: center;
    }

    .hero-logo-slot img {
      max-width: 100%;
      width: auto;
      height: 32px;
      object-fit: contain;
    }

    .hero-logo-slot.logo-wide img {
      height: 30px;
    }

    .hero-logo-slot.logo-seal img {
      height: 40px;
    }

    .hero-media {
      grid-column: 2;
      grid-row: 1;
      align-self: stretch;
      min-height: 620px;
      position: relative;
      display: grid;
      align-items: end;
      z-index: 1;
    }

    .campus-frame {
      position: absolute;
      inset: 26px 0 96px 0;
      border-radius: 8px;
      overflow: hidden;
      border: 1px solid var(--line-dark);
      box-shadow: 0 28px 80px var(--shadow);
      background: var(--forest);
    }

    .campus-frame::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, color-mix(in oklch, var(--forest-strong) 2%, transparent), color-mix(in oklch, var(--forest-strong) 44%, transparent));
      pointer-events: none;
    }

    .campus-frame img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: saturate(0.86) contrast(0.98);
    }

    .student-figure {
      position: absolute;
      right: -48px;
      bottom: 74px;
      width: min(112%, 630px);
      max-height: none;
      object-fit: contain;
      object-position: bottom right;
      filter: drop-shadow(0 24px 46px oklch(8% 0.03 174 / 0.46));
      z-index: 2;
    }

    .hero-caption {
      position: absolute;
      left: 0;
      bottom: 42px;
      z-index: 3;
      width: min(310px, 58%);
      padding: 17px 18px;
      border-radius: 8px;
      background: var(--lime);
      color: var(--forest-strong);
      box-shadow: 0 20px 52px oklch(8% 0.04 164 / 0.28);
    }

    .hero-caption strong {
      display: block;
      font-size: 15px;
      margin-bottom: 3px;
    }

    .hero-caption span {
      display: block;
      font-size: 13px;
      line-height: 1.35;
      color: color-mix(in oklch, var(--forest-strong) 84%, var(--paper));
    }

    .trust-band {
      width: 100%;
      padding: 0 var(--pad) clamp(28px, 4vw, 44px);
    }

    .trust-inner {
      width: min(100%, var(--max));
      margin: 0 auto;
      padding: 14px 20px 16px;
      display: flex;
      flex-direction: column;
      gap: 12px;
      background: color-mix(in oklch, var(--paper) 92%, var(--lime-low));
      border: 1px solid var(--line-dark);
      border-radius: 10px;
      overflow: hidden;
    }

    .trust-label {
      color: var(--moss);
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      white-space: nowrap;
    }

    .trust-items {
      display: flex;
      align-items: center;
      gap: 30px;
      white-space: nowrap;
      animation: drift 32s linear infinite;
    }

    .trust-logo {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      height: 34px;
      flex-shrink: 0;
    }

    .trust-logo img {
      max-width: 120px;
      max-height: 26px;
      width: auto;
      height: auto;
      object-fit: contain;
    }

    .trust-logo.tall img {
      max-height: 30px;
    }

    .trust-logo.wide img {
      max-width: 148px;
    }

    .trust-logo::after {
      content: "·";
      margin-left: 30px;
      color: color-mix(in oklch, var(--forest) 22%, transparent);
      font-size: 16px;
    }

    @keyframes drift {
      from { transform: translateX(0); }
      to { transform: translateX(-50%); }
    }

    .numbers-proof {
      padding: clamp(56px, 6vw, 82px) 0 clamp(66px, 7vw, 92px);
      background:
        linear-gradient(180deg, var(--paper) 0%, color-mix(in oklch, var(--paper-low) 64%, var(--paper)) 100%);
      color: var(--ink);
      border-bottom: 1px solid var(--line);
    }

    .numbers-proof-head {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(280px, 0.42fr);
      gap: clamp(24px, 4vw, 58px);
      align-items: end;
      margin-bottom: clamp(24px, 3.3vw, 38px);
    }

    .numbers-proof-kicker {
      margin: 0 0 8px;
      font-family: var(--serif);
      font-style: italic;
      font-weight: 500;
      font-size: clamp(30px, 3vw, 43px);
      line-height: 1;
      color: var(--moss);
    }

    .numbers-proof-title {
      margin: 0;
      max-width: 920px;
      color: var(--forest-strong);
      font-size: clamp(44px, 4.65vw, 66px);
      line-height: 0.98;
      font-weight: 900;
      letter-spacing: 0;
    }

    .numbers-proof-note {
      margin: 0;
      max-width: 520px;
      color: var(--ink-soft);
      font-size: 17px;
      line-height: 1.62;
    }

    .numbers-proof-grid {
      display: grid;
      grid-template-columns: minmax(340px, 0.7fr) minmax(580px, 1.3fr);
      gap: clamp(18px, 2.4vw, 32px) clamp(24px, 3vw, 42px);
      align-items: stretch;
    }

    .institution-proof-card,
    .acceptance-card {
      border-radius: 8px;
      background: color-mix(in oklch, var(--paper) 76%, var(--paper-low));
      overflow: hidden;
      border: 1px solid color-mix(in oklch, var(--line) 80%, transparent);
    }

    .institution-proof-card {
      min-height: clamp(300px, 25vw, 360px);
      position: relative;
      background: var(--forest-strong);
    }

    .institution-fader {
      position: absolute;
      inset: 0;
    }

    .institution-fader img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0;
      filter: saturate(0.9) contrast(1.03);
      animation: institutionFade 15s infinite;
      will-change: opacity, transform;
    }

    .institution-fader img:nth-child(2) {
      animation-delay: 5s;
    }

    .institution-fader img:nth-child(3) {
      animation-delay: 10s;
    }

    @keyframes institutionFade {
      0%, 7% { opacity: 0; transform: scale(1.02); }
      13%, 33% { opacity: 1; transform: scale(1); }
      40%, 100% { opacity: 0; transform: scale(1.015); }
    }

    .proof-stat-stack {
      display: grid;
      grid-template-columns: 1fr;
      grid-column: 1;
      grid-row: 2;
      border: 1px solid color-mix(in oklch, var(--line) 80%, transparent);
      border-radius: 8px;
      overflow: hidden;
      background: color-mix(in oklch, var(--paper) 76%, var(--paper-low));
      margin: 0;
    }

    .proof-stat-card {
      min-height: 124px;
      padding: clamp(16px, 1.5vw, 22px);
      display: grid;
      grid-template-columns: minmax(86px, 0.28fr) minmax(0, 1fr);
      align-items: center;
      gap: clamp(14px, 1.6vw, 22px);
      background: color-mix(in oklch, var(--paper) 76%, var(--paper-low));
    }

    .proof-stat-card strong {
      color: var(--moss);
      font-size: clamp(48px, 3.8vw, 66px);
      line-height: 0.9;
      font-weight: 900;
      letter-spacing: 0;
    }

    .proof-stat-card p {
      margin: 0;
      color: var(--ink-soft);
      font-size: clamp(15px, 1.08vw, 17px);
      line-height: 1.42;
      font-weight: 700;
    }

    .acceptance-card {
      grid-column: 2;
      grid-row: 1 / span 2;
      padding: clamp(24px, 2.35vw, 34px);
      display: grid;
      align-content: start;
    }

    .acceptance-card h2 {
      margin: 0;
      color: var(--forest-strong);
      font-size: clamp(24px, 2vw, 32px);
      line-height: 1.05;
      font-weight: 900;
    }

    .acceptance-legend {
      display: flex;
      flex-wrap: wrap;
      gap: 14px 26px;
      margin: 22px 0 20px;
      color: var(--muted);
      font-size: 13px;
      font-weight: 500;
    }

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

    .acceptance-legend span::before {
      content: "";
      width: 12px;
      height: 12px;
      border-radius: 4px;
      background: color-mix(in oklch, var(--line) 84%, var(--forest));
    }

    .acceptance-legend span:last-child {
      color: var(--moss);
    }

    .acceptance-legend span:last-child::before {
      background: var(--moss);
    }

    .acceptance-chart {
      display: grid;
      gap: 11px;
    }

    .acceptance-row {
      display: grid;
      grid-template-columns: 116px minmax(0, 1fr);
      gap: 14px;
      align-items: center;
    }

    .acceptance-school {
      color: color-mix(in oklch, var(--ink) 80%, var(--muted));
      font-size: 16px;
      font-weight: 900;
    }

    .acceptance-bars {
      display: grid;
      gap: 6px;
    }

    .acceptance-mini-bar,
    .acceptance-main-bar {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 10px;
      align-items: center;
    }

    .proof-bar-track {
      height: 11px;
      border-radius: 999px;
      background: color-mix(in oklch, var(--line) 54%, transparent);
      overflow: hidden;
    }

    .acceptance-mini-bar .proof-bar-track {
      height: 12px;
      max-width: 92px;
      background: transparent;
    }

    .proof-bar-fill {
      display: block;
      width: var(--bar-width);
      height: 100%;
      border-radius: inherit;
      transform: scaleX(0);
      transform-origin: left center;
      transition: transform 920ms cubic-bezier(0.16, 1, 0.3, 1);
    }

    .acceptance-mini-bar .proof-bar-fill {
      background: color-mix(in oklch, var(--line) 84%, var(--forest));
      transition-delay: 80ms;
    }

    .acceptance-main-bar .proof-bar-fill {
      background: linear-gradient(90deg, var(--forest-strong), var(--moss));
      transition-delay: 180ms;
    }

    .numbers-proof.visible .proof-bar-fill {
      transform: scaleX(1);
    }

    .acceptance-value {
      min-width: 48px;
      color: var(--muted);
      font-size: 14px;
      font-weight: 600;
      line-height: 1;
    }

    .acceptance-main-bar .acceptance-value {
      color: var(--moss);
      font-weight: 700;
    }

    .section {
      padding: 104px 0;
    }

    .section.compact {
      padding: 76px 0;
    }

    .section.dark {
      background: var(--forest);
      color: var(--paper);
    }

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

    .section-head {
      display: grid;
      grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.65fr);
      gap: 48px;
      align-items: end;
      margin-bottom: 46px;
    }

    .section-title {
      margin: 0;
      max-width: 760px;
      color: var(--forest-strong);
      font-size: 52px;
      line-height: 1;
      font-weight: 800;
      letter-spacing: 0;
    }

    .section.dark .section-title {
      color: var(--paper);
    }

    .section-title.serif {
      font-family: var(--serif);
      font-size: 58px;
      font-weight: 500;
      line-height: 1.03;
    }

    .section-copy {
      margin: 0;
      color: var(--muted);
      font-size: 17px;
      line-height: 1.65;
      max-width: 620px;
    }

    .dark .section-copy {
      color: color-mix(in oklch, var(--paper) 66%, var(--forest));
    }

    .intro-grid {
      display: grid;
      grid-template-columns: 0.95fr 1.05fr;
      gap: 52px;
      align-items: stretch;
    }

    .intro-panel {
      padding: 42px;
      background: var(--forest-strong);
      color: var(--paper);
      border-radius: 8px;
      min-height: 440px;
      display: grid;
      align-content: space-between;
      position: relative;
      overflow: hidden;
    }

    .intro-panel::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 5%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 5%, transparent) 1px, transparent 1px);
      background-size: 56px 56px;
      pointer-events: none;
      opacity: 0.8;
    }

    .intro-panel > * {
      position: relative;
      z-index: 1;
    }

    .intro-panel blockquote {
      margin: 0;
      font-family: var(--serif);
      font-size: 42px;
      line-height: 1.08;
      color: var(--paper);
    }

    .intro-panel cite {
      margin-top: 32px;
      color: var(--lime);
      font-size: 13px;
      font-style: normal;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.12em;
    }

    .intro-copy {
      display: grid;
      gap: 18px;
      align-content: center;
    }

    .intro-copy p {
      margin: 0;
      color: var(--ink-soft);
      font-size: 18px;
      line-height: 1.65;
      max-width: 760px;
    }

    .intro-copy strong {
      color: var(--ink);
      font-weight: 800;
    }

    .photo-slot {
      min-height: 320px;
      border-radius: 8px;
      border: 1px solid color-mix(in oklch, var(--line) 88%, var(--forest));
      background:
        linear-gradient(135deg, color-mix(in oklch, var(--paper) 85%, var(--lime-low)), color-mix(in oklch, var(--paper-deep) 82%, var(--moss))),
        var(--paper-low);
      position: relative;
      overflow: hidden;
      display: grid;
      place-items: end start;
      padding: 22px;
    }

    .photo-slot::before {
      content: "";
      position: absolute;
      inset: 16px;
      border: 1px solid color-mix(in oklch, var(--forest) 18%, transparent);
      border-radius: 5px;
    }

    .photo-slot::after {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, transparent 49.6%, color-mix(in oklch, var(--forest) 16%, transparent) 50%, transparent 50.4%),
        linear-gradient(180deg, transparent 49.6%, color-mix(in oklch, var(--forest) 16%, transparent) 50%, transparent 50.4%);
      opacity: 0.45;
    }

    .slot-label {
      position: relative;
      z-index: 1;
      display: grid;
      gap: 4px;
    }

    .slot-label strong {
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--forest);
    }

    .slot-label span {
      font-family: var(--serif);
      font-size: 23px;
      line-height: 1.05;
      color: var(--ink);
    }

    .belief-section {
      padding: clamp(48px, 6vw, 82px) 0;
      background: var(--paper);
      scroll-margin-top: 92px;
    }

    .belief-model {
      position: relative;
    }

    .belief-scroll-shell {
      min-height: 238vh;
    }

    .belief-scroll-sticky {
      position: sticky;
      top: 92px;
      min-height: min(780px, calc(100vh - 116px));
      padding: clamp(26px, 3.4vw, 42px);
      border-radius: 8px;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 5%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 5%, transparent) 1px, transparent 1px),
        var(--forest-strong);
      background-size: 58px 58px, 58px 58px, auto;
      color: var(--paper);
      overflow: hidden;
      display: grid;
      align-content: center;
    }

    .belief-scroll-sticky::after {
      content: "";
      position: absolute;
      inset: -28% -18% auto auto;
      width: 420px;
      height: 420px;
      border-radius: 50%;
      background: color-mix(in oklch, var(--moss) 22%, transparent);
      filter: blur(80px);
      pointer-events: none;
    }

    .belief-scroll-sticky > * {
      position: relative;
      z-index: 1;
    }

    .belief-model-head {
      display: grid;
      grid-template-columns: minmax(0, 0.88fr) minmax(320px, 0.52fr);
      gap: clamp(26px, 5vw, 76px);
      align-items: end;
      padding-bottom: clamp(24px, 3vw, 34px);
      border-bottom: 1px solid color-mix(in oklch, var(--paper) 16%, transparent);
    }

    .belief-model-head > * {
      min-width: 0;
    }

    .belief-model-head h2 {
      margin: 0;
      max-width: 760px;
      color: var(--paper);
      font-size: clamp(40px, 4.8vw, 64px);
      line-height: 0.96;
      font-weight: 900;
      letter-spacing: 0;
      overflow-wrap: break-word;
      text-wrap: balance;
    }

    .belief-model-head > p {
      margin: 0;
      max-width: 520px;
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
      font-size: 17px;
      line-height: 1.62;
    }

    .belief-scroll-grid {
      display: grid;
      grid-template-columns: minmax(380px, 0.78fr) minmax(360px, 0.72fr);
      gap: clamp(24px, 4vw, 60px);
      margin-top: clamp(20px, 2.6vw, 28px);
      align-items: stretch;
    }

    .belief-step-list {
      display: grid;
      gap: 1px;
      border: 1px solid color-mix(in oklch, var(--paper) 16%, transparent);
      border-radius: 8px;
      overflow: hidden;
      background: color-mix(in oklch, var(--paper) 16%, transparent);
    }

    .belief-step {
      min-height: 136px;
      padding: clamp(18px, 2vw, 24px);
      display: grid;
      grid-template-columns: minmax(76px, 0.24fr) minmax(0, 1fr);
      gap: clamp(16px, 2.2vw, 28px);
      align-items: start;
      background: color-mix(in oklch, var(--forest) 76%, var(--forest-strong));
      opacity: 0.62;
      transition: opacity 260ms ease, background 260ms ease, color 260ms ease;
    }

    .belief-step.is-active {
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--lime) 9%, transparent), transparent 62%),
        color-mix(in oklch, var(--forest) 62%, var(--forest-strong));
      opacity: 1;
    }

    .belief-model-number {
      color: color-mix(in oklch, var(--paper) 30%, var(--forest));
      font-family: var(--serif);
      font-size: clamp(54px, 5vw, 76px);
      line-height: 0.82;
      font-weight: 500;
      letter-spacing: 0;
      transition: color 260ms ease;
    }

    .belief-step.is-active .belief-model-number {
      color: var(--lime);
    }

    .belief-step-copy {
      min-width: 0;
    }

    .belief-step h3 {
      margin: 0;
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
      font-size: clamp(23px, 2vw, 29px);
      line-height: 1.02;
      font-weight: 900;
      transition: color 260ms ease;
    }

    .belief-step.is-active h3 {
      color: var(--paper);
    }

    .belief-step p {
      margin: 12px 0 0;
      max-width: 360px;
      color: color-mix(in oklch, var(--paper) 48%, var(--forest));
      font-size: 14px;
      line-height: 1.48;
      transition: color 260ms ease;
    }

    .belief-step.is-active p {
      color: color-mix(in oklch, var(--paper) 76%, var(--forest));
    }

    .belief-visual {
      min-height: 100%;
      display: grid;
    }

    .belief-visual-frame {
      min-height: 100%;
      border: 1px solid color-mix(in oklch, var(--paper) 16%, transparent);
      border-radius: 8px;
      background:
        color-mix(in oklch, var(--paper) 10%, var(--forest));
      position: relative;
      overflow: hidden;
    }

    .belief-visual-frame::before {
      content: "";
      position: absolute;
      inset: 18px;
      border: 1px solid color-mix(in oklch, var(--paper) 18%, transparent);
      border-radius: 5px;
      pointer-events: none;
      z-index: 2;
    }

    .belief-visual-image {
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      opacity: 0;
      background-position: center;
      background-size: cover;
      transform: scale(1.012);
      transition: opacity 520ms cubic-bezier(0.22, 1, 0.36, 1), transform 900ms cubic-bezier(0.22, 1, 0.36, 1);
      will-change: opacity, transform;
    }

    .belief-visual-image::after {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, transparent 48%, color-mix(in oklch, var(--forest-strong) 28%, transparent)),
        radial-gradient(circle at 72% 18%, color-mix(in oklch, var(--lime) 11%, transparent), transparent 32%);
      z-index: 1;
    }

    .belief-visual-image.is-active {
      opacity: 1;
      transform: scale(1);
    }

    .belief-visual-symbol {
      position: relative;
      z-index: 3;
      width: min(42%, 176px);
      min-width: 112px;
      aspect-ratio: 1;
      height: auto;
      padding: clamp(22px, 2.8vw, 34px);
      border: 1px solid color-mix(in oklch, var(--lime) 28%, transparent);
      border-radius: 999px;
      color: color-mix(in oklch, var(--lime) 74%, var(--paper));
      background:
        radial-gradient(circle at 34% 24%, color-mix(in oklch, var(--paper) 13%, transparent), transparent 38%),
        color-mix(in oklch, var(--forest-strong) 42%, transparent);
      box-shadow: 0 24px 70px color-mix(in oklch, var(--forest-strong) 42%, transparent);
      stroke: currentColor;
      fill: none;
      stroke-width: 2.25;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .belief-visual-image-1 {
      background-image:
        linear-gradient(128deg, color-mix(in oklch, var(--paper) 10%, transparent), transparent 52%),
        radial-gradient(circle at 30% 32%, color-mix(in oklch, var(--lime) 22%, transparent), transparent 24%),
        linear-gradient(150deg, color-mix(in oklch, var(--moss) 42%, var(--forest)), var(--forest-strong));
    }

    .belief-visual-image-2 {
      background-image:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 8%, transparent) 1px, transparent 1px),
        linear-gradient(0deg, color-mix(in oklch, var(--paper) 7%, transparent) 1px, transparent 1px),
        radial-gradient(circle at 74% 24%, color-mix(in oklch, var(--clay) 22%, transparent), transparent 26%),
        linear-gradient(145deg, color-mix(in oklch, var(--forest-soft) 76%, var(--moss)), var(--forest-strong));
      background-size: 46px 46px, 46px 46px, auto, auto;
    }

    .belief-visual-image-3 {
      background-image:
        linear-gradient(135deg, color-mix(in oklch, var(--paper) 13%, transparent), transparent 44%),
        radial-gradient(circle at 50% 18%, color-mix(in oklch, var(--blue) 22%, transparent), transparent 24%),
        linear-gradient(180deg, color-mix(in oklch, var(--forest) 82%, var(--paper)), var(--forest-strong));
    }

    @media (prefers-reduced-motion: reduce) {
      .belief-visual-image {
        transform: none;
        transition: opacity 1ms linear;
      }
    }

    .belief-scroll-track {
      position: absolute;
      inset: 0;
      pointer-events: none;
    }

    .program-shell {
      display: grid;
      grid-template-columns: 290px minmax(0, 1fr);
      gap: 26px;
      align-items: stretch;
    }

    .program-tabs {
      display: grid;
      gap: 10px;
      align-content: start;
    }

    .program-tab {
      width: 100%;
      min-height: 74px;
      padding: 16px;
      border: 1px solid var(--line-dark);
      border-radius: 8px;
      background: color-mix(in oklch, var(--forest-strong) 64%, transparent);
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
      display: grid;
      gap: 5px;
      text-align: left;
      cursor: pointer;
      transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
    }

    .program-tab:hover,
    .program-tab[aria-selected="true"] {
      background: var(--lime);
      color: var(--forest-strong);
      border-color: var(--lime);
    }

    .program-tab strong {
      font-size: 15px;
      font-weight: 900;
    }

    .program-tab span {
      font-size: 12px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      opacity: 0.82;
    }

    .program-stage {
      display: none;
      grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.72fr);
      gap: 30px;
      min-height: 520px;
      border: 1px solid var(--line-dark);
      border-radius: 8px;
      background: color-mix(in oklch, var(--forest-strong) 68%, transparent);
      overflow: hidden;
    }

    .program-stage.active {
      display: grid;
    }

    .stage-copy {
      padding: 42px;
      display: grid;
      align-content: space-between;
      gap: 36px;
    }

    .stage-kicker {
      color: var(--lime);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      margin: 0 0 12px;
    }

    .stage-copy h3 {
      margin: 0;
      font-size: 48px;
      line-height: 1;
      font-weight: 800;
      letter-spacing: 0;
    }

    .stage-copy p {
      margin: 22px 0 0;
      max-width: 620px;
      color: color-mix(in oklch, var(--paper) 70%, var(--forest));
      font-size: 17px;
      line-height: 1.62;
    }

    .stage-list {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0;
      border-top: 1px solid var(--line-dark);
      border-bottom: 1px solid var(--line-dark);
      list-style: none;
      margin: 0;
      padding: 0;
    }

    .stage-list li {
      padding: 15px 16px 15px 0;
      border-bottom: 1px solid var(--line-dark);
      color: color-mix(in oklch, var(--paper) 76%, var(--forest));
      font-size: 14px;
      line-height: 1.42;
    }

    .stage-list li:nth-child(2n) {
      padding-left: 16px;
      border-left: 1px solid var(--line-dark);
    }

    .stage-list li:nth-last-child(-n + 2) {
      border-bottom: none;
    }

    .stage-media {
      padding: 24px 24px 24px 0;
      display: grid;
      min-height: 100%;
    }

    .stage-media .photo-slot {
      min-height: 100%;
      background:
        linear-gradient(135deg, color-mix(in oklch, var(--forest-soft) 78%, var(--paper)), color-mix(in oklch, var(--lime-low) 24%, var(--forest))),
        var(--forest-soft);
      border-color: var(--line-dark);
    }

    .stage-media .slot-label strong,
    .stage-media .slot-label span {
      color: var(--paper);
    }

    .method-section {
      position: relative;
      overflow: hidden;
    }

    .method-section::before {
      content: "";
      position: absolute;
      inset: 0 0 auto;
      height: 520px;
      background:
        linear-gradient(180deg, color-mix(in oklch, var(--lime-low) 36%, transparent), transparent 78%),
        linear-gradient(90deg, color-mix(in oklch, var(--forest-strong) 4%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--forest-strong) 4%, transparent) 1px, transparent 1px);
      background-size: auto, 96px 96px, 96px 96px;
      pointer-events: none;
    }

    .method-section .wrap {
      position: relative;
      z-index: 1;
    }

    .method-grid {
      display: grid;
      gap: clamp(46px, 6.6vw, 88px);
    }

    .method-hero {
      display: grid;
      grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.56fr);
      gap: clamp(30px, 6vw, 94px);
      align-items: end;
    }

    .method-hero h2 {
      margin: 0;
      max-width: 840px;
      line-height: 0.95;
      letter-spacing: 0;
    }

    .method-hero h2 span,
    .method-hero h2 strong {
      display: block;
    }

    .method-hero h2 span {
      font-family: var(--serif);
      font-size: clamp(43px, 5.1vw, 80px);
      font-style: italic;
      font-weight: 500;
      color: var(--moss);
      letter-spacing: 0;
    }

    .method-hero h2 strong {
      margin-top: 6px;
      color: var(--forest-strong);
      font-size: clamp(48px, 6.9vw, 104px);
      font-weight: 900;
      letter-spacing: 0;
    }

    .method-hero p:not(.eyebrow) {
      margin: 0;
      max-width: 520px;
      color: var(--ink-soft);
      font-size: clamp(18px, 1.5vw, 22px);
      line-height: 1.54;
    }

    .method-sequence {
      display: grid;
      gap: 0;
    }

    .method-chapter {
      --method-copy-opacity: 1;
      --method-visual-opacity: 1;
      --method-copy-y: 0px;
      --method-visual-y: 0px;
      --method-visual-scale: 1;
      display: grid;
      grid-template-columns: minmax(0, 0.58fr) minmax(420px, 0.74fr);
      gap: clamp(34px, 7vw, 112px);
      align-items: center;
      min-height: clamp(720px, 86svh, 940px);
      padding-block: clamp(56px, 8svh, 104px);
    }

    .method-chapter:nth-child(2n) {
      grid-template-columns: minmax(0, 0.58fr) minmax(420px, 0.74fr);
    }

    .method-chapter:nth-child(2n) .method-feature {
      grid-column: 1;
    }

    .method-chapter:nth-child(2n) .method-visual {
      grid-column: 2;
      grid-row: 1;
    }

    .method-feature {
      display: grid;
      align-content: center;
      gap: 20px;
      max-width: 620px;
    }

    .method-scroll-ready .method-feature {
      opacity: var(--method-copy-opacity);
      transform: translate3d(0, var(--method-copy-y), 0);
      transition: opacity 120ms linear, transform 120ms linear;
      will-change: opacity, transform;
    }

    .method-kicker {
      margin: 0;
      color: var(--moss);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.12em;
      text-transform: uppercase;
    }

    .method-feature h3 {
      margin: 0;
      color: var(--forest-strong);
      font-size: clamp(36px, 4.2vw, 64px);
      line-height: 1;
      letter-spacing: 0;
    }

    .method-feature p {
      margin: 0;
      max-width: 570px;
      color: var(--ink-soft);
      font-size: 18.5px;
      line-height: 1.62;
    }

    .method-pill-row {
      display: flex;
      flex-wrap: wrap;
      gap: 9px;
      margin-top: 6px;
    }

    .method-pill {
      display: inline-flex;
      align-items: center;
      min-height: 34px;
      padding: 0 12px;
      border-radius: 999px;
      background: color-mix(in oklch, var(--lime-low) 74%, var(--paper));
      color: var(--forest-strong);
      font-size: 11px;
      font-weight: 900;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      border: 1px solid color-mix(in oklch, var(--moss) 18%, transparent);
    }

    .method-visual {
      position: relative;
      min-height: 490px;
      border-radius: 8px;
      overflow: hidden;
      isolation: isolate;
      background:
        linear-gradient(135deg, color-mix(in oklch, var(--paper-low) 92%, var(--lime-low)), color-mix(in oklch, var(--lime-low) 34%, var(--paper))),
        linear-gradient(90deg, color-mix(in oklch, var(--forest-strong) 7%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--forest-strong) 7%, transparent) 1px, transparent 1px);
      background-size: auto, 76px 76px, 76px 76px;
      border: 1px solid var(--line);
      box-shadow: 0 30px 80px color-mix(in oklch, var(--forest-strong) 13%, transparent);
    }

    .method-scroll-ready .method-visual {
      opacity: var(--method-visual-opacity);
      transform: translate3d(0, var(--method-visual-y), 0) scale(var(--method-visual-scale));
      transform-origin: center;
      transition: opacity 120ms linear, transform 120ms linear;
      will-change: opacity, transform;
    }

    .method-visual::before {
      content: "";
      position: absolute;
      inset: auto 0 0;
      height: 42%;
      background: linear-gradient(180deg, transparent, color-mix(in oklch, var(--forest-strong) 18%, transparent));
      pointer-events: none;
      z-index: 1;
    }

    .method-visual::after {
      content: "";
      position: absolute;
      inset: 22px;
      border: 1px solid color-mix(in oklch, var(--forest-strong) 10%, transparent);
      pointer-events: none;
      z-index: 1;
    }

    .method-visual-photo img {
      position: absolute;
      right: -8px;
      bottom: 0;
      width: min(78%, 430px);
      max-height: 95%;
      object-fit: contain;
      object-position: bottom right;
      filter: drop-shadow(0 24px 42px color-mix(in oklch, var(--forest-strong) 24%, transparent));
      z-index: 2;
    }

    .method-admit-card,
    .method-proof-card,
    .method-note-card {
      position: absolute;
      z-index: 3;
      border-radius: 8px;
      box-shadow: 0 18px 42px color-mix(in oklch, var(--forest-strong) 16%, transparent);
    }

    .method-admit-card {
      left: 26px;
      top: 26px;
      width: 188px;
      padding: 19px 20px;
      background: var(--forest-strong);
      color: var(--paper);
      border: 1px solid var(--line-dark);
    }

    .method-admit-card span,
    .method-proof-card span,
    .method-note-card span {
      display: block;
      font-size: 11px;
      font-weight: 900;
      letter-spacing: 0.12em;
      text-transform: uppercase;
    }

    .method-admit-card span {
      color: var(--lime);
    }

    .method-admit-card strong {
      display: block;
      margin-top: 8px;
      font-family: var(--serif);
      font-size: 32px;
      font-weight: 500;
      line-height: 0.98;
    }

    .method-proof-card {
      left: 48px;
      bottom: 50px;
      width: min(288px, 64%);
      padding: 18px 20px;
      background: var(--paper);
      color: var(--forest-strong);
      border: 1px solid var(--line);
    }

    .method-proof-card span,
    .method-note-card span {
      color: var(--moss);
    }

    .method-proof-card strong,
    .method-note-card strong {
      display: block;
      margin-top: 8px;
      font-size: 20px;
      line-height: 1.12;
    }

    .method-blueprint {
      position: absolute;
      inset: 38px;
      z-index: 2;
      display: grid;
      align-content: center;
      gap: 16px;
    }

    .method-visual:not(.method-visual-photo) .method-blueprint {
      inset: 38px 38px 150px;
    }

    .blueprint-line {
      display: grid;
      grid-template-columns: 64px 1fr auto;
      gap: 16px;
      align-items: center;
      min-height: 82px;
      padding: 16px 18px;
      background: color-mix(in oklch, var(--paper) 88%, transparent);
      border: 1px solid var(--line);
      box-shadow: 0 16px 34px color-mix(in oklch, var(--forest-strong) 9%, transparent);
    }

    .blueprint-line:nth-child(2) {
      margin-left: clamp(18px, 8vw, 82px);
    }

    .blueprint-line:nth-child(3) {
      margin-left: clamp(6px, 4vw, 40px);
    }

    .blueprint-line span {
      font-family: var(--serif);
      color: var(--moss);
      font-size: 34px;
      line-height: 1;
    }

    .blueprint-line strong {
      color: var(--forest-strong);
      font-size: 20px;
      line-height: 1.1;
    }

    .blueprint-line em {
      justify-self: end;
      font-style: normal;
      color: var(--forest-strong);
      font-size: 11px;
      font-weight: 900;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      background: var(--lime-low);
      border-radius: 999px;
      padding: 8px 10px;
    }

    .method-note-card {
      right: 28px;
      bottom: 28px;
      width: min(260px, 52%);
      padding: 17px 18px;
      background: var(--forest-strong);
      color: var(--paper);
      border: 1px solid var(--line-dark);
    }

    .method-note-card span {
      color: var(--lime);
    }

    .outcome-carousel {
      position: relative;
    }

    .outcome-track {
      display: flex;
      gap: 14px;
      overflow-x: auto;
      scroll-snap-type: x mandatory;
      scroll-behavior: smooth;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
      padding-bottom: 2px;
    }

    .outcome-track::-webkit-scrollbar {
      display: none;
    }

    .outcome-track .outcome-card {
      flex: 0 0 calc((100% - 42px) / 4);
      scroll-snap-align: start;
    }

    .outcome-nav {
      display: flex;
      gap: 10px;
      justify-content: flex-end;
      margin-top: 22px;
    }

    .outcome-btn {
      width: 42px;
      height: 42px;
      border-radius: 50%;
      border: 1px solid var(--line);
      background: var(--paper);
      color: var(--forest-strong);
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background 0.15s, border-color 0.15s, color 0.15s;
      flex-shrink: 0;
    }

    .outcome-btn:hover:not(:disabled) {
      background: var(--forest-strong);
      color: var(--paper);
      border-color: var(--forest-strong);
    }

    .outcome-btn:disabled {
      opacity: 0.28;
      cursor: default;
    }

    .outcome-btn svg {
      width: 18px;
      height: 18px;
    }

    .outcome-card {
      min-height: 460px;
      border-radius: 8px;
      overflow: hidden;
      background: var(--paper);
      border: 1px solid var(--line);
      display: grid;
      grid-template-rows: 320px 1fr;
    }

    .outcome-card .photo-slot {
      min-height: 288px;
      border: none;
      border-radius: 0;
    }

    .outcome-photo {
      width: 100%;
      height: 320px;
      object-fit: cover;
      object-position: center;
      background: var(--paper-low);
    }

    .outcome-body {
      padding: 20px;
      display: grid;
      grid-template-rows: auto 1fr;
      gap: 13px;
    }

    .outcome-name {
      display: flex;
      justify-content: space-between;
      gap: 14px;
      align-items: center;
      border-bottom: 1px solid var(--line);
      padding-bottom: 13px;
    }

    .outcome-name strong {
      font-size: 20px;
    }

    .outcome-body p {
      margin: 0;
      color: var(--ink-soft);
      font-size: 14px;
      line-height: 1.55;
    }

    .admit-badges {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 9px;
      align-items: center;
      flex: 0 0 auto;
    }

    .admit-badge {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 28px;
      height: 28px;
    }

    .admit-badge img {
      width: 26px;
      height: 26px;
      object-fit: contain;
    }

    .stories-showcase {
      position: relative;
      overflow: hidden;
      padding: clamp(82px, 10vw, 132px) 0 clamp(90px, 11vw, 142px);
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 6%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 6%, transparent) 1px, transparent 1px),
        var(--forest-strong);
      background-size: 88px 88px;
      color: var(--paper);
      border-top: 1px solid var(--line-dark);
      border-bottom: 1px solid var(--line-dark);
    }

    .stories-head {
      display: grid;
      grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.6fr);
      gap: clamp(28px, 5vw, 72px);
      align-items: end;
      margin-bottom: clamp(34px, 6vw, 76px);
    }

    .stories-title {
      margin: 0;
      max-width: 850px;
      font-size: clamp(54px, 8.6vw, 118px);
      line-height: 0.88;
      letter-spacing: 0;
      font-weight: 900;
      color: var(--paper);
    }

    .stories-title span {
      display: block;
    }

    .stories-title em {
      display: block;
      font-family: var(--serif);
      font-weight: 500;
      font-style: italic;
      color: var(--lime);
    }

    .stories-copy {
      margin: 0;
      max-width: 520px;
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
      font-size: 18px;
      line-height: 1.62;
    }

    .student-story-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: clamp(16px, 2vw, 24px);
      align-items: start;
    }

    .student-story-card {
      min-height: 100%;
      border: 1px solid color-mix(in oklch, var(--paper) 18%, transparent);
      border-radius: 8px;
      overflow: hidden;
      background: var(--paper);
      color: var(--ink);
      display: grid;
      grid-template-rows: auto auto 1fr;
      box-shadow: 0 28px 66px color-mix(in oklch, var(--ink) 18%, transparent);
    }

    .student-story-card:nth-child(even) {
      margin-top: clamp(24px, 4vw, 54px);
    }

    .story-card-top {
      min-height: 122px;
      padding: 18px;
      border-bottom: 1px solid var(--line);
      display: grid;
      align-content: end;
      gap: 8px;
      background: color-mix(in oklch, var(--paper-low) 82%, var(--lime-low));
    }

    .accepted-label {
      color: var(--muted);
      font-size: 10px;
      font-weight: 900;
      letter-spacing: 0.13em;
      text-transform: uppercase;
    }

    .accepted-school {
      color: var(--forest-strong);
      font-size: clamp(22px, 2.4vw, 34px);
      line-height: 0.98;
      font-weight: 900;
    }

    .story-photo-wrap {
      position: relative;
      aspect-ratio: 1 / 1.08;
      overflow: hidden;
      background: var(--paper-low);
    }

    .story-photo-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      transform: scale(1.01);
      transition: transform 420ms cubic-bezier(0.25, 0, 0.15, 1);
    }

    .student-story-card:hover .story-photo-wrap img {
      transform: scale(1.045);
    }

    .story-card-body {
      padding: 20px;
      display: grid;
      gap: 18px;
      align-content: start;
    }

    .story-meta {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
      padding-bottom: 17px;
      border-bottom: 1px solid var(--line);
    }

    .story-meta span {
      display: block;
      margin-bottom: 5px;
      color: var(--muted);
      font-size: 10px;
      font-weight: 900;
      letter-spacing: 0.12em;
      text-transform: uppercase;
    }

    .story-meta strong {
      display: block;
      color: var(--ink);
      font-size: 14px;
      line-height: 1.22;
      font-weight: 900;
    }

    .story-card-note {
      margin: 0;
      color: var(--ink-soft);
      font-size: 14px;
      line-height: 1.58;
    }

    .story-link {
      display: inline-flex;
      align-items: center;
      justify-self: start;
      min-height: 42px;
      padding: 0 16px;
      border-radius: 999px;
      background: var(--forest-strong);
      color: var(--paper);
      font-size: 13px;
      font-weight: 900;
      transition: background 160ms ease, color 160ms ease;
    }

    .story-link:hover {
      background: var(--lime);
      color: var(--forest-strong);
    }

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

    .fit-block {
      border: 1px solid var(--line-dark);
      border-radius: 8px;
      padding: 30px;
      background: var(--forest-strong);
    }

    .fit-block h3 {
      margin: 0 0 20px;
      color: var(--paper);
      font-size: 30px;
      line-height: 1.1;
    }

    .fit-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 13px;
    }

    .fit-list li {
      display: grid;
      grid-template-columns: 22px minmax(0, 1fr);
      gap: 11px;
      color: color-mix(in oklch, var(--paper) 74%, var(--forest));
      font-size: 15px;
      line-height: 1.48;
    }

    .fit-list svg {
      width: 18px;
      height: 18px;
      margin-top: 2px;
      color: var(--lime);
    }

    .fit-block.not .fit-list svg {
      color: color-mix(in oklch, var(--paper) 34%, var(--forest));
    }

    .team-section {
      padding: clamp(72px, 8vw, 96px) 0;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        var(--forest-strong);
      background-size: 80px 80px;
      color: var(--paper);
    }

    .team-section .eyebrow {
      color: var(--lime);
    }

    .team-section .team-header h2 {
      color: var(--paper);
    }

    .team-section .team-header p:not(.eyebrow) {
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
    }

    .team-grid {
      display: grid;
      gap: clamp(30px, 4vw, 46px);
    }

    .team-header {
      display: grid;
      grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.52fr);
      gap: clamp(28px, 5vw, 70px);
      align-items: end;
    }

    .team-header h2 {
      margin: 0;
      max-width: 820px;
      font-size: clamp(42px, 4.7vw, 64px);
      line-height: 0.98;
      font-weight: 900;
      letter-spacing: 0;
    }

    .team-header p:not(.eyebrow) {
      margin: 0;
      color: var(--ink-soft);
      font-size: 17px;
      line-height: 1.62;
      max-width: 560px;
    }

    .team-people-grid {
      display: grid;
      grid-template-columns: minmax(380px, 0.92fr) minmax(0, 1.08fr);
      gap: clamp(18px, 2vw, 24px);
      align-items: stretch;
    }

    .team-person {
      border: 1px solid color-mix(in oklch, var(--line) 82%, transparent);
      border-radius: 8px;
      background: color-mix(in oklch, var(--paper) 76%, var(--paper-low));
      overflow: hidden;
    }

    .team-person {
      display: grid;
    }

    .team-founder {
      min-height: 536px;
      grid-template-rows: minmax(320px, 1fr) auto;
    }

    .team-support-stack {
      display: grid;
      grid-template-rows: repeat(2, minmax(0, 1fr));
      gap: clamp(14px, 1.8vw, 20px);
    }

    .team-support {
      min-height: 0;
      grid-template-columns: minmax(142px, 0.34fr) minmax(0, 1fr);
    }

    .team-photo {
      min-height: 220px;
      position: relative;
      overflow: hidden;
    }

    .team-photo img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
    }

    .team-founder .team-photo {
      min-height: 340px;
    }

    .team-support .team-photo {
      min-height: 100%;
    }

    .team-person-copy {
      padding: clamp(22px, 2.4vw, 32px);
      display: grid;
      align-content: start;
    }

    .team-role {
      margin: 0 0 9px;
      color: var(--moss);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.11em;
      text-transform: uppercase;
    }

    .team-person h3 {
      margin: 0;
      color: var(--forest-strong);
      font-size: clamp(25px, 2.4vw, 34px);
      line-height: 1;
      font-weight: 900;
      letter-spacing: 0;
    }

    .team-person-copy p:last-child {
      margin: 28px 0 0;
      color: var(--ink-soft);
      font-size: 15px;
      line-height: 1.55;
    }

    .team-name-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }

    .team-founder .team-name-row {
      flex-direction: column;
      align-items: flex-start;
      gap: 10px;
    }

    .team-name-li {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .team-li-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 26px;
      height: 26px;
      border-radius: 5px;
      background: #0a66c2;
      color: var(--paper);
      flex-shrink: 0;
      text-decoration: none;
      transition: opacity 0.15s;
    }

    .team-li-btn:hover {
      opacity: 0.8;
    }

    .team-li-btn svg {
      width: 14px;
      height: 14px;
    }

    .team-inst-badges {
      display: flex;
      gap: 8px;
      align-items: center;
      flex-shrink: 0;
    }

    .team-inst-badge {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 40px;
      height: 40px;
    }

    .team-inst-badge img {
      width: 38px;
      height: 38px;
      object-fit: contain;
    }

    .universities {
      display: grid;
      grid-template-columns: repeat(6, minmax(0, 1fr));
      border-top: 1px solid var(--line);
      border-left: 1px solid var(--line);
      background: var(--paper);
    }

    .university {
      min-height: 120px;
      padding: 20px;
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      display: grid;
      align-content: center;
      gap: 10px;
    }

    .university img {
      width: 52px;
      height: 52px;
      object-fit: contain;
      filter: saturate(0.84);
    }

    .university strong {
      font-size: 15px;
      line-height: 1.15;
    }

    .university span {
      color: var(--muted);
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.08em;
    }

    .quote-band {
      padding: 90px 0;
      background: var(--lime);
      color: var(--forest-strong);
    }

    .quote-layout {
      display: grid;
      grid-template-columns: minmax(0, 0.36fr) minmax(0, 1fr);
      gap: 46px;
      align-items: start;
    }

    .quote-mark {
      font-family: var(--serif);
      font-size: 126px;
      line-height: 0.75;
    }

    .quote-text {
      margin: 0;
      font-family: var(--serif);
      font-style: italic;
      font-size: 42px;
      line-height: 1.18;
    }

    .quote-credit {
      margin-top: 24px;
      font-size: 13px;
      font-style: normal;
      font-weight: 900;
      letter-spacing: 0.1em;
      text-transform: uppercase;
    }

    .cta-section {
      padding: 96px 0;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        var(--forest-strong);
      background-size: 80px 80px;
      color: var(--paper);
    }

    .cta-grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 340px;
      gap: 42px;
      align-items: center;
    }

    .cta-grid h2 {
      margin: 0;
      font-size: 66px;
      line-height: 0.95;
      font-weight: 800;
    }

    .cta-grid p {
      margin: 22px 0 0;
      max-width: 640px;
      color: color-mix(in oklch, var(--paper) 68%, var(--forest));
      font-size: 18px;
      line-height: 1.58;
    }

    .cta-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      justify-content: center;
    }

    .footer {
      background: var(--forest-strong);
      color: color-mix(in oklch, var(--paper) 62%, var(--forest));
      border-top: 1px solid var(--line-dark);
      padding: 54px 0 32px;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 1.35fr repeat(2, minmax(0, 1fr));
      gap: 36px;
    }

    .footer h3 {
      margin: 0 0 14px;
      color: var(--paper);
      font-size: 13px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: 0.12em;
    }

    .footer p,
    .footer a {
      color: color-mix(in oklch, var(--paper) 62%, var(--forest));
      font-size: 14px;
      line-height: 1.62;
    }

    .footer a:hover {
      color: var(--lime);
    }

    .footer ul {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 9px;
    }

    .footer-bottom {
      margin-top: 40px;
      padding-top: 22px;
      border-top: 1px solid var(--line-dark);
      display: flex;
      justify-content: space-between;
      gap: 20px;
      color: color-mix(in oklch, var(--paper) 55%, var(--forest));
      font-size: 12px;
    }

    .footer-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      margin-bottom: 18px;
    }

    .footer .brand-word strong { color: var(--paper); }

    .sticky-cta {
      position: fixed;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 60;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: clamp(14px, 2.2vw, 28px);
      width: 100%;
      min-height: 72px;
      padding: 12px var(--pad) calc(12px + env(safe-area-inset-bottom));
      background: var(--forest-strong);
      color: var(--paper);
      border-top: 1px solid var(--line-dark);
      box-shadow: 0 -18px 46px var(--shadow);
      transform: translateY(120%);
      transition: transform 260ms ease;
    }

    .sticky-cta.visible {
      transform: translateY(0);
    }

    .sticky-cta span {
      max-width: 560px;
      font-size: 14px;
      line-height: 1.4;
      color: color-mix(in oklch, var(--paper) 74%, var(--forest));
    }

    .reveal {
      opacity: 1;
      transform: none;
      transition: opacity 320ms ease, transform 320ms ease;
    }

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

    @media (max-width: 1120px) {
      .hero h1 {
        font-size: 68px;
      }

      .hero-grid {
        grid-template-columns: minmax(0, 1fr) 390px;
        gap: 34px;
      }

      .section-title,
      .team-header h2 {
        font-size: 46px;
      }

      .section-title.serif {
        font-size: 50px;
      }

      .outcome-track .outcome-card {
        flex: 0 0 calc((100% - 14px) / 2);
      }

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

      .student-story-card:nth-child(even) {
        margin-top: 0;
      }

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

    @media (max-width: 920px) {
      body.menu-open .nav-links {
        display: grid;
      }

      .nav {
        height: 68px;
      }

      .brand-mark {
        width: 36px;
        height: 36px;
      }

      .brand-mark svg {
        width: 34px;
        height: 34px;
      }

      .brand-word strong,
      .brand-word span {
        font-size: 16px;
        letter-spacing: -0.02em;
      }

      .nav-links {
        display: none;
        position: fixed;
        inset: 68px 16px auto 16px;
        padding: 16px;
        border-radius: 8px;
        border: 1px solid var(--line-dark);
        background: var(--forest-strong);
        box-shadow: 0 18px 54px var(--shadow);
      }

      .nav-links a {
        justify-content: space-between;
        min-height: 46px;
        border-bottom: 1px solid var(--line-dark);
        border-radius: 0;
      }

      .nav-links li:last-child a {
        border-bottom: none;
      }

      .nav-actions {
        margin-left: auto;
      }

      .phone-link {
        display: none;
      }

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

      .hero {
        min-height: auto;
      }

      .hero-grid {
        grid-template-columns: 1fr;
        padding-top: 26px;
      }

      .hero-copy {
        grid-column: 1;
        grid-row: 2;
        padding-bottom: 10px;
      }

      .hero-media {
        grid-column: 1;
        grid-row: 1;
        min-height: 520px;
      }

      .campus-frame {
        inset: 20px 0 84px 0;
      }

      .student-figure {
        right: -20px;
        bottom: 62px;
        width: min(68%, 430px);
      }

      .hero-caption {
        width: min(330px, 76%);
      }

      .section-head,
      .stories-head,
      .intro-grid,
      .belief-grid,
      .program-shell,
      .program-stage,
      .method-hero,
      .method-chapter,
      .team-grid,
      .team-header,
      .team-people-grid,
      .cta-grid,
      .quote-layout {
        grid-template-columns: 1fr;
      }

      .program-tabs {
        grid-template-columns: repeat(4, minmax(210px, 1fr));
        overflow-x: auto;
        padding-bottom: 6px;
      }

      .program-stage {
        min-height: auto;
      }

      .stage-media {
        padding: 0 24px 24px;
      }

      .stage-media .photo-slot {
        min-height: 340px;
      }

      .method-chapter,
      .method-chapter:nth-child(2n) {
        grid-template-columns: 1fr;
        min-height: auto;
        padding-block: 0;
      }

      .method-chapter:nth-child(2n) .method-feature,
      .method-chapter:nth-child(2n) .method-visual {
        grid-column: auto;
        grid-row: auto;
      }

      .method-sequence {
        gap: 70px;
      }

      .method-visual {
        min-height: 430px;
      }

      .fit-grid {
        grid-template-columns: 1fr;
      }

      .belief-model-head,
      .belief-scroll-grid {
        grid-template-columns: 1fr;
      }

      .belief-scroll-grid {
        gap: clamp(16px, 4vw, 26px);
        align-items: start;
      }

      .belief-scroll-shell {
        min-height: auto;
      }

      .belief-scroll-sticky {
        position: relative;
        top: auto;
        min-height: auto;
        overflow: visible;
        align-content: start;
      }

      .belief-scroll-sticky::after {
        display: none;
      }

      .belief-visual {
        order: -1;
        min-height: auto;
        position: sticky;
        top: 84px;
        z-index: 2;
      }

      .belief-visual-frame {
        min-height: clamp(260px, 42vw, 420px);
        box-shadow: 0 18px 42px color-mix(in oklch, var(--forest-strong) 30%, transparent);
      }

      .team-founder {
        min-height: auto;
      }

      .team-support {
        grid-template-columns: minmax(148px, 0.34fr) minmax(0, 1fr);
      }

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

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

    @media (max-width: 640px) {
      body {
        padding-bottom: calc(104px + env(safe-area-inset-bottom));
      }

      .nav-actions .btn {
        display: none;
      }

      .brand-word strong {
        font-size: 14px;
      }

      .brand-word span {
        font-size: 14px;
      }

      .brand-mark {
        width: 34px;
        height: 34px;
      }

      .brand-mark svg {
        width: 32px;
        height: 32px;
      }

      .hero h1 {
        font-size: 48px;
      }

      .hero-lede {
        font-size: 17px;
      }

      .hero-alumni {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding: 14px 16px 16px;
      }

      .hero-alumni-label {
        padding-right: 0;
        border-right: none;
        padding-bottom: 10px;
        border-bottom: 1px solid var(--line-dark);
        width: 100%;
      }

      .hero-logo-row {
        width: 100%;
        gap: 10px;
      }

      .hero-logo-slot img {
        height: 28px;
      }

      .hero-logo-slot.logo-wide img {
        height: 26px;
      }

      .hero-logo-slot.logo-seal img {
        height: 34px;
      }

      .hero-media {
        min-height: 430px;
      }

      .student-figure {
        right: -28px;
        bottom: 62px;
        width: min(86%, 390px);
      }

      .hero-caption {
        bottom: 24px;
      }

      .trust-items {
        animation-duration: 24s;
      }

      .section {
        padding: 74px 0;
      }

      .section.compact {
        padding: 58px 0;
      }

      .section-title,
      .stage-copy h3,
      .team-header h2 {
        font-size: 38px;
      }

      .section-title.serif {
        font-size: 42px;
      }

      .intro-panel,
      .stage-copy,
      .fit-block {
        padding: 26px;
      }

      .intro-panel blockquote,
      .quote-text {
        font-size: 31px;
      }

      .belief-section {
        padding: 64px 0;
      }

      .belief-model-head {
        gap: 18px;
        padding-bottom: 26px;
      }

      .belief-model-head h2 {
        font-size: clamp(34px, 9.2vw, 38px);
        line-height: 0.98;
        max-width: min(100%, 8.4em);
      }

      .belief-model-head > p {
        max-width: min(100%, 31ch);
        font-size: 15px;
        line-height: 1.55;
      }

      .belief-scroll-sticky {
        padding: 26px;
      }

      .belief-scroll-grid {
        gap: 14px;
      }

      .belief-step {
        min-height: auto;
        grid-template-columns: 1fr;
        gap: 22px;
      }

      .belief-model-number {
        font-size: 78px;
      }

      .belief-visual {
        top: 74px;
      }

      .belief-visual-frame {
        min-height: clamp(190px, 58vw, 300px);
      }

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

      .stage-list li:nth-child(2n) {
        padding-left: 0;
        border-left: none;
      }

      .stage-list li:nth-last-child(-n + 2) {
        border-bottom: 1px solid var(--line-dark);
      }

      .stage-list li:last-child {
        border-bottom: none;
      }

      .program-tabs {
        grid-template-columns: 1fr;
        overflow-x: visible;
      }

      .method-grid {
        gap: 48px;
      }

      .method-hero {
        gap: 22px;
      }

      .method-hero h2 {
        line-height: 0.98;
      }

      .method-hero h2 span {
        font-size: 37px;
      }

      .method-hero h2 strong {
        font-size: 43px;
      }

      .method-hero p:not(.eyebrow),
      .method-feature p {
        font-size: 17px;
        line-height: 1.55;
      }

      .method-sequence {
        gap: 62px;
      }

      .method-chapter {
        gap: 26px;
      }

      .method-feature {
        gap: 15px;
      }

      .method-feature h3 {
        font-size: 35px;
        line-height: 1.02;
      }

      .method-visual {
        min-height: 360px;
      }

      .method-visual::after {
        inset: 14px;
      }

      .method-visual-photo img {
        width: min(78%, 310px);
      }

      .method-admit-card {
        left: 14px;
        top: 14px;
        width: 150px;
        padding: 15px;
      }

      .method-admit-card strong {
        font-size: 25px;
      }

      .method-proof-card {
        left: 20px;
        bottom: 24px;
        width: min(238px, 70%);
        padding: 15px;
      }

      .method-proof-card strong {
        font-size: 17px;
      }

      .method-blueprint {
        inset: 18px;
        gap: 10px;
      }

      .method-visual:not(.method-visual-photo) {
        min-height: auto;
        padding: 18px;
      }

      .method-visual:not(.method-visual-photo) .method-blueprint {
        position: relative;
        inset: auto;
      }

      .blueprint-line {
        grid-template-columns: 44px 1fr;
        min-height: auto;
        padding: 13px 14px;
      }

      .blueprint-line:nth-child(2),
      .blueprint-line:nth-child(3) {
        margin-left: 0;
      }

      .blueprint-line span {
        font-size: 27px;
      }

      .blueprint-line strong {
        font-size: 16px;
      }

      .blueprint-line em {
        grid-column: 2;
        justify-self: start;
        font-size: 10px;
        padding: 6px 8px;
      }

      .method-note-card {
        right: 18px;
        bottom: 18px;
        width: min(220px, 68%);
        padding: 14px;
      }

      .method-visual:not(.method-visual-photo) .method-note-card {
        position: relative;
        right: auto;
        bottom: auto;
        width: 100%;
        margin-top: 12px;
      }

      .method-note-card strong {
        font-size: 17px;
      }

      .outcome-track .outcome-card {
        flex: 0 0 100%;
      }

      .student-story-grid,
      .footer-grid {
        grid-template-columns: 1fr;
      }

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

      .team-support {
        grid-template-columns: 1fr;
      }

      .team-support .team-photo {
        min-height: 220px;
      }

      .team-person-copy {
        padding: 22px;
      }

      .quote-mark {
        font-size: 92px;
      }

      .cta-grid h2 {
        font-size: 42px;
      }

      .footer-bottom {
        flex-direction: column;
      }

      .sticky-cta {
        left: 0;
        right: 0;
        bottom: 0;
        flex-direction: column;
        align-items: stretch;
        justify-content: center;
        gap: 10px;
        min-height: 76px;
        padding: 12px var(--pad) calc(12px + env(safe-area-inset-bottom));
      }

      .sticky-cta span {
        font-size: 13px;
        max-width: none;
      }

      .sticky-cta .btn {
        width: 100%;
      }

      .stories-title {
        font-size: clamp(46px, 15vw, 66px);
      }

      .story-card-top {
        min-height: 104px;
      }
    }

    /* Clay CTA button */
    .btn-clay {
      background: var(--clay);
      color: var(--paper);
      border-color: var(--clay);
    }

    .btn-clay:hover {
      background: color-mix(in oklch, var(--clay) 86%, var(--ink));
    }

    /* ─── Services v2: sticky text + scrolling cards ─── */

    /* Override old padding:0 */
    .services-section {
      padding: clamp(72px, 9vw, 116px) 0 clamp(80px, 10vw, 128px);
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--paper) 4%, transparent) 1px, transparent 1px),
        var(--forest-strong);
      background-size: 80px 80px;
      color: var(--paper);
    }

    .services-section .eyebrow {
      color: var(--lime);
    }

    .services-section .services-heading em {
      color: var(--lime);
    }

    .services-section .services-heading strong {
      color: var(--paper);
    }

    .services-section .service-text-block h3 {
      color: var(--paper);
    }

    .services-section .service-text-block p {
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
    }

    .services-section .method-kicker {
      color: var(--lime);
    }

    .services-section .services-text-nav {
      border-top-color: var(--line-dark);
    }

    .services-section .services-counter {
      color: color-mix(in oklch, var(--paper) 48%, var(--forest));
    }

    .services-section .services-counter strong {
      color: var(--paper);
    }

    .services-section .services-dot {
      background: var(--line-dark);
    }

    .services-section .services-dot.is-active {
      background: var(--lime);
    }

    .services-section .service-row-text h3 {
      color: var(--paper);
    }

    .services-section .service-row-text p {
      color: color-mix(in oklch, var(--paper) 72%, var(--forest));
    }

    .services-section .service-row {
      border-bottom-color: var(--line-dark);
    }

    .services-header {
      margin-bottom: clamp(48px, 6vw, 80px);
    }

    .services-heading {
      margin: 10px 0 0;
      line-height: 1;
      letter-spacing: -0.01em;
    }

    .services-heading em {
      display: block;
      font-family: var(--serif);
      font-style: italic;
      font-weight: 500;
      font-size: clamp(36px, 4.4vw, 64px);
      color: var(--moss);
      line-height: 1.06;
    }

    .services-heading strong {
      display: block;
      font-size: clamp(40px, 5.2vw, 76px);
      font-weight: 900;
      color: var(--forest-strong);
      line-height: 1;
      margin-top: 2px;
    }

    /* Two-column grid */
    .services-layout {
      display: grid;
      grid-template-columns: minmax(0, 0.50fr) minmax(340px, 0.68fr);
      gap: clamp(40px, 8vw, 112px);
      align-items: start;
    }

    /* Left: sticky text column */
    .services-text-sticky {
      position: sticky;
      top: calc(74px + clamp(18px, 4svh, 50px));
      display: grid;
      gap: 22px;
    }

    /* Fixed-height well — all text blocks are absolute inside */
    .services-text-well {
      height: clamp(340px, 50svh, 520px);
      position: relative;
    }

    .service-text-block {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 18px;
      opacity: 0;
      transform: translateY(26px);
      pointer-events: none;
      transition: opacity 460ms cubic-bezier(0.25, 0, 0.15, 1),
                  transform 460ms cubic-bezier(0.25, 0, 0.15, 1);
    }

    .service-text-block.is-prev {
      opacity: 0;
      transform: translateY(-26px);
    }

    .service-text-block.is-active {
      opacity: 1;
      transform: translateY(0);
      pointer-events: auto;
    }

    .service-text-block h3 {
      margin: 0;
      font-size: clamp(24px, 3.1vw, 46px);
      font-weight: 900;
      line-height: 1.02;
      letter-spacing: -0.01em;
      color: var(--forest-strong);
    }

    .service-text-block p {
      margin: 0;
      max-width: 500px;
      font-size: clamp(16px, 1.3vw, 18px);
      line-height: 1.62;
      color: var(--ink-soft);
    }

    /* Progress bar below text */
    .services-text-nav {
      display: flex;
      align-items: center;
      gap: 18px;
      padding-top: 16px;
      border-top: 1px solid var(--line);
    }

    .services-counter {
      position: static; /* override old absolute-positioned counter from scroll-budget era */
      left: auto;
      bottom: auto;
      z-index: auto;
      font-size: 11px;
      font-weight: 900;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--muted);
      white-space: nowrap;
    }

    .services-counter strong {
      color: var(--forest-strong);
    }

    .services-progress-dots {
      display: flex;
      gap: 9px;
      align-items: center;
    }

    .services-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--line);
      cursor: pointer;
      transition: background 280ms ease, transform 280ms ease;
    }

    .services-dot.is-active {
      background: var(--forest-strong);
      transform: scale(1.6);
    }

    /* Right: scrolling service rows */
    .services-cards-col {
      display: grid;
      gap: clamp(80px, 14svh, 180px);
    }

    .service-row-text {
      display: none; /* desktop uses sticky panel; shown on mobile */
    }

    .service-card {
      position: relative;
      min-height: clamp(460px, 68svh, 640px);
      border-radius: 8px;
      overflow: hidden;
      isolation: isolate;
      background:
        linear-gradient(135deg, color-mix(in oklch, var(--paper-low) 92%, var(--lime-low)), color-mix(in oklch, var(--lime-low) 34%, var(--paper))),
        linear-gradient(90deg, color-mix(in oklch, var(--forest-strong) 7%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--forest-strong) 7%, transparent) 1px, transparent 1px);
      background-size: auto, 76px 76px, 76px 76px;
      border: 1px solid var(--line);
      box-shadow: 0 28px 72px color-mix(in oklch, var(--forest-strong) 10%, transparent);
    }

    .service-card::before {
      content: "";
      position: absolute;
      inset: auto 0 0;
      height: 42%;
      background: linear-gradient(180deg, transparent, color-mix(in oklch, var(--forest-strong) 18%, transparent));
      pointer-events: none;
      z-index: 1;
    }

    .service-card::after {
      content: "";
      position: absolute;
      inset: 22px;
      border: 1px solid color-mix(in oklch, var(--forest-strong) 10%, transparent);
      pointer-events: none;
      z-index: 1;
    }

    /* Photo variant */
    .service-card-photo img {
      position: absolute;
      right: -8px;
      bottom: 0;
      width: min(78%, 430px);
      max-height: 95%;
      object-fit: contain;
      object-position: bottom right;
      filter: drop-shadow(0 24px 42px color-mix(in oklch, var(--forest-strong) 24%, transparent));
      z-index: 2;
      will-change: transform;
    }

    /* SVG illustration variant — fills the card */
    .service-card-svg img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      z-index: 2;
    }

    /* Blueprint layout inside non-photo card */
    .service-card .method-blueprint {
      inset: 38px 38px 150px;
    }

    @media (max-width: 860px) {
      /* Crimson-style: each service row stacks text above card */
      .services-layout {
        display: block;
      }

      .services-text-sticky {
        display: none;
      }

      .services-cards-col {
        display: flex;
        flex-direction: column;
        gap: 0;
      }

      .service-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: clamp(16px, 4vw, 28px);
        align-items: center;
        padding: clamp(32px, 5vw, 52px) var(--pad);
        border-bottom: 1px solid var(--line);
      }

      .service-row:last-child {
        border-bottom: none;
      }

      .service-row-text {
        display: flex;
        flex-direction: column;
        gap: 10px;
      }

      .service-row-text .method-kicker {
        font-size: 10px;
        margin: 0;
      }

      .service-row-text h3 {
        margin: 0;
        font-size: clamp(17px, 4.5vw, 24px);
        font-weight: 800;
        line-height: 1.1;
        letter-spacing: -0.01em;
        color: var(--forest-strong);
      }

      .service-row-text p {
        margin: 0;
        font-size: clamp(13px, 3.2vw, 15px);
        line-height: 1.58;
        color: var(--ink-soft);
      }

      .service-row-text .method-pill-row {
        display: none;
      }

      .service-card {
        min-height: clamp(220px, 42svh, 360px);
      }
    }

    @media (max-width: 520px) {
      /* Stack fully on small phones */
      .service-row {
        grid-template-columns: 1fr;
        gap: clamp(14px, 3vw, 20px);
      }

      .service-row-text {
        order: 2;
      }

      .service-card {
        order: 1;
        min-height: clamp(240px, 48svh, 340px);
      }
    }

    @media (max-width: 480px) {
      .services-heading em { font-size: 28px; }
      .services-heading strong { font-size: 32px; }
    }

    @media (max-width: 1180px) {
      .numbers-proof-grid {
        grid-template-columns: 1fr;
      }

      .institution-proof-card {
        min-height: 480px;
      }

      .proof-stat-stack,
      .acceptance-card {
        grid-column: auto;
        grid-row: auto;
      }
    }

    @media (max-width: 760px) {
      .numbers-proof {
        padding: 72px 0;
      }

      .numbers-proof-head {
        grid-template-columns: 1fr;
        gap: 18px;
      }

      .numbers-proof-grid {
        grid-template-columns: 1fr;
      }

      .institution-proof-card {
        min-height: 430px;
      }

      .proof-stat-stack {
        grid-template-columns: 1fr;
      }

      .acceptance-row {
        grid-template-columns: 1fr;
        gap: 8px;
      }

      .acceptance-school {
        font-size: 15px;
      }

      .acceptance-main-bar {
        grid-template-columns: minmax(0, 1fr) 48px;
      }
    }

    @media (max-width: 480px) {
      .numbers-proof-title {
        font-size: 42px;
      }

      .numbers-proof-kicker {
        font-size: 33px;
      }

      .institution-proof-card {
        min-height: 390px;
      }

      .proof-stat-card {
        grid-template-columns: 1fr;
        min-height: 190px;
        gap: 16px;
      }

      .acceptance-card {
        padding: 24px 18px;
      }
    }

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

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