/* ============================================================
   UNIGREEN POWER — Landing ("steroid" build)
   Light base · cinematic dark hero + dark sections
   Built on Unigreen tokens (colors_and_type.css loaded first)
   ============================================================ */

:root{
  --ink:        #0a0920;          /* deepest navy — hero/cta canvas      */
  --ink-2:      #100e2e;          /* raised dark surface                 */
  --ink-line:   rgba(255,255,255,0.09);
  --maxw:       1200px;
  --pad:        clamp(20px, 5vw, 56px);
  --sec-y:      clamp(72px, 11vh, 144px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--fg);
  line-height:var(--lh-normal);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--mint); color:var(--ink); }

/* thin custom scrollbar */
body::-webkit-scrollbar{ width:11px; }
body::-webkit-scrollbar-track{ background:var(--ink); }
body::-webkit-scrollbar-thumb{ background:var(--navy-600); border-radius:999px; border:3px solid var(--ink); }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:var(--sec-y); position:relative; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.55em;
  font-size:var(--t-eyebrow); font-weight:var(--w-bold);
  letter-spacing:.2em; text-transform:uppercase; color:var(--mint-600);
}
.eyebrow::before{ content:""; width:16px; height:2px; background:var(--mint); border-radius:2px; }
.dark .eyebrow{ color:var(--mint); }
.dark .eyebrow::before{ background:var(--mint); box-shadow:0 0 18px rgba(98,237,170,.6); }

.section-head{ max-width:760px; margin-bottom:clamp(40px,6vh,72px); }
.cmp-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; }   /* wide table scrolls in its box on tablet instead of being clipped */
.section-head h2{
  font-size:clamp(2rem, 1.2rem + 3.4vw, 3.6rem);
  font-weight:var(--w-black); line-height:1.28; letter-spacing:-.02em;
  margin:.5em 0 0; text-wrap:balance;
}
.section-head p{ font-size:clamp(1rem,.95rem + .4vw,1.22rem); color:var(--fg-2); margin:.9em 0 0; max-width:60ch; }
.dark{ background:var(--ink); color:var(--fg-on-navy); }
.dark h2{ color:#fff; }
.dark .section-head p{ color:#b8bad8; }

.btn{
  --bg:var(--mint); --fg:var(--ink);
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:inherit; font-weight:var(--w-bold); font-size:1.02rem;
  padding:.92em 1.55em; border-radius:var(--r-pill); border:0; cursor:pointer;
  background:var(--bg); color:var(--fg);
  transition:transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out), background var(--dur);
  white-space:nowrap;
}
.btn svg{ width:1.15em; height:1.15em; }
.btn-primary{ box-shadow:0 8px 30px rgba(98,237,170,.35); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 14px 44px rgba(98,237,170,.5); background:var(--mint-600); }
.btn-ghost{ background:transparent; color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.28); }
.btn-ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--mint); color:var(--mint); transform:translateY(-3px); }
.btn-dark{ background:var(--navy); color:#fff; box-shadow:var(--sh-2); }
.btn-dark:hover{ transform:translateY(-3px); background:var(--navy-700); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:18px var(--pad);
  transition:background var(--dur), backdrop-filter var(--dur), box-shadow var(--dur), padding var(--dur);
}
.nav.scrolled{
  background:rgba(255,255,255,.82); backdrop-filter:blur(16px) saturate(1.2);
  box-shadow:0 1px 0 var(--border), var(--sh-1); padding-block:12px;
}
.brand{ display:flex; align-items:center; z-index:2; }
.brand img{ height:30px; width:auto; display:block; }
.brand .logo-light{ display:none; }
.nav.scrolled .brand .logo-dark{ display:none; }
.nav.scrolled .brand .logo-light{ display:block; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a.link{ font-size:.96rem; font-weight:var(--w-semibold); color:rgba(255,255,255,.82); position:relative; padding:4px 0; }
.nav-links a.link::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--mint); transition:width var(--dur) var(--ease-out); }
.nav-links a.link:hover{ color:#fff; } .nav-links a.link:hover::after{ width:100%; }
.nav.scrolled .nav-links a.link{ color:var(--fg-2); } .nav.scrolled .nav-links a.link:hover{ color:var(--navy); }
.nav-cta{
  display:inline-flex; align-items:center; gap:.5em; font-weight:var(--w-bold); font-size:.95rem;
  padding:.62em 1.15em; border-radius:var(--r-pill); background:var(--mint); color:var(--ink);
  box-shadow:0 6px 22px rgba(98,237,170,.34); transition:transform var(--dur) var(--ease-out), background var(--dur);
}
.nav-cta:hover{ transform:translateY(-2px); background:var(--mint-600); }
.nav-cta svg{ width:1.05em; height:1.05em; }
.nav-burger{ display:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  background:var(--ink); color:#fff; overflow:hidden; isolation:isolate;
}
#heroCanvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero-veil{ position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(120% 80% at 50% -10%, transparent 40%, rgba(10,9,32,.55) 100%),
    linear-gradient(180deg, rgba(10,9,32,.35) 0%, transparent 24%, transparent 64%, var(--ink) 100%);
}
/* realistic project photo as hero background (sub-pages) */
.hero-photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero.has-photo #heroCanvas, .hero.has-photo .hero-grid, .hero.has-photo .hero-leaf{ display:none; }
.hero.has-photo .hero-veil{
  background:
    linear-gradient(95deg, rgba(10,9,32,.9) 0%, rgba(10,9,32,.66) 36%, rgba(10,9,32,.3) 66%, rgba(10,9,32,.42) 100%),
    linear-gradient(180deg, rgba(10,9,32,.45) 0%, transparent 28%, transparent 52%, var(--ink) 100%);
}
.hero-grid{ position:absolute; inset:0; z-index:1; opacity:.5;
  background-image:linear-gradient(var(--ink-line) 1px, transparent 1px), linear-gradient(90deg, var(--ink-line) 1px, transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(120% 90% at 50% 30%, #000 30%, transparent 78%);
}
.hero-leaf{ position:absolute; z-index:1; opacity:.5; filter:saturate(1.1); pointer-events:none; will-change:transform; }
.hero-leaf.l1{ width:120px; top:18%; left:7%; }
.hero-leaf.l2{ width:74px; top:58%; left:14%; opacity:.4; }
.hero-leaf.l3{ width:150px; top:24%; right:9%; opacity:.45; }
.hero-leaf.l4{ width:58px; bottom:22%; right:18%; opacity:.55; }

.hero-inner{ position:relative; z-index:3; width:100%; }
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:.6em; padding:.5em 1em;
  border-radius:var(--r-pill); background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  font-size:.8rem; font-weight:var(--w-bold); letter-spacing:.14em; text-transform:uppercase; color:#dfe2f3;
}
.hero-eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--mint); box-shadow:0 0 0 0 rgba(98,237,170,.6); animation:pulse 2.4s var(--ease-out) infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(98,237,170,.55);} 70%{ box-shadow:0 0 0 12px rgba(98,237,170,0);} 100%{ box-shadow:0 0 0 0 rgba(98,237,170,0);} }
.hero h1{
  font-size:clamp(2.9rem, 1.6rem + 6.6vw, 6.6rem);
  font-weight:var(--w-black); line-height:1.16; letter-spacing:-.025em; color:#fff;
  margin:.42em 0 0; max-width:16ch; text-wrap:balance; padding-bottom:.08em;
}
.hero h1 .accent{ position:relative; color:var(--mint);
  background:linear-gradient(100deg, var(--cyan), var(--mint) 55%, var(--purple));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-sub{ font-size:clamp(1.05rem,.98rem + .6vw,1.4rem); color:#c3c5e2; margin:1.3em 0 0; max-width:52ch; line-height:1.62; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2.2em; }
.scroll-cue{ position:absolute; left:var(--pad); bottom:30px; z-index:3; display:flex; align-items:center; gap:12px; color:rgba(255,255,255,.6); }
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(var(--mint), transparent); position:relative; overflow:hidden; }
.scroll-cue .bar::after{ content:""; position:absolute; inset:0; background:var(--mint); animation:cue 1.9s var(--ease-in-out, ease) infinite; }
@keyframes cue{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(100%);} }
.scroll-cue span{ font-size:.7rem; letter-spacing:.34em; text-transform:uppercase; writing-mode:vertical-rl; }

/* ============================================================
   STATS BAND (odometers)  — dark
   ============================================================ */
.stats{ position:relative; z-index:3; background:var(--ink); border-top:1px solid var(--ink-line); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:clamp(28px,4vw,52px) clamp(20px,3vw,40px); border-left:1px solid var(--ink-line); position:relative; }
.stat:first-child{ border-left:0; }
.stat .num{ display:flex; align-items:baseline; font-weight:var(--w-black); line-height:1;
  font-size:clamp(2.6rem,1.5rem + 3.4vw,4.4rem); letter-spacing:-.03em; color:#fff; }
.stat .num .suffix{ font-size:.42em; font-weight:var(--w-extra); margin-left:.32em; color:var(--mint); letter-spacing:0; }
.stat .lbl{ margin-top:.6em; font-size:.92rem; color:#9a9cc0; line-height:1.4; }
.stat .lbl b{ color:#e6e7f6; font-weight:var(--w-bold); }

/* odometer reels */
.odo{ display:inline-flex; }
.odo .reel{ display:inline-block; height:1em; overflow:hidden; vertical-align:bottom; }
.odo .reel .col{ display:flex; flex-direction:column; transition:transform 1.5s var(--ease-out); }
.odo .reel .col span{ height:1em; display:flex; align-items:center; }
.odo .sep{ display:inline-block; margin:0 .12em; transform:scaleX(.6); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ background:var(--mint); color:var(--ink); overflow:hidden; border-block:0; }
.marquee .track{ display:flex; gap:64px; width:max-content; animation:scroll-x 26s linear infinite; }
.marquee:hover .track{ animation-play-state:paused; }
.marquee .item{ display:inline-flex; align-items:center; padding:14px 0; font-weight:var(--w-black); font-size:1.05rem; letter-spacing:.02em; text-transform:uppercase; white-space:nowrap; }
@keyframes scroll-x{ to{ transform:translateX(-50%);} }

/* ============================================================
   ECOSYSTEM — dark, 3 connected islands
   ============================================================ */
.eco{ position:relative; overflow:hidden; }
.eco-bg{ position:absolute; inset:0; z-index:0; opacity:.7;
  background:radial-gradient(60% 50% at 18% 12%, rgba(8,201,252,.16), transparent 60%),
             radial-gradient(55% 50% at 82% 24%, rgba(172,101,255,.14), transparent 60%),
             radial-gradient(60% 60% at 50% 108%, rgba(98,237,170,.16), transparent 60%); }
.eco .wrap{ position:relative; z-index:1; }
.eco-flow{ position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2.4vw,30px); margin-top:8px; }
.eco-line{ position:absolute; top:64px; left:12%; right:12%; height:2px; z-index:0;
  background:linear-gradient(90deg, var(--cyan), var(--mint), var(--purple)); opacity:.28; }
.eco-line::before{ content:""; position:absolute; top:-2px; left:0; width:46px; height:6px; border-radius:6px;
  background:#fff; filter:blur(2px); box-shadow:0 0 18px var(--mint); animation:flow 4.5s linear infinite; }
@keyframes flow{ 0%{ left:0; opacity:0;} 12%{ opacity:1;} 88%{ opacity:1;} 100%{ left:100%; opacity:0;} }
.island{ position:relative; z-index:1; background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--ink-line); border-radius:var(--r-xl); padding:clamp(24px,3vw,38px);
  backdrop-filter:blur(4px); transition:transform var(--dur) var(--ease-out), border-color var(--dur), box-shadow var(--dur); }
.island:hover{ transform:translateY(-6px); border-color:rgba(98,237,170,.45); box-shadow:0 24px 60px rgba(0,0,0,.4); }
.island .ic{ width:60px; height:60px; border-radius:16px; display:grid; place-items:center; margin-bottom:22px;
  background:rgba(98,237,170,.12); color:var(--mint); border:1px solid rgba(98,237,170,.25); }
.island.c2 .ic{ background:rgba(8,201,252,.12); color:var(--cyan); border-color:rgba(8,201,252,.25); }
.island.c3 .ic{ background:rgba(172,101,255,.12); color:var(--purple); border-color:rgba(172,101,255,.25); }
.island .ic svg{ width:30px; height:30px; }
.island .role{ font-size:.74rem; font-weight:var(--w-bold); letter-spacing:.2em; text-transform:uppercase; color:#8587ad; }
.island h3{ font-size:1.7rem; font-weight:var(--w-black); margin:.3em 0 .35em; color:#fff; letter-spacing:-.01em; }
.island p{ font-size:.98rem; color:#aeb0d2; margin:0; line-height:1.6; }
.island .step{ position:absolute; top:clamp(24px,3vw,38px); right:clamp(24px,3vw,38px); font-size:.78rem; font-weight:var(--w-black); color:rgba(255,255,255,.16); }

/* ============================================================
   SOLUTIONS — light, numbered editorial cards
   ============================================================ */
.sol{ background:var(--bg); }
.sol-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,26px); }
.sol-card{ position:relative; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:clamp(26px,2.6vw,38px); display:flex; flex-direction:column; overflow:hidden;
  box-shadow:var(--sh-1); transition:transform var(--dur) var(--ease-out), box-shadow var(--dur), border-color var(--dur); }
.sol-card::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:var(--grad-leaf); transform:scaleX(0); transform-origin:left; transition:transform var(--dur-slow) var(--ease-out); }
.sol-card:hover{ transform:translateY(-8px); box-shadow:var(--sh-3); border-color:var(--border-strong); }
.sol-card:hover::before{ transform:scaleX(1); }
.sol-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.sol-num{ font-size:2.6rem; font-weight:var(--w-black); line-height:1; letter-spacing:-.04em;
  -webkit-text-stroke:1.5px var(--border-strong); color:transparent; }
.sol-card:hover .sol-num{ -webkit-text-stroke:1.5px var(--mint-600); }
.sol-chip{ display:inline-flex; align-items:center; gap:.4em; font-size:.78rem; font-weight:var(--w-bold);
  color:var(--mint-600); background:var(--mint-050); border:1px solid var(--mint-200); padding:.4em .8em; border-radius:var(--r-pill); }
.sol-chip svg{ width:.95em; height:.95em; }
.sol-card h3{ font-size:1.6rem; font-weight:var(--w-black); letter-spacing:-.01em; margin:0 0 .5em; color:var(--navy); }
.sol-card .desc{ font-size:.98rem; color:var(--fg-2); margin:0 0 20px; line-height:1.62; }
.sol-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:26px; }
.sol-tags span{ font-size:.78rem; font-weight:var(--w-semibold); color:var(--fg-2); background:var(--surface-2); border:1px solid var(--border); padding:.36em .7em; border-radius:var(--r-sm); }
.sol-stat{ margin-top:auto; padding-top:22px; border-top:1px solid var(--border); display:flex; align-items:center; gap:.7em; }
.sol-stat .big{ font-size:clamp(2.4rem,1.6rem + 2vw,3.2rem); font-weight:var(--w-black); line-height:.9; letter-spacing:-.03em; color:var(--navy); white-space:nowrap; }
.sol-stat .big .suffix{ font-size:.4em; color:var(--mint-600); margin-left:.22em; }
.sol-stat .cap{ font-size:.84rem; color:var(--fg-3); line-height:1.35; max-width:18ch; }

/* ============================================================
   PRODUCTS / PACKAGES — light subtle, external links
   ============================================================ */
.prods{ background:var(--bg-subtle); }
.pk-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,26px); }
.pk{ position:relative; display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:clamp(26px,2.6vw,36px); overflow:hidden; min-height:340px;
  box-shadow:var(--sh-1); transition:transform var(--dur) var(--ease-out), box-shadow var(--dur), border-color var(--dur); }
.pk-glow{ position:absolute; width:220px; height:220px; right:-70px; top:-70px; border-radius:50%; filter:blur(34px); opacity:.5;
  background:radial-gradient(circle, var(--mint) 0%, transparent 70%); transition:opacity var(--dur), transform var(--dur-slow) var(--ease-out); }
.pk.p2 .pk-glow{ background:radial-gradient(circle, var(--cyan) 0%, transparent 70%); }
.pk.p3 .pk-glow{ background:radial-gradient(circle, var(--purple) 0%, transparent 70%); }
.pk:hover{ transform:translateY(-8px); box-shadow:var(--sh-3); border-color:var(--border-strong); }
.pk:hover .pk-glow{ opacity:.85; transform:scale(1.18); }
.pk .kicker{ position:relative; font-size:.74rem; font-weight:var(--w-bold); letter-spacing:.14em; text-transform:uppercase; color:var(--mint-600); }
.pk.p2 .kicker{ color:var(--cyan-600); } .pk.p3 .kicker{ color:var(--purple-600); }
.pk h3{ position:relative; font-size:1.8rem; font-weight:var(--w-black); letter-spacing:-.015em; margin:.4em 0 .45em; color:var(--navy); }
.pk .pdesc{ position:relative; font-size:.96rem; color:var(--fg-2); margin:0 0 22px; line-height:1.6; }
.pk-specs{ position:relative; display:flex; flex-wrap:wrap; gap:8px; margin-bottom:26px; }
.pk-specs span{ font-size:.8rem; font-weight:var(--w-semibold); color:var(--navy); background:var(--surface-2); border:1px solid var(--border); padding:.4em .75em; border-radius:var(--r-pill); }
.pk-go{ position:relative; margin-top:auto; display:inline-flex; align-items:center; justify-content:space-between; gap:.5em;
  font-weight:var(--w-bold); font-size:1rem; color:var(--navy); padding-top:20px; border-top:1px solid var(--border); }
.pk-go .arrow{ width:40px; height:40px; border-radius:50%; display:grid; place-items:center; background:var(--navy); color:#fff;
  transition:transform var(--dur) var(--ease-out), background var(--dur); }
.pk-go .arrow svg{ width:18px; height:18px; }
.pk:hover .pk-go .arrow{ background:var(--mint); color:var(--ink); transform:translate(3px,-3px) rotate(0deg); }

/* ============================================================
   CTA — dark, contact tiles
   ============================================================ */
.cta{ position:relative; overflow:hidden; text-align:center; }
.cta-bg{ position:absolute; inset:0; z-index:0; opacity:.9;
  background:radial-gradient(70% 60% at 50% 0%, rgba(98,237,170,.18), transparent 60%),
             radial-gradient(50% 50% at 15% 90%, rgba(8,201,252,.16), transparent 60%),
             radial-gradient(50% 50% at 85% 90%, rgba(172,101,255,.16), transparent 60%); }
.cta .wrap{ position:relative; z-index:1; }
.cta h2{ font-size:clamp(2.3rem,1.4rem + 3.6vw,4.4rem); font-weight:var(--w-black); letter-spacing:-.025em; line-height:1.32; color:#fff; margin:0; padding-top:.08em; }
.cta p{ font-size:clamp(1.02rem,.96rem + .5vw,1.28rem); color:#c3c5e2; max-width:54ch; margin:1.1em auto 0; }
.cta-actions{ display:flex; justify-content:center; flex-wrap:wrap; gap:14px; margin-top:2.2em; }
.contact-tiles{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:clamp(40px,6vh,64px); text-align:left; }
.tile{ display:flex; align-items:center; gap:14px; padding:18px 18px; border-radius:var(--r-lg); min-width:0;
  background:rgba(255,255,255,.04); border:1px solid var(--ink-line); transition:transform var(--dur) var(--ease-out), border-color var(--dur), background var(--dur); }
.tile>span:last-child{ min-width:0; flex:1 1 auto; }
.tile:hover{ transform:translateY(-4px); border-color:rgba(98,237,170,.4); background:rgba(255,255,255,.06); }
.tile .ti{ width:46px; height:46px; flex:none; border-radius:13px; display:grid; place-items:center; background:rgba(98,237,170,.12); color:var(--mint); border:1px solid rgba(98,237,170,.22); }
.tile.t2 .ti{ background:rgba(6,199,85,.14); color:#06C755; border-color:rgba(6,199,85,.30); }
.tile.t3 .ti{ background:rgba(59,141,240,.14); color:#3b8df0; border-color:rgba(59,141,240,.30); }
.tile.t4 .ti{ background:rgba(255,0,0,.12); color:#FF0000; border-color:rgba(255,0,0,.28); }
.tile .ti svg{ width:24px; height:24px; }
.tile .tk{ display:block; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:#8587ad; font-weight:var(--w-bold); white-space:nowrap; }
.tile .tv{ display:block; font-size:clamp(.9rem,.78rem + .45vw,1.05rem); font-weight:var(--w-extra); color:#fff; margin-top:2px; line-height:1.2; white-space:nowrap; }
@media (max-width:1100px){ .contact-tiles{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink-2); color:#c3c5e2; padding-block:clamp(48px,7vh,80px) 36px; border-top:1px solid var(--ink-line); }
.footer .wrap{ display:grid; grid-template-columns:1.4fr 1fr; gap:40px; align-items:start; }
.footer .f-brand img{ width:148px; margin-bottom:18px; }
.footer .f-brand p{ font-size:.96rem; color:#9a9cc0; max-width:42ch; line-height:1.6; margin:0; }
.footer .f-meta{ display:flex; flex-direction:column; gap:8px; font-size:.96rem; }
.footer .f-meta .h{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:#8587ad; font-weight:var(--w-bold); margin-bottom:6px; }
.footer .f-meta a{ color:#e6e7f6; font-weight:var(--w-semibold); }
.footer .f-meta a:hover{ color:var(--mint); }
.footer .copy{ grid-column:1/-1; margin-top:28px; padding-top:22px; border-top:1px solid var(--ink-line);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.84rem; color:#7b7d9f; }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-d="1"]{ transition-delay:.08s; }
[data-reveal][data-d="2"]{ transition-delay:.16s; }
[data-reveal][data-d="3"]{ transition-delay:.24s; }
[data-reveal][data-d="4"]{ transition-delay:.32s; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  [data-reveal]{ opacity:1; transform:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(3){ border-left:0; }
  .stat:nth-child(odd){ border-left:0; }
  .stat{ border-top:1px solid var(--ink-line); }
  .stat:nth-child(-n+2){ border-top:0; }
  .eco-flow{ grid-template-columns:1fr; }
  .eco-line{ display:none; }
  .sol-grid, .pk-grid, .contact-tiles{ grid-template-columns:1fr; }
  .footer .wrap{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .hero-leaf.l1,.hero-leaf.l2{ display:none; }
}

/* ===== mobile hamburger menu (shared across all packages pages) ===== */
.nav-burger{ display:none; background:none; border:0; cursor:pointer; padding:6px; color:#fff; line-height:0; }
.nav.scrolled .nav-burger{ color:var(--navy); }
.nav-burger svg{ width:28px; height:28px; }
.m-cta-link{ display:none !important; }
@media (max-width:820px){
  .nav{ flex-wrap:wrap; gap:10px; }
  .nav-burger{ display:inline-flex !important; align-items:center; margin-left:auto; }
  .nav-cta{ display:none !important; }
  .nav-links{ display:none !important; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0; background:#fff;
    border-top:1px solid var(--border); box-shadow:0 12px 26px rgba(28,27,69,.14); padding:6px 0; }
  .nav.open .nav-links{ display:flex !important; }
  .nav-links a.link{ padding:15px 22px; font-size:1.02rem; color:var(--navy) !important; border-bottom:1px solid var(--border); }
  .nav-links a.link:last-child{ border-bottom:0; }
  .nav-links a.link::after{ display:none !important; }
  .m-cta-link{ display:flex !important; align-items:center; gap:.5em; justify-content:center;
    margin:10px 18px 8px; background:var(--mint); color:var(--ink) !important; font-weight:800;
    border-radius:var(--r-pill); border-bottom:0 !important; }
}

/* ===== mobile layout fixes (shared across all packages pages) ===== */
@media (max-width:820px){
  /* keep hero content below the fixed nav — was overlapping the eyebrow/logo */
  .hero{ align-items:flex-start; padding-top:100px; padding-bottom:54px; }
  /* wide comparison / price-structure tables don't fit phones — hide on mobile */
  .section.cmp{ display:none !important; }
  /* decorative vertical "Scroll" cue overlaps hero facts on phones — hide it */
  .scroll-cue{ display:none !important; }
}
