/* ============================================================
   IYADI PLANNING SOLUTIONS — shared design system
   Multi-page cinematic build · light / airy / architectural
   ============================================================ */

:root{
  --green:      #2b7a2b;
  --green-2:    #2b7a2b;
  --green-deep: #1a4d1a;
  --green-ink:  #133a13;
  --green-bright:#37a437;
  --gold:       #c9a327;
  --gold-2:     #e3c265;
  --gold-deep:  #9c7611;
  --ink:        #0d0d0d;
  --ink-2:      #44504a;
  --paper:      #fafaf7;
  --sage:       #eff4ec;
  --line:       rgba(13,13,13,.12);
  --line-soft:  rgba(13,13,13,.07);

  --maxw: 1320px;
  --gutter: clamp(20px, 5vw, 72px);

  --font-display: "Playfair Display", Georgia, serif;
  --font-sans: "Plus Jakarta Sans", system-ui, sans-serif;
  --font-mono: "Space Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.25,.46,.45,.94);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-in-out: cubic-bezier(.76,0,.24,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  --nav-h: 86px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--font-sans); background:var(--paper); color:var(--ink);
  line-height:1.6; font-weight:400; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  opacity:0; transition:opacity .5s var(--ease);
}
body.page-ready{ opacity:1; }
body.is-locked{ overflow:hidden; }

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--green); color:#fff; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:1.02;
  letter-spacing:-.01em; text-wrap:balance; }
.eyebrow{ display:inline-flex; align-items:center; gap:.7em; font-family:var(--font-mono);
  font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--green);
  font-weight:400; }
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--green); display:inline-block; }
.eyebrow.gold{ color:var(--gold-deep); } .eyebrow.gold::before{ background:var(--gold); }
.eyebrow.light{ color:rgba(255,255,255,.8); } .eyebrow.light::before{ background:var(--gold-2); }
.section-title{ font-size:clamp(2.3rem,5.6vw,4.8rem); }
.lead{ font-size:clamp(1.05rem,1.6vw,1.32rem); color:var(--ink-2); line-height:1.62;
  font-weight:400; max-width:48ch; }

/* ---------- reveal ---------- */
[data-reveal]{ opacity:0; transform:translateY(40px); transition:opacity .9s var(--ease),
  transform 1s var(--ease); will-change:transform,opacity; }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal="fade"]{ transform:none; }
[data-reveal="left"]{ transform:translateX(-46px); }
[data-reveal="right"]{ transform:translateX(46px); }
[data-reveal="scale"]{ transform:scale(.92); }
[data-reveal="clip"]{ opacity:1; clip-path:inset(100% 0 0 0); transform:translateY(20px);
  transition:clip-path 1s var(--ease-out), transform 1s var(--ease-out); }
[data-reveal="clip"].in{ clip-path:inset(0 0 0 0); transform:none; }
[data-delay]{ transition-delay:var(--d,0ms); }

.kinetic .word{ display:inline-block; vertical-align:top; }
.kinetic .word > span{ display:inline-block; transform:translateY(.55em); opacity:0;
  transition:transform .9s var(--ease-out), opacity .7s var(--ease-out); }
.kinetic.in .word > span{ transform:none; opacity:1; }
.kinetic .ksp{ display:inline-block; width:.27em; }
.chars .ch{ display:inline-block; opacity:0; transform:translateY(.5em);
  transition:opacity .5s var(--ease), transform .6s var(--ease-out); }
.chars.in .ch{ opacity:1; transform:none; }

/* ---------- blueprint grid overlay ---------- */
.bp-grid{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:0;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),
    linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:62px 62px;
  mask-image:radial-gradient(120% 95% at 72% 35%,#000 25%,transparent 82%);
  animation:bpIn 1.4s var(--ease) .3s forwards; }
@keyframes bpIn{ 0%{opacity:.8;} 100%{opacity:.5;} }

/* ============================================================
   PAGE TRANSITION + PROGRESS
   ============================================================ */
.page-fade{ position:fixed; inset:0; z-index:210; background:var(--green-deep);
  transform:scaleY(0); transform-origin:bottom; pointer-events:none;
  transition:transform .45s var(--ease-in-out); }
.page-fade.show{ transform:scaleY(1); transform-origin:top; }
.scroll-prog{ position:fixed; top:0; left:0; height:3px; z-index:160;
  background:linear-gradient(90deg,var(--green),var(--gold-2)); width:0; }

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{ position:fixed; inset:0; z-index:300; background:var(--green-deep);
  display:grid; place-items:center; }
.pre-inner{ text-align:center; color:#fff; }
.pre-mark{ display:inline-block; background:#fff; border-radius:18px; padding:22px 30px;
  margin:0 auto 30px; box-shadow:0 30px 70px -30px rgba(0,0,0,.6);
  opacity:0; transform:translateY(14px) scale(.94); animation:preMarkIn .9s var(--ease-spring) .15s forwards; }
.pre-mark img{ height:clamp(64px,9vw,84px); width:auto; display:block; }
@keyframes preMarkIn{ to{ opacity:1; transform:none; } }
.draw{ stroke-dasharray:var(--len,200); stroke-dashoffset:var(--len,200);
  animation:draw 1.5s var(--ease-out) .2s forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
.pre-pop{ opacity:0; transform:translateY(10px) scale(.8); transform-box:fill-box;
  transform-origin:bottom; animation:pop .6s var(--ease-spring) 1.1s forwards; }
@keyframes pop{ to{ opacity:1; transform:none; } }
.pre-word{ font-family:var(--font-display); font-weight:800; letter-spacing:.01em;
  font-size:clamp(1.3rem,3.4vw,2.1rem); color:#fff; }
.pre-word .l{ display:inline-block; }
.pre-bar-track{ width:min(320px,60vw); height:2px; background:rgba(255,255,255,.18);
  margin:28px auto 0; overflow:hidden; border-radius:2px; }
.pre-bar{ height:100%; width:0; background:linear-gradient(90deg,var(--gold),var(--gold-2)); }
.pre-count{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.3em;
  color:rgba(255,255,255,.6); margin-top:14px; }
.curtain{ position:fixed; inset:0; z-index:299; pointer-events:none; display:flex; }
.curtain span{ flex:1; background:var(--green-deep); transform:translateY(0); }

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor{ position:fixed; top:0; left:0; width:34px; height:34px; border:1.5px solid var(--green);
  border-radius:50%; pointer-events:none; z-index:250; transform:translate(-50%,-50%);
  transition:width .3s var(--ease-out), height .3s var(--ease-out), background .3s, border-color .3s;
  mix-blend-mode:difference; will-change:transform; }
.cursor.hot{ width:62px; height:62px; background:#fff; border-color:#fff; }
.cursor-dot{ position:fixed; width:5px; height:5px; background:var(--green); border-radius:50%;
  pointer-events:none; z-index:251; transform:translate(-50%,-50%); }
@media (hover:none){ .cursor,.cursor-dot{ display:none !important; } }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; top:0; left:0; right:0; z-index:120; height:var(--nav-h);
  display:flex; align-items:center; transition:background .5s var(--ease),
  box-shadow .5s var(--ease), height .5s var(--ease); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; width:100%; gap:20px; }
.nav.scrolled{ background:rgba(250,250,247,.85); backdrop-filter:blur(16px) saturate(1.3);
  box-shadow:0 1px 0 var(--line); height:70px; }
.brand{ display:flex; align-items:center; gap:12px; z-index:130; flex:none; }
.brand img.mark{ height:42px; width:auto; flex:none; display:block; }
.mark-chip{ display:inline-flex; background:#fff; border-radius:11px; padding:8px 13px; flex:none;
  box-shadow:0 8px 24px -14px rgba(0,0,0,.5); }
.mark-chip img{ height:36px; width:auto; display:block; }
.nav.scrolled .brand img.mark{ height:38px; }
.brand .bt{ line-height:1; }
.brand .bt b{ font-family:var(--font-display); font-weight:800; font-size:1.18rem;
  letter-spacing:.02em; display:block; }
.brand .bt small{ font-family:var(--font-mono); font-size:.54rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--green); display:block; margin-top:2px; }
.nav-links{ display:flex; align-items:center; gap:2px; }
.nav-links a{ position:relative; font-size:.82rem; font-weight:600; padding:10px 13px;
  color:var(--ink-2); transition:color .3s; white-space:nowrap; }
.nav-links a::after{ content:""; position:absolute; left:13px; right:13px; bottom:5px;
  height:1.5px; background:var(--green); transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease-out); }
.nav-links a:hover{ color:var(--ink); } .nav-links a:hover::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--green); } .nav-links a.active::after{ transform:scaleX(1); }
.nav-cta{ display:inline-flex; align-items:center; gap:9px; background:var(--green); color:#fff;
  padding:12px 22px; border-radius:100px; font-size:.8rem; font-weight:700;
  transition:transform .3s var(--ease-out), background .3s; white-space:nowrap; }
.nav-cta .dot{ width:7px; height:7px; border-radius:50%; background:#fff; animation:pulse 2.4s infinite; }
.nav-cta:hover{ background:var(--green-deep); }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(255,255,255,.5);}
  70%{box-shadow:0 0 0 8px rgba(255,255,255,0);} 100%{box-shadow:0 0 0 0 rgba(255,255,255,0);} }
.burger{ display:none; width:46px; height:46px; border-radius:50%; border:1px solid var(--line);
  position:relative; z-index:130; flex:none; }
.burger span{ position:absolute; left:13px; right:13px; height:2px; background:var(--ink);
  transition:transform .4s var(--ease-out), opacity .3s; }
.burger span:nth-child(1){ top:18px; } .burger span:nth-child(2){ bottom:18px; }
body.nav-on-dark .nav:not(.scrolled) .nav-links a{ color:rgba(255,255,255,.82); }
body.nav-on-dark .nav:not(.scrolled) .nav-links a:hover{ color:#fff; }
body.nav-on-dark .nav:not(.scrolled) .brand .bt b{ color:#fff; }
body.nav-on-dark .nav:not(.scrolled) .brand .bt small{ color:var(--gold-2); }
body.nav-on-dark .nav:not(.scrolled) .burger span{ background:#fff; }
body.menu-open .burger span{ background:#fff; }
body.menu-open .burger span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
body.menu-open .burger span:nth-child(2){ transform:translateY(-5px) rotate(-45deg); }

.menu{ position:fixed; inset:0; z-index:115; background:var(--green-deep); color:#fff;
  clip-path:circle(0 at calc(100% - 46px) 42px); transition:clip-path .8s var(--ease-in-out);
  display:flex; flex-direction:column; justify-content:center; padding:var(--gutter);
  pointer-events:none; }
body.menu-open .menu{ clip-path:circle(160% at calc(100% - 46px) 42px); pointer-events:auto; }
.menu a{ font-family:var(--font-display); font-weight:800; font-size:clamp(1.8rem,8vw,3.2rem);
  padding:.1em 0; opacity:0; transform:translateX(-30px); transition:opacity .5s, transform .6s;
  line-height:1.05; display:flex; align-items:baseline; gap:16px; }
.menu a .n{ font-family:var(--font-mono); font-size:.78rem; color:var(--gold-2); font-weight:400; }
body.menu-open .menu a{ opacity:1; transform:none; }
body.menu-open .menu a:nth-child(1){ transition-delay:.22s; }
body.menu-open .menu a:nth-child(2){ transition-delay:.28s; }
body.menu-open .menu a:nth-child(3){ transition-delay:.34s; }
body.menu-open .menu a:nth-child(4){ transition-delay:.40s; }
body.menu-open .menu a:nth-child(5){ transition-delay:.46s; }
body.menu-open .menu a:nth-child(6){ transition-delay:.52s; }
body.menu-open .menu a:nth-child(7){ transition-delay:.58s; }
.menu-foot{ margin-top:42px; display:flex; flex-wrap:wrap; gap:22px; opacity:0;
  transition:opacity .5s .6s; font-family:var(--font-mono); font-size:.72rem;
  letter-spacing:.06em; color:rgba(255,255,255,.65); }
body.menu-open .menu-foot{ opacity:1; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{ position:relative; display:inline-flex; align-items:center; gap:11px; padding:16px 30px;
  border-radius:100px; font-weight:700; font-size:.86rem; font-family:var(--font-sans);
  transition:transform .35s var(--ease-out); overflow:hidden; isolation:isolate; }
.btn .arr{ transition:transform .4s var(--ease-out); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-solid{ background:var(--ink); color:#fff; }
.btn-solid::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(120deg,var(--green-deep),var(--green)); transform:translateY(101%);
  transition:transform .5s var(--ease-out); }
.btn-solid:hover::before{ transform:translateY(0); }
.btn-green{ background:var(--green); color:#fff; }
.btn-green::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--green-deep);
  transform:translateY(101%); transition:transform .5s var(--ease-out); }
.btn-green:hover::before{ transform:translateY(0); }
.btn-ghost{ border:1.5px solid var(--line); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--ink); }
.btn-gold{ background:var(--gold); color:#1a1306; }
.btn-gold::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--gold-2);
  transform:translateY(101%); transition:transform .5s var(--ease-out); }
.btn-gold:hover::before{ transform:translateY(0); }
.btn-light{ background:#fff; color:var(--green-deep); }
.btn-light:hover{ background:var(--gold-2); }
.mag{ will-change:transform; }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{ position:relative; }
.block{ padding-block:clamp(78px,11vh,150px); }
.block-head{ display:grid; grid-template-columns:1fr; gap:18px; margin-bottom:clamp(40px,6vh,68px); }
.block-head.split{ grid-template-columns:1.1fr .9fr; align-items:end; gap:40px; }

/* ---------- page hero (shared, inner pages) ---------- */
.page-hero{ position:relative; min-height:74vh; display:flex; align-items:flex-end;
  padding-top:var(--nav-h); padding-bottom:clamp(46px,8vh,90px); overflow:hidden; background:var(--paper); }
.page-hero .ph-photo{ position:absolute; inset:0; z-index:0; }
.page-hero .ph-photo img{ width:100%; height:120%; object-fit:cover; opacity:.16;
  will-change:transform; }
.page-hero .ph-photo::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, var(--paper) 0%, rgba(250,250,247,.4) 50%, var(--paper) 100%); }
.page-hero .wrap{ position:relative; z-index:3; width:100%; }
.page-hero h1{ font-size:clamp(2.8rem,9vw,7rem); letter-spacing:-.02em; line-height:.98; }
.page-hero h1 .gold{ color:var(--gold-deep); }
.page-hero .lead{ margin-top:26px; }
.crumb{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:22px; display:flex; gap:10px; align-items:center; }
.crumb .sep{ color:var(--green); }

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding-bottom:clamp(40px,7vh,86px); overflow:hidden; background:var(--paper); }
.hero-photo{ position:absolute; right:0; top:0; bottom:0; width:42%; min-width:320px; z-index:0;
  clip-path:polygon(14% 0,100% 0,100% 100%,0 100%); overflow:hidden; }
.hero-photo img{ width:100%; height:100%; object-fit:cover; transform:scale(1.12); will-change:transform; }
.hero-photo::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(120deg, var(--paper) 0%, rgba(250,250,247,.18) 32%, transparent 56%); }
.hero-skyline{ position:absolute; left:0; right:0; bottom:0; height:32vh; z-index:1; pointer-events:none; }
.hero-skyline svg{ width:100%; height:100%; }
.hero-content{ position:relative; z-index:3; width:100%; }
.hero h1{ font-size:clamp(2.2rem,4.6vw,4.2rem); letter-spacing:-.02em; line-height:1.04; max-width:14ch; }
.hero h1 .gold{ color:var(--gold-deep); }
.hero-sub{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between;
  gap:30px 50px; margin-top:32px; max-width:880px; }
.hero-cta-row{ display:flex; gap:16px; align-items:center; margin-top:30px; flex-wrap:wrap; }
.scroll-cue{ position:absolute; left:var(--gutter); bottom:24px; z-index:3;
  font-family:var(--font-mono); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-2); display:flex; align-items:center; gap:12px; }
.scroll-cue .ln{ width:1px; height:40px; background:var(--line); overflow:hidden; position:relative; }
.scroll-cue .ln::after{ content:""; position:absolute; top:-40px; left:0; width:1px; height:40px;
  background:var(--green); animation:cueDown 2.2s var(--ease-in-out) infinite; }
@keyframes cueDown{ 0%{transform:translateY(0);} 60%,100%{transform:translateY(80px);} }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ border-block:1px solid var(--line); background:var(--ink); color:var(--paper);
  padding:22px 0; overflow:hidden; }
.marquee.gold{ background:var(--gold); color:#1a1306; border-color:transparent; }
.marquee.green{ background:var(--green); color:#fff; border-color:transparent; }
.marquee-track{ display:flex; width:max-content; will-change:transform; }
.marquee-track .it{ display:inline-flex; align-items:center; gap:26px; padding-inline:26px;
  font-family:var(--font-display); font-weight:800; font-size:clamp(1.3rem,3vw,2rem);
  white-space:nowrap; }
.marquee-track .it .star{ color:var(--gold-2); font-size:1rem; }
.marquee.gold .it .star,.marquee.green .it .star{ color:#fff; }

/* ============================================================
   STATS
   ============================================================ */
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.stat{ background:var(--paper); padding:clamp(26px,3.4vw,44px) clamp(18px,2.6vw,32px); }
.stat .num{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.4rem,5.4vw,4.2rem);
  line-height:.9; display:flex; align-items:baseline; color:var(--green-deep); }
.stat .num .suf{ color:var(--gold); font-size:.5em; margin-left:.05em; }
.stat .lbl{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-2); margin-top:14px; }
.stat .barline{ height:2px; background:var(--line); margin-top:18px; overflow:hidden; }
.stat .barline i{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--green),var(--gold));
  transition:width 1.5s var(--ease-out); }
.stats.dark{ background:var(--green-ink); }
.stats.dark .stats-grid{ background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.12); }
.stats.dark .stat{ background:var(--green-ink); }
.stats.dark .num{ color:#fff; } .stats.dark .lbl{ color:rgba(255,255,255,.65); }

/* ============================================================
   TILT CARDS  (VMV / generic)
   ============================================================ */
.tilt{ position:relative; transform-style:preserve-3d; transition:transform .4s var(--ease-out);
  will-change:transform; }
.vcard{ background:var(--paper); border:1px solid var(--line); border-radius:14px;
  padding:clamp(26px,3.2vw,42px); min-height:330px; display:flex; flex-direction:column;
  justify-content:space-between; position:relative; overflow:hidden; }
.vcard .shine{ position:absolute; width:300px; height:300px; border-radius:50%; filter:blur(60px);
  opacity:0; transition:opacity .5s; pointer-events:none; transform:translate(-50%,-50%);
  background:rgba(43,122,43,.45); }
.vcard:hover .shine{ opacity:.6; }
.vcard.gold .shine{ background:rgba(201,163,39,.5); }
.vcard .vnum{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.18em; color:var(--green); }
.vcard.gold .vnum{ color:var(--gold-deep); }
.vcard h3{ font-size:1.9rem; margin-top:auto; }
.vcard p{ color:var(--ink-2); margin-top:14px; font-size:1rem; }
.vcard .ic{ width:52px; height:52px; margin-top:18px; }
.vcard .vrow{ display:flex; gap:12px; align-items:baseline; padding:8px 0; border-top:1px solid var(--line); }
.vcard .vrow:first-of-type{ border-top:none; }
.vcard .vrow b{ font-family:var(--font-display); font-size:1.1rem; min-width:108px; }
.vcard .vrow span{ color:var(--ink-2); font-size:.9rem; }

/* ============================================================
   SERVICES rows
   ============================================================ */
.svc-list{ border-top:1px solid var(--line); }
.svc{ display:grid; grid-template-columns:auto 1fr auto; gap:28px; align-items:center;
  padding:clamp(22px,3vw,34px) 6px; border-bottom:1px solid var(--line); position:relative;
  cursor:pointer; transition:padding-left .5s var(--ease-out); }
.svc::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:0; z-index:0;
  background:var(--green-deep); transition:width .55s var(--ease-out); }
.svc:hover{ padding-left:32px; } .svc:hover::before{ width:100%; }
.svc > *{ position:relative; z-index:1; transition:color .4s; }
.svc-no{ font-family:var(--font-mono); font-size:.8rem; color:var(--green); }
.svc-main h3{ font-size:clamp(1.4rem,3.2vw,2.4rem); }
.svc-desc{ color:var(--ink-2); font-size:.96rem; max-width:54ch; margin-top:6px; }
.svc-expand{ max-height:0; overflow:hidden; opacity:0; transition:max-height .55s var(--ease-out), opacity .4s; }
.svc:hover .svc-expand{ max-height:120px; opacity:1; margin-top:10px; }
.svc-expand a{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:.84rem;
  color:var(--gold-2); margin-top:10px; }
.svc:hover, .svc:hover .svc-desc, .svc:hover .svc-no{ color:var(--paper); }
.svc-arrow{ width:54px; height:54px; border-radius:50%; border:1px solid var(--line);
  display:grid; place-items:center; transition:transform .5s var(--ease-out), border-color .4s, background .4s; }
.svc:hover .svc-arrow{ transform:rotate(-45deg); background:var(--gold); border-color:var(--gold); }
.svc:hover .svc-arrow svg{ stroke:#1a1306; }

/* ---------- process timeline ---------- */
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.process::before{ content:""; position:absolute; left:0; right:0; top:34px; height:2px;
  background:var(--line); }
.pstep{ position:relative; }
.pstep .dot{ width:70px; height:70px; border-radius:50%; background:var(--paper); border:2px solid var(--green);
  display:grid; place-items:center; font-family:var(--font-display); font-weight:800; font-size:1.5rem;
  color:var(--green-deep); position:relative; z-index:1; }
.pstep h4{ font-size:1.3rem; margin-top:22px; }
.pstep p{ color:var(--ink-2); font-size:.92rem; margin-top:8px; }

/* ============================================================
   WHY cards
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.why-card{ background:var(--paper); border:1px solid var(--line); border-radius:14px;
  padding:clamp(26px,3vw,40px); position:relative; overflow:hidden; min-height:280px;
  transition:transform .45s var(--ease-out), box-shadow .45s, border-color .45s; }
.why-card:hover{ transform:translateY(-6px); border-color:transparent;
  box-shadow:0 34px 70px -34px rgba(13,13,13,.4); }
.why-card .wn{ font-family:var(--font-display); font-weight:800; font-size:3.4rem; line-height:1;
  color:var(--sage); -webkit-text-stroke:1px var(--green); }
.why-card h3{ font-size:1.45rem; margin-top:24px; }
.why-card p{ color:var(--ink-2); margin-top:12px; font-size:.96rem; }
.why-card .ln{ height:2px; width:34px; background:var(--gold); margin-top:20px; transition:width .5s var(--ease-out); }
.why-card:hover .ln{ width:64px; }

/* ============================================================
   CERTIFICATIONS
   ============================================================ */
.cert-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cert{ border:1px solid var(--line); border-radius:14px; padding:28px; background:var(--paper);
  transition:transform .4s var(--ease-out), border-color .4s, box-shadow .4s; position:relative; overflow:hidden; }
.cert:hover{ transform:translateY(-6px); border-color:var(--gold);
  box-shadow:0 30px 60px -30px rgba(201,163,39,.45); }
.cert .vbadge{ width:30px; height:30px; border-radius:50%; background:var(--sage); display:grid;
  place-items:center; margin-bottom:18px; }
.cert .abbr{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:var(--green-deep); }
.cert .full{ font-size:.86rem; color:var(--ink-2); margin-top:10px; line-height:1.45; }
.cert .ln{ height:3px; width:36px; margin-top:18px; transition:width .5s var(--ease-out); }
.cert:hover .ln{ width:100%; }
.cert.feature{ background:var(--green-deep); color:#fff; grid-column:span 2;
  display:flex; flex-direction:column; justify-content:space-between; }
.cert.feature .abbr{ color:var(--gold-2); font-size:2.4rem; }
.cert.feature .full{ color:rgba(255,255,255,.8); }
.cert.feature .vbadge{ background:rgba(255,255,255,.14); }

/* ============================================================
   TEAM
   ============================================================ */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.member{ position:relative; border-radius:14px; overflow:hidden; padding:clamp(24px,2.6vw,32px);
  background:var(--paper); border:1px solid var(--line); transition:transform .45s var(--ease-out),
  box-shadow .45s, border-color .45s; min-height:240px; display:flex; flex-direction:column;
  justify-content:space-between; }
.member:hover{ border-color:transparent; box-shadow:0 30px 60px -32px rgba(13,13,13,.4); }
.member .av{ width:74px; height:74px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:#fff;
  background:radial-gradient(120% 120% at 30% 20%, var(--green-bright), var(--green-deep)); }
.member .av.gold{ background:radial-gradient(120% 120% at 30% 20%, var(--gold-2), var(--gold-deep)); }
.member .role{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--green); margin-top:28px; }
.member b{ font-family:var(--font-display); font-size:1.3rem; display:block; margin-top:8px; line-height:1.05; }
.member .cred{ color:var(--ink-2); font-size:.86rem; margin-top:10px; }
.member .tag{ align-self:flex-start; margin-top:16px; font-family:var(--font-mono); font-size:.58rem;
  letter-spacing:.1em; background:var(--sage); color:var(--green-deep); padding:5px 10px; border-radius:6px; }

/* ============================================================
   CTA BANDS
   ============================================================ */
.cta-band{ background:var(--green-deep); color:#fff; padding-block:clamp(70px,12vh,130px);
  position:relative; overflow:hidden; }
.cta-band .bp-grid{ mask-image:radial-gradient(120% 120% at 50% 0,#000,transparent 75%);
  background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px); }
.cta-band h2{ font-size:clamp(2.2rem,6vw,4.6rem); color:#fff; max-width:18ch; }
.cta-band .lead{ color:rgba(255,255,255,.82); }
.cta-band .ph{ display:flex; gap:26px; flex-wrap:wrap; margin-top:8px; }
.cta-band .ph a{ font-family:var(--font-mono); font-size:.86rem; color:var(--gold-2);
  letter-spacing:.04em; transition:color .3s; }
.cta-band .ph a:hover{ color:#fff; }

/* ============================================================
   GOING GREEN
   ============================================================ */
.green-hero{ background:var(--green-ink); color:#fff; position:relative; overflow:hidden; }
.green-particles{ position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.green-particles i{ position:absolute; width:6px; height:6px; border-radius:50%; background:var(--gold-2);
  opacity:.5; animation:floatUp linear infinite; }
@keyframes floatUp{ 0%{transform:translateY(20px); opacity:0;}
  10%{opacity:.6;} 90%{opacity:.5;} 100%{transform:translateY(-110vh); opacity:0;} }
.glass-card{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16);
  border-radius:18px; padding:clamp(30px,4vw,56px); backdrop-filter:blur(14px); }
.commit-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.commit{ border:1px solid var(--line); border-radius:14px; padding:clamp(26px,3vw,40px); background:var(--paper);
  transition:transform .45s var(--ease-out), box-shadow .45s; }
.commit:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -32px rgba(13,13,13,.35); }
.commit .ic{ width:56px; height:56px; }
.commit h3{ font-size:1.4rem; margin-top:22px; } .commit p{ color:var(--ink-2); margin-top:10px; font-size:.95rem; }
.bigquote{ text-align:center; font-family:var(--font-display); font-weight:800;
  font-size:clamp(2rem,5.5vw,4.4rem); line-height:1.08; color:var(--green-deep); max-width:20ch; margin-inline:auto; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(40px,6vw,84px); }
.cinfo .row{ display:flex; gap:18px; padding:22px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.cinfo .row .ic{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line);
  display:grid; place-items:center; flex:none; transition:background .4s,border-color .4s; }
.cinfo .row:hover .ic{ background:var(--green); border-color:var(--green); }
.cinfo .row:hover .ic svg{ stroke:#fff; }
.cinfo .k{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); }
.cinfo .v{ font-size:1.02rem; font-weight:600; margin-top:5px; }
.cinfo .v a{ display:block; transition:color .3s; } .cinfo .v a:hover{ color:var(--green); }
.cform{ background:var(--sage); border:1px solid var(--line); border-radius:18px; padding:clamp(26px,3vw,42px); }
.fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:0 22px; }
.field{ position:relative; margin-bottom:8px; }
.field.full{ grid-column:1 / -1; }
.field input,.field textarea,.field select{ width:100%; background:transparent; border:none;
  border-bottom:1.5px solid var(--line); padding:24px 0 12px; font-size:1rem; font-family:inherit;
  color:var(--ink); transition:border-color .4s; }
.field textarea{ resize:none; min-height:90px; }
.field select{ -webkit-appearance:none; appearance:none; cursor:pointer; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--green);
  box-shadow:0 1px 0 var(--green); }
.field label{ position:absolute; left:0; top:24px; color:var(--ink-2); pointer-events:none;
  transition:transform .35s var(--ease-out), color .35s, font-size .35s; transform-origin:left; }
.field input:focus + label,.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,.field textarea:not(:placeholder-shown) + label,
.field.filled label{ transform:translateY(-22px); font-size:.7rem; color:var(--green); letter-spacing:.04em; }
.field select + label{ transform:translateY(-22px); font-size:.7rem; color:var(--green); }
.cform .btn{ width:100%; justify-content:center; margin-top:22px; }
.form-note{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.06em; color:var(--ink-2);
  margin-top:16px; text-align:center; }
.form-ok{ display:none; align-items:center; gap:10px; color:var(--green); font-weight:600;
  justify-content:center; margin-top:18px; } .form-ok.show{ display:flex; }
.reg-band{ background:var(--green-deep); color:#fff; border-radius:18px; padding:clamp(28px,3.4vw,44px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.reg-band .ri b{ font-family:var(--font-display); font-size:1.3rem; display:block; color:var(--gold-2); }
.reg-band .ri span{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.1em;
  text-transform:uppercase; color:rgba(255,255,255,.7); }
.socials{ display:flex; gap:14px; }
.socials a{ width:50px; height:50px; border-radius:50%; border:1px solid var(--line); display:grid;
  place-items:center; transition:background .4s, border-color .4s, transform .4s var(--ease-out); }
.socials a:hover{ background:var(--green); border-color:var(--green); transform:translateY(-4px); }
.socials a:hover svg{ fill:#fff; }
.map-ph{ border:1px solid var(--line); border-radius:18px; overflow:hidden; position:relative;
  min-height:260px; background:
    repeating-linear-gradient(45deg,var(--sage),var(--sage) 18px,#e8eee4 18px,#e8eee4 36px);
  display:grid; place-items:center; text-align:center; }
.map-ph .pin{ background:var(--paper); border:1px solid var(--line); border-radius:14px;
  padding:22px 28px; box-shadow:0 20px 50px -24px rgba(0,0,0,.4); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--green-deep); color:var(--paper); padding-top:clamp(60px,9vh,104px); }
.footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1.2fr; gap:40px; padding-bottom:48px; }
.footer .brand .bt b{ color:#fff; } .footer .brand .bt small{ color:var(--gold-2); }
.footer .fdesc{ color:rgba(255,255,255,.72); font-size:.94rem; margin-top:20px; max-width:34ch; }
.foot-col h5{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.16em;
  text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:16px; }
.foot-col a,.foot-col p{ display:block; color:rgba(255,255,255,.8); padding:6px 0; font-size:.92rem;
  transition:color .3s, padding-left .3s; }
.foot-col a:hover{ color:#fff; padding-left:6px; }
.foot-rule{ height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.footer-bot{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between;
  padding:26px 0 40px; font-family:var(--font-mono); font-size:.66rem; letter-spacing:.06em;
  color:rgba(255,255,255,.55); }
.footer-bot .regs{ display:flex; flex-wrap:wrap; gap:20px; }
.footer-bot .bbee{ color:var(--gold-2); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .nav-links a{ padding:10px 9px; font-size:.78rem; }
  .why-grid,.commit-grid,.team-grid{ grid-template-columns:1fr 1fr; }
  .cert-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-grid{ grid-template-columns:1fr 1fr; }
  .reg-band{ grid-template-columns:1fr 1fr; }
  .block-head.split{ grid-template-columns:1fr; }
}
@media (max-width:860px){
  :root{ --nav-h:72px; }
  .nav-links,.nav .nav-cta{ display:none; }
  .burger{ display:block; }
  .vmv-grid,.process{ grid-template-columns:1fr !important; }
  .process::before{ display:none; }
  .contact-grid,.footer-top{ grid-template-columns:1fr; }
  .hero-photo{ width:64%; opacity:.45; }
  .hero-content{ max-width:100%; }
  .cursor,.cursor-dot{ display:none; }
}
@media (max-width:560px){
  .why-grid,.cert-grid,.team-grid,.stats-grid,.commit-grid,.reg-band,.fgrid{ grid-template-columns:1fr; }
  .cert.feature{ grid-column:span 1; }
  .hero-sub{ flex-direction:column; align-items:flex-start; }
  .scroll-cue{ display:none; }
  .svc{ grid-template-columns:auto 1fr; } .svc-arrow{ display:none; }
  .brand .bt small{ display:none; }
}
.vmv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
