:root {
  --night: #06102A;
  --green: #12306A;
  --cobalt: #0A3F96;
  --cyan: #12A8D8;
  --moon: #EEF5FA;
  --black: #111111;
  --ivory: #F7F4EE;
  --gold: #D0AD64;
  --gold-soft: #E6CF97;
  --muted: #A9B8C6;
  --ink-muted: #586775;
  --line: rgba(208, 173, 100, .28);
  --dark-line: rgba(247, 245, 242, .15);
  --serif: "Bodoni Moda", Didot, "Times New Roman", serif;
  --sans: "Manrope", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--black);
  background:
    radial-gradient(circle at 88% 4%, rgba(18, 168, 216, .14), transparent 28rem),
    var(--ivory);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.75;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 20;
  pointer-events: none;
  opacity: .045;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23grain)'/%3E%3C/svg%3E");
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
h1, h2, h3, p { margin-top: 0; }
h1, h2 {
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: 0;
  line-height: .98;
}
h1 { max-width: 900px; font-size: clamp(3.15rem, 5.25vw, 5.85rem); }
h2 { font-size: clamp(2.25rem, 3.9vw, 4.55rem); }
h3 { font-size: 1.25rem; line-height: 1.35; }
button, input, select, textarea { font: inherit; }

.section { padding: 8.5rem max(5vw, calc((100vw - 1280px) / 2)); }
.section-heading { max-width: 760px; margin-bottom: 4rem; }
.section-heading.centered { margin-right: auto; margin-left: auto; text-align: center; }
.section-heading p:not(.eyebrow) { color: var(--ink-muted); }
.eyebrow {
  margin-bottom: 1.3rem;
  color: var(--gold);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .18em;
  line-height: 1.4;
  text-transform: uppercase;
}
.eyebrow::before {
  content: "";
  display: inline-block;
  width: 36px;
  height: 1px;
  margin: 0 12px 4px 0;
  background: currentColor;
}
.centered .eyebrow::before { display: none; }
.eyebrow.light { color: #E6CB93; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  min-height: 56px;
  padding: .95rem 1.45rem;
  border: 1px solid var(--gold);
  border-radius: 2px;
  color: #071126;
  background: linear-gradient(135deg, #B98E3F, #E6CF97 46%, #B68B3C);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .12em;
  line-height: 1.2;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.button:hover { transform: translateY(-2px); color: var(--gold-soft); background: transparent; }
.button span { font-size: 1rem; transition: transform .25s ease; }
.button:hover span { transform: translateX(5px); }
.button-ghost { color: var(--ivory); background: transparent; border-color: rgba(247, 245, 242, .44); }
.button-ghost:hover { color: var(--night); background: var(--ivory); border-color: var(--ivory); }
.button-light { color: var(--night); background: var(--moon); border-color: var(--moon); }
.button-light:hover { color: var(--ivory); background: transparent; }
.button-small { min-height: 42px; padding: .7rem 1rem; }
.menu-toggle {
  display: none;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  padding: 0;
  color: var(--ivory);
  background: rgba(247, 245, 242, .05);
  border: 1px solid rgba(247, 245, 242, .24);
  border-radius: 50%;
  cursor: pointer;
}
.menu-toggle span {
  display: block;
  width: 16px;
  height: 1px;
  background: currentColor;
}

.site-header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1.4rem 4vw;
  color: var(--ivory);
  border-bottom: 1px solid rgba(247, 245, 242, .13);
}
.brand { display: inline-flex; align-items: center; line-height: 1; }
.brand img { display: block; width: 180px; height: auto; }
.site-header nav { display: flex; gap: 2rem; font-size: .66rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.site-header nav a { opacity: .76; transition: opacity .2s ease, color .2s ease; }
.site-header nav a:hover { color: var(--gold); opacity: 1; }

.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(480px, .98fr);
  min-height: 100svh;
  overflow: hidden;
  color: var(--ivory);
  background:
    radial-gradient(circle at 18% 78%, rgba(20, 66, 101, .4), transparent 34rem),
    linear-gradient(120deg, #06111D 0%, #0A2034 58%, #071521 100%);
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 52% 14%, rgba(238, 245, 250, .1), transparent 20rem),
    linear-gradient(100deg, transparent 0 55%, rgba(18, 168, 216, .08) 56%, transparent 67%);
}
.hero::after {
  content: none;
}
.hero-copy {
  position: relative;
  z-index: 2;
  align-self: center;
  padding: 9rem 5vw 7rem;
}
.hero-copy h1 {
  max-width: 780px;
  font-size: clamp(2.8rem, 3.3vw, 3.9rem);
  line-height: 1.04;
}
.hero-emphasis {
  display: inline-block;
  color: var(--gold-soft);
  font-weight: 600;
  letter-spacing: .02em;
}
.lunar-emblem {
  width: clamp(92px, 11vw, 148px);
  margin-bottom: 1.6rem;
  filter: drop-shadow(0 0 34px rgba(174, 217, 238, .22));
}
.lunar-emblem svg { width: 100%; height: auto; overflow: visible; }
.lunar-emblem circle {
  fill: rgba(238, 245, 250, .78);
  stroke: rgba(230, 207, 151, .64);
  stroke-width: 1.4;
}
.lunar-emblem path {
  fill: none;
  stroke: rgba(151, 122, 65, .82);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.hero-lead { max-width: 650px; color: #D7DDDE; font-size: 1.05rem; line-height: 1.8; }
.hero-lead-mobile,
.mobile-benefits { display: none; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2.2rem; }
.hero-visual {
  position: relative;
  min-height: 100svh;
  margin-left: -2vw;
  overflow: hidden;
}
.hero-backdrop {
  position: absolute;
  inset: 0;
  background: #07131F url("assets/new-hero-2.png") center bottom / contain no-repeat;
  filter: none;
  transform: none;
}
.hero-backdrop::after {
  content: none;
}
.hero-person {
  position: absolute;
  right: clamp(-5.5rem, -4vw, -2rem);
  bottom: -7vh;
  z-index: 1;
  width: min(63vw, 830px);
  max-width: none;
  height: auto;
  filter: drop-shadow(-34px 26px 48px rgba(3, 8, 23, .58)) saturate(.96) contrast(1.03);
}
.hero-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(90deg, #071521 0%, rgba(7, 21, 33, .42) 7%, transparent 18%);
}
.portrait-card {
  position: absolute;
  right: 3vw;
  bottom: 8vh;
  z-index: 3;
  max-width: 270px;
  padding: 1.4rem;
  color: var(--ivory);
  background: rgba(6, 16, 42, .62);
  border: 1px solid rgba(230, 207, 151, .54);
  backdrop-filter: blur(14px);
}
.portrait-card span { color: var(--gold); font-size: .64rem; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.portrait-card p { margin: .7rem 0 0; font-family: var(--serif); font-size: 1.25rem; line-height: 1.25; }
.scroll-hint {
  position: absolute;
  left: 5vw;
  bottom: 2.2rem;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: .85rem;
  color: rgba(247, 245, 242, .72);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.scroll-hint span { width: 42px; height: 1px; background: var(--gold); }

.problem {
  background:
    radial-gradient(circle at 8% 8%, rgba(18, 168, 216, .08), transparent 24rem),
    linear-gradient(180deg, #FBF8F2, #EEF5FA);
}
.signal-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
}
.signal-card {
  min-height: 170px;
  padding: 1.25rem;
  background:
    linear-gradient(180deg, rgba(255, 253, 250, .88), rgba(238, 245, 250, .68)),
    rgba(255, 255, 255, .68);
  border: 1px solid rgba(17, 17, 17, .09);
  box-shadow: 0 18px 42px rgba(6, 16, 42, .045);
}
.signal-card span,
.pillar-card span,
.step-card span,
.program-card span {
  color: var(--gold);
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.signal-card h3 {
  margin: 1.8rem 0 .55rem;
  font-family: var(--serif);
  font-size: 1.28rem;
  font-weight: 500;
}
.signal-card p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .82rem;
  line-height: 1.55;
}

.transformation {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 7vw;
  color: var(--ivory);
  background:
    radial-gradient(circle at 20% 15%, rgba(18, 168, 216, .24), transparent 26rem),
    linear-gradient(140deg, rgba(7, 38, 94, .96), rgba(6, 16, 42, .98)),
    var(--green);
}
.sticky-copy { position: sticky; top: 4rem; align-self: start; }
.sticky-copy p:not(.eyebrow) { max-width: 520px; color: #D6DBD6; }
.benefit-list { border-top: 1px solid var(--dark-line); }
.benefit-row {
  display: grid;
  grid-template-columns: minmax(190px, .55fr) 1fr;
  gap: 2rem;
  padding: 1.65rem 0;
  border-bottom: 1px solid var(--dark-line);
}
.benefit-row strong { font-family: var(--serif); font-size: 1.36rem; font-weight: 500; line-height: 1.2; }
.benefit-row span { color: #C7CECC; font-size: .9rem; }

.method {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 7vw;
  background:
    linear-gradient(90deg, rgba(238, 245, 250, .72), rgba(255, 253, 250, .9)),
    #fffdfa;
}
.method-intro p:not(.eyebrow) { max-width: 560px; color: var(--ink-muted); }
.pillar-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.pillar-card {
  min-height: 240px;
  padding: 1.5rem;
  color: var(--ivory);
  background:
    radial-gradient(circle at 78% 8%, rgba(18, 168, 216, .15), transparent 12rem),
    var(--night);
  border: 1px solid rgba(200, 167, 106, .35);
}
.pillar-card:nth-child(2), .pillar-card:nth-child(4) {
  background:
    radial-gradient(circle at 20% 20%, rgba(18, 168, 216, .2), transparent 12rem),
    var(--green);
}
.pillar-card:nth-child(5) { grid-column: span 2; min-height: 190px; }
.pillar-card h3 { margin: 3rem 0 .7rem; font-family: var(--serif); font-size: 1.48rem; font-weight: 500; }
.pillar-card p { margin: 0; color: #CDD4D2; font-size: .86rem; }

.steps {
  background:
    radial-gradient(circle at 90% 16%, rgba(18, 168, 216, .08), transparent 24rem),
    var(--ivory);
}
.step-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.step-card {
  min-height: 260px;
  padding: 1.7rem;
  background: #fffdfa;
  border: 1px solid rgba(17, 17, 17, .11);
}
.step-card h3 { margin: 3.5rem 0 .8rem; font-family: var(--serif); font-size: 1.55rem; font-weight: 500; }
.step-card p { color: var(--ink-muted); }

.programs {
  color: var(--ivory);
  background:
    radial-gradient(circle at 50% 0, rgba(18, 168, 216, .22), transparent 30rem),
    linear-gradient(rgba(6, 16, 42, .95), rgba(5, 11, 28, .98)),
    var(--night);
}
.programs .section-heading p:not(.eyebrow) { color: #C8D0D0; }
.program-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.program-card {
  min-height: 310px;
  padding: 1.6rem;
  border: 1px solid rgba(247, 245, 242, .14);
  background: rgba(247, 245, 242, .035);
}
.program-card.featured { border-color: rgba(200, 167, 106, .72); background: rgba(200, 167, 106, .08); }
.program-card h3 { margin: 5rem 0 1rem; font-family: var(--serif); font-size: 1.72rem; font-weight: 500; }
.program-card p { color: #D0D6D4; }
.center-action { margin-top: 2rem; text-align: center; }

.bio {
  display: grid;
  grid-template-columns: .86fr 1.14fr;
  gap: 7vw;
  align-items: center;
  background:
    linear-gradient(180deg, #fffdfa, #F0F7FA);
}
.bio-visual { position: relative; padding: 0 0 3rem 3rem; }
.bio-visual::before {
  content: "T";
  position: absolute;
  left: -1rem;
  top: -5.8rem;
  z-index: 0;
  color: rgba(208, 173, 100, .14);
  font-family: var(--serif);
  font-size: 22rem;
  line-height: 1;
}
.bio-visual img { position: relative; z-index: 1; width: 100%; max-height: 760px; object-fit: cover; object-position: center 35%; }
.bio-tag {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: 1rem 1.2rem;
  color: var(--night);
  background: linear-gradient(135deg, #B98E3F, #E6CF97, #BD9244);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.bio-copy p:not(.eyebrow) { max-width: 680px; color: var(--ink-muted); }
.credentials { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.8rem; }
.credentials span {
  padding: .55rem .75rem;
  color: var(--green);
  border: 1px solid rgba(18, 52, 47, .22);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.mentor-tribute {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 7vw;
  align-items: start;
  color: var(--ivory);
  background:
    radial-gradient(circle at 12% 28%, rgba(18, 168, 216, .16), transparent 25rem),
    linear-gradient(120deg, #06111D, #0A2742 62%, #071521);
  border-top: 1px solid rgba(230, 207, 151, .25);
  border-bottom: 1px solid rgba(230, 207, 151, .25);
}
.mentor-tribute h2 { max-width: 620px; font-size: clamp(2.4rem, 4vw, 4.6rem); }
.mentor-tribute-story { max-width: 760px; }
.mentor-tribute-story > p { color: #D7DDDE; }
.mentor-tribute strong { color: var(--gold-soft); }
.mentor-tribute blockquote {
  margin: 2rem 0;
  padding: 1.5rem 0 1.5rem 1.6rem;
  border-left: 2px solid var(--gold);
}
.mentor-tribute blockquote p {
  margin: 0 0 .75rem;
  color: var(--ivory);
  font-family: var(--serif);
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  line-height: 1.4;
}
.mentor-tribute cite {
  color: var(--gold-soft);
  font-size: .66rem;
  font-style: normal;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.mentor-tribute .mentor-thanks { margin-bottom: 0; color: var(--ivory); font-weight: 600; }

.outcomes {
  background:
    radial-gradient(circle at 50% 0, rgba(18, 168, 216, .07), transparent 34rem),
    var(--ivory);
}
.outcome-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.outcome-card {
  min-height: 210px;
  padding: 1.4rem;
  background: rgba(255, 253, 250, .78);
  border: 1px solid rgba(17, 17, 17, .1);
}
.outcome-card::before {
  content: "";
  display: block;
  width: 34px;
  height: 2px;
  margin-bottom: 3rem;
  background: var(--gold);
}
.outcome-card h3 { margin-bottom: .7rem; font-family: var(--serif); font-size: 1.36rem; font-weight: 500; }
.outcome-card p { margin: 0; color: var(--ink-muted); font-size: .84rem; }

.faq {
  display: grid;
  grid-template-columns: .72fr 1fr;
  gap: 7vw;
  background:
    linear-gradient(180deg, #fffdfa, #F2F8FB);
}
.faq-list { border-top: 1px solid rgba(17, 17, 17, .12); }
details { border-bottom: 1px solid rgba(17, 17, 17, .12); }
summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.25rem 0;
  font-family: var(--serif);
  font-size: 1.28rem;
  list-style: none;
  cursor: pointer;
}
summary::-webkit-details-marker { display: none; }
summary span { color: var(--gold); font-family: var(--sans); transition: transform .25s ease; }
details[open] summary span { transform: rotate(45deg); }
details p { max-width: 690px; margin: 0; padding: 0 2rem 1.4rem 0; color: var(--ink-muted); font-size: .9rem; }

.contact {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: 7vw;
  color: var(--ivory);
  background:
    radial-gradient(circle at 88% 8%, rgba(18, 168, 216, .22), transparent 28rem),
    linear-gradient(135deg, rgba(6, 16, 42, .98), rgba(8, 52, 118, .92)),
    var(--night);
}
.contact-copy { align-self: start; position: sticky; top: 4rem; }
.contact-copy p:not(.eyebrow) { max-width: 560px; color: #D1D8D6; }
.contact-note {
  max-width: 480px;
  margin-top: 2rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--dark-line);
}
.contact-note strong { display: block; margin-bottom: .4rem; font-family: var(--serif); font-size: 1.34rem; font-weight: 500; }
.contact-note span { color: #C8D0D0; font-size: .9rem; }
.contact-form {
  padding: 2rem;
  color: var(--black);
  background: linear-gradient(180deg, #fffdfa, #F2F8FB);
  border: 1px solid rgba(208, 173, 100, .42);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.contact-form label {
  display: block;
  margin-bottom: 1.15rem;
  color: #2D3032;
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .11em;
  text-transform: uppercase;
}
.contact-form input:not([type="checkbox"]),
.contact-form select,
.contact-form textarea {
  width: 100%;
  margin-top: .45rem;
  padding: .8rem 0;
  color: var(--black);
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(17, 17, 17, .19);
  border-radius: 0;
  outline: none;
  font-size: .93rem;
  letter-spacing: 0;
  text-transform: none;
  transition: border-color .2s ease;
}
.contact-form textarea { resize: vertical; }
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus { border-color: var(--gold); }
.privacy {
  display: flex !important;
  gap: .65rem;
  align-items: flex-start;
  color: var(--ink-muted) !important;
  font-size: .78rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.5;
  text-transform: none !important;
}
.privacy input { margin-top: .25rem; accent-color: var(--green); }
.bot-field { display: none; }
.contact-form .button { width: 100%; }
.form-help { margin: .9rem 0 0; color: var(--ink-muted); font-size: .78rem; text-align: center; }

.thank-you-page {
  min-height: 100svh;
  color: var(--ivory);
  background:
    radial-gradient(circle at 78% 10%, rgba(18, 168, 216, .2), transparent 30rem),
    linear-gradient(135deg, #06102A, #0B3C88 58%, #050B1C);
}
.thank-you-main {
  display: flex;
  min-height: 100svh;
  align-items: center;
  justify-content: center;
  padding: 8rem max(5vw, calc((100vw - 980px) / 2)) 5rem;
}
.thank-you-content {
  max-width: 760px;
  text-align: center;
}
.thank-you-content h1 {
  max-width: none;
  margin-bottom: 1.35rem;
  font-size: clamp(3rem, 6vw, 5.4rem);
}
.thank-you-content p:not(.eyebrow) {
  max-width: 620px;
  margin-right: auto;
  margin-left: auto;
  color: #D7DDDE;
  font-size: 1.05rem;
}
.thank-you-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .9rem;
  margin-top: 2rem;
}

.final-cta {
  padding: 7rem max(5vw, calc((100vw - 980px) / 2));
  color: var(--ivory);
  text-align: center;
  background: var(--green);
  background:
    radial-gradient(circle at 50% 0, rgba(18, 168, 216, .28), transparent 26rem),
    linear-gradient(140deg, #06102A, #0B3C88);
}
.final-cta h2 { max-width: 850px; margin-right: auto; margin-left: auto; }
.final-cta p:not(.eyebrow) { max-width: 640px; margin-right: auto; margin-left: auto; color: #D7DDDA; }

footer {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 2rem;
  align-items: center;
  padding: 2rem 4vw;
  color: #C7CFCE;
  background: #030817;
  font-size: .72rem;
}
footer p { margin: 0; max-width: 740px; }
footer div { display: flex; gap: 1.2rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.mobile-cta { display: none; }

.private-page {
  color: var(--ivory);
  background:
    radial-gradient(circle at 80% 10%, rgba(18, 168, 216, .18), transparent 32rem),
    linear-gradient(135deg, #06102A, #0B3C88 58%, #050B1C);
}
.private-header { position: fixed; background: rgba(3, 8, 23, .52); backdrop-filter: blur(18px); }
.private-label {
  color: var(--gold-soft);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.private-hero {
  min-height: 92svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 9rem max(5vw, calc((100vw - 1120px) / 2)) 6rem;
  background:
    linear-gradient(90deg, rgba(6, 16, 42, .95), rgba(6, 16, 42, .62)),
    url("assets/tania-hero-photographic.webp") 78% center / cover;
}
.private-hero h1 { max-width: 820px; }
.private-hero p:not(.eyebrow) { max-width: 680px; color: #D7DDDE; font-size: 1.04rem; }
.private-intro {
  color: var(--black);
  background:
    radial-gradient(circle at 10% 0, rgba(18, 168, 216, .08), transparent 26rem),
    var(--ivory);
}
.private-programs { padding-top: 7rem; }
.private-detail {
  display: grid;
  grid-template-columns: .75fr 1fr;
  gap: 7vw;
  color: var(--black);
  background:
    linear-gradient(180deg, #fffdfa, #F2F8FB);
}
.private-notes p { color: var(--ink-muted); }
.private-final { background: linear-gradient(140deg, #06102A, #0B3C88); }

.reveal { opacity: 1; transform: none; transition: opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity: 1; transform: none; }
.hero .reveal { opacity: 1; transform: none; }

@media (max-width: 1040px) {
  .site-header nav,
  .site-header > .button { display: none; }
  .menu-toggle { display: inline-flex; }
  .hero {
    display: flex;
    flex-direction: column;
    min-height: auto;
    padding-top: 68px;
    background: var(--night);
  }
  .hero::before { opacity: .42; }
  .hero::after { display: none; }
  .hero-visual {
    order: 1;
    z-index: 1;
    isolation: isolate;
    display: block;
    min-height: 0;
    height: clamp(420px, 58svh, 560px);
    width: 100%;
    margin-left: 0;
    overflow: hidden;
  }
  .hero-backdrop {
    background: url("assets/new-hero-2.png") center 36% / cover;
  }
  .hero-person {
    right: 50%;
    bottom: -5.5rem;
    width: min(116vw, 520px);
    transform: translateX(55%);
    filter: drop-shadow(0 22px 32px rgba(3, 8, 23, .58)) saturate(.96) contrast(1.03);
  }
  .hero-visual::after {
    background:
      linear-gradient(180deg, rgba(6, 16, 42, .24) 0%, rgba(6, 16, 42, .16) 44%, rgba(3, 8, 23, .88) 100%),
      linear-gradient(90deg, rgba(3, 8, 23, .48), transparent 38%, rgba(3, 8, 23, .16));
  }
  .portrait-card { display: none; }
  .hero-copy {
    order: 2;
    z-index: 2;
    min-height: auto;
    margin-top: -6.5rem;
    padding: 6.8rem 1.4rem 5.5rem;
    background: linear-gradient(180deg, rgba(3, 8, 23, 0) 0%, #030817 6.2rem, #06102A 100%);
  }
  .lunar-emblem,
  .hero-copy .eyebrow,
  .hero-actions .button-ghost { display: none; }
  .hero-copy h1 {
    max-width: 12.8em;
    margin-bottom: 1.05rem;
    font-size: clamp(2.15rem, 8.8vw, 3rem);
    font-weight: 600;
    line-height: 1.02;
    text-shadow: 0 2px 14px rgba(3, 8, 23, .68);
  }
  .hero-lead-desktop { display: none; }
  .hero-lead-mobile {
    display: block;
    max-width: 24rem;
    margin-bottom: 0;
    color: #DDE5E5;
    font-size: 1rem;
    line-height: 1.55;
  }
  .hero-actions {
    display: block;
    margin-top: 1.45rem;
  }
  .hero-actions .button {
    width: 100%;
    min-height: 58px;
    padding: 1rem 1.1rem;
  }
  .mobile-benefits {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1rem;
    color: rgba(247, 244, 238, .82);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .14em;
    line-height: 1.4;
    text-transform: uppercase;
  }
  .mobile-benefits span:not(:last-child)::after {
    content: "·";
    margin-left: .55rem;
    color: var(--gold-soft);
  }
  .signal-grid, .outcome-grid { grid-template-columns: repeat(2, 1fr); }
  .transformation, .method, .bio, .mentor-tribute, .faq, .contact { grid-template-columns: 1fr; }
  .sticky-copy, .contact-copy { position: static; }
  .program-grid, .step-grid { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  body { font-size: 15px; }
  h1 { font-size: clamp(2.65rem, 12.5vw, 3.8rem); line-height: 1.02; }
  h2 { font-size: clamp(2.15rem, 10.5vw, 3.2rem); line-height: 1.02; }
  .section { padding: 5.5rem 1.15rem; }
  .site-header {
    position: absolute;
    padding: .9rem 1rem;
    background: rgba(3, 8, 23, .72);
    backdrop-filter: blur(16px);
  }
  .brand img { width: 155px; }
  .hero { padding-top: 64px; }
  .hero-visual { height: clamp(360px, 55svh, 500px); }
  .hero-person {
    right: 50%;
    bottom: -4.8rem;
    width: min(118vw, 500px);
    transform: translateX(56%);
  }
  .hero-copy {
    margin-top: -5rem;
    padding: 5.35rem 1.15rem 5.3rem;
    background: linear-gradient(180deg, rgba(3, 8, 23, 0) 0%, #030817 4.8rem, #06102A 100%);
  }
  .hero-copy h1 {
    max-width: 12.8em;
    font-size: clamp(2.05rem, 8.7vw, 2.85rem);
    font-weight: 600;
    line-height: 1.04;
    text-shadow: 0 2px 14px rgba(3, 8, 23, .72);
  }
  .hero-lead-mobile { font-size: .98rem; }
  .scroll-hint { display: none; }
  .signal-grid, .pillar-grid, .outcome-grid { grid-template-columns: 1fr; }
  .pillar-card:nth-child(5) { grid-column: auto; }
  .signal-card { min-height: auto; padding: 1.15rem; }
  .benefit-row { grid-template-columns: 1fr; gap: .5rem; }
  .bio-visual { padding: 0 0 2.8rem 1rem; }
  .bio-tag { left: 0; right: auto; max-width: calc(100% - 1rem); }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .contact-form { padding: 1.25rem; }
  .thank-you-main {
    align-items: flex-start;
    padding: 7.5rem 1.15rem 4rem;
  }
  .thank-you-content { text-align: left; }
  .thank-you-content h1 { font-size: clamp(2.5rem, 12vw, 3.6rem); }
  .thank-you-actions { justify-content: flex-start; }
  .thank-you-actions .button { width: 100%; }
  footer {
    display: block;
    padding: 2rem 1.15rem 6.5rem;
    text-align: center;
  }
  footer p { margin: 1rem auto; }
  footer div { justify-content: center; flex-wrap: wrap; }
  .private-label { display: none; }
  .private-hero { min-height: 86svh; padding: 7rem 1.15rem 5rem; background-position: 70% center; }
  .private-detail { grid-template-columns: 1fr; }
  .mobile-cta {
    position: fixed;
    right: .75rem;
    bottom: .75rem;
    left: .75rem;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 54px;
    padding: .95rem 1rem;
    color: var(--night);
    background: linear-gradient(135deg, #B98E3F, #E6CF97 48%, #B68B3C);
    border: 1px solid rgba(247, 245, 242, .45);
    box-shadow: 0 18px 40px rgba(0, 0, 0, .32);
    font-size: .68rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    transition: transform .25s ease, opacity .25s ease;
  }
  body.hero-in-view .mobile-cta {
    opacity: 0;
    pointer-events: none;
    transform: translateY(120%);
  }
}

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