@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Manrope:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,500;0,600;1,500&display=swap');

:root {
  --ink: #101010;
  --muted: #687069;
  --paper: #f3f5f1;
  --white: #fff;
  --mint: #a4d8a9;
  --sage: #a9b7a7;
  --sage-soft: #e7ece5;
  --sage-deep: #4f6256;
  --line: rgba(16, 16, 16, .14);
  --shadow: 0 30px 80px rgba(0, 0, 0, .12);
  --serif: "Playfair Display", Georgia, serif;
  --sans: "Manrope", "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 999;
  opacity: .025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, textarea, select { font: inherit; }

.site-header {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  width: min(1240px, calc(100% - 36px));
  height: 74px;
  padding: 0 18px 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 100;
  border: 1px solid rgba(255,255,255,.52);
  background: rgba(247,249,246,.78);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 14px 40px rgba(0,0,0,.08);
  transition: height .35s ease, top .35s ease, background .35s ease;
}
.site-header.scrolled { top: 8px; height: 64px; background: rgba(247,249,246,.94); }
.brand { display:flex; align-items:center; gap:11px; flex-shrink:0; }
.brand img { width:38px; height:38px; object-fit:contain; flex-shrink:0; }
.brand span { font-size:10px; font-weight:600; letter-spacing:.21em; white-space:nowrap; }
.desktop-nav { display: flex; align-items: center; gap: 34px; }
.desktop-nav a { position: relative; font-size: 12px; letter-spacing: .12em; text-transform: uppercase; }
.desktop-nav a::after { content:""; position:absolute; left:0; right:100%; bottom:-7px; height:1px; background:#111; transition:right .3s ease; }
.desktop-nav a:hover::after, .desktop-nav a.active::after { right:0; }
.nav-cta { padding: 13px 19px; background: #111; color: white !important; box-shadow: inset 0 -3px 0 var(--mint); }
.nav-cta::after { display: none; }
.menu-toggle { display:none; border:0; background:none; padding:10px; cursor:pointer; }
.menu-toggle span { display:block; width:25px; height:1px; background:#111; margin:6px 0; transition:.3s; }

.container { width: min(1200px, calc(100% - 48px)); margin-inline: auto; }
.eyebrow { display:flex; align-items:center; gap:11px; margin:0 0 22px; padding-left:14px; border-left:2px solid var(--mint); color:var(--sage-deep); font-size:10px; font-weight:600; letter-spacing:.21em; text-transform:uppercase; }
.eyebrow::after { content:"↘"; font-size:13px; font-weight:400; letter-spacing:0; opacity:.48; transform:translateY(-1px); }
.display { margin:0; font-family:var(--serif); font-weight:500; line-height:.98; letter-spacing:-.045em; }
.display em { font-weight:500; }
.lead { font-size:clamp(18px,2vw,24px); font-weight:300; line-height:1.5; color:#353535; }
.muted { color:var(--muted); }
.button { display:inline-flex; align-items:center; gap:16px; min-height:52px; padding:0 24px; border:1px solid #111; font-size:11px; font-weight:600; letter-spacing:.15em; text-transform:uppercase; transition:.35s ease; }
.button::after { content:"↗"; font-size:15px; transition:transform .3s; }
.button:hover { color:white; background:#111; box-shadow:0 15px 35px rgba(0,0,0,.16); transform:translateY(-2px); }
.button:hover::after { transform:translate(3px,-3px); }
.button.light { color:#fff; border-color:rgba(255,255,255,.5); }
.button.light:hover { color:#111; background:#fff; }

.hero { min-height:100svh; position:relative; display:grid; align-items:end; overflow:hidden; background:#181818; color:white; }
.hero-bg { position:absolute; inset:0; background:url('assets/hero-impact.png') center/cover no-repeat; transform:scale(1.04); animation:heroZoom 12s ease-out forwards; }
.hero-bg::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.48) 42%,rgba(0,0,0,.06) 72%), linear-gradient(0deg,rgba(0,0,0,.5),transparent 50%); }
@keyframes heroZoom { to { transform:scale(1); } }
.hero-content { position:relative; z-index:2; padding:180px 0 84px; }
.hero h1 { max-width:830px; font-size:clamp(60px,9vw,128px); }
.hero h1 em { display:block; color:#cbd5c9; }
.hero-bottom { margin-top:52px; display:grid; grid-template-columns:1fr 1fr; align-items:end; gap:40px; }
.hero-intro { max-width:560px; margin:0; font-size:clamp(17px,1.7vw,22px); font-weight:300; color:rgba(255,255,255,.78); }
.scroll-cue { justify-self:end; display:flex; align-items:center; gap:14px; font-size:10px; letter-spacing:.18em; text-transform:uppercase; }
.scroll-cue i { width:44px; height:44px; border:1px solid rgba(255,255,255,.45); border-radius:50%; display:grid; place-items:center; font-style:normal; animation:float 2s ease-in-out infinite; }
@keyframes float { 50% { transform:translateY(7px); } }

.section { padding:130px 0; }
.section.white { background:#fff; }
.section.dark { background:#111; color:#fff; }
.intro-grid { display:grid; grid-template-columns:.7fr 1.3fr; gap:9vw; align-items:start; }
.intro-grid .display { font-size:clamp(44px,6vw,84px); }
.intro-copy { max-width:660px; }
.text-link { display:inline-block; margin-top:24px; border-bottom:2px solid var(--mint); font-size:11px; font-weight:600; letter-spacing:.15em; text-transform:uppercase; padding-bottom:5px; }
.stats { margin-top:100px; border-top:1px solid var(--line); display:grid; grid-template-columns:repeat(3,1fr); }
.stat { padding:38px 30px 0 0; }
.stat + .stat { border-left:1px solid var(--line); padding-left:40px; }
.stat strong { display:block; font-family:var(--serif); font-size:clamp(48px,6vw,78px); line-height:1; font-weight:500; }
.stat span { display:block; max-width:270px; margin-top:13px; color:var(--muted); font-size:13px; }

.field-notes { position:relative; padding:40px 0 150px; overflow:hidden; background:#fff; }
.field-notes::before { content:""; position:absolute; width:520px; height:520px; right:-180px; top:80px; border-radius:50%; background:rgba(137,157,135,.14); filter:blur(2px); }
.notes-grid { position:relative; min-height:780px; display:grid; grid-template-columns:1.15fr .85fr; gap:8vw; align-items:center; }
.notes-copy { position:relative; z-index:3; max-width:520px; margin-left:8vw; margin-right:-7vw; padding:48px; background:rgba(239,243,237,.86); backdrop-filter:blur(18px); box-shadow:0 28px 70px rgba(42,50,43,.12); }
.notes-copy .display { font-size:clamp(45px,5vw,72px); }
.notes-copy p:not(.eyebrow) { color:var(--muted); }
.notes-images { position:relative; min-height:700px; }
.notes-main, .notes-small { position:absolute; margin:0; overflow:hidden; box-shadow:var(--shadow); }
.notes-main { inset:0 6% 0 4%; }
.notes-small { width:52%; height:38%; left:-28%; bottom:-5%; border:10px solid #fff; }
.notes-main img, .notes-small img { width:100%; height:100%; object-fit:cover; }
.notes-main::after, .notes-small::after, .programme-shot::after, .founder-portrait::after { content:""; position:absolute; inset:0; pointer-events:none; }
.notes-main::after { background:linear-gradient(155deg,rgba(119,91,55,.03),rgba(83,104,77,.19)); }
.notes-small::after { background:rgba(65,78,95,.09); }
.notes-caption { position:absolute; right:-4%; bottom:24px; z-index:2; writing-mode:vertical-rl; font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }

.image-story { display:grid; grid-template-columns:1.05fr .95fr; min-height:750px; background:#111; color:#fff; }
.story-image { min-height:640px; background:url('assets/mentorship.png') center/cover; position:relative; overflow:hidden; }
.story-image::after { content:""; position:absolute; inset:0; box-shadow:inset -60px 0 80px rgba(0,0,0,.18); }
.story-copy { padding:8vw; display:flex; flex-direction:column; justify-content:center; }
.story-copy .display { font-size:clamp(45px,5.5vw,78px); }
.story-copy p { max-width:520px; color:rgba(255,255,255,.68); margin:28px 0; }

.services-list { margin-top:70px; border-top:1px solid var(--line); }
.service-row { position:relative; display:grid; grid-template-columns:80px 1fr 1fr 30px; gap:32px; padding:36px 0; border-bottom:1px solid var(--line); align-items:center; transition:padding .35s ease, background .35s ease; }
.service-row:hover { padding-left:16px; background:linear-gradient(90deg,rgba(164,216,169,.18),transparent 78%); }
.service-row .num { color:var(--muted); font-size:12px; }
.service-row h3 { margin:0; font-family:var(--serif); font-size:clamp(26px,3vw,40px); font-weight:500; }
.service-row p { margin:0; color:var(--muted); font-size:14px; }
.service-row .arrow { font-size:23px; transition:transform .3s; }
.service-row:hover .arrow { transform:translate(5px,-5px); }

.quote-section { position:relative; padding:140px 0; text-align:center; overflow:hidden; }
.quote-section::before { content:""; position:absolute; inset:0; background:url('assets/quote-overlay.webp') center/cover no-repeat; opacity:.72; pointer-events:none; }
.quote-section .container { position:relative; z-index:1; }
.quote-section blockquote { max-width:980px; margin:0 auto; font-family:var(--serif); font-size:clamp(37px,5vw,70px); line-height:1.15; letter-spacing:-.035em; }
.quote-section cite { display:block; margin-top:35px; font-style:normal; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.cta-band { position:relative; padding:100px 0; overflow:hidden; background:#26332b; color:white; }
.cta-band::before { content:"M"; position:absolute; right:-2vw; top:-130px; font-family:var(--serif); font-size:420px; color:rgba(255,255,255,.035); }
.cta-inner { position:relative; display:flex; justify-content:space-between; gap:40px; align-items:end; }
.cta-inner h2 { max-width:760px; font-family:var(--serif); font-size:clamp(48px,7vw,96px); line-height:1; letter-spacing:-.045em; font-weight:500; margin:0; }

.page-hero { position:relative; isolation:isolate; overflow:hidden; padding:220px 0 100px; background:#fff; }
.page-hero .container { position:relative; z-index:1; }
.page-hero-about::before { content:""; position:absolute; z-index:0; inset:0; background-repeat:no-repeat; background-position:right center; background-size:56% auto; opacity:.11; pointer-events:none; }
.page-hero-about::before { background-image:url('assets/diractor.jpg'); }
.page-hero .display { max-width:1000px; font-size:clamp(58px,9vw,120px); }
.page-hero .lead { max-width:720px; margin:42px 0 0 auto; }
.page-line { border-top:1px solid var(--line); margin-top:70px; }
.split { display:grid; grid-template-columns:1fr 1fr; gap:10vw; }
.split h2 { font-family:var(--serif); font-size:clamp(40px,5vw,68px); line-height:1.05; letter-spacing:-.035em; font-weight:500; margin:0; }
.values { margin-top:50px; }
.value { display:grid; grid-template-columns:40px 1fr; gap:28px; padding:26px 0; border-top:1px solid var(--line); }
.value b { font-family:var(--serif); font-size:24px; font-weight:500; }
.value p { margin:7px 0 0; color:var(--muted); }
.founder-gallery { position:relative; min-height:760px; }
.founder-gallery::before { content:""; position:absolute; width:68%; height:72%; left:-24px; bottom:-24px; background:var(--mint); opacity:.55; }
.founder-portrait { position:absolute; margin:0; overflow:hidden; background:var(--sage-soft); box-shadow:var(--shadow); }
.founder-portrait::after { background:linear-gradient(145deg,rgba(196,167,128,.05),transparent 45%,rgba(47,62,52,.1)); }
.founder-portrait img { width:100%; height:100%; object-fit:cover; }
.founder-portrait-main { inset:0 16% 0 0; }
.founder-portrait-secondary { z-index:2; width:46%; height:46%; right:0; bottom:-36px; border:9px solid #fff; }
.founder-gallery-label { position:absolute; z-index:3; top:22px; right:-8px; padding:12px 15px; background:#111; color:#fff; font-size:8px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; writing-mode:vertical-rl; }
.founder-copy { align-self:center; }
.founder-copy .display { font-size:clamp(45px,5vw,70px); }
.founder-copy blockquote { margin:38px 0; padding-left:24px; border-left:1px solid; font-family:var(--serif); font-size:26px; font-style:italic; line-height:1.45; }

.package-list { margin-top:70px; }
.package { display:grid; grid-template-columns:.65fr .5fr 1fr; gap:45px; padding:50px 0; border-top:1px solid var(--line); }
.package:last-child { border-bottom:1px solid var(--line); }
.package h3 { margin:0; font-family:var(--serif); font-size:clamp(36px,4vw,58px); font-weight:500; }
.package .level { font-size:13px; font-weight:500; }
.package ul { list-style:none; padding:0; margin:0; color:var(--muted); }
.package li { padding:6px 0; }
.package li::before { content:"—"; margin-right:12px; color:#111; }
.programmes { counter-reset:programme; }
.programme-visuals { position:relative; display:grid; grid-template-columns:1.25fr .75fr; gap:22px; margin:70px 0 88px; }
.programme-shot { position:relative; min-height:430px; margin:0; overflow:hidden; box-shadow:0 24px 70px rgba(0,0,0,.28); }
.programme-shot.secondary { min-height:350px; margin-top:80px; }
.programme-shot img { width:100%; height:100%; object-fit:cover; transition:transform .9s cubic-bezier(.2,.7,.2,1); }
.programme-shot:hover img { transform:scale(1.025); }
.programme-shot::after { background:linear-gradient(180deg,transparent 45%,rgba(10,10,10,.36)); }
.programme-shot.secondary::after { background:rgba(111,128,96,.12); }
.image-label { position:absolute; z-index:2; left:22px; bottom:18px; color:#fff; font-size:9px; letter-spacing:.19em; text-transform:uppercase; }
.programme { counter-increment:programme; display:grid; grid-template-columns:80px 1fr 1fr; gap:40px; padding:32px 0; border-top:1px solid rgba(255,255,255,.17); }
.programme::before { content:"0" counter(programme); color:rgba(255,255,255,.45); font-size:12px; }
.programme h3 { margin:0; font-family:var(--serif); font-size:30px; font-weight:500; }
.programme p { margin:0; color:rgba(255,255,255,.55); }
.curriculum { display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); border-left:1px solid var(--line); margin-top:60px; }
.module { min-height:230px; padding:30px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); transition:.35s; }
.module:hover { background:#fff; box-shadow:var(--shadow); transform:translateY(-6px); }
.module span { font-size:11px; color:var(--muted); }
.module h3 { margin:50px 0 0; font-family:var(--serif); font-size:25px; font-weight:500; }

.contact-section { padding-top:210px; min-height:90vh; }
.contact-layout { display:grid; grid-template-columns:.8fr 1.2fr; gap:8vw; }
.contact-info h1 { font-family:var(--serif); font-size:clamp(56px,7vw,94px); line-height:1; letter-spacing:-.04em; font-weight:500; margin:0 0 35px; }
.contact-info p { color:var(--muted); max-width:450px; }
.contact-details { margin-top:60px; }
.contact-details a { display:grid; grid-template-columns:72px 1fr; gap:18px; padding:18px 0; border-top:1px solid var(--line); transition:color .25s ease, padding .25s ease; }
.contact-details a:hover { color:var(--sage-deep); padding-left:8px; }
.contact-details span { padding-top:6px; color:var(--muted); font-size:9px; font-weight:600; letter-spacing:.17em; text-transform:uppercase; }
.contact-details strong { font-family:var(--serif); font-size:20px; line-height:1.45; font-weight:500; overflow-wrap:anywhere; }
.contact-form { padding:55px; background:#fff; box-shadow:var(--shadow); }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:25px; }
.field { margin-bottom:28px; }
.field label { display:block; margin-bottom:9px; font-size:10px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; }
.field input, .field select, .field textarea { width:100%; border:0; border-bottom:1px solid #aaa; background:transparent; border-radius:0; padding:10px 0 13px; outline:none; transition:border .3s; }
.field textarea { min-height:120px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus { border-color:#111; }
.form-note { margin-top:18px; color:var(--muted); font-size:12px; }
.map-section { padding:120px 0; background:#fff; }
.map-heading { display:grid; grid-template-columns:1fr 1fr; gap:8vw; align-items:end; margin-bottom:55px; }
.map-heading h2 { max-width:650px; margin:0; font-family:var(--serif); font-size:clamp(42px,5vw,68px); line-height:1.05; letter-spacing:-.035em; font-weight:500; }
.map-heading > p { justify-self:end; margin:0; color:var(--muted); font-size:14px; }
.map-frame { height:520px; padding:10px; background:var(--sage-soft); box-shadow:var(--shadow); }
.map-frame iframe { width:100%; height:100%; display:block; border:0; filter:grayscale(.22) saturate(.82); }

footer { background:#090909; color:#fff; padding:80px 0 30px; }
.footer-top { display:grid; grid-template-columns:1.4fr .6fr .6fr; gap:60px; padding-bottom:70px; }
.footer-mark { filter:invert(1); width:250px; opacity:.92; }
.footer-copy { max-width:390px; color:rgba(255,255,255,.45); font-size:13px; margin-top:25px; }
.footer-col h4 { margin:0 0 20px; color:rgba(255,255,255,.4); font-size:10px; letter-spacing:.17em; text-transform:uppercase; }
.footer-col a { display:block; margin:9px 0; font-size:13px; color:rgba(255,255,255,.75); }
.footer-bottom { display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px 30px; padding-top:25px; border-top:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.35); font-size:11px; }
.footer-bottom a { color:rgba(164,216,169,.82); border-bottom:1px solid rgba(164,216,169,.35); }

.reveal { opacity:0; transform:translateY(30px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.visible { opacity:1; transform:none; }

@media (max-width: 900px) {
  .site-header { top:10px; width:calc(100% - 20px); }
  .brand img { width:31px; height:31px; }
  .brand span { font-size:9px; letter-spacing:.16em; }
  .desktop-nav { position:fixed; top:78px; left:0; right:0; padding:30px; background:rgba(255,255,255,.97); display:flex; flex-direction:column; align-items:flex-start; gap:22px; opacity:0; pointer-events:none; transform:translateY(-15px); transition:.3s; box-shadow:0 30px 50px rgba(0,0,0,.13); }
  .desktop-nav.open { opacity:1; pointer-events:auto; transform:none; }
  .menu-toggle { display:block; }
  .hero-content { padding-bottom:55px; }
  .hero-bottom, .intro-grid, .image-story, .split, .contact-layout { grid-template-columns:1fr; }
  .founder-gallery { width:min(620px, calc(100% - 24px)); min-height:760px; margin-bottom:35px; }
  .scroll-cue { display:none; }
  .section { padding:90px 0; }
  .contact-section { padding-top:160px; }
  .intro-grid { gap:45px; }
  .image-story { min-height:0; }
  .story-image { min-height:540px; }
  .story-copy { padding:70px 30px; }
  .notes-grid { grid-template-columns:.8fr 1.2fr; gap:20px; }
  .notes-copy { margin-left:0; margin-right:-4vw; padding:36px; }
  .notes-small { left:-12%; }
  .programme-visuals { grid-template-columns:1fr; }
  .programme-shot.secondary { min-height:430px; margin-top:0; }
  .service-row { grid-template-columns:45px 1fr 25px; }
  .service-row p { grid-column:2/3; }
  .stats { grid-template-columns:1fr; }
  .stat { padding:30px 0; border-bottom:1px solid var(--line); }
  .stat + .stat { border-left:0; padding-left:0; }
  .cta-inner { align-items:flex-start; flex-direction:column; }
  .package { grid-template-columns:1fr 1fr; }
  .package ul { grid-column:1/-1; }
  .programme { grid-template-columns:50px 1fr; }
  .programme p { grid-column:2; }
  .curriculum { grid-template-columns:repeat(2,1fr); }
  .map-heading { grid-template-columns:1fr; gap:25px; }
  .map-heading > p { justify-self:start; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .footer-brand { grid-column:1/-1; }
}

@media (max-width: 560px) {
  .container { width:calc(100% - 32px); }
  .hero h1 { font-size:58px; }
  .hero-bottom { margin-top:35px; }
  .page-hero { padding:170px 0 75px; }
  .page-hero .display { font-size:55px; }
  .contact-section { padding-top:140px; }
  .page-hero-about::before { background-size:cover; background-position:center; opacity:.07; }
  .founder-gallery { width:calc(100% - 12px); min-height:560px; margin-bottom:22px; }
  .founder-gallery::before { left:-12px; bottom:-12px; }
  .founder-portrait-main { inset:0 12% 30px 0; }
  .founder-portrait-secondary { width:48%; height:44%; bottom:-18px; border-width:6px; }
  .founder-gallery-label { top:14px; right:0; }
  .service-row { grid-template-columns:34px 1fr 20px; gap:12px; }
  .package, .curriculum, .field-row { grid-template-columns:1fr; }
  .field-notes { padding:25px 0 95px; }
  .notes-grid { display:flex; flex-direction:column-reverse; min-height:0; }
  .notes-images { width:100%; min-height:580px; }
  .notes-main { inset:0 0 80px 12%; }
  .notes-small { left:0; bottom:0; width:55%; height:35%; }
  .notes-caption { display:none; }
  .notes-copy { width:calc(100% - 22px); margin:-35px 0 0 auto; }
  .package .level, .package ul { grid-column:auto; }
  .contact-form { padding:32px 22px; }
  .contact-details a { grid-template-columns:60px 1fr; gap:10px; }
  .map-section { padding:80px 0; }
  .map-frame { height:380px; padding:6px; }
  .footer-top { grid-template-columns:1fr; }
  .footer-brand { grid-column:auto; }
  .footer-bottom { flex-direction:column; gap:8px; }
}

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