/* ===== VYDA — shared design system ===== */
:root{
  --ivory:#F4F0E6; --ivory-2:#FAF7EF; --sage:#8A8468; --forest:#3F5147;
  --green:#222824; --green-2:#2C332F; --gold:#B89B5E; --gold-soft:#C9B27E; --ink:#2A2A26;
  --sans:'Inter',-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  --display:'Jost',-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--ivory);line-height:1.85;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.dz{font-family:var(--display);font-weight:200;line-height:1.12;letter-spacing:.01em}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
.wrap{max-width:1200px;margin:0 auto;padding:0 40px}
.narrow{max-width:840px;margin:0 auto;padding:0 40px}
.eyebrow{font-family:var(--display);font-size:12px;letter-spacing:.42em;text-transform:uppercase;color:var(--sage);font-weight:400}
.rule{width:1px;height:64px;background:linear-gradient(var(--gold),transparent);margin:0 auto}
.grule{width:46px;height:1px;background:var(--gold);border:0;margin:30px auto}
.ornament{display:flex;align-items:center;justify-content:center;gap:18px;margin:30px 0}
.ornament .l{width:70px;height:1px;background:var(--gold);opacity:.8}
.ornament .d{color:var(--gold);font-size:11px;letter-spacing:.2em}

/* scroll progress */
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--gold);z-index:60;transition:width .1s linear}

/* enter button + intro veil */
.enter-btn{display:inline-flex;align-items:center;gap:14px;font-family:var(--display);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:#f1ead9;background:transparent;border:1px solid rgba(201,178,126,.55);padding:16px 34px;cursor:pointer;transition:.45s;font-weight:400}
.enter-btn:hover{background:rgba(201,178,126,.14);border-color:var(--gold-soft);letter-spacing:.4em}
#enter-veil{position:fixed;inset:0;z-index:80;background:var(--green);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .9s ease}
#enter-veil.show{opacity:1;pointer-events:auto}
#enter-veil.lift{opacity:0}
.veil-mark{width:118px;opacity:0;filter:brightness(0) invert(1);position:relative;z-index:2}
#enter-veil.show .veil-mark{animation:markIn 1.7s ease forwards}
.veil-ring{position:absolute;width:0;height:0;border:1px solid var(--gold-soft);border-radius:50%;opacity:0}
#enter-veil.show .veil-ring{animation:ringExp 1.9s ease forwards}
.veil-word{position:absolute;bottom:34%;font-family:var(--display);font-size:11px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold-soft);opacity:0}
#enter-veil.show .veil-word{animation:wordIn 1.9s ease forwards}
@keyframes markIn{0%{opacity:0;transform:scale(.82)}45%{opacity:1}100%{opacity:1;transform:scale(1)}}
@keyframes ringExp{0%{width:0;height:0;opacity:0}30%{opacity:.65}100%{width:360px;height:360px;opacity:0}}
@keyframes wordIn{0%{opacity:0;letter-spacing:.3em}50%{opacity:1}100%{opacity:.9;letter-spacing:.5em}}

/* enquiry / action links */
.enq{display:inline-block;font-family:var(--display);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--forest);border-bottom:1px solid var(--gold);padding-bottom:5px;transition:.4s;font-weight:400}
.enq:hover{color:var(--gold);letter-spacing:.24em}
.enq.light{color:#efe9da;border-color:var(--gold-soft)}
.enq.light:hover{color:#fff}

.reveal{opacity:0;transform:translateY(26px);transition:opacity 1.1s ease,transform 1.1s ease}
.reveal.in{opacity:1;transform:none}

/* ===== header (symmetrical) ===== */
header{position:fixed;top:0;left:0;right:0;z-index:50;padding:24px 0;transition:background .5s ease,padding .5s ease,box-shadow .5s ease}
header.solid{background:rgba(244,240,230,.97);padding:14px 0;box-shadow:0 1px 0 rgba(42,42,38,.08);backdrop-filter:saturate(120%) blur(8px)}
.headbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;max-width:1200px;margin:0 auto;padding:0 40px}
.nav-left,.nav-right{display:flex;gap:36px}
.nav-left{grid-column:1;justify-self:start}
.nav-right{grid-column:3;justify-self:end}
.brand{grid-column:2;justify-self:center}
.brand img{height:34px;transition:filter .5s ease,height .5s ease}
.over-dark .brand img{filter:brightness(0) invert(1)}
header.solid .brand img{filter:none;height:30px}
.headbar a.navlink{font-family:var(--display);font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink);opacity:.82;transition:.3s;font-weight:400;position:relative}
.over-dark .headbar a.navlink{color:#efe9da}
header.solid .headbar a.navlink{color:var(--ink)}
.headbar a.navlink:hover{opacity:1;color:var(--gold)}
.over-dark .headbar a.navlink:hover{color:var(--gold-soft)}
.burger{display:none;background:none;border:0;cursor:pointer;color:inherit;grid-column:3;justify-self:end;width:30px;height:20px;position:relative}
.burger span{position:absolute;left:0;width:100%;height:1px;background:currentColor;transition:.3s}
.burger span:nth-child(1){top:3px}.burger span:nth-child(2){top:50%}.burger span:nth-child(3){bottom:3px}
.over-dark .burger{color:#efe9da}header.solid .burger{color:var(--ink)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;background:var(--ivory);z-index:70;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;transform:translateY(-102%);transition:transform .55s cubic-bezier(.7,0,.2,1)}
.mobile-menu.open{transform:none}
.mobile-menu img{height:34px;margin-bottom:14px}
.mobile-menu a{font-family:var(--display);font-size:19px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);font-weight:300}
.mobile-menu a:hover{color:var(--gold)}
.mobile-menu .mclose{position:absolute;top:26px;right:30px;font-size:26px;color:var(--ink);background:none;border:0;cursor:pointer;line-height:1}
.mobile-menu .memail{font-family:var(--display);font-size:12px;letter-spacing:.18em;color:var(--sage);margin-top:14px}

/* ===== hero ===== */
.hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ivory);
  background:linear-gradient(rgba(20,26,21,.52),rgba(20,26,21,.6)),url('hero-plantation.jpg') center/cover no-repeat;background-attachment:fixed}
.hero-inner{max-width:900px;padding:0 32px}
.hero .emblem{height:52px;margin:0 auto 26px;opacity:.95;filter:brightness(0) invert(1)}
.hero .eyebrow{color:#ded6c2}
.hero h1{font-size:clamp(40px,7vw,92px);margin:22px 0 0;font-weight:200}
.hero p{font-size:clamp(15px,1.5vw,19px);font-weight:300;max-width:540px;margin:0 auto;color:#ece6d8;letter-spacing:.03em}
.hero .ornament .l{background:var(--gold-soft)}
.scroll-cue{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);text-align:center}
.scroll-cue span{font-family:var(--display);font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:#cfc8b6;display:block;margin-bottom:12px}
.scroll-cue .rule{height:46px}

/* inner page hero */
.page-hero{position:relative;height:60vh;min-height:420px;display:flex;align-items:flex-end;color:var(--ivory);background-position:center;background-size:cover;background-repeat:no-repeat}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,26,21,.22),rgba(20,26,21,.62))}
.page-hero .wrap{position:relative;z-index:2;padding-bottom:60px}
.page-hero .eyebrow{color:#ded6c2}
.page-hero h1{font-size:clamp(34px,5.5vw,66px);margin-top:14px;font-weight:200}

/* manifesto */
.manifesto{position:relative;z-index:4;text-align:center;padding:clamp(110px,15vw,180px) 0}
.manifesto img{height:46px;margin:0 auto 12px;opacity:.9}
.manifesto p{font-family:var(--display);font-size:clamp(23px,2.7vw,34px);font-weight:200;line-height:1.5;max-width:900px;margin:0 auto;color:var(--green)}

/* cinematic */
.cine{position:relative;height:90vh;min-height:580px;display:flex;align-items:flex-end;justify-content:center;text-align:center;color:var(--ivory);background-position:center;background-size:cover;background-repeat:no-repeat;background-attachment:fixed}
.cine::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(15,20,16,.18),rgba(15,20,16,.62))}
.cine-inner{position:relative;z-index:2;padding-bottom:clamp(70px,10vw,120px)}
.cine .eyebrow{color:#e4dcc6}
.cine h2{font-size:clamp(30px,4vw,52px);margin-top:16px;font-weight:200}

/* virtues */
.virtues{position:relative;z-index:4;padding:clamp(110px,14vw,170px) 0;background:var(--ivory-2)}
.virtue{max-width:760px;margin:0 auto;text-align:center;padding:clamp(46px,6vw,72px) 0}
.virtue + .virtue{border-top:1px solid rgba(42,42,38,.12)}
.virtue .num{font-family:var(--display);font-size:13px;letter-spacing:.5em;color:var(--gold);font-weight:400}
.virtue h3{font-size:clamp(26px,3vw,38px);margin:18px 0 20px;color:var(--green);font-weight:200}
.virtue p{font-size:17px;color:#4c4c44;max-width:580px;margin:0 auto}

/* split */
.split{position:relative;z-index:4;display:grid;grid-template-columns:1fr 1fr;align-items:center;background:var(--ivory)}
.split .img img{width:100%;height:100%;object-fit:cover;min-height:640px}
.split .txt{padding:clamp(60px,8vw,110px)}
.split .txt .eyebrow{color:var(--sage)}
.split .txt h2{font-size:clamp(30px,3.6vw,46px);color:var(--green);margin:18px 0 24px;font-weight:200}
.split .txt p{font-size:16.5px;color:#46463f;margin-bottom:22px;max-width:470px}
.specs{list-style:none;margin:30px 0 36px;border-top:1px solid rgba(42,42,38,.16)}
.specs li{display:flex;justify-content:space-between;font-size:14px;padding:15px 0;border-bottom:1px solid rgba(42,42,38,.12);color:var(--green)}
.specs li span:first-child{font-family:var(--display);letter-spacing:.22em;text-transform:uppercase;color:var(--sage);font-size:11.5px;font-weight:400}

/* gallery */
.gallery{position:relative;z-index:4;padding:clamp(100px,13vw,160px) 0;background:var(--ivory-2)}
.gallery .head{text-align:center;margin-bottom:64px}
.gallery .head h2{font-size:clamp(28px,3.4vw,44px);color:var(--green);font-weight:200;margin-top:16px}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:1240px;margin:0 auto;padding:0 24px}
.gal-grid figure{overflow:hidden;background:var(--ivory)}
.gal-grid img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform 1.2s ease}
.gal-grid figure:hover img{transform:scale(1.05)}

/* stats */
.stats{position:relative;z-index:4;background:var(--green);color:var(--ivory);text-align:center;padding:clamp(80px,10vw,120px) 0}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px}
.stat .n{font-family:var(--display);font-size:clamp(40px,5vw,60px);font-weight:200;color:var(--gold-soft)}
.stat .l{font-family:var(--display);font-size:12px;letter-spacing:.28em;color:#cdd2c8;margin-top:14px;text-transform:uppercase}
.stat + .stat{border-left:1px solid rgba(201,178,126,.22)}

/* assurances */
.assure{position:relative;z-index:4;text-align:center;padding:clamp(90px,11vw,140px) 0;background:var(--ivory)}
.assure .eyebrow{color:var(--sage)}
.assure h2{font-size:clamp(26px,3vw,40px);color:var(--green);font-weight:200;margin:16px 0 8px}
.assure .sub{font-size:16px;color:#56564e;max-width:560px;margin:0 auto 60px}
.creds{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;max-width:980px;margin:0 auto;padding:0 24px}
.cred{padding:34px 18px;border:1px solid rgba(42,42,38,.14);background:var(--ivory-2)}
.cred .mk{width:46px;height:46px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--gold);font-size:20px}
.cred h4{font-family:var(--display);font-size:14px;letter-spacing:.16em;text-transform:uppercase;color:var(--green);font-weight:400;margin-bottom:6px}
.cred p{font-size:12.5px;color:#6a6a60;letter-spacing:.04em}

/* house / founder */
.house .img img{min-height:620px}
.house .txt h2{font-size:clamp(28px,3.4vw,44px);color:var(--green);margin:18px 0 22px;font-weight:200}
.house .txt p{font-size:16.5px;color:#46463f;margin-bottom:20px;max-width:480px}
.signature{font-family:var(--display);font-size:15px;letter-spacing:.08em;color:var(--green);margin-top:8px}
.signature span{display:block;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);margin-top:4px}

/* timeline */
.timeline{position:relative;z-index:4;max-width:760px;margin:0 auto;padding:clamp(90px,11vw,150px) 40px}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:34px;padding:34px 0;border-top:1px solid rgba(42,42,38,.12)}
.tl-item .yr{font-family:var(--display);font-size:24px;color:var(--gold);font-weight:300}
.tl-item h3{font-family:var(--display);font-size:20px;color:var(--green);font-weight:300;margin-bottom:10px}
.tl-item p{font-size:15.5px;color:#4c4c44}

/* prose */
.prose{position:relative;z-index:4;padding:clamp(80px,10vw,130px) 0;background:var(--ivory)}
.prose p{font-size:17px;color:#43433c;margin-bottom:26px}
.prose .lead{font-family:var(--display);font-size:clamp(20px,2.3vw,27px);font-weight:200;line-height:1.5;color:var(--green);margin-bottom:36px}
.pullquote{position:relative;z-index:4;font-family:var(--display);font-size:clamp(22px,2.6vw,30px);font-weight:200;line-height:1.45;color:var(--green);text-align:center;max-width:820px;margin:clamp(60px,8vw,90px) auto;padding:0 40px;background:var(--ivory)}

/* enquiry */
.enquiry{position:relative;z-index:4;text-align:center;padding:clamp(120px,16vw,200px) 0;background:var(--ivory)}
.enquiry img{height:42px;margin:0 auto 18px;opacity:.85}
.enquiry h2{font-size:clamp(30px,4vw,52px);color:var(--green);font-weight:200;margin-bottom:24px}
.enquiry p{font-size:17.5px;color:#4c4c44;max-width:600px;margin:0 auto 48px}
.enq-links{display:flex;gap:56px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.enq-mail{font-family:var(--display);font-size:12.5px;letter-spacing:.16em;color:var(--sage)}
.enq-mail a{border-bottom:1px solid var(--gold);padding-bottom:2px}

/* form */
.form-wrap{position:relative;z-index:4;max-width:660px;margin:0 auto;padding:clamp(60px,8vw,90px) 40px clamp(100px,12vw,150px);background:var(--ivory)}
.form-wrap .intro{text-align:center;margin-bottom:54px}
.form-wrap .intro h1{font-size:clamp(30px,4vw,48px);color:var(--green);font-weight:200;margin:16px 0 18px}
.form-wrap .intro p{font-size:16.5px;color:#4c4c44;max-width:520px;margin:0 auto}
.field{margin-bottom:22px}
.field.row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
label{display:block;font-family:var(--display);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);margin-bottom:9px;font-weight:400}
input,select,textarea{width:100%;background:var(--ivory-2);border:1px solid rgba(42,42,38,.2);padding:14px 15px;font-family:var(--sans);font-size:15px;color:var(--ink);transition:border .3s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
textarea{min-height:130px;resize:vertical}
.submit{margin-top:14px;text-align:center}
button.send{font-family:var(--display);font-size:13px;letter-spacing:.24em;text-transform:uppercase;padding:16px 44px;border:1px solid var(--green);background:var(--green);color:var(--ivory);cursor:pointer;transition:.4s;font-weight:400}
button.send:hover{background:transparent;color:var(--green)}
.form-foot{text-align:center;margin-top:30px;font-family:var(--display);font-size:12.5px;letter-spacing:.14em;color:var(--sage)}
.form-foot a{border-bottom:1px solid var(--gold);padding-bottom:2px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-err{color:#9a4a3a}
.confirm{display:none;text-align:center;padding:60px 20px}
.confirm.show{display:block}
.confirm .mk{font-size:34px;color:var(--gold);margin-bottom:18px}
.confirm h3{font-family:var(--display);font-size:26px;color:var(--green);font-weight:200;margin-bottom:14px}
.confirm p{font-size:16px;color:#4c4c44;max-width:440px;margin:0 auto}

/* footer */
footer{position:relative;z-index:4;background:var(--green);color:var(--ivory);text-align:center;padding:90px 0 46px}
footer .mono{height:50px;margin:0 auto 24px;opacity:.92}
footer .wordmark{height:24px;margin:0 auto 22px;filter:brightness(0) invert(1)}
footer .fmail{font-family:var(--display);font-size:12.5px;letter-spacing:.16em;color:var(--gold-soft);margin-bottom:26px}
footer .fnav{display:flex;justify-content:center;gap:38px;flex-wrap:wrap;margin-bottom:30px}
footer .fnav a{font-family:var(--display);font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:#cdd2c8;opacity:.85}
footer .fnav a:hover{opacity:1;color:var(--gold-soft)}
footer .fine{font-family:var(--display);font-size:12px;letter-spacing:.14em;color:#9aa399;line-height:2.2}

@media(max-width:880px){
  .nav-left,.nav-right{display:none}
  .burger{display:block}
  .split,.house .split{grid-template-columns:1fr}
  .split .txt{order:2}
  .split .img img,.house .img img{min-height:360px}
  .gal-grid{grid-template-columns:1fr 1fr;gap:10px;padding:0 16px}
  .stat-grid{grid-template-columns:1fr;gap:42px}
  .stat + .stat{border-left:0;border-top:1px solid rgba(201,178,126,.22);padding-top:42px}
  .creds{grid-template-columns:1fr 1fr;gap:14px}
  .tl-item{grid-template-columns:1fr;gap:8px}
  .field.row{grid-template-columns:1fr}
  .enq-links{gap:28px}
  .hero,.cine{background-attachment:scroll}
  .hero h1{font-size:clamp(38px,11vw,60px)}
  .wrap,.narrow{padding:0 24px}
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero,.cine{background-attachment:scroll}
}
