/*
 * ═══════════════════════════════════════════════════════════════════
 * MAKAYA PLANTATIONS LIMITED — site.css  v1.0  (apex / master brand)
 * "The Cultivated Estate." One root; branches multiplying.
 * Identity system: Ink foundation, Heritage-Green stem, Antique-Gold accents.
 * EB Garamond display · DM Sans body.
 * ═══════════════════════════════════════════════════════════════════
 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Palette — official Makaya identity system */
  --ink:#161310;--ink0:#100D0A;--ink2:#1E1A15;--ink3:#272118;--ink4:#322A1F;
  --green:#0E4A39;--green-lt:#2E7D5B;--green-dk:#0A382C;
  --gold:#A8823C;--gold-lt:#C9A55E;--gold-br:#D8B968;
  --ivory:#F4F0E7;--paper:#FBF9F3;
  --muted:#A39C8B;--muted2:#7C7466;
  --bdr:rgba(168,130,60,.18);--bdrg:rgba(168,130,60,.32);
  /* Text opacity layers (ivory ink on dark) */
  --t100:rgba(244,240,231,1);
  --t78:rgba(244,240,231,.80);
  --t55:rgba(244,240,231,.56);
  --t35:rgba(244,240,231,.36);
  /* Typography */
  --dp:'EB Garamond',Georgia,'Times New Roman',serif;
  --bd:'DM Sans',system-ui,sans-serif;
  /* Layout */
  --mxw:1200px;--px:clamp(1.5rem,5vw,4rem);
  --section-pad:clamp(5rem,10vw,8rem);
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--ink);color:var(--ivory);font-family:var(--bd);font-size:18px;line-height:1.8;overflow-x:hidden;-webkit-font-smoothing:antialiased;font-weight:400}
h1,h2,h3,h4,h5{font-family:var(--dp);font-weight:400;line-height:1.1;color:var(--ivory)}
em{font-style:italic} strong{font-weight:500;color:var(--ivory)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button{font-family:var(--bd);cursor:pointer}
.wrap{max-width:var(--mxw);margin:0 auto;padding:0 var(--px)}
section{padding:var(--section-pad) 0}
figcaption{font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.65rem;line-height:1.55}

/* ── SCROLL REVEAL ─────────────────────────────────────────────── */
.sr{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.sr.in{opacity:1;transform:none}
.sr.d1{transition-delay:.12s}.sr.d2{transition-delay:.24s}
.sr.d3{transition-delay:.36s}.sr.d4{transition-delay:.48s}

/* ── ATOMS ─────────────────────────────────────────────────────── */
.eyebrow{display:flex;align-items:center;gap:.7rem;font-size:.63rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.eyebrow::before{content:'';width:1.6rem;height:1px;background:var(--gold);flex-shrink:0}
.sec-title{font-size:clamp(2.4rem,4.8vw,4.2rem);font-weight:400;line-height:1.05;margin-bottom:1.75rem;color:var(--ivory);letter-spacing:-.01em}
.sec-title em{color:var(--gold-lt);font-style:italic}
.sec-sub{font-size:1.1rem;color:var(--t55);max-width:62ch;line-height:1.8;margin-bottom:3rem}

/* Buttons */
.btn-p{display:inline-flex;align-items:center;gap:.55rem;font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2rem;background:var(--gold);color:var(--ink);border:1px solid var(--gold);transition:background .25s,border-color .25s,color .25s}
.btn-p:hover{background:var(--gold-lt);border-color:var(--gold-lt)}
.btn-g{display:inline-flex;align-items:center;gap:.55rem;font-size:.72rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2rem;border:1px solid rgba(244,240,231,.22);color:var(--t55);transition:border-color .25s,color .25s}
.btn-g:hover{border-color:var(--ivory);color:var(--ivory)}
.read-more{display:inline-flex;align-items:center;gap:.45rem;font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-lt);transition:gap .2s}
.read-more:hover{gap:.7rem}

blockquote.pull{margin:2.5rem 0;padding:1.5rem 0 1.5rem 1.6rem;border-left:2px solid var(--gold);font-family:var(--dp);font-size:clamp(1.3rem,2.2vw,1.75rem);font-style:italic;color:var(--ivory);line-height:1.4}

/* ── STEM MARK ─────────────────────────────────────────────────── */
.stem-mark{display:block}
.stem-mark .stem-line{fill:none;stroke:var(--stem-color,#C9B79A);stroke-linecap:round}
.stem-mark .node-fill{fill:var(--gold)}
.stem-mark .node-open{fill:none;stroke:var(--gold);stroke-width:2}
.stem-mark .node-apex{fill:none;stroke:var(--gold-lt);stroke-width:1.8;stroke-dasharray:2.2 2.4}

/* Animated hero stem: draw-on + node reveal */
.stem-hero .stem-line{stroke-dasharray:240;stroke-dashoffset:240;animation:stemDraw 2.2s cubic-bezier(.4,0,.2,1) forwards}
.stem-hero .stem-line.b1{animation-delay:.5s}.stem-hero .stem-line.b2{animation-delay:.75s}
.stem-hero .stem-line.b3{animation-delay:1s}.stem-hero .stem-line.b4{animation-delay:1.25s}
.stem-hero circle{opacity:0;transform-box:fill-box;transform-origin:center;animation:nodeIn .6s ease forwards}
.stem-hero .n1{animation-delay:1.0s}.stem-hero .n2{animation-delay:1.25s}
.stem-hero .n3{animation-delay:1.5s}.stem-hero .n4{animation-delay:1.75s}.stem-hero .n5{animation-delay:2.1s}
@keyframes stemDraw{to{stroke-dashoffset:0}}
@keyframes nodeIn{from{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}
@media(prefers-reduced-motion:reduce){
  .stem-hero .stem-line{stroke-dashoffset:0;animation:none}
  .stem-hero circle{opacity:1;animation:none}
}

/* ── NAV ───────────────────────────────────────────────────────── */
#nav{position:fixed;inset:0 0 auto;z-index:200;padding:1rem var(--px);display:flex;align-items:center;justify-content:space-between;transition:background .35s,border-color .35s;border-bottom:1px solid transparent}
#nav.scrolled{background:rgba(16,13,10,.96);backdrop-filter:blur(14px);border-color:var(--bdr)}
.nav-brand{display:flex;align-items:center;gap:.85rem;text-decoration:none}
.nav-brand .stem-mark{height:40px;width:auto;flex-shrink:0;--stem-color:#C9B79A}
.nav-brand-text{display:flex;flex-direction:column;line-height:1.02}
.nav-brand-text .name{font-family:var(--dp);font-size:1.32rem;font-weight:500;color:var(--ivory);letter-spacing:.005em}
.nav-brand-text .name em{font-style:italic;color:var(--gold-lt)}
.nav-brand-text .sub{font-size:.5rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-top:.15rem}
.nav-motto{font-family:var(--dp);font-style:italic;font-size:1.15rem;color:var(--gold-lt);letter-spacing:.01em;white-space:nowrap;opacity:1}
.nav-brand-text .sub-motto{display:none}
.nav-motto::before{content:'\00AB\2009';color:var(--gold);opacity:.7}
.nav-motto::after{content:'\2009\00BB';color:var(--gold);opacity:.7}
@media(max-width:1200px){.nav-motto{display:none}}
.nav-ul{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-ul a{font-size:.68rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--t55);transition:color .22s}
.nav-ul a:hover{color:var(--ivory)}
.nav-cta{padding:.5rem 1.2rem;border:1px solid var(--gold);color:var(--ivory)!important;transition:background .25s,color .25s!important}
.nav-cta:hover{background:var(--gold);color:var(--ink)!important}
.nav-phone{color:var(--gold-lt)!important;font-size:.62rem!important;letter-spacing:.06em!important}
.nav-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;z-index:300;cursor:pointer}
.nav-ham span{display:block;width:22px;height:1px;background:var(--ivory);transition:transform .3s,opacity .3s}
#nav.open .nav-ham span:nth-child(1){transform:translateY(6px) rotate(45deg)}
#nav.open .nav-ham span:nth-child(2){opacity:0}
#nav.open .nav-ham span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:900px){
  .nav-ham{display:flex;z-index:1100;position:relative}
  .nav-ul{display:none;position:fixed;top:0;left:0;width:100%;height:100dvh;background:var(--ink);flex-direction:column;justify-content:center;align-items:center;gap:1rem;z-index:1000;overscroll-behavior:contain}
  #nav.open .nav-ul{display:flex}
  .nav-ul a:not(.nav-cta):not(.nav-phone){font-family:var(--dp);font-size:clamp(1.1rem,3vh,1.4rem);font-weight:400;letter-spacing:.02em;color:var(--ivory)}
  .nav-ul .nav-phone{font-size:clamp(.7rem,1.9vh,.82rem)!important}
  .nav-ul .nav-cta{font-size:.65rem;padding:.65rem 1.75rem}
  .nav-brand-text .sub{display:none}
  .nav-brand-text .sub-motto{display:block;font-family:var(--dp);font-style:italic;font-size:.78rem;color:var(--gold-lt);letter-spacing:.005em;margin-top:.2rem;white-space:nowrap}
  .nav-brand-text .sub-motto::before{content:'\00AB\2009';color:var(--gold);opacity:.7}
  .nav-brand-text .sub-motto::after{content:'\2009\00BB';color:var(--gold);opacity:.7}
}

/* ── HERO ───────────────────────────────────────────────────────── */
#hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:
  radial-gradient(1100px 700px at 78% 12%,rgba(46,125,91,.10),transparent 60%),
  radial-gradient(900px 600px at 10% 90%,rgba(168,130,60,.08),transparent 55%),
  var(--ink)}
.hero-grain{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(rgba(244,240,231,.025) 1px,transparent 1px);background-size:3px 3px}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.25fr .75fr;gap:3rem;align-items:center;width:100%}
.hero-tag{font-size:.62rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem;display:flex;align-items:center;gap:.7rem}
.hero-tag::before{content:'';width:1.6rem;height:1px;background:var(--gold)}
.hero-h1{font-family:var(--dp);font-size:clamp(2.9rem,6.2vw,5.6rem);font-weight:400;line-height:1.02;max-width:15ch;margin-bottom:1.6rem;color:var(--ivory);letter-spacing:-.018em}
.hero-h1 em{color:var(--gold-lt);font-style:italic}
.hero-sub{font-size:clamp(1.06rem,1.5vw,1.2rem);color:var(--t78);max-width:52ch;margin-bottom:2.4rem;line-height:1.72}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stem-wrap{display:flex;justify-content:center;align-items:center}
.hero-stem-wrap .stem-mark{width:min(280px,72%);height:auto;--stem-color:#C9B79A}
.hero-foot{position:absolute;left:var(--px);right:var(--px);bottom:2rem;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--t35);border-top:1px solid var(--bdr);padding-top:1.1rem}
.hero-foot b{color:var(--muted);font-weight:500}
@media(max-width:860px){
  .hero-inner{grid-template-columns:1fr}
  .hero-stem-wrap{display:none}
  #hero{padding-top:7rem;padding-bottom:5rem}
}
/* Dynamic hero rotator — slides overlap in one grid cell so height = tallest */
.hero-rotator{display:grid;position:relative}
.hero-slide{grid-area:1/1;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1),visibility .7s;pointer-events:none}
.hero-slide.is-active{opacity:1;visibility:visible;transform:none;pointer-events:auto}
.hero-slide .hero-sub{margin-bottom:0}
.hero-controls{display:flex;align-items:center;gap:1.4rem;margin-top:2.4rem;flex-wrap:wrap}
.hero-dots{display:flex;gap:.55rem}
.hero-dots button{width:30px;height:3px;border:none;background:rgba(244,240,231,.18);padding:0;cursor:pointer;transition:background .3s;border-radius:2px}
.hero-dots button[aria-selected="true"]{background:var(--gold)}
.hero-dots button:hover{background:rgba(244,240,231,.45)}
.hero-pause{background:none;border:none;color:var(--t35);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:color .25s}
.hero-pause:hover{color:var(--muted)}
.hero-pause .pi{width:7px;height:7px;border-left:2px solid currentColor;border-right:2px solid currentColor;box-sizing:border-box}
.hero-pause.paused .pi{border:none;width:0;height:0;border-top:4px solid transparent;border-bottom:4px solid transparent;border-left:7px solid currentColor;border-right:0}
@media(prefers-reduced-motion:reduce){.hero-slide{transition:opacity .25s}}
@media(max-width:860px){.hero-controls{margin-top:1.8rem}.hero-actions{flex-wrap:wrap}}

/* ── FACT STRIP ─────────────────────────────────────────────────── */
.fact-strip{background:var(--ink0);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);padding:1.5rem var(--px);overflow:hidden}
.fact-inner{max-width:var(--mxw);margin:0 auto;display:flex;align-items:center;gap:0;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}
.fact-inner::-webkit-scrollbar{display:none}
.fact-item{display:flex;flex-direction:column;gap:.2rem;flex-shrink:0;padding:0 2.4rem;border-right:1px solid var(--bdr)}
.fact-item:first-child{padding-left:0}
.fact-item:last-child{border-right:none}
.fact-num{font-family:var(--dp);font-size:1.6rem;font-weight:400;color:var(--ivory);line-height:1}
.fact-num em{font-style:normal;color:var(--gold-lt);font-size:.7em}
.fact-label{font-size:.6rem;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);line-height:1.4;max-width:14ch}
@media(max-width:680px){
  .fact-inner{flex-wrap:wrap}
  .fact-item{flex:1 1 45%;padding:.7rem 1.2rem;border-right:none;border-bottom:1px solid var(--bdr)}
  .fact-item:nth-child(odd){border-right:1px solid var(--bdr)}
}

/* ── ESTATE / MANIFESTO BAND ────────────────────────────────────── */
#estate{background:linear-gradient(135deg,var(--green-dk),var(--green));border-bottom:1px solid rgba(168,130,60,.3);padding:clamp(4rem,8vw,6.5rem) 0}
.estate-wrap{max-width:var(--mxw);margin:0 auto;padding:0 var(--px);display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:center}
.estate-lead{font-family:var(--dp);font-size:clamp(1.9rem,3.6vw,3rem);font-weight:400;color:var(--ivory);font-style:italic;line-height:1.18;letter-spacing:-.01em}
.estate-lead .u{color:var(--gold-br);font-style:normal}
.estate-copy p{color:rgba(244,240,231,.85);font-size:1.05rem;line-height:1.82;margin-bottom:1rem}
.estate-copy p:last-child{margin-bottom:0}
.estate-copy strong{color:var(--gold-br)}
@media(max-width:760px){.estate-wrap{grid-template-columns:1fr;gap:2.25rem}}

/* ── ARCHITECTURE DIAGRAM ───────────────────────────────────────── */
#architecture{background:var(--ink);border-top:1px solid var(--bdr)}
.arch-head{text-align:center;max-width:60ch;margin:0 auto 3.5rem}
.arch-head .eyebrow{justify-content:center}
.arch-diagram{max-width:760px;margin:0 auto;position:relative}
.arch-apex{text-align:center;margin-bottom:.4rem}
.arch-apex .ap-name{font-family:var(--dp);font-size:clamp(1.5rem,3vw,2.1rem);color:var(--ivory)}
.arch-apex .ap-sub{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:.3rem}
.arch-connector{height:38px;width:1px;background:linear-gradient(to bottom,var(--gold),transparent);margin:0 auto}
.arch-branches{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:.4rem}
.arch-branch{background:var(--ink2);padding:1.8rem 1.4rem;text-align:center;position:relative;transition:background .3s}
.arch-branch:hover{background:var(--ink3)}
.arch-branch .ab-dot{width:11px;height:11px;border-radius:50%;margin:0 auto .9rem;background:var(--gold);box-shadow:0 0 0 4px rgba(168,130,60,.12)}
.arch-branch.emerging .ab-dot{background:transparent;border:2px solid var(--gold-lt);box-shadow:none}
.arch-branch .ab-name{font-family:var(--dp);font-size:1.12rem;color:var(--ivory);line-height:1.2;margin-bottom:.3rem}
.arch-branch .ab-tag{font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.arch-note{text-align:center;font-size:.82rem;color:var(--t35);margin-top:2rem;line-height:1.7;max-width:64ch;margin-left:auto;margin-right:auto}
.arch-legend{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-top:1.5rem;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.arch-legend span{display:flex;align-items:center;gap:.5rem}
.lg-fill{width:9px;height:9px;border-radius:50%;background:var(--gold)}
.lg-open{width:9px;height:9px;border-radius:50%;border:2px solid var(--gold-lt)}
.lg-dash{width:9px;height:9px;border-radius:50%;border:1.5px dashed var(--gold-lt)}
@media(max-width:680px){.arch-branches{grid-template-columns:1fr 1fr}}

/* ── COMPANIES ──────────────────────────────────────────────────── */
#companies{background:var(--ink2);border-top:1px solid var(--bdr)}
.co-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--bdr);margin-top:3rem}
.co-card{padding:2.6rem;border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr);position:relative;overflow:hidden;transition:background .3s;display:flex;flex-direction:column}
.co-card:nth-child(2n){border-right:none}
.co-card:nth-last-child(-n+2){border-bottom:none}
.co-card::after{content:'';position:absolute;left:0;bottom:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.co-card:hover{background:rgba(168,130,60,.05)}
.co-card:hover::after{transform:scaleX(1)}
.co-logo{height:46px;margin-bottom:1.5rem;display:flex;align-items:center}
.co-logo img{height:100%;width:auto}
.co-logo.consult{height:auto;margin-bottom:1.5rem}
.co-logo.consult img{height:54px;width:54px;border-radius:50%;filter:drop-shadow(0 2px 9px rgba(0,0,0,.28))}
.co-rc{font-size:.58rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.co-card h3{font-size:1.5rem;margin-bottom:.7rem;color:var(--ivory);line-height:1.2}
.co-card p{font-size:.97rem;color:var(--muted);line-height:1.72;margin-bottom:1.25rem;flex-grow:1}
.co-meta{font-size:.78rem;color:var(--t55);line-height:1.6;margin-bottom:1.25rem;padding-top:1rem;border-top:1px solid var(--bdr)}
.co-more{display:inline-flex;align-items:center;gap:.4rem;font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-lt);transition:gap .2s}
.co-more:hover{gap:.65rem}
.co-emerging{position:absolute;top:1.6rem;right:1.6rem;font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-lt);border:1px solid var(--bdrg);padding:.25rem .55rem;border-radius:2px}
@media(max-width:760px){.co-grid{grid-template-columns:1fr}.co-card{border-right:none;border-bottom:1px solid var(--bdr)}.co-card:last-child{border-bottom:none}}

/* ── PROJECTS / SPV ─────────────────────────────────────────────── */
#projects{background:var(--ink);border-top:1px solid var(--bdr)}
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:3rem}
.proj-card{background:var(--ink2);padding:2.4rem;transition:background .3s}
.proj-card:hover{background:var(--ink3)}
.proj-tag{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem}
.proj-card h3{font-family:var(--dp);font-size:1.3rem;color:var(--ivory);margin-bottom:.6rem;line-height:1.25}
.proj-card p{font-size:.92rem;color:var(--muted);line-height:1.72}
@media(max-width:680px){.proj-grid{grid-template-columns:1fr}}

/* ── FOUNDATION ─────────────────────────────────────────────────── */
#foundation{background:var(--ink0);border-top:1px solid var(--bdr);position:relative;overflow:hidden}
.found-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.found-lead{font-family:var(--dp);font-size:clamp(1.7rem,3.2vw,2.6rem);font-style:italic;color:var(--ivory);line-height:1.22;margin-bottom:1.5rem}
.found-lead .u{color:var(--gold-br);font-style:normal}
.found-copy p{color:var(--t78);font-size:1.04rem;line-height:1.82;margin-bottom:1.1rem}
.found-pillars{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.found-pillar{background:var(--ink2);padding:1.9rem 1.6rem}
.found-pillar .fp-n{font-family:var(--dp);font-size:.85rem;color:var(--gold);margin-bottom:.6rem}
.found-pillar h4{font-family:var(--dp);font-size:1.12rem;color:var(--ivory);margin-bottom:.45rem;line-height:1.25}
.found-pillar p{font-size:.86rem;color:var(--muted);line-height:1.65}
@media(max-width:860px){.found-grid{grid-template-columns:1fr;gap:2.5rem}}

/* ── HERITAGE / FOUNDER ─────────────────────────────────────────── */
#heritage{background:var(--ink2);border-top:1px solid var(--bdr)}
.her-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:5rem;align-items:start}
.her-img-wrap{position:relative}
.her-img-wrap img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center top;border:1px solid var(--bdr)}
.her-img-cap{position:absolute;bottom:0;left:0;right:0;padding:1.2rem;background:linear-gradient(to top,rgba(16,13,10,.95),transparent);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--t55)}
.her-text p{color:var(--t78);font-size:1.06rem;line-height:1.82;margin-bottom:1.25rem}
.her-text strong{color:var(--ivory)}
.founder-chip{margin-top:2rem;padding-top:1.75rem;border-top:1px solid var(--bdr)}
.founder-name{font-family:var(--dp);font-size:1.2rem;color:var(--ivory)}
.founder-role{font-size:.62rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:.25rem}
@media(max-width:860px){.her-grid{grid-template-columns:1fr;gap:2.5rem}.her-img-wrap img{aspect-ratio:4/3}}

/* ── CONTACT ────────────────────────────────────────────────────── */
#contact{background:var(--ink0);border-top:1px solid var(--bdr)}
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:2.5rem;align-items:start}
.contact-lhs,.contact-rhs{border:1px solid var(--bdr);background:var(--ink2);padding:clamp(1.8rem,3vw,2.8rem);border-radius:12px}
.contact-lhs p{color:var(--t55);font-size:1.02rem;line-height:1.8;margin-bottom:1.25rem}
.contact-lhs address{font-style:normal;margin-top:2.25rem;border-top:1px solid var(--bdr);padding-top:1.75rem}
.c-row{display:flex;gap:1.5rem;padding:.8rem 0;border-bottom:1px solid var(--bdr);align-items:baseline}
.c-row:last-child{border-bottom:none}
.c-lbl{font-size:.6rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);flex-shrink:0;width:5.5rem}
.c-val{font-size:.92rem;color:var(--t78);line-height:1.55}
.c-val a{transition:color .2s}
.c-val a:hover{color:var(--gold-lt)}
form label{display:block;font-size:.62rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
form input,form select,form textarea{width:100%;background:var(--ink2);border:1px solid var(--bdrg);padding:.85rem 1rem;font-family:var(--bd);font-size:.95rem;color:var(--ivory);transition:border-color .2s;outline:none;border-radius:7px;-webkit-appearance:none}
form input:focus,form select:focus,form textarea:focus{border-color:var(--gold-lt)}
form select option{background:var(--ink2)}
form textarea{resize:vertical;min-height:140px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}
.form-field{margin-bottom:1.25rem}
.form-submit{margin-top:1.5rem}
.form-note{font-size:.75rem;color:var(--t35);margin-top:.75rem;line-height:1.55}
.contact-success{display:none;padding:2rem;border:1px solid var(--bdrg);background:rgba(168,130,60,.06);color:var(--ivory);font-size:1rem;line-height:1.7}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:3rem}.form-row{grid-template-columns:1fr}}

/* ── FOOTER ─────────────────────────────────────────────────────── */
footer{background:var(--ink2);border-top:3px solid var(--gold);padding:4rem var(--px) 2.5rem}
.foot-inner{max-width:var(--mxw);margin:0 auto}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:4rem;padding-bottom:3rem;border-bottom:1px solid var(--bdr);margin-bottom:2rem}
.fb-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:.9rem;text-decoration:none}
.fb-logo .stem-mark{height:42px;width:auto;--stem-color:#C9B79A}
.fb-name{font-family:var(--dp);font-size:1.35rem;color:var(--ivory)}
.fb-name em{color:var(--gold-lt);font-style:italic}
.fb-sub{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.95rem;display:block}
.fb-desc{font-size:.85rem;color:var(--muted);line-height:1.72;max-width:42ch}
.foot-nav h4,.foot-contact h4{font-size:.58rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:.7;margin-bottom:1rem}
.foot-nav-links{display:flex;flex-direction:column;gap:.55rem}
.foot-nav-links a{font-size:.85rem;color:var(--muted);transition:color .2s;line-height:1.4}
.foot-nav-links a:hover{color:var(--ivory)}
.foot-contact p{font-size:.85rem;color:var(--muted);line-height:1.9}
.foot-contact a{color:var(--muted);transition:color .2s}
.foot-contact a:hover{color:var(--ivory)}
.foot-copy{font-size:.68rem;color:var(--t35);line-height:1.7}
.foot-copy a{color:var(--t35);transition:color .2s}
.foot-copy a:hover{color:var(--muted)}
@media(max-width:860px){footer{padding:2.5rem var(--px) 2rem}.foot-top{grid-template-columns:1fr;gap:2.5rem}}

/* ── FLOAT BUTTONS + COOKIE ─────────────────────────────────────── */
#wa-btn{position:fixed;bottom:5.5rem;right:1.5rem;z-index:300;width:52px;height:52px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(0,0,0,.45);transition:transform .25s,background .25s}
#wa-btn:hover{transform:scale(1.07);background:var(--green-lt)}
#wa-btn svg{width:28px;height:28px;fill:#fff}
#btt{position:fixed;bottom:1.5rem;right:1.5rem;z-index:300;width:40px;height:40px;background:var(--ink3);border:1px solid var(--bdr);color:var(--muted);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s,background .2s;font-size:1rem}
#btt.show{opacity:1;pointer-events:auto}
#btt:hover{background:var(--ink4);color:var(--ivory)}
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--ink4);border-top:1px solid var(--bdr);padding:1.1rem clamp(1.5rem,5vw,4rem);display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;transform:translateY(100%);transition:transform .4s ease}
#cookie-banner.visible{transform:translateY(0)}
.cookie-text{font-size:.86rem;color:var(--muted);line-height:1.6;flex:1;min-width:200px}
.cookie-text a{color:var(--gold-lt);text-decoration:underline;text-underline-offset:3px}
.cookie-btns{display:flex;gap:.75rem;flex-shrink:0}
.cookie-accept{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.6rem 1.5rem;background:var(--gold);color:var(--ink);border:none;cursor:pointer;transition:background .25s}
.cookie-accept:hover{background:var(--gold-lt)}
.cookie-decline{font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.6rem 1.5rem;background:transparent;color:var(--muted);border:1px solid var(--bdr);cursor:pointer}
@media(max-width:580px){#cookie-banner{flex-direction:column;align-items:flex-start}.cookie-btns{width:100%}.cookie-accept,.cookie-decline{flex:1;text-align:center}}

/* ---- Social icon links (heritage gold→green blend, not brand colours) ---- */
.soc-ic{width:20px;height:20px;flex-shrink:0;display:block}
.foot-soc{display:flex;gap:1.8rem;flex-wrap:wrap;margin-bottom:.9rem}
.foot-soc a{display:inline-flex;align-items:center;gap:.55rem;font-size:.8rem;color:var(--muted);transition:color .2s}
.foot-soc a:hover{color:var(--ivory)}
.soc-row{display:inline-flex;gap:1.4rem;flex-wrap:wrap;align-items:center}
.soc-row a{display:inline-flex;align-items:center;gap:.45rem;color:inherit}
.soc-row a:hover{color:var(--gold-lt)}

/* ---- Brand intro / entrance splash (index only) ---- */
html.intro-active,html.intro-active body{overflow:hidden}
html:not(.intro-active) #mp-intro{display:none}
#mp-intro{position:fixed;inset:0;z-index:9999;background:#0A2017;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .8s ease;cursor:pointer;overflow:hidden}
#mp-intro.exit{opacity:0;pointer-events:none}
#mp-intro video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mp-intro-scrim{position:absolute;inset:0;background:radial-gradient(120% 100% at 50% 38%,transparent 52%,rgba(8,32,25,.5) 100%),linear-gradient(to top,rgba(8,32,25,.88),transparent 38%),linear-gradient(to bottom,rgba(8,32,25,.5),transparent 16%)}
.mp-intro-content{position:absolute;left:0;right:0;bottom:clamp(2.4rem,8vh,5rem);display:flex;flex-direction:column;align-items:center;gap:1.05rem;text-align:center;padding:0 1.5rem;z-index:2}
#mp-intro-enter{font-size:.82rem}
.mp-intro-hint{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
#mp-intro-skip{position:absolute;top:1.4rem;right:1.6rem;z-index:2;background:none;border:none;color:rgba(244,240,231,.72);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:color .2s;text-shadow:0 1px 6px rgba(8,32,25,.6)}
#mp-intro-skip:hover{color:var(--ivory)}
/* Portrait / narrow: letterbox so the full brand (incl. FARMS) is never cropped */
@media (max-aspect-ratio:16/9){#mp-intro{background:#B2CCAE}#mp-intro video{object-fit:contain}}
@media(prefers-reduced-motion:reduce){#mp-intro{transition:none}}
