/* ============================================================
   OCEAN GREENS — microsite stylesheet
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --abyss:#021a22;
  --deep:#052a33;
  --deep-2:#073640;
  --ocean:#0a4a52;
  --kelp:#34a96a;
  --kelp-dark:#1c7a48;
  --lime:#c4ff5e;
  --aqua:#5fe8d0;
  --sand:#d6c498;
  --sand-dark:#a98f54;
  --paper:#f1f6ef;
  --cream:#e7efe6;
  --ink:#0a2723;
  --ink-soft:#3c5651;
  --line:#0a27231a;
  --radius:20px;
  --radius-s:13px;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-d:'Bricolage Grotesque',system-ui,sans-serif;
  --font-b:'Inter',system-ui,sans-serif;
}

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

body{
  font-family:var(--font-b);
  background:var(--abyss);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.6;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input,textarea,select{font-family:inherit}
::selection{background:var(--lime);color:var(--abyss)}

h1,h2,h3{font-family:var(--font-d);font-weight:700;line-height:1.04;letter-spacing:-.02em}

/* ---------- SHARED ---------- */
section[id]{scroll-margin-top:78px}
.section{
  max-width:var(--maxw);
  margin-inline:auto;
  padding:clamp(80px,11vw,160px) clamp(20px,5vw,64px);
  position:relative;
}
.section__head{max-width:880px;margin-bottom:clamp(48px,6vw,84px)}
.eyebrow{
  font-family:var(--font-d);font-weight:600;font-size:.82rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--kelp-dark);margin-bottom:22px;
}
.eyebrow--light{color:var(--lime)}
.section__title{
  font-size:clamp(2rem,4.6vw,3.7rem);
  color:var(--ink);
}
.section__title--light{color:var(--paper)}
.section__intro{
  margin-top:24px;font-size:clamp(1.02rem,1.5vw,1.22rem);
  color:var(--ink-soft);max-width:720px;
}
.section__intro--light{color:#bcd4cd}
.section__intro em{color:var(--kelp-dark);font-style:italic}
.section__intro--light strong{color:var(--lime);font-weight:600}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-d);font-weight:600;font-size:1rem;
  padding:16px 26px;border-radius:100px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  will-change:transform;
}
.btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2.4;
  stroke-linecap:round;stroke-linejoin:round;transition:transform .3s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn--primary{background:var(--lime);color:var(--abyss);
  box-shadow:0 10px 30px -8px #c4ff5e88}
.btn--primary:hover{box-shadow:0 16px 40px -8px #c4ff5ecc;transform:translateY(-2px)}
.btn--ghost{border:1.5px solid #ffffff44;color:#fff}
.btn--ghost:hover{border-color:var(--aqua);background:#ffffff12;transform:translateY(-2px)}
.btn--soft{background:var(--ink);color:var(--paper)}
.btn--soft:hover{background:var(--kelp-dark);transform:translateY(-2px)}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(34px);
  transition:opacity .9s var(--ease),transform .9s var(--ease);
  transition-delay:var(--d,0s);}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:200;
  background:radial-gradient(120% 90% at 50% 30%,#0a4a52,#021a22 70%);
  display:grid;place-items:center;
  transition:opacity .7s var(--ease),visibility .7s;
}
.preloader.done{opacity:0;visibility:hidden}
.preloader__inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.preloader__kelp{width:46px;height:92px;overflow:visible}
.preloader__frond{
  fill:none;stroke:var(--lime);stroke-width:5;stroke-linecap:round;
  stroke-dasharray:240;stroke-dashoffset:240;
  animation:grow 1.6s var(--ease) forwards;
}
@keyframes grow{to{stroke-dashoffset:0}}
.preloader__word{
  font-family:var(--font-d);font-weight:800;letter-spacing:.22em;
  color:#fff;font-size:1.05rem;margin-top:14px;
  opacity:0;animation:fadeUp .6s .7s var(--ease) forwards;
}
.preloader__sub{
  font-size:.82rem;color:var(--aqua);letter-spacing:.04em;
  opacity:0;animation:fadeUp .6s 1s var(--ease) forwards;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ============================================================
   PROGRESS + CURSOR GLOW
   ============================================================ */
.progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--kelp),var(--lime),var(--aqua));
  box-shadow:0 0 14px #c4ff5e99;
}
.cursor-glow{
  position:fixed;top:0;left:0;width:520px;height:520px;
  margin:-260px 0 0 -260px;border-radius:50%;pointer-events:none;z-index:1;
  background:radial-gradient(circle,#5fe8d022,transparent 65%);
  opacity:0;transition:opacity .4s;mix-blend-mode:screen;
}
@media (hover:hover){.cursor-glow{opacity:1}}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,48px);
  transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s;
}
.nav.scrolled{
  background:#04222baa;backdrop-filter:blur(14px);
  padding-top:12px;padding-bottom:12px;
  box-shadow:0 1px 0 #ffffff14;
}
.nav__brand{display:flex;align-items:center;gap:11px;color:#fff;z-index:2}
.nav__mark{
  width:34px;height:34px;display:grid;place-items:center;
  background:var(--lime);border-radius:10px;
}
.nav__mark svg{width:21px;height:21px;fill:var(--abyss)}
.nav__name{font-family:var(--font-d);font-weight:700;font-size:1.12rem;letter-spacing:-.01em}
.nav__links{display:flex;align-items:center;gap:4px}
.nav__links a{
  color:#dcebe7;font-size:.95rem;font-weight:500;
  padding:9px 15px;border-radius:100px;transition:color .25s,background .25s;
}
.nav__links a:hover{color:#fff;background:#ffffff14}
.nav__cta{
  background:var(--lime);color:var(--abyss)!important;
  font-family:var(--font-d);font-weight:600;margin-left:8px;
}
.nav__cta:hover{background:#fff!important;}
.nav__burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;
  align-items:center;justify-content:center;z-index:2}
.nav__burger span{width:22px;height:2px;background:#fff;border-radius:2px;
  transition:transform .3s var(--ease),opacity .2s}
.nav.open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:center;
  background:#02161c;
  overflow:hidden;
  padding:140px clamp(20px,5vw,64px) 120px;
}
.hero__photo{
  position:absolute;inset:0;z-index:0;
  background:url('https://images.unsplash.com/photo-1745917784526-fbad88531db1?w=2200&q=80&auto=format&fit=crop') center/cover no-repeat;
  filter:saturate(1.05);
}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.hero__depth{
  position:absolute;inset:0;z-index:1;
  background:
   linear-gradient(100deg,rgba(2,22,28,.78) 0%,rgba(2,22,28,.55) 38%,rgba(2,22,28,.15) 65%,rgba(2,22,28,0) 100%),
   linear-gradient(180deg,rgba(2,22,28,.35) 0%,transparent 32%,rgba(2,22,28,.85) 100%);
}
.hero__rays{
  position:absolute;inset:-20% 0 0;z-index:1;pointer-events:none;
  background:
    linear-gradient(78deg,transparent 42%,#bdfff044 49%,transparent 56%),
    linear-gradient(92deg,transparent 60%,#bdfff033 66%,transparent 72%),
    linear-gradient(70deg,transparent 20%,#bdfff038 26%,transparent 33%);
  mix-blend-mode:screen;
  animation:rays 14s ease-in-out infinite alternate;
  transform-origin:top;
}
@keyframes rays{from{transform:translateX(-3%) scaleY(1)}to{transform:translateX(3%) scaleY(1.08)}}
.hero__kelp{
  position:absolute;left:0;right:0;bottom:0;height:62%;z-index:2;
  display:flex;align-items:flex-end;justify-content:space-around;
  pointer-events:none;filter:blur(.3px);
}
.hero__floor{
  position:absolute;left:0;right:0;bottom:0;height:90px;z-index:3;
  background:linear-gradient(180deg,transparent,#02141a 70%);
}
.hero__inner{
  position:relative;z-index:5;max-width:var(--maxw);width:100%;margin-inline:auto;
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-d);font-weight:600;font-size:.82rem;
  letter-spacing:.13em;text-transform:uppercase;color:var(--aqua);
  padding:9px 16px;border:1px solid #5fe8d040;border-radius:100px;
  background:#0a3a3f66;margin-bottom:28px;
}
.hero__eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);
  box-shadow:0 0 10px var(--lime);animation:blink 2s infinite}
@keyframes blink{50%{opacity:.3}}
.hero__title{
  font-size:clamp(2.7rem,7.4vw,6.4rem);font-weight:800;color:#fff;
  max-width:15ch;
}
.hero__title span{display:block}
.hero__title--accent{
  background:linear-gradient(100deg,var(--lime),var(--aqua));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero__lead{
  margin-top:26px;max-width:54ch;font-size:clamp(1.05rem,1.6vw,1.3rem);
  color:#c4dbd6;
}
.hero__actions{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}
.hero__stats{
  margin-top:54px;display:grid;grid-template-columns:repeat(3,1fr);
  gap:14px;max-width:760px;
}
.hero__stat{
  border-left:2px solid #5fe8d04d;padding-left:16px;
}
.hero__stat strong{
  display:block;font-family:var(--font-d);font-weight:700;
  font-size:clamp(1.7rem,3vw,2.5rem);color:var(--lime);line-height:1;
}
.hero__stat span{display:block;margin-top:8px;font-size:.86rem;color:#9fbcb6}
.hero__scroll{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:5;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:var(--font-d);font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;color:#9fbcb6;
}
.hero__scroll-line{width:1.5px;height:46px;background:linear-gradient(#5fe8d0,transparent);
  position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;
  background:var(--lime);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}60%,100%{transform:translateY(260%)}}

/* kelp fronds (shared) */
.kelp-frond{
  transform-origin:bottom center;
  animation:sway var(--dur,7s) ease-in-out infinite alternate;
  animation-delay:var(--delay,0s);
}
@keyframes sway{from{transform:rotate(-4deg)}to{transform:rotate(4.5deg)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--abyss);border-block:1px solid #ffffff12;
  padding:18px 0;overflow:hidden;white-space:nowrap;
}
.marquee__track{
  display:inline-flex;align-items:center;gap:34px;
  animation:slide 32s linear infinite;
}
.marquee__track span{
  font-family:var(--font-d);font-weight:700;font-size:clamp(1.1rem,2vw,1.7rem);
  color:#fff;text-transform:uppercase;letter-spacing:.01em;
}
.marquee__dot{color:var(--lime)!important;font-size:1rem!important}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================
   CRISIS
   ============================================================ */
.crisis{background:var(--paper)}
.compare{margin:0 0 clamp(40px,5vw,64px)}
.compare__stage{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:16/8.4;box-shadow:0 40px 80px -40px #04303a66;
  cursor:ew-resize;
  --pos:42%;
}
@media (max-width:640px){
  .compare__stage{aspect-ratio:4/4.6}
  .compare__tag{font-size:.7rem;padding:6px 10px}
  .compare__tag--left{left:12px;bottom:12px}
  .compare__tag--right{right:12px;bottom:12px}
}
.scene{position:absolute;inset:0;overflow:hidden;isolation:isolate;background-size:cover;background-position:center}
.scene--forest{
  z-index:1;
  background-image:
   linear-gradient(180deg,rgba(8,60,64,.15) 0%,rgba(4,40,46,.45) 100%),
   url('https://images.unsplash.com/photo-1745909123989-92cee1d0aaf5?w=1800&q=80&auto=format&fit=crop');
}
.scene--barren{
  z-index:2;
  background-image:
   linear-gradient(180deg,rgba(70,68,52,.25) 0%,rgba(50,42,28,.55) 100%),
   url('https://images.unsplash.com/photo-1774966772067-e252a4044d7a?w=1800&q=80&auto=format&fit=crop');
  filter:grayscale(.25) saturate(.85) brightness(.92) contrast(1.05);
  clip-path:inset(0 calc(100% - var(--pos)) 0 0);
}
.scene__floor{position:absolute;left:0;right:0;bottom:0;height:24%}
.scene--forest .scene__floor{
  background:linear-gradient(180deg,transparent,#04262a);
}
.scene--barren .scene__floor{
  background:linear-gradient(180deg,transparent,#3f3322);
}
.scene__caption{
  position:absolute;left:20px;bottom:18px;z-index:4;
  font-family:var(--font-d);font-weight:600;
}
.compare__handle{
  position:absolute;top:0;bottom:0;left:var(--pos);
  transform:translateX(-50%);z-index:6;pointer-events:none;
}
.compare__line{
  position:absolute;top:0;bottom:0;left:50%;width:3px;
  transform:translateX(-50%);
  background:linear-gradient(180deg,var(--lime),#fff,var(--lime));
  box-shadow:0 0 18px #ffffffaa;
}
.compare__knob{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:#fff;display:grid;place-items:center;
  box-shadow:0 8px 24px -6px #000a;
}
.compare__knob svg{width:24px;height:24px;fill:none;stroke:var(--abyss);
  stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.compare__tag{
  position:absolute;bottom:18px;z-index:5;
  font-family:var(--font-d);font-weight:600;font-size:.82rem;
  padding:7px 13px;border-radius:100px;backdrop-filter:blur(4px);
}
.compare__tag--left{left:18px;background:#3f332299;color:#f0e4c8}
.compare__tag--right{right:18px;background:#04303a99;color:var(--aqua)}
.compare__range{
  position:absolute;inset:0;width:100%;height:100%;
  opacity:0;cursor:ew-resize;z-index:7;margin:0;
}
.compare__cap{
  margin-top:18px;text-align:center;font-size:.95rem;color:var(--ink-soft);
  font-family:var(--font-d);font-weight:500;
}

/* scene life */
.urchin{position:absolute;animation:urchinPulse 4s ease-in-out infinite}
@keyframes urchinPulse{50%{transform:scale(1.05)}}
.fish{position:absolute;animation:swim var(--sdur,16s) linear infinite}
@keyframes swim{
  from{transform:translateX(-60px)}
  to{transform:translateX(calc(100% + 60px))}
}
.crit-bubble{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#ffffffcc,#ffffff10);
  animation:critRise var(--bdur,7s) linear infinite;
}
@keyframes critRise{
  from{transform:translateY(0);opacity:0}
  10%{opacity:.7}
  90%{opacity:.5}
  to{transform:translateY(-340px);opacity:0}
}

.crisis__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.statcard{
  background:#fff;border-radius:var(--radius);padding:34px 30px;
  border:1px solid var(--line);
  box-shadow:0 24px 50px -38px #04303a55;
}
.statcard__num{
  font-family:var(--font-d);font-weight:800;
  font-size:clamp(2.6rem,5vw,3.8rem);line-height:1;
  color:var(--kelp-dark);
}
.statcard p{margin-top:12px;color:var(--ink-soft);font-size:.98rem}

/* ============================================================
   SOLUTION
   ============================================================ */
.solution{background:var(--cream)}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.step{
  position:relative;background:#fff;border-radius:var(--radius);
  padding:32px 26px 30px;border:1px solid var(--line);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.step:hover{transform:translateY(-7px);box-shadow:0 30px 56px -34px #04303a66}
.step__line{
  position:absolute;top:54px;right:-9px;width:18px;height:2px;
  background:repeating-linear-gradient(90deg,var(--kelp) 0 5px,transparent 5px 10px);
}
.step:last-child .step__line{display:none}
.step__num{
  font-family:var(--font-d);font-weight:800;font-size:.9rem;
  color:var(--kelp);letter-spacing:.05em;
}
.step__icon{
  display:grid;place-items:center;width:62px;height:62px;margin:14px 0 18px;
  border-radius:16px;background:linear-gradient(140deg,#eafce4,#d5f5dd);
}
.step__icon svg{width:32px;height:32px;fill:none;stroke:var(--kelp-dark);
  stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.step h3{font-size:1.5rem;color:var(--ink)}
.step p{margin-top:9px;font-size:.95rem;color:var(--ink-soft)}

/* ---------- BANNER ---------- */
.banner{
  position:relative;margin:clamp(40px,5vw,72px) 0 0;
  border-radius:var(--radius);overflow:hidden;
  aspect-ratio:16/6;min-height:280px;
  box-shadow:0 40px 80px -40px #04303a66;
}
@media (max-width:640px){.banner{aspect-ratio:4/4}}
.banner__img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.04);transition:transform 1.2s var(--ease);
}
.banner:hover .banner__img{transform:scale(1.08)}
.banner figcaption{
  position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;
  justify-content:flex-end;gap:8px;
  padding:clamp(22px,3vw,40px);
  background:linear-gradient(180deg,rgba(2,22,28,.05) 0%,rgba(2,22,28,.6) 70%,rgba(2,22,28,.9) 100%);
  color:#fff;
}
.banner__eyebrow{
  font-family:var(--font-d);font-weight:600;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--lime);
}
.banner__line{
  font-family:var(--font-d);font-weight:600;font-size:clamp(1.15rem,2vw,1.7rem);
  max-width:42ch;line-height:1.18;
}

/* ============================================================
   IMPACT DASHBOARD
   ============================================================ */
.impact{
  background:linear-gradient(180deg,#04262e,#073a3a 60%,#04262e);
  max-width:none;
}
.impact>*{max-width:var(--maxw);margin-inline:auto}
.impact__bg{
  position:absolute;inset:0;
  background:radial-gradient(50% 50% at 80% 12%,#34a96a33,transparent),
            radial-gradient(45% 45% at 12% 85%,#5fe8d022,transparent);
}
.dash{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative;
}
.dash__card{
  background:#0b3a3f;border:1px solid #ffffff14;border-radius:var(--radius);
  padding:32px 26px;text-align:center;
  transition:transform .4s var(--ease),border-color .4s;
}
.dash__card:hover{transform:translateY(-7px);border-color:#5fe8d055}
.dash__ring{
  width:88px;height:88px;border-radius:50%;margin:0 auto 20px;
  background:conic-gradient(from -90deg,var(--lime),var(--aqua) var(--p,0%),#ffffff12 var(--p,0%));
  display:grid;place-items:center;
}
.dash__ring::after{
  content:"";width:64px;height:64px;border-radius:50%;background:#0b3a3f;
}
.dash__num{
  font-family:var(--font-d);font-weight:800;
  font-size:clamp(2rem,3.6vw,2.9rem);line-height:1;color:#fff;
}
.dash__label{margin-top:8px;font-family:var(--font-d);font-weight:600;
  color:var(--lime);font-size:1rem}
.dash__note{margin-top:7px;font-size:.83rem;color:#8fb0aa}

/* ============================================================
   MAP
   ============================================================ */
.map{background:var(--paper)}
.map__layout{
  display:grid;grid-template-columns:1.25fr 1fr;gap:32px;align-items:stretch;
}
.map__stage{
  position:relative;background:linear-gradient(160deg,#06343c,#042227);
  border-radius:var(--radius);padding:24px;overflow:hidden;
}
.map__stage::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 70% 20%,#34a96a26,transparent);
}
.map__svg{width:100%;height:auto}
.map__land{stroke:#5fe8d04d;stroke-width:2}
.map__pins{position:absolute;inset:24px}
.pin{
  position:absolute;width:0;height:0;
}
.pin__dot{
  position:absolute;left:0;top:0;transform:translate(-50%,-50%);
  width:18px;height:18px;border-radius:50%;
  background:var(--lime);border:2.5px solid #04262e;
  box-shadow:0 0 0 0 #c4ff5e88;cursor:pointer;
  transition:transform .25s var(--ease);
  animation:pinPulse 2.6s ease-out infinite;
}
.pin__dot:hover,.pin.active .pin__dot{transform:translate(-50%,-50%) scale(1.35)}
.pin.active .pin__dot{background:var(--aqua)}
@keyframes pinPulse{
  0%{box-shadow:0 0 0 0 #c4ff5e77}
  70%{box-shadow:0 0 0 18px #c4ff5e00}
  100%{box-shadow:0 0 0 0 #c4ff5e00}
}
.pin__label{
  position:absolute;left:0;top:0;
  transform:translate(-50%,-150%);
  background:#04262e;color:#fff;font-family:var(--font-d);font-weight:600;
  font-size:.78rem;white-space:nowrap;padding:5px 11px;border-radius:8px;
  opacity:0;pointer-events:none;transition:opacity .2s,transform .2s var(--ease);
  border:1px solid #5fe8d040;
}
.pin:hover .pin__label{opacity:1;transform:translate(-50%,-180%)}

.map__panel{
  background:var(--ink);color:#dcebe7;border-radius:var(--radius);
  padding:34px 32px;display:flex;flex-direction:column;
}
.map__panel-tag{
  font-family:var(--font-d);font-weight:600;font-size:.76rem;
  letter-spacing:.13em;text-transform:uppercase;color:var(--lime);
}
.map__panel h3{color:#fff;font-size:1.7rem;margin-top:12px}
.map__panel p{margin-top:12px;font-size:.97rem;color:#a9c4be}
.map__meter{margin-top:22px}
.map__meter-row{
  display:flex;justify-content:space-between;font-family:var(--font-d);
  font-weight:600;font-size:.85rem;color:#cfe3dd;margin-bottom:7px;
}
.map__bar{height:8px;border-radius:100px;background:#ffffff1a;overflow:hidden}
.map__bar i{
  display:block;height:100%;border-radius:100px;
  background:linear-gradient(90deg,var(--kelp),var(--lime));
  transition:width 1s var(--ease);
}
.map__facts{margin-top:22px;display:grid;gap:11px}
.map__facts div{display:flex;justify-content:space-between;gap:16px;
  padding-bottom:11px;border-bottom:1px solid #ffffff14;font-size:.9rem}
.map__facts dt{color:#8fb0aa}
.map__facts dd{color:#fff;font-family:var(--font-d);font-weight:600;text-align:right}

/* ============================================================
   ADOPT
   ============================================================ */
.adopt{background:var(--cream)}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tier{
  position:relative;background:#fff;border-radius:var(--radius);
  padding:36px 30px;border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.tier--featured{
  background:linear-gradient(180deg,#063a3e,#04282d);color:#fff;
  border-color:#5fe8d040;box-shadow:0 40px 70px -40px #04303aaa;
}
.tier__flag{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--lime);color:var(--abyss);
  font-family:var(--font-d);font-weight:700;font-size:.74rem;
  letter-spacing:.06em;text-transform:uppercase;
  padding:6px 14px;border-radius:100px;
}
.tier__head{padding-bottom:22px;border-bottom:1px solid var(--line);margin-bottom:22px}
.tier--featured .tier__head{border-color:#ffffff1f}
.tier__name{font-family:var(--font-d);font-weight:600;font-size:1rem;
  letter-spacing:.04em;text-transform:uppercase;color:var(--kelp)}
.tier--featured .tier__name{color:var(--lime)}
.tier__price{
  display:block;font-family:var(--font-d);font-weight:800;
  font-size:clamp(2.6rem,4.6vw,3.4rem);line-height:1.1;margin-top:6px;color:var(--ink);
}
.tier--featured .tier__price{color:#fff}
.tier__price sup{font-size:.4em;font-weight:700;vertical-align:.9em;margin-right:2px}
.tier__unit{font-size:.85rem;color:var(--ink-soft)}
.tier--featured .tier__unit{color:#9fbcb6}
.tier__list{display:grid;gap:12px;margin-bottom:26px;flex:1}
.tier__list li{position:relative;padding-left:28px;font-size:.94rem;color:var(--ink-soft)}
.tier--featured .tier__list li{color:#bcd4cd}
.tier__list li::before{
  content:"";position:absolute;left:0;top:3px;width:17px;height:17px;
  border-radius:50%;background:var(--lime);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='4' stroke-linecap='round' stroke-linejoin='round' d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/13px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='4' stroke-linecap='round' stroke-linejoin='round' d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/13px no-repeat;
}
.tier .btn{justify-content:center}
.adopt__foot{
  margin-top:30px;text-align:center;font-size:.92rem;color:var(--ink-soft);
}

/* ============================================================
   PARTNERS
   ============================================================ */
.partners{
  background:linear-gradient(180deg,#04222b,#063138 55%,#04222b);
  max-width:none;overflow:hidden;
}
.partners>*{max-width:var(--maxw);margin-inline:auto}
.partners__bg{
  position:absolute;inset:0;
  background:
   radial-gradient(40% 40% at 85% 8%,#c4ff5e1f,transparent),
   radial-gradient(45% 45% at 8% 95%,#5fe8d01f,transparent);
}
.partners__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;
}
.partner{
  background:#0a363c;border:1px solid #ffffff16;border-radius:var(--radius);
  padding:34px 30px;position:relative;
  transition:transform .4s var(--ease),border-color .4s;
}
.partner:hover{transform:translateY(-8px);border-color:#5fe8d055}
.partner--lead{
  background:linear-gradient(170deg,#10524a,#0a363c);
  border-color:#c4ff5e55;
}
.partner__flag{
  position:absolute;top:-13px;left:30px;
  background:var(--lime);color:var(--abyss);
  font-family:var(--font-d);font-weight:700;font-size:.73rem;
  letter-spacing:.05em;text-transform:uppercase;
  padding:6px 13px;border-radius:100px;
}
.partner__icon{
  display:grid;place-items:center;width:60px;height:60px;border-radius:15px;
  background:#ffffff10;margin-bottom:18px;
}
.partner__icon svg{width:32px;height:32px;fill:none;stroke:var(--lime);
  stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.partner__level{
  font-family:var(--font-d);font-weight:600;font-size:.76rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--aqua);
}
.partner h3{color:#fff;font-size:1.6rem;margin-top:6px}
.partner p{margin-top:12px;font-size:.94rem;color:#a9c4be}
.partner__from{
  display:block;margin-top:18px;padding-top:16px;border-top:1px solid #ffffff16;
  font-family:var(--font-d);font-weight:600;font-size:.92rem;color:var(--lime);
}
.partners__why{
  position:relative;margin-top:28px;
  background:#ffffff0a;border:1px solid #ffffff14;border-radius:var(--radius);
  padding:clamp(30px,4vw,48px);
}
.partners__why h3{color:#fff;font-size:clamp(1.4rem,2.4vw,2rem)}
.partners__why-grid{
  margin-top:24px;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.partners__why-grid div{display:flex;flex-direction:column;gap:6px}
.partners__why-grid strong{
  font-family:var(--font-d);font-weight:600;color:var(--lime);font-size:1.02rem;
}
.partners__why-grid span{font-size:.88rem;color:#a9c4be}
.partners__cta{margin-top:30px}

/* ============================================================
   ENGINE
   ============================================================ */
.engine{background:var(--paper)}
.engine__layout{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center;
}
.loop{
  position:relative;width:min(420px,86vw);aspect-ratio:1;margin:0 auto;
}
.loop__ring{position:absolute;inset:0;width:100%;height:100%}
.loop__ring circle{
  fill:none;stroke:var(--kelp);stroke-width:2;stroke-dasharray:5 9;
  opacity:.55;animation:spin 30s linear infinite;transform-origin:center;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loop__core{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:40%;aspect-ratio:1;border-radius:50%;
  background:linear-gradient(150deg,var(--kelp-dark),#063a3e);color:#fff;
  display:grid;place-content:center;text-align:center;
  box-shadow:0 20px 44px -20px #1c7a4899;
}
.loop__core span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--aqua)}
.loop__core strong{font-family:var(--font-d);font-weight:800;font-size:1.5rem}
.loop__node{
  position:absolute;width:42%;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:13px 15px;box-shadow:0 16px 32px -22px #04303a66;
}
.loop__node span{
  font-family:var(--font-d);font-weight:800;color:var(--kelp);font-size:.82rem;
}
.loop__node p{font-size:.85rem;color:var(--ink);font-weight:500;margin-top:2px;line-height:1.35}
.loop__node--1{top:-4%;left:50%;transform:translateX(-50%)}
.loop__node--2{top:50%;right:-8%;transform:translateY(-50%)}
.loop__node--3{bottom:-4%;left:50%;transform:translateX(-50%)}
.loop__node--4{top:50%;left:-8%;transform:translateY(-50%)}
.engine__products{display:grid;gap:14px}
.product{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);
  padding:24px 26px;transition:transform .35s var(--ease)}
.product:hover{transform:translateX(7px)}
.product__tag{
  font-family:var(--font-d);font-weight:600;font-size:.74rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--kelp);
  background:#eafce4;padding:5px 11px;border-radius:100px;display:inline-block;
}
.product h3{font-size:1.3rem;color:var(--ink);margin-top:12px}
.product p{font-size:.93rem;color:var(--ink-soft);margin-top:6px}

/* ============================================================
   GLOBAL
   ============================================================ */
.global{
  position:relative;
  background:linear-gradient(180deg,#04262e,#052b2f);max-width:none;
  overflow:hidden;
}
.global__photo{
  position:absolute;inset:0;z-index:0;
  background:url('https://images.unsplash.com/photo-1703850688116-700267cc9349?w=2200&q=80&auto=format&fit=crop') center/cover no-repeat;
  filter:saturate(.85);
}
.global::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
   linear-gradient(100deg,rgba(4,38,46,.92) 0%,rgba(4,38,46,.72) 45%,rgba(4,38,46,.4) 85%),
   linear-gradient(180deg,rgba(4,38,46,.35) 0%,rgba(4,38,46,.85) 100%);
}
.global>*:not(.global__photo){max-width:var(--maxw);margin-inline:auto;position:relative;z-index:2}
.phases{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.phase{
  background:#0b3a3f;border:1px solid #ffffff14;border-radius:var(--radius);
  padding:32px 28px;position:relative;
}
.phase--active{
  background:linear-gradient(165deg,#10524a,#0a363c);
  border-color:#c4ff5e4d;
}
.phase__year{
  font-family:var(--font-d);font-weight:600;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--lime);
}
.phase h3{color:#fff;font-size:1.4rem;margin-top:10px}
.phase p{color:#a9c4be;font-size:.94rem;margin-top:10px}

/* ============================================================
   INVEST
   ============================================================ */
.invest{
  position:relative;background:linear-gradient(180deg,#063540,#021a22);
  max-width:none;overflow:hidden;
}
.invest__canvas{position:absolute;inset:0;width:100%;height:100%}
.invest__inner{
  position:relative;z-index:2;max-width:var(--maxw);margin-inline:auto;
  padding:clamp(80px,11vw,150px) clamp(20px,5vw,64px);
  display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:start;
}
.invest__copy h2{
  color:#fff;font-size:clamp(2.2rem,4.4vw,3.6rem);margin-top:18px;
}
.invest__lead{margin-top:20px;color:#bcd4cd;font-size:1.06rem;max-width:46ch}
.invest__points{margin-top:24px;display:grid;gap:11px}
.invest__points li{display:flex;gap:11px;color:#cfe3dd;font-size:.96rem}
.invest__points span{color:var(--lime)}
.invest__form{
  background:#ffffff0c;border:1px solid #ffffff1f;border-radius:var(--radius);
  padding:clamp(26px,3vw,38px);
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  backdrop-filter:blur(6px);
}
.field{display:flex;flex-direction:column;gap:7px}
.field--full{grid-column:1/-1}
.field label{
  font-family:var(--font-d);font-weight:600;font-size:.82rem;
  color:#9fbcb6;letter-spacing:.03em;
}
.field input,.field textarea,.field select{
  background:#04282d;border:1px solid #ffffff22;border-radius:11px;
  padding:13px 14px;color:#fff;font-size:.95rem;transition:border-color .25s;
  width:100%;
}
.field textarea{resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--lime);
}
.field input::placeholder,.field textarea::placeholder{color:#5d7a74}
.invest__form .btn{justify-content:center}
.invest__success{
  grid-column:1/-1;text-align:center;color:var(--lime);
  font-family:var(--font-d);font-weight:600;font-size:.95rem;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--abyss);color:#cfe3dd;
  padding:clamp(56px,7vw,88px) clamp(20px,5vw,64px) 30px}
.footer__top{
  max-width:var(--maxw);margin-inline:auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid #ffffff14;
}
.footer__brand{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.footer__brand strong{font-family:var(--font-d);font-weight:700;color:#fff;font-size:1.3rem}
.footer__brand p{color:#7f9c96;font-size:.94rem;max-width:30ch}
.footer__nav,.footer__contact{display:flex;flex-direction:column;gap:11px}
.footer__nav a{color:#9fbcb6;font-size:.94rem;transition:color .2s}
.footer__nav a:hover{color:var(--lime)}
.footer__contact span{
  font-family:var(--font-d);font-weight:600;color:#fff;font-size:.86rem;
  letter-spacing:.04em;text-transform:uppercase;
}
.footer__contact a{color:var(--aqua);font-size:.95rem}
.footer__contact a:hover{color:var(--lime)}
.footer__bar{
  max-width:var(--maxw);margin:24px auto 0;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:.82rem;color:#5d7a74;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .map__layout{grid-template-columns:1fr}
  .engine__layout{grid-template-columns:1fr;gap:60px}
  .invest__inner{grid-template-columns:1fr;gap:36px}
  .partners__why-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav__links{
    position:fixed;inset:0 0 auto;top:0;
    flex-direction:column;justify-content:center;
    background:#04222bf2;backdrop-filter:blur(16px);
    height:100svh;gap:8px;
    transform:translateY(-100%);transition:transform .45s var(--ease);
  }
  .nav.open .nav__links{transform:translateY(0)}
  .nav__links a{font-size:1.3rem;font-family:var(--font-d);font-weight:600;padding:12px 24px}
  .nav__cta{margin-left:0}
  .nav__burger{display:flex}
  .steps,.crisis__stats,.dash,.tiers,.partners__grid,.phases{
    grid-template-columns:1fr 1fr;
  }
  .hero__stats{grid-template-columns:1fr}
  .step__line{display:none}
}
@media (max-width:560px){
  .steps,.crisis__stats,.dash,.tiers,.partners__grid,.phases,
  .partners__why-grid,.invest__form{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr;gap:30px}
  .hero{padding-top:120px}
  .loop__node{width:54%}
  .loop__node--2{right:-14%}
  .loop__node--4{left:-14%}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  .hero__rays,.marquee__track,.loop__ring circle,.pin__dot,
  .hero__scroll-line::after,.urchin,.fish,.crit-bubble,
  .hero__eyebrow .dot,.kelp-frond{animation:none!important}
}
