/* ============================================================
   Guidance Jairos Makani — Statesman Editorial
   ============================================================ */

:root{
  --paper:    #F6F1E7;   /* warm cream */
  --paper-2:  #EFE8DA;
  --ink:      #131210;   /* warm near-black */
  --ink-2:    #1C1A16;
  --muted:    #6A6358;
  --line:     #D8CEBE;

  --green:    #1E7A46;   /* Zimbabwe */
  --gold:     #E2A100;
  --red:      #C0322B;

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 80px);
  --ease: cubic-bezier(.22,1,.36,1);

  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Hanken Grotesk", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,18px);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
section{ position:relative; }

/* ---- Shared type ---- */
.eyebrow{
  font-size:.72rem; letter-spacing:.28em; text-transform:uppercase;
  font-weight:600; color:var(--green); display:inline-block; margin-bottom:1.1rem;
}
h2{
  font-family:var(--font-display);
  font-weight:400; font-optical-sizing:auto;
  font-size:clamp(2rem,4.8vw,3.6rem);
  line-height:1.04; letter-spacing:-.02em;
}
.lead{ font-size:clamp(1.15rem,1.7vw,1.4rem); color:var(--ink-2); }
.section-head{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); margin-bottom:clamp(2.5rem,5vw,4rem); }
.section-head--center{ text-align:center; }
.section-head--center .section-sub{ margin:1.4rem auto 0; }
.section-sub{ max-width:54ch; color:var(--muted); font-size:1.1rem; }

.tricolor{
  display:inline-block; width:34px; height:3px; vertical-align:middle;
  margin-right:.7rem; border-radius:2px;
  background:linear-gradient(90deg,var(--green) 0 33%,var(--gold) 33% 66%,var(--red) 66% 100%);
}
.tricolor--wide{ width:120px; height:4px; margin:0; }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  font-weight:600; font-size:.95rem; letter-spacing:.01em;
  padding:.85rem 1.5rem; border-radius:100px;
  transition:transform .3s var(--ease), background .3s, color .3s, box-shadow .3s;
}
.btn--lg{ padding:1.05rem 2rem; font-size:1.02rem; }
.btn--solid{ background:var(--ink); color:var(--paper); }
.btn--solid:hover{ background:var(--green); transform:translateY(-3px); box-shadow:0 12px 30px -12px rgba(30,122,70,.6); }
.btn--ghost{ border:1.5px solid var(--ink); color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); transform:translateY(-3px); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--pad);
  transition:background .4s, padding .4s, box-shadow .4s;
}
.nav.scrolled{
  background:rgba(246,241,231,.82);
  backdrop-filter:blur(14px);
  padding:.7rem var(--pad);
  box-shadow:0 1px 0 var(--line);
}
.brand{ display:flex; align-items:center; gap:.65rem; font-weight:700; }
.brand__mark{
  width:38px; height:38px; flex:none; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:600; font-size:1rem;
  color:var(--paper); background:var(--ink);
  border-radius:10px; letter-spacing:.02em;
  position:relative; overflow:hidden;
}
.brand__mark::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:4px;
  background:linear-gradient(90deg,var(--green) 0 33%,var(--gold) 33% 66%,var(--red) 66% 100%);
}
.brand__name{ font-size:.98rem; letter-spacing:-.01em; }
.nav__links{ display:flex; align-items:center; gap:2rem; }
.nav__links a{ font-size:.92rem; font-weight:500; position:relative; }
.nav__links a:not(.nav__cta)::after{
  content:""; position:absolute; left:0; bottom:-4px; width:0; height:2px;
  background:var(--green); transition:width .3s var(--ease);
}
.nav__links a:not(.nav__cta):hover::after{ width:100%; }
.nav__cta{ padding:.5rem 1.1rem; border:1.5px solid var(--ink); border-radius:100px; transition:.3s var(--ease); }
.nav__cta:hover{ background:var(--ink); color:var(--paper); }
.nav__toggle{ display:none; background:none; border:0; cursor:pointer; width:30px; height:24px; position:relative; }
.nav__toggle span{ position:absolute; left:0; width:100%; height:2px; background:var(--ink); transition:.3s var(--ease); }
.nav__toggle span:first-child{ top:6px; } .nav__toggle span:last-child{ bottom:6px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:7rem var(--pad) 3rem; position:relative; overflow:hidden;
}
.hero__bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(120% 80% at 85% 10%, rgba(226,161,0,.10), transparent 55%),
    radial-gradient(100% 90% at 0% 100%, rgba(30,122,70,.10), transparent 50%);
}
.hero__bg::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; opacity:.35;
  mask-image:radial-gradient(80% 70% at 50% 40%,#000,transparent 80%);
}
.hero__grid{
  position:relative; z-index:1; width:100%; max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,5rem); align-items:center;
}
.kicker{ font-size:.8rem; letter-spacing:.22em; text-transform:uppercase; font-weight:600; color:var(--muted); display:flex; align-items:center; }
.hero__title{
  font-family:var(--font-display); font-weight:340; font-optical-sizing:auto;
  font-size:clamp(3rem,8.5vw,6.6rem); line-height:.95; letter-spacing:-.03em;
  margin:.8rem 0 1.4rem;
}
.hero__title em{ color:var(--green); font-weight:420; }
.hero__lede{ font-size:clamp(1.1rem,1.6vw,1.32rem); max-width:42ch; color:var(--ink-2); }
.hero__actions{ display:flex; gap:.9rem; margin-top:2.2rem; flex-wrap:wrap; }

.hero__portrait{ position:relative; }
.hero__portrait img{
  width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center 20%;
  border-radius:6px; filter:grayscale(.12) contrast(1.03);
  box-shadow:0 40px 80px -30px rgba(19,18,16,.5);
}
.hero__portrait::before{
  content:""; position:absolute; inset:14px -14px -14px 14px; z-index:-1;
  border:1.5px solid var(--ink); border-radius:6px;
}
.hero__portrait figcaption{
  position:absolute; bottom:-1px; left:-1px; right:-1px;
  background:var(--ink); color:var(--paper); font-size:.82rem; letter-spacing:.01em;
  padding:.7rem 1rem; border-radius:0 0 6px 6px;
}
.hero__scroll{
  position:absolute; bottom:1.8rem; left:50%; transform:translateX(-50%); z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted);
}
.hero__scroll svg{ animation:bob 1.8s var(--ease) infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(6px);} }

/* ============================================================
   STATEMENT
   ============================================================ */
.statement{ background:var(--ink); color:var(--paper); padding:clamp(5rem,12vw,9rem) var(--pad); text-align:center; }
.statement__text{
  font-family:var(--font-display); font-weight:340; font-optical-sizing:auto;
  font-size:clamp(1.7rem,4.4vw,3.4rem); line-height:1.18; letter-spacing:-.02em;
  max-width:18ch; margin:0 auto;
}
.statement .hl{ color:var(--gold); font-style:italic; }
.statement__by{ margin-top:2rem; letter-spacing:.18em; text-transform:uppercase; font-size:.78rem; color:rgba(246,241,231,.6); }

/* ============================================================
   STORY
   ============================================================ */
.story{ padding:clamp(5rem,11vw,8rem) 0; }
.story__body{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2.5rem,5vw,5rem); align-items:start;
}
.story__img{ position:sticky; top:120px; }
.story__img img{
  width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:6px;
  filter:grayscale(.1) contrast(1.03);
  box-shadow:0 30px 60px -28px rgba(19,18,16,.45);
}
.story__text p{ margin-bottom:1.2rem; color:var(--ink-2); }
.story__text .lead{ margin-bottom:1.6rem; }
.facts{ list-style:none; margin-top:2.4rem; border-top:1px solid var(--line); }
.facts li{
  display:grid; grid-template-columns:1fr 2fr; gap:1rem; align-items:baseline;
  padding:1rem 0; border-bottom:1px solid var(--line);
  font-size:1.05rem; font-weight:500;
}
.facts li span{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:600; }

/* ============================================================
   VALUES
   ============================================================ */
.values{ padding:clamp(5rem,11vw,8rem) 0; background:var(--paper-2); }
.values__grid{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem;
}
.value{
  background:var(--paper); border:1px solid var(--line); border-radius:10px;
  padding:2rem 1.6rem 1.8rem; transition:transform .4s var(--ease), box-shadow .4s, border-color .4s;
}
.value:hover{ transform:translateY(-6px); box-shadow:0 24px 50px -28px rgba(19,18,16,.4); border-color:var(--green); }
.value__no{
  font-family:var(--font-display); font-style:italic; font-size:1.5rem; color:var(--gold);
  display:block; margin-bottom:1.2rem;
}
.value h3{ font-size:1.18rem; font-weight:600; margin-bottom:.6rem; letter-spacing:-.01em; }
.value p{ font-size:.96rem; color:var(--muted); }

/* ============================================================
   IMPACT
   ============================================================ */
.impact{ padding:clamp(5rem,11vw,8rem) 0; }
.impact__feature{
  max-width:var(--maxw); margin:0 auto clamp(3rem,6vw,5rem); padding:0 var(--pad);
  display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(2rem,5vw,4rem); align-items:center;
}
.impact__img img{
  width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:6px;
  filter:grayscale(.1) contrast(1.03); box-shadow:0 30px 60px -30px rgba(19,18,16,.45);
}
.impact__lead .lead{ position:relative; padding-left:1.4rem; }
.impact__lead .lead::before{ content:""; position:absolute; left:0; top:.4rem; bottom:.4rem; width:3px; border-radius:2px;
  background:linear-gradient(var(--green),var(--gold),var(--red)); }
.impact__grid{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem;
}
.card{
  background:var(--ink); color:var(--paper); border-radius:10px; padding:1.8rem 1.5rem;
  position:relative; overflow:hidden; transition:transform .4s var(--ease);
  min-height:200px; display:flex; flex-direction:column; justify-content:flex-end;
}
.card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--green) 0 33%,var(--gold) 33% 66%,var(--red) 66% 100%);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease);
}
.card:hover{ transform:translateY(-6px); }
.card:hover::before{ transform:scaleX(1); }
.card h3{ font-family:var(--font-display); font-weight:400; font-size:1.4rem; margin-bottom:.6rem; }
.card p{ font-size:.92rem; color:rgba(246,241,231,.72); }

/* ============================================================
   VENTURES
   ============================================================ */
.ventures{ padding:clamp(5rem,11vw,8rem) 0; background:var(--paper-2); }
.ventures__list{ list-style:none; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.ventures__list li{
  display:grid; grid-template-columns:auto 1fr auto; gap:1.5rem; align-items:center;
  padding:1.6rem 0; border-top:1px solid var(--line);
  transition:padding .35s var(--ease);
}
.ventures__list li:last-child{ border-bottom:1px solid var(--line); }
.ventures__list li:hover{ padding-left:1rem; }
.ventures__idx{ font-family:var(--font-display); font-style:italic; color:var(--gold); font-size:1.1rem; }
.ventures__name{ font-family:var(--font-display); font-size:clamp(1.4rem,3vw,2.1rem); font-weight:400; letter-spacing:-.01em; }
.ventures__tag{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:600; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ overflow:hidden; padding:clamp(3rem,6vw,5rem) 0; background:var(--ink); }
.gallery__track{ display:flex; gap:1.2rem; width:max-content; padding:0 1.2rem; animation:slide 40s linear infinite; will-change:transform; }
.gallery__track figure{ width:clamp(220px,28vw,360px); flex:none; }
.gallery__track img{
  width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:6px;
  filter:grayscale(.3) contrast(1.05); transition:filter .4s;
}
.gallery__track figure:hover img{ filter:grayscale(0); }
@keyframes slide{ to{ transform:translateX(-50%);} }

/* ============================================================
   CONNECT
   ============================================================ */
.connect{ padding:clamp(6rem,13vw,10rem) var(--pad); text-align:center; position:relative; overflow:hidden; }
.connect::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(70% 60% at 50% 0%, rgba(30,122,70,.12), transparent 60%);
}
.connect__inner{ max-width:760px; margin:0 auto; }
.connect h2{ margin:.3rem 0 1.3rem; }
.connect__sub{ color:var(--muted); font-size:1.15rem; max-width:46ch; margin:0 auto; }
.connect__actions{ display:flex; gap:1rem; justify-content:center; margin-top:2.4rem; flex-wrap:wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--ink); color:var(--paper); padding:clamp(3rem,7vw,5rem) var(--pad) 2rem; }
.foot__top{ display:flex; flex-direction:column; align-items:center; gap:1rem; text-align:center; padding-bottom:2.5rem; border-bottom:1px solid rgba(246,241,231,.14); }
.brand__mark--lg{ width:54px; height:54px; font-size:1.4rem; border-radius:14px; }
.foot__name{ font-family:var(--font-display); font-size:1.5rem; }
.foot__bottom{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-top:1.8rem; flex-wrap:wrap; }
.foot__bottom p{ font-size:.85rem; color:rgba(246,241,231,.6); }
.foot__links{ display:flex; gap:1.6rem; }
.foot__links a{ font-size:.85rem; color:rgba(246,241,231,.75); transition:color .3s; }
.foot__links a:hover{ color:var(--gold); }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.1s; }
.reveal[data-delay="2"]{ transition-delay:.2s; }
.reveal[data-delay="3"]{ transition-delay:.3s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .gallery__track,.hero__scroll svg{ animation:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   UPDATES
   ============================================================ */
.updates{ padding:clamp(5rem,11vw,8rem) 0; }
.updates__grid{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem;
}
.updates__empty{ text-align:center; color:var(--muted); font-size:1.1rem; }
.updates__more{ max-width:var(--maxw); margin:clamp(2.2rem,4vw,3rem) auto 0; padding:0 var(--pad); text-align:center; }
.update{
  background:var(--paper); border:1px solid var(--line); border-radius:12px;
  overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s, border-color .4s;
}
.update:hover{ transform:translateY(-6px); box-shadow:0 26px 54px -30px rgba(19,18,16,.45); border-color:var(--green); }
.update__link{ display:flex; flex-direction:column; height:100%; }
.update__img{ aspect-ratio:16/10; overflow:hidden; }
.update__img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.update:hover .update__img img{ transform:scale(1.04); }
.update__body{ padding:1.5rem 1.5rem 1.7rem; display:flex; flex-direction:column; gap:.5rem; flex:1; }
.update__date{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--green); font-weight:600; }
.update__title{ font-family:var(--font-display); font-weight:420; font-size:1.3rem; line-height:1.15; letter-spacing:-.01em; }
.update__excerpt{ font-size:.95rem; color:var(--muted); }
.update__more{ margin-top:auto; padding-top:.6rem; font-size:.85rem; font-weight:600; color:var(--ink); }

/* ============================================================
   CONTACT FORM
   ============================================================ */
.form-wrap{
  max-width:680px; margin:clamp(3rem,6vw,4.5rem) auto 0; text-align:left;
  background:var(--paper); border:1px solid var(--line); border-radius:16px;
  padding:clamp(1.8rem,4vw,2.6rem);
  box-shadow:0 30px 70px -45px rgba(19,18,16,.5);
}
.form-wrap__title{ font-family:var(--font-display); font-weight:420; font-size:1.6rem; margin-bottom:1.4rem; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form__field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.form__field span{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; font-weight:600; color:var(--muted); }
.form__field input,
.form__field textarea{
  font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:var(--paper-2); border:1.5px solid var(--line); border-radius:9px;
  padding:.8rem .9rem; transition:border-color .3s, background .3s, box-shadow .3s; resize:vertical;
}
.form__field input:focus,
.form__field textarea:focus{
  outline:none; border-color:var(--green); background:var(--paper);
  box-shadow:0 0 0 4px rgba(30,122,70,.12);
}
.form .btn{ margin-top:.4rem; border:0; cursor:pointer; font-family:var(--font-body); }
.form__hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-note{ padding:.95rem 1.1rem; border-radius:10px; margin-bottom:1.3rem; font-size:.96rem; font-weight:500; }
.form-note--ok{ background:rgba(30,122,70,.12); color:#155e36; border:1px solid rgba(30,122,70,.3); }
.form-note--err{ background:rgba(192,50,43,.1); color:var(--red); border:1px solid rgba(192,50,43,.3); }

/* WhatsApp inline button */
.btn--wa{ background:#25D366; color:#0b3d22; }
.btn--wa:hover{ background:#1ebe5a; transform:translateY(-3px); box-shadow:0 12px 30px -12px rgba(37,211,102,.6); }

/* WhatsApp floating button */
.wa-float{
  position:fixed; right:clamp(16px,3vw,28px); bottom:clamp(16px,3vw,28px); z-index:80;
  width:60px; height:60px; border-radius:50%; display:grid; place-items:center;
  background:#25D366; color:#fff; box-shadow:0 14px 34px -10px rgba(37,211,102,.7);
  transition:transform .3s var(--ease), box-shadow .3s;
}
.wa-float::before{
  content:""; position:absolute; inset:0; border-radius:50%;
  background:#25D366; z-index:-1; animation:waPulse 2.4s ease-out infinite;
}
.wa-float:hover{ transform:scale(1.08); box-shadow:0 18px 40px -8px rgba(37,211,102,.8); }
.wa-float__tip{
  position:absolute; right:72px; top:50%; transform:translateY(-50%) translateX(8px);
  white-space:nowrap; background:var(--ink); color:var(--paper);
  font-size:.82rem; font-weight:600; padding:.5rem .85rem; border-radius:8px;
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease), transform .3s var(--ease);
}
.wa-float__tip::after{
  content:""; position:absolute; right:-5px; top:50%; transform:translateY(-50%) rotate(45deg);
  width:10px; height:10px; background:var(--ink);
}
.wa-float:hover .wa-float__tip{ opacity:1; transform:translateY(-50%) translateX(0); }
@media (max-width:560px){ .wa-float__tip{ display:none; } }
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.6;} 70%{ transform:scale(1.6); opacity:0;} 100%{ opacity:0;} }
@media (prefers-reduced-motion:reduce){ .wa-float::before{ animation:none; } }

/* ============================================================
   BLOG / SINGLE / PAGE TEMPLATES
   ============================================================ */
.page{ padding-top:clamp(7rem,12vh,9rem); padding-bottom:clamp(4rem,8vw,6rem); min-height:70vh; }
.page-head{ max-width:var(--maxw); margin:0 auto clamp(2.5rem,5vw,3.5rem); padding:0 var(--pad); text-align:center; }
.page-head__title{ font-family:var(--font-display); font-weight:400; font-size:clamp(2.2rem,5vw,3.4rem); line-height:1.05; letter-spacing:-.02em; }
.page-head__sub{ color:var(--muted); font-size:1.1rem; max-width:54ch; margin:1.1rem auto 0; }
.page-wrap{ max-width:var(--maxw); margin-left:auto; margin-right:auto; padding-left:var(--pad); padding-right:var(--pad); }

/* Pagination */
.pagination{ display:flex; justify-content:center; gap:.5rem; margin-top:clamp(2.5rem,5vw,3.5rem); flex-wrap:wrap; }
.pagination .page-numbers{
  display:inline-grid; place-items:center; min-width:44px; height:44px; padding:0 .8rem;
  border:1.5px solid var(--line); border-radius:100px; font-weight:600; font-size:.95rem;
  color:var(--ink); transition:.3s var(--ease);
}
.pagination .page-numbers:hover{ border-color:var(--green); color:var(--green); }
.pagination .page-numbers.current{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pagination .dots{ border:0; }

/* Single post / page */
.single{ max-width:760px; margin:0 auto; padding:0 var(--pad); }
.single__head{ margin-bottom:2rem; }
.single__back{ display:inline-block; font-size:.85rem; font-weight:600; letter-spacing:.04em; color:var(--green); margin-bottom:1.4rem; }
.single__back:hover{ text-decoration:underline; }
.single__date{ display:block; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:600; margin-bottom:.7rem; }
.single__title{ font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,4.6vw,3.2rem); line-height:1.08; letter-spacing:-.02em; }
.single__hero{ max-width:980px; margin:0 auto 2.6rem; padding:0 var(--pad); }
.single__hero img{ width:100%; border-radius:10px; box-shadow:0 30px 60px -34px rgba(19,18,16,.5); }
.single__content{ font-size:1.08rem; color:var(--ink-2); }
.single__content > *{ margin-bottom:1.3rem; }
.single__content h2{ font-size:1.7rem; margin-top:2.2rem; }
.single__content h3{ font-family:var(--font-display); font-weight:500; font-size:1.35rem; margin-top:1.8rem; }
.single__content a{ color:var(--green); text-decoration:underline; text-underline-offset:3px; }
.single__content img{ border-radius:10px; margin:1.6rem 0; }
.single__content blockquote{
  border-left:3px solid var(--green); padding-left:1.4rem; margin:1.8rem 0;
  font-family:var(--font-display); font-style:italic; font-size:1.3rem; color:var(--ink);
}
.single__content ul,.single__content ol{ padding-left:1.4rem; }
.single__content li{ margin-bottom:.5rem; }
.single__foot{ max-width:760px; margin:3.5rem auto 0; padding:2rem var(--pad) 0; border-top:1px solid var(--line); text-align:center; }
.single__nav{ display:flex; justify-content:space-between; gap:1rem; margin-bottom:2rem; font-weight:600; font-size:.95rem; flex-wrap:wrap; }
.single__nav a{ color:var(--ink); }
.single__nav a:hover{ color:var(--green); }
.single__nav-next{ margin-left:auto; text-align:right; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .values__grid,.impact__grid{ grid-template-columns:repeat(2,1fr); }
  .updates__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .nav__links{
    position:fixed; inset:0 0 auto 0; top:0; flex-direction:column; gap:1.6rem;
    background:var(--paper); padding:6rem 2rem 2.5rem; box-shadow:0 20px 40px -20px rgba(0,0,0,.3);
    transform:translateY(-100%); transition:transform .45s var(--ease); align-items:flex-start;
  }
  .nav__links.open{ transform:translateY(0); }
  .nav__links a{ font-size:1.3rem; }
  .nav__toggle{ display:block; z-index:60; }
  .nav.menu-open .nav__toggle span:first-child{ top:11px; transform:rotate(45deg); }
  .nav.menu-open .nav__toggle span:last-child{ bottom:11px; transform:rotate(-45deg); }
  .hero__grid{ grid-template-columns:1fr; gap:3rem; }
  .hero__portrait{ max-width:380px; }
  .story__body{ grid-template-columns:1fr; }
  .story__img{ position:static; max-width:420px; }
  .impact__feature{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .values__grid,.impact__grid{ grid-template-columns:1fr; }
  .updates__grid{ grid-template-columns:1fr; }
  .form__row{ grid-template-columns:1fr; }
  .ventures__list li{ grid-template-columns:auto 1fr; }
  .ventures__tag{ grid-column:2; }
  .foot__bottom{ flex-direction:column; text-align:center; }
  .brand__name{ display:none; }
}
