/* =====================================================================
   New Leaf Ventures — Homepage + signature sections
   ===================================================================== */

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  isolation:isolate;overflow:hidden;color:var(--on-dark);padding-bottom:clamp(3rem,7vw,6rem);}
.hero__poster,#hero-gl{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero__poster{z-index:-3;}
#hero-gl{z-index:-2;}
/* legible gradient over imagery */
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(20,42,32,.55) 0%,rgba(20,42,32,.15) 35%,rgba(20,42,32,.30) 70%,rgba(20,42,32,.82) 100%);}
.hero__content{position:relative;z-index:2;width:min(100% - 2*var(--gutter),var(--container));margin-inline:auto;}
.hero .eyebrow{color:var(--brass-lt);}
.hero .eyebrow::before{background:var(--brass-lt);}
.hero h1{color:#fff;max-width:18ch;text-shadow:0 2px 30px rgba(20,42,32,.4);}
.hero h1 em{font-style:italic;color:var(--brass-lt);}
.hero .lead{color:rgba(255,255,255,.9);max-width:50ch;margin-top:1.3rem;text-shadow:0 1px 14px rgba(20,42,32,.35);}
.hero .cta-row{margin-top:2rem;}
.hero__meta{display:flex;gap:2rem;margin-top:2.5rem;flex-wrap:wrap;align-items:center;}
.hero__meta .m{display:flex;flex-direction:column;}
.hero__meta .m b{font-family:var(--serif);font-size:1.7rem;color:var(--brass-lt);line-height:1;}
.hero__meta .m span{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:.3rem;}
.hero__scroll{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:2;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.75);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;}
.hero__scroll::after{content:"";width:1px;height:34px;background:linear-gradient(var(--brass-lt),transparent);animation:scrolldot 2s var(--ease) infinite;}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top;}40%{transform:scaleY(1);transform-origin:top;}60%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}
html.calm .hero__scroll::after{animation:none;}

/* split intro */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
.split.rev{direction:rtl;}.split.rev>*{direction:ltr;}
@media(max-width:860px){.split{grid-template-columns:1fr;}.split.rev{direction:ltr;}}
.split__media{position:relative;}
.split__media .frame{aspect-ratio:4/5;}
.split__badge{position:absolute;bottom:-1.4rem;right:-1.4rem;background:var(--cream);border-radius:var(--r-md);
  padding:1.1rem 1.3rem;box-shadow:var(--shadow-lg);text-align:center;border:1px solid var(--line-soft);max-width:200px;}
.split__badge b{font-family:var(--serif);font-size:2.2rem;color:var(--forest);display:block;line-height:1;}
.split__badge span{font-size:.82rem;color:var(--ink-soft);}
@media(max-width:520px){.split__badge{right:1rem;bottom:1rem;padding:.8rem 1rem;}.split__badge b{font-size:1.6rem;}}

/* trust strip */
.trust-strip{border-block:1px solid var(--line-soft);background:var(--cream);}
.trust-strip .inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-block:1.5rem;}
.trust-strip .ts-item{display:flex;align-items:center;gap:.7rem;font-weight:500;color:var(--ink-soft);font-size:.95rem;}
.trust-strip .ts-item svg{width:1.4em;color:var(--leaf);flex:none;}

/* ---------- BEFORE / AFTER SLIDER (signature interaction) ---------- */
.ba{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);
  aspect-ratio:16/10;user-select:none;touch-action:pan-y;cursor:ew-resize;}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;}
.ba__after{clip-path:inset(0 0 0 var(--pos,50%));} /* right portion = after */
.ba__label{position:absolute;top:1rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  color:#fff;background:rgba(20,42,32,.6);padding:.35rem .7rem;border-radius:var(--r-pill);backdrop-filter:blur(4px);z-index:3;}
.ba__label.before{left:1rem;}
.ba__label.after{right:1rem;background:rgba(176,137,79,.85);}
.ba__handle{position:absolute;top:0;bottom:0;left:var(--pos,50%);width:3px;background:#fff;
  transform:translateX(-50%);z-index:4;box-shadow:0 0 16px rgba(0,0,0,.3);}
.ba__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;
  background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);color:var(--forest);}
.ba__grip svg{width:26px;}
.ba__hint{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);z-index:3;color:#fff;font-size:.8rem;
  background:rgba(20,42,32,.55);padding:.35rem .9rem;border-radius:var(--r-pill);backdrop-filter:blur(4px);transition:opacity .4s;}
.ba.touched .ba__hint{opacity:0;}

/* ---------- process steps (sticky stack-ish) ---------- */
.steps{display:grid;gap:1.2rem;}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;background:var(--surface);
  border:1px solid var(--line-soft);border-radius:var(--r-md);padding:clamp(1.4rem,3vw,2rem);box-shadow:var(--shadow-sm);}
.step__n{font-family:var(--serif);font-size:1.6rem;color:#fff;background:var(--leaf);width:56px;height:56px;
  border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;box-shadow:var(--shadow-sm);}
.step h3{margin-bottom:.35rem;}
.step p{color:var(--ink-soft);margin:0;}
@media(min-width:861px){.steps{grid-template-columns:repeat(2,1fr);}}

/* ---------- featured project parallax ---------- */
.feature-band{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden;isolation:isolate;color:var(--on-dark);}
.feature-band__bg{position:absolute;inset:-12% 0;z-index:-2;}
.feature-band__bg img{width:100%;height:100%;object-fit:cover;}
.feature-band::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(20,42,32,.88),rgba(20,42,32,.5) 60%,rgba(20,42,32,.25));}
.feature-band .card-glass{background:rgba(20,42,32,.4);border:1px solid rgba(241,239,230,.18);backdrop-filter:blur(8px);
  border-radius:var(--r-md);padding:clamp(1.6rem,3vw,2.6rem);max-width:560px;}
.feature-band h2{color:#fff;}
.feature-band p{color:var(--on-dark-soft);}

/* ---------- testimonials row ---------- */
.tst-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;}
@media(max-width:760px){.tst-grid{grid-template-columns:1fr;}}

/* ---------- areas teaser ---------- */
.areas-list{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem;}
.areas-list span{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-pill);
  padding:.5rem 1.1rem;font-size:.92rem;color:var(--ink-soft);font-weight:500;}

/* ---------- final CTA ---------- */
.cta-band{position:relative;background:var(--forest);color:var(--on-dark);border-radius:var(--r-lg);
  padding:clamp(2.5rem,6vw,5rem);text-align:center;overflow:hidden;isolation:isolate;}
.cta-band::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background:radial-gradient(70% 120% at 50% -20%,var(--leaf),transparent 60%),radial-gradient(50% 80% at 10% 120%,var(--brass),transparent 60%);}
.cta-band h2{color:#fff;max-width:20ch;margin-inline:auto;}
.cta-band .lead{color:rgba(255,255,255,.85);margin:1rem auto 0;}
.cta-band__leaf{position:absolute;font-size:22vw;font-family:var(--serif);font-style:italic;color:rgba(203,169,104,.07);
  right:-2%;bottom:-8%;line-height:.7;pointer-events:none;z-index:-1;}

/* gallery grid (gallery.html + homepage teaser) */
.gallery-grid{columns:3;column-gap:1.2rem;}
.gallery-grid .g-item{break-inside:avoid;margin-bottom:1.2rem;border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--shadow-sm);position:relative;display:block;}
.gallery-grid .g-item img{width:100%;transition:transform .8s var(--ease);}
.gallery-grid .g-item:hover img{transform:scale(1.05);}
.gallery-grid .g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1rem .9rem;
  background:linear-gradient(transparent,rgba(20,42,32,.8));color:#fff;font-size:.9rem;font-weight:500;
  opacity:0;transform:translateY(8px);transition:.4s var(--ease);}
.gallery-grid .g-item:hover figcaption{opacity:1;transform:translateY(0);}
@media(max-width:900px){.gallery-grid{columns:2;}}
@media(max-width:560px){.gallery-grid{columns:1;}}
