/* ═══════════════════════════════════════════════════════════════════════════
   RHEM Works Inc. — Stylesheet v8
   Palette: Navy/Ruby/Orange · Gallery-trend-driven · Outfit + DM Serif
   ═══════════════════════════════════════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  /* Original brand palette */
  --navy:#1B2A4A;--navy-deep:#0F1B33;--navy-light:#243B5E;
  --ruby:#9B111E;--ruby-deep:#7A0D17;--ruby-light:#C41E2A;
  --orange:#E8722A;--orange-light:#F09A56;
  --gold:#C49A6C;
  --solar:#F59E0B;--solar-light:#FCD34D;--solar-bg:#FFFBEB;
  --green:#16a34a;--green-light:#86efac;
  /* Neutrals — slightly cooler/cleaner than before */
  --cream:#FAFAF8;--warm-bg:#F4F2EF;
  --white:#FFFFFF;--bg-3:#EBEBED;
  --text:#1A1A1F;--text-2:#52525B;--text-3:#8C8C9A;
  --border:rgba(27,42,74,0.09);--border-strong:rgba(27,42,74,0.18);
  /* Shadows — refined for depth */
  --shadow-xs:0 1px 2px rgba(0,0,0,0.04);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.06);
  --shadow-md:0 8px 24px rgba(0,0,0,0.08);
  --shadow-lg:0 20px 48px rgba(0,0,0,0.12);
  --shadow-ruby:0 4px 16px rgba(155,17,30,0.18);
  --shadow-solar:0 4px 14px rgba(245,158,11,0.16);
  --shadow-navy:0 6px 20px rgba(15,27,51,0.22);
  /* Geometry */
  --radius:10px;--radius-lg:16px;--radius-xl:24px;--radius-pill:100px;
  --max-w:1400px;--nav-h:60px;
  /* Spacing scale */
  --space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2.5rem;--space-2xl:4rem;
  /* Easing */
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
}
html{scroll-behavior:smooth}
body{
  font-family:'Outfit',-apple-system,BlinkMacSystemFont,'SF Pro Text','Helvetica Neue',Arial,sans-serif;
  font-size:16px;color:var(--text);background:var(--cream);line-height:1.65;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
/* Prevent body scroll when mobile nav is open */
body.nav-open{overflow:hidden;touch-action:none}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4{
  font-family:'DM Serif Display',-apple-system,BlinkMacSystemFont,'SF Pro Display','Helvetica Neue',serif;
  font-weight:400;letter-spacing:-0.02em;line-height:1.15;
}
h1{font-weight:400} /* DM Serif Display only has 400 */
h2,h3,h4{font-weight:400}
.serif{font-family:'DM Serif Display',serif;font-weight:400;letter-spacing:-0.02em}
/* Weight-based hierarchy with Outfit for UI elements */
.section-tag,.btn,.nav-links a,.svc-tool,.pill,.form-group label,.footer-col-title,.breadcrumb{
  font-family:'Outfit',-apple-system,sans-serif;
}
.section-tag{
  font-size:.68rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ruby);margin-bottom:.6rem;display:block;
}
.section-title{font-size:clamp(1.5rem,3.5vw,2.5rem);letter-spacing:-.035em;line-height:1.12;margin-bottom:.8rem;color:var(--text)}
.section-desc{font-size:1rem;color:var(--text-2);line-height:1.75}
.section-hdr{text-align:center;max-width:800px;margin:0 auto 3.5rem}
section{padding:5rem 2rem}
/* Smooth gradient dividers between sections */
section + section{position:relative}
section + section::after{content:'';position:absolute;top:-1px;left:0;right:0;height:60px;background:linear-gradient(to bottom,rgba(250,250,248,.6),transparent);pointer-events:none;z-index:1}
section.bg-warm + section{border-top:none}
section.bg-warm + section::after{background:linear-gradient(to bottom,rgba(244,242,239,.6),transparent)}

/* ── ANNOUNCEMENT BAR ── */
.announce-bar{
  background:linear-gradient(90deg,var(--ruby) 0%,var(--orange) 100%);
  text-align:center;padding:6px 2rem;
  font-family:'Outfit',sans-serif;font-size:.72rem;font-weight:600;color:#fff;
  letter-spacing:.02em;
  position:relative;z-index:1001;
}
.announce-bar a{color:#fff;text-decoration:underline;text-underline-offset:2px;font-weight:700}
.announce-bar-close{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:.9rem;padding:2px 6px;line-height:1}
.announce-bar-close:hover{color:#fff}

/* ── NAVBAR ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(15,27,51,0.82);
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border-bottom:1px solid rgba(255,255,255,0.05);
  transition:background .4s var(--ease-out),box-shadow .4s var(--ease-out),border-color .4s var(--ease-out);
  will-change:transform;transform:translateZ(0);-webkit-transform:translateZ(0);
}
.nav.scrolled{
  background:rgba(15,27,51,0.96);
  box-shadow:0 1px 24px rgba(0,0,0,.2);
  border-bottom-color:rgba(255,255,255,.03);
}
.nav-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2rem;height:var(--nav-h);
}
/* ── Sticky page title — subtitle bar beneath nav ── */
.nav-title-bar{
  position:fixed;top:var(--nav-h);left:0;right:0;z-index:999;
  background:rgba(15,27,51,0.96);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid rgba(255,255,255,.05);
  padding:8px 2rem;
  transform:translateY(-100%);opacity:0;
  transition:transform .18s var(--ease-out),opacity .15s var(--ease-out);
  pointer-events:none;
}
.nav-title-bar.show{
  transform:translateY(0);opacity:1;pointer-events:auto;
}
.nav-page-title{
  color:#fff;
  font-family:'DM Serif Display',-apple-system,BlinkMacSystemFont,'SF Pro Display','Helvetica Neue',serif;
  font-size:1.55rem;font-weight:400;
  letter-spacing:-.04em;line-height:1.15;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:var(--max-w);margin:0 auto;
  text-align:left;
}
@media(max-width:900px){
  .nav-page-title{font-size:1.3rem}
}
@media(max-width:600px){
  .nav-page-title{font-size:1.1rem}
}

.nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo{height:46px;width:auto;object-fit:contain;display:block;transition:all .3s var(--ease-out);filter:drop-shadow(0 0 6px rgba(245,158,11,.3)) drop-shadow(0 0 14px rgba(245,158,11,.1));animation:logoBoltGlow 3s ease-in-out infinite}
.nav-brand:hover .nav-logo{transform:scale(1.08);filter:drop-shadow(0 0 10px rgba(245,158,11,.5)) drop-shadow(0 0 24px rgba(245,158,11,.2))}
@keyframes logoBoltGlow{0%,100%{filter:drop-shadow(0 0 6px rgba(245,158,11,.3)) drop-shadow(0 0 14px rgba(245,158,11,.1))}50%{filter:drop-shadow(0 0 10px rgba(245,158,11,.45)) drop-shadow(0 0 20px rgba(245,158,11,.18))}}
.nav-brand-name{color:#fff;font-weight:700;font-size:1.22rem;letter-spacing:-.02em;display:block;line-height:1.2}
.nav-brand-sub{color:rgba(255,255,255,.38);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;display:block}
.nav-links{display:flex;gap:.15rem;align-items:center}
.nav-links>a,.nav-dropdown>a{
  color:rgba(255,255,255,.6);font-size:.8rem;font-weight:500;
  transition:color .2s,background .2s;padding:.4rem .8rem;border-radius:6px;
  letter-spacing:.005em;
}
.nav-links>a:hover,.nav-dropdown>a:hover,.nav-links>a.active,.nav-dropdown.open>a{color:#fff}

/* ── Dropdown base ── */
.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:4px}
.nav-dd-chevron{width:9px;height:9px;opacity:.35;transition:transform .25s cubic-bezier(.4,0,.2,1)}
.nav-dropdown.open .nav-dd-chevron{transform:rotate(180deg);opacity:.6}
.nav-dropdown-menu{
  visibility:hidden;opacity:0;
  position:absolute;top:calc(100% + 4px);left:0;
  padding-top:8px;min-width:220px;z-index:200;
  transform:translateY(-6px);
  transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1),visibility .25s;
}
.nav-dropdown.open .nav-dropdown-menu{visibility:visible;opacity:1;transform:translateY(0)}
.nav-dropdown-menu-inner{
  background:rgba(13,25,50,0.96);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;padding:.5rem 0;
  box-shadow:0 12px 40px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.04);
}
.nav-dropdown-menu a{
  display:block;padding:.5rem 1.15rem;
  color:rgba(255,255,255,.55);font-size:.8rem;font-weight:400;
  transition:color .15s,background .15s,padding-left .15s;white-space:nowrap;
}
.nav-dropdown-menu a:hover{color:#fff;background:rgba(255,255,255,.06);padding-left:1.3rem}
.ndm-featured{border-bottom:1px solid rgba(255,255,255,.06)!important;margin-bottom:.2rem;padding-bottom:.55rem!important;font-weight:600!important}
.ndm-solar{color:var(--solar)!important}
.ndm-safety{color:#fca5a5!important}
.ndm-env{color:#86efac!important}

/* ── Mega-menu: full-width services panel ── */
.mega-menu{
  visibility:hidden;opacity:0;
  position:absolute;top:100%;left:0;right:0;
  background:rgba(10,18,38,0.97);
  backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
  border-top:1px solid rgba(255,255,255,.04);
  box-shadow:0 20px 60px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.03);
  transform:translateY(-8px);
  transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1),visibility .3s;
  padding:1.75rem 0 2rem;
  max-height:calc(100vh - var(--nav-h));
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent;
}
.mega-menu::-webkit-scrollbar{width:5px}
.mega-menu::-webkit-scrollbar-track{background:transparent}
.mega-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.mega-menu::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.25)}
.mega-menu.open{visibility:visible;opacity:1;transform:translateY(0)}
.mega-inner{
  max-width:var(--max-w);margin:0 auto;padding:0 2rem;
  display:grid;grid-template-columns:1fr 1fr 1fr 220px;gap:2rem;
}
.mega-col-title{
  font-size:.6rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:.65rem;padding-bottom:.4rem;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mega-col-title--safety{color:#fca5a5}
.mega-col-title--renew{color:var(--solar)}
.mega-col-title--energy{color:#86efac}
.mega-col-title--elec{color:#93c5fd}
.mega-col-title--env{color:#22c55e}
.mega-sub-title{
  font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.38);margin-top:.6rem;margin-bottom:.12rem;padding-left:0;
  border-left:2px solid rgba(255,255,255,.15);padding-left:.45rem;
}
.mega-sub-title~.mega-link{padding-left:.55rem}
.mega-link{
  display:block;padding:.28rem 0;
  color:rgba(255,255,255,.5);font-size:.78rem;font-weight:400;
  transition:color .15s,padding-left .2s cubic-bezier(.4,0,.2,1);
  border-radius:4px;
}
.mega-link:hover{color:#fff;padding-left:.35rem}
.mega-link--featured{font-weight:600;color:rgba(255,255,255,.75);margin-bottom:.2rem}
.mega-link--all{font-weight:600;color:rgba(255,255,255,.65);font-size:.82rem}
/* ── Mega-menu collapsible H&S categories ── */
.mega-cat{margin-top:.35rem}
.mega-cat-btn{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:.32rem .45rem .32rem .45rem;border:none;background:rgba(255,255,255,.03);
  border-left:2px solid rgba(255,255,255,.15);border-radius:0 6px 6px 0;
  font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.42);cursor:pointer;
  transition:background .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1);
}
.mega-cat-btn:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.65)}
.mega-cat.open .mega-cat-btn{color:rgba(255,255,255,.7);background:rgba(255,255,255,.05);border-left-color:rgba(252,165,165,.5)}
.mega-cat-chev{width:8px;height:8px;opacity:.35;flex-shrink:0;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .25s}
.mega-cat.open .mega-cat-chev{transform:rotate(180deg);opacity:.6}
.mega-cat-links{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1)}
.mega-cat.open .mega-cat-links{max-height:300px}
.mega-cat-links .mega-link{padding-left:.55rem}
.mega-col--cta{display:flex;flex-direction:column;justify-content:flex-start}
.mega-promo{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
  border-radius:12px;padding:1.25rem;
}
.mega-promo-title{font-weight:700;font-size:.88rem;color:#fff;margin-bottom:.35rem}
.mega-promo-desc{font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.55}

/* ── Solar link — solid golden gradient matching hero btn-solar ── */
.nav-solar-link{
  border-radius:var(--radius-pill)!important;
  color:var(--navy-deep)!important;
  font-weight:700!important;
  padding:6px 16px!important;
  margin-left:.25rem;
  background:linear-gradient(135deg,#F59E0B 0%,#FBBF24 50%,#F59E0B 100%)!important;
  background-size:200% 200%!important;
  border:1px solid rgba(251,191,36,.6)!important;
  box-shadow:0 0 16px rgba(245,158,11,.4),0 0 40px rgba(245,158,11,.12);
  animation:navSolarGlow 2.5s ease-in-out infinite,navSolarShimmer 3s linear infinite;
  transition:all .3s var(--ease-out);
  position:relative;overflow:hidden;
  font-size:.8rem!important;
  letter-spacing:.02em;
}
.nav-solar-link::after{content:'';position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);animation:solar-shine 3.5s ease-in-out infinite}
@keyframes navSolarGlow{
  0%,100%{box-shadow:0 0 16px rgba(245,158,11,.4),0 0 40px rgba(245,158,11,.12)}
  50%{box-shadow:0 0 24px rgba(245,158,11,.55),0 0 60px rgba(245,158,11,.2)}
}
@keyframes navSolarShimmer{0%{background-position:200% center}100%{background-position:-200% center}}
.nav-solar-link:hover{background:linear-gradient(135deg,#FBBF24 0%,#FCD34D 50%,#FBBF24 100%)!important;border-color:rgba(251,191,36,.8)!important;transform:scale(1.06);box-shadow:0 0 30px rgba(245,158,11,.6),0 0 80px rgba(245,158,11,.2)!important;filter:brightness(1.1);animation:none!important}
/* Contact CTA */
.nav-cta{
  background:var(--ruby)!important;color:#fff!important;
  padding:6px 16px!important;border-radius:var(--radius-pill);
  font-size:.78rem!important;font-weight:600!important;
  transition:background .2s,transform .2s!important;margin-left:.25rem;
}
.nav-cta:hover{background:var(--ruby-deep)!important;transform:scale(1.02)}

/* ── Hamburger ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;border-radius:6px;transition:background .2s}
.hamburger:hover{background:rgba(255,255,255,.06)}
.hamburger span{display:block;width:20px;height:1.5px;background:rgba(255,255,255,.8);border-radius:2px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .2s}
body.nav-open .hamburger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.nav-open .hamburger span:nth-child(2){opacity:0;transform:scaleX(0)}
body.nav-open .hamburger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── Mobile nav ── */
.mobile-nav{
  display:none;background:rgba(8,15,32,.99);
  border-top:1px solid rgba(255,255,255,.05);
  max-height:calc(100dvh - var(--nav-h));
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  padding-bottom:2rem;
}
.mobile-nav.open{display:block;animation:mn-slide .3s cubic-bezier(.4,0,.2,1)}
@keyframes mn-slide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mobile-nav a{
  display:block;color:rgba(255,255,255,.7);
  padding:.7rem 1.5rem .7rem 2rem;font-size:.88rem;
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:background .15s,color .15s,padding-left .2s;
  letter-spacing:-.01em;
}
.mobile-nav a:active,.mobile-nav a:hover{background:rgba(255,255,255,.04);color:#fff;padding-left:2.2rem}
.mobile-nav-section{
  padding:.55rem 1.5rem .45rem;
  font-size:.58rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;
  margin-top:.3rem;border-left:4px solid transparent;
}
.mn-sec-svc{color:#93c5fd;border-left-color:#3b82f6;background:rgba(59,130,246,.07)}
.mn-sec-tool{color:#fcd34d;border-left-color:#f59e0b;background:rgba(245,158,11,.07)}
.mn-sec-co{color:#6ee7b7;border-left-color:#10b981;background:rgba(16,185,129,.07)}
.mn-tool{border-left:3px solid rgba(245,158,11,.25);padding-left:2rem}
.mn-co{border-left:3px solid rgba(16,185,129,.25);padding-left:2rem}
.mn-cta{font-weight:700;padding:.85rem 1.5rem;font-size:.92rem;border-left:4px solid transparent;letter-spacing:-.01em}
.mn-cta-solar{background:linear-gradient(90deg,rgba(245,158,11,.1),rgba(251,191,36,.15));color:#fcd34d;border-left-color:#f59e0b;box-shadow:inset 0 0 20px rgba(245,158,11,.05),0 0 12px rgba(245,158,11,.1);animation:navSolarGlow 2.5s ease-in-out infinite}
.mn-cta-safety{background:rgba(220,38,38,.08);color:#fca5a5;border-left-color:#ef4444}
.mn-cta-env{background:rgba(34,197,94,.08);color:#86efac;border-left-color:#22c55e}

/* ── Mobile accordion ── */
.mn-accordion{border-bottom:1px solid rgba(255,255,255,.04)}
.mn-acc-trigger{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:.7rem 1.5rem;font-size:.58rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#93c5fd;background:rgba(59,130,246,.07);border:none;border-left:4px solid #3b82f6;
  cursor:pointer;font-family:inherit;
  transition:background .15s;
}
.mn-acc-trigger:hover{background:rgba(59,130,246,.12)}
.mn-chevron{width:10px;height:10px;opacity:.4;transition:transform .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}
.mn-accordion.open .mn-chevron{transform:rotate(180deg);opacity:.7}
.mn-acc-body{
  max-height:0;overflow:hidden;
  transition:max-height .35s cubic-bezier(.4,0,.2,1);
}
.mn-accordion.open .mn-acc-body{max-height:2000px}
.mn-acc-body a{
  display:block;padding:.55rem 1.5rem .55rem 2.5rem;
  color:rgba(255,255,255,.6);font-size:.84rem;
  border-bottom:1px solid rgba(255,255,255,.03);
  transition:color .15s,background .15s,padding-left .2s;
}
.mn-acc-body a:hover,.mn-acc-body a:active{color:#fff;background:rgba(255,255,255,.04);padding-left:2.7rem}
.mn-cat-label{
  padding:.6rem 1.5rem .15rem 2rem;
  font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
  border-left:2px solid rgba(255,255,255,.12);margin-left:1.5rem;padding-left:.5rem;
}
.mn-cat-label:first-of-type{margin-top:.3rem}
.mn-cat-label~a{padding-left:3rem}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:12px 24px;border-radius:var(--radius-pill);
  font-family:'Outfit',inherit;font-size:.88rem;font-weight:600;
  cursor:pointer;transition:all .3s var(--ease-out);border:none;
  text-decoration:none;line-height:1.2;letter-spacing:-.005em;
  position:relative;overflow:hidden;
}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:opacity .3s var(--ease-out)}
.btn:hover::after{opacity:1}
.btn-sm{padding:8px 18px;font-size:.82rem}
.btn-lg{padding:16px 32px;font-size:.97rem}
.btn-primary{background:var(--ruby);color:#fff;box-shadow:var(--shadow-ruby);transition:all .3s var(--ease-out)}
.btn-primary:hover{background:var(--ruby-deep);transform:translateY(-1px);box-shadow:0 6px 20px rgba(155,17,30,.28)}
.btn-solar{background:linear-gradient(135deg,#F59E0B 0%,#FBBF24 50%,#F59E0B 100%);background-size:200% 200%;color:var(--navy-deep);font-weight:700;box-shadow:0 0 20px rgba(245,158,11,.35),0 0 60px rgba(245,158,11,.1);animation:solar-glow 2.5s ease-in-out infinite,solar-shimmer 3s linear infinite;transition:all .3s var(--ease-out);position:relative;overflow:hidden}
.btn-solar::after{content:'';position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:skewX(-20deg);animation:solar-shine 3.5s ease-in-out infinite}
.btn-solar:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 0 30px rgba(245,158,11,.5),0 0 80px rgba(245,158,11,.2);filter:brightness(1.1)}
@keyframes solar-glow{0%,100%{box-shadow:0 0 20px rgba(245,158,11,.35),0 0 60px rgba(245,158,11,.1)}50%{box-shadow:0 0 30px rgba(245,158,11,.5),0 0 80px rgba(245,158,11,.25)}}
@keyframes solar-shimmer{0%{background-position:200% center}100%{background-position:-200% center}}
@keyframes solar-shine{0%,100%{left:-60%;opacity:0}50%{left:120%;opacity:1}}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--border-strong);transition:all .3s var(--ease-out)}
.btn-outline:hover{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm)}
.btn-outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.2);transition:all .3s var(--ease-out)}
.btn-outline-white:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.08)}
.btn-consult{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);color:#fff;box-shadow:var(--shadow-navy);transition:all .3s var(--ease-out)}
.btn-consult:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(15,27,51,.35)}
.btn-full{width:100%;justify-content:center}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.btn:disabled::after{display:none}

/* ── PAGE STRUCTURE ── */
.page-wrap{padding-top:var(--nav-h)}
.container{max-width:var(--max-w);margin:0 auto;padding-left:1.5rem;padding-right:1.5rem}

/* ── HERO ── */
.hero{
  min-height:100vh;
  background:linear-gradient(140deg,var(--navy-deep) 0%,var(--navy) 45%,#2A1520 100%);
  display:flex;align-items:center;
  padding:calc(var(--nav-h) + 5rem) 2rem 5rem;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 55% 65% at 78% 38%,rgba(155,17,30,.14) 0%,transparent 60%),
    radial-gradient(ellipse 40% 50% at 18% 72%,rgba(232,114,42,.07) 0%,transparent 55%);
  transform:translateY(calc(var(--scroll,0) * 0.3px));will-change:transform;
}
/* Auto-grain on main hero */
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:180px 180px;
}
.hero-grid{
  position:absolute;inset:0;opacity:.03;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:55px 55px;
}
.hero-inner{position:relative;z-index:2;max-width:var(--max-w);margin:0 auto;width:100%}
.hero-content{max-width:880px;margin:0 auto;text-align:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(155,17,30,.18);border:1px solid rgba(155,17,30,.35);
  padding:5px 16px;border-radius:var(--radius-pill);
  color:var(--ruby-light);font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.75rem;
}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--orange);border-radius:50%;animation:pulse-d 2s ease infinite}
@keyframes pulse-d{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}
.hero h1{font-size:clamp(2rem,5vw,3.5rem);color:#fff;line-height:1.1;margin-bottom:1.2rem;letter-spacing:-.04em}
.hero h1 em{font-style:italic;background:linear-gradient(135deg,var(--ruby-light),var(--orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.55);max-width:640px;line-height:1.75;margin:0 auto 2.5rem;font-weight:400}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center;margin-bottom:3rem}
.hero-stats{display:flex;gap:2.75rem;flex-wrap:wrap;justify-content:center}
.hero-stat .num{font-size:1.9rem;color:var(--orange);line-height:1;font-weight:700;letter-spacing:-.04em}
.hero-stat .lbl{font-size:.7rem;color:rgba(255,255,255,.38);margin-top:4px;letter-spacing:.06em;text-transform:uppercase}

/* ── PAGE HERO ── */
.page-hero{
  background:linear-gradient(140deg,var(--navy-deep) 0%,var(--navy) 100%);
  padding:calc(var(--nav-h) + 4rem) 2rem 4rem;
  position:relative;overflow:hidden;
}
/* Auto-grain on all page heroes */
.page-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  opacity:.03;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:180px 180px;
}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(155,17,30,.1) 0%,transparent 60%);transform:translateY(calc(var(--scroll,0) * 0.3px));will-change:transform;transition:transform 0s}
.page-hero-inner{position:relative;z-index:2;max-width:var(--max-w);margin:0 auto}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);color:#fff;margin-bottom:1rem;max-width:800px;letter-spacing:-.04em}
.page-hero p{font-size:1rem;color:rgba(255,255,255,.55);max-width:580px;line-height:1.72}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.74rem;color:rgba(255,255,255,.32);margin-bottom:1.5rem;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.42);transition:color .15s}
.breadcrumb a:hover{color:rgba(255,255,255,.8)}
.breadcrumb-sep{color:rgba(255,255,255,.18)}
.page-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(232,114,42,.15);border:1px solid rgba(232,114,42,.3);
  padding:4px 12px;border-radius:var(--radius-pill);
  color:var(--orange-light);font-size:.68rem;font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;margin-bottom:1rem;
}

/* ── TRUST BAR ── */
.trust{background:var(--white);border-bottom:1px solid var(--border);padding:1.1rem 2rem}
.trust-inner{max-width:var(--max-w);margin:0 auto;display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;align-items:center}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:500;color:var(--text-2);opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease}
.trust-item.visible{opacity:1;transform:translateY(0)}
.trust-item:nth-child(1){transition-delay:0s}
.trust-item:nth-child(2){transition-delay:.1s}
.trust-item:nth-child(3){transition-delay:.2s}
.trust-item:nth-child(4){transition-delay:.3s}
.trust-item:nth-child(5){transition-delay:.4s}
.trust-item:nth-child(6){transition-delay:.5s}
.trust-item:nth-child(7){transition-delay:.6s}
.trust-item:nth-child(8){transition-delay:.7s}
.trust-icon{width:26px;height:26px;border-radius:7px;background:rgba(27,42,74,.07);display:flex;align-items:center;justify-content:center;font-size:.8rem}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-xs);transition:box-shadow .4s var(--ease-out),transform .4s var(--ease-out),border-color .4s var(--ease-out)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:rgba(155,17,30,.14)}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
@media(max-width:900px){
  .card-grid-4{grid-template-columns:repeat(2,1fr)}
  .card-grid-3{grid-template-columns:repeat(2,1fr)}
  .card-grid-2{grid-template-columns:1fr}
}
@media(max-width:600px){
  .card-grid-4,.card-grid-3,.card-grid-2{grid-template-columns:1fr}
}
/* Process steps responsive */
@media(max-width:900px){
  .process-steps{grid-template-columns:repeat(3,1fr)!important}
}
@media(max-width:600px){
  .process-steps{grid-template-columns:1fr 1fr!important}
}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:box-shadow .4s var(--ease-out),transform .4s var(--ease-out),border-color .4s var(--ease-out);position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ruby),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.svc-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.09);transform:translateY(-2px);border-color:rgba(232,114,42,.15)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card-icon{font-size:2rem;margin-bottom:.9rem;line-height:1}
.svc-card-title{font-size:1.05rem;font-weight:700;margin-bottom:.4rem;color:var(--navy);letter-spacing:-.02em}
.svc-card-desc{font-size:.87rem;color:var(--text-2);line-height:1.65;margin-bottom:1rem}
.svc-tools{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:1rem}
.svc-tool{background:rgba(27,42,74,.06);border:1px solid var(--border);padding:2px 8px;border-radius:5px;font-size:.66rem;font-weight:600;color:var(--navy);letter-spacing:.02em}
.svc-card-price{font-size:.77rem;color:var(--text-3);border-top:1px solid var(--border);padding-top:.7rem;margin-top:auto}
.svc-card-price strong{color:var(--navy)}

/* ── WORKFLOW + DELIVERABLES ── */
.workflow{display:flex;flex-direction:column;gap:0}
.workflow-step{display:flex;gap:1.25rem;padding:1.1rem 0;border-bottom:1px solid var(--border)}
.workflow-step:last-child{border-bottom:none}
.workflow-num{width:30px;height:30px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;flex-shrink:0;margin-top:2px}
.workflow-step-title{font-weight:700;color:var(--navy);margin-bottom:.2rem;font-size:.92rem;letter-spacing:-.01em}
.workflow-step-desc{font-size:.84rem;color:var(--text-2);line-height:1.6}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;margin-top:2rem}
.stat-card{background:var(--warm-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center}
.stat-num{font-size:2rem;font-weight:700;color:var(--navy);line-height:1;margin-bottom:.3rem;letter-spacing:-.04em}
.stat-label{font-size:.82rem;color:var(--text-2);line-height:1.45}
.deliverables{list-style:none;display:flex;flex-direction:column;gap:.45rem}
.deliverables li{display:flex;align-items:flex-start;gap:.6rem;font-size:.88rem;color:var(--text-2);line-height:1.55}
.deliverables li::before{content:'✓';color:var(--green);font-weight:700;margin-top:1px;flex-shrink:0}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}
.form-group label{font-size:.84rem;font-weight:600;color:var(--navy);letter-spacing:-.01em}
.form-group label .req{color:var(--ruby);margin-left:2px}
.form-control{padding:.72rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:.92rem;color:var(--text);background:var(--white);transition:border-color .2s,box-shadow .2s;outline:none;width:100%;-webkit-appearance:none}
.form-control:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,42,74,.1)}
.form-control.error{border-color:var(--ruby)}
.form-error{font-size:.74rem;color:var(--ruby);display:none;margin-top:.2rem}
.form-error.show{display:block}
.form-hint{font-size:.74rem;color:var(--text-3);margin-top:.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.toggle-group{display:flex;gap:.5rem;flex-wrap:wrap}
.toggle-opt input{display:none}
.toggle-opt span{display:flex;align-items:center;gap:.4rem;padding:.52rem 1rem;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.84rem;font-weight:500;color:var(--text-2);transition:all .2s;cursor:pointer}
.toggle-opt input:checked + span{border-color:var(--navy);background:var(--navy);color:#fff}
.toggle-opt span:hover{border-color:var(--navy);color:var(--navy)}

/* ── COLLAPSIBLE ── */
details.rhem-collapse{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.6rem;background:var(--white);transition:box-shadow .2s}
details.rhem-collapse[open]{box-shadow:var(--shadow-sm)}
details.rhem-collapse summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;cursor:pointer;font-weight:600;font-size:.92rem;color:var(--navy);list-style:none;user-select:none;transition:background .15s;letter-spacing:-.01em}
details.rhem-collapse summary::-webkit-details-marker{display:none}
details.rhem-collapse summary::after{content:'';width:18px;height:18px;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B2A4A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center;transition:transform .25s}
details.rhem-collapse[open] summary::after{transform:rotate(180deg)}
details.rhem-collapse summary:hover{background:var(--warm-bg)}
.collapse-body{padding:.25rem 1.25rem 1.1rem;color:var(--text-2);font-size:.9rem;line-height:1.7}
details.rhem-collapse-dark{border-color:rgba(255,255,255,.1);background:rgba(255,255,255,.04)}
details.rhem-collapse-dark summary{color:rgba(255,255,255,.85)}
details.rhem-collapse-dark summary::after{filter:invert(1) brightness(.6)}
details.rhem-collapse-dark .collapse-body{color:rgba(255,255,255,.55)}

/* ── REBATES (dark panels) ── */
.rebates-panel{background:rgba(0,0,0,.2);border:1px solid rgba(134,239,172,.15);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.25rem}
.rebates-hdr{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}
.rebates-hdr-icon{font-size:1.5rem;line-height:1}
.rebates-title{font-size:.95rem;font-weight:700;color:#86efac;margin-bottom:.15rem}
.rebates-sub{font-size:.78rem;color:rgba(255,255,255,.4)}
.rebate-item{background:rgba(255,255,255,.03);border-radius:8px;padding:.9rem;margin-bottom:.5rem;border-left:3px solid var(--text-3)}
.rebate-item.federal{border-left-color:#f59e0b}
.rebate-item.provincial{border-left-color:#86efac}
.rebate-item.utility{border-left-color:#60a5fa}
.rebate-badge{font-size:.63rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:4px;margin-bottom:.35rem;display:inline-block}
.rebate-badge.federal{background:rgba(245,158,11,.2);color:#f59e0b}
.rebate-badge.provincial{background:rgba(134,239,172,.15);color:#86efac}
.rebate-badge.utility{background:rgba(96,165,250,.15);color:#60a5fa}
.rebate-name{font-weight:700;font-size:.88rem;color:rgba(255,255,255,.85)}
.rebate-amount{font-size:.82rem;color:#86efac;font-weight:700;margin:.25rem 0}
.rebate-desc{font-size:.78rem;color:rgba(255,255,255,.55);line-height:1.5}
.rebate-excluded{opacity:.45}
.rebate-stackable{font-size:.63rem;font-weight:700;color:#86efac;background:rgba(134,239,172,.1);padding:1px 6px;border-radius:3px;margin-left:4px}
.rebate-noncash{font-size:.63rem;color:rgba(255,255,255,.3);background:rgba(255,255,255,.06);padding:1px 6px;border-radius:3px;margin-left:4px}
.net-cost-summary{background:rgba(134,239,172,.06);border:1px solid rgba(134,239,172,.2);border-radius:var(--radius);padding:1.25rem 1.5rem;margin:1rem 0}
.ncs-title{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.38);margin-bottom:.9rem}
.ncs-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;padding:.3rem 0}
.ncs-lbl{color:rgba(255,255,255,.55)}
.ncs-val{font-weight:700;color:rgba(255,255,255,.8)}
.ncs-green{color:#86efac}
.ncs-divider{height:1px;background:rgba(255,255,255,.1);margin:.4rem 0}
.ncs-total-val{font-size:1.5rem;font-weight:700;color:#86efac;letter-spacing:-.035em}
.ncs-pct{font-size:.78rem;color:rgba(134,239,172,.7);margin-top:.75rem;text-align:center;font-weight:600}
.noncash-strip{display:flex;gap:.75rem;align-items:flex-start;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:.75rem 1rem;margin:.75rem 0}
.noncash-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.3);margin-bottom:.2rem}
.noncash-list{font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.5}
.rebates-note{font-size:.7rem;color:rgba(255,255,255,.22);line-height:1.5;border-top:1px solid rgba(255,255,255,.06);padding-top:.75rem;margin-top:.75rem}

/* ── SOLAR RESULTS ── */
.sr-wrap{background:var(--navy-deep);border-radius:var(--radius-xl);padding:2.5rem;margin-top:2rem;color:#fff}
.sr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}
.sr-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:1.25rem;text-align:center}
.sr-card-label{font-size:.63rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:.5rem}
.sr-card-val{font-size:1.75rem;color:var(--solar);line-height:1;font-weight:700;letter-spacing:-.035em}
.sr-card-unit{font-size:.72rem;color:rgba(255,255,255,.3);margin-top:.3rem}
.payback-bar-wrap{margin-bottom:1.5rem}
.payback-label{font-size:.65rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:.5rem}
.payback-bar{height:6px;border-radius:3px;background:rgba(255,255,255,.08);overflow:hidden}
.payback-fill{height:100%;background:linear-gradient(90deg,#16a34a,#f59e0b);border-radius:3px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.payback-ticks{display:flex;justify-content:space-between;font-size:.63rem;color:rgba(255,255,255,.2);margin-top:.3rem}
.sr-disc-wrap{background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:1.5rem;margin-top:1.5rem}
.sr-disc-section{display:flex;flex-direction:column;gap:.8rem;font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.6}
.sr-disc-row{display:flex;gap:.75rem;align-items:flex-start}
.sr-disc-badge{font-size:.63rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 8px;border-radius:4px;white-space:nowrap;flex-shrink:0;margin-top:1px}
.sr-disc-badge--data{background:rgba(96,165,250,.2);color:#93c5fd}
.sr-disc-badge--params{background:rgba(245,158,11,.2);color:#fcd34d}
.sr-disc-badge--disclaimer{background:rgba(248,113,113,.2);color:#fca5a5}
.chart-wrap{background:rgba(0,0,0,.2);border-radius:var(--radius);padding:1.5rem;margin:1.5rem 0}
.chart-title{font-size:.7rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:1rem}

/* ── SCENARIO CARDS ── */
.scenario-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.6rem;background:var(--white)}
.scenario-hdr{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.1rem;cursor:pointer;transition:background .15s;user-select:none}
.scenario-hdr:hover{background:var(--warm-bg)}
.scenario-badge{display:inline-flex;align-items:center;gap:.4rem;padding:3px 10px;border-radius:var(--radius-pill);font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.scenario-badge.a{background:rgba(27,42,74,.1);color:var(--navy)}
.scenario-badge.b{background:rgba(22,163,74,.1);color:var(--green)}
.scenario-badge.c{background:rgba(245,158,11,.12);color:#92400e}
.scenario-badge.d{background:rgba(155,17,30,.1);color:var(--ruby)}
.scenario-title{font-weight:600;font-size:.9rem;color:var(--navy);letter-spacing:-.01em}
.scenario-subtitle{font-size:.75rem;color:var(--text-3)}
.scenario-body{display:none;padding:1.1rem;background:var(--warm-bg);border-top:1px solid var(--border)}
.scenario-card.open .scenario-body{display:block}
.scenario-math-row{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid var(--border);font-size:.84rem;color:var(--text-2)}
.scenario-math-row:last-child{border:none;font-weight:700;color:var(--navy);font-size:.92rem}
.scenario-green{color:var(--green);font-weight:700}
.scenario-illus{font-size:.72rem;color:var(--text-3);font-style:italic;margin-top:.5rem;line-height:1.5}

/* ── OPPORTUNITY CHECK ── */
.opp-section{margin-top:3rem;padding-top:3rem;border-top:1px solid rgba(255,255,255,.08)}
.opp-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:1.5rem 0}
.opp-tile{background:rgba(255,255,255,.04);border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:1.5rem 1rem;cursor:pointer;transition:all .25s;text-align:center}
.opp-tile:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.07);transform:translateY(-2px)}
.opp-tile.selected{border-color:var(--solar);background:rgba(245,158,11,.08)}
.opp-tile-icon{font-size:1.75rem;margin-bottom:.5rem;line-height:1}
.opp-tile-title{font-weight:700;font-size:.88rem;color:rgba(255,255,255,.9);letter-spacing:-.01em}
.opp-tile-sub{font-size:.72rem;color:rgba(255,255,255,.38);margin-top:.2rem}
.occ-module{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:1.75rem;margin-top:1rem}
.occ-module-hdr{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}
.occ-q{margin-bottom:1.1rem}
.occ-q-label{font-size:.88rem;font-weight:600;color:rgba(255,255,255,.78);margin-bottom:.5rem}
.occ-opts{display:flex;flex-wrap:wrap;gap:.4rem}
.occ-opt{padding:.45rem .9rem;border:1px solid rgba(255,255,255,.13);border-radius:var(--radius-pill);font-size:.82rem;cursor:pointer;transition:all .2s;color:rgba(255,255,255,.52);background:none;font-family:inherit}
.occ-opt:hover{border-color:rgba(255,255,255,.35);color:#fff}
.occ-opt.selected{border-color:var(--solar);background:rgba(245,158,11,.1);color:var(--solar)}
.occ-opt.unknown{font-style:italic}
.occ-result{background:rgba(0,0,0,.25);border-radius:var(--radius);padding:1.5rem;margin-top:1.25rem}
.occ-result-title{font-size:1.05rem;font-weight:700;margin-bottom:1rem;color:#fff;letter-spacing:-.02em}
.occ-insight{display:flex;gap:.6rem;margin-bottom:.5rem;font-size:.85rem;color:rgba(255,255,255,.68);line-height:1.55}
.occ-insight::before{content:'→';color:var(--orange);flex-shrink:0;margin-top:1px}
.occ-verify-hdr{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-light);margin:1rem 0 .4rem}

/* ── TOTAL OPPORTUNITY SUMMARY ── */
.tos-wrap{background:linear-gradient(140deg,var(--navy-deep) 0%,#2a1520 100%);border-radius:var(--radius-xl);padding:2.5rem;margin-top:2rem;color:#fff;border:1px solid rgba(245,158,11,.15)}
.tos-title{font-size:1.5rem;font-weight:700;margin-bottom:.4rem;color:#fff;letter-spacing:-.04em}
.tos-sub{font-size:.88rem;color:rgba(255,255,255,.42);margin-bottom:2rem}
.tos-ranges{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}
.tos-range{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:1.1rem}
.tos-range-tech{font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.33);margin-bottom:.3rem}
.tos-range-val{font-size:1.2rem;font-weight:700;color:var(--solar);letter-spacing:-.025em}
.tos-range-note{font-size:.72rem;color:rgba(255,255,255,.28);font-style:italic;margin-top:.2rem}
.tos-disclaimer{font-size:.72rem;color:rgba(255,255,255,.18);line-height:1.5;border-top:1px solid rgba(255,255,255,.06);padding-top:1rem;margin-top:1rem}

/* ── CONSULT CTA ── */
.consult-cta-block{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);border-radius:var(--radius-xl);padding:3rem 2rem;text-align:center;position:relative;overflow:hidden;margin-top:3rem}
.consult-cta-block::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 0%,rgba(155,17,30,.15) 0%,transparent 60%)}
.consult-cta-block-inner{position:relative;z-index:1}
.consult-cta-block h3{font-size:clamp(1.3rem,3vw,1.6rem);font-weight:700;color:#fff;margin-bottom:.6rem;letter-spacing:-.04em}
.consult-cta-block p{font-size:.95rem;color:rgba(255,255,255,.5);margin-bottom:1.5rem;max-width:460px;margin-left:auto;margin-right:auto}
.consult-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── LEAD PROFILE BANNER ── */
.lp-banner{background:rgba(27,42,74,.07);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.lp-banner-text{flex:1;min-width:0}
.lp-banner-title{font-size:.84rem;font-weight:600;color:var(--navy);margin-bottom:.15rem}
.lp-banner-fields{font-size:.78rem;color:var(--text-3);display:flex;flex-wrap:wrap;gap:.75rem}
.lp-banner-field-val{color:var(--navy);font-weight:600}
.lp-clear-btn{font-size:.74rem;color:var(--text-3);cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-pill);padding:3px 10px;background:none;font-family:inherit;transition:all .2s}
.lp-clear-btn:hover{color:var(--navy);border-color:var(--border-strong)}

/* ── FAB ── */
.consult-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;background:var(--ruby);color:#fff;border:none;border-radius:var(--radius-pill);padding:.8rem 1.4rem;font-family:inherit;font-weight:700;font-size:.84rem;cursor:pointer;box-shadow:var(--shadow-ruby);display:flex;align-items:center;gap:.5rem;transition:all .2s;text-decoration:none;animation:slide-up .4s ease}
.consult-fab:hover{background:var(--ruby-deep);transform:translateY(-2px)}
@keyframes slide-up{from{transform:translateY(80px);opacity:0}to{transform:none;opacity:1}}

/* ── TOAST ── */
.toast{position:fixed;top:calc(var(--nav-h) + 10px);right:1rem;z-index:2000;background:var(--navy-deep);color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:.9rem 1.1rem;max-width:340px;box-shadow:var(--shadow-navy);animation:notif-in .3s ease;font-size:.86rem;line-height:1.5;cursor:pointer}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid var(--ruby)}
@keyframes notif-in{from{transform:translateX(100px);opacity:0}to{transform:none;opacity:1}}

/* ── RESPONSIVE GRID UTILITIES ── */
/* Use these instead of inline grid-template-columns so mobile media queries can collapse them */
.grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.grid-2col-lg{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.grid-2col-xl{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.grid-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}
.grid-2fr-1fr{display:grid;grid-template-columns:2fr 1fr;gap:2.5rem;align-items:start}
.grid-5col-process{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;max-width:960px;margin:0 auto}
.grid-5col-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:.55rem}
@media(max-width:900px){
  .grid-2col,.grid-2col-lg,.grid-2col-xl,.grid-2fr-1fr{grid-template-columns:1fr}
  .grid-3col{grid-template-columns:1fr 1fr}
  .grid-5col-process{grid-template-columns:repeat(3,1fr)}
  .grid-5col-cards{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .grid-3col{grid-template-columns:1fr}
  .grid-5col-process{grid-template-columns:1fr 1fr}
  .grid-5col-cards{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .grid-5col-process{grid-template-columns:1fr}
}

/* ── UTILITIES ── */
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hidden{display:none!important}
.fade-in{opacity:0;transform:translateY(14px);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);will-change:opacity,transform}
.fade-in.visible{opacity:1;transform:translateY(0)}
/* Staggered children — cards in grids fade in sequentially */
.card-grid-2 > .fade-in-child,
.card-grid-3 > .fade-in-child,
.card-grid-4 > .fade-in-child,
.grid-2col > .fade-in-child,
.grid-3col > .fade-in-child{opacity:0;transform:translateY(12px);transition:opacity .35s var(--ease-out),transform .35s var(--ease-out);will-change:opacity,transform}
.card-grid-2 > .fade-in-child.visible,
.card-grid-3 > .fade-in-child.visible,
.card-grid-4 > .fade-in-child.visible,
.grid-2col > .fade-in-child.visible,
.grid-3col > .fade-in-child.visible{opacity:1;transform:translateY(0)}
.fade-in-child:nth-child(1){transition-delay:0s}
.fade-in-child:nth-child(2){transition-delay:.05s}
.fade-in-child:nth-child(3){transition-delay:.1s}
.fade-in-child:nth-child(4){transition-delay:.15s}
.fade-in-child:nth-child(5){transition-delay:.2s}
.fade-in-child:nth-child(6){transition-delay:.25s}
.fade-in-child:nth-child(7){transition-delay:.3s}
.fade-in-child:nth-child(8){transition-delay:.35s}
.fade-in-child:nth-child(9){transition-delay:.4s}
.fade-in-child:nth-child(10){transition-delay:.45s}
.fade-in-child:nth-child(11){transition-delay:.5s}
.fade-in-child:nth-child(12){transition-delay:.55s}
.pill{display:inline-flex;align-items:center;gap:.3rem;padding:3px 10px;border-radius:var(--radius-pill);font-size:.7rem;font-weight:700}
.pill-ruby{background:rgba(155,17,30,.1);color:var(--ruby)}
.pill-green{background:rgba(22,163,74,.1);color:var(--green)}
.pill-solar{background:rgba(245,158,11,.12);color:#92400e}
.sw-badge{background:rgba(27,42,74,.06);border:1px solid var(--border);padding:.2rem .7rem;border-radius:5px;font-size:.7rem;font-weight:600;color:var(--navy)}
.text-center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-6{margin-top:3rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mb-6{margin-bottom:3rem}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:1rem}.flex-wrap{flex-wrap:wrap}.flex-col{flex-direction:column}

/* ── FOOTER ── */
.footer{background:var(--navy-deep);color:rgba(255,255,255,.6);padding:1.5rem 2rem 1rem;border-top:1px solid rgba(155,17,30,.2)}
.footer-compact{text-align:center;line-height:2}
.footer-inner{max-width:var(--max-w);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}
.footer-brand-name{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.5rem;letter-spacing:-.025em}
.footer-brand-desc{font-size:.82rem;line-height:1.6;margin-bottom:1rem;max-width:260px;display:none}
.footer-col-title{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1rem}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.footer-links a{color:rgba(255,255,255,.62);font-size:.82rem;transition:color .15s}
.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.74rem}

/* ── RESPONSIVE ── */
/* Large screens — let content breathe with generous side padding */
@media(min-width:1600px){
  .container,.hero-inner,.page-hero-inner,.trust-inner,.sw-logos-inner,.cert-logos-inner,.footer-inner{
    padding-left:2rem;padding-right:2rem;
  }
}
@media(min-width:1440px){
  :root{--max-w:1500px}
}
@media(min-width:1800px){
  :root{--max-w:1600px}
}
@media(max-width:900px){
  .footer{padding:1.5rem 1.5rem 1rem}
  .footer-grid{grid-template-columns:1fr;gap:.75rem;margin-bottom:1rem}
  .footer-links{flex-direction:row;flex-wrap:wrap;gap:.2rem .75rem}
  .footer-links a{font-size:.75rem}
  .footer-bottom{padding-top:.75rem;font-size:.68rem}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .nav-links{display:none}
  .mega-menu{display:none!important}
  .hamburger{display:flex}
  .hero{padding:calc(var(--nav-h) + 3rem) 1.5rem 3rem}
  section{padding:3.5rem 1.5rem}
  #charts-container,#charts-grid{grid-template-columns:1fr!important}
}
@media(max-width:600px){
  .opp-tiles{grid-template-columns:1fr 1fr}
  .sr-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2rem}
  .consult-fab{bottom:1rem;right:1rem;padding:.7rem 1.1rem;font-size:.78rem}
}

/* ── SOFTWARE LOGOS TRUST BAR ── */
.sw-logos-bar{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.1rem 2rem;overflow:hidden}
.sw-logos-inner{display:flex;align-items:center;gap:2rem;justify-content:center;flex-wrap:wrap}
.sw-logo-group{display:flex;flex-direction:column;align-items:center;gap:.3rem;filter:grayscale(1);transition:filter .2s;cursor:default;white-space:nowrap}
.sw-logo-group:hover{filter:grayscale(0)}
.sw-logo-svg{width:auto;height:24px}
.sw-logo-label{font-size:.57rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-2);font-weight:600}
.sw-logos-divider{width:1px;height:26px;background:var(--border);flex-shrink:0}
.cert-logos-bar{background:var(--navy-deep);padding:1.25rem 2rem}
.cert-logos-inner{display:flex;align-items:center;gap:2rem;justify-content:center;flex-wrap:wrap}
.cert-logo-item{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.55);font-size:.74rem;font-weight:600;transition:color .2s}
.cert-logo-item:hover{color:rgba(255,255,255,.85)}
.cert-logo-icon{font-size:1.1rem}

/* ── ADDRESS AUTOCOMPLETE ── */
.addr-wrap{position:relative}
.addr-suggestions{position:absolute;top:100%;left:0;right:0;background:rgba(255,255,255,.98);backdrop-filter:blur(12px);border:1.5px solid var(--navy);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-md);z-index:200;max-height:260px;overflow-y:auto;display:none}
.addr-suggestions.open{display:block}
.addr-suggestion{padding:.65rem 1rem;font-size:.84rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s;display:flex;flex-direction:column;gap:.1rem}
.addr-suggestion:hover{background:var(--warm-bg)}
.addr-suggestion:last-child{border-bottom:none}
.addr-main{color:var(--navy);font-weight:600}
.addr-secondary{font-size:.74rem;color:var(--text-3)}
.addr-loading{display:none;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}
.addr-geo-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-3);font-size:.84rem;transition:color .2s;display:flex;align-items:center;gap:.2rem}
.addr-geo-btn:hover{color:var(--navy)}

/* ── REBATES PAGE ── */
.rebate-province-nav{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem}
.rpn-btn{padding:.38rem .85rem;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.78rem;cursor:pointer;background:var(--white);color:var(--text-2);transition:all .2s;font-weight:500}
.rpn-btn.active{background:var(--navy);border-color:var(--navy);color:#fff}
.rebate-full-card{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem;border:1px solid var(--border);transition:box-shadow .2s}
.rebate-full-card:hover{box-shadow:var(--shadow-md)}
.rfc-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:.75rem}
.rfc-badge{flex-shrink:0;padding:.22rem .6rem;border-radius:var(--radius-pill);font-size:.63rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.rfc-badge.federal{background:#EFF6FF;color:#1E40AF}
.rfc-badge.provincial{background:#F0FDF4;color:#15803D}
.rfc-badge.utility{background:#FFF7ED;color:#C2410C}
.rfc-name{font-weight:700;font-size:.95rem;color:var(--navy);letter-spacing:-.015em}
.rfc-amount{font-size:1.1rem;font-weight:700;color:var(--green);margin-bottom:.4rem;letter-spacing:-.025em}
.rfc-desc{font-size:.83rem;color:var(--text-2);line-height:1.65;margin-bottom:.75rem}
.rfc-why{background:var(--warm-bg);border-radius:8px;padding:.6rem .9rem;font-size:.78rem;color:var(--text-3)}
.rfc-why strong{color:var(--navy)}
.excluded-section{background:rgba(155,17,30,.04);border:1px solid rgba(155,17,30,.1);border-radius:var(--radius);padding:1.5rem}

/* ── ABOUT PAGE ── */
.team-card{background:var(--white);border-radius:var(--radius-xl);padding:2rem;display:flex;gap:1.5rem;align-items:flex-start;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.team-avatar{width:76px;height:76px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;font-size:1.9rem;flex-shrink:0}
.team-name{font-size:1.08rem;font-weight:700;color:var(--navy);letter-spacing:-.02em}
.team-title{font-size:.74rem;color:var(--ruby);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin:.2rem 0}
.team-bio{font-size:.83rem;color:var(--text-2);line-height:1.65}

/* ── CONTACT PAGE ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.contact-info-block{background:var(--navy-deep);border-radius:var(--radius-xl);padding:2.5rem;color:#fff}
.contact-method{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.25rem}
.contact-method-icon{font-size:1.25rem;flex-shrink:0;margin-top:.1rem}
.contact-method-text{display:flex;flex-direction:column;gap:.15rem}
.contact-method-label{font-size:.67rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.32);font-weight:700}
.contact-method-value{font-size:.9rem;color:#fff;font-weight:600;letter-spacing:-.01em}
.contact-method-sub{font-size:.75rem;color:rgba(255,255,255,.38)}

/* ── SERVICES DEEP-DIVE PAGE ── */
.svc-deep-nav{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.svc-deep-tab{padding:.45rem 1rem;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.78rem;font-weight:600;color:var(--text-2);cursor:pointer;background:var(--white);transition:all .2s}
.svc-deep-tab:hover{border-color:var(--navy);color:var(--navy)}
.svc-deep-tab.active{background:var(--navy);border-color:var(--navy);color:#fff}
.svc-deep-panel{display:none}
.svc-deep-panel.active{display:block}
.deliverable-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1.25rem}
.deliverable-card{background:var(--warm-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
.deliverable-card-icon{font-size:1.25rem;margin-bottom:.4rem}
.deliverable-card-title{font-size:.88rem;font-weight:700;color:var(--navy);margin-bottom:.25rem;letter-spacing:-.01em}
.deliverable-card-desc{font-size:.78rem;color:var(--text-2);line-height:1.55}
.svc-timeline{position:relative;padding-left:2rem;margin-top:1.5rem}
.svc-timeline::before{content:'';position:absolute;left:.5rem;top:0;bottom:0;width:1px;background:var(--border)}
.svc-timeline-step{position:relative;margin-bottom:1.5rem}
.svc-timeline-step::before{content:'';position:absolute;left:calc(-1.5rem + .5px);top:.3rem;width:10px;height:10px;border-radius:50%;background:var(--navy);border:2px solid var(--white);box-shadow:0 0 0 2px var(--navy)}
.svc-timeline-head{font-weight:700;font-size:.92rem;color:var(--navy);margin-bottom:.25rem;letter-spacing:-.01em}
.svc-timeline-body{font-size:.84rem;color:var(--text-2);line-height:1.6}

/* ── SPECIALTY PAGE (EOR / Gates / Drone) ── */
.specialty-hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(232,114,42,.15);border:1px solid rgba(232,114,42,.3);padding:4px 14px;border-radius:var(--radius-pill);color:var(--orange);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
.eor-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .25s}
.eor-card:hover{box-shadow:var(--shadow-md)}
.eor-card-header{padding:2rem;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);color:#fff}
.eor-card-title{font-size:1.25rem;font-weight:700;margin-bottom:.4rem;letter-spacing:-.03em}
.eor-card-sub{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.6}
.eor-card-body{padding:1.75rem}
.eor-use-cases{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}
.eor-use-case{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--text-2);line-height:1.55}
.eor-use-case::before{content:'→';color:var(--orange);flex-shrink:0;font-weight:700}
.compliance-strip{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}
.compliance-tag{background:rgba(27,42,74,.07);border:1px solid var(--border);padding:3px 9px;border-radius:5px;font-size:.7rem;font-weight:600;color:var(--navy)}
.drone-visual{background:linear-gradient(135deg,#0F1B33 0%,#1B2A4A 60%,#2A1520 100%);border-radius:var(--radius-xl);padding:2.5rem;color:#fff;position:relative;overflow:hidden}
.drone-visual::after{content:'✈';position:absolute;right:2rem;top:50%;transform:translateY(-50%);font-size:5rem;opacity:.07}

/* ── AI REBATES PAGE ── */
.rebate-live-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.rebate-live-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.2);padding:5px 14px;border-radius:var(--radius-pill);font-size:.72rem;font-weight:700;color:var(--green);letter-spacing:.05em}
.rebate-live-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse-d 2s ease infinite}
.rebate-last-updated{font-size:.78rem;color:var(--text-3)}
.rebate-ai-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.75rem;margin-bottom:1.25rem;transition:box-shadow .2s;overflow:hidden;word-break:break-word;max-width:100%}
.rebate-ai-card:hover{box-shadow:var(--shadow-md)}
.rebate-ai-card-header{margin-bottom:.75rem}
.rebate-ai-amount{font-size:1.15rem;font-weight:700;color:var(--green);letter-spacing:-.03em}
.rebate-ai-status{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:var(--radius-pill)}
.rebate-ai-status.active{background:rgba(22,163,74,.1);color:var(--green)}
.rebate-ai-status.expiring{background:rgba(245,158,11,.12);color:#92400e}
.rebate-ai-status.new{background:rgba(155,17,30,.1);color:var(--ruby)}
.rebate-ai-status.announced{background:rgba(99,102,241,.1);color:#4338ca}
.rebate-ai-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.75rem}
.rebate-ai-tag{background:var(--warm-bg);border:1px solid var(--border);padding:2px 8px;border-radius:4px;font-size:.68rem;font-weight:600;color:var(--text-2)}
.rebate-skeleton{background:var(--warm-bg);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem;animation:skeleton-pulse 1.5s ease-in-out infinite}
@keyframes skeleton-pulse{0%,100%{opacity:1}50%{opacity:.5}}
.rebate-skeleton-line{height:14px;border-radius:4px;background:var(--bg-3);margin-bottom:.6rem}
.rebate-skeleton-line.short{width:40%}
.rebate-skeleton-line.med{width:65%}

@media(max-width:900px){
  .hs-stat-grid{grid-template-columns:1fr 1fr}
  .compliance-matrix{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .sw-logos-divider{display:none}
  .rebate-ai-card{padding:1.25rem}
  .rebate-ai-amount{font-size:1rem}
  .rfc-name{font-size:.88rem}
  .rpn-btn{padding:.3rem .65rem;font-size:.72rem}
}
@media(max-width:600px){
  .hs-stat-grid{grid-template-columns:1fr 1fr}
  .tier-cards{grid-template-columns:1fr}
  .svc-deep-nav{gap:.3rem}
  .svc-deep-tab{font-size:.72rem;padding:.38rem .8rem}
  .rebate-ai-card{padding:1rem}
  .rfc-desc{font-size:.78rem}
}

/* ── COOKIE CONSENT BANNER ── */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:99998;background:var(--navy-deep);border-top:1px solid rgba(255,255,255,.1);padding:1rem 2rem}
.cookie-banner-inner{max-width:var(--max-w,1200px);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cookie-banner-text{display:flex;flex-direction:column;gap:.25rem;color:rgba(255,255,255,.7);font-size:.82rem}
.cookie-banner-text strong{color:#fff;font-size:.88rem}
.cookie-banner-actions{display:flex;gap:.5rem;flex-shrink:0}
@media(max-width:600px){.cookie-banner-inner{flex-direction:column;text-align:center}.cookie-banner-actions{width:100%;justify-content:center}}

/* ── GRAIN TEXTURE OVERLAY ── */
.grain::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:180px 180px;
}
.grain{position:relative}

/* ── DARK SECTION UTILITY ── */
.bg-dark{background:var(--navy-deep);color:#fff;position:relative}
.bg-dark .section-tag{color:var(--orange-light)}
.bg-dark .section-title{color:#fff}
.bg-dark .section-desc{color:rgba(255,255,255,.5)}

/* ── GRADIENT BORDER ACCENT CARDS ── */
.glow-card{
  position:relative;background:var(--white);border-radius:var(--radius-lg);padding:1.75rem;
  border:1px solid transparent;
  background-clip:padding-box;
  transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out);
}
.glow-card::before{
  content:'';position:absolute;inset:-1px;border-radius:calc(var(--radius-lg) + 1px);
  background:linear-gradient(135deg,rgba(155,17,30,.2),rgba(232,114,42,.15),rgba(245,158,11,.1));
  z-index:-1;opacity:0;transition:opacity .4s var(--ease-out);
}
.glow-card:hover::before{opacity:1}
.glow-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* Dark variant */
.glow-card-dark{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);
  padding:1.75rem;position:relative;
  transition:transform .4s var(--ease-out),border-color .4s var(--ease-out),background .4s var(--ease-out);
}
.glow-card-dark:hover{
  border-color:rgba(155,17,30,.3);background:rgba(255,255,255,.06);transform:translateY(-2px);
}

/* ── ENHANCED SECTION DIVIDERS ── */
.section-divider{
  height:1px;border:none;margin:0;
  background:linear-gradient(90deg,transparent,var(--border-strong),transparent);
}
.section-divider-glow{
  height:1px;border:none;margin:0;
  background:linear-gradient(90deg,transparent,rgba(155,17,30,.25),rgba(232,114,42,.2),transparent);
}

/* ── DARK CARD FOR HOMEPAGE ── */
.dark-feature-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);padding:1.75rem;
  transition:border-color .35s var(--ease-out),background .35s var(--ease-out),transform .35s var(--ease-out);
}
.dark-feature-card:hover{
  border-color:rgba(155,17,30,.25);background:rgba(255,255,255,.06);transform:translateY(-2px);
}
.dark-feature-card-icon{font-size:1.75rem;margin-bottom:1rem;line-height:1}
.dark-feature-card-title{
  font-family:'DM Serif Display',serif;font-size:1.1rem;color:#fff;
  margin-bottom:.5rem;font-weight:400;letter-spacing:-.02em;
}
.dark-feature-card-desc{font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.6}

/* ── MODERN FORM ENHANCEMENTS ── */
.form-control{
  transition:border-color .25s var(--ease-out),box-shadow .25s var(--ease-out),background .25s var(--ease-out);
}
.form-control:hover:not(:focus){border-color:var(--border-strong)}
.form-control:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(27,42,74,.08),0 2px 8px rgba(27,42,74,.06);
  background:var(--white);
}
.form-control::placeholder{color:var(--text-3);transition:color .2s}
.form-control:focus::placeholder{color:transparent}

/* ── ENHANCED FOOTER ── */
.footer{
  background:var(--navy-deep);color:rgba(255,255,255,.45);
  padding:4rem 2rem 2rem;
  border-top:none;
  position:relative;
}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(155,17,30,.35),rgba(232,114,42,.2),transparent);
}
.footer-brand-tagline{font-size:.82rem;color:rgba(255,255,255,.55);line-height:1.6;max-width:260px;margin-bottom:.75rem}
.footer-social{display:flex;gap:.6rem;margin-top:.5rem}
.footer-social a{
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.6);font-size:.82rem;
  transition:background .2s,color .2s,border-color .2s;
}
.footer-social a:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.15)}

/* ── SCROLL-REVEAL ANIMATIONS ── */
.reveal-up{
  opacity:0;transform:translateY(20px);
  transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);
  will-change:opacity,transform;
}
.reveal-up.visible{opacity:1;transform:translateY(0)}
.reveal-scale{
  opacity:0;transform:scale(.97);
  transition:opacity .35s var(--ease-out),transform .35s var(--ease-out);
  will-change:opacity,transform;
}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.reveal-left{
  opacity:0;transform:translateX(-16px);
  transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);
  will-change:opacity,transform;
}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{
  opacity:0;transform:translateX(16px);
  transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);
  will-change:opacity,transform;
}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* ── COUNTER ANIMATION ── */
.counter-animate{
  display:inline-block;
  transition:transform .3s var(--ease-spring);
}
.counter-animate.counting{transform:scale(1.05)}

/* ── PROCESS STEP MODERN ── */
.process-step{text-align:center}
.process-step-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:1.3rem;
  margin:0 auto 1rem;
  transition:background .3s var(--ease-out),transform .3s var(--ease-out);
}
.process-step:hover .process-step-num{background:var(--ruby);transform:scale(1.08)}
.process-step-num.ruby{background:var(--ruby)}
.process-step-title{font-weight:700;margin-bottom:.3rem;color:var(--navy)}
.process-step-desc{font-size:.82rem;color:var(--text-3)}

/* ── FEATURE ROW (EOR section) ── */
.feature-row{
  display:flex;gap:.75rem;padding:1rem;
  background:var(--warm-bg);border-radius:var(--radius);
  transition:background .25s var(--ease-out),transform .25s var(--ease-out);
}
.feature-row:hover{background:var(--bg-3);transform:translateX(4px)}
.feature-row-icon{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}
.feature-row-title{font-weight:700;margin-bottom:.25rem;color:var(--navy);font-size:.92rem}
.feature-row-desc{font-size:.82rem;color:var(--text-2)}

/* ── CHECKLIST MODERN ── */
.check-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.check-list li{display:flex;align-items:center;gap:.6rem;font-size:.9rem}
.check-list li::before{content:'';width:18px;height:18px;flex-shrink:0;border-radius:50%;background:rgba(22,163,74,.12);display:flex;align-items:center;justify-content:center;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316a34a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:11px;background-repeat:no-repeat;background-position:center}

/* ── SOLAR EXAMPLE PANEL ── */
.solar-example{
  background:#060d1a;border-radius:var(--radius-xl);padding:1.75rem;color:#fff;
  border:1px solid rgba(245,158,11,.15);
  transition:border-color .4s var(--ease-out);
}
.solar-example:hover{border-color:rgba(245,158,11,.3)}

/* ── NAV LINK HOVER UNDERLINE ── */
.nav-links>a::after,.nav-dropdown>a::after{
  content:'';position:absolute;bottom:0;left:50%;width:0;height:1.5px;
  background:rgba(255,255,255,.5);transition:width .25s var(--ease-out),left .25s var(--ease-out);
}
.nav-links>a:hover::after,.nav-dropdown>a:hover::after,.nav-links>a.active::after{
  width:60%;left:20%;
}
.nav-links>a,.nav-dropdown>a{position:relative}

/* ── HERO GLOW ORB ── */
.hero-orb{
  position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(155,17,30,.12) 0%,transparent 70%);
  filter:blur(80px);pointer-events:none;
  animation:orb-float 8s ease-in-out infinite alternate;
}
.hero-orb-2{
  position:absolute;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,114,42,.08) 0%,transparent 70%);
  filter:blur(60px);pointer-events:none;
  animation:orb-float 10s ease-in-out infinite alternate-reverse;
}
@keyframes orb-float{
  0%{transform:translate(0,0)}
  100%{transform:translate(30px,-20px)}
}

/* ── REDUCE MOTION ── */
@media(prefers-reduced-motion:reduce){
  .fade-in,.fade-in-child,.trust-item,.reveal-up,.reveal-scale,.reveal-left,.reveal-right{opacity:1!important;transform:none!important;transition:none!important}
  .card,.svc-card,.btn,.btn-solar,.btn-primary,.btn-consult,.btn-outline,.btn-outline-white,.glow-card,.glow-card-dark,.dark-feature-card,.feature-row,.process-step-num{transition:none!important;animation:none!important}
  .hero::before,.page-hero::before{transform:none!important}
  .hero-orb,.hero-orb-2{animation:none!important}
  @keyframes solar-pulse{0%,50%,100%{box-shadow:none}}
  @keyframes solar-glow{0%,50%,100%{box-shadow:none}}
  @keyframes solar-shimmer{0%,100%{background-position:0 center}}
  @keyframes solar-shine{0%,100%{left:-60%;opacity:0}}
  .btn-solar::after,.nav-solar-link::after{animation:none!important}
  @keyframes navSolarGlow{0%,50%,100%{box-shadow:none}}
  @keyframes navSolarShimmer{0%,100%{background-position:0 center}}
  @keyframes logoBoltGlow{0%,50%,100%{filter:none}}
  .nav-logo{animation:none!important;filter:none!important}
}

/* ── Chart Glow (Apple dark theme) ── */
.js-plotly-plot .main-svg{filter:drop-shadow(0 0 8px rgba(10,132,255,0.10))}
[id*="chart-"] canvas,[id*="Chart"] canvas,#srCumCanvas{filter:drop-shadow(0 0 6px rgba(10,132,255,0.08))}

/* ── Charts: mobile responsive ── */
@media(max-width:768px){
  #charts-grid,#charts-container{gap:1.5rem !important}
  #charts-grid>div,#charts-container>div{padding:1rem 0.75rem 1rem !important;border-radius:14px !important}
  .js-plotly-plot{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .js-plotly-plot .main-svg{min-width:320px}
}
