/* Green Root Concepts — colors & typography strictly from PDF */
:root{
  --forest:#3d4a2a;       /* dark olive-forest background */
  --forest-deep:#2d3820;  /* deeper shadow */
  --cream:#e8e5d8;        /* paper cream */
  --cream-warm:#efecdf;
  --ink:#2a3418;          /* dark ink on cream */
  --sage:#6b7a3f;         /* subtle tape/accent green */
  --muted:rgba(232,229,216,.72);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--ink);font-family:'Cormorant Garamond',serif;font-weight:400;font-size:27px;line-height:1.6;-webkit-font-smoothing:antialiased}
@media(max-width:1024px){html,body{font-size:24px}}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Italiana',serif;font-weight:400;letter-spacing:.04em;line-height:1.05}
h1{font-size:clamp(2.6rem,6vw,5.6rem)}
h2{font-size:clamp(2rem,4.5vw,3.8rem)}
h3{font-size:clamp(1.4rem,2vw,1.9rem)}
.eyebrow{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:.32em;font-size:.78rem;font-weight:500}
.script{font-family:'Dancing Script',cursive;font-weight:500}

.container{max-width:2560px;margin:0 auto;padding:0 clamp(1.2rem,4vw,3rem)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;justify-content:space-between;align-items:center;padding:.6rem clamp(1.2rem,4vw,3rem);background:var(--forest);box-shadow:0 6px 24px rgba(0,0,0,.22);color:var(--cream)}
.nav .brand{display:flex;align-items:center}
.nav .brand img{height:58px;width:auto;display:block}
.burger{width:34px;height:22px;position:relative;cursor:pointer;background:none;border:0}
.burger span{position:absolute;left:0;right:0;height:1.5px;background:var(--cream);transition:transform .5s cubic-bezier(.7,0,.2,1),opacity .3s}
.burger span:nth-child(1){top:4px}
.burger span:nth-child(2){top:50%;transform:translateY(-50%)}
.burger span:nth-child(3){bottom:4px}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Menu overlay — scottresort-style slide-in */
.menu{position:fixed;inset:0;z-index:9000;isolation:isolate;background:var(--forest);color:var(--cream);clip-path:circle(0px at calc(100% - 40px) 40px);transition:clip-path 1.1s cubic-bezier(.77,0,.175,1);pointer-events:none;overflow:hidden}
body.menu-open .menu{clip-path:circle(250vmax at calc(100% - 40px) 40px);pointer-events:auto}
.menu-inner{position:relative;height:100%;width:100%;display:grid;grid-template-columns:1fr;align-content:center;padding:6rem clamp(1.2rem,6vw,5rem) 3rem;gap:2rem;z-index:1}
@media(min-width:900px){.menu-inner{grid-template-columns:1.4fr 1fr}}
.menu ul{list-style:none}
.menu li{padding:.4rem 0}
.menu li a{display:inline-block;font-family:'Italiana',serif;font-size:clamp(2.2rem,5vw,4.5rem);line-height:1.1;letter-spacing:.04em;opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .9s cubic-bezier(.7,0,.2,1);position:relative}
.menu li a::after{content:'';position:absolute;left:0;right:100%;bottom:.1em;height:1px;background:var(--cream);transition:right .6s ease}
.menu li a:hover::after{right:0}
body.menu-open .menu li a{opacity:1;transform:translateY(0)}
body.menu-open .menu li:nth-child(1) a{transition-delay:.35s}
body.menu-open .menu li:nth-child(2) a{transition-delay:.42s}
body.menu-open .menu li:nth-child(3) a{transition-delay:.49s}
body.menu-open .menu li:nth-child(4) a{transition-delay:.56s}
body.menu-open .menu li:nth-child(5) a{transition-delay:.63s}
.menu-aside{align-self:end;opacity:0;transform:translateY(20px);transition:all .7s ease .7s;border-top:1px solid rgba(232,229,216,.25);padding-top:1.5rem;font-size:.95rem;color:var(--muted)}
body.menu-open .menu-aside{opacity:1;transform:none}
.menu-aside p+p{margin-top:.4rem}

/* HERO — full-bleed leaf image with overlaid text */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:#0e150a url(../assets/img/hero-leaf.jpg) center/cover no-repeat;color:var(--cream);overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,28,10,.78) 0%,rgba(20,28,10,.55) 38%,rgba(20,28,10,.15) 70%,rgba(20,28,10,.35) 100%);z-index:0}
.hero-visual{display:none}
#particles{position:absolute;inset:0;pointer-events:none;z-index:1}
.hero-text{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;padding:clamp(5rem,10vw,9rem) clamp(1.5rem,6vw,6rem);width:100%;max-width:1400px;margin:0 auto;text-align:center;align-items:center;min-height:100vh}
.hero-text h1{max-width:18ch}
.hero-mark{width:min(440px,75%);margin-bottom:2.5rem;opacity:1}
.hero h1{font-size:clamp(2.8rem,6vw,5.4rem);line-height:1.02}
.hero .tag{margin-top:1.5rem;font-size:.82rem}
.hero .by{margin-top:2rem;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
@media(max-width:700px){.hero-text{max-width:100%}}

/* Sections */
section{padding:clamp(4rem,9vw,8rem) 0;position:relative}
.sec-forest{background:var(--forest);color:var(--cream)}
.sec-forest h1,.sec-forest h2,.sec-forest h3{color:var(--cream)}
.sec-cream{background:var(--cream);color:var(--ink)}

.divider{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1.2rem 0 2.5rem;opacity:.6}
.divider::before,.divider::after{content:'';flex:1;max-width:180px;height:1px;background:currentColor}
.divider span{font-size:.6rem;letter-spacing:.4em}

.center{text-align:center}
.lede{max-width:62ch;margin:0 auto;font-size:1.15rem}

/* Grids */
.grid{display:grid;gap:clamp(1.5rem,3vw,2.5rem)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-4{grid-template-columns:repeat(2,1fr)}
@media(min-width:900px){.g-4{grid-template-columns:repeat(4,1fr)}}
.g-3{grid-template-columns:repeat(2,1fr)}
@media(min-width:900px){.g-3{grid-template-columns:repeat(3,1fr)}}
.g-split{grid-template-columns:1fr}
@media(min-width:900px){.g-split{grid-template-columns:1fr 1fr;align-items:center}}

/* Pillar card */
.pillar{text-align:center;padding:1rem}
.pillar .icon{width:96px;height:96px;margin:0 auto 1.2rem;display:flex;align-items:center;justify-content:center;opacity:.9}
.pillar .icon img{max-width:100%;max-height:100%;object-fit:contain}
.pillar h3{margin-bottom:.6rem}
.pillar p{font-size:.98rem;opacity:.82}

/* Oval image frame (matches PDF) */
.oval{border-radius:50%/48%;overflow:hidden;aspect-ratio:3/4;background:#111}
.oval img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s ease}
.oval:hover img{transform:scale(1.05)}

/* Offerings list */
.offerings{list-style:none;margin-top:1.5rem}
.offerings li{padding:.55rem 0 .55rem 1.6rem;position:relative;border-bottom:1px solid rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.1em;font-size:.82rem}
.sec-cream .offerings li{border-bottom-color:rgba(42,52,24,.15)}
.offerings li::before{content:'';position:absolute;left:0;top:1.15em;width:10px;height:10px;border:1px solid currentColor;border-radius:50%;opacity:.7}

/* Quote section */
.quote{min-height:85vh;display:flex;align-items:center;justify-content:center;background:#000;position:relative;color:var(--cream);text-align:center;padding:3rem}
.quote::before{content:'';position:absolute;inset:0;background:url(../assets/img/waterfall.jpg) center/cover;opacity:.55}
.quote::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(61,74,42,.5))}
.quote blockquote{position:relative;z-index:1;max-width:56ch;font-family:'Italiana',serif;font-size:clamp(1.5rem,3vw,2.6rem);line-height:1.25}
.quote cite{display:block;margin-top:1.5rem;font-style:normal;letter-spacing:.3em;font-size:.78rem;text-transform:uppercase}

/* Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:all 1.1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* Ripple on buttons/links */
.btn{display:inline-block;position:relative;padding:1rem 2.2rem;border:1px solid currentColor;text-transform:uppercase;letter-spacing:.28em;font-size:.74rem;overflow:hidden;cursor:pointer;background:none;color:inherit}
.btn span{position:relative;z-index:1}
.btn::before{content:'';position:absolute;left:50%;top:50%;width:0;height:0;border-radius:50%;background:currentColor;opacity:.12;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}
.btn:hover::before{width:340px;height:340px}

/* Footer */
footer{background:var(--forest-deep);color:var(--muted);padding:3rem 0;text-align:center;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase}
footer .brand{font-family:'Italiana',serif;font-size:1.1rem;color:var(--cream);letter-spacing:.2em;margin-bottom:.8rem;display:block}

/* Ethos constellation */
.ethos{position:relative;min-height:90vh;background:url(../assets/img/pine-bg.jpg) center/cover;color:var(--cream);padding:6rem 0}
.ethos::before{content:'';position:absolute;inset:0;background:rgba(20,28,10,.55)}
.ethos .container{position:relative;z-index:1}
.ethos-grid{display:grid;gap:2rem;grid-template-columns:repeat(2,1fr);margin-top:3rem}
@media(min-width:900px){.ethos-grid{grid-template-columns:repeat(3,1fr)}}
.ethos-item{padding:1.5rem}
.ethos-item .num{font-family:'Italiana',serif;font-size:.9rem;letter-spacing:.3em;opacity:.7;margin-bottom:.4rem}
.ethos-item p{font-size:.95rem;opacity:.8;margin-top:.6rem}

/* Impact timeline */
.impact{display:grid;gap:2rem;grid-template-columns:repeat(2,1fr);margin-top:3rem}
@media(min-width:900px){.impact{grid-template-columns:repeat(3,1fr)}}
.impact figure{position:relative}
.impact figure{text-align:center}
.impact img{width:100%;max-width:300px;aspect-ratio:1/1;object-fit:cover;border-radius:50%;margin:0 auto}
.impact figure h3{margin-top:2.2rem}
.impact .num{margin:1.4rem 0 .5rem;font-size:.8rem;letter-spacing:.3em;opacity:.75}

/* Contact card */
.contact-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:900px){.contact-grid{grid-template-columns:1.1fr 1fr}}
.contact-info p{padding:1.2rem 0;border-bottom:1px solid rgba(232,229,216,.25);letter-spacing:.15em;font-size:.95rem}
.contact-info p:first-child{border-top:1px solid rgba(232,229,216,.25)}

/* Subtle leaf decor */
.leaf-accent{position:absolute;width:220px;opacity:.18;pointer-events:none}

/* Tape (matches Dali page) */
.tape-frame{position:relative;background:var(--cream-warm);padding:1rem 1rem 3rem;box-shadow:0 30px 80px rgba(0,0,0,.35);transform:rotate(-1deg)}
.tape-frame::before,.tape-frame::after{content:'';position:absolute;width:110px;height:26px;background:var(--sage);opacity:.75;top:-14px;left:20%}
.tape-frame::after{left:auto;right:20%;top:auto;bottom:-14px;transform:rotate(2deg)}
.tape-frame .cap{text-align:center;margin-top:1rem;letter-spacing:.3em;font-size:.7rem;text-transform:uppercase;color:var(--ink)}

@media(max-width:700px){
  html,body{font-size:19px}
  .hero-text{padding:7rem 1.2rem 3rem;text-align:center}
  .hero-text h1{font-size:clamp(2.4rem,11vw,3.6rem);max-width:14ch}
  .menu li a{font-size:2.2rem}
  .nav{padding:1rem 1.2rem}
  .nav .brand img{height:64px}
  section{padding:4rem 0}
  .container{padding:0 1.2rem}
  .grid{gap:1.5rem}
  h1{font-size:clamp(2.4rem,9vw,3.6rem)}
  h2{font-size:clamp(1.9rem,7vw,2.6rem)}
  .lede{font-size:1rem}
  .pillar h3{font-size:1.15rem}
  .pillar p{font-size:.95rem}
  .quote blockquote{font-size:1.3rem;line-height:1.4}
  .impact figure h3{font-size:1.2rem;margin-top:1.4rem}
  .ethos-item{padding:.6rem}
  .menu-inner{padding:5rem 1.4rem 2rem}
  .menu-aside{font-size:.85rem}
  .offerings li{font-size:.72rem}
}
