﻿:root {
  --ivory: #f4eadc;
  --ivory-soft: #fbf6ee;
  --cream: #fffaf3;
  --linen: #eadbc8;
  --sand: #d3b996;
  --champagne: #c8a972;
  --taupe: #897463;
  --clay: #705b4c;
  --espresso: #15100c;
  --ink: #26201b;
  --muted: rgba(21, 16, 12, .66);
  --muted-deep: rgba(21, 16, 12, .78);
  --muted-light: rgba(244, 234, 220, .72);
  --line: rgba(21, 16, 12, .11);
  --line-strong: rgba(21, 16, 12, .17);
  --line-light: rgba(244, 234, 220, .15);
  --shadow-soft: 0 22px 70px rgba(54, 40, 27, .10);
  --shadow-deep: 0 38px 120px rgba(54, 40, 27, .18);
  --display: 'Instrument Serif', Georgia, serif;
  --sans: 'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --container: 1180px;
  --header: 76px;
  --ease: cubic-bezier(.22, 1, .36, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--ivory); }
body {
  margin: 0;
  color: var(--espresso);
  overflow-x: hidden;
  background:
    radial-gradient(circle at 7% 4%, rgba(200, 169, 114, .22), transparent 24rem),
    radial-gradient(circle at 92% 2%, rgba(211, 185, 150, .35), transparent 30rem),
    linear-gradient(180deg, var(--ivory), var(--ivory-soft) 34%, #ebddcb 100%);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body.nav-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img, video { display: block; max-width: 100%; }
button, summary { font: inherit; }
button { cursor: pointer; }
::selection { color: var(--ivory); background: var(--espresso); }

.skip-link {
  position: fixed;
  left: 1rem;
  top: -5rem;
  z-index: 9999;
  padding: .8rem 1rem;
  color: var(--ivory);
  background: var(--espresso);
  border-radius: 999px;
  transition: top .2s ease;
}
.skip-link:focus { top: 1rem; }
.container { width: min(calc(100% - 2rem), var(--container)); margin-inline: auto; }
.section { padding: clamp(5.5rem, 9vw, 9.5rem) 0; }
.kicker, .eyebrow, .mini-kicker {
  margin: 0 0 1rem;
  color: var(--clay);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .18em;
  line-height: 1.2;
  text-transform: uppercase;
}
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { color: inherit; line-height: .98; letter-spacing: -.035em; }
h1, h2 { font-family: var(--display); font-weight: 400; }
h1 { max-width: 930px; margin-bottom: 1.45rem; font-size: clamp(4rem, 7.75vw, 8.35rem); letter-spacing: -.032em; line-height: .99; }
h2 { margin-bottom: 1rem; font-size: clamp(3.05rem, 5.7vw, 6.3rem); }
h3 { margin-bottom: .75rem; font-family: var(--display); font-size: clamp(1.95rem, 2.8vw, 3rem); font-weight: 400; }
p { color: var(--muted); }

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 1000;
  height: var(--header);
  background: rgba(244, 234, 220, .66);
  border-bottom: 1px solid transparent;
  backdrop-filter: blur(18px);
  transition: background .25s ease, border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
.site-header.is-scrolled,
.site-header.menu-active { background: rgba(244, 234, 220, .96); border-color: var(--line); box-shadow: 0 18px 60px rgba(54, 40, 27, .08); }
.nav {
  width: min(calc(100% - 1.4rem), 1380px);
  height: 100%;
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
}
.brand { display: inline-flex; align-items: center; gap: .72rem; font-size: .75rem; font-weight: 900; letter-spacing: .14em; line-height: 1; text-transform: uppercase; }
.brand-text span { display: inline; }
.brand-mark { display: grid; width: 42px; height: 42px; place-items: center; color: var(--ivory); background: var(--espresso); border: 1px solid rgba(200, 169, 114, .4); border-radius: 50%; font-family: var(--display); font-size: 1.1rem; font-weight: 400; letter-spacing: -.02em; }
.nav-menu { display: flex; align-items: center; gap: clamp(1rem, 1.55vw, 1.65rem); }
.nav-menu a { color: rgba(21, 16, 12, .64); font-size: .69rem; font-weight: 900; letter-spacing: .135em; text-transform: uppercase; transition: color .2s ease, background .2s ease, transform .2s ease; }
.nav-menu a:hover, .nav-menu a:focus-visible, .nav-menu a.is-current { color: var(--espresso); }
.nav-menu a.is-current { position: relative; }
.nav-menu a.is-current::after { content: ''; position: absolute; left: 0; right: 0; bottom: -.42rem; height: 1px; background: currentColor; opacity: .45; }
.nav-menu .nav-cta { padding: .86rem 1.05rem; color: var(--ivory); background: #211913; border-radius: 999px; box-shadow: 0 14px 36px rgba(21,16,12,.12); }
.nav-menu .nav-cta:hover { color: var(--ivory); transform: translateY(-1px); background: var(--espresso); }
.nav-toggle { display: none; }

.hero { position: relative; min-height: 100svh; padding: calc(var(--header) + 4.2rem) 0 2.8rem; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: linear-gradient(118deg, transparent 0 53%, rgba(200,169,114,.08) 53% 53.35%, transparent 53.35% 100%); opacity: .55; pointer-events: none; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(4px); pointer-events: none; }
.hero-orb-one { width: 38rem; height: 38rem; right: -18rem; top: 6rem; background: rgba(211,185,150,.24); }
.hero-orb-two { width: 24rem; height: 24rem; left: -12rem; bottom: 3rem; background: rgba(200,169,114,.14); }
.hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1.06fr) minmax(330px, .66fr); gap: clamp(3rem, 7vw, 7rem); align-items: center; min-height: calc(100svh - var(--header) - 8rem); }
.lede, .large-copy { color: var(--muted-deep); font-size: clamp(1.08rem, 1.45vw, 1.32rem); line-height: 1.75; }
.lede { max-width: 760px; margin-bottom: 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .95rem; margin-top: 2.2rem; }
.btn { display: inline-flex; min-height: 56px; align-items: center; justify-content: center; padding: 1rem 1.28rem; border: 1px solid transparent; border-radius: 999px; font-size: .74rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; transition: transform .25s var(--ease), background .25s ease, border-color .25s ease, color .25s ease, box-shadow .25s ease; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { color: var(--ivory); background: var(--espresso); box-shadow: 0 18px 52px rgba(21, 16, 12, .18); }
.btn-primary:hover { background: var(--ink); box-shadow: 0 24px 70px rgba(21,16,12,.22); }
.btn-secondary { color: var(--espresso); background: rgba(255, 250, 243, .74); border-color: rgba(21,16,12,.2); box-shadow: 0 10px 34px rgba(21,16,12,.05); }
.btn-secondary:hover { background: rgba(255, 250, 243, .96); border-color: rgba(21,16,12,.34); }
.btn-light { color: var(--espresso); background: var(--ivory); box-shadow: none; }
.btn-light:hover { background: var(--cream); }
.hero-trust { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.8rem; }
.hero-trust span { padding: .58rem .78rem; color: rgba(21,16,12,.72); background: rgba(255,250,243,.45); border: 1px solid var(--line); border-radius: 999px; font-size: .72rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.hero-proof-card { display: grid; grid-template-columns: auto 1fr; gap: .85rem; align-items: center; max-width: 690px; margin-top: 1.25rem; padding: 1.02rem 1.08rem; background: rgba(21,16,12,.04); border: 1px solid rgba(21,16,12,.1); border-radius: 24px; box-shadow: 0 18px 48px rgba(55,42,30,.06); }
.hero-proof-card strong { color: var(--espresso); font-size: .78rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.hero-proof-card span { color: rgba(21,16,12,.68); font-size: .93rem; line-height: 1.45; }
.hero-visual { justify-self: end; width: min(100%, 510px); }
.visual-frame { position: relative; min-height: 670px; }
.hero-img-main { position: absolute; inset: 0 0 auto auto; width: 83%; aspect-ratio: 4 / 5.55; object-fit: cover; object-position: center; border: 1px solid rgba(21,16,12,.1); border-radius: 999px 999px 42px 42px; box-shadow: var(--shadow-deep); filter: saturate(.9) contrast(1.03); }
.hero-img-secondary { position: absolute; left: 0; bottom: 4.8rem; width: 45%; aspect-ratio: 3 / 4.08; object-fit: cover; object-position: center top; border: .55rem solid var(--ivory); border-radius: 30px; box-shadow: 0 30px 84px rgba(54,40,27,.16); filter: saturate(.88) contrast(1.02); }
.glass { background: rgba(255, 250, 243, .82); border: 1px solid rgba(21, 16, 12, .1); box-shadow: 0 24px 70px rgba(54, 40, 27, .12); backdrop-filter: blur(16px); }
.availability-card { position: absolute; right: .8rem; bottom: .2rem; max-width: 322px; padding: 1.05rem 1.1rem; border-radius: 24px; }
.availability-card p, .method-badge p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.45; }
.credibility-strip { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; margin-top: 2.15rem; overflow: hidden; background: var(--line); border: 1px solid var(--line); border-radius: 30px; }
.credibility-strip div { display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: start; padding: 1.25rem 1.35rem; background: rgba(255, 250, 243, .58); }
.credibility-strip strong { color: var(--clay); font-size: .74rem; font-weight: 900; letter-spacing: .15em; }
.credibility-strip span { color: var(--muted-deep); font-size: .92rem; line-height: 1.5; }

.signal-strip { position: relative; margin-top: -1px; padding: .88rem 0; overflow: hidden; color: var(--ivory); background: var(--espresso); border-block: 1px solid rgba(244,234,220,.12); }
.signal-track { display: flex; flex-wrap: wrap; gap: .65rem; justify-content: center; }
.signal-track span { padding: .55rem .82rem; color: rgba(244,234,220,.74); background: rgba(244,234,220,.055); border: 1px solid rgba(244,234,220,.12); border-radius: 999px; font-size: .7rem; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }

.split-grid { display: grid; grid-template-columns: .62fr 1fr; gap: clamp(2.5rem, 7vw, 6rem); align-items: start; }
.section-sticky { position: sticky; top: calc(var(--header) + 2rem); }
.standard-content { padding-top: .45rem; }
.large-copy { max-width: 780px; margin-bottom: 2rem; }
.principle-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; overflow: hidden; background: var(--line); border: 1px solid var(--line); border-radius: 32px; }
.principle-grid article { padding: clamp(1.25rem, 2.5vw, 1.85rem); background: rgba(255,250,243,.58); }
.principle-grid span, .offer-topline span, .timeline span, .result-list span { display: block; margin: 0 0 1rem; color: var(--clay); font-size: .72rem; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.principle-grid h3 { font-size: clamp(1.85rem, 2.5vw, 2.45rem); }
.principle-grid p, .offer-card p, .section-head p, .faq-intro { color: var(--muted); }
.standard-note { margin-top: 1rem; padding: 1.1rem 1.25rem; background: rgba(255,250,243,.55); border: 1px solid var(--line); border-radius: 24px; }
.standard-note p { margin: 0; color: rgba(21,16,12,.72); }
.standard-note strong { color: var(--espresso); }

.diagnosis { padding-top: 0; }
.diagnosis-panel { display: grid; grid-template-columns: .85fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; padding: clamp(1.5rem, 4vw, 3rem); background: rgba(255,250,243,.48); border: 1px solid var(--line); border-radius: 40px; box-shadow: var(--shadow-soft); }
.diagnosis-list { display: grid; gap: 1px; overflow: hidden; background: var(--line); border: 1px solid var(--line); border-radius: 28px; }
.diagnosis-list p { margin: 0; padding: 1.25rem 1.35rem; color: rgba(21,16,12,.75); background: rgba(244,234,220,.7); font-size: clamp(1rem, 1.3vw, 1.12rem); }

.method { color: var(--ivory); background: linear-gradient(180deg, var(--espresso), #0b0806); }
.method .kicker, .application .kicker { color: var(--sand); }
.method-grid { display: grid; grid-template-columns: .76fr 1fr; gap: clamp(3rem, 7vw, 6rem); align-items: center; }
.method-media { position: relative; }
.method-media img { width: 100%; aspect-ratio: 4 / 5.2; object-fit: cover; object-position: center; border: 1px solid var(--line-light); border-radius: 40px; box-shadow: 0 36px 110px rgba(0,0,0,.36); filter: saturate(.84) contrast(1.03); }
.method-badge { position: absolute; left: 1rem; right: 1rem; bottom: 1rem; padding: 1rem; border-radius: 22px; }
.method-badge span { display: block; margin-bottom: .3rem; color: var(--espresso); font-size: .72rem; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.method-copy p:not(.kicker) { max-width: 680px; color: var(--muted-light); font-size: 1.05rem; line-height: 1.78; }
.method-pillars { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 1.25rem; }
.method-pillars span { padding: .58rem .78rem; color: var(--ivory); background: rgba(244,234,220,.08); border: 1px solid rgba(244,234,220,.14); border-radius: 999px; font-size: .72rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.timeline { display: grid; gap: 1px; margin-top: 2rem; overflow: hidden; background: var(--line-light); border: 1px solid var(--line-light); border-radius: 30px; }
.timeline article { padding: clamp(1.25rem, 2.6vw, 1.9rem); background: rgba(244, 234, 220, .055); }
.timeline h3 { margin-bottom: .48rem; color: var(--ivory); font-size: clamp(1.65rem, 2.35vw, 2.2rem); }
.timeline span { color: var(--sand); margin-bottom: .72rem; }
.timeline p { margin: 0; color: var(--muted-light); }

.section-head { max-width: 930px; margin-bottom: 2.25rem; }
.offer-grid { display: grid; grid-template-columns: 1.16fr repeat(2, 1fr); gap: 1rem; }
.offer-card { display: flex; min-height: 100%; flex-direction: column; padding: clamp(1.35rem, 2.7vw, 2rem); background: rgba(255,250,243,.5); border: 1px solid var(--line); border-radius: 34px; box-shadow: var(--shadow-soft); transition: transform .25s var(--ease), box-shadow .25s ease; }
.offer-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-deep); }
.offer-card.featured { color: var(--ivory); background: var(--espresso); border-color: rgba(200,169,114,.3); }
.offer-card.featured p, .offer-card.featured li { color: var(--muted-light); }
.offer-card.featured .offer-topline span, .offer-card.featured .offer-topline small { color: var(--sand); }
.offer-topline { display: flex; justify-content: space-between; align-items: center; margin-bottom: .9rem; }
.offer-topline span { margin: 0; }
.offer-topline small { color: var(--clay); font-size: .72rem; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
ul { margin: 1.2rem 0 1.5rem; padding: 0; list-style: none; }
li { position: relative; margin: .68rem 0; padding-left: 1.2rem; color: var(--muted); }
li::before { content: ''; position: absolute; left: 0; top: .72em; width: 5px; height: 5px; background: var(--champagne); border-radius: 50%; }
.offer-card a { display: inline-flex; width: fit-content; margin-top: auto; color: inherit; font-size: .72rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; border-bottom: 1px solid currentColor; }

.outcomes { padding-top: 0; }
.outcomes-grid { display: grid; grid-template-columns: .82fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.outcomes-copy { padding: clamp(1.45rem, 3vw, 2.35rem); background: rgba(255,250,243,.44); border: 1px solid var(--line); border-radius: 36px; box-shadow: var(--shadow-soft); }
.outcomes-copy p:not(.kicker) { color: var(--muted); }
.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; margin-top: 1.55rem; overflow: hidden; background: var(--line); border: 1px solid var(--line); border-radius: 24px; }
.stats-grid div { padding: 1rem; background: rgba(244,234,220,.68); }
.stats-grid strong { display: block; margin-bottom: .2rem; font-family: var(--display); font-size: clamp(1.85rem, 3vw, 2.6rem); font-weight: 400; line-height: 1; letter-spacing: -.04em; }
.stats-grid span { color: var(--muted); font-size: .68rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.result-list { display: grid; gap: 1px; overflow: hidden; background: var(--line); border: 1px solid var(--line); border-radius: 32px; }
.result-list article { display: grid; grid-template-columns: auto 1fr; gap: 1rem; padding: 1.25rem 1.4rem; background: rgba(255,250,243,.6); }
.result-list span { margin: .25rem 0 0; }
.result-list p { margin: 0; color: rgba(21,16,12,.76); font-size: clamp(1.05rem, 1.55vw, 1.25rem); }
.media-showcase { display: grid; grid-template-columns: .86fr 1.16fr .86fr; gap: .9rem; margin-top: 1rem; align-items: stretch; }
.media-showcase img, .video-tile { width: 100%; min-height: clamp(270px, 36vw, 500px); border: 1px solid rgba(21,16,12,.1); border-radius: 32px; box-shadow: 0 20px 70px rgba(54,40,27,.1); overflow: hidden; }
.media-showcase img { height: 100%; object-fit: cover; filter: saturate(.88) contrast(1.02); }
.video-tile { position: relative; background: var(--espresso); }
.video-tile video { width: 100%; height: 100%; min-height: inherit; object-fit: cover; opacity: .9; }
.video-control { position: absolute; left: 1rem; bottom: 1rem; padding: .82rem 1rem; color: var(--espresso); background: rgba(255,250,243,.86); border: 1px solid rgba(21,16,12,.12); border-radius: 999px; font-size: .72rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; backdrop-filter: blur(14px); }

.experience { position: relative; overflow: hidden; background: linear-gradient(135deg, rgba(255,250,243,.58), rgba(211,185,150,.25)); border-top: 1px solid var(--line); }
.experience::before { content: ''; position: absolute; inset: 10% auto auto -8rem; width: 24rem; height: 24rem; background: rgba(200,169,114,.18); border-radius: 50%; filter: blur(16px); pointer-events: none; }
.experience-grid { position: relative; display: grid; grid-template-columns: .72fr 1fr; gap: clamp(2.5rem, 6vw, 5rem); align-items: start; }
.experience-copy { position: sticky; top: calc(var(--header) + 2rem); }
.experience-copy p:not(.kicker) { max-width: 620px; color: var(--muted-deep); font-size: clamp(1.03rem, 1.35vw, 1.22rem); line-height: 1.75; }
.experience-stack { display: grid; gap: .85rem; }
.experience-stack article { padding: clamp(1.25rem, 2.6vw, 1.9rem); background: rgba(255,250,243,.62); border: 1px solid var(--line); border-radius: 30px; box-shadow: var(--shadow-soft); }
.experience-stack span { display: block; margin-bottom: .7rem; color: var(--clay); font-size: .72rem; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.experience-stack h3 { margin-bottom: .45rem; font-size: clamp(1.8rem, 2.6vw, 2.55rem); }
.experience-stack p { margin: 0; color: var(--muted); }

.deja { background: linear-gradient(180deg, rgba(255,250,243,.28), rgba(211,185,150,.26)); border-block: 1px solid var(--line); }
.deja-grid { display: grid; grid-template-columns: .64fr 1fr; gap: clamp(3rem, 7vw, 6rem); align-items: center; }
.portrait { margin: 0; }
.portrait img { width: 100%; aspect-ratio: 4 / 4.85; object-fit: cover; object-position: center; border: 1px solid rgba(21,16,12,.1); border-radius: 42px; box-shadow: var(--shadow-deep); filter: saturate(.9) contrast(1.03); }
.portrait figcaption { margin-top: .85rem; color: var(--muted); font-size: .72rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.deja-copy p:not(.kicker) { max-width: 730px; color: var(--muted); font-size: 1.04rem; line-height: 1.78; }
.specialisms { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 1.4rem; }
.specialisms span { padding: .64rem .85rem; color: var(--espresso); background: rgba(211,185,150,.44); border: 1px solid rgba(21,16,12,.08); border-radius: 999px; font-size: .75rem; font-weight: 900; }

.application { color: var(--ivory); background: linear-gradient(180deg, var(--espresso), #0b0806); }
.application-panel { display: grid; grid-template-columns: .82fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; padding: clamp(1.7rem, 4vw, 3.25rem); background: rgba(244,234,220,.06); border: 1px solid var(--line-light); border-radius: 42px; box-shadow: 0 34px 110px rgba(0,0,0,.26); }
.application-copy p:not(.kicker) { max-width: 610px; color: var(--muted-light); }
.application-steps { display: grid; gap: 1px; margin: 0; padding: 0; overflow: hidden; background: var(--line-light); border: 1px solid var(--line-light); border-radius: 30px; list-style: none; }
.application-steps li { margin: 0; padding: 1.25rem 1.35rem; background: rgba(244,234,220,.055); }
.application-steps li::before { display: none; }
.application-steps span { display: block; margin-bottom: .55rem; color: var(--sand); font-size: .72rem; font-weight: 900; letter-spacing: .14em; }
.application-steps h3 { margin-bottom: .35rem; color: var(--ivory); font-size: clamp(1.55rem, 2.1vw, 2.05rem); }
.application-steps p { margin: 0; color: var(--muted-light); }

.faq-grid { display: grid; grid-template-columns: .58fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.faq-list { display: grid; gap: .75rem; }
details { background: rgba(255,250,243,.48); border: 1px solid var(--line); border-radius: 22px; overflow: hidden; }
summary { position: relative; cursor: pointer; padding: 1.08rem 3rem 1.08rem 1.25rem; color: var(--espresso); font-weight: 900; letter-spacing: -.01em; list-style: none; }
summary::after { content: '+'; position: absolute; right: 1.2rem; top: 50%; transform: translateY(-50%); color: var(--clay); font-size: 1.25rem; line-height: 1; }
details[open] summary::after { content: '−'; }
summary::-webkit-details-marker { display: none; }
details p { margin: 0; padding: 0 1.25rem 1.2rem; color: var(--muted); }

.site-footer { padding: 2.4rem 0 1.3rem; color: rgba(244,234,220,.66); background: #0b0806; }
.footer-grid { display: grid; grid-template-columns: 1fr auto auto; gap: 1.5rem; align-items: center; }
.site-footer .brand-mark { color: var(--espresso); background: var(--ivory); }
.site-footer p { max-width: 420px; margin: .9rem 0 0; color: rgba(244,234,220,.5); font-size: .92rem; }
.site-footer nav, .footer-contact { display: flex; flex-wrap: wrap; gap: 1rem; }
.site-footer a { font-size: .72rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.copyright { margin: 1.7rem 0 0; color: rgba(244,234,220,.42); text-align: center; font-size: .82rem; }
.mobile-cta { display: none; }

.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1120px) {
  .hero-grid, .split-grid, .diagnosis-panel, .method-grid, .outcomes-grid, .experience-grid, .deja-grid, .application-panel, .faq-grid { grid-template-columns: 1fr; }
  .section-sticky, .experience-copy { position: static; }
  .hero-visual { justify-self: start; max-width: 590px; }
  .principle-grid, .offer-grid { grid-template-columns: 1fr; }
  .outcomes { padding-top: clamp(5.5rem, 9vw, 9.5rem); }
}

@media (max-width: 900px) {
  :root { --header: 70px; }
  .brand { font-size: .7rem; }
  .brand-text span { display: none; }
  .nav-toggle { position: relative; z-index: 1002; display: grid; gap: 6px; width: 44px; height: 44px; place-content: center; color: var(--espresso); background: rgba(255,250,243,.56); border: 1px solid var(--line); border-radius: 50%; }
  .nav-toggle span { width: 18px; height: 1.5px; background: currentColor; transition: transform .22s ease; }
  .nav-toggle.is-active span:first-child { transform: translateY(3.75px) rotate(45deg); }
  .nav-toggle.is-active span:last-child { transform: translateY(-3.75px) rotate(-45deg); }
  .nav-menu { position: fixed; inset: 0; z-index: 1001; flex-direction: column; align-items: flex-start; justify-content: center; gap: 1.2rem; padding: 6rem 1.25rem 2rem; background: rgba(244,234,220,.98); opacity: 0; pointer-events: none; transform: translateY(-12px); transition: opacity .25s ease, transform .25s ease; }
  .nav-menu.is-open { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .nav-menu a { color: var(--espresso); font-size: 1rem; }
  .nav-menu .nav-cta { width: 100%; justify-content: center; text-align: center; }
  .credibility-strip, .stats-grid, .footer-grid, .media-showcase { grid-template-columns: 1fr; }
  .hero-proof-card { grid-template-columns: 1fr; }
  .media-showcase img, .video-tile { min-height: auto; height: auto; }
  .video-tile video { min-height: 360px; }
}

@media (max-width: 640px) {
  body { font-size: 15px; }
  .container { width: min(calc(100% - 1.25rem), var(--container)); }
  .section { padding: 4.5rem 0; }
  .hero { min-height: auto; padding: calc(var(--header) + 2.35rem) 0 3.35rem; }
  .hero-grid { min-height: auto; gap: 2.15rem; }
  h1 { max-width: 100%; font-size: clamp(2.55rem, 11.5vw, 4rem); line-height: 1.05; letter-spacing: -.018em; overflow-wrap: normal; }
  h2 { max-width: 100%; font-size: clamp(2.35rem, 10.5vw, 3.75rem); line-height: 1.02; letter-spacing: -.025em; }
  .eyebrow, .kicker { max-width: 100%; font-size: .65rem; letter-spacing: .13em; overflow-wrap: anywhere; }
  .lede { max-width: 100%; font-size: 1.02rem; line-height: 1.68; }
  .hero-actions { display: grid; gap: .72rem; }
  .btn { width: 100%; min-height: 54px; padding-inline: 1rem; }
  .hero-proof-card { padding: .9rem; }
  .hero-trust span { font-size: .66rem; letter-spacing: .08em; }
  .visual-frame { min-height: 500px; }
  .hero-img-main { width: 88%; }
  .hero-img-secondary { width: 43%; bottom: 4.55rem; border-width: .38rem; border-radius: 24px; }
  .availability-card { right: .45rem; left: .45rem; bottom: 0; max-width: none; }
  .credibility-strip { margin-top: 1.2rem; border-radius: 24px; }
  .credibility-strip div { grid-template-columns: 1fr; gap: .35rem; padding: 1.05rem; }
  .principle-grid, .timeline, .result-list, .application-steps, .diagnosis-list { border-radius: 24px; }
  .offer-card, .outcomes-copy, .diagnosis-panel, .application-panel, .experience-stack article { border-radius: 27px; }
  .portrait img, .method-media img, .media-showcase img, .video-tile { border-radius: 30px; }
  .result-list article { grid-template-columns: 1fr; gap: .2rem; }
  .video-tile video { min-height: 320px; }
  .site-footer nav, .footer-contact { flex-direction: column; }
  .mobile-cta { position: fixed; left: .65rem; right: .65rem; bottom: max(.65rem, env(safe-area-inset-bottom)); z-index: 920; display: flex; min-height: 58px; align-items: center; justify-content: center; color: var(--ivory); background: var(--espresso); border: 1px solid rgba(244,234,220,.18); border-radius: 999px; box-shadow: 0 18px 44px rgba(0,0,0,.25); font-size: .75rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
  .site-footer { padding-bottom: 5.5rem; }
}

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

/* Mobile containment hardening - 2026-05-30 review */
html, body { max-width: 100%; overflow-x: hidden; }
.container, .hero-grid, .hero-copy, .hero-visual { min-width: 0; max-width: 100%; }
.hero-copy > *, .standard-content > *, .section-sticky > * { max-width: 100%; }
.btn { max-width: 100%; white-space: normal; text-align: center; }

@media (max-width: 640px) {
  .nav { width: calc(100% - 1rem); }
  .hero { padding-top: calc(var(--header) + 1.7rem); }
  .hero-grid { width: 100%; overflow: hidden; }
  .hero-copy { width: 100%; overflow: hidden; }
  h1 {
    max-width: 100%;
    font-size: clamp(2.15rem, 9.4vw, 3.25rem);
    line-height: 1.08;
    letter-spacing: -.012em;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: none;
  }
  h2 {
    font-size: clamp(2.1rem, 9.2vw, 3.15rem);
    line-height: 1.06;
  }
  .eyebrow, .kicker {
    font-size: .61rem;
    line-height: 1.35;
    letter-spacing: .105em;
    white-space: normal;
    overflow-wrap: break-word;
  }
  .lede {
    font-size: .98rem;
    line-height: 1.62;
    overflow-wrap: break-word;
  }
  .hero-actions,
  .hero-trust,
  .hero-proof-card { max-width: 100%; }
  .btn {
    width: 100%;
    min-width: 0;
    padding: .95rem .8rem;
    font-size: .68rem;
    letter-spacing: .09em;
    overflow-wrap: break-word;
  }
  .mobile-cta {
    left: .7rem;
    right: .7rem;
    width: auto;
    max-width: calc(100vw - 1.4rem);
  }
}
@media (max-width: 640px) {
  .hero-orb { display: none; }
  .hero::before { opacity: .28; }
}
