/* ============================================================
   Foundeure — styled after the Planar template's design system
   Switzer type · Inconsolata labels · warm paper ground · ink
   pill buttons · Lenis smooth scroll · GSAP scroll reveals
   ============================================================ */

:root {
  --paper:   #F6F6F3;   /* page ground */
  --panel:   #FFFFFF;   /* cards */
  --alt:     #F1F0EA;   /* alternating section + soft panels */
  --stage:   #E7E6DF;   /* media stage frame */
  --ink:     #191919;   /* buttons / strong */
  --head:    #292929;   /* headings */
  --text:    #353535;   /* body */
  --muted:   rgba(41,41,41,.60);  /* lighter grey so subtitles read clearly distinct from ink headings */
  --faint:   rgba(41,41,41,.66);  /* ~4.6:1 on paper — WCAG AA */
  --line:    rgba(25,25,25,.10);
  --line-2:  rgba(25,25,25,.06);

  --radius:  18px;
  --radius-lg: 24px;
  --radius-sm: 12px;
  --container: 1180px;
  --pad: clamp(72px, 9vw, 116px);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  /* motion durations */
  --t-fast: .15s;   /* micro: toggles, presses */
  --t-base: .26s;   /* default: hovers, UI transitions */
  --t-slow: .4s;    /* larger surfaces, image zoom */

  /* elevation — layered ambient + key, warm-tinted (one light dir: top) */
  --e-card:  0 1px 2px rgba(28,24,20,.05), 0 14px 26px -16px rgba(28,24,20,.18);
  --e-hover: 0 2px 6px rgba(28,24,20,.07), 0 30px 54px -30px rgba(28,24,20,.30);
  --e-float: 0 3px 10px rgba(28,24,20,.10), 0 42px 76px -34px rgba(28,24,20,.40);
}

* { box-sizing: border-box; }

/* Lenis smooth scroll */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }

html { scroll-padding-top: 90px; }

body {
  margin: 0;
  font-family: "Switzer", "Inter", Arial, sans-serif;
  font-size: 17px;
  line-height: 1.6;
  color: var(--text);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* Keyboard focus — one branded ring, legible on light + dark surfaces */
:focus-visible { outline: 2px solid var(--ink); outline-offset: 3px; }
.cta :focus-visible, .aq :focus-visible, .nav__promo:focus-visible,
.freecard :focus-visible, .duo__panel :focus-visible, .phase__visual :focus-visible,
.htile :focus-visible, .mcard :focus-visible { outline-color: #fff; }

/* Honor reduced-motion globally (JS already disables GSAP/Lenis; this collapses CSS too) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}

.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 24px;
}

/* ---------- Typography ---------- */
/* Type ramp — optical line-height + tracking, restrained sizes (Apple-style) */
h1, h2, h3, h4 {
  color: var(--head);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.022em;
  margin: 0;
  text-wrap: balance;
}
p, li, .hero__sub, .section__lede, .case__role, .tier__who, .subhero__lede { text-wrap: pretty; }
h1 { font-size: clamp(2.5rem, 5.2vw, 3.75rem); line-height: 1.05; letter-spacing: -0.03em; }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.6rem);  line-height: 1.1;  letter-spacing: -0.026em; }
h3 { font-size: clamp(1.35rem, 2vw, 1.6rem);   line-height: 1.2;  letter-spacing: -0.018em; }
h4 { font-size: 1.2rem; line-height: 1.35; letter-spacing: -0.012em; font-weight: 500; }

.muted { color: var(--muted); }

.eyebrow {
  font-family: "Inconsolata", ui-monospace, monospace;
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--faint);
  font-weight: 500;
  margin: 0 0 18px;
}
.eyebrow--num { color: var(--ink); letter-spacing: .1em; }

/* ---------- Buttons ---------- */
.btn {
  --bg: var(--ink); --fg: #fff;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5em;
  height: 48px;
  padding: 0 26px;
  border-radius: 999px;
  font-size: .95rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  border: 1px solid transparent;
  background: var(--bg);
  color: var(--fg);
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition: transform .28s var(--ease-out), color .25s var(--ease), border-color .25s var(--ease);
  white-space: nowrap;
}
.btn > span { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: .5em; transition: transform .28s var(--ease-out); }
/* circle that grows from the cursor on hover (JS sets --mx/--my) */
.btn::after {
  content: ""; position: absolute; z-index: 0; left: var(--mx, 50%); top: var(--my, 50%);
  width: 260%; aspect-ratio: 1; border-radius: 50%; background: #000;
  transform: translate(-50%, -50%) scale(0); transform-origin: center;
  transition: transform .55s var(--ease-out); will-change: transform;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0) scale(.985); transition-duration: .12s; }
.btn:hover::after { transform: translate(-50%, -50%) scale(1); }

.btn--primary { background: var(--ink); color: #fff; }
.btn--primary::after { background: rgba(255,255,255,.16); } /* soft light ripple over dark */
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn--ghost::after { background: rgba(0,0,0,.085); } /* light-grey fill grows from cursor */
.btn--ghost:hover { color: var(--ink); border-color: rgba(25,25,25,.22); }
.btn--invert { background: #fff; color: var(--ink); }
.btn--invert::after { background: rgba(0,0,0,.085); }
.btn--invert:hover { color: var(--ink); }
.btn--sm { height: 40px; padding: 0 19px; font-size: .9rem; }
.btn--block { width: 100%; margin-top: auto; }
/* nav waitlist button — smaller, pill, Apple-like */
.nav__right .btn--sm { height: 37px; padding: 0 16px; font-size: .86rem; font-weight: 500; border-radius: 999px; }

/* ---------- Nav (floating island + mega-menu) ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding-top: 12px;
  transition: transform .5s var(--ease-out);
}
.nav.is-hidden { transform: translateY(calc(-100% - 12px)); }
body { padding-top: 74px; }

/* the island bar */
.nav__bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  height: 52px; padding: 6px 6px 6px 18px;
  border-radius: 14px;
  background: transparent;
  border: 1px solid transparent;
  transition: background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease), backdrop-filter .4s var(--ease);
}
.nav.is-scrolled .nav__bar,
.nav.is-menu-open .nav__bar {
  background: rgba(238,237,231,.78);
  backdrop-filter: saturate(180%) blur(16px);
  border-color: var(--line);
  box-shadow: 0 14px 34px -22px rgba(25,25,25,.30);
}

.brand { display: inline-flex; align-items: center; gap: 10px; }
.brand__mark { width: 26px; height: 26px; object-fit: contain; transition: transform .5s var(--ease-out); }
.brand:hover .brand__mark { transform: rotate(-8deg) scale(1.06); }
.brand__word { font-size: 1.18rem; font-weight: 500; letter-spacing: -0.02em; color: var(--head); }
.nav__bar .brand__word { font-size: 1.05rem; }
.nav__bar .brand__mark { width: 23px; height: 23px; }

.nav__right { display: flex; align-items: center; gap: 9px; }

.nav__toggle { width: 37px; height: 37px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.5); cursor: pointer; position: relative; transition: background .25s var(--ease), border-color .25s var(--ease); }
.nav__toggle:hover { background: #fff; border-color: rgba(25,25,25,.18); }
.nav__toggle span { position: absolute; left: 12px; right: 12px; height: 1.6px; background: var(--ink); border-radius: 2px; transition: transform .4s var(--ease-out), opacity .2s; }
.nav__toggle span:nth-child(1) { top: 15px; }
.nav__toggle span:nth-child(2) { top: 21px; }
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(3px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { transform: translateY(-3px) rotate(-45deg); }

/* mega-menu panel */
.nav > .container { position: relative; }
.nav__menu {
  position: absolute; z-index: 1; left: 0; right: 0; margin-inline: auto;
  width: calc(100% - 16px); max-width: 880px; top: calc(100% + 8px);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: 0 30px 70px -34px rgba(25,25,25,.40);
  padding: 18px;
  opacity: 0; visibility: hidden; transform: translateY(-12px) scale(.985);
  transform-origin: top center;
  transition: opacity .4s var(--ease-out), transform .45s var(--ease-out), visibility .45s;
}
.nav.is-menu-open .nav__menu { opacity: 1; visibility: visible; transform: none; }
.nav__menu-grid { display: grid; grid-template-columns: 1fr 1fr 1.05fr; gap: 14px; }

.nav__links { display: flex; flex-direction: column; }
.nav__col-label { font-family: "Inconsolata", monospace; font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); padding: 4px 14px 12px; }
.nav__links a {
  display: flex; flex-direction: column; gap: 2px;
  padding: 12px 14px; border-radius: 12px;
  transition: background .25s var(--ease), transform .25s var(--ease-out);
}
.nav__links a span { font-size: 1.05rem; color: var(--head); letter-spacing: -0.01em; }
.nav__links a em { font-style: normal; font-size: .85rem; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.nav__links a em .nav__tag { display: inline-flex; align-items: center; background: #eceae3; color: #75746a; font-size: .7rem; font-weight: 500; letter-spacing: 0; padding: 2px 7px; border-radius: 6px; line-height: 1.45; }
.nav__links a:hover { background: var(--alt); transform: translateX(3px); }

/* promo card — designed graphic (shows when no photo; grain enriches the photo too) */
.nav__promo {
  position: relative; display: flex; flex-direction: column; justify-content: flex-end;
  border-radius: 16px; overflow: hidden; min-height: 240px; padding: 22px;
  color: #fff; isolation: isolate;
  background:
    radial-gradient(66% 58% at 80% 12%, rgba(255,238,214,.55), transparent 62%),
    repeating-radial-gradient(circle at 50% 124%, rgba(255,255,255,.11) 0 1px, transparent 1px 26px),
    linear-gradient(155deg, #ddad87 0%, #a9663f 56%, #6a3d27 100%);
}
.nav__promo-media { position: absolute; inset: 0; z-index: 0; }
.nav__promo-media img { width: 100%; height: 100%; object-fit: cover; }
.nav__promo-media.is-empty { display: none; } /* reveal the designed background */
.nav__promo::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .5;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 150px 150px;
}
.nav__promo::after { content: ""; position: absolute; inset: 0; z-index: 2; background: linear-gradient(to top, rgba(20,12,8,.86), rgba(20,12,8,.12) 58%, rgba(20,12,8,.02)); }
.nav__promo-body { position: relative; z-index: 3; display: flex; flex-direction: column; gap: 3px; }
.nav__promo-eyebrow { font-family: "Inconsolata", monospace; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.7); }
.nav__promo-title { font-size: 1.3rem; letter-spacing: -0.02em; }
.nav__promo-cta { margin-top: 16px; align-self: flex-start; height: auto; min-height: 0; padding: 10px 18px; font-size: .84rem; font-weight: 600; letter-spacing: -0.01em; border-radius: 999px; box-shadow: 0 12px 26px -14px rgba(0,0,0,.6); }
.nav__promo:hover .nav__promo-cta { box-shadow: 0 18px 32px -14px rgba(0,0,0,.62); }
/* light button variant — fill grows from cursor in light grey (same motion as every .btn) */
.btn--light { --bg: #fff; --fg: #1a1a1a; background: #fff; color: #1a1a1a; }
.btn--light::after { background: rgba(0,0,0,.085); }
.btn--light:hover { color: #1a1a1a; }
.nav__promo:hover .nav__promo-media img { transform: scale(1.04); }
.nav__promo-media img { transition: transform .6s var(--ease-out); }

/* invisible click-catcher behind the open menu (no page dimming) */
.nav__scrim { position: fixed; inset: 0; z-index: 0; background: transparent; }

/* ---------- Hero ---------- */
.hero { padding-top: clamp(56px, 8vw, 92px); padding-bottom: var(--pad); }
.hero__inner { display: flex; flex-direction: column; align-items: center; text-align: center; }
.hero__title { max-width: none; margin-bottom: 0; }
.hero__title-soft { color: color-mix(in srgb, var(--head) 30%, var(--paper)); }
.hero__tagline { display: block; font-size: clamp(1.6rem, 3vw, 2.25rem); line-height: 1.2; letter-spacing: -0.015em; margin-top: 0.45em; }
.hero__sub { max-width: 50ch; font-size: clamp(1.08rem, 1.7vw, 1.25rem); line-height: 1.4; color: var(--muted); margin: clamp(16px, 2vw, 22px) auto 0; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin: clamp(38px, 4.6vw, 52px) 0 0; }
.hero__proof { margin: 18px 0 0; font-size: .95rem; color: var(--muted); text-wrap: balance; }
.hero__proof strong { color: var(--head); font-weight: 600; white-space: nowrap; }
.hero__reassure { margin: 7px 0 clamp(46px, 5.5vw, 64px); font-size: .85rem; color: var(--faint); letter-spacing: -0.01em; }

.hero__panel { width: 100%; max-width: 940px; margin-top: clamp(48px, 7vw, 84px); }

/* product panel mock */
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 1px 0 rgba(25,25,25,.02), 0 30px 60px -32px rgba(25,25,25,.22);
  overflow: hidden;
}
.panel__bar { display: flex; align-items: center; gap: 8px; padding: 14px 18px; border-bottom: 1px solid var(--line-2); }
.dot { width: 9px; height: 9px; border-radius: 999px; background: var(--line); }
.dot--ink { background: var(--ink); flex: none; }
.panel__label { margin-left: 10px; font-family: "Inconsolata", monospace; font-size: .82rem; color: var(--faint); letter-spacing: .04em; }
.panel__body { display: grid; grid-template-columns: 1.1fr 1fr; gap: 28px; padding: 28px; }
.panel__col { display: flex; flex-direction: column; gap: 12px; }
.panel__col--chart { border-left: 1px solid var(--line-2); padding-left: 28px; }

.chip { font-size: .82rem; color: var(--head); font-weight: 500; }
.chip--muted { color: var(--faint); font-weight: 400; }
.bar { height: 10px; border-radius: 999px; background: var(--alt); position: relative; overflow: hidden; }
.bar::after { content:""; position: absolute; inset: 0; width: var(--w,70%); background: var(--ink); border-radius: 999px; transform-origin: left; }
.bar--80 { --w: 80%; } .bar--64 { --w: 64%; } .bar--92 { --w: 92%; } .bar--45 { --w: 45%; }

.spark { width: 100%; height: 96px; }
.spark polyline { fill: none; stroke: var(--ink); stroke-width: 2; vector-effect: non-scaling-stroke; }
.panel__months { display: flex; justify-content: space-between; font-family: "Inconsolata", monospace; font-size: .72rem; color: var(--faint); }

/* ---------- Trust band ---------- */
.trust { border-top: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2); }
.trust__inner { padding: 30px 24px; text-align: center; }
.trust p { margin: 0; color: var(--muted); font-size: 1rem; }
.trust strong { color: var(--head); font-weight: 500; }

/* ============================================================
   "Founder works with" — scrolling wordmark marquee
   ============================================================ */
.marquee { padding: 26px 0 30px; border-bottom: 1px solid var(--line-2); }
.marquee__inner { display: flex; align-items: center; gap: clamp(22px, 3vw, 48px); }
.marquee__label { flex: none; margin: 0; white-space: nowrap; text-align: left; font-size: 1.02rem; font-weight: 500; letter-spacing: -0.01em; color: var(--muted); }
.marquee__viewport { position: relative; flex: 1; min-width: 0; overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 9%, #000 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 9%, #000 92%, transparent 100%); }
.marquee__track { display: flex; width: max-content; animation: marquee-scroll 38s linear infinite; }
.marquee__viewport:hover .marquee__track { animation-play-state: paused; }
.marquee__item { display: inline-flex; align-items: center; gap: 9px; padding: 0 30px; font-size: 1.08rem; font-weight: 500; letter-spacing: -0.015em; color: var(--muted); white-space: nowrap; opacity: .72; transition: color .3s var(--ease), opacity .3s var(--ease); }
.marquee__item:hover { color: var(--head); opacity: 1; }
.marquee__dot { width: 9px; height: 9px; border-radius: 3px; background: currentColor; opacity: .55; flex: none; }
@keyframes marquee-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (max-width: 560px) {
  .marquee__inner { flex-direction: column; align-items: flex-start; gap: 14px; }
  .marquee__viewport { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
  .marquee__track { animation: none; flex-wrap: wrap; width: 100%; }
  .marquee__track > :nth-child(n+8) { display: none; }
  .marquee__item { padding: 6px 18px 6px 0; }
}

/* ============================================================
   Signal chips — replaces dense bullet lists in story rows
   ============================================================ */
.signals { list-style: none; margin: 16px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.signals li { display: flex; align-items: center; gap: 13px; padding: 13px 16px; background: #fff; border: 1px solid var(--line); border-radius: 12px; font-size: 1rem; color: var(--text); transition: transform .3s var(--ease-out), border-color .3s var(--ease), box-shadow .3s var(--ease); }
.signals li:hover { transform: translateX(4px); border-color: rgba(25,25,25,.18); box-shadow: 0 14px 26px -20px rgba(25,25,25,.45); }
.signals li::before { content: ""; flex: none; width: 9px; height: 9px; border-radius: 999px; background: var(--accent, var(--ink)); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent, #777) 16%, transparent); }

/* ============================================================
   Interactive hero tiles — cursor cue + click feedback
   ============================================================ */
.htile--ui .oscard, .htile--vivid .autocard { cursor: default; }
.oscard__row { cursor: pointer; user-select: none; }
.oscard__row .meter::after { transition: width .55s var(--ease-out); }
.oscard__hint, .autocard__hint { display: block; margin-top: 9px; font-family: "Inconsolata", monospace; font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; color: var(--faint); transition: color .3s var(--ease); }
.autocard__hint.is-live { color: #3f8a5b; }
.oscard__score { margin-left: auto; font-variant-numeric: tabular-nums; }
.htile--photo { cursor: pointer; }
.htile__chip { transition: transform .4s var(--ease-out), opacity .3s var(--ease); }
.htile--photo:hover .htile__chip { transform: translateY(-2px); }

/* ============================================================
   Colourful free modules (programs page)
   ============================================================ */
.freegrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 880px; margin-inline: auto; }
.freecard { position: relative; overflow: hidden; isolation: isolate; border-radius: var(--radius-lg); padding: clamp(26px, 3vw, 38px); color: #fff; display: flex; flex-direction: column; min-height: 360px; }
.freecard::after { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .4; mix-blend-mode: soft-light; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='fg'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23fg)'/%3E%3C/svg%3E"); background-size: 150px; }
.freecard > * { position: relative; z-index: 1; }
.freecard--warm { background: radial-gradient(72% 60% at 80% 10%, rgba(255,236,210,.4), transparent 56%), linear-gradient(152deg, #cf9a76, #8a4a30 64%, #5e3520); }
.freecard--sage { background: radial-gradient(72% 60% at 80% 10%, rgba(226,240,210,.4), transparent 56%), linear-gradient(152deg, #8aa06a, #566f3d 62%, #324626); }
.freecard__tag { align-self: flex-start; display: inline-flex; align-items: center; gap: 7px; background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.28); color: #fff; font-family: "Inconsolata", monospace; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; padding: 5px 12px; border-radius: 999px; backdrop-filter: blur(4px); }
.freecard h3 { color: #fff; font-size: clamp(1.5rem, 2.4vw, 2rem); margin: 18px 0 8px; }
.freecard__sub { color: rgba(255,255,255,.82); margin: 0 0 20px; font-size: 1.02rem; }
.freecard__list { list-style: none; margin: 0 0 26px; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.freecard__list li { position: relative; padding-left: 28px; color: rgba(255,255,255,.92); font-size: 1rem; }
.freecard__list li::before { content: ""; position: absolute; left: 0; top: 3px; width: 17px; height: 17px; border-radius: 999px; background: rgba(255,255,255,.18); }
.freecard__list li::after { content: ""; position: absolute; left: 5.5px; top: 8px; width: 6px; height: 3px; border-left: 1.6px solid #fff; border-bottom: 1.6px solid #fff; transform: rotate(-45deg); }
.freecard .btn { margin-top: auto; }
.freecard__btn { background: #fff; color: #1a1a1a; }
.freecard__btn::after { background: rgba(0,0,0,.085); }
.freecard__btn:hover { color: #1a1a1a; }
@media (max-width: 760px) { .freegrid { grid-template-columns: 1fr; } }

/* ============================================================
   Tier enrichment — meta tags + outcome footer
   ============================================================ */
.tier__meta { display: flex; flex-wrap: wrap; gap: 7px; margin: 0 0 16px; }
.tier__metatag { font-family: "Inconsolata", monospace; font-size: .68rem; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); background: var(--alt); border-radius: 999px; padding: 4px 10px; }
.tier--featured .tier__metatag { color: rgba(255,255,255,.82); background: rgba(255,255,255,.12); }
.tier__outcome { margin: 16px 0 0; padding-top: 15px; border-top: 1px solid var(--line); font-size: .9rem; color: var(--text); }
.tier__outcome strong { color: var(--head); font-weight: 600; }
.tier--featured .tier__outcome { border-top-color: rgba(255,255,255,.16); color: rgba(255,255,255,.86); }
.tier--featured .tier__outcome strong { color: #fff; }

/* ============================================================
   Tool callout chip (method page)
   ============================================================ */
.toolchip { display: inline-flex; align-items: center; gap: 10px; margin-top: 4px; padding: 9px 16px 9px 11px; background: var(--panel); border: 1px solid var(--line); border-radius: 999px; font-size: .9rem; color: var(--head); }
.toolchip__dot { width: 26px; height: 26px; border-radius: 8px; flex: none; display: grid; place-content: center; color: #fff; }
.toolchip__dot svg { width: 15px; height: 15px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.toolchip em { font-style: normal; color: var(--muted); }
.section--alt .toolchip { background: #fff; }

/* ============================================================
   Method page — colourful phase rows
   ============================================================ */
.phase { padding: clamp(40px, 6vw, 76px) 0; border-top: 1px solid var(--line); }
.phase:first-of-type { border-top: 0; }
.phase__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 72px); align-items: center; }
.phase--reverse .phase__visual { order: -1; }
.phase__num { font-family: "Inconsolata", monospace; font-size: .82rem; letter-spacing: .12em; color: var(--accent); margin: 0 0 14px; }
.phase__eyebrow { display: inline-flex; align-items: center; gap: 11px; font-family: "Inconsolata", monospace; font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); margin: 0 0 16px; }
.phase__eyebrow::before { content: ""; width: 24px; height: 2px; border-radius: 2px; background: var(--accent); }
.phase h2 { margin: 0 0 16px; }
.phase__lede { margin: 0 0 22px; color: var(--muted); font-size: 1.08rem; }
.phase__visual { position: relative; overflow: hidden; isolation: isolate; border-radius: var(--radius-lg); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; padding: clamp(22px, 3.4vw, 46px); color: #fff; }
.phase__visual::after { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .38; mix-blend-mode: soft-light; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='pn'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23pn)'/%3E%3C/svg%3E"); background-size: 160px; }
.phase__motif { position: relative; z-index: 1; width: clamp(120px, 22vw, 190px); height: clamp(120px, 22vw, 190px); }
.phase__motif svg { width: 100%; height: 100%; }
.phase__motif svg * { fill: none; stroke: rgba(255,255,255,.7); stroke-width: 2.6; stroke-linecap: round; stroke-linejoin: round; }
.phase__motif .mk { fill: rgba(255,255,255,.8); stroke: none; }
.phase--1 { --accent: #9a5836; } .phase--1 .phase__visual { background: radial-gradient(70% 60% at 76% 14%, rgba(255,236,210,.42), transparent 58%), linear-gradient(150deg, #cf9a76, #8a4a30 64%, #5e3520); }
.phase--2 { --accent: #466071; } .phase--2 .phase__visual { background: radial-gradient(70% 60% at 76% 14%, rgba(214,236,244,.42), transparent 58%), linear-gradient(150deg, #6f93a6, #3f5f72 62%, #243a48); }
.phase--3 { --accent: #4f6b50; } .phase--3 .phase__visual { background: radial-gradient(70% 60% at 76% 14%, rgba(226,240,210,.42), transparent 58%), linear-gradient(150deg, #8aa06a, #566f3d 62%, #324626); }
.phase--4 { --accent: #9a6a32; } .phase--4 .phase__visual { background: radial-gradient(70% 60% at 76% 14%, rgba(255,236,206,.42), transparent 58%), linear-gradient(150deg, #b98a5a, #7a5230 58%, #3a2a1a); }
.phase .signals { margin-top: 4px; }
@media (max-width: 860px) {
  .phase__inner { grid-template-columns: 1fr; gap: 26px; }
  .phase--reverse .phase__visual { order: 0; }
  .phase__visual { aspect-ratio: auto; min-height: 300px; padding: 30px; }
}

/* ============================================================
   Phase mockups — mini dashboards floating on the gradient
   ============================================================ */
.pmock { position: relative; z-index: 1; width: 344px; max-width: 100%; flex: none; background: #fff; border-radius: 16px; box-shadow: 0 36px 66px -34px rgba(20,18,16,.6), 0 4px 12px -7px rgba(20,18,16,.28); padding: 18px; display: flex; flex-direction: column; gap: 13px; color: var(--head); }
.pmock__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-family: "Inconsolata", monospace; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--faint); }
.pmock__head b { display: inline-flex; align-items: center; gap: 7px; font-weight: 500; color: var(--head); }
.pmock__dot { width: 8px; height: 8px; border-radius: 999px; background: #57c98a; flex: none; }
.pmock__tag { background: color-mix(in srgb, var(--accent) 15%, transparent); color: var(--accent); border-radius: 999px; padding: 3px 9px; font-size: .64rem; letter-spacing: .06em; }

/* Architect — progress rows */
.prow { display: flex; align-items: center; justify-content: space-between; gap: 12px; font-size: .85rem; }
.pbar { width: 116px; height: 8px; border-radius: 999px; background: var(--alt); position: relative; overflow: hidden; flex: none; }
.pbar::after { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: var(--w, 70%); border-radius: 999px; background: var(--accent, var(--ink)); }
.pchip { align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; background: var(--alt); border-radius: 999px; padding: 5px 12px 5px 6px; font-size: .74rem; }
.pchip b { width: 19px; height: 19px; border-radius: 6px; background: var(--accent); color: #fff; display: grid; place-content: center; font-size: .66rem; font-weight: 600; }

/* Position — niche scatter map */
.pscatter { position: relative; width: 100%; aspect-ratio: 16 / 9; border-radius: 10px; background: var(--alt); overflow: hidden; }
.pscatter svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.pscatter .ax { stroke: rgba(40,40,40,.13); stroke-width: 1; }
.pscatter .pd { fill: rgba(40,40,40,.27); }
.pscatter .you { fill: var(--accent); }
.pscatter .halo { fill: none; stroke: var(--accent); stroke-width: 2; opacity: .4; }
.plegend { display: flex; gap: 16px; font-size: .72rem; color: var(--muted); }
.plegend span { display: inline-flex; align-items: center; gap: 6px; }
.plegend i { width: 8px; height: 8px; border-radius: 999px; flex: none; }

/* Build — content pipeline */
.pbrief { display: flex; align-items: center; gap: 9px; font-size: .82rem; }
.pbrief span:first-child { flex: 1; padding: 8px 11px; background: var(--alt); border-radius: 8px; color: var(--head); }
.pbrief .ar { flex: none; color: var(--accent); font-weight: 700; }
.pbrief span:last-child { padding: 8px 11px; border: 1px solid var(--line); border-radius: 8px; color: var(--muted); white-space: nowrap; }

/* Convert — checklist + revenue chart */
.pcheck { display: flex; align-items: center; gap: 10px; font-size: .85rem; color: var(--head); cursor: pointer; user-select: none; }
.pcheck i { width: 18px; height: 18px; border-radius: 6px; border: 1.5px solid var(--line); flex: none; display: grid; place-content: center; transition: background .2s var(--ease), border-color .2s var(--ease); }
.pcheck:hover i { border-color: var(--accent); }
.pcheck.on i { background: var(--accent); border-color: var(--accent); }
.pcheck i::after { content: ""; width: 8px; height: 4px; margin-top: -2px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) scale(0); transition: transform .2s var(--ease-out); }
.pcheck.on i::after { transform: rotate(-45deg) scale(1); }
.pchart { display: flex; align-items: flex-end; gap: 8px; height: 64px; margin-top: 4px; }
.pchart i { flex: 1; background: var(--alt); border-radius: 5px 5px 0 0; transform-origin: bottom; }
.pchart i.hi { background: var(--accent); }
.pchart__cap { display: flex; justify-content: space-between; font-family: "Inconsolata", monospace; font-size: .62rem; color: var(--faint); letter-spacing: .1em; }

/* ============================================================
   Freebie pages — visual + opt-in, Notion mockup, live mockup, countdown
   ============================================================ */
.free2 { display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(28px, 4vw, 56px); align-items: center; }
@media (max-width: 900px) { .free2 { grid-template-columns: 1fr; } }
.free2__opt h2 { margin: 0 0 10px; }
.free2__opt > p { color: var(--muted); margin: 0 0 20px; }

/* shared grain on the coloured mockup panels */
.nmock::after, .lmock::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .32; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='fz'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23fz)'/%3E%3C/svg%3E"); background-size: 160px;
}

/* Notion-workspace mockup (Blueprint) */
.nmock { position: relative; isolation: isolate; overflow: hidden; border-radius: var(--radius-lg); padding: clamp(30px, 4vw, 54px) clamp(22px, 3vw, 40px); display: grid; place-items: center;
  background: radial-gradient(66% 56% at 84% 4%, rgba(255,233,204,.55), transparent 56%), radial-gradient(60% 64% at 8% 96%, rgba(150,200,172,.5), transparent 60%), linear-gradient(150deg, #d9ab87, #bd7f9e 54%, #6f6ab0); }
.nmock__page { position: relative; z-index: 1; width: 100%; max-width: 400px; background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 40px 70px -34px rgba(30,24,30,.5), 0 4px 12px -6px rgba(30,24,30,.24);
  transition: transform var(--t-base) var(--ease-out); }
.nmock:hover .nmock__page { transform: translateY(-5px); }
.nmock__cover { height: 74px; background: linear-gradient(108deg, #eab98c, #cb82a6 56%, #7e79c6); }
.nmock__head { padding: 0 22px; }
.nmock__emoji { width: 50px; height: 50px; margin-top: -23px; border-radius: 13px; background: #fff; box-shadow: 0 8px 18px -8px rgba(0,0,0,.32); display: grid; place-content: center; color: #b9789a; }
.nmock__emoji svg { width: 26px; height: 26px; fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.nmock__title { font-size: 1.22rem; font-weight: 600; letter-spacing: -0.02em; margin: 13px 0 3px; color: var(--head); }
.nmock__meta { font-family: "Inconsolata", monospace; font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; color: var(--faint); margin: 0; }
.nmock__list { padding: 14px 12px 18px; display: flex; flex-direction: column; gap: 2px; }
.nrow { display: flex; align-items: center; gap: 11px; padding: 9px 10px; border-radius: 9px; font-size: .9rem; color: var(--head); transition: background .2s var(--ease); }
.nrow:hover { background: var(--alt); }
.nrow__sq { width: 22px; height: 22px; border-radius: 7px; flex: none; }
.nrow .d { margin-left: auto; font-family: "Inconsolata", monospace; font-size: .68rem; letter-spacing: .06em; color: var(--faint); white-space: nowrap; }

/* Live-session mockup (Masterclass) */
.lmock { position: relative; isolation: isolate; overflow: hidden; border-radius: var(--radius-lg); padding: clamp(30px, 4vw, 54px) clamp(22px, 3vw, 40px); display: grid; place-items: center;
  background: radial-gradient(64% 56% at 84% 4%, rgba(214,234,246,.5), transparent 56%), radial-gradient(60% 64% at 8% 96%, rgba(207,154,118,.4), transparent 60%), linear-gradient(150deg, #5d809a, #3f5f72 56%, #283845); }
.lmock__frame { position: relative; z-index: 1; width: 100%; max-width: 420px; background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 40px 70px -34px rgba(20,26,34,.55), 0 4px 12px -6px rgba(20,26,34,.28);
  transition: transform var(--t-base) var(--ease-out); }
.lmock:hover .lmock__frame { transform: translateY(-5px); }
.lmock__video { position: relative; aspect-ratio: 16 / 10; background: radial-gradient(82% 96% at 50% 16%, #46627b, #1e2b37); display: grid; place-items: center; }
.lmock__presenter { width: 62px; height: 62px; border-radius: 999px; background: linear-gradient(140deg, #cf9a76, #8a4a30); box-shadow: 0 0 0 6px rgba(255,255,255,.08); }
.lmock__live { position: absolute; top: 13px; left: 13px; display: inline-flex; align-items: center; gap: 7px; background: rgba(0,0,0,.42); backdrop-filter: blur(4px); padding: 5px 11px; border-radius: 999px; font-family: "Inconsolata", monospace; font-size: .66rem; letter-spacing: .14em; text-transform: uppercase; color: #fff; }
.lmock__live i { width: 8px; height: 8px; border-radius: 999px; background: #ff5a52; box-shadow: 0 0 0 0 rgba(255,90,82,.7); animation: livePulse2 1.8s var(--ease-out) infinite; }
@keyframes livePulse2 { 0% { box-shadow: 0 0 0 0 rgba(255,90,82,.7); } 70% { box-shadow: 0 0 0 8px rgba(255,90,82,0); } 100% { box-shadow: 0 0 0 0 rgba(255,90,82,0); } }
.lmock__bar { display: flex; align-items: center; gap: 12px; padding: 14px 18px; }
.lmock__ppl { display: flex; }
.lmock__ppl span { width: 26px; height: 26px; border-radius: 999px; border: 2px solid #fff; margin-left: -9px; }
.lmock__ppl span:first-child { margin-left: 0; }
.lmock__cap { font-size: .84rem; color: var(--muted); }

/* Countdown */
.countband { text-align: center; }
.countband__label { font-family: "Inconsolata", monospace; font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); margin: 0 0 18px; }
.countdown { display: flex; gap: clamp(8px, 1.6vw, 16px); justify-content: center; flex-wrap: wrap; }
.countdown__unit { background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: clamp(14px, 2vw, 20px) clamp(15px, 2.4vw, 26px); min-width: 72px; box-shadow: var(--e-card); }
.countdown__num { font-size: clamp(1.7rem, 4vw, 2.5rem); font-weight: 600; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; color: var(--head); line-height: 1; }
.countdown__label { font-family: "Inconsolata", monospace; font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); margin-top: 9px; }

/* "What's inside" / "What we cover" — gradient-tile rows */
.inside { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.inrow { position: relative; display: grid; grid-template-columns: 56px 1fr; gap: 20px; align-items: center; padding: 20px 24px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--e-card); transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out); }
.inrow:hover { transform: translateY(-3px); box-shadow: var(--e-hover); }
.inrow__tile { width: 56px; height: 56px; border-radius: 15px; display: grid; place-content: center; color: #fff; box-shadow: 0 12px 24px -12px rgba(25,20,20,.55); background: linear-gradient(145deg, color-mix(in srgb, var(--c, #888) 60%, #fff), var(--c, #888)); }
.inrow__tile span { font-family: "Inconsolata", monospace; font-weight: 600; font-size: 1.06rem; letter-spacing: .02em; }
.inrow__day { font-family: "Inconsolata", monospace; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); margin: 0 0 4px; }
.inrow__body h3 { font-size: 1.12rem; font-weight: 600; letter-spacing: -0.01em; margin: 0 0 5px; color: var(--head); }
.inrow__body p { margin: 0; color: var(--muted); font-size: .96rem; line-height: 1.5; }
@media (max-width: 560px) { .inrow { grid-template-columns: 1fr; gap: 13px; padding: 18px 20px; } .inrow__tile { width: 48px; height: 48px; } }

/* Nav: little animated clock on the Live Masterclass link */
.nav__mc { position: relative; padding-right: 34px; }
.nav__clock { position: absolute; top: 50%; right: 12px; transform: translateY(-50%); width: 19px; height: 19px; color: var(--muted); pointer-events: none; }
.nav__clock svg { width: 100%; height: 100%; display: block; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; overflow: visible; }
.nav__clock-h, .nav__clock-m { transform-box: view-box; transform-origin: 12px 12px; }
.nav__clock-h { animation: clockSpin 12s linear infinite; }
.nav__clock-m { animation: clockSpin 3s linear infinite; }
@keyframes clockSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* ============================================================
   About page — varied, colourful section treatments
   ============================================================ */
/* shared grain on coloured panels */
.aq::after, .duo__panel::after, .mcard::after, .orgcard__top::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .4; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='ag'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ag)'/%3E%3C/svg%3E");
  background-size: 150px 150px;
}

/* big thesis pull-quote band (full-bleed, dark) */
.aq { position: relative; overflow: hidden; isolation: isolate; color: #fff; text-align: center; padding: clamp(76px, 10vw, 132px) 24px;
  background: radial-gradient(70% 70% at 50% 0%, rgba(160,196,148,.18), transparent 62%), linear-gradient(158deg, #3c4b3b, #242d25 66%, #181c17); }
.aq > * { position: relative; z-index: 1; }
.aq h2 { color: #fff; font-size: clamp(2.1rem, 5vw, 3.4rem); line-height: 1.08; letter-spacing: -0.025em; max-width: 20ch; margin: 0 auto; }
.aq__by { margin: 28px auto 0; max-width: 46ch; color: rgba(255,255,255,.6); font-size: 1.08rem; }

/* mission / vision — two coloured gradient panels */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.duo__panel { position: relative; overflow: hidden; isolation: isolate; border-radius: var(--radius-lg); padding: clamp(28px, 3.4vw, 40px); color: #fff; min-height: 384px; display: flex; flex-direction: column; gap: clamp(16px, 2.4vw, 28px); box-shadow: var(--e-float); transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out); }
.duo__panel:hover { transform: translateY(-6px); }
.duo__panel > * { position: relative; z-index: 1; }
.duo__top .eyebrow { color: rgba(255,255,255,.74); margin: 0 0 13px; }
.duo__top h3 { color: #fff; font-size: clamp(1.7rem, 2.7vw, 2.2rem); line-height: 1.08; margin: 0 0 13px; max-width: 14ch; }
.duo__top p { color: rgba(255,255,255,.85); margin: 0; max-width: 36ch; font-size: 1.02rem; }
.duo__panel--warm { background: radial-gradient(80% 72% at 84% 6%, rgba(255,236,210,.48), transparent 56%), linear-gradient(150deg, #cf9a76, #8a4a30 62%, #5e3520); }
.duo__panel--steel { background: radial-gradient(80% 72% at 84% 6%, rgba(214,236,244,.48), transparent 56%), linear-gradient(150deg, #6f93a6, #3f5f72 60%, #243a48); }

/* mission/vision — animated graphic that fills the lower half */
.duo__viz { flex: 1; min-height: 92px; align-self: stretch; position: relative; }
.duo__viz svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.duo__viz .ar { fill: rgba(255,255,255,.13); stroke: none; }
.duo__viz .ln { fill: none; stroke: rgba(255,255,255,.5); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: stroke .3s var(--ease); }
.duo__viz .nd { fill: rgba(255,255,255,.7); }
.duo__viz .core { fill: #fff; filter: drop-shadow(0 0 5px rgba(255,255,255,.55)); }
.duo__viz .halo { fill: none; stroke: rgba(255,255,255,.9); stroke-width: 1.5; opacity: 0; transform-box: fill-box; transform-origin: center; }
.duo__panel:hover .duo__viz .ln { stroke: rgba(255,255,255,.88); }
.duo__panel:hover .duo__viz .halo { animation: vizHalo 1.9s var(--ease-out) infinite; }
@keyframes vizHalo { 0% { transform: scale(.5); opacity: .8; } 75% { transform: scale(2.2); opacity: 0; } 100% { transform: scale(2.2); opacity: 0; } }

/* method recap — 4 coloured motif cards */
.methodrow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.mcard { position: relative; overflow: hidden; isolation: isolate; border-radius: var(--radius); padding: 26px 22px; color: #fff; min-height: 220px; display: flex; flex-direction: column; justify-content: space-between; }
.mcard > * { position: relative; z-index: 1; }
.mcard__n { font-family: "Inconsolata", monospace; font-size: .76rem; letter-spacing: .12em; color: rgba(255,255,255,.7); }
.mcard h4 { color: #fff; font-size: 1.35rem; margin: 0 0 4px; }
.mcard em { font-style: normal; font-size: .85rem; color: rgba(255,255,255,.66); }
.mcard__motif { width: 50px; height: 50px; margin-bottom: 16px; }
.mcard__motif svg { width: 100%; height: 100%; }
.mcard__motif svg * { fill: none; stroke: rgba(255,255,255,.62); stroke-width: 3.4; stroke-linecap: round; stroke-linejoin: round; }
.mcard__motif .mk { fill: rgba(255,255,255,.72); stroke: none; }
.mcard--1 { background: linear-gradient(150deg, #cf9a76, #8a4a30 64%, #5e3520); }
.mcard--2 { background: linear-gradient(150deg, #6f93a6, #3f5f72 62%, #243a48); }
.mcard--3 { background: linear-gradient(150deg, #8aa06a, #5a7340 62%, #354a26); }
.mcard--4 { background: linear-gradient(150deg, #b98a5a, #7a5230 56%, #3a2a1a); }

/* wider structure — cards with coloured header bands */
.orgcard { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out); }
.section--alt .orgcard { background: #fff; }
.orgcard:hover { transform: translateY(-6px); box-shadow: var(--e-hover); }
.orgcard__top { position: relative; overflow: hidden; isolation: isolate; height: 96px; display: flex; align-items: flex-end; padding: 16px 18px; color: #fff; }
.orgcard__top span { position: relative; z-index: 1; font-family: "Inconsolata", monospace; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; }
.orgcard__top--1 { background: linear-gradient(120deg, #cf9a76, #8a4a30); }
.orgcard__top--2 { background: linear-gradient(120deg, #8aa06a, #5a7340); }
.orgcard__top--3 { background: linear-gradient(120deg, #6f93a6, #3f5f72); }
.orgcard__body { padding: 22px 24px 26px; }
.orgcard__body h3 { margin: 0 0 8px; }
.orgcard__body p { margin: 0; color: var(--muted); }

@media (max-width: 920px) { .duo { grid-template-columns: 1fr; } .methodrow { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .methodrow { grid-template-columns: 1fr; } }

/* ---------- Free Blueprint band ---------- */
.freeband { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; background: var(--alt); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(28px, 4vw, 46px); }
.freeband__text { max-width: 52ch; }
.freeband__text h2 { font-size: clamp(1.6rem, 2.6vw, 2.1rem); margin: 0 0 8px; }
.freeband__text p { margin: 0; color: var(--muted); }
.freeband .btn { flex: none; }
@media (max-width: 640px) { .freeband { flex-direction: column; align-items: flex-start; max-width: calc(100% - 32px); } .freeband .btn { width: 100%; } }

/* ---------- Section scaffolding ---------- */
.section { padding-block: var(--pad); }
.section--alt { background: var(--alt); }
.section__head { max-width: 64ch; margin: 0 auto clamp(44px, 6vw, 72px); text-align: center; }
.section__lede { margin: 20px auto 0; font-size: 1.12rem; color: var(--muted); }

/* ---------- Alternating rows ---------- */
.row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  padding-block: clamp(40px, 5vw, 64px);
}
.row + .row { border-top: 1px solid var(--line-2); }
.row--reverse .row__media { order: -1; }
.row__text h3 { margin: 0 0 16px; }
.row__text p { margin: 0 0 22px; }

.ticks { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.ticks li { position: relative; padding-left: 28px; color: var(--text); }
.ticks li::before {
  content: ""; position: absolute; left: 0; top: .55em;
  width: 14px; height: 8px; border-left: 1.5px solid var(--ink); border-bottom: 1.5px solid var(--ink);
  transform: rotate(-45deg);
}

/* ---------- Media stage + color-in ---------- */
.row__media { display: flex; justify-content: center; }
.stage {
  position: relative; width: 100%; max-width: 460px; aspect-ratio: 5 / 4;
  border-radius: var(--radius-lg); overflow: hidden;
  display: flex; align-items: center; justify-content: center; padding: 30px;
  background: var(--stage);
}
/* colored art layer — colored by default; JS animates a grey->colour reveal on enter */
.stage__art { position: absolute; inset: 0; z-index: 0; }
/* each art layer carries a design (pattern) integrated into the colour */
.stage__art--sand {
  background:
    repeating-radial-gradient(circle at 80% 16%, rgba(255,255,255,.18) 0 1.5px, transparent 1.5px 30px),
    radial-gradient(120% 120% at 20% 15%, #f3d9bf, #e9c6a4 38%, #d8a987 70%, #c98f6e);
}
.stage__art--sky {
  background:
    radial-gradient(rgba(255,255,255,.26) 1.4px, transparent 1.6px) 0 0 / 22px 22px,
    radial-gradient(120% 120% at 80% 10%, #cfe0e6, #aec6d2 40%, #8fb0c0 72%, #76a0b3);
}
.stage__art--moss {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.14) 0 1.5px, transparent 1.5px 22px),
    radial-gradient(120% 120% at 25% 85%, #dde0cd, #c2caa6 42%, #a3b083 72%, #8a9a6c);
}
.stage__art::after {
  content: ""; position: absolute; inset: 0; opacity: .45; pointer-events: none; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='sg'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23sg)'/%3E%3C/svg%3E");
  background-size: 150px 150px;
}
.stage .mock { position: relative; z-index: 1; max-width: none; width: 100%; aspect-ratio: auto; margin: 0; box-shadow: 0 20px 44px -26px rgba(25,25,25,.35); }

.mock {
  width: 100%; max-width: 440px;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px; display: flex; flex-direction: column; gap: 15px; justify-content: center;
}
.mock .chip { margin-bottom: 4px; }
.mock__line { height: 11px; border-radius: 999px; background: var(--alt); }
.w30{width:30%}.w45{width:45%}.w50{width:50%}.w60{width:60%}.w70{width:70%}.w80{width:80%}.w90{width:90%}
.mock__id { display: flex; align-items: center; gap: 13px; margin-bottom: 4px; }
.mock__avatar { width: 40px; height: 40px; border-radius: 999px; flex: none; background: radial-gradient(120% 120% at 30% 25%, #d8a987, #b06a45); }
.mock__tags { display: flex; gap: 8px; margin-top: 8px; }
.mock__tags span { font-size: .76rem; padding: 6px 12px; border: 1px solid var(--line); border-radius: 999px; color: var(--head); }
.mock__row { display: flex; align-items: center; gap: 12px; }
.mock__row .mock__line { flex: 1; }
.mock__pill { align-self: flex-start; margin-top: 8px; font-size: .76rem; color: #fff; background: var(--ink); padding: 6px 14px; border-radius: 999px; }
.mock__pill--live { display: inline-flex; align-items: center; gap: 8px; }
.live-dot { width: 8px; height: 8px; border-radius: 999px; background: #54cc8c; box-shadow: 0 0 9px 1px rgba(84,204,140,.85), 0 0 0 0 rgba(84,204,140,.6); animation: pulse 2.2s var(--ease-out) infinite; }
@keyframes pulse {
  0%   { box-shadow: 0 0 9px 1px rgba(84,204,140,.9), 0 0 0 0 rgba(84,204,140,.55); }
  70%  { box-shadow: 0 0 12px 2px rgba(84,204,140,.7), 0 0 0 9px rgba(84,204,140,0); }
  100% { box-shadow: 0 0 9px 1px rgba(84,204,140,.6), 0 0 0 0 rgba(84,204,140,0); }
}
.mock--flywheel { position: relative; align-items: center; justify-content: center; aspect-ratio: 5/4; }
.mock--flywheel svg { width: 88%; overflow: visible; }
.fw-base { stroke: var(--line); stroke-width: 1; }
.fw-area { stroke: none; }
.fw-line { fill: none; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }
.fw-glow { fill: #4f6b50; opacity: .16; transform-box: fill-box; transform-origin: center; animation: fwHeart 2.4s var(--ease-out) infinite; }
.fw-dot { fill: #4f6b50; filter: drop-shadow(0 0 4px rgba(79,107,80,.8)); }
@keyframes fwHeart {
  0%   { transform: scale(.5);  opacity: .5; }
  12%  { transform: scale(1.3); opacity: .28; }
  24%  { transform: scale(.85); opacity: .42; }
  38%  { transform: scale(1.65); opacity: .16; }
  55%  { transform: scale(2.1); opacity: 0; }
  100% { transform: scale(2.1); opacity: 0; }
}
.fw-lbl { fill: var(--faint); font-family: "Inconsolata", monospace; font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; }

/* ---------- Cards (three-up) ---------- */
.grid { display: grid; gap: 22px; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.card {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 32px 30px; transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.section--alt .card { background: #fff; }
.card:hover { transform: translateY(-5px); box-shadow: var(--e-hover); }
.card__index { display: inline-block; font-family: "Inconsolata", monospace; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); margin-bottom: 18px; }
.card h3 { margin: 0 0 12px; }
.card p { margin: 0; color: var(--muted); }

/* ---------- Outcomes six-up (icon cards) ---------- */
.grid--feat { gap: 16px; }
.feat {
  position: relative; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 30px 28px; overflow: hidden;
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color .3s var(--ease);
}
.section--alt .feat { background: #fff; }
.feat > * { position: relative; z-index: 1; }
/* coloured glow that washes in on hover */
.feat::after { content: ""; position: absolute; z-index: 0; top: -42%; right: -28%; width: 72%; height: 86%; border-radius: 999px; pointer-events: none; opacity: 0; transition: opacity .4s var(--ease);
  background: radial-gradient(closest-side, color-mix(in srgb, var(--accent) 30%, transparent), transparent 72%); }
.feat:hover::after { opacity: 1; }
/* top accent line grows on hover */
.feat::before { content: ""; position: absolute; z-index: 2; left: 0; top: 0; height: 3px; width: 0; background: var(--accent, var(--ink)); transition: width .45s var(--ease-out); }
.feat:hover { transform: translateY(-6px); box-shadow: var(--e-hover); border-color: rgba(25,25,25,.16); }
.feat:hover::before { width: 100%; }
/* bold gradient icon tile, white icon, coloured glow */
.feat__icon { display: inline-grid; place-content: center; width: 52px; height: 52px; border-radius: 15px; color: #fff; margin-bottom: 20px;
  background: linear-gradient(140deg, color-mix(in srgb, var(--accent) 58%, #fff), var(--accent));
  box-shadow: 0 12px 24px -10px color-mix(in srgb, var(--accent) 74%, transparent);
  transition: transform .4s var(--ease-out); }
.feat__icon svg { width: 24px; height: 24px; fill: none; stroke: #fff; stroke-width: 1.85; stroke-linecap: round; stroke-linejoin: round; }
.feat:hover .feat__icon { transform: translateY(-3px) scale(1.06) rotate(-4deg); }
/* big tinted index number */
.feat__num { position: absolute; top: 16px; right: 22px; font-family: "Inconsolata", monospace; font-size: 1.55rem; font-weight: 500; letter-spacing: .01em; color: color-mix(in srgb, var(--accent) 26%, transparent); }
.feat h4 { margin: 0 0 8px; }
.feat p { margin: 0; color: var(--muted); font-size: 1rem; }
/* per-card accent — vivid, on-brand earth tones */
.feat:nth-child(1) { --accent: #b3582e; }
.feat:nth-child(2) { --accent: #4d7d57; }
.feat:nth-child(3) { --accent: #3d6a86; }
.feat:nth-child(4) { --accent: #bf8133; }
.feat:nth-child(5) { --accent: #5d8169; }
.feat:nth-child(6) { --accent: #8a6647; }

/* ---------- Tiers ---------- */
.tiers { align-items: stretch; }
.tier {
  position: relative; display: flex; flex-direction: column; gap: 20px;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 36px 32px; transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.tiers .tier:nth-of-type(1) { --accent: #9a5836; }
.tiers .tier:nth-of-type(2) { --accent: #7d9663; }
.tiers .tier:nth-of-type(3) { --accent: #466071; }
.tier::before { content: ""; position: absolute; left: 16px; right: 16px; top: 0; height: 3px; border-radius: 0 0 3px 3px; background: var(--accent, var(--ink)); transform: scaleX(0); transform-origin: center; transition: transform .5s var(--ease-out); }
.tier:hover::before { transform: scaleX(1); }
.section--alt .tier:not(.tier--featured) { background: #fff; }
.tier:hover { transform: translateY(-6px); box-shadow: var(--e-hover); }
.tier .ticks li::before { border-color: var(--accent, var(--ink)); }
.tier--featured,
.section--alt .tier--featured {
  border-color: transparent;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.045) 0 1px, transparent 1px 18px),
    radial-gradient(85% 55% at 75% -5%, rgba(155,192,142,.20), transparent 60%),
    linear-gradient(158deg, #3c4b3b, #242d25 66%, #181c17);
}
.tier--featured h3, .tier--featured .tier__who { color: #fff; }
.tier--featured .tier__who { color: rgba(255,255,255,.66); }
.tier--featured .ticks li { color: rgba(255,255,255,.88); }
.tier--featured .ticks li::before { border-color: #aecb9e; }
.tier--featured::before { background: #aecb9e; }
.tier__badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); font-family: "Inconsolata", monospace; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: #2a3528; background: #cfe0c2; padding: 6px 14px; border-radius: 999px; white-space: nowrap; box-shadow: 0 8px 20px -8px rgba(40,53,40,.6); }
.tier__head h3 { margin: 0 0 8px; }
.tier__who { margin: 0; color: var(--muted); font-size: 1rem; }
.tier .ticks { margin-bottom: 6px; }
.tiers__note { text-align: center; margin: clamp(40px, 5vw, 60px) 0 0; color: var(--faint); font-size: .92rem; }

/* ---------- Founder ---------- */
.founder { display: grid; grid-template-columns: 360px 1fr; gap: clamp(40px, 6vw, 88px); align-items: center; }
.founder__media { position: relative; display: flex; justify-content: center; }
.founder__halo { position: absolute; z-index: 0; left: -6%; top: -5%; width: 112%; height: 110%; border-radius: 44px; filter: blur(40px); opacity: .6; pointer-events: none;
  background: radial-gradient(56% 56% at 28% 24%, rgba(207,154,118,.95), transparent 62%), radial-gradient(58% 58% at 78% 82%, rgba(125,150,99,.85), transparent 64%); }
.founder__photo { position: relative; z-index: 1; width: 100%; max-width: 340px; aspect-ratio: 4 / 5; border-radius: 28px; overflow: hidden; isolation: isolate;
  background: linear-gradient(155deg, var(--alt), #e7e6df); border: 1px solid rgba(255,255,255,.55); box-shadow: 0 46px 84px -44px rgba(25,25,25,.55), 0 4px 12px -6px rgba(25,25,25,.2); }
.founder__photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .8s var(--ease-out); }
.founder__photo.is-empty img { display: none; }
.founder__media:hover .founder__photo img { transform: scale(1.035); }
.founder__photo::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .22; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='fn'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23fn)'/%3E%3C/svg%3E"); background-size: 150px; }
.founder__caption { position: absolute; z-index: 2; left: 14px; bottom: 14px; display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,.82); backdrop-filter: saturate(160%) blur(10px); border-radius: 13px; padding: 8px 13px; font-size: .82rem; color: var(--head); box-shadow: 0 16px 32px -18px rgba(25,25,25,.6); }
.founder__caption::before { content: ""; width: 7px; height: 7px; border-radius: 999px; background: #9a5836; flex: none; }
.founder__text .eyebrow { margin-bottom: 16px; }
.founder__text h2 { margin: 0 0 18px; }
.founder__text p { margin: 0 0 18px; }
.founder__sign { margin: 28px 0 24px; padding-top: 20px; border-top: 1px solid var(--line); display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.founder__autograph { font-family: "Great Vibes", cursive; font-size: clamp(2.6rem, 4.6vw, 3.4rem); line-height: .95; color: var(--head); padding-right: .15em; }
.founder__role { font-family: "Inconsolata", monospace; font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.founder__text .btn { margin-top: 8px; }

/* ---------- FAQ (animated accordion) ---------- */
.faq { max-width: 820px; }
.faq__list { border-top: 1px solid var(--line); }
.qa { border-bottom: 1px solid var(--line); }
.qa__q {
  width: 100%; text-align: left; background: none; border: 0; cursor: pointer;
  font-family: inherit; font-size: 1.15rem; color: var(--head); letter-spacing: -0.01em;
  padding: 24px 48px 24px 4px; position: relative; transition: color .25s var(--ease);
}
.qa__q:hover { color: var(--ink); }
.qa__icon { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 15px; height: 15px; }
.qa__icon::before, .qa__icon::after { content: ""; position: absolute; background: var(--muted); transition: transform .4s var(--ease-out), background .25s; }
.qa__icon::before { top: 7px; left: 0; right: 0; height: 1.5px; }
.qa__icon::after { left: 7px; top: 0; bottom: 0; width: 1.5px; }
.qa.is-open .qa__icon::after { transform: scaleY(0); }
.qa.is-open .qa__q { color: var(--ink); }
.qa__panel { height: 0; overflow: hidden; will-change: height; }
.qa__inner { padding: 0 48px 26px 4px; }
.qa__inner p { margin: 0; color: var(--muted); }

/* ---------- CTA ---------- */
.cta { padding-block: var(--pad); padding-inline: 16px; }
.cta__inner {
  max-width: 860px; text-align: center; background: var(--ink); color: #fff;
  border-radius: 28px; padding: clamp(48px, 7vw, 84px) clamp(28px, 5vw, 64px);
  position: relative; overflow: hidden;
}
.cta__inner::before { content:""; position:absolute; inset:-40% -10% auto; height:140%; background: radial-gradient(50% 60% at 50% 0%, rgba(255,255,255,.08), transparent 70%); pointer-events:none; }
.cta__inner h2 { color: #fff; margin: 0 0 16px; position: relative; }
.cta__inner > p { color: rgba(255,255,255,.66); max-width: 48ch; margin: 0 auto 30px; position: relative; }
.cta__form { display: flex; gap: 10px; max-width: 460px; margin: 0 auto; position: relative; }
.cta__form input {
  flex: 1; height: 52px; padding: 0 20px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); color: #fff;
  font: inherit; font-size: 1rem; transition: border-color .3s var(--ease), background .3s var(--ease);
}
.cta__form input::placeholder { color: rgba(255,255,255,.4); }
.cta__form input:focus { outline: none; border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.1); }
.cta__form .btn { height: 52px; }
.cta__form .btn--invert::after { background: #d9d9d2; }
.cta__fine { margin: 18px 0 0; font-size: .82rem; color: rgba(255,255,255,.4); position: relative; }

/* ---------- Footer ---------- */
.footer { border-top: 1px solid var(--line); padding-block: clamp(48px, 6vw, 72px) 30px; }
.footer__inner { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 40px; }
.footer__tag { margin: 16px 0 0; color: var(--muted); max-width: 34ch; font-size: 1rem; }
.footer__col { display: flex; flex-direction: column; gap: 12px; }
.footer__h { font-family: "Inconsolata", monospace; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); margin-bottom: 4px; }
.footer__col a { position: relative; width: fit-content; color: var(--text); font-size: 1rem; transition: color .2s; }
.footer__col a:hover { color: var(--ink); }
.footer__bottom { display: flex; justify-content: space-between; gap: 16px; margin-top: 44px; padding-top: 24px; border-top: 1px solid var(--line-2); color: var(--faint); font-size: .85rem; font-family: "Inconsolata", monospace; letter-spacing: .02em; }

/* ---------- Reveal base states (GSAP toggles these) ---------- */
[data-reveal], [data-reveal-rise], [data-reveal-head] > *, [data-stagger] > *, .reveal-line { will-change: transform, opacity; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation: none !important; }
}

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .nav__menu { padding: 16px; }
  .nav__menu-grid { grid-template-columns: 1fr; gap: 14px; }
  .nav__promo { min-height: 150px; }
  .panel__body { grid-template-columns: 1fr; }
  .panel__col--chart { border-left: none; padding-left: 0; border-top: 1px solid var(--line-2); padding-top: 20px; }
  .row { grid-template-columns: 1fr; gap: 32px; }
  .row--reverse .row__media { order: 0; }
  .grid--3 { grid-template-columns: 1fr; }
  .founder { grid-template-columns: 1fr; text-align: center; }
  .founder__media { order: -1; }
  .founder__sign { align-items: center; }
  .founder__text .btn { margin-inline: auto; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  body { font-size: 16px; }
  .hero__sub { font-size: 1.05rem; }
  .cta__form { gap: 8px; }
  .cta__form .btn { padding: 0 18px; }
  .footer__inner { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; }
}

/* ============================================================
   Sub-pages (Approach / Programs / Case studies / About / Contact)
   ============================================================ */

/* sub-page hero */
.subhero { padding: clamp(40px, 6vw, 80px) 0 clamp(36px, 5vw, 60px); text-align: center; }
.subhero__inner { max-width: 60ch; margin-inline: auto; }
.subhero h1 { margin: 0 0 20px; font-size: clamp(1.55rem, 6.2vw, 2.8rem); letter-spacing: -0.025em; }
.subhero__lede { font-size: 1.12rem; color: var(--muted); margin: 0 auto; max-width: 48ch; }
.subhero__cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 32px; }
.subhero__meta { display: flex; gap: 28px; justify-content: center; flex-wrap: wrap; margin-top: 36px; font-family: "Inconsolata", monospace; font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; color: var(--faint); }
.subhero__meta span { display: inline-flex; align-items: center; gap: 8px; }
.subhero__meta span::before { content: ""; width: 6px; height: 6px; border-radius: 999px; background: var(--ink); }

/* process steps (Approach) */
.steps { max-width: 880px; margin-inline: auto; display: flex; flex-direction: column; }
.step { display: grid; grid-template-columns: 88px 1fr; gap: 28px; padding: 36px 0; border-top: 1px solid var(--line); }
.step:last-child { border-bottom: 1px solid var(--line); }
.step__num { font-family: "Inconsolata", monospace; font-size: 1.05rem; color: var(--faint); letter-spacing: .08em; padding-top: 6px; }
.step h3 { margin: 0 0 12px; }
.step p { margin: 0 0 16px; color: var(--muted); }
.step .ticks li { color: var(--text); }

/* case studies */
.case { display: grid; grid-template-columns: 340px 1fr; gap: clamp(32px, 5vw, 72px); align-items: start; padding-block: clamp(44px, 5vw, 76px); }
.case:nth-of-type(1) { --accent: #9a5836; --tint: #f1e4d7; }
.case:nth-of-type(2) { --accent: #466071; --tint: #dde7ec; }
.case:nth-of-type(3) { --accent: #4f6b50; --tint: #e2e9e0; }
.case + .case { border-top: 1px solid var(--line-2); }
.case--reverse { grid-template-columns: 1fr 340px; }
.case--reverse .case__aside { order: 1; }
.case__aside { position: sticky; top: 100px; }
.case__tag { display: inline-block; font-size: .82rem; font-weight: 600; letter-spacing: .01em; color: var(--accent); }
.case__name { font-size: clamp(1.8rem, 3.2vw, 2.4rem); letter-spacing: -0.02em; color: var(--head); margin: 10px 0 14px; }
.case__role { color: var(--muted); font-size: 1rem; line-height: 1.55; margin: 0; }
.case__role em { color: var(--head); font-style: italic; }
.case__art { margin-top: 24px; aspect-ratio: 16 / 10; border-radius: var(--radius); position: relative; overflow: hidden; isolation: isolate; display: flex; align-items: flex-end; padding: 18px; }
.case__art::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .4; mix-blend-mode: soft-light; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='c'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23c)'/%3E%3C/svg%3E"); background-size: 150px 150px; }
.case__mono { position: absolute; inset: 0; z-index: 0; display: grid; place-content: center; font-size: clamp(3.5rem, 8vw, 5rem); font-weight: 500; letter-spacing: -0.03em; color: rgba(255,255,255,.92); }
.case__cap { position: relative; z-index: 2; font-family: "Inconsolata", monospace; font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.9); }
.case__art--a { background: radial-gradient(70% 60% at 76% 16%, rgba(255,238,214,.5), transparent 60%), linear-gradient(150deg, #cf9a76, #8a4a30 62%, #5e3520); }
.case__art--b { background: radial-gradient(70% 60% at 78% 16%, rgba(214,236,244,.5), transparent 58%), linear-gradient(150deg, #6f93a6, #3f5f72 60%, #243a48); }
.case__art--c { background: radial-gradient(70% 60% at 78% 16%, rgba(230,240,210,.5), transparent 58%), linear-gradient(150deg, #8aa06a, #5a7340 60%, #354a26); }
.case__breakdown { display: flex; flex-direction: column; gap: 14px; }
.case__block { padding: 24px 26px; border-radius: var(--radius); border: 1px solid var(--line); background: var(--panel); transition: border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out); }
.case__block:hover { border-color: rgba(25,25,25,.16); box-shadow: 0 26px 48px -36px rgba(25,25,25,.26); transform: translateY(-3px); }
.case__k { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; background: var(--tint); color: var(--accent); font-size: .85rem; font-weight: 600; letter-spacing: .01em; margin-bottom: 14px; }
.case__block h4 { margin: 0 0 9px; font-size: clamp(1.2rem, 1.8vw, 1.4rem); }
.case__block p { margin: 0; color: var(--muted); }
.case__take { margin-top: 6px; padding: 22px 26px; background: var(--tint); border-radius: var(--radius); }
.case__take strong { color: var(--accent); font-weight: 600; }
.case__disclaimer { max-width: 760px; margin: 8px auto 0; text-align: center; color: var(--faint); font-size: .88rem; }

/* contact */
.contact { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); align-items: start; }
.contact__intro h1, .contact__intro h2 { margin: 0 0 18px; }
.contact__intro p { color: var(--muted); margin: 0 0 24px; }
.contact__points { list-style: none; padding: 0; margin: 26px 0 0; display: flex; flex-direction: column; gap: 14px; }
.contact__points li { position: relative; padding-left: 28px; color: var(--text); }
.contact__points li::before { content: ""; position: absolute; left: 0; top: .55em; width: 14px; height: 8px; border-left: 1.5px solid var(--ink); border-bottom: 1.5px solid var(--ink); transform: rotate(-45deg); }
.contact__card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(28px, 4vw, 40px); box-shadow: 0 30px 60px -38px rgba(25,25,25,.30); }
.contact__card h2 { font-size: 1.5rem; margin: 0 0 8px; }
.contact__card > p { color: var(--muted); margin: 0 0 24px; font-size: 1rem; }
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.field label { font-size: .85rem; color: var(--head); font-weight: 500; }
.field input, .field textarea, .field select {
  font: inherit; font-size: 1rem; color: var(--text);
  padding: 12px 16px; border-radius: 12px; border: 1px solid var(--line); background: #fff;
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.field textarea { resize: vertical; min-height: 110px; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--ink); box-shadow: 0 0 0 3px rgba(25,25,25,.16); }
.contact__card .btn { width: 100%; margin-top: 6px; }
.contact__note { margin: 14px 0 0; font-size: .82rem; color: var(--faint); text-align: center; }

@media (max-width: 920px) {
  .case { grid-template-columns: 1fr; gap: 24px; }
  .case__aside { position: static; }
  .case--reverse .case__aside { order: 0; }
  .contact { grid-template-columns: 1fr; }
  .step { grid-template-columns: 1fr; gap: 6px; }
  .step__num { padding-top: 0; }
}

/* ============================================================
   Apple-style page transition + colorful hero tiles + switcher
   ============================================================ */

/* page-load reveal: a paper cover fades out on every load (no white flash) */
html::before {
  content: ""; position: fixed; inset: 0; z-index: 9999; background: var(--paper);
  pointer-events: none; opacity: 0; animation: pageReveal .6s var(--ease-out);
}
@keyframes pageReveal { from { opacity: 1; } to { opacity: 0; } }
/* exit cover, toggled by JS before navigating away */
.page-cover { position: fixed; inset: 0; z-index: 9998; background: var(--paper); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .4s var(--ease-out), visibility .4s; }
.page-cover.is-on { opacity: 1; visibility: visible; pointer-events: auto; }

/* ---- hero colorful tile cluster ---- */
/* tiles sit close together: outer corners rounded, inner corners square (joined group) */
.hero__tiles { width: 100%; max-width: 1000px; margin-top: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.hero__tiles .htile { border-radius: 0; }
.hero__tiles .htile:first-child { border-top-left-radius: var(--radius-lg); border-bottom-left-radius: var(--radius-lg); }
.hero__tiles .htile:last-child { border-top-right-radius: var(--radius-lg); border-bottom-right-radius: var(--radius-lg); }

/* editorial statement below the tiles — toned down */
.hero__statement { width: 100%; max-width: 1000px; margin: clamp(48px, 5.5vw, 74px) auto 0; text-align: left; }
.hero__statement h2 { font-size: clamp(1.3rem, 2.1vw, 1.7rem); font-weight: 400; letter-spacing: -0.015em; line-height: 1.4; color: var(--head); margin: 0; max-width: 32ch; }
.hero__statement p { font-size: clamp(1.3rem, 2.1vw, 1.7rem); font-weight: 400; letter-spacing: -0.015em; line-height: 1.4; color: var(--muted); margin: 6px 0 0; max-width: 42ch; }
.htile {
  position: relative; border-radius: var(--radius); overflow: hidden; min-height: 330px;
  isolation: isolate; border: 1px solid var(--line); display: flex; padding: 18px;
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.htile { box-shadow: 0 30px 56px -38px rgba(25,25,25,.28); }
.htile::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .4; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size: 150px 150px;
}
.htile > * { position: relative; z-index: 2; }
.htile--photo { background: radial-gradient(70% 58% at 76% 16%, rgba(255,238,214,.5), transparent 60%), linear-gradient(155deg, #e3b78f, #b06a45 58%, #6e3f28); align-items: flex-start; }
.htile--photo img { position: absolute; left: -1px; right: -1px; top: -1px; width: calc(100% + 2px); height: calc(100% + 2px); object-fit: cover; z-index: 0; }
.htile--ui { background: var(--alt); align-items: center; justify-content: center; }
.htile--vivid { background: radial-gradient(72% 55% at 80% 18%, rgba(255,188,96,.62), transparent 55%), radial-gradient(66% 70% at 16% 85%, rgba(108,186,138,.66), transparent 60%), linear-gradient(150deg, #6f936c, #5688a0 50%, #cf9350); align-items: center; justify-content: center; }

.htile__chip { background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border-radius: 12px; padding: 9px 14px; font-size: .82rem; color: var(--head); box-shadow: 0 14px 30px -18px rgba(25,25,25,.55); }
.htile__chip strong { font-weight: 600; }
.float { animation: floaty 5.5s ease-in-out infinite; }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }

/* tile 2 — founder OS mini card */
.oscard { width: 100%; max-width: 230px; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 16px; box-shadow: 0 18px 34px -22px rgba(25,25,25,.3); display: flex; flex-direction: column; gap: 11px; }
.oscard__top { display: flex; align-items: center; gap: 8px; font-family: "Inconsolata", monospace; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--faint); }
.oscard__dot { width: 8px; height: 8px; border-radius: 999px; background: #57c98a; }
.oscard__row { display: flex; align-items: center; justify-content: space-between; gap: 10px; font-size: .82rem; color: var(--head); }
.oscard__row .meter { width: 92px; height: 8px; border-radius: 999px; background: var(--alt); position: relative; overflow: hidden; }
.oscard__row .meter::after { content: ""; position: absolute; inset: 0; width: var(--w, 70%); background: var(--ink); border-radius: 999px; }
.meter--80 { --w: 80%; } .meter--64 { --w: 64%; } .meter--92 { --w: 92%; }
.oscard__chip { margin-top: 2px; display: inline-flex; align-items: center; gap: 8px; font-size: .74rem; color: var(--head); background: var(--alt); border-radius: 999px; padding: 6px 11px; align-self: flex-start; }
.oscard__brand { width: 18px; height: 18px; border-radius: 5px; background: var(--ink); color: #fff; display: grid; place-content: center; font-size: .7rem; }

/* tile 3 — automations card with real toggles */
.autocard { width: 100%; max-width: 230px; background: #fff; border-radius: 14px; padding: 16px; box-shadow: 0 18px 34px -22px rgba(25,25,25,.4); }
.autocard__h { display: block; font-family: "Inconsolata", monospace; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--faint); margin-bottom: 6px; }
.autorow { display: flex; align-items: center; gap: 10px; font-size: .9rem; color: var(--head); cursor: pointer; padding: 7px 0; }
.autorow input { appearance: none; -webkit-appearance: none; width: 19px; height: 19px; flex: none; border: 1.5px solid var(--line); border-radius: 6px; display: grid; place-content: center; cursor: pointer; transition: background .22s var(--ease), border-color .22s var(--ease); }
.autorow input::after { content: ""; width: 9px; height: 5px; margin-top: -2px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) scale(0); transition: transform .22s var(--ease-out); }
.autorow input:checked { background: var(--ink); border-color: var(--ink); }
.autorow input:checked::after { transform: rotate(-45deg) scale(1); }

/* ---- interactive switcher section ---- */
.switcher { display: grid; grid-template-columns: 300px 1fr; gap: 22px; align-items: stretch; }
.switcher__tabs { display: flex; flex-direction: column; gap: 6px; }
.switcher__tab { text-align: left; background: none; border: 1px solid transparent; border-radius: 14px; padding: 16px 18px; cursor: pointer; font: inherit; font-size: 1.08rem; color: var(--muted); letter-spacing: -0.01em; transition: background .25s var(--ease), color .25s var(--ease), border-color .25s; display: flex; flex-direction: column; gap: 3px; }
.switcher__tab em { font-style: normal; font-size: .84rem; color: var(--faint); }
.switcher__tab:hover { color: var(--head); }
.switcher__tab.is-active { background: var(--panel); color: var(--head); border-color: var(--line); box-shadow: 0 16px 32px -26px rgba(25,25,25,.35); }
.section--alt .switcher__tab.is-active { background: #fff; }
.switcher__stage { position: relative; border-radius: var(--radius-lg); overflow: hidden; min-height: 400px; border: 1px solid var(--line); }
.switcher__panel { position: absolute; inset: 0; padding: clamp(26px, 3.2vw, 44px); display: flex; flex-direction: column; justify-content: flex-end; gap: 12px; opacity: 0; visibility: hidden; transform: scale(1.015); transition: opacity .5s var(--ease-out), transform .6s var(--ease-out), visibility .5s; isolation: isolate; }
.switcher__panel::after { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .35; mix-blend-mode: soft-light; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='s'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23s)'/%3E%3C/svg%3E"); background-size: 160px 160px; }
.switcher__panel.is-active { opacity: 1; visibility: visible; transform: none; }
.switcher__panel > * { position: relative; z-index: 1; }
.switcher__motif { position: absolute; top: 28px; right: 28px; width: 34%; max-width: 180px; pointer-events: none; }
.switcher__motif svg { width: 100%; height: auto; display: block; }
.switcher__motif svg * { fill: none; stroke: rgba(255,255,255,.5); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.switcher__motif .mk { fill: rgba(255,255,255,.62); stroke: none; }
@media (max-width: 560px) { .switcher__motif { display: none; } }
.switcher__panel .eyebrow { color: rgba(255,255,255,.7); margin: 0; }
.switcher__panel h3 { margin: 0; color: #fff; max-width: 18ch; }
.switcher__panel p { margin: 0; color: rgba(255,255,255,.82); max-width: 42ch; }
.switcher__panel--brand { background: radial-gradient(70% 60% at 78% 16%, rgba(255,236,210,.5), transparent 58%), linear-gradient(150deg, #cf9a76, #8a4a30 60%, #5e3520); }
.switcher__panel--systems { background: radial-gradient(70% 60% at 80% 14%, rgba(214,236,244,.5), transparent 58%), linear-gradient(150deg, #6f93a6, #3f5f72 60%, #243a48); }
.switcher__panel--offers { background: radial-gradient(70% 60% at 78% 16%, rgba(230,240,210,.5), transparent 58%), linear-gradient(150deg, #8aa06a, #5a7340 60%, #354a26); }
.switcher__panel--loop { background: radial-gradient(70% 60% at 80% 16%, rgba(255,224,196,.5), transparent 58%), linear-gradient(150deg, #b98a5a, #7a5230 55%, #3a2a1a); }

@media (max-width: 920px) {
  .hero__tiles { grid-template-columns: 1fr; max-width: 380px; gap: 10px; }
  .hero__tiles .htile,
  .hero__tiles .htile:first-child,
  .hero__tiles .htile:last-child { border-radius: var(--radius-lg); }
  .htile { min-height: 240px; }
  .switcher { grid-template-columns: 1fr; }
  .switcher__tabs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; overflow: visible; }
  .switcher__tab { flex: none; text-align: center; align-items: center; padding: 12px 10px; font-size: .98rem; }
  .switcher__tab em { display: none; }
  .switcher__tab.is-active { box-shadow: 0 4px 12px -8px rgba(25,25,25,.26); }
  .switcher__stage { min-height: 340px; }
}

/* ============================================================
   Mobile polish (audit pass) — media safety, long-word wrapping,
   6-up grid density, tap targets, contained horizontal scroll
   ============================================================ */
img, video, iframe, svg { max-width: 100%; }
img, video { height: auto; }

/* Long strings (emails, URLs) can't blow out a narrow column */
p, li, h1, h2, h3, h4, .btn, .card, .feat, .inrow__body, td { overflow-wrap: break-word; }

/* Six-up outcome/values cards: two across on phones, not a stack of six */
@media (max-width: 920px) {
  .grid.grid--feat { grid-template-columns: 1fr 1fr; gap: 14px; }
}
@media (max-width: 560px) {
  .grid.grid--feat .feat { padding: 22px 18px; }
  .grid.grid--feat .feat__icon { width: 46px; height: 46px; margin-bottom: 14px; }
  .grid.grid--feat .feat__num { top: 12px; right: 15px; font-size: 1.3rem; }
  .grid.grid--feat .feat h3 { font-size: 1.1rem; line-height: 1.25; margin-bottom: 8px; }
  .grid.grid--feat .feat p { font-size: .9rem; line-height: 1.45; }
}
@media (max-width: 360px) {
  .grid.grid--feat { grid-template-columns: 1fr; }
}

/* Comfortable tap targets on phones */
@media (max-width: 640px) {
  .footer__col a { padding-block: 8px; }
  /* Nav CTA shortens to "Join" so the island stays compact, not edge-to-edge */
  .nav__cta-rest { display: none; }
}

/* Intentional horizontal scrollers (tab strip) don't chain to the page */
.switcher__tabs { overscroll-behavior-x: contain; }

/* Founder bio: on phones, drop the desktop per-sentence breaks and left-align
   so the paragraph flows cleanly instead of centred + ragged */
@media (max-width: 920px) {
  .founder__text p:not(.eyebrow) { text-align: left; }
  .founder__text p:not(.eyebrow) br { display: none; }
}
