/* ============================================================
   Blue-Green Infrastructure – homepage stylesheet
   Warm blue-green cleantech. Schibsted Grotesk + Hanken Grotesk.
   ============================================================ */
:root {
  --paper:    #F6F3EA;   /* warm cream */
  --paper-2:  #FBFAF3;
  --sage:     #E7EEDC;
  --sage-2:   #EEF2E6;
  --canopy:   #16352B;   /* deep canopy green */
  --canopy-2: #1F4438;
  --ink:      #21302A;
  --ink-soft: #51625A;
  --green:    #5BA838;   /* matched toward brand leaf green */
  --green-br: #7EC632;   /* brand green (logo) */
  --green-dp: #2F6B30;
  --green-lt: #9FD982;   /* on dark */
  --water:    #1C9BD8;   /* brand blue (logo) */
  --water-dp: #0E6FA8;
  --sand:     #B07A2E;   /* amber – placeholders only */
  --sand-bg:  #F6ECD8;
  --line:     #E3DECF;
  --line-sage:#D7E0C7;
  --d-line:   rgba(255,255,255,0.16);
  --d-soft:   rgba(255,255,255,0.66);
  --disp: "Schibsted Grotesk", system-ui, sans-serif;
  --text: "Hanken Grotesk", system-ui, sans-serif;
  --maxw: 1240px;
  --pad: 40px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink);
  font-family: var(--text); font-size: 18px; line-height: 1.62;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
img { display: block; max-width: 100%; }
h1,h2,h3,h4 { font-family: var(--disp); margin: 0; font-weight: 700; letter-spacing: -0.02em; }
p { margin: 0; text-wrap: pretty; }
a { color: inherit; }

/* ---- type scale ---- */
.h1 { font-size: clamp(40px, 6vw, 72px); line-height: 1.02; font-weight: 800; letter-spacing: -0.035em; }
.h2 { font-size: clamp(30px, 3.6vw, 46px); line-height: 1.08; font-weight: 700; letter-spacing: -0.028em; }
.h3 { font-size: clamp(20px, 1.8vw, 25px); line-height: 1.2; font-weight: 700; }
.lede { font-size: clamp(19px, 1.6vw, 22px); line-height: 1.5; color: var(--ink-soft); font-weight: 400; }
.eyebrow { font-family: var(--text); font-size: 13px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--green-dp); display: inline-flex; align-items: center; gap: 11px; }
.eyebrow::before { content:''; width: 20px; height: 2px; background: var(--green); border-radius: 2px; flex: 0 0 auto; }
.on-dark .eyebrow, .eyebrow.on-dark { color: var(--green-lt); }
.on-dark .eyebrow::before, .eyebrow.on-dark::before { background: var(--green-lt); }
.measure { max-width: 64ch; }

/* ---- layout ---- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }
.section { padding: clamp(64px, 9vw, 120px) 0; }
.section-sm { padding: clamp(48px, 6vw, 80px) 0; }
.bg-paper  { background: var(--paper); }
.bg-paper2 { background: var(--paper-2); }
.bg-sage   { background: var(--sage); }
.bg-canopy { background: var(--canopy); color: #fff; }
.bg-canopy .h2, .bg-canopy .h3, .bg-canopy h2, .bg-canopy h3 { color: #fff; }
.bg-canopy .lede { color: var(--d-soft); }
.sec-head { max-width: 760px; margin-bottom: clamp(36px, 5vw, 56px); }
.sec-head .h2 { margin-top: 16px; }
.sec-head .lede { margin-top: 20px; text-wrap: pretty; }
/* balanced two-column section header: heading left, intro text right */
.problem-head { display: grid; grid-template-columns: 1.08fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: end; margin-bottom: clamp(40px, 5vw, 60px); }
.problem-head .h2 { margin-top: 14px; }
.problem-head .lede { margin-top: 0; }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; gap: 9px; font-family: var(--text);
  font-weight: 600; font-size: 16px; line-height: 1; text-decoration: none; cursor: pointer;
  padding: 16px 28px; border-radius: 999px; border: 0; transition: transform .15s, box-shadow .15s, background .15s; }
.btn svg { width: 16px; height: 16px; }
.btn-primary { background: var(--green-dp); color: #fff; box-shadow: 0 8px 22px rgba(47,107,48,0.26); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 12px 30px rgba(47,107,48,0.34); }
.btn-ghost { background: transparent; color: var(--ink); box-shadow: inset 0 0 0 1.5px rgba(33,48,42,0.24); }
.btn-ghost:hover { box-shadow: inset 0 0 0 1.5px rgba(33,48,42,0.55); }
.btn-on-dark { background: var(--green-br); color: #10261F; box-shadow: 0 8px 22px rgba(0,0,0,0.25); }
.btn-on-dark:hover { transform: translateY(-1px); }
.btn-on-dark.ghost { background: transparent; color: #fff; box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.42); }
.btn-on-dark.ghost:hover { box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.8); }
.cta-row { display: flex; flex-wrap: wrap; gap: 14px; }

/* ---- honesty primitives ---- */
.vision-tag { position: absolute; z-index: 3; left: 16px; bottom: 14px;
  display: inline-flex; align-items: center; gap: 7px; padding: 6px 12px; border-radius: 999px;
  background: rgba(16,30,24,0.6); backdrop-filter: blur(4px);
  font-family: var(--text); font-size: 11.5px; font-weight: 600; letter-spacing: 0.03em; color: rgba(255,255,255,0.92); }
.vision-tag::before { content:''; width: 7px; height: 7px; border-radius: 50%; background: var(--green-lt); flex: 0 0 auto; }
.figure { position: relative; overflow: hidden; }
.figure > img { width: 100%; height: 100%; object-fit: cover; }
.confirm { display: inline-block; vertical-align: middle; background: var(--sand-bg); color: var(--sand);
  border: 1px dashed var(--sand); border-radius: 5px; padding: 1px 8px; font-family: var(--text);
  font-size: 0.82em; font-weight: 700; letter-spacing: 0.03em; white-space: nowrap; }

/* placeholder slot (diagrams / unshot imagery) */
.ph { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
  text-align: center; padding: 28px;
  background: repeating-linear-gradient(135deg, var(--sage-2) 0 14px, var(--sage) 14px 28px);
  border: 1.5px dashed var(--line-sage); border-radius: 14px; color: var(--green-dp); }
.ph-k { font-family: var(--text); font-size: 12px; font-weight: 700; letter-spacing: 0.13em; text-transform: uppercase; }
.ph-d { font-size: 13.5px; color: var(--ink-soft); max-width: 320px; line-height: 1.4; }
.ph.dark { background: repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 14px, rgba(255,255,255,0.02) 14px 28px);
  border-color: var(--d-line); color: var(--green-lt); }
.ph.dark .ph-d { color: var(--d-soft); }

/* video slot */
.video-slot { position: relative; border-radius: 16px; overflow: hidden; background: #0E211B; color: #fff;
  display: flex; align-items: center; justify-content: center; aspect-ratio: 16/9; }
.video-slot .vs-inner { display: flex; flex-direction: column; align-items: center; gap: 14px; text-align: center; padding: 28px; }
.video-slot .vs-play { width: 64px; height: 64px; border-radius: 50%; background: rgba(255,255,255,0.16);
  border: 1.5px solid rgba(255,255,255,0.55); display: flex; align-items: center; justify-content: center; transition: background .15s; }
.video-slot:hover .vs-play { background: rgba(255,255,255,0.26); }
.video-slot .vs-play::after { content:''; border-style: solid; border-width: 11px 0 11px 18px; border-color: transparent transparent transparent #fff; margin-left: 5px; }
.video-slot .vs-k { font-family: var(--text); font-weight: 700; font-size: 12.5px; letter-spacing: 0.13em; text-transform: uppercase; }
.video-slot .vs-d { font-size: 13px; color: rgba(255,255,255,0.7); max-width: 340px; }
.video-slot .vs-link { font-size: 12px; color: var(--green-lt); text-decoration: none; }

/* hero ambient explainer teaser */
.hero-clip-video { position: relative; display: block; border-radius: 16px; overflow: hidden;
  aspect-ratio: 16/9; background: #0E211B; box-shadow: 0 26px 60px rgba(0,0,0,0.42); }
.hero-clip-video video { width: 100%; height: 100%; object-fit: contain; display: block; background: #0E211B; }
.hcv-badge { position: absolute; left: 14px; bottom: 14px; display: inline-flex; align-items: center; gap: 9px;
  padding: 7px 13px; border-radius: 999px; background: rgba(16,30,24,0.68); backdrop-filter: blur(4px);
  color: #fff; font-family: var(--text); font-size: 12.5px; font-weight: 600; letter-spacing: 0.02em; }
.hcv-play { width: 0; height: 0; border-style: solid; border-width: 5px 0 5px 9px; border-color: transparent transparent transparent var(--green-lt); }

/* primary explainer player (How it works) */
.explainer { margin: 0 0 clamp(36px, 5vw, 52px); }
.explainer .ex-frame { position: relative; border-radius: 18px; overflow: hidden; background: #0E211B; box-shadow: 0 24px 56px rgba(0,0,0,0.32); }
.explainer video { width: 100%; height: auto; display: block; background: #0E211B; }
.explainer figcaption { margin-top: 16px; font-size: 15px; color: var(--ink-soft); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.explainer figcaption .tag { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-dp); }

/* ============================================================
   NAV
   ============================================================ */
.nav { position: sticky; top: 0; z-index: 40; background: rgba(246,243,234,0.9);
  backdrop-filter: saturate(1.4) blur(12px); border-bottom: 1px solid var(--line); }
.nav-inner { display: flex; align-items: center; gap: 36px; padding: 16px var(--pad); max-width: var(--maxw); margin: 0 auto; }
.brand { display: flex; align-items: center; gap: 13px; margin-right: auto; text-decoration: none; }
.brand-logo { height: 44px; width: auto; display: block; }
.brand-name { font-family: var(--disp); font-weight: 600; font-size: 15px; line-height: 1.1;
  letter-spacing: -0.01em; color: var(--ink); padding-left: 14px; border-left: 1px solid var(--line); }
.brand .bw { font-family: var(--disp); font-weight: 700; font-size: 19px; letter-spacing: -0.02em; color: var(--ink); line-height: 1.05; }
.brand .bw small { display: block; font-family: var(--text); font-weight: 500; font-size: 11px;
  letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-soft); margin-top: 3px; }

/* TNS product lockup (on light) */
.tns-lockup { height: 74px; width: auto; max-width: 100%; align-self: flex-start; flex: 0 0 auto; object-fit: contain; display: block; margin-bottom: 24px; }
/* solution header: eyebrow left –––– enlarged TNS logo right */
.solution-top { display: flex; align-items: center; justify-content: space-between; gap: 32px; margin-bottom: clamp(22px, 3vw, 34px); }
.tns-lockup-lg { height: clamp(84px, 9.5vw, 132px); margin: 0; align-self: auto; filter: drop-shadow(0 10px 22px rgba(22,53,43,0.14)); }
@media (prefers-reduced-motion: no-preference) {
  .solution-top .tns-lockup-lg { opacity: 0; transform: translateY(12px) scale(0.9); transition: opacity .85s ease, transform .95s cubic-bezier(.19,.9,.22,1); }
  .solution-top.in .tns-lockup-lg { opacity: 1; transform: none; animation: tnsFloat 6.5s ease-in-out 1.1s infinite; }
}
@keyframes tnsFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }

/* footer logo plate – colored mark on a deliberate light plate over dark green */
.footer-logo-plate { background: transparent; padding: 0; align-self: flex-start; box-shadow: none; }
.footer-logo-plate img { height: 56px; width: auto; display: block; }
.nav-links { display: flex; gap: 28px; }
.nav-links a { font-family: var(--text); font-size: 15px; font-weight: 500; color: var(--ink-soft); text-decoration: none; transition: color .15s; }
.nav-links a:hover { color: var(--ink); }
.nav .btn { padding: 12px 20px; font-size: 15px; }

/* ============================================================
   HERO (immersive)
   ============================================================ */
.hero { position: relative; min-height: clamp(620px, 86vh, 860px); display: flex; align-items: flex-end;
  overflow: hidden; color: #fff; }
.hero-bg { position: absolute; inset: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-bg img { filter: brightness(1.08) saturate(1.05); }
.hero-rain { position: absolute; inset: 0; z-index: 2; width: 100%; height: 100%; pointer-events: none; opacity: 0.55; }
@media (prefers-reduced-motion: reduce) { .hero-rain { display: none; } }
.hero-scrim { position: absolute; inset: 0; background:
  linear-gradient(100deg, rgba(11,28,21,0.80) 0%, rgba(11,28,21,0.5) 33%, rgba(11,28,21,0.18) 60%, rgba(11,28,21,0.02) 100%); }
.hero-inner { position: relative; z-index: 3; width: 100%; max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--pad) clamp(56px, 7vw, 88px); display: flex; align-items: flex-end; }
.hero-copy { max-width: 680px; }
.hero-copy .h1 { color: #fff; margin: 20px 0 22px; }
.hero-copy .sub { font-size: clamp(19px, 1.7vw, 23px); line-height: 1.5; color: rgba(255,255,255,0.92); max-width: 620px; margin-bottom: 32px; }
.hero-clip { flex: 0 0 320px; width: 320px; }
.hero-clip .video-slot { box-shadow: 0 26px 60px rgba(0,0,0,0.42); }
.hero-clip .cap { color: rgba(255,255,255,0.72); font-size: 12.5px; margin-top: 11px; }
.hero .vision-tag { top: auto; bottom: 26px; left: auto; right: var(--pad); }

/* headline mask-reveal entrance (visible by default; JS arms it only when motion is allowed) */
.hero-title { display: block; }
.hero-title .line { display: block; overflow: hidden; padding-bottom: 0.1em; margin-bottom: -0.1em; }
.hero-title .line-inner { display: block; }
@media (prefers-reduced-motion: no-preference) {
  .hero-title.armed .line-inner { transform: translateY(112%); opacity: 0; transition: transform 0.95s cubic-bezier(.19,.9,.22,1), opacity 0.8s ease; }
  .hero-title.armed .line:nth-child(2) .line-inner { transition-delay: 0.16s; }
  .hero-title.go .line-inner { transform: none; opacity: 1; }
  .hero-copy.armed .eyebrow, .hero-copy.armed .sub, .hero-copy.armed .cta-row { opacity: 0; transform: translateY(12px); transition: opacity 0.8s ease, transform 0.8s ease; }
  .hero-copy.go .eyebrow { transition-delay: 0.05s; }
  .hero-copy.go .sub { transition-delay: 0.6s; }
  .hero-copy.go .cta-row { transition-delay: 0.8s; }
  .hero-copy.go .eyebrow, .hero-copy.go .sub, .hero-copy.go .cta-row { opacity: 1; transform: none; }
}

/* trust strip under hero */
.trust { background: var(--sage); color: var(--ink); border-top: 1px solid var(--line-sage); border-bottom: 1px solid var(--line-sage); }
.trust-inner { display: flex; flex-wrap: wrap; align-items: center; gap: 16px 44px; padding: 24px var(--pad); max-width: var(--maxw); margin: 0 auto; }
.trust-item { display: flex; align-items: center; gap: 12px; font-size: 16px; color: var(--ink); }
.trust-item b { color: var(--ink); font-weight: 700; }
.trust-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green-dp); flex: 0 0 auto; }
.trust-sep { width: 1px; height: 22px; background: var(--line-sage); }

/* ============================================================
   INTRO (sponge)
   ============================================================ */
.intro-stack { display: flex; flex-direction: column; gap: clamp(32px, 4vw, 48px); }
.intro-head { max-width: 900px; display: flex; flex-direction: column; gap: 18px; }
.intro-figure { align-self: stretch; display: flex; flex-direction: column; gap: 16px; }
.intro-video { position: relative; border-radius: 18px; overflow: hidden; cursor: pointer; width: 100%; }
.intro-video img { width: 100%; height: auto; display: block; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset, 0 22px 50px rgba(22,53,43,0.12); }
.intro-video video { width: 100%; height: auto; display: block; border-radius: 18px; }
.intro-figbar { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.intro-play { display: inline-flex; align-items: center; gap: 12px; padding: 13px 24px 13px 15px; border: 0; border-radius: 999px; cursor: pointer;
  font-family: var(--text); font-weight: 600; font-size: 15.5px; color: #fff; background: var(--green-dp); box-shadow: 0 10px 26px rgba(47,107,48,0.26);
  flex: 0 0 auto; transition: transform .18s ease, box-shadow .18s ease; }
.intro-play:hover { transform: translateY(-1px); box-shadow: 0 14px 32px rgba(47,107,48,0.34); }
.intro-play-ic { width: 30px; height: 30px; border-radius: 50%; background: rgba(255,255,255,0.18); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.intro-play-ic::after { content: ''; border-style: solid; border-width: 7px 0 7px 11px; border-color: transparent transparent transparent #fff; margin-left: 3px; }
.intro-body { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 56px); max-width: 1040px; }
.intro-body p { color: var(--ink-soft); font-size: 16.5px; line-height: 1.62; }
.intro-fig-cap { display: flex; gap: 9px; font-size: 13.5px; color: var(--ink-soft); line-height: 1.45; flex: 1 1 320px; min-width: 280px; }
.intro-fig-cap .ifc-dot { flex: 0 0 auto; margin-top: 6px; width: 7px; height: 7px; border-radius: 50%; background: var(--green); }

/* word-by-word "imagining" reveal on the lead sentence */
.intro-imagine .il-w { display: inline-block; }
@media (prefers-reduced-motion: no-preference) {
  .intro-imagine.armed .il-w { opacity: 0; filter: blur(6px); transform: translateY(6px);
    transition: opacity .6s ease, filter .6s ease, transform .6s ease; }
  .intro-imagine.armed .il-rest { opacity: 0; transition: opacity .9s ease .1s; }
  .intro-imagine.go .il-w { opacity: 1; filter: blur(0); transform: none; }
  .intro-imagine.go .il-rest { opacity: 1; }
}
.intro-lead { font-family: var(--disp); font-weight: 500; font-size: clamp(22px, 2.15vw, 28px);
  line-height: 1.4; letter-spacing: -0.015em; color: var(--ink); }
.intro-lead b { color: var(--green-dp); font-weight: 700; }
.intro-body { display: flex; flex-direction: column; gap: 16px; }
.intro-body p { color: var(--ink-soft); font-size: 16.5px; line-height: 1.62; }
.benefits { display: flex; flex-wrap: nowrap; justify-content: space-between; gap: 8px; margin-top: clamp(34px, 4vw, 48px); }
.benefit { font-size: 12.5px; font-weight: 600; color: var(--green-dp); background: #fff; border: 1px solid var(--line-sage); border-radius: 999px; padding: 8px 13px 8px 11px; display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; box-shadow: 0 1px 0 var(--mist); }
.benefit::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: linear-gradient(135deg, var(--water), var(--green-br)); flex: 0 0 auto; }

/* ============================================================
   PROBLEM
   ============================================================ */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
.split.reverse > .figure { order: 2; }
.split .figure { border-radius: 18px; aspect-ratio: 5/4; }
.problem-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 8px; }
.problem-item { display: flex; flex-direction: column; gap: 11px; padding-top: 24px; border-top: 2px solid var(--green-dp); }
.problem-no { font-family: var(--disp); font-weight: 800; font-size: 13px; letter-spacing: 0.14em; color: var(--green-dp); }
.problem-item h3 { font-family: var(--disp); font-size: 21px; font-weight: 700; color: var(--ink); line-height: 1.2; }
.problem-fig { aspect-ratio: 4/3; border-radius: 14px; margin-bottom: 18px; background: #E7EEDC; box-shadow: 0 2px 0 var(--line-sage); }
.problem-fig img { width: 100%; height: 100%; object-fit: cover; object-position: center bottom; transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.problem-item:hover .problem-fig img { transform: scale(1.04); }
.problem-item:nth-child(2) .problem-fig img { object-position: center; }
.problem-item:nth-child(3) .problem-fig img { object-position: center; }
.problem-item:nth-child(2) .problem-fig { background: #DFE8CB; }
.problem-item p { font-size: 15.5px; color: var(--ink-soft); line-height: 1.55; }

/* hidden climate cost block – dark, high-contrast cost panel */
.climate { margin-top: clamp(56px, 7vw, 88px); background: var(--canopy); border-radius: 26px; padding: clamp(36px,5vw,64px); position: relative; overflow: hidden; }
.climate::before { content: ''; position: absolute; left: 0; top: 0; right: 0; height: 5px; background: linear-gradient(90deg, #C2502F 0%, #D98324 55%, var(--green-br) 100%); }
.climate-head { display: grid; grid-template-columns: 1.08fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.climate-divider { width: 48px; height: 3px; border-radius: 3px; background: linear-gradient(90deg, var(--water), var(--green-br)); margin-bottom: 22px; }
.climate-h { font-family: var(--disp); font-weight: 800; font-size: clamp(30px, 3.4vw, 44px); letter-spacing: -0.025em; color: #fff; line-height: 1.06; }
.climate-head p { margin: 0; font-size: 17px; color: rgba(255,255,255,0.72); line-height: 1.6; }
.climate-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-top: clamp(28px, 4vw, 44px); }
.climate-card { background: rgba(255,255,255,0.045); border: 1px solid rgba(255,255,255,0.12); border-radius: 16px; padding: 22px 20px; display: flex; flex-direction: column; gap: 11px; position: relative; transition: transform .28s cubic-bezier(.2,.7,.2,1), background .28s, border-color .28s; }
.climate-card::before { content: ''; position: absolute; left: 20px; right: 20px; top: 0; height: 2px; background: #C2502F; opacity: .85; }
.climate-card:hover { transform: translateY(-5px); background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.22); }
.cc-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.cc-icon { width: 40px; height: 40px; border-radius: 10px; background: rgba(194,80,47,0.18); color: #F0A07F; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.cc-icon svg { width: 22px; height: 22px; }
.cc-chip { font-family: var(--text); font-size: 10px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; padding: 4px 8px; border-radius: 999px; white-space: nowrap; }
.cc-chip-strong { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.78); }
.cc-chip-research { background: rgba(217,131,36,0.16); color: #E9B872; border: 1px dashed rgba(217,131,36,0.55); }
.climate-card h4 { font-family: var(--disp); font-size: 17px; font-weight: 700; color: #fff; line-height: 1.2; letter-spacing: -0.01em; }
.climate-card > p { font-size: 13.5px; color: rgba(255,255,255,0.66); line-height: 1.52; flex: 1 1 auto; }
.cc-rev { color: var(--green-lt); font-weight: 700; }
.cc-more { margin-top: 2px; border-top: 1px solid rgba(255,255,255,0.12); padding-top: 10px; }
.cc-more summary { font-family: var(--text); font-size: 13px; font-weight: 700; color: var(--green-lt); cursor: pointer; list-style: none; display: inline-flex; align-items: center; gap: 6px; }
.cc-more[open] summary { margin-bottom: 8px; }
.cc-more p { font-size: 12.5px; color: rgba(255,255,255,0.6); line-height: 1.5; }
.cc-more summary::-webkit-details-marker { display: none; }
.cc-more summary::before { content: '+'; font-weight: 700; font-size: 15px; line-height: 1; }
.cc-more[open] summary::before { content: '\2013'; }
.cc-more p { margin-top: 9px; font-size: 12.5px; color: rgba(255,255,255,0.82); line-height: 1.5; }

/* feature callout (street trees) – single full-width cost image */
.cost-figure { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 21/9; }
.cost-figure img { width: 100%; height: 100%; object-fit: cover; object-position: center 42%; filter: saturate(0.9) contrast(1.05); }
.cost-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(8,18,14,0.74) 0%, rgba(8,18,14,0.12) 42%, rgba(8,18,14,0) 70%); }
.cost-tag { position: absolute; left: 28px; bottom: 24px; z-index: 3; color: #fff; max-width: 560px; }
.cost-tag .t { font-family: var(--disp); font-weight: 700; font-size: 24px; letter-spacing: -0.015em; display: block; }
.cost-tag small { display: block; font-size: 15px; color: rgba(255,255,255,0.86); margin-top: 6px; line-height: 1.45; }
.cost-climax { display: grid; grid-template-columns: 1.08fr 1fr; gap: clamp(32px,5vw,72px); align-items: center; margin: clamp(46px,6vw,70px) 0 clamp(26px,3vw,34px); }
.cost-bridge { grid-column: 1 / -1; font-size: 18px; color: var(--ink-soft); line-height: 1.55; max-width: 880px; margin: 0 0 4px; }
.cost-climax-h { font-family: var(--disp); font-weight: 800; font-size: clamp(28px,3.2vw,40px); letter-spacing: -0.025em; color: var(--ink); line-height: 1.1; }
.cost-climax p { margin: 0; font-size: 17px; color: var(--ink-soft); line-height: 1.6; }
  background: repeating-linear-gradient(135deg, #8b9290 0 16px, #7c8381 16px 32px); color: #eef1ef; }
.ba-ph-cold .ph-k { font-family: var(--text); font-size: 12px; font-weight: 700; letter-spacing: 0.13em; text-transform: uppercase; }
.ba-ph-cold .ph-d { font-size: 13px; color: rgba(255,255,255,0.9); max-width: 220px; line-height: 1.4; }

/* ============================================================
   SOLUTION / CULTURAL / MODULAR
   ============================================================ */
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; counter-reset: pillar; }
.solution-head { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(32px, 5vw, 60px); align-items: center; margin-bottom: clamp(40px, 5vw, 60px); }
.solution-figure { position: relative; border-radius: 22px; overflow: hidden; aspect-ratio: 4/3; box-shadow: 0 24px 56px rgba(22,53,43,0.20); }
.solution-figure img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.2,1); }
.solution-figure:hover img { transform: scale(1.05); }
.solution-fig-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(9,24,18,0.78) 0%, rgba(9,24,18,0.18) 40%, rgba(9,24,18,0) 66%); }
.solution-fig-tag { position: absolute; left: 26px; right: 26px; bottom: 22px; z-index: 2; color: #fff; }
.solution-fig-tag .t { font-family: var(--disp); font-weight: 700; font-size: clamp(22px, 2.1vw, 27px); letter-spacing: -0.015em; display: block; }
.solution-fig-tag small { display: block; font-size: 14.5px; color: rgba(255,255,255,0.86); margin-top: 5px; }
.pillar { position: relative; background: var(--canopy); border: 0; border-radius: 22px; padding: 40px 30px 34px; display: flex; flex-direction: column; gap: 14px; overflow: hidden; counter-increment: pillar; box-shadow: 0 16px 40px rgba(22,53,43,0.16); transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease; }
.pillar::before { content: ''; position: absolute; left: 0; top: 0; right: 0; height: 5px; background: linear-gradient(90deg, var(--water) 0%, var(--green-br) 100%); }
.pillar::after { content: counter(pillar, decimal-leading-zero); position: absolute; top: 22px; right: 24px; font-family: var(--disp); font-weight: 800; font-size: 52px; line-height: 1; color: rgba(255,255,255,0.07); letter-spacing: -0.04em; }
.pillar:hover { transform: translateY(-6px); box-shadow: 0 26px 56px rgba(22,53,43,0.26); }
.bg-canopy .pillar { background: var(--canopy-2); border-color: var(--d-line); }
.pillar .pn { font-family: var(--disp); font-weight: 800; font-size: 14px; letter-spacing: 0.12em; color: var(--green-lt); }
/* animated BGI droplet marker – bare droplet (no circle) */
.pn-drop { position: relative; display: inline-flex; align-items: flex-end; justify-content: center; width: 46px; height: 60px; }
.pn-drop img { width: 38px; height: auto; display: block; position: relative; z-index: 2; will-change: transform; }
.pn-drop .ripple { position: absolute; left: 50%; bottom: 2px; width: 30px; height: 8px; transform: translateX(-50%); border-radius: 50%;
  background: radial-gradient(closest-side, rgba(159,217,130,0.4), rgba(159,217,130,0) 72%); z-index: 1; }
@media (prefers-reduced-motion: no-preference) {
  .pn-drop img { animation: dropBob 3.4s ease-in-out infinite; transform-origin: center bottom; }
  .pn-drop .ripple { animation: dropRipple 3.4s ease-in-out infinite; }
  .pillars .pillar:nth-child(2) .pn-drop img, .pillars .pillar:nth-child(2) .pn-drop .ripple { animation-delay: 0.55s; }
  .pillars .pillar:nth-child(3) .pn-drop img, .pillars .pillar:nth-child(3) .pn-drop .ripple { animation-delay: 1.1s; }
}
@keyframes dropBob {
  0%, 100% { transform: translateY(0) scaleX(1) scaleY(1); }
  28% { transform: translateY(-7px) scaleX(0.96) scaleY(1.05); }
  60% { transform: translateY(0) scaleX(1.06) scaleY(0.95); }
  72% { transform: translateY(0) scaleX(0.99) scaleY(1.01); }
}
@keyframes dropRipple {
  0%, 52%, 100% { transform: translateX(-50%) scale(0.5); opacity: 0; }
  62% { opacity: 1; }
  80% { transform: translateX(-50%) scale(1.5); opacity: 0; }
}
.bg-canopy .pillar .pn { color: var(--green-lt); }
.pillar h3 { font-size: 22px; color: #fff; margin-top: 4px; }
.pillar p { font-size: 15.5px; color: var(--d-soft); }
.bg-canopy .pillar p { color: var(--d-soft); }

.quote-band { position: relative; border-radius: 22px; overflow: hidden; color: #fff; }
.quote-band .figure { position: absolute; inset: 0; }
.quote-band .figure img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
.quote-band-scrim { position: absolute; inset: 0; background: linear-gradient(100deg, rgba(247,243,234,0.96) 0%, rgba(247,243,234,0.88) 34%, rgba(247,243,234,0.5) 56%, rgba(247,243,234,0) 78%); }
.quote-band-body { position: relative; z-index: 3; padding: clamp(44px, 6vw, 80px); max-width: 820px; }
.quote-band-body .q { font-family: var(--disp); font-weight: 700; font-size: clamp(25px, 2.7vw, 35px); line-height: 1.28; letter-spacing: -0.025em; color: var(--canopy); text-shadow: none; }
.quote-band-body .q b, .quote-band-body .q strong { color: var(--green-dp); }
.quote-band-body .eyebrow.on-dark { color: var(--green-dp); }
.quote-band-body .src { color: var(--ink-soft) !important; }
.quote-band-body .src { margin-top: 22px; font-size: 14.5px; color: rgba(255,255,255,0.7); }

/* modular */
.modular-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
.modular-grid .video-slot { box-shadow: 0 24px 56px rgba(22,53,43,0.2); }

/* ============================================================
   STAT BLOCKS
   ============================================================ */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.stat { display: flex; flex-direction: column; gap: 7px; }
.stat-rule { height: 3px; width: 32px; background: var(--green); border-radius: 3px; margin-bottom: 5px; }
.stat-n { font-family: var(--disp); font-size: clamp(34px, 3.6vw, 48px); font-weight: 800; letter-spacing: -0.035em; color: var(--green-dp); line-height: 0.98; }
.stat-n .u { font-size: 0.46em; font-weight: 700; color: var(--ink-soft); margin-left: 4px; letter-spacing: 0; }
.stat-l { font-size: 15px; color: var(--ink-soft); line-height: 1.4; }
.on-canopy .stat-rule { background: var(--green-lt); }
.on-canopy .stat-n { color: var(--green-lt); }
.on-canopy .stat-l { color: var(--d-soft); }
.stat.text .stat-n { font-size: clamp(26px, 2.6vw, 32px); }

/* ============================================================
   HOW IT WORKS (components)
   ============================================================ */
.components { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.component { position: relative; display: flex; background: var(--canopy); border: 0; border-radius: 22px; padding: 38px 30px 32px; overflow: hidden; box-shadow: 0 16px 40px rgba(22,53,43,0.16); transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease; }
.component::before { content: ''; position: absolute; left: 0; top: 0; right: 0; height: 5px; background: linear-gradient(90deg, var(--water) 0%, var(--green-br) 100%); }
.component:hover { transform: translateY(-6px); box-shadow: 0 26px 56px rgba(22,53,43,0.26); }
.component .cbody { display: flex; flex-direction: column; flex: 1; }
.component .cbody h3 { font-size: 22px; line-height: 1.18; margin-top: 8px; color: #fff; text-wrap: balance; }
.component .ctm { font-size: 12.5px; font-weight: 700; letter-spacing: 0.08em; color: var(--green-lt); text-transform: uppercase; }
.component .cbody p { color: var(--d-soft); margin-top: 13px; font-size: 15.5px; line-height: 1.6; text-wrap: pretty; }
.component .cfact { margin-top: 24px; display: inline-flex; align-items: baseline; gap: 9px; padding: 13px 17px; background: rgba(159,217,130,0.14); border: 1px solid rgba(159,217,130,0.2); border-radius: 12px; align-self: flex-start; }
.component .cfact b { font-family: var(--disp); font-weight: 800; font-size: 21px; color: var(--green-lt); letter-spacing: -0.02em; }
.component .cfact span { font-size: 13px; color: var(--d-soft); }
.cap-h { font-family: var(--disp); font-weight: 700; font-size: clamp(24px,2.6vw,32px); letter-spacing: -0.02em; color: var(--ink); line-height: 1.15; margin: 0 0 16px; }
.nbclause { display: inline-block; white-space: nowrap; }
.cap-block { display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(32px,5vw,64px); align-items: center; }
.cap-punch { font-size: clamp(26px,3vw,38px); font-weight: 800; line-height: 1.12; margin: 0; }
.cap-big { color: var(--green-dp); font-size: clamp(34px,4.4vw,56px); font-weight: 800; letter-spacing: -0.03em; display: inline-block; line-height: 1.02; }
.cap-body { display: flex; flex-direction: column; gap: 16px; padding-top: 6px; }
.cap-body p { font-size: 18px; color: var(--ink-soft); line-height: 1.62; margin: 0; }
.cap-body p.lede { font-size: 18px; color: var(--ink); }
@media (max-width: 860px) { .cap-block { grid-template-columns: 1fr; gap: 22px; } }
.culture-band { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 16/6; margin-top: clamp(28px, 4vw, 40px); }
.culture-band img { width: 100%; height: 100%; object-fit: cover; object-position: center 38%; }
.culture-src { margin-top: 18px; font-size: 13.5px; color: var(--ink-soft); max-width: 860px; line-height: 1.55; }

/* ============================================================
   VARIANTS
   ============================================================ */
.variants { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.variant { display: flex; flex-direction: column; gap: 9px; text-decoration: none; color: inherit; transition: transform .28s cubic-bezier(.2,.7,.2,1); }
.variant:hover { transform: translateY(-4px); }
.variant:hover .vfig { border-color: var(--green); box-shadow: 0 14px 32px rgba(22,53,43,0.12); }
.variant .vfig { transition: border-color .25s, box-shadow .25s; }
.v-more { font-family: var(--text); font-weight: 600; font-size: 14px; color: var(--green-dp); margin-top: 2px; opacity: 0; transform: translateY(-3px); transition: opacity .25s, transform .25s; }
.variant:hover .v-more { opacity: 1; transform: none; }
.variant .vfig { aspect-ratio: 16/10; border-radius: 14px; background: #fff; border: 1px solid var(--line); overflow: hidden; }
.variant .vfig img { width: 100%; height: 100%; object-fit: contain; }
.partners-lockup { height: 96px; width: auto; max-width: 100%; opacity: 1; }
.variant .vn { font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green); }
.variant h4 { font-family: var(--disp); font-size: 18px; margin-top: 2px; }
.variant p { font-size: 14px; color: var(--ink-soft); margin-top: 4px; }

/* ============================================================
   DEFENSIBILITY / IP
   ============================================================ */
.defend { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.defend-item { background: var(--paper-2); border: 1px solid var(--line); border-radius: 18px; padding: 30px; }
.defend-item .di-no { display: block; font-family: var(--disp); font-weight: 800; font-size: 13px; letter-spacing: 0.14em; color: var(--green-dp); margin-bottom: 12px; }
.defend-item h3 { color: var(--ink); font-size: 20px; }
.defend-item p { color: var(--ink-soft); font-size: 15.5px; margin-top: 10px; }

/* Technology partners – two equal cells */
.partners-wrap { display: flex; flex-direction: column; align-items: center; gap: 22px; text-align: center; }
.partners-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0; max-width: 1000px; width: 100%; }
.partner-cell { display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 16px; padding: 8px clamp(24px,4vw,52px); }
.partner-cell:first-child { border-right: 1px solid var(--line); }
.partner-cell .partners-lockup { height: auto; width: 100%; max-width: 360px; object-fit: contain; }
.partner-cell .pm-logo img { height: 40px; width: auto; display: block; }
.partner-cap { margin: 0; font-size: 14.5px; color: var(--ink-soft); line-height: 1.55; }
.partner-cap b { color: var(--ink); }
.partner-cap a { color: var(--green-dp); font-weight: 600; text-decoration: none; }
.partner-cap a:hover { text-decoration: underline; }
.contact-meta { margin-top: 30px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 12px 26px; }
.contact-meta .cm-email { font-family: var(--text); font-weight: 600; font-size: 16px; color: var(--green-dp); text-decoration: none; }
.contact-meta .cm-email:hover { text-decoration: underline; }
.contact-meta .cm-loc { font-size: 15px; color: var(--ink-soft); }

/* ============================================================
   PARTNERSHIP / INVESTMENT
   ============================================================ */
.invest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.invest-point { display: flex; flex-direction: column; gap: 9px; padding-top: 22px; border-top: 2px solid var(--green-dp); }
.invest-point .ip-no { font-family: var(--disp); font-weight: 800; font-size: 13px; letter-spacing: 0.14em; color: var(--green-dp); }
.invest-point h3 { font-family: var(--disp); font-size: 20px; font-weight: 700; color: var(--ink); }
.invest-point p { font-size: 15px; color: var(--ink-soft); line-height: 1.55; }
.invest-note { margin-top: clamp(28px, 4vw, 40px); font-size: 15.5px; color: var(--ink-soft); }
.invest-note a { color: var(--green-dp); font-weight: 600; text-decoration: none; }
.invest-note a:hover { text-decoration: underline; }
/* inline learn-more link */
.inline-link { color: var(--green-lt); font-weight: 600; text-decoration: none; white-space: nowrap; }
.on-canopy .inline-link, .component .inline-link { color: var(--green-lt); }
.inline-link:hover { text-decoration: underline; }
/* flooded-street band */
.flood-band { margin: clamp(36px,5vw,56px) 0 0; }
.flood-band figcaption { margin-top: 16px; font-size: 16px; color: var(--ink-soft); line-height: 1.55; max-width: 880px; }
.flood-band figcaption b { color: var(--ink); }
.flood-frame { border-radius: 18px; overflow: hidden; aspect-ratio: 21/8; }
.flood-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* footer full wordmark */
.footer-wordmark { display: inline-block; }
.footer-wordmark img { height: 84px; width: auto; display: block; }
/* live monitoring band (How it works) */
.monitor-band { margin-top: 0; background: linear-gradient(105deg, var(--sage) 0%, var(--sage-2) 100%); border: 0; border-left: 4px solid var(--green); border-radius: 14px; padding: clamp(26px,3vw,40px) clamp(28px,4vw,48px); display: flex; align-items: center; gap: clamp(28px,4vw,56px); }vw,56px); }
.monitor-band .mb-text { flex: 1 1 auto; }
.monitor-band .ctm { font-size: 12.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.monitor-band .cap-h { font-family: var(--disp); font-weight: 700; font-size: clamp(22px,2.3vw,28px); letter-spacing: -0.02em; color: var(--ink); }
.monitor-band p { font-size: 16px; line-height: 1.55; max-width: 760px; }
/* EnviroKerb/ESPPI inline video */
.esppi-video { position: relative; border-radius: 16px; overflow: hidden; cursor: pointer; aspect-ratio: 16/10; background: #0E211B; box-shadow: 0 24px 56px rgba(22,53,43,0.2); }
.esppi-video video { width: 100%; height: 100%; object-fit: cover; display: block; }
.esppi-play { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); display: inline-flex; align-items: center; gap: 11px; padding: 12px 20px 12px 14px; border: 0; border-radius: 999px; cursor: pointer; font-family: var(--text); font-weight: 600; font-size: 15px; color: var(--canopy); background: rgba(255,255,255,0.92); backdrop-filter: blur(4px); box-shadow: 0 10px 30px rgba(0,0,0,0.3); transition: transform .18s, background .18s; }
.esppi-video:hover .esppi-play { transform: translate(-50%,-50%) scale(1.04); background: #fff; }
.ep-ic { width: 28px; height: 28px; border-radius: 50%; background: var(--green-dp); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.ep-ic::after { content: ''; border-style: solid; border-width: 6px 0 6px 10px; border-color: transparent transparent transparent #fff; margin-left: 3px; }
.esppi-duo { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px,3vw,32px); margin-top: clamp(28px,4vw,40px); }
.esppi-duo figure { margin: 0; }
.esppi-duo .esppi-video { aspect-ratio: 16/10; }
.esppi-duo figure:nth-child(1) .esppi-video video { object-fit: cover; object-position: center 35%; background: #0E211B; }
.esppi-duo figure:nth-child(2) .esppi-video video { object-fit: cover; object-position: center 63%; background: #0E211B; }
.esppi-duo figcaption { margin-top: 14px; font-size: 14.5px; color: var(--ink-soft); line-height: 1.55; }
.esppi-duo figcaption b { color: var(--ink); }
.esppi-note { margin-top: clamp(20px,3vw,28px); font-size: 14.5px; color: var(--ink-soft); line-height: 1.6; max-width: 920px; }
@media (max-width: 760px) { .esppi-duo { grid-template-columns: 1fr; } }
.monitor-band .mb-link { display: inline-block; margin-top: 14px; font-family: var(--text); font-weight: 600; font-size: 15px; color: var(--green-dp); text-decoration: none; }
.monitor-band .mb-link:hover { text-decoration: underline; }
.monitor-band .mb-logo { flex: 0 0 auto; }
.monitor-band .mb-logo img { height: 48px; width: auto; display: block; }
@media (max-width: 760px) { .monitor-band { flex-direction: column; align-items: flex-start; gap: 20px; } }
.invest { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(40px, 5vw, 72px); align-items: center; }
.invest ul { margin: 22px 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 15px; }
.invest li { display: flex; gap: 13px; font-size: 16.5px; color: var(--ink-soft); }
.invest li::before { content:''; flex: 0 0 auto; margin-top: 9px; width: 8px; height: 8px; background: var(--green); transform: rotate(45deg); border-radius: 2px; }
.invest li b { color: var(--ink); }
.invest-card { background: var(--canopy); color: #fff; border-radius: 22px; padding: clamp(32px, 4vw, 48px); }
.invest-card h3 { color: #fff; font-size: 25px; }
.invest-card p { color: var(--d-soft); margin-top: 12px; font-size: 16.5px; }
.invest-card .cta-row { margin-top: 26px; }
.invest-card .note { margin-top: 20px; font-size: 13px; color: rgba(255,255,255,0.5); }

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.contact { position: relative; overflow: hidden; padding-top: clamp(56px, 6vw, 84px); padding-bottom: clamp(56px, 6vw, 84px); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(36px, 5vw, 72px); align-items: start; max-width: var(--maxw); margin: 0 auto; }
.contact-intro .h2 { color: var(--ink); margin: 14px 0 16px; }
.contact-intro .lede { color: var(--ink-soft); margin: 0; }
.contact-intro .contact-meta { margin-top: 26px; justify-content: flex-start; }
.contact-form { background: var(--paper-2); border: 1px solid var(--line); border-radius: 20px; padding: clamp(26px, 3vw, 36px); box-shadow: 0 16px 40px rgba(22,53,43,0.08); }
.cf-note { font-size: 12.5px; color: var(--ink-soft); margin-bottom: 18px; line-height: 1.5; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cf-field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 14px; }
.cf-field span { font-family: var(--text); font-size: 13px; font-weight: 600; color: var(--ink); }
.cf-field input, .cf-field select, .cf-field textarea { font-family: var(--text); font-size: 15px; color: var(--ink); background: #fff; border: 1px solid var(--line-sage); border-radius: 10px; padding: 11px 13px; width: 100%; transition: border-color .15s, box-shadow .15s; }
.cf-field input:focus, .cf-field select:focus, .cf-field textarea:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(95,174,50,0.16); }
.cf-field textarea { resize: vertical; min-height: 96px; }
.cf-hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.cf-submit { margin-top: 6px; width: 100%; justify-content: center; }
.cf-fallback { margin-top: 14px; font-size: 13.5px; color: var(--ink-soft); text-align: center; }
.cf-fallback a { color: var(--green-dp); font-weight: 600; text-decoration: none; }
.cf-fallback a:hover { text-decoration: underline; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--paper); color: var(--ink-soft); padding: clamp(48px, 6vw, 76px) 0 34px; border-top: 1px solid var(--line); }
.footer-top { display: grid; grid-template-columns: 1.7fr 1fr 1fr 1.1fr; gap: 44px; padding-bottom: 40px; }
.footer-brand { display: flex; flex-direction: column; gap: 16px; }
.footer-brand .fb { display: flex; align-items: center; gap: 12px; }
.footer-brand .fb img { width: 36px; height: 50px; object-fit: contain; }
.footer-brand .fb span { font-family: var(--disp); font-weight: 700; font-size: 18px; color: var(--ink); }
.footer-brand p { font-size: 14.5px; max-width: 320px; line-height: 1.55; }
.footer-col h4 { font-family: var(--text); color: var(--ink); font-size: 12.5px; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 15px; font-weight: 700; }
.footer-col a { display: block; color: var(--ink-soft); text-decoration: none; font-size: 14.5px; margin-bottom: 10px; transition: color .15s; }
.footer-col a:hover { color: var(--ink); }
.footer-legal { border-top: 1px solid var(--line); padding-top: 24px; display: flex; justify-content: space-between; gap: 36px; flex-wrap: wrap; }
.footer-legal p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.65; max-width: 820px; }
.footer-legal .copy { white-space: nowrap; }

/* ============================================================
   REVEAL ANIMATION (progressive – visible by default)
   ============================================================ */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
  .reveal.in { opacity: 1; transform: none; }
  .hero-bg img { animation: heroZoom 26s ease-out both; }
}
@keyframes heroZoom { from { transform: scale(1.09); } to { transform: scale(1); } }

/* ---- premium hover & image motion ---- */
.variant, .component, .defend-item { transition: transform .28s cubic-bezier(.2,.7,.2,1), box-shadow .28s ease, border-color .28s ease; }
.variant:hover, .component:hover, .defend-item:hover { transform: translateY(-4px); box-shadow: 0 18px 44px rgba(22,53,43,0.12); border-color: var(--line-sage); }
.variant .vfig img, .bas-good img, .quote-band .figure img, .canopy-band img { transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.variant:hover .vfig img, .bas-good:hover img, .quote-band:hover .figure img, .canopy-band:hover img { transform: scale(1.05); }
.canopy-band { border-radius: 18px; aspect-ratio: 32/10; overflow: hidden; }
.nav-links a { position: relative; }
.nav-links a::after { content: ''; position: absolute; left: 0; right: 0; bottom: -5px; height: 2px; background: var(--green-dp); border-radius: 2px; transform: scaleX(0); transform-origin: left; transition: transform .25s ease; }
.nav-links a:hover::after { transform: scaleX(1); }
.stat-n .count { font-variant-numeric: tabular-nums; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .stats { grid-template-columns: repeat(2, 1fr); gap: 30px 26px; }
  .pillars { grid-template-columns: 1fr; }
  .climate-grid { grid-template-columns: repeat(3, 1fr); }
  .variants { grid-template-columns: repeat(2, 1fr); }
  .benefits { flex-wrap: wrap; justify-content: flex-start; gap: 10px; }
  .defend { grid-template-columns: 1fr; }
}
@media (max-width: 1200px) { .brand-name { display: none; } }
@media (max-width: 1000px) { .nav-links { display: none; } }
@media (max-width: 900px) {
  :root { --pad: 24px; }
  .nav-links { display: none; }
  .hero-inner { flex-direction: column; align-items: flex-start; }
  .hero-clip { width: 100%; flex: none; max-width: 420px; }
  .hero .vision-tag { top: 76px; }
  .intro-grid, .split, .modular-grid, .invest, .quote-band-body, .problem-list, .problem-head, .solution-head, .intro-body, .cost-climax { grid-template-columns: 1fr; }
  .problem-head { gap: 18px; align-items: start; }
  .climate-head { grid-template-columns: 1fr; gap: 16px; align-items: start; }
  .climate-grid { grid-template-columns: repeat(2, 1fr); }
  .partner-matter { flex-direction: column; align-items: flex-start; gap: 16px; }
  .partners-row { grid-template-columns: 1fr; gap: 28px; }
  .partner-cell:first-child { border-right: 0; border-bottom: 1px solid var(--line); padding-bottom: 28px; }
  .solution-figure { aspect-ratio: 16/10; }
  .benefits { flex-wrap: wrap; justify-content: flex-start; gap: 10px; }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .invest-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
  .cost-figure { aspect-ratio: 4/3; }
  .split.reverse > .figure { order: 0; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .components { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .stats, .variants { grid-template-columns: 1fr; }
  .climate-grid { grid-template-columns: 1fr; }
  .cf-row { grid-template-columns: 1fr; gap: 0; }
  .invest-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .footer-legal { flex-direction: column; gap: 14px; }
  .trust-sep { display: none; }
}
