
:root{
  --bg:#F2F7EC;--surface:#FFFFFF;--surface-2:#E9F1DB;--surface-3:#DEEACF;
  --ink:#0B2818;--ink-soft:#23402F;--muted:#4A5D4E;--faint:#7C8E80;
  --canopy:#1B6B3A;--canopy-deep:#124A28;--lime:#7FB52E;--lime-bright:#9ACA3C;
  --solar:#F2A11C;--solar-soft:#F8C45A;--sunrise:#FF7A45;
  --line:rgba(20,60,30,.13);--line-2:rgba(20,60,30,.2);
  --shadow:0 22px 50px -22px rgba(20,70,35,.30);--shadow-sm:0 10px 28px -14px rgba(20,70,35,.24);
  --grad-sun:linear-gradient(118deg,#F2A11C 0%,#FF7A45 42%,#9ACA3C 100%);
  --grad-canopy:linear-gradient(160deg,#124A28 0%,#1B6B3A 100%);
  --grad-glow:radial-gradient(60% 60% at 70% 20%,rgba(242,161,28,.20),transparent 70%);
  --r:18px;--r-lg:28px;--r-sm:12px;--ease:cubic-bezier(.22,.61,.36,1);--maxw:1240px;
}
html[data-theme="dark"]{
  --bg:#07150D;--surface:#0E2317;--surface-2:#14301E;--surface-3:#1A3A26;
  --ink:#EAF3E4;--ink-soft:#CFE0C6;--muted:#9DB3A2;--faint:#6E8675;
  --canopy:#4FB477;--canopy-deep:#0E2317;--lime:#A9D94A;--lime-bright:#BCE65C;
  --solar:#FFB23E;--solar-soft:#FFC868;--sunrise:#FF8A5B;
  --line:rgba(255,255,255,.10);--line-2:rgba(255,255,255,.16);
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);--shadow-sm:0 10px 30px -16px rgba(0,0,0,.6);
  --grad-canopy:linear-gradient(160deg,#0A2014 0%,#123A24 100%);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .5s var(--ease),color .5s var(--ease)}
html[data-theme="light"] body{background:radial-gradient(56% 46% at 100% -6%,rgba(242,161,28,.16),transparent 56%),radial-gradient(50% 44% at -8% 24%,rgba(127,181,46,.14),transparent 55%),radial-gradient(46% 40% at 108% 78%,rgba(255,122,69,.10),transparent 55%),var(--bg);background-attachment:fixed}
html[data-theme="dark"] body{background:radial-gradient(56% 46% at 100% -6%,rgba(242,161,28,.055),transparent 56%),radial-gradient(50% 44% at -8% 100%,rgba(79,180,119,.06),transparent 55%),var(--bg);background-attachment:fixed}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;line-height:1.05;font-weight:700;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.mono{font-family:'Space Mono',monospace}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.eyebrow{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--canopy);display:inline-flex;align-items:center;gap:10px}
html[data-theme="dark"] .eyebrow{color:var(--lime)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--grad-sun);border-radius:2px}
.eyebrow.center::before{display:none}
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:var(--grad-sun);transition:width .1s linear}
.reveal{animation:revUp .7s var(--ease) both}
@keyframes revUp{from{transform:translateY(16px)}to{transform:none}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none}}
.reveal.d1{animation-delay:.08s}.reveal.d2{animation-delay:.16s}.reveal.d3{animation-delay:.24s}.reveal.d4{animation-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:120;transition:all .4s var(--ease)}
.nav-inner{max-width:var(--maxw);margin:14px auto 0;padding:11px 16px 11px 20px;display:flex;align-items:center;gap:14px;background:color-mix(in srgb,var(--surface) 72%,transparent);backdrop-filter:blur(18px) saturate(1.4);border:1px solid var(--line);border-radius:60px;box-shadow:var(--shadow-sm);transition:all .4s var(--ease)}
.nav.scrolled .nav-inner{margin-top:8px;background:color-mix(in srgb,var(--surface) 93%,transparent)}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand img{height:36px;width:auto}
.brand .logo-dark{display:none}
html[data-theme="dark"] .brand .logo-light{display:none}
html[data-theme="dark"] .brand .logo-dark{display:block}
.nav-links{display:flex;gap:2px;margin-left:auto;align-items:center}
.nav-links>a,.nav-drop>a{font-size:.9rem;font-weight:600;color:var(--ink-soft);padding:9px 13px;border-radius:40px;transition:.25s;display:inline-flex;align-items:center;gap:5px}
.nav-links>a:hover,.nav-drop>a:hover{color:var(--canopy);background:var(--surface-2)}
.nav-links>a.active,.nav-drop.active>a{color:var(--canopy)}
html[data-theme="dark"] .nav-links>a:hover,html[data-theme="dark"] .nav-drop>a:hover,html[data-theme="dark"] .nav-links>a.active,html[data-theme="dark"] .nav-drop.active>a{color:var(--lime)}
.nav-drop{position:relative}
.nav-drop .menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:10px;min-width:230px;opacity:0;visibility:hidden;transition:.3s var(--ease)}
.nav-drop:hover .menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop .menu a{display:flex;gap:11px;align-items:center;padding:11px 13px;border-radius:12px;font-size:.9rem;font-weight:600;color:var(--ink-soft);transition:.2s}
.nav-drop .menu a:hover{background:var(--surface-2);color:var(--canopy)}
html[data-theme="dark"] .nav-drop .menu a:hover{color:var(--lime)}
.nav-drop .menu a .di{width:32px;height:32px;border-radius:9px;background:var(--surface-2);display:grid;place-items:center;color:var(--canopy);flex-shrink:0}
html[data-theme="dark"] .nav-drop .menu a .di{color:var(--lime)}
.nav-drop .menu a .di svg{width:17px;height:17px}
.nav-drop .menu a small{display:block;font-weight:400;font-size:.72rem;color:var(--faint)}
.nav-cta{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:var(--bg);padding:10px 18px;border-radius:40px;font-weight:700;font-size:.88rem;transition:.3s;border:none;cursor:pointer;white-space:nowrap}
html[data-theme="dark"] .nav-cta{background:var(--lime);color:#07150D}
.nav-cta:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.theme-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);cursor:pointer;display:grid;place-items:center;color:var(--ink);transition:.3s;flex-shrink:0}
.theme-btn:hover{transform:rotate(20deg) scale(1.06);border-color:var(--solar)}
.theme-btn svg{width:17px;height:17px}.theme-btn .ico-moon{display:none}
html[data-theme="dark"] .theme-btn .ico-sun{display:none}html[data-theme="dark"] .theme-btn .ico-moon{display:block}
.burger{display:none;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:18px;height:2px;background:var(--ink);border-radius:2px}

/* buttons */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--grad-sun);color:#10260f;padding:15px 26px;border-radius:50px;font-weight:800;font-size:1rem;border:none;cursor:pointer;transition:.35s var(--ease);box-shadow:0 14px 34px -14px rgba(242,161,28,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 44px -14px rgba(242,161,28,.85)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:15px 24px;border-radius:50px;font-weight:700;font-size:1rem;border:1.5px solid var(--line-2);color:var(--ink);background:color-mix(in srgb,var(--surface) 40%,transparent);backdrop-filter:blur(6px);transition:.3s;cursor:pointer}
.btn-ghost:hover{border-color:var(--canopy);background:var(--surface)}
.arrow-ic{width:16px;height:16px}

/* HERO SLIDER */
.hero{position:relative;height:100vh;min-height:680px;overflow:hidden}
/* backgrounds */
.hero-bgs{position:absolute;inset:0;z-index:0}
.slide-bg{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1.1s var(--ease),visibility 1.1s;overflow:hidden}
.slide-bg.active{opacity:1;visibility:visible}
.slide-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.04)}
.slide-bg.active img{animation:kenburns 9.5s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.17)}}
@media (prefers-reduced-motion:reduce){.slide-bg.active img{animation:none}}
.slide-bg::after{content:"";position:absolute;inset:0}
.slide-bg.t-img::after{background:linear-gradient(100deg,rgba(7,21,13,.8) 0%,rgba(7,21,13,.45) 52%,rgba(7,21,13,.25) 100%)}
html[data-theme="light"] .slide-bg.t-img::after{background:linear-gradient(96deg,rgba(244,248,241,.97) 0%,rgba(244,248,241,.86) 26%,rgba(244,248,241,.42) 56%,rgba(244,248,241,.06) 92%)}
html[data-theme="light"] .slide-bg.t-text{background:linear-gradient(135deg,#FBE8CB 0%,#EFF5DC 50%,#FCE3D2 100%)}
html[data-theme="light"] .slide-bg.t-text::after{background:radial-gradient(70% 70% at 76% 16%,rgba(242,161,28,.16),transparent 70%);opacity:1}
html[data-theme="light"] .slide-content.t-text .kick{color:var(--canopy)}
html[data-theme="light"] .slide-content.t-text h1{color:var(--ink)}
html[data-theme="light"] .slide-content.t-text p{color:var(--ink-soft)}
html[data-theme="light"] .slide-bignum .a{color:var(--canopy-deep)}
html[data-theme="light"] .slide-bignum .arrowto{color:var(--solar)}
html[data-theme="light"] .slide-bg.t-stat::after{background:linear-gradient(180deg,rgba(7,21,13,.34) 0%,rgba(7,21,13,.55) 58%,rgba(7,21,13,.74) 100%)}
.slide-bg.t-text{background:var(--grad-canopy)}
.slide-bg.t-text::after{background:var(--grad-glow);opacity:.9}
.slide-bg.t-stat::after{background:linear-gradient(180deg,rgba(7,21,13,.42),rgba(7,21,13,.82))}
/* persistent sun (v1 signature) */
.hero-sun{position:absolute;top:-80px;right:-20px;width:330px;height:330px;z-index:2;pointer-events:none;opacity:.88}
.hero-sun .glow{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(255,216,140,.66),rgba(242,161,28,.34) 32%,rgba(255,122,69,.14) 52%,transparent 68%);filter:blur(5px);animation:sunpulse 7s ease-in-out infinite}
.hero-sun .core{position:absolute;top:50%;left:50%;width:96px;height:96px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,#FFEEB8,#F7B43A 56%,rgba(242,161,28,0) 78%);box-shadow:0 0 56px 20px rgba(242,161,28,.26)}
.hero-sun .rays{position:absolute;inset:-10%;border-radius:50%;background:repeating-conic-gradient(from 0deg,rgba(255,205,120,.12) 0deg 2.4deg,transparent 2.4deg 16deg);-webkit-mask:radial-gradient(circle,transparent 36%,#000 41%,#000 58%,transparent 65%);mask:radial-gradient(circle,transparent 36%,#000 41%,#000 58%,transparent 65%);animation:spin 110s linear infinite;opacity:.4}
@keyframes sunpulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.07);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.hero-sun .glow,.hero-sun .rays{animation:none}}
/* bottom scrim so stats read on every slide */
.hero-scrim{position:absolute;left:0;right:0;bottom:0;height:260px;z-index:1;background:linear-gradient(180deg,transparent,rgba(7,21,13,.74));pointer-events:none}
/* content stack */
.hero-contents{position:relative;z-index:3;height:100%;display:flex;align-items:center;padding:96px 0 150px}
.hero-contents .wrap{width:100%}
.hero-stage{display:grid}
.slide-content{grid-area:1/1;align-self:center;max-width:760px;opacity:0;visibility:hidden;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease),visibility .8s}
.slide-content.active{opacity:1;visibility:visible;transform:none;transition-delay:.15s}
.slide-content .kick{font-family:'Space Mono';font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--solar);display:inline-block;margin-bottom:18px}
.slide-content.t-text .kick,.slide-content.t-stat .kick{color:var(--solar-soft)}
.slide-content h1{font-size:clamp(2.5rem,6.2vw,5rem);font-weight:800;letter-spacing:-.03em;color:var(--ink)}
.slide-content.t-text h1,.slide-content.t-stat h1{color:#fff}
.slide-content h1 .accent{background:var(--grad-sun);-webkit-background-clip:text;background-clip:text;color:transparent}
.slide-content p{font-size:clamp(1.02rem,1.6vw,1.28rem);color:var(--ink-soft);margin:22px 0 32px;max-width:560px;font-weight:500}
.slide-content.t-text p,.slide-content.t-stat p{color:rgba(234,243,228,.85)}
.slide-content .row{display:flex;gap:13px;flex-wrap:wrap;align-items:center}
.slide-content.t-text .btn-ghost,.slide-content.t-stat .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.slide-bignum{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;margin:8px 0 28px}
.slide-bignum .a{font-family:'Bricolage Grotesque';font-size:clamp(3rem,8vw,6rem);font-weight:800;color:#fff;line-height:.9}
.slide-bignum .arrowto{font-size:2rem;color:var(--solar-soft)}
.slide-bignum .b{font-family:'Bricolage Grotesque';font-size:clamp(3rem,8vw,6rem);font-weight:800;background:var(--grad-sun);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:.9}
/* persistent bottom bar: stats + slider controls */
.hero-bottom{position:absolute;left:0;right:0;bottom:0;z-index:5;padding-bottom:30px}
.hero-bottom .wrap{display:flex;align-items:flex-end;justify-content:space-between;gap:26px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap}
.hstat{position:relative;padding-left:16px}
.hstat::before{content:"";position:absolute;left:0;top:4px;bottom:6px;width:3px;border-radius:3px;background:var(--grad-sun)}
.hstat .n{font-family:'Bricolage Grotesque';font-size:2rem;font-weight:800;color:#fff;line-height:1}
.hstat .n .unit{font-size:1rem;color:var(--solar-soft)}
.hstat .l{font-family:'Space Mono';font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(234,243,228,.72);margin-top:6px}
.slider-ctrl{display:flex;align-items:center;gap:16px;padding-bottom:4px}
.slider-dots{display:flex;gap:8px}
.s-dot{width:36px;height:4px;border-radius:4px;background:rgba(255,255,255,.28);border:none;cursor:pointer;overflow:hidden;position:relative;padding:0}
.s-dot .fill{position:absolute;inset:0;width:0;background:var(--solar);border-radius:4px}
.s-dot.active .fill{animation:dotfill 6.5s linear forwards}
@keyframes dotfill{to{width:100%}}
.slider-arrows{display:flex;gap:10px}
.s-arrow{width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.1);backdrop-filter:blur(6px);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.3s}
.s-arrow:hover{background:var(--solar);color:#10260f;border-color:var(--solar)}
.s-arrow svg{width:20px;height:20px}
@media(max-width:880px){.hero-bottom .wrap{justify-content:flex-start}.hero-stats{gap:22px}.hstat .n{font-size:1.6rem}.hero-contents{padding-bottom:180px}}
@media(max-width:560px){.hstat .l{font-size:.6rem}.hero-sun{width:230px;height:230px;top:-70px;right:-50px}}

/* marquee */
.marquee{background:var(--ink);color:var(--bg);padding:17px 0;overflow:hidden;white-space:nowrap}
html[data-theme="dark"] .marquee{background:var(--surface-2)}
.marquee-track{display:inline-flex;animation:scrollx 32s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:'Bricolage Grotesque';font-weight:600;font-size:1.12rem;display:inline-flex;align-items:center;gap:42px;opacity:.92;padding-right:42px}
.marquee .star{color:var(--solar)}
@keyframes scrollx{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* sections */
.section{padding:104px 0;position:relative}
.section.tight{padding:78px 0}
.section-head{max-width:680px;margin-bottom:54px}
.section-head h2{font-size:clamp(2rem,4.2vw,3.3rem);margin:18px 0 16px}
.section-head p{color:var(--muted);font-size:1.08rem;max-width:600px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .eyebrow{justify-content:center}
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;pointer-events:none}

/* page hero (inner) */
.phero{position:relative;padding:170px 0 70px;overflow:hidden;background:var(--grad-canopy);color:#fff}
.phero::after{content:"";position:absolute;top:-34%;right:-8%;width:540px;height:540px;border-radius:50%;background:radial-gradient(circle,rgba(242,161,28,.24),rgba(255,122,69,.10) 45%,transparent 66%);z-index:0;pointer-events:none}
.phero .wrap{position:relative;z-index:2}
.phero::before{content:"";position:absolute;inset:0;background:var(--grad-glow);opacity:.8}
.phero .bgimg{position:absolute;inset:0;z-index:0;opacity:.34}
.phero .bgimg img{width:100%;height:100%;object-fit:cover}
.phero .wrap{position:relative;z-index:3}
.phero h1{font-size:clamp(2.3rem,5.4vw,4rem);color:#fff;max-width:760px;margin:16px 0 14px}
.phero p{color:rgba(234,243,228,.84);font-size:1.12rem;max-width:560px}
.phero .eyebrow{color:var(--solar-soft)}
.crumb{display:flex;gap:8px;align-items:center;font-family:'Space Mono';font-size:.74rem;letter-spacing:.08em;color:rgba(234,243,228,.6);margin-bottom:8px}
.crumb a:hover{color:#fff}.crumb .sep{opacity:.5}

/* story */
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.story.rev{grid-template-columns:.95fr 1.05fr}
.story-text h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin:18px 0 22px}
.story-text p{color:var(--muted);margin-bottom:18px;font-size:1.05rem}
.story-text strong{color:var(--ink)}
.story-badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.story-badge{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:12px 18px;border-radius:40px;font-weight:600;font-size:.9rem;box-shadow:var(--shadow-sm)}
.story-badge .ic{width:28px;height:28px;border-radius:50%;background:var(--grad-sun);display:grid;place-items:center;color:#10260f}
.story-badge .ic svg{width:15px;height:15px}
.story-media{position:relative}
.story-media .main{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;background:var(--grad-canopy)}
.story-media .main img{width:100%;height:100%;object-fit:cover;transition:.8s var(--ease)}
.story-media:hover .main img{transform:scale(1.05)}
.story-media .float{position:absolute;bottom:-26px;left:-26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px 24px;box-shadow:var(--shadow);max-width:240px}
.story-media .float .big{font-family:'Bricolage Grotesque';font-size:2.4rem;font-weight:800;background:var(--grad-sun);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.story-media .float .lbl{font-size:.82rem;color:var(--muted);margin-top:4px}
.story-media .badge-top{position:absolute;top:22px;right:-20px;background:var(--ink);color:var(--bg);padding:13px 17px;border-radius:14px;box-shadow:var(--shadow);font-family:'Space Mono';font-size:.76rem;letter-spacing:.06em}
html[data-theme="dark"] .story-media .badge-top{background:var(--lime);color:#07150D}

/* video */
.video-sec{position:relative;overflow:hidden}
.video-wrap{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/9;background:#000}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-poster{position:absolute;inset:0;cursor:pointer;z-index:2}
.video-poster img{width:100%;height:100%;object-fit:cover}
.video-poster::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(18,74,40,.3),rgba(7,21,13,.65))}
.video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;width:96px;height:96px;border-radius:50%;background:var(--grad-sun);display:grid;place-items:center;color:#10260f;box-shadow:0 0 0 0 rgba(242,161,28,.5);animation:playpulse 2.2s infinite;pointer-events:none}
@keyframes playpulse{0%{box-shadow:0 0 0 0 rgba(242,161,28,.5)}100%{box-shadow:0 0 0 26px rgba(242,161,28,0)}}
.video-play svg{width:38px;height:38px;margin-left:5px}
.video-cap{position:absolute;left:30px;bottom:26px;z-index:3;color:#fff;pointer-events:none}
.video-cap .t{font-family:'Space Mono';font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--solar-soft)}
.video-cap h3{font-size:1.5rem;color:#fff;margin-top:6px}
.video-split{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:center}

/* impact */
.impact{background:var(--grad-canopy);color:#EAF3E4;position:relative;overflow:hidden}
.impact::before{content:"";position:absolute;inset:0;background:var(--grad-glow);opacity:.7}
.impact .arrows{position:absolute;right:-40px;top:-40px;width:380px;opacity:.10;z-index:0}
.impact .wrap{position:relative;z-index:2}
.impact .section-head h2{color:#fff}.impact .section-head p{color:rgba(234,243,228,.78)}.impact .eyebrow{color:var(--solar-soft)}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.impact-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:var(--r-lg);padding:32px 26px;backdrop-filter:blur(6px);transition:.4s var(--ease)}
.impact-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.1);border-color:var(--solar)}
.impact-card .ic{width:48px;height:48px;border-radius:14px;background:var(--grad-sun);display:grid;place-items:center;margin-bottom:20px;color:#10260f}
.impact-card .ic svg{width:24px;height:24px}
.impact-card .num{font-family:'Bricolage Grotesque';font-size:3rem;font-weight:800;line-height:1;color:#fff}
.impact-card .num .suf{color:var(--solar-soft);font-size:1.6rem}
.impact-card .cap{font-family:'Space Mono';font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(234,243,228,.7);margin-top:12px}

/* verticals */
.vert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.vert{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:1/1.18;background:var(--grad-canopy);cursor:pointer;box-shadow:var(--shadow-sm)}
.vert img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease);opacity:.86}
.vert:hover img{transform:scale(1.1);opacity:1}
.vert::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(7,21,13,.86) 100%)}
.vert .lbl{position:absolute;left:18px;bottom:16px;right:18px;z-index:2;color:#fff}
.vert .lbl h4{font-size:1.16rem;color:#fff}
.vert .lbl .n{font-family:'Space Mono';font-size:.7rem;color:var(--solar-soft);letter-spacing:.16em}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.pillar{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:370px;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;color:#fff;box-shadow:var(--shadow);isolation:isolate}
.pillar .bg{position:absolute;inset:0;z-index:-2}
.pillar .bg img{width:100%;height:100%;object-fit:cover;transition:.8s var(--ease)}
.pillar:hover .bg img{transform:scale(1.08)}
.pillar::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(160deg,rgba(18,74,40,.25) 0%,rgba(7,21,13,.9) 100%)}
.pillar .tag{font-family:'Space Mono';font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--solar-soft);margin-bottom:12px}
.pillar h3{font-size:1.8rem;color:#fff;margin-bottom:12px}
.pillar p{color:rgba(255,255,255,.82);font-size:.97rem;margin-bottom:18px;max-width:92%}
.pillar .feats{display:flex;flex-wrap:wrap;gap:8px}
.pillar .feats span{font-size:.78rem;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);padding:6px 12px;border-radius:30px;backdrop-filter:blur(4px)}
.pillar .arrow{position:absolute;top:30px;right:30px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);display:grid;place-items:center;transition:.4s;backdrop-filter:blur(4px)}
.pillar:hover .arrow{background:var(--solar);color:#10260f;transform:rotate(-45deg)}

/* products */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.filter-btn{font-family:'Space Mono';font-size:.8rem;letter-spacing:.06em;padding:10px 18px;border-radius:40px;border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;transition:.25s;font-weight:700}
.filter-btn:hover{border-color:var(--canopy);color:var(--ink)}
.filter-btn.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
html[data-theme="dark"] .filter-btn.active{background:var(--lime);color:#07150D;border-color:var(--lime)}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.prod{border-radius:var(--r);overflow:hidden;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.4s var(--ease)}
.prod.hide{display:none}
.prod:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--lime)}
.prod .img{aspect-ratio:1/1;overflow:hidden;background:var(--surface-2);position:relative}
.prod .img img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.prod:hover .img img{transform:scale(1.08)}
.prod .cat{position:absolute;top:12px;left:12px;font-family:'Space Mono';font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:blur(6px);padding:5px 10px;border-radius:30px;color:var(--canopy);font-weight:700}
html[data-theme="dark"] .prod .cat{color:var(--lime)}
.prod .body{padding:16px 18px}
.prod .body h4{font-size:1.02rem;margin-bottom:4px}
.prod .body p{font-size:.84rem;color:var(--muted);margin-bottom:12px}
.prod .body .more{font-family:'Space Mono';font-size:.74rem;color:var(--canopy);font-weight:700;display:inline-flex;align-items:center;gap:6px}
html[data-theme="dark"] .prod .body .more{color:var(--lime)}
.prod:hover .more{gap:10px}

/* calculator */
.calc-sec{background:var(--surface-2);position:relative;overflow:hidden}
.calc-sec::before{content:"";position:absolute;top:-120px;left:-100px;width:420px;height:420px;border-radius:50%;background:var(--grad-glow);opacity:.8}
.calc{display:grid;grid-template-columns:1fr 1.05fr;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);position:relative;z-index:2}
.calc-controls{background:var(--surface);padding:46px 44px}
.calc-controls h3{font-size:1.7rem;margin-bottom:8px}.calc-controls .lead{color:var(--muted);font-size:.96rem;margin-bottom:30px}
.field{margin-bottom:26px}
.field label{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:.92rem;margin-bottom:12px}
.field label .val{font-family:'Space Mono';color:var(--canopy);font-size:1.05rem}
html[data-theme="dark"] .field label .val{color:var(--lime)}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:8px;background:linear-gradient(90deg,var(--solar),var(--lime));outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--surface);border:3px solid var(--canopy);cursor:pointer;box-shadow:var(--shadow-sm)}
input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--surface);border:3px solid var(--canopy);cursor:pointer}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:84px;padding:12px 8px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--muted);font-weight:700;font-size:.84rem;cursor:pointer;transition:.25s}
.seg button.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
html[data-theme="dark"] .seg button.active{background:var(--lime);color:#07150D;border-color:var(--lime)}
.calc-readout{background:var(--grad-canopy);color:#EAF3E4;padding:46px 44px;position:relative;overflow:hidden}
.calc-readout::after{content:"";position:absolute;inset:0;background:var(--grad-glow)}
.calc-readout .inner{position:relative;z-index:2}
.ro-eye{font-family:'Space Mono';font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--solar-soft);margin-bottom:6px}
.ro-hero{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}
.ro-hero .big{font-family:'Bricolage Grotesque';font-size:3.2rem;font-weight:800;color:#fff;line-height:1}
.ro-hero .per{color:rgba(234,243,228,.7);font-size:1rem}
.ro-sub{color:rgba(234,243,228,.72);font-size:.92rem;margin-bottom:30px}
.ro-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:26px}
.ro-cell{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:18px}
.ro-cell .k{font-family:'Space Mono';font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(234,243,228,.66);margin-bottom:8px;display:flex;align-items:center;gap:7px}
.ro-cell .k svg{width:14px;height:14px;color:var(--solar-soft)}
.ro-cell .v{font-family:'Bricolage Grotesque';font-size:1.7rem;font-weight:700;color:#fff;line-height:1}
.ro-cell .v small{font-size:.85rem;color:var(--solar-soft);font-family:'Space Mono'}
.ro-eco{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.07);border:1px dashed rgba(154,202,60,.5);border-radius:14px;padding:16px 18px;margin-bottom:22px}
.ro-eco .leaf{width:42px;height:42px;border-radius:12px;background:var(--grad-sun);display:grid;place-items:center;color:#10260f;flex-shrink:0}
.ro-eco .txt{font-size:.88rem;color:rgba(234,243,228,.85)}.ro-eco .txt b{color:#fff}
.ro-note{font-size:.74rem;color:rgba(234,243,228,.5);margin-top:14px;line-height:1.5}
.ro-cta{display:inline-flex;align-items:center;gap:10px;background:var(--grad-sun);color:#10260f;padding:14px 24px;border-radius:40px;font-weight:800;font-size:.95rem;border:none;cursor:pointer;transition:.3s;width:100%;justify-content:center;text-decoration:none}
.ro-cta:hover{transform:translateY(-2px)}

/* how it works infographic */
.howto{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative}
.howto .step{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;text-align:center;position:relative;transition:.4s}
.howto .step:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--lime)}
.howto .step .ic{width:64px;height:64px;border-radius:18px;background:var(--grad-sun);display:grid;place-items:center;color:#10260f;margin:0 auto 18px}
.howto .step .ic svg{width:32px;height:32px}
.howto .step .n{font-family:'Space Mono';font-size:.7rem;letter-spacing:.16em;color:var(--canopy);text-transform:uppercase}
html[data-theme="dark"] .howto .step .n{color:var(--lime)}
.howto .step h4{font-size:1.1rem;margin:8px 0}
.howto .step p{font-size:.88rem;color:var(--muted)}

/* offerings grid (service) */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.offer{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.4s var(--ease);box-shadow:var(--shadow-sm)}
.offer:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--lime)}
.offer .img{aspect-ratio:16/10;overflow:hidden;background:var(--surface-2)}
.offer .img img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.offer:hover .img img{transform:scale(1.07)}
.offer .body{padding:24px}
.offer .body .ic{width:46px;height:46px;border-radius:13px;background:var(--surface-2);display:grid;place-items:center;color:var(--canopy);margin-bottom:14px}
html[data-theme="dark"] .offer .body .ic{color:var(--lime)}
.offer .body .ic svg{width:23px;height:23px}
.offer .body h4{font-size:1.18rem;margin-bottom:8px}
.offer .body p{color:var(--muted);font-size:.92rem}

/* benefits list */
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.benefit{display:flex;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;transition:.3s}
.benefit:hover{border-color:var(--lime);transform:translateX(4px)}
.benefit .ic{width:44px;height:44px;border-radius:12px;background:var(--grad-sun);display:grid;place-items:center;color:#10260f;flex-shrink:0}
.benefit .ic svg{width:22px;height:22px}
.benefit h4{font-size:1.06rem;margin-bottom:4px}
.benefit p{font-size:.9rem;color:var(--muted)}

/* gallery strip */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gal .g{border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;cursor:pointer;background:var(--grad-canopy);box-shadow:var(--shadow-sm)}
.gal .g img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.gal .g:hover img{transform:scale(1.1)}
.gal .g.wide{grid-column:span 2;aspect-ratio:2/1}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;overflow:hidden;transition:.3s}
.faq-item.open{border-color:var(--lime);box-shadow:var(--shadow-sm)}
.faq-q{padding:22px 26px;font-weight:700;font-size:1.05rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .pm{width:30px;height:30px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;flex-shrink:0;transition:.3s;color:var(--canopy)}
html[data-theme="dark"] .faq-q .pm{color:var(--lime)}
.faq-item.open .faq-q .pm{background:var(--grad-sun);color:#10260f;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);color:var(--muted)}
.faq-a .inner{padding:0 26px 24px}
.faq-item.open .faq-a{max-height:300px}

/* process */
.process{position:relative}
.proc-line{position:absolute;left:50%;top:80px;bottom:40px;width:2px;background:linear-gradient(var(--solar),var(--lime),var(--canopy));transform:translateX(-50%);opacity:.4}
.proc-step{display:grid;grid-template-columns:1fr 80px 1fr;align-items:center;margin-bottom:8px}
.proc-step .card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:26px 28px;box-shadow:var(--shadow-sm);transition:.4s}
.proc-step .card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--lime)}
.proc-step:nth-child(even) .card{grid-column:3}
.proc-step:nth-child(even) .spacer{grid-column:1}
.proc-step .node{grid-column:2;display:grid;place-items:center;position:relative;z-index:2}
.proc-step .node .ring{width:58px;height:58px;border-radius:50%;background:var(--grad-sun);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;color:#10260f;font-size:1.3rem;box-shadow:0 0 0 6px var(--bg),var(--shadow-sm)}
.proc-step .card h4{font-size:1.2rem;margin-bottom:8px}
.proc-step .card p{color:var(--muted);font-size:.92rem}
.proc-step .card .tag{font-family:'Space Mono';font-size:.68rem;color:var(--canopy);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;display:block}
html[data-theme="dark"] .proc-step .card .tag{color:var(--lime)}

/* projects */
.proj-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:14px}
.proj{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);background:var(--grad-canopy)}
.proj.hide{display:none}
.proj img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease);opacity:.92}
.proj:hover img{transform:scale(1.09)}
.proj::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(7,21,13,.85));opacity:.85;transition:.4s}
.proj .meta{position:absolute;left:18px;bottom:16px;right:18px;z-index:2;color:#fff;transform:translateY(8px);opacity:.9;transition:.4s}
.proj:hover .meta{transform:none;opacity:1}
.proj .meta .loc{font-family:'Space Mono';font-size:.68rem;letter-spacing:.12em;color:var(--solar-soft);text-transform:uppercase}
.proj .meta h4{font-size:1.08rem;color:#fff;margin-top:4px}
.proj.big{grid-column:span 3;grid-row:span 2}.proj.tall{grid-row:span 2}.proj.wide{grid-column:span 2}

/* why/values */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:.4s var(--ease);position:relative;overflow:hidden}
.value::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-sun);transform:scaleX(0);transform-origin:left;transition:.4s}
.value:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.value:hover::before{transform:scaleX(1)}
.value .ic{width:52px;height:52px;border-radius:15px;background:var(--surface-2);display:grid;place-items:center;color:var(--canopy);margin-bottom:20px;transition:.4s}
html[data-theme="dark"] .value .ic{color:var(--lime)}
.value:hover .ic{background:var(--grad-sun);color:#10260f}
.value .ic svg{width:26px;height:26px}
.value h4{font-size:1.2rem;margin-bottom:10px}.value p{color:var(--muted);font-size:.93rem}

/* testimonials */
.testi-sec{background:var(--ink);color:var(--bg);position:relative;overflow:hidden}
html[data-theme="dark"] .testi-sec{background:var(--surface-2)}
.testi-sec .eyebrow{color:var(--solar-soft)}
.testi-sec .section-head h2{color:var(--bg)}
html[data-theme="dark"] .testi-sec .section-head h2{color:var(--ink)}
.testi-wrap{position:relative;max-width:860px;margin:0 auto}
.testi{display:none;text-align:center;animation:fadein .6s var(--ease)}
.testi.active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.testi .quote{font-family:'Bricolage Grotesque';font-size:clamp(1.4rem,2.8vw,2.1rem);font-weight:500;line-height:1.3;color:var(--bg);margin-bottom:30px}
html[data-theme="dark"] .testi .quote{color:var(--ink)}
.testi .stars{color:var(--solar);font-size:1.2rem;margin-bottom:18px;letter-spacing:3px}
.testi .who{display:flex;align-items:center;justify-content:center;gap:14px}
.testi .who .av{width:50px;height:50px;border-radius:50%;background:var(--grad-sun);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;color:#10260f;font-size:1.1rem}
.testi .who .info{text-align:left}
.testi .who .info .nm{font-weight:700;color:var(--bg)}
html[data-theme="dark"] .testi .who .info .nm{color:var(--ink)}
.testi .who .info .rl{font-size:.82rem;color:rgba(244,248,241,.6)}
html[data-theme="dark"] .testi .who .info .rl{color:var(--muted)}
.testi-nav{display:flex;justify-content:center;gap:10px;margin-top:40px}
.testi-dot{width:10px;height:10px;border-radius:50%;background:rgba(244,248,241,.25);border:none;cursor:pointer;transition:.3s}
.testi-dot.active{background:var(--solar);width:30px;border-radius:6px}

/* CTA */
.cta-sec{padding:0 0 104px}
.cta{background:var(--grad-canopy);border-radius:var(--r-lg);padding:62px 56px;position:relative;overflow:hidden;text-align:center;box-shadow:var(--shadow)}
.cta::before{content:"";position:absolute;inset:0;background:var(--grad-glow);opacity:.9}
.cta .arrows{position:absolute;right:-60px;bottom:-60px;width:360px;opacity:.12}
.cta-inner{position:relative;z-index:2;max-width:640px;margin:0 auto}
.cta h2{font-size:clamp(2rem,4.4vw,3.2rem);color:#fff;margin-bottom:18px}
.cta p{color:rgba(234,243,228,.82);font-size:1.1rem;margin-bottom:34px}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .btn-white{background:#fff;color:var(--canopy-deep);padding:16px 30px;border-radius:50px;font-weight:800;display:inline-flex;align-items:center;gap:10px;transition:.3s}
.cta .btn-white:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.cta .btn-out{border:1.5px solid rgba(255,255,255,.4);color:#fff;padding:16px 28px;border-radius:50px;font-weight:700;display:inline-flex;align-items:center;gap:10px;transition:.3s}
.cta .btn-out:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* product detail */
.pd{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:start}
.pd-gallery .main{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--grad-canopy);box-shadow:var(--shadow);margin-bottom:14px}
.pd-gallery .main img{width:100%;height:100%;object-fit:cover}
.pd-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.pd-thumbs .t{border-radius:14px;overflow:hidden;aspect-ratio:1/1;cursor:pointer;border:2px solid transparent;background:var(--surface-2)}
.pd-thumbs .t.active{border-color:var(--solar)}
.pd-thumbs .t img{width:100%;height:100%;object-fit:cover}
.pd-info .cat{font-family:'Space Mono';font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--canopy)}
html[data-theme="dark"] .pd-info .cat{color:var(--lime)}
.pd-info h1{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:10px 0 16px}
.pd-info .lead{color:var(--muted);font-size:1.05rem;margin-bottom:24px}
.pd-feats{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.pd-apps{display:flex;align-items:center;flex-wrap:wrap;gap:9px;margin:0 0 26px}
.pd-apps .pl{font-family:'Space Mono';font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-right:4px}
.pd-apps .chip{font-size:.82rem;font-weight:600;padding:6px 14px;border-radius:30px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft)}
html[data-theme="dark"] .pd-apps .chip{background:rgba(255,255,255,.05)}
.pd-feats .f{display:flex;gap:12px;align-items:flex-start}
.pd-feats .f .ck{width:24px;height:24px;border-radius:50%;background:var(--grad-sun);display:grid;place-items:center;color:#10260f;flex-shrink:0;margin-top:2px}
.pd-feats .f .ck svg{width:14px;height:14px}
.pd-feats .f span{font-size:.96rem;color:var(--ink-soft)}
.spec-table{width:100%;border-collapse:collapse;margin:20px 0 28px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.spec-table tr{border-bottom:1px solid var(--line)}
.spec-table td{padding:14px 18px;font-size:.92rem}
.spec-table td:first-child{font-family:'Space Mono';font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);width:45%;background:var(--surface-2)}
.spec-table td:last-child{font-weight:600}
.pd-actions{display:flex;gap:12px;flex-wrap:wrap}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
.cinfo .row{display:flex;gap:16px;margin-bottom:24px;align-items:flex-start}
.cinfo .row .ic{width:50px;height:50px;border-radius:14px;background:var(--grad-sun);display:grid;place-items:center;color:#10260f;flex-shrink:0}
.cinfo .row .ic svg{width:24px;height:24px}
.cinfo .row .t{font-family:'Space Mono';font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
.cinfo .row .d{font-weight:700;font-size:1.05rem}
.cinfo .row .d a:hover{color:var(--canopy)}
.cform{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-sm)}
.cform h3{font-size:1.5rem;margin-bottom:6px}.cform .sub{color:var(--muted);font-size:.94rem;margin-bottom:24px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.82rem;font-weight:700;margin-bottom:7px;color:var(--ink-soft)}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 15px;border-radius:12px;border:1px solid var(--line);background:var(--bg);color:var(--ink);font-family:inherit;font-size:.94rem;transition:.25s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--canopy);box-shadow:0 0 0 3px rgba(127,181,46,.18)}
.fg textarea{resize:vertical;min-height:110px}
.cmap{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);margin-top:30px;aspect-ratio:21/9}
.cmap iframe{width:100%;height:100%;border:0;filter:grayscale(.1)}

/* blog / insights */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:.4s var(--ease);display:flex;flex-direction:column}
.post:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--lime)}
.post .img{aspect-ratio:16/10;overflow:hidden;background:var(--surface-2);position:relative}
.post .img img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.post:hover .img img{transform:scale(1.07)}
.post .img .cat{position:absolute;top:12px;left:12px;font-family:'Space Mono';font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;background:color-mix(in srgb,var(--surface) 90%,transparent);backdrop-filter:blur(6px);padding:6px 11px;border-radius:30px;color:var(--canopy);font-weight:700}
html[data-theme="dark"] .post .img .cat{color:var(--lime)}
.post .body{padding:24px;display:flex;flex-direction:column;flex:1}
.post .meta{font-family:'Space Mono';font-size:.7rem;letter-spacing:.06em;color:var(--faint);margin-bottom:10px}
.post h3{font-size:1.22rem;line-height:1.2;margin-bottom:10px}
.post p{color:var(--muted);font-size:.92rem;margin-bottom:16px;flex:1}
.post .more{font-family:'Space Mono';font-size:.74rem;color:var(--canopy);font-weight:700;display:inline-flex;align-items:center;gap:6px;align-self:flex-start}
html[data-theme="dark"] .post .more{color:var(--lime)}
.post:hover .more{gap:10px}
.post.feat{grid-column:span 2;flex-direction:row}
.post.feat .img{aspect-ratio:auto;flex:1.1}
.post.feat .body{flex:1;justify-content:center}
.post.feat h3{font-size:1.7rem}
/* article */
.article{max-width:760px;margin:0 auto}
.article .lead{font-size:1.2rem;color:var(--ink-soft);font-weight:500;margin-bottom:28px;line-height:1.6}
.article h2{font-size:1.6rem;margin:36px 0 14px}
.article h3{font-size:1.25rem;margin:28px 0 10px}
.article p{color:var(--muted);margin-bottom:18px;font-size:1.04rem;line-height:1.75}
.article ul{margin:0 0 20px 0;padding-left:0;list-style:none}
.article ul li{position:relative;padding-left:30px;margin-bottom:12px;color:var(--muted)}
.article ul li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:14px;border-radius:4px;background:var(--grad-sun)}
.article .pull{border-left:3px solid var(--lime);padding:6px 0 6px 24px;margin:28px 0;font-family:'Bricolage Grotesque';font-size:1.4rem;font-weight:500;color:var(--ink);line-height:1.35}
.article-hero{aspect-ratio:21/9;border-radius:var(--r-lg);overflow:hidden;margin-bottom:40px;box-shadow:var(--shadow);background:var(--grad-canopy)}
.article-hero img{width:100%;height:100%;object-fit:cover}
.article-meta{display:flex;gap:16px;align-items:center;margin-bottom:24px;font-family:'Space Mono';font-size:.78rem;color:var(--faint)}
.article-meta .tag{background:var(--grad-sun);color:#10260f;padding:5px 12px;border-radius:30px;font-weight:700;letter-spacing:.04em}
.share{display:flex;gap:10px;align-items:center;margin-top:40px;padding-top:24px;border-top:1px solid var(--line)}
.share span{font-family:'Space Mono';font-size:.74rem;color:var(--faint);text-transform:uppercase;letter-spacing:.1em}
.share a{width:38px;height:38px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center;color:var(--ink);transition:.3s}
.share a:hover{background:var(--grad-sun);color:#10260f}
.share a svg{width:16px;height:16px}
/* case study */
.cs-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:38px 0}
.cs-stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:24px;text-align:center}
.cs-stat .n{font-family:'Bricolage Grotesque';font-size:2.2rem;font-weight:800;background:var(--grad-sun);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.cs-stat .l{font-family:'Space Mono';font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-top:8px}
.cs-spec{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:24px 0}
.cs-spec .s{display:flex;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--surface-2);border-radius:12px;font-size:.92rem}
.cs-spec .s .k{color:var(--faint);font-family:'Space Mono';font-size:.78rem}
.cs-spec .s .v{font-weight:700}
@media(max-width:880px){.blog-grid{grid-template-columns:1fr 1fr}.post.feat{grid-column:span 2;flex-direction:column}.post.feat .img{aspect-ratio:16/10}.cs-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.blog-grid{grid-template-columns:1fr}.post.feat{grid-column:span 1}.cs-spec{grid-template-columns:1fr}}

/* footer */
.footer{background:var(--surface-2);border-top:1px solid var(--line);padding:70px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px}
.foot-brand img{height:44px;margin-bottom:20px}
.foot-brand .logo-dark{display:none}
html[data-theme="dark"] .foot-brand .logo-light{display:none}
html[data-theme="dark"] .foot-brand .logo-dark{display:block}
.foot-brand p{color:var(--muted);font-size:.94rem;max-width:300px;margin-bottom:22px}
.foot-social{display:flex;gap:10px}
.foot-social a{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);transition:.3s}
.foot-social a:hover{background:var(--grad-sun);color:#10260f;transform:translateY(-3px)}
.foot-social svg{width:18px;height:18px}
.foot-col h5{font-family:'Space Mono';font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:18px}
.foot-col a{display:block;color:var(--muted);font-size:.93rem;margin-bottom:11px;transition:.2s}
.foot-col a:hover{color:var(--canopy);transform:translateX(4px)}
html[data-theme="dark"] .foot-col a:hover{color:var(--lime)}
.foot-contact .row{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}
.foot-contact .row .ic{width:36px;height:36px;border-radius:10px;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;color:var(--canopy);flex-shrink:0}
html[data-theme="dark"] .foot-contact .row .ic{color:var(--lime)}
.foot-contact .row .ic svg{width:16px;height:16px}
.foot-contact .row .t{font-size:.72rem;color:var(--faint);font-family:'Space Mono';letter-spacing:.08em;text-transform:uppercase}
.foot-contact .row .d{font-weight:600;font-size:.94rem}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.86rem}
.foot-bottom .made{font-family:'Space Mono';font-size:.78rem}

/* fab + lightbox + drawer */
.fab{position:fixed;bottom:24px;right:24px;z-index:130;background:#25D366;color:#fff;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:.3s;animation:fabpulse 2.4s infinite}
.fab:hover{transform:scale(1.08)}.fab svg{width:30px;height:30px}
@keyframes fabpulse{0%,100%{box-shadow:0 12px 30px -8px rgba(37,211,102,.6)}50%{box-shadow:0 12px 30px -8px rgba(37,211,102,.6),0 0 0 12px rgba(37,211,102,0)}}
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(7,21,13,.92);display:none;place-items:center;padding:30px;backdrop-filter:blur(8px)}
.lightbox.open{display:grid}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:var(--r);box-shadow:var(--shadow)}
.lightbox .close{position:absolute;top:24px;right:28px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;font-size:1.4rem}
.drawer{position:fixed;inset:0;z-index:140;background:var(--bg);transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:90px 30px 30px;overflow-y:auto}
.drawer.open{transform:none}
.drawer a{font-family:'Bricolage Grotesque';font-size:1.5rem;font-weight:600;padding:15px 0;border-bottom:1px solid var(--line)}
.drawer .btn-primary{margin-top:24px;justify-content:center}
.drawer-close{position:absolute;top:24px;right:24px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);font-size:1.4rem;cursor:pointer;color:var(--ink)}

@media(max-width:1080px){
  .impact-grid{grid-template-columns:repeat(2,1fr)}.prod-grid{grid-template-columns:repeat(3,1fr)}
  .vert-grid{grid-template-columns:repeat(2,1fr)}.why{grid-template-columns:repeat(2,1fr)}
  .offers{grid-template-columns:repeat(2,1fr)}.howto{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:880px){
  .nav-links{display:none}.burger{display:flex}
  .story,.story.rev{grid-template-columns:1fr;gap:40px}.story-media{max-width:440px;margin:0 auto}
  .pillars{grid-template-columns:1fr}.calc{grid-template-columns:1fr}
  .video-split{grid-template-columns:1fr;gap:30px}
  .proj-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.proj.big{grid-column:span 2;grid-row:span 2}
  .foot-grid{grid-template-columns:1fr 1fr}
  .proc-step{grid-template-columns:1fr}.proc-step .node,.proc-line,.proc-step .spacer{display:none}.proc-step:nth-child(even) .card{grid-column:1}
  .pd{grid-template-columns:1fr;gap:32px}.contact-grid{grid-template-columns:1fr}
  .benefits{grid-template-columns:1fr}.frow{grid-template-columns:1fr}
}
@media(max-width:560px){
  .section{padding:70px 0}.prod-grid,.offers,.gal{grid-template-columns:repeat(2,1fr)}
  .why,.howto{grid-template-columns:1fr}.ro-grid{grid-template-columns:1fr}.foot-grid{grid-template-columns:1fr}
  .calc-controls,.calc-readout{padding:32px 24px}.cta{padding:42px 24px}.gal .g.wide{grid-column:span 2}
  .slider-ctrl{padding-bottom:0}.s-dot{width:28px}
}
