/* =========================================================
   NMS — Net Metering Systems | Design System v4
   Implements Claude Design package (Homepage V1 — Conservative)
   Author: Revelation Agency
   ========================================================= */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{min-height:100vh;line-height:1.55;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video,svg{max-width:100%;height:auto;display:block}
button,input,textarea,select{font:inherit;color:inherit}
button{background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ---------- TOKENS (verbatim from design package) ---------- */
:root{
  --nms-navy:        #1c2936;
  --nms-navy-2:      #243446;
  --nms-navy-deep:   #131c25;
  --nms-yellow:      #ffcc00;
  --nms-yellow-soft: #ffe071;
  --nms-yellow-warm: #fff3b0;
  --nms-teal:        #1cb5bd;
  --nms-cream:       #fafaf7;
  --nms-cream-2:     #f3f1ea;
  --nms-line:        rgba(28,41,54,.10);
  --nms-line-2:      rgba(28,41,54,.18);
  --nms-text:        #1c2936;
  --nms-text-2:      #4a5768;
  --nms-text-3:      #7b8797;
  --nms-text-on-navy:     #f3f1ea;
  --nms-text-on-navy-dim: rgba(243,241,234,.65);
  --nms-shadow-sm: 0 1px 2px rgba(28,41,54,.06), 0 4px 12px -4px rgba(28,41,54,.08);
  --nms-shadow-md: 0 6px 16px -6px rgba(28,41,54,.12), 0 20px 40px -20px rgba(28,41,54,.18);
  --nms-shadow-lg: 0 24px 60px -24px rgba(28,41,54,.28);
  --nms-radius:    14px;
  --nms-radius-lg: 22px;
  --nms-radius-xl: 32px;

  /* legacy aliases for already-built pages */
  --nms-gold: var(--nms-yellow);
  --nms-gold-2: #f5b800;
  --nms-orange: #ff6900;
  --nms-orange-2: #e65a00;
  --nms-bg: var(--nms-cream);
  --nms-bg-2: var(--nms-cream-2);
  --nms-bg-3: #eef2f6;
  --nms-danger: #d64545;
  --nms-success: #1f9d55;
  --on-dark: #fff;
  /* Round 8 fix: --grad-gold was referenced site-wide but never defined,
     causing yellow gradient backgrounds (step-1 circle, thank-you check
     circle) to fall through to nothing → invisible white-on-white. */
  --grad-gold: linear-gradient(135deg, #ffcc00 0%, #ffb000 100%);
  --on-dark-2: var(--nms-text-on-navy);
  --on-dark-3: var(--nms-text-on-navy-dim);

  /* fluid type */
  --fs-xs:   clamp(.75rem,.72rem + .15vw,.85rem);
  --fs-sm:   clamp(.85rem,.82rem + .2vw,.95rem);
  --fs-base: clamp(.95rem,.9rem + .25vw,1.05rem);
  --fs-lg:   clamp(1.05rem,1rem + .35vw,1.2rem);
  --fs-xl:   clamp(1.2rem,1.1rem + .5vw,1.4rem);
  --fs-2xl:  clamp(1.5rem,1.3rem + .8vw,1.9rem);
  --fs-3xl:  clamp(2rem,1.6rem + 1.6vw,2.8rem);
  --fs-4xl:  clamp(2.4rem,1.8rem + 2.4vw,3.6rem);
  --fs-hero: clamp(2.6rem,2rem + 4.4vw,4.4rem);

  --r-sm: 8px; --r: var(--nms-radius); --r-lg: var(--nms-radius-lg); --r-xl: var(--nms-radius-xl); --r-pill: 999px;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --t-fast: .18s var(--ease);
  --t: .32s var(--ease);
  --t-slow: .6s var(--ease-out);

  --container: 1280px;
  --container-narrow: 920px;
  --nav-h: 76px;

  /* ---------- SPACING SCALE (Round 4) ---------- */
  /* Base scale used for gaps, margins, internal card padding. */
  --space-xs:  8px;
  --space-sm:  16px;
  --space-md:  24px;
  --space-lg:  40px;
  --space-xl:  64px;
  --space-2xl: 96px;
  --space-3xl: 128px;
  /* Section vertical-rhythm tokens. --section-y is the homepage default
     (=96px, what V1 sections already use). --section-y-tight (64px) for
     compact rows like partners. --section-y-loose (128px) for hero-like
     feature sections. */
  --section-y:        96px;
  --section-y-tight:  64px;
  --section-y-loose:  128px;
}

/* Mobile: scale section/spacing tokens to ~70% so the rhythm doesn't
   feel airy on small screens. */
@media (max-width: 640px){
  :root{
    --space-lg:  28px;
    --space-xl:  48px;
    --space-2xl: 72px;
    --space-3xl: 96px;
    --section-y:        72px;
    --section-y-tight:  48px;
    --section-y-loose:  96px;
  }
}

/* ---------- BASE ---------- */
body{
  font-family: "Poppins","Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  font-size: var(--fs-base);
  font-feature-settings: "ss01","cv11";
  color: var(--nms-text);
  background: var(--nms-cream);
  overflow-x: hidden;
}
::selection{background: var(--nms-yellow); color: var(--nms-navy);}

/* ---------- CONTAINER ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(1rem,3vw,2.5rem);position:relative;z-index:1}
.container-narrow{max-width:var(--container-narrow)}

/* ---------- TYPOGRAPHY ---------- */
/* Round 5 spacing audit: every heading gets a default margin-bottom so
   paragraphs / lists below breathe. Eyebrow→h2→subtext stacks across
   the site were rendering near-flush. Each h-tag gets a token-scaled
   gap so the rhythm is consistent + override-able locally. */
h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--nms-navy);margin:0 0 var(--space-md)}
h1{font-size:var(--fs-hero);font-weight:800;letter-spacing:-.025em;line-height:1.05;margin-bottom:var(--space-md)}
h2{font-size:var(--fs-4xl);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin-bottom:var(--space-md)}
h3{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.015em;line-height:1.18;margin-bottom:var(--space-sm)}
h4{font-size:var(--fs-xl);font-weight:600;line-height:1.22;margin-bottom:var(--space-sm)}
h5{font-size:var(--fs-lg);font-weight:600;letter-spacing:.02em;text-transform:uppercase;margin-bottom:var(--space-sm)}
h6{font-size:var(--fs-sm);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--nms-text-2);margin-bottom:var(--space-xs)}
p{color:var(--nms-text-2);font-size:var(--fs-base);line-height:1.65;margin:0 0 var(--space-md)}
p:last-child{margin-bottom:0}
.lede{font-size:var(--fs-lg);line-height:1.55;color:var(--nms-text)}

/* eyebrow / kicker */
.nms-eyebrow,.kicker{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--nms-text-2);
}
.nms-eyebrow::before,.kicker::before{content:"";width:28px;height:1.5px;background:var(--nms-yellow);border-radius:2px}
.nms-eyebrow.on-dark,.kicker.on-dark{color:var(--nms-yellow)}
.nms-eyebrow.on-dark::before,.kicker.on-dark::before{background:var(--nms-yellow)}

.gradient-text,.highlight,.gold-text{color:var(--nms-yellow)}
.on-dark{color:var(--nms-text-on-navy)}
.on-dark p{color:var(--nms-text-on-navy-dim)}
.on-dark h1,.on-dark h2,.on-dark h3,.on-dark h4{color:#fff}

/* ---------- LAYOUT PRIMITIVES ---------- */
/* Round 4 Edit 1: bare <section> gets the homepage section rhythm by
   default. V1-class sections (.v1-hero, .v1-compare-wrap, etc.) set
   their own padding so they win specificity and stay unchanged. */
section{padding:var(--section-y) clamp(1rem,3vw,2.5rem);position:relative;z-index:1}
.section-tight{padding-top:var(--section-y-tight);padding-bottom:var(--section-y-tight)}
.section-loose{padding-top:var(--section-y-loose);padding-bottom:var(--section-y-loose)}
.section-alt{background:var(--nms-cream)}
.section-navy{background:var(--nms-navy);color:var(--nms-text-on-navy)}
.section-navy h1,.section-navy h2,.section-navy h3,.section-navy h4{color:#fff}
.section-navy p{color:var(--nms-text-on-navy-dim)}
.grid{display:grid;gap:clamp(1rem,2.5vw,2rem)}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.stack > * + *{margin-top:1rem}

/* ---------- BUTTONS (V1 system) ---------- */
.nms-btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.9rem 1.4rem;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.005em;
  border:none;cursor:pointer;text-decoration:none;
  transition:transform .2s, box-shadow .2s, background .2s, color .2s, border-color .2s;
  white-space:nowrap;
}
.nms-btn-primary{
  background:var(--nms-yellow);color:var(--nms-navy);
  box-shadow:0 6px 16px -6px rgba(255,204,0,.5), inset 0 -2px 0 rgba(28,41,54,.08);
}
.nms-btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 24px -8px rgba(255,204,0,.55), inset 0 -2px 0 rgba(28,41,54,.08)}
.nms-btn-navy{background:var(--nms-navy);color:var(--nms-cream)}
.nms-btn-navy:hover{background:var(--nms-navy-2);transform:translateY(-1px)}
.nms-btn-ghost{background:transparent;color:var(--nms-navy);border:1.5px solid var(--nms-line-2)}
.nms-btn-ghost:hover{border-color:var(--nms-navy)}
.nms-btn-light{background:rgba(255,255,255,.12);color:var(--nms-cream);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.nms-btn-light:hover{background:rgba(255,255,255,.2)}

/* legacy .btn → primary alias */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;padding:.9rem 1.4rem;border-radius:999px;
  font-weight:600;font-size:.92rem;border:none;cursor:pointer;text-decoration:none;
  transition:transform .2s, box-shadow .2s, background .2s;white-space:nowrap;
  background:var(--nms-yellow);color:var(--nms-navy);
  box-shadow:0 6px 16px -6px rgba(255,204,0,.5), inset 0 -2px 0 rgba(28,41,54,.08);
}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px -8px rgba(255,204,0,.55)}
.btn-gold{background:var(--nms-yellow);color:var(--nms-navy)}
.btn-navy{background:var(--nms-navy);color:#fff;box-shadow:none}
.btn-navy:hover{background:var(--nms-navy-2)}
.btn-ghost{background:transparent;color:var(--nms-navy);border:1.5px solid var(--nms-line-2);box-shadow:none}
.btn-ghost:hover{border-color:var(--nms-navy);background:transparent}
.on-dark .btn-ghost{color:#fff;border-color:rgba(255,255,255,.25)}
.on-dark .btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff}
.btn-sm{padding:.6rem 1.1rem;font-size:.78rem}
.btn-lg{padding:1.05rem 1.4rem;font-size:.95rem}

.link{display:inline-flex;align-items:center;gap:.4rem;color:var(--nms-navy);font-weight:600;border-bottom:2px solid var(--nms-yellow);padding-bottom:.2rem;transition:color .2s}
.link:hover{color:var(--nms-navy-2)}

/* ---------- INPUTS / FORMS (V1 system) ---------- */
.nms-input,.nms-select,.nms-textarea{
  width:100%;background:var(--nms-cream);border:1.5px solid var(--nms-line);
  border-radius:12px;padding:.85rem 1rem;font:inherit;color:var(--nms-text);
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.nms-input:focus,.nms-select:focus,.nms-textarea:focus{
  outline:none;border-color:var(--nms-navy);background:#fff;
  box-shadow:0 0 0 4px rgba(255,204,0,.18);
}
.nms-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--nms-text-3);margin-bottom:.5rem}

/* ---------- CARDS ---------- */
.nms-card{
  background:#fff;border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg);
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.nms-card.hoverable:hover{transform:translateY(-4px);box-shadow:var(--nms-shadow-md);border-color:transparent}

/* ---------- REVEAL ---------- */
.nms-reveal,[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--delay,0ms)}
.nms-reveal.is-in,[data-reveal].is-in{opacity:1;transform:none}
[data-reveal="left"]{transform:translateX(-24px)} [data-reveal="left"].is-in{transform:none}
[data-reveal="right"]{transform:translateX(24px)} [data-reveal="right"].is-in{transform:none}
[data-reveal="fade"]{transform:none}

/* stat counter */
.nms-stat-num{font-weight:800;letter-spacing:-.025em;line-height:1;font-variant-numeric:tabular-nums}

/* striped placeholder */
.nms-placeholder{
  background:repeating-linear-gradient(135deg, rgba(28,41,54,.04) 0 12px, rgba(28,41,54,.07) 12px 24px), var(--nms-cream-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--nms-text-3);font-family:"JetBrains Mono",ui-monospace,monospace;
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
}

/* haze drift used in ambient backgrounds */
@keyframes v1-haze-drift-anim{
  0%{transform:translate3d(0,0,0) scale(1)}
  33%{transform:translate3d(2%,-1.5%,0) scale(1.04)}
  66%{transform:translate3d(-1.5%,1%,0) scale(1.02)}
  100%{transform:translate3d(0,0,0) scale(1)}
}
.v1-haze-drift{animation:v1-haze-drift-anim 22s ease-in-out infinite;will-change:transform}

/* ---------- HEADER ----------
   Round 5: header content boxed inside a max-width 1280px container so
   on wide screens the logo / nav / CTA cluster around the same width
   as the body content rather than sprawling edge-to-edge. The header
   bar background still spans full-width via .nms-header. */
.nms-header{
  display:block;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--nms-line);
  position:sticky;top:0;z-index:50;
  transition:background .3s, border-color .3s, box-shadow .3s;
}
.nms-header > .nms-brand,
.nms-header > .nms-nav,
.nms-header > .nms-header-cta{
  /* fallback for any direct flex children that haven't been wrapped */
}
.nms-header-inner{
  max-width:var(--container);margin:0 auto;
  padding:1.1rem clamp(1rem,3vw,2.5rem);
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);
}
.nms-header.is-scrolled{background:rgba(255,255,255,.96);box-shadow:0 10px 30px -16px rgba(28,41,54,.14)}
.nms-header.dark{background:rgba(19,28,37,.72);border-bottom-color:rgba(255,255,255,.08)}
.nms-header.dark.is-scrolled{background:rgba(19,28,37,.92)}
.nms-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--nms-navy)}
.nms-header.dark .nms-brand{color:var(--nms-text-on-navy)}
/* Real NMS logomark — PNG aspect 1.82:1; height-locked, width auto.
   Round 5: bumped from 44px → 56px per Blaine's "logo bigger on the
   menu" feedback. Mobile stays at 44px. */
.brand-logo{display:block;height:56px;width:auto;max-width:none}
@media (max-width:560px){.brand-logo{height:44px}}
/* Footer (and any dark-bg) variant: invert to a clean white silhouette
   so it reads on --nms-navy-deep. The yellow swoosh becomes white;
   that's an acceptable launch-day tradeoff vs. dropping the logo or
   shipping an unreadable navy-on-navy mark. */
.brand-logo-light{filter:brightness(0) invert(1)}
.v1-foot .brand-logo{height:48px}
/* legacy mark+txt lockup — kept for any place still using it */
.nms-brand .mark{width:34px;height:34px;border-radius:9px;background:var(--nms-yellow);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nms-brand .mark svg{width:24px;height:24px;color:var(--nms-navy)}
.nms-brand .txt{line-height:1.05}
.nms-brand .txt .name{font-weight:800;font-size:1.02rem;letter-spacing:-.01em}
.nms-brand .txt .sub{font-size:.66rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;opacity:.65}
.nms-nav{display:flex;gap:2rem;align-items:center}
.nms-nav a{font-size:.88rem;font-weight:500;text-decoration:none;color:var(--nms-text-2);transition:color .2s}
.nms-nav a:hover,.nms-nav a.is-active{color:var(--nms-navy)}
.nms-header.dark .nms-nav a{color:rgba(243,241,234,.78)}
.nms-header.dark .nms-nav a:hover,.nms-header.dark .nms-nav a.is-active{color:var(--nms-yellow)}

/* ---------- NAV DROPDOWNS (Round 7 Edit 1) ---------------------------
   Hover-trigger on parent, 150ms delay before close on mouseleave so
   the cursor can travel from parent to menu without it collapsing.
   Keyboard: focus on parent reveals the menu via :focus-within. ESC
   closes (handled in design.js). Children menu items keep their own
   tab order — no aria-hidden trickery, just a CSS-driven panel that
   the JS toggles `data-open` on.                                       */
.nms-nav-group{position:relative;display:inline-flex;align-items:center}
.nms-nav-parent{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.88rem;font-weight:500;color:var(--nms-text-2);
  text-decoration:none;cursor:pointer;
  transition:color .2s;
}
.nms-nav-parent:hover,.nms-nav-parent.is-active{color:var(--nms-navy)}
.nms-nav-caret{
  transition:transform .2s ease-out;flex-shrink:0;
  transform:translateY(1px);
}
.nms-nav-group:hover .nms-nav-caret,
.nms-nav-group:focus-within .nms-nav-caret,
.nms-nav-group[data-open] .nms-nav-caret{transform:translateY(1px) rotate(180deg)}
.nms-nav-menu{
  position:absolute;top:100%;left:50%;
  transform:translate(-50%,-6px);
  min-width:280px;padding:.5rem;
  background:#fff;border:1px solid var(--nms-line);
  border-radius:var(--nms-radius-lg);
  box-shadow:0 24px 60px -24px rgba(28,41,54,.35),0 8px 24px -12px rgba(28,41,54,.18);
  display:flex;flex-direction:column;gap:.15rem;
  opacity:0;pointer-events:none;visibility:hidden;
  transition:opacity .18s ease-out,transform .18s ease-out,visibility 0s linear .18s;
  z-index:50;
}
.nms-nav-group:hover .nms-nav-menu,
.nms-nav-group:focus-within .nms-nav-menu,
.nms-nav-group[data-open] .nms-nav-menu{
  opacity:1;pointer-events:auto;visibility:visible;
  transform:translate(-50%,2px);
  transition:opacity .18s ease-out,transform .18s ease-out;
}
/* invisible pad above the menu so cursor travel doesn't break the hover */
.nms-nav-menu::before{
  content:"";position:absolute;top:-10px;left:0;right:0;height:10px;
}
.nms-nav-item{
  display:block;padding:.7rem .9rem;
  font-size:.92rem;font-weight:600;color:var(--nms-navy);
  text-decoration:none;border-radius:var(--nms-radius);
  transition:background .15s,color .15s;
  letter-spacing:-.005em;
}
.nms-nav-item:hover,.nms-nav-item:focus-visible{
  background:var(--nms-cream-2);color:var(--nms-navy);outline:none;
}
.nms-nav-item.is-active{
  background:rgba(255,204,0,.18);color:var(--nms-navy);
}
.nms-nav-item-sub{
  display:block;font-size:.78rem;font-weight:400;
  color:var(--nms-text-3);margin-top:.15rem;letter-spacing:.005em;
}
@media (max-width:960px){
  .nms-nav-group,.nms-nav-menu{display:none}
}
.nms-header-cta{display:flex;align-items:center;gap:1rem}
.nms-phone{font-size:.86rem;font-weight:600;color:var(--nms-navy);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem}
.nms-phone:hover{color:var(--nms-navy-2)}
.nms-header.dark .nms-phone{color:var(--nms-yellow)}
/* Mobile hamburger toggle — Round 6 hot-fix:
   Was rendering as a 42×42 circle with only 2 horizontal lines (looked
   like an "=" inside a pill). Now a clean square button with 3 visible
   bars — the universal mobile-menu signifier. No background ring; the
   bars themselves are the affordance. */
.nms-toggle{
  display:none;width:44px;height:44px;
  border-radius:8px;border:none;background:transparent;
  color:var(--nms-navy);align-items:center;justify-content:center;
  padding:0;cursor:pointer;
}
.nms-toggle svg{width:26px;height:26px;display:block}
.nms-toggle:hover{background:rgba(28,41,54,.06)}
.nms-toggle:focus-visible{outline:2px solid var(--nms-yellow);outline-offset:2px}
@media (max-width:960px){
  .nms-nav,.nms-phone{display:none}
  .nms-toggle{display:inline-flex}
}

/* mobile drawer */
.nms-mnav{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:60;
  background:#fff;padding:5rem 1.5rem 2rem;overflow:auto;
  transform:translateY(-12px);opacity:0;pointer-events:none;
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.nms-mnav.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
.nms-mnav-close{position:absolute;top:1rem;right:1.25rem;width:42px;height:42px;border-radius:999px;border:1px solid var(--nms-line-2);display:flex;align-items:center;justify-content:center;color:var(--nms-navy)}
.nms-mnav a{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;font-size:1.2rem;font-weight:600;color:var(--nms-navy);border-bottom:1px solid var(--nms-line)}
.nms-mnav a:hover{color:var(--nms-yellow)}
.nms-mnav-cta{margin-top:2rem;display:grid;gap:.75rem}
/* Round 6 hot-fix: drawer CTA buttons inherited the link rule's
   `justify-content:space-between` + bottom border — text was pinned to
   the left and the cards looked half-broken. Override here so the CTA
   pill behaves like a real button (centered, no row separator). */
.nms-mnav-cta a.nms-btn{
  justify-content:center;border-bottom:none;
  padding:1rem 1.4rem;font-size:1rem;
}
/* Round 6 hot-fix #2: nested children (Careers under About; FAQ +
   Video Library under Learning Center). Indented + de-emphasized so the
   parent/child hierarchy is obvious at a glance. */
.nms-mnav .mnav-child{
  padding-left:1.25rem;font-size:1rem;font-weight:500;
  color:var(--nms-text-2);
  border-bottom:1px solid var(--nms-line);
  position:relative;
}
.nms-mnav .mnav-child::before{
  content:"";position:absolute;left:0;top:50%;
  width:.6rem;height:1px;background:var(--nms-line-2);
  transform:translateY(-50%);
}
.nms-mnav .mnav-child:hover{color:var(--nms-yellow)}

/* ---------- REFERRAL MARQUEE ---------- */
.nms-marquee{
  display:block;background:var(--nms-yellow);color:var(--nms-navy);
  padding:.7rem 0;overflow:hidden;
  border-top:1px solid rgba(28,41,54,.1);border-bottom:1px solid rgba(28,41,54,.1);
  text-decoration:none;
}
.nms-marquee-track{
  display:flex;gap:3rem;white-space:nowrap;
  animation:nms-marquee-v1 32s linear infinite;
  font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
}
.nms-marquee-track > span{display:inline-flex;align-items:center;gap:.7rem}
.nms-marquee-track .star{color:var(--nms-navy)}
.nms-marquee-track .sep{opacity:.5;margin-left:2rem}
.nms-marquee-track .sep2{opacity:.35;margin-left:2rem}
@keyframes nms-marquee-v1{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* ---------- HERO (V1 — interactive shimmer) ---------- */
/* .v1-hero zeroes the new default section padding — internal padding
   is handled by .v1-hero-inner. Don't drag homepage hero rhythm. */
.v1-hero{padding:0;position:relative;overflow:hidden;background:var(--nms-navy);min-height:720px}
.v1-hero-bg{position:absolute;inset:0;z-index:0;background-image:url('/assets/img/photos/hero-home.jpg');background-size:cover;background-position:center}
.v1-hero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg, rgba(28,41,54,.92) 0%, rgba(28,41,54,.6) 55%, rgba(28,41,54,.35) 100%)}
.v1-hero-sun{
  position:absolute;top:10%;right:14%;width:380px;height:380px;z-index:2;
  background:radial-gradient(circle, rgba(255,204,0,.28), transparent 60%);
  animation:v1-sun-breathe 6s ease-in-out infinite;pointer-events:none;
  transition:opacity .8s;
}
.v1-hero.is-tracking .v1-hero-sun{opacity:.4}
@keyframes v1-sun-breathe{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.85}}
.v1-hero-shimmer-1,.v1-hero-shimmer-2,.v1-hero-shimmer-3{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity .6s var(--ease), background-position .4s ease-out}
.v1-hero-shimmer-1{
  background:radial-gradient(circle 380px at var(--mx,70%) var(--my,30%), rgba(255,224,113,.32), rgba(255,204,0,.12) 30%, transparent 60%);
  mix-blend-mode:screen;
}
.v1-hero-shimmer-2{
  background:radial-gradient(circle 140px at var(--mx,70%) var(--my,30%), rgba(255,255,255,.18), transparent 70%);
  mix-blend-mode:overlay;transition-duration:.4s;
}
.v1-hero-shimmer-3{
  background:linear-gradient(105deg, transparent 38%, rgba(255,255,255,.06) 49%, rgba(255,224,113,.1) 50%, rgba(255,255,255,.06) 51%, transparent 62%);
  background-size:300% 300%;
  background-position:var(--mx,70%) var(--my,30%);
  mix-blend-mode:screen;transition-duration:.8s;
}
.v1-hero.is-tracking .v1-hero-shimmer-1,
.v1-hero.is-tracking .v1-hero-shimmer-2,
.v1-hero.is-tracking .v1-hero-shimmer-3{opacity:1}

.v1-hero-grid{position:absolute;inset:0;z-index:2;opacity:.06;pointer-events:none}
.v1-hero-inner{position:relative;z-index:3;padding:5.5rem clamp(1rem,3vw,2.5rem) 6rem;max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:4rem;align-items:center}
@media (max-width:980px){.v1-hero-inner{grid-template-columns:1fr;gap:3rem}}
.v1-hero h1{font-size:clamp(2.6rem,4.4vw,4.4rem);font-weight:800;line-height:1.05;letter-spacing:-.025em;color:#fff;margin:1rem 0 1.25rem}
.v1-hero h1 em{color:var(--nms-yellow);font-style:normal;display:inline-block;position:relative}
.v1-hero h1 .underline{position:absolute;left:0;right:0;bottom:-.1em;width:100%;height:.18em}
.v1-hero h1 .underline path{stroke:#ffcc00;stroke-width:3;fill:none;stroke-linecap:round;stroke-dasharray:220;stroke-dashoffset:220;animation:v1-draw 1.4s .4s var(--ease) forwards}
@keyframes v1-draw{to{stroke-dashoffset:0}}
.v1-hero p.lede{font-size:1.12rem;color:rgba(243,241,234,.78);max-width:540px;line-height:1.65;margin-bottom:2rem}
.v1-hero-actions{display:flex;gap:.85rem;flex-wrap:wrap}
.v1-hero-stats{margin-top:3rem;display:flex;gap:2.5rem;flex-wrap:wrap}
.v1-hero-stats .num{font-size:2rem;color:#fff}
.v1-hero-stats .lbl{font-size:.78rem;color:rgba(243,241,234,.6);margin-top:.3rem;letter-spacing:.05em}
.v1-hero-scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:4;color:rgba(243,241,234,.5);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;transition:opacity .4s}
.v1-hero-scroll .bar{width:1px;height:32px;background:rgba(243,241,234,.4);position:relative;overflow:hidden}
.v1-hero-scroll .bar span{position:absolute;inset:0;background:var(--nms-yellow);animation:v1-scroll-cue 2s ease-in-out infinite}
.v1-hero.is-scrolled .v1-hero-scroll{opacity:0}
@keyframes v1-scroll-cue{0%{transform:translateY(-100%)} 60%,100%{transform:translateY(100%)}}

/* ---------- COMPARE (V1 — hover expand) ---------- */
.v1-compare-wrap{padding:6rem clamp(1rem,3vw,2.5rem);background:var(--nms-cream)}
.v1-compare-wrap > .container{max-width:1280px}
.v1-compare-head{text-align:center;margin-bottom:3.5rem}
.v1-compare-head h2{font-size:clamp(2rem,3.4vw,2.9rem);font-weight:800;letter-spacing:-.025em;margin-top:.8rem}
.v1-compare-head h2 .stroke{color:var(--nms-yellow);-webkit-text-stroke:1px var(--nms-navy)}
.v1-compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;transition:grid-template-columns .5s var(--ease)}
.v1-compare-grid.left-active{grid-template-columns:1.1fr .9fr}
.v1-compare-grid.right-active{grid-template-columns:.9fr 1.1fr}
@media (max-width:880px){.v1-compare-grid,.v1-compare-grid.left-active,.v1-compare-grid.right-active{grid-template-columns:1fr}}
.v1-compare-col{padding:2.5rem;border-radius:var(--nms-radius-lg);border:1px solid var(--nms-line);background:#fff;cursor:default;transition:transform .4s, box-shadow .4s}
.v1-compare-col.solar{background:var(--nms-navy);color:var(--nms-cream);border-color:transparent}
.v1-compare-col.is-active{transform:translateY(-4px);box-shadow:var(--nms-shadow-lg)}
.v1-compare-col .icon{width:56px;height:56px;border-radius:16px;background:var(--nms-cream-2);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-size:1.6rem}
.v1-compare-col.solar .icon{background:var(--nms-yellow)}
/* Compare-section illustration banner: replaces the previous emoji icon
   with a wide image header above the column heading. Traditional column
   uses the supplied Traditional-Power graphic; Solar column uses a real
   photo of an NMS install. 16:9 aspect, rounded, subtle inner ring. */
.v1-compare-col .compare-illustration{aspect-ratio:16/9;border-radius:var(--nms-radius);overflow:hidden;margin-bottom:1.5rem;background:var(--nms-cream-2);box-shadow:inset 0 0 0 1px rgba(28,41,54,.06)}
.v1-compare-col.solar .compare-illustration{background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.v1-compare-col .compare-illustration img{width:100%;height:100%;object-fit:contain;padding:.75rem;display:block}
.v1-compare-col.solar .compare-illustration{background:rgba(255,255,255,.92)}
.v1-compare-col.solar .compare-illustration img{padding:1rem}
.v1-compare-col h3{font-size:1.6rem;font-weight:700;letter-spacing:-.015em;margin-bottom:.5rem;color:inherit}
.v1-compare-col .sub{opacity:.75;margin-bottom:2rem;font-size:.95rem;line-height:1.6}
.v1-compare-col .items{display:grid;gap:1rem}
.v1-compare-col .items .row{display:flex;gap:1rem;align-items:flex-start}
.v1-compare-col .items .n{width:28px;height:28px;border-radius:8px;flex-shrink:0;background:var(--nms-cream);color:var(--nms-navy);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem}
.v1-compare-col.solar .items .n{background:rgba(255,204,0,.15);color:var(--nms-yellow)}
.v1-compare-col .items .ttl{font-weight:600;margin-bottom:.15rem}
.v1-compare-col .items .desc{font-size:.88rem;opacity:.7;line-height:1.55}

/* ---------- PRODUCTS (V1 — pill badges) ---------- */
.v1-products{padding:6rem clamp(1rem,3vw,2.5rem);background:#fff}
.v1-products > .container{max-width:1280px}
.v1-products-head{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:end;margin-bottom:3rem}
@media (max-width:780px){.v1-products-head{grid-template-columns:1fr;gap:1.5rem}}
.v1-products-head h2{font-size:clamp(2rem,3.4vw,2.9rem);font-weight:800;letter-spacing:-.025em;margin-top:.8rem}
.v1-products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media (max-width:880px){.v1-products-grid{grid-template-columns:1fr}}
.v1-product-card{padding:2rem;position:relative;overflow:hidden}
.v1-product-card .badge{position:absolute;top:1.25rem;right:1.25rem;font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--nms-navy);background:var(--nms-yellow);padding:.3rem .6rem;border-radius:999px}
.v1-product-card .icon{width:64px;height:64px;border-radius:18px;background:var(--nms-cream);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}
.v1-product-card .icon img{width:36px;height:36px}
.v1-product-card h3{font-size:1.3rem;font-weight:700;letter-spacing:-.015em;margin-bottom:.6rem}
.v1-product-card p{color:var(--nms-text-2);font-size:.95rem;line-height:1.65;margin-bottom:1.5rem}

/* ---------- CALCULATOR (V1) ---------- */
.v1-calc{padding:6rem clamp(1rem,3vw,2.5rem);background:var(--nms-navy);color:var(--nms-cream);position:relative;overflow:hidden;--cx:85%;--cy:20%}
.v1-calc::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at var(--cx) var(--cy), rgba(255,204,0,.18), transparent 60%);pointer-events:none}
.v1-calc-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative}
@media (max-width:880px){.v1-calc-inner{grid-template-columns:1fr;gap:2.5rem}}
.v1-calc h2{font-size:clamp(2rem,3.4vw,2.9rem);font-weight:800;letter-spacing:-.025em;line-height:1.05;color:#fff;margin-top:.8rem;margin-bottom:1rem}
.v1-calc h2 em{color:var(--nms-yellow);font-style:normal}
.v1-calc p.intro{color:rgba(243,241,234,.72);font-size:1.05rem;margin-bottom:2rem;line-height:1.6}
.v1-calc-slider{margin-bottom:1.5rem}
.v1-calc-slider .head{display:flex;justify-content:space-between;margin-bottom:.6rem}
.v1-calc-slider .lbl{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(243,241,234,.6)}
.v1-calc-slider .val{font-size:1.2rem;font-weight:700;color:var(--nms-yellow)}
.v1-calc-slider input[type="range"]{width:100%;accent-color:#ffcc00}
.v1-calc-slider .ends{display:flex;justify-content:space-between;font-size:.72rem;color:rgba(243,241,234,.45);margin-top:.4rem}
.v1-calc-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--nms-radius-xl);padding:2.25rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.v1-calc-card .row{border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:1rem;margin-bottom:1.25rem}
.v1-calc-card .row:last-of-type{border-bottom:none;margin-bottom:.5rem}
.v1-calc-card .lbl{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(243,241,234,.55);margin-bottom:.4rem}
.v1-calc-card .val{font-size:2.1rem;font-weight:800;letter-spacing:-.025em;color:#fff;font-variant-numeric:tabular-nums}
.v1-calc-card .val.gold{color:var(--nms-yellow)}
.v1-calc-card .note{font-size:.74rem;color:rgba(243,241,234,.5);line-height:1.5}

/* ---------- GUIDE (V1 — image left, copy right) ---------- */
.v1-guide{padding:6rem clamp(1rem,3vw,2.5rem);background:var(--nms-cream)}
.v1-guide-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:center}
@media (max-width:880px){.v1-guide-inner{grid-template-columns:1fr;gap:2.5rem}}
/* Round 3 Edit 5: We Are Here to Guide You photo — points at a placeholder
   PNG. Drop the real screenshot at the same path and the section updates
   with no code change. Solid cream backstop so the empty placeholder
   reads as a slot, not a broken image. */
.v1-guide-photo{aspect-ratio:4/5;border-radius:var(--nms-radius-xl);overflow:hidden;background:#f3f1ea url('/assets/img/home/replacements/we-guide-you-screenshot.png') center/cover;box-shadow:var(--nms-shadow-lg);transition:transform .6s}
.v1-guide-photo:hover{transform:scale(1.02)}
.v1-guide h2{font-size:clamp(2rem,3.4vw,2.9rem);font-weight:800;letter-spacing:-.025em;margin-top:.8rem;margin-bottom:1.25rem}
.v1-guide h2 .stroke{color:var(--nms-yellow);-webkit-text-stroke:1px var(--nms-navy)}
.v1-guide .intro{font-size:1.05rem;color:var(--nms-text-2);line-height:1.65;margin-bottom:2rem}
.v1-guide-bullets{display:grid;gap:1.5rem;margin-bottom:2rem}
.v1-guide-bullet{display:flex;gap:1rem}
.v1-guide-bullet .accent{width:4px;background:var(--nms-yellow);border-radius:4px;flex-shrink:0}
.v1-guide-bullet .ttl{font-weight:700;margin-bottom:.25rem}
.v1-guide-bullet .desc{color:var(--nms-text-2);font-size:.92rem}

/* ---------- TESTIMONIALS CAROUSEL (V1) ---------- */
.v1-test{padding:6rem clamp(1rem,3vw,2.5rem);background:#fff}
.v1-test > .container{max-width:1280px}
.v1-test-head{text-align:center;margin-bottom:3rem}
.v1-test-head h2{font-size:clamp(2rem,3.4vw,2.9rem);font-weight:800;letter-spacing:-.025em;margin:.8rem auto 0;max-width:720px}
.v1-test-stage{position:relative;height:280px;max-width:880px;margin:0 auto}
.v1-test-card-wrap{position:absolute;inset:0;opacity:0;transform:translateX(0) scale(.96);transition:opacity .6s var(--ease), transform .6s var(--ease);pointer-events:none}
.v1-test-card-wrap.is-active{opacity:1;transform:translateX(0) scale(1);pointer-events:auto}
.v1-test-card{padding:3rem;text-align:center;box-shadow:var(--nms-shadow-md);background:#fff;border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg)}
.v1-test-card .stars{color:var(--nms-yellow);font-size:1.25rem;margin-bottom:1.25rem;letter-spacing:.15em}
.v1-test-card p{color:var(--nms-text);font-size:1.3rem;line-height:1.45;margin-bottom:2rem;font-weight:500;letter-spacing:-.015em}
.v1-test-card .who{display:flex;gap:.85rem;align-items:center;justify-content:center}
.v1-test-card .av{width:44px;height:44px;border-radius:999px;background:var(--nms-cream-2);display:flex;align-items:center;justify-content:center;font-weight:700}
.v1-test-card .nm{font-weight:600}
.v1-test-card .ml{font-size:.8rem;color:var(--nms-text-3)}
.v1-test-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}
.v1-test-dot{width:8px;height:8px;border-radius:999px;border:none;cursor:pointer;background:var(--nms-line-2);transition:all .3s;padding:0}
.v1-test-dot.is-active{width:28px;background:var(--nms-navy)}
.v1-test-foot{text-align:center;margin-top:2.5rem}

/* ---------- PARTNERS (V1) ---------- */
.v1-partners{padding:5rem clamp(1rem,3vw,2.5rem);background:var(--nms-cream)}
.v1-partners > .container{max-width:1280px}
.v1-partners-head{text-align:center;margin-bottom:2.5rem}
.v1-partners-head h2{font-size:clamp(1.6rem,2.4vw,2.1rem);font-weight:700;letter-spacing:-.02em;margin-top:.6rem}
.v1-partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}
@media (max-width:880px){.v1-partners-grid{grid-template-columns:repeat(2,1fr)}}
.v1-partner{padding:2.25rem 1.5rem;text-align:center}
/* Hot fix C: real branded SVGs for Tesla + QCells with brand colors
   (Tesla red #cc0000, Q CELLS blue #003366). Container bumped to 90px
   tall + image max-height 76px so logos don't feel trapped. Opacity
   1.0 — full brand color always. */
.v1-partner .logo{height:90px;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;padding:.25rem}
.v1-partner .logo img{max-height:76px;max-width:92%;opacity:1;filter:none;transition:transform .2s}
.v1-partner:hover .logo img{transform:scale(1.04)}
.v1-partner p{font-size:.88rem;color:var(--nms-text-2);line-height:1.55}

/* ---------- CTA (V1 — cursor-aware) ---------- */
.v1-cta{padding:6rem clamp(1rem,3vw,2.5rem);background:var(--nms-navy);color:var(--nms-cream);position:relative;overflow:hidden;--cx:70%;--cy:50%}
.v1-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 55% 70% at var(--cx) var(--cy), rgba(255,204,0,.18), transparent 60%);pointer-events:none}
.v1-cta-inner{max-width:800px;margin:0 auto;text-align:center;position:relative}
.v1-cta h2{font-size:clamp(2rem,3.6vw,3rem);font-weight:800;letter-spacing:-.025em;margin:.8rem 0 1rem;color:#fff}
.v1-cta p{color:rgba(243,241,234,.7);font-size:1.08rem;margin-bottom:2rem}
.v1-cta-phone{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;color:var(--nms-yellow);text-decoration:none;letter-spacing:-.02em;display:inline-block;transition:opacity .2s}
.v1-cta-phone:hover{opacity:.85}
.v1-cta-foot{margin-top:1.75rem}

/* ---------- FOOTER (V1) ---------- */
.v1-foot{background:var(--nms-navy-deep);color:var(--nms-text-on-navy);padding:var(--section-y) clamp(1rem,3vw,2.5rem) var(--space-xl)}
.v1-foot-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;max-width:1280px;margin:0 auto}
@media (max-width:900px){.v1-foot-inner{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:560px){.v1-foot-inner{grid-template-columns:1fr}}
.v1-foot p.tag{margin-top:1.2rem;color:rgba(243,241,234,.65);font-size:.92rem;line-height:1.65;max-width:320px}
.v1-foot-socials{margin-top:1.5rem;display:flex;gap:.6rem}
.v1-foot-socials a{width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:rgba(243,241,234,.85);text-decoration:none;transition:background .2s,color .2s,border-color .2s,transform .2s}
.v1-foot-socials a:hover{background:var(--nms-yellow);color:var(--nms-navy);border-color:var(--nms-yellow);transform:translateY(-2px)}
.v1-foot-socials a svg{width:18px;height:18px;display:block}
.v1-foot h6{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--nms-yellow);margin-bottom:1.2rem}
.v1-foot ul{display:grid;gap:.65rem}
.v1-foot ul a{color:rgba(243,241,234,.75);text-decoration:none;font-size:.92rem}
.v1-foot ul a:hover{color:var(--nms-yellow)}
.v1-foot-bottom{max-width:1280px;margin:4rem auto 0;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem;color:rgba(243,241,234,.45)}
.v1-foot-bottom a{color:rgba(243,241,234,.75)}
.v1-foot-bottom a:hover{color:var(--nms-yellow)}

/* ---------- BACK TO TOP ---------- */
.back-top{
  position:fixed;left:20px;bottom:24px;z-index:70;
  width:44px;height:44px;border-radius:999px;border:none;cursor:pointer;
  background:var(--nms-navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--nms-shadow-md);
  opacity:0;pointer-events:none;
  transform:translateY(10px);
  transition:opacity .25s,transform .25s,background .2s,color .2s;
}
.back-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-top:hover{background:var(--nms-yellow);color:var(--nms-navy)}

/* ---------- LEGACY COMPAT (existing pages) ---------- */
.banner{display:none}
.nav{position:sticky;top:0;left:0;right:0;z-index:50;height:auto;display:flex;align-items:center;backdrop-filter:saturate(180%) blur(14px);background:rgba(255,255,255,.85);border-bottom:1px solid var(--nms-line)}
.nav-inner{width:100%;max-width:1280px;margin:0 auto;padding:1.1rem clamp(1rem,3vw,2.5rem);display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav-brand{display:flex;align-items:center;gap:.6rem;color:var(--nms-navy);flex-shrink:0}
.nav-brand img{height:40px;width:auto}
.nav-links{display:flex;gap:1.4rem;align-items:center}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--nms-text-2)}
.nav-links a:hover,.nav-links a.is-active{color:var(--nms-navy)}
.nav-cta{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.nav-phone{display:inline-flex;align-items:center;gap:.4rem;color:var(--nms-navy);font-size:.86rem;font-weight:600}
.nav-phone:hover{color:var(--nms-navy-2)}
.nav-toggle{display:none;width:42px;height:42px;border-radius:999px;border:1px solid var(--nms-line-2);color:var(--nms-navy);align-items:center;justify-content:center}
@media (max-width:960px){.nav-links,.nav-phone{display:none}.nav-toggle{display:inline-flex}}
.mnav{position:fixed;top:0;left:0;right:0;bottom:0;z-index:60;background:#fff;padding:5rem 1.5rem 2rem;overflow:auto;transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.mnav.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
.mnav-links{display:grid}
.mnav-links a{padding:1rem 0;font-size:1.2rem;font-weight:600;color:var(--nms-navy);border-bottom:1px solid var(--nms-line);display:flex;justify-content:space-between;align-items:center}

/* Round 5: page-head padding made symmetric (--space-2xl top + bottom
   = 96/96), bigger subtext (--fs-lg), and explicit gaps between
   breadcrumb / h1 / subtext per Blaine's screenshot. */
.page-head{padding:var(--space-2xl) 0 var(--space-2xl);text-align:center;background:var(--nms-cream-2);border-bottom:1px solid var(--nms-line)}
.page-head .bc{margin:0 0 var(--space-sm)}
.page-head h1{margin:0 auto var(--space-md)}
.page-head p{font-size:var(--fs-lg);max-width:60ch;margin:0 auto;color:var(--nms-text-2);line-height:1.55}
.bc{font-size:.72rem;color:var(--nms-text-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}
.bc a:hover{color:var(--nms-navy)}

/* .section-head — eyebrow + h2 + p stack used by every page section.
   Was rendering near-flush; now gets explicit token-scaled spacing. */
.section-head{margin-bottom:var(--space-xl)}
.section-head .nms-eyebrow,.section-head .kicker{margin-bottom:var(--space-sm)}
.section-head h2{margin-bottom:var(--space-md)}
.section-head p{font-size:var(--fs-lg);line-height:1.55}
.section-head p:last-child{margin-bottom:0}

/* legacy compare/feature/testimonial cards — minimal so other pages don't break */
.feature-card{background:#fff;border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg);padding:1.75rem;transition:transform .3s var(--ease), box-shadow .3s, border-color .3s}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--nms-shadow-md);border-color:transparent}
.feature-card .icon{width:56px;height:56px;border-radius:14px;background:var(--nms-cream-2);color:var(--nms-navy);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
/* Hot fix D: title→subtext breathing room. Was rendering with 0 gap
   so h3 sat flush against the paragraph. */
.feature-card h3{margin-bottom:.6rem;line-height:1.18}
.feature-card p{line-height:1.6}
.difference-section .difference-card{padding:2rem}
.difference-section .difference-card h3{margin-bottom:.85rem}
.difference-section .difference-card p{margin-top:.15rem}
.feature-card .icon.orange{background:rgba(255,204,0,.18);color:var(--nms-navy-2)}
.feature-card .icon.teal{background:rgba(28,181,189,.15);color:var(--nms-teal)}
.feature-card .num{font-weight:800;font-size:2.6rem;color:var(--nms-yellow);opacity:.4;line-height:1;margin-bottom:.3rem;letter-spacing:-.04em}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media (max-width:860px){.compare{grid-template-columns:1fr}}
.compare-col{padding:2rem;border-radius:var(--nms-radius-lg);background:#fff;border:1px solid var(--nms-line)}
.compare-col.solar{background:var(--nms-navy);color:var(--nms-cream)}
.compare-col.solar h3,.compare-col.solar h4{color:#fff}
.compare-col h3{margin-bottom:.4rem}
.compare-col h4{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem;color:var(--nms-text-2);font-weight:700}
.compare-col.solar h4{color:rgba(243,241,234,.7)}
.compare-col .tag{display:inline-flex;padding:.25rem .6rem;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(214,69,69,.10);color:var(--nms-danger);border-radius:999px;font-weight:700}
.compare-col .tag.good{background:rgba(255,204,0,.18);color:var(--nms-navy)}
.compare-col.solar .tag.good{background:var(--nms-yellow);color:var(--nms-navy)}
.compare-diagram{aspect-ratio:16/10;border-radius:var(--nms-radius);overflow:hidden;margin-bottom:1.25rem;background:var(--nms-cream-2);border:1px solid var(--nms-line)}
.compare-diagram img{width:100%;height:100%;object-fit:contain;padding:1rem}
.compare ol{display:flex;flex-direction:column;gap:.6rem;counter-reset:step;margin-top:.5rem}
.compare ol li{display:flex;gap:.9rem;padding:.75rem .9rem;background:var(--nms-cream-2);border-radius:var(--nms-radius);counter-increment:step;font-size:.92rem;color:var(--nms-text-2)}
.compare-col.solar ol li{background:rgba(255,255,255,.04);color:rgba(243,241,234,.78)}
.compare ol li::before{content:counter(step,decimal-leading-zero);font-family:"JetBrains Mono",monospace;font-size:.78rem;color:var(--nms-text-3);flex-shrink:0;width:28px;font-weight:600}
.compare-col.solar ol li::before{color:var(--nms-yellow)}

.t-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-md)}
.t-card{padding:1.75rem;border-radius:var(--nms-radius-lg);background:#fff;border:1px solid var(--nms-line);transition:transform .3s var(--ease), box-shadow .3s, border-color .3s}
.t-card:hover{transform:translateY(-4px);box-shadow:var(--nms-shadow-md);border-color:transparent}
.t-card .stars{color:var(--nms-yellow);margin-bottom:.9rem;display:flex;gap:2px}
.t-card .stars svg{width:18px;height:18px;fill:currentColor}
.t-card .source{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--nms-text-3);font-weight:600;margin-bottom:.75rem}
.t-card .source .src-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;background:var(--nms-cream-2);color:var(--nms-text-2)}
.t-card .source .src-badge svg{width:13px;height:13px}
.t-card .who{display:flex;align-items:center;gap:.75rem;margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--nms-line)}
.t-card .who .av{width:38px;height:38px;border-radius:999px;background:var(--nms-yellow);color:var(--nms-navy);display:flex;align-items:center;justify-content:center;font-weight:700}
.t-card .who .nm{font-weight:600;font-size:.92rem}
.t-card .who .ml{font-size:.72rem;color:var(--nms-text-3)}

.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md)}
.team-card{border-radius:var(--nms-radius-lg);overflow:hidden;border:1px solid var(--nms-line);background:#fff;transition:transform .3s var(--ease), box-shadow .3s, border-color .3s}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--nms-shadow-md);border-color:transparent}
.team-photo{aspect-ratio:4/5;overflow:hidden;background:var(--nms-cream-2)}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-meta{padding:1.25rem 1.3rem 1.5rem}
.team-meta h3{font-size:1.2rem;margin-bottom:.2rem}
.team-meta .role{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--nms-text-2);font-weight:700;margin-bottom:.6rem}
.team-meta p{font-size:.92rem;color:var(--nms-text-2);line-height:1.55}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem}
.stat{text-align:center;padding:1.5rem 1rem;border-radius:var(--nms-radius-lg);background:#fff;border:1px solid var(--nms-line);transition:border-color .2s, box-shadow .2s}
.stat:hover{border-color:var(--nms-yellow);box-shadow:var(--nms-shadow-sm)}
.stat .val{font-weight:800;font-size:clamp(2rem,4vw,2.9rem);color:var(--nms-navy);line-height:1;letter-spacing:-.025em}
.stat .lbl{margin-top:.5rem;font-size:.92rem;color:var(--nms-text-2)}
.section-navy .stat{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
.section-navy .stat .val{color:var(--nms-yellow)}
.section-navy .stat .lbl{color:rgba(243,241,234,.7)}

.faq-list{max-width:820px;margin:0 auto;display:grid;gap:.75rem}
.faq-item{border:1px solid var(--nms-line);background:#fff;border-radius:var(--nms-radius);overflow:hidden;transition:border-color .2s, box-shadow .2s}
.faq-item[open]{border-color:var(--nms-line-2);box-shadow:var(--nms-shadow-sm)}
.faq-item summary{list-style:none;padding:1.2rem 1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:1rem;font-weight:600;color:var(--nms-navy);letter-spacing:-.005em}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .plus{width:28px;height:28px;border-radius:999px;flex-shrink:0;background:var(--nms-cream-2);display:flex;align-items:center;justify-content:center;transition:transform .3s, background .2s;color:var(--nms-navy);font-size:1rem}
.faq-item[open] summary .plus{transform:rotate(45deg);background:var(--nms-yellow)}
.faq-item .a{padding:0 1.4rem 1.3rem;color:var(--nms-text-2);font-size:.95rem;line-height:1.6}

.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}
.video-card{border-radius:var(--nms-radius-lg);overflow:hidden;border:1px solid var(--nms-line);background:#fff;transition:transform .3s var(--ease), box-shadow .3s, border-color .3s}
.video-card:hover{transform:translateY(-4px);box-shadow:var(--nms-shadow-md);border-color:transparent}
.video-thumb{aspect-ratio:16/9;position:relative;background:var(--nms-cream-2);overflow:hidden}
.video-thumb img{width:100%;height:100%;object-fit:cover}
.video-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,41,54,0) 40%,rgba(28,41,54,.55))}
.video-thumb .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:999px;background:rgba(255,255,255,.95);color:var(--nms-navy);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -6px rgba(0,0,0,.3);transition:transform .2s, background .2s;z-index:1}
.video-thumb .play svg{width:22px;height:22px;margin-left:3px}
.video-card:hover .play{transform:translate(-50%,-50%) scale(1.08);background:var(--nms-yellow)}
.video-meta{padding:1.1rem 1.25rem 1.4rem}
.video-meta h3{font-size:1.05rem;margin-bottom:.3rem}
.video-meta p{font-size:.88rem;color:var(--nms-text-3)}

.cta-band{padding:var(--section-y) clamp(1rem,3vw,2.5rem);background:var(--nms-navy);color:#fff;position:relative;overflow:hidden}
/* Round 4 Edit 2: cursor-aware yellow glow. The radial gradient
   center reads --cx/--cy CSS vars set by the [data-cta-glow] handler
   in design.js (same pattern as .v1-cta / .v1-calc). On hover the
   gradient brightens a step. Smoothed cursor displacement: glow
   drifts AWAY from the cursor by ~25% rather than tracking it
   directly — subtle, not showy. */
.cta-band{--cx:80%;--cy:0%}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at var(--cx) var(--cy), rgba(255,204,0,.18), transparent 60%);pointer-events:none;transition:background .35s var(--ease-out)}
.cta-band:hover::before{background:radial-gradient(700px 400px at var(--cx) var(--cy), rgba(255,204,0,.28), transparent 60%)}
@media (prefers-reduced-motion: reduce){
  .cta-band::before,.cta-band:hover::before{background:radial-gradient(700px 400px at 80% 0%, rgba(255,204,0,.18), transparent 60%) !important}
}
.cta-band-inner{display:grid;grid-template-columns:1.2fr auto;align-items:center;gap:2rem;position:relative;z-index:1;max-width:1280px;margin:0 auto}
@media (max-width:800px){.cta-band-inner{grid-template-columns:1fr}}
.cta-band h2{color:#fff;margin-bottom:1rem}
.cta-band p{color:rgba(243,241,234,.7);font-size:1.05rem;max-width:56ch}

.foot{background:var(--nms-navy-deep);color:var(--nms-text-on-navy);padding:var(--section-y) clamp(1rem,3vw,2.5rem) var(--space-xl)}
.foot-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;max-width:1280px;margin:0 auto 3rem}
@media (max-width:900px){.foot-inner{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:560px){.foot-inner{grid-template-columns:1fr}}
.foot-brand .nav-brand img{filter:brightness(0) invert(1)}
.foot-brand p{font-size:.92rem;color:rgba(243,241,234,.65);margin-top:1rem;max-width:42ch;line-height:1.65}
.foot h6{font-size:.72rem;letter-spacing:.2em;color:var(--nms-yellow);margin-bottom:1rem;font-weight:700}
.foot ul{display:grid;gap:.55rem}
.foot ul a{font-size:.92rem;color:rgba(243,241,234,.75);transition:color .2s}
.foot ul a:hover{color:var(--nms-yellow)}
.foot-bottom{max-width:1280px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(243,241,234,.45)}
.foot-bottom a{color:rgba(243,241,234,.75)}
.foot-bottom a:hover{color:var(--nms-yellow)}
.foot-socials{display:flex;gap:.6rem;margin-top:1.25rem}
.foot-socials a{width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:rgba(243,241,234,.7);transition:all .2s}
.foot-socials a:hover{background:var(--nms-yellow);color:var(--nms-navy);border-color:var(--nms-yellow)}
.foot-socials svg{width:18px;height:18px}

/* prose / forms / utilities — Round 6 Edit 3 typography polish.
   The previous .prose was readable but a bit "janky" per audit (uneven
   header rhythm, weak link hover, no lead, generic paragraph color, no
   spacing for embedded media). This pass:
   - bumps body copy to 17px / 1.7 line-height (longer-form readability)
   - first p after page-head becomes a lead (1.2rem, navy-2, dropped weight)
   - h2/h3 get tighter letter-spacing + navy-1 + clearer rhythm
   - links pick up animated underline + yellow hover
   - figure/iframe wrappers reserve aspect-ratio + soft shadow            */
.prose{max-width:780px;margin:0 auto;font-size:17px;line-height:1.7;color:var(--nms-text)}
.prose > p:first-of-type{
  font-size:1.2rem;line-height:1.65;color:var(--nms-text-2);
  font-weight:500;margin-bottom:1.6rem;
}
.prose h2{
  margin-top:2.75rem;margin-bottom:.9rem;
  font-size:clamp(1.4rem,2.4vw,1.65rem);font-weight:700;
  letter-spacing:-.02em;color:var(--nms-navy);line-height:1.25;
}
.prose h3{
  margin-top:2rem;margin-bottom:.55rem;
  font-size:1.15rem;font-weight:700;
  letter-spacing:-.015em;color:var(--nms-navy);line-height:1.3;
}
.prose h2 + p,.prose h3 + p{margin-top:.25rem}
.prose p{margin-bottom:1.1rem;color:var(--nms-text)}
.prose ul{list-style:disc;padding-left:1.4rem;color:var(--nms-text);margin-bottom:1.2rem}
.prose ol{list-style:decimal;padding-left:1.4rem;color:var(--nms-text);margin-bottom:1.2rem}
.prose ol li,.prose ul li{margin-bottom:.45rem;padding-left:.15rem}
.prose ol li::marker,.prose ul li::marker{color:var(--nms-yellow)}
/* Article publish/updated meta (Round 7 Edit 3) */
.article-meta{
  display:inline-block;font-size:.78rem;color:var(--nms-text-3);
  letter-spacing:.04em;font-weight:600;text-transform:uppercase;
  margin-top:.5rem;
}
.prose a{
  color:var(--nms-navy);text-decoration:underline;text-decoration-thickness:1.5px;
  text-underline-offset:3px;border-bottom:none;
  transition:color .18s,text-decoration-color .18s;
}
.prose a:hover{color:var(--nms-yellow);text-decoration-color:var(--nms-yellow)}
.prose blockquote{
  margin:1.75rem 0;padding:1.1rem 1.4rem;
  border-left:4px solid var(--nms-yellow);background:var(--nms-cream-2);
  border-radius:0 var(--nms-radius) var(--nms-radius) 0;
  color:var(--nms-text);font-style:italic;font-size:1.05rem;
}
.prose strong{color:var(--nms-navy);font-weight:700}
.prose-table{width:100%;border-collapse:collapse;margin:1.6rem 0;font-size:.95rem}
.prose-table th,.prose-table td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--nms-line)}
.prose-table th{background:var(--nms-cream-2);font-weight:700;color:var(--nms-navy);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}
.prose-table tr:hover td{background:var(--nms-cream)}

/* Article-embedded YouTube (Round 6 Edit 3 — strategic embeds) */
.prose-embed{
  margin:2rem 0;border-radius:var(--nms-radius-lg);overflow:hidden;
  border:1px solid var(--nms-line);box-shadow:0 14px 40px -28px rgba(28,41,54,.4);
  background:#000;aspect-ratio:16/9;
}
.prose-embed iframe{width:100%;height:100%;display:block;border:0}
.prose-embed-caption{
  font-size:.85rem;color:var(--nms-text-3);margin-top:-1rem;margin-bottom:1.6rem;
  text-align:center;font-style:italic;
}

/* Learning Center children promo cards (Round 6 Edit 3, polished R7 E2) -
   Round 7 Edit 2 fixes:
   - Internal padding bumped (felt cramped) — 2.2rem vertical / 2rem horiz
   - Icon scale up 56→68 with stronger shadow so they feel like
     destinations, not afterthoughts
   - Heading 1.2rem → 1.35rem, tighter to body, body color upgraded
   - Tightened section gaps with explicit margin-top on the cards
     section + .lc-articles-section so the feature cards now sit ~--space-lg
     (40px) from the article grid instead of the previous ~80px gap.    */
.lc-features-section{padding-top:var(--space-lg);padding-bottom:var(--space-lg)}
.lc-articles-section{padding-top:var(--space-lg)}
.lc-children{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);
  margin-bottom:0;
}
@media (max-width:760px){.lc-children{grid-template-columns:1fr;gap:var(--space-sm)}}
.lc-child-card{
  display:flex;align-items:center;gap:1.5rem;
  padding:2.2rem 2rem;border-radius:var(--nms-radius-lg);
  background:#fff;border:1px solid var(--nms-line);text-decoration:none;
  transition:transform .2s,border-color .2s,box-shadow .2s;
  box-shadow:0 1px 0 rgba(28,41,54,.04);
}
@media (max-width:540px){.lc-child-card{padding:1.6rem 1.4rem;gap:1rem}}
.lc-child-card:hover{
  transform:translateY(-3px);border-color:var(--nms-yellow);
  box-shadow:0 18px 44px -22px rgba(28,41,54,.22);
}
.lc-child-icon{
  flex-shrink:0;width:68px;height:68px;border-radius:16px;
  background:var(--grad-gold,linear-gradient(135deg,#ffcc00,#ffb000));
  display:flex;align-items:center;justify-content:center;
  font-size:1.85rem;color:var(--nms-navy);font-weight:700;
  box-shadow:0 6px 16px -8px rgba(255,204,0,.6);
}
.lc-child-body{flex:1;min-width:0}
.lc-child-body h3{
  font-size:1.35rem;font-weight:700;letter-spacing:-.02em;
  color:var(--nms-navy);margin:0 0 .35rem;line-height:1.25;
}
.lc-child-body p{
  font-size:.95rem;color:var(--nms-text-2);margin:0;line-height:1.5;
}
.lc-child-arrow{
  color:var(--nms-navy);font-size:1.5rem;font-weight:700;
  transition:transform .2s;flex-shrink:0;
}
.lc-child-card:hover .lc-child-arrow{transform:translateX(5px);color:var(--nms-yellow)}
.lc-articles-h{
  font-size:clamp(1.5rem,2.5vw,1.85rem);font-weight:700;
  letter-spacing:-.02em;color:var(--nms-navy);
  margin-bottom:var(--space-lg);
}
.form-card{padding:2rem;border-radius:var(--nms-radius-xl);background:#fff;border:1px solid var(--nms-line);box-shadow:var(--nms-shadow-md)}
.form-card h3{font-size:1.4rem;margin-bottom:.3rem}
.form-card .sub{color:var(--nms-text-2);font-size:.92rem;margin-bottom:1.5rem}
.form-row{display:grid;gap:.75rem;margin-bottom:.75rem;grid-template-columns:1fr}
.form-row.two{grid-template-columns:1fr 1fr}
@media (max-width:560px){.form-row.two{grid-template-columns:1fr}}
.field input,.field textarea,.field select{width:100%;background:var(--nms-cream);border:1.5px solid var(--nms-line);border-radius:12px;padding:.85rem 1rem;color:var(--nms-text);font-size:.95rem}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--nms-navy);background:#fff;box-shadow:0 0 0 4px rgba(255,204,0,.18)}
.field label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--nms-text-3);margin-bottom:.4rem}
.form-note{font-size:.72rem;color:var(--nms-text-3);margin-top:.6rem;text-align:center}

.text-center{text-align:center}
.mt-0{margin-top:0}.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-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
.max-600{max-width:600px;margin-left:auto;margin-right:auto}
.max-780{max-width:780px;margin-left:auto;margin-right:auto}
@media (max-width:640px){.hide-sm{display:none}}

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

/* ---------- VIDEO MODAL (Edit 2 — See How Solar Works) ---------- */
.video-modal{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease-out;
}
.video-modal[hidden]{display:none !important}
.video-modal.is-open{opacity:1;pointer-events:auto}
.video-modal-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.85);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.video-modal-card{
  position:relative;width:100%;max-width:1100px;
  border-radius:var(--nms-radius-lg);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  transform:translateY(8px) scale(.985);
  transition:transform .2s ease-out;
}
.video-modal.is-open .video-modal-card{transform:translateY(0) scale(1)}
.video-modal-frame{
  position:relative;width:100%;
  aspect-ratio:16/9;background:#000;
}
.video-modal-frame iframe{width:100%;height:100%;border:0;display:block}
.video-modal-close{
  position:absolute;top:.85rem;right:.85rem;z-index:2;
  width:36px;height:36px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.55);color:#fff;
  border:1px solid rgba(255,255,255,.18);
  transition:background .2s,transform .2s;
}
.video-modal-close:hover,.video-modal-close:focus-visible{
  background:rgba(0,0,0,.75);transform:scale(1.06);outline:none;
}
body.video-modal-open{overflow:hidden}
@media (max-width:640px){
  .video-modal{padding:1rem}
  .video-modal-close{top:.5rem;right:.5rem;width:32px;height:32px}
}

/* ---------- GBP REVIEWS (Edit 3 — Google Reviews scaffolding) -------
   Real review data ported from the live old site (currently rendered
   as a static dataset). Component structure mirrors a Google Place
   Details payload so a real fetch() can swap in once a Place ID +
   API key land. Avatars are deterministic CSS initials — no fake
   profile photos. */
.gbp-reviews{padding:6rem clamp(1rem,3vw,2.5rem);background:#fff}
.gbp-reviews > .container{max-width:1280px}
.gbp-head{text-align:center;max-width:760px;margin:0 auto 3rem}
.gbp-head h2{margin-top:.6rem;font-size:clamp(2rem,3.4vw,2.9rem);font-weight:800;letter-spacing:-.025em}
.gbp-aggregate{display:inline-flex;align-items:center;gap:.85rem;flex-wrap:wrap;justify-content:center;margin-top:1.5rem;padding:.85rem 1.25rem;border:1px solid var(--nms-line);border-radius:var(--nms-radius);background:var(--nms-cream);box-shadow:var(--nms-shadow-sm)}
.gbp-aggregate-stars{color:var(--nms-yellow);font-size:1.25rem;letter-spacing:.05em;line-height:1}
.gbp-aggregate-meta{font-size:.92rem;color:var(--nms-text-2)}
.gbp-aggregate-meta strong{color:var(--nms-navy);font-weight:700}
.gbp-google-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--nms-navy);border-left:1px solid var(--nms-line-2);padding-left:.85rem;text-decoration:none;transition:color .2s}
.gbp-google-link:hover{color:var(--nms-orange,#1a73e8)}
.gbp-google-link .g-mark{display:inline-flex;width:18px;height:18px;flex-shrink:0}
@media (max-width:560px){.gbp-google-link{border-left:0;padding-left:0;border-top:1px solid var(--nms-line-2);padding-top:.6rem;margin-top:.4rem}}

.gbp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-top:.5rem}
@media (max-width:980px){.gbp-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.gbp-grid{grid-template-columns:1fr}}

.gbp-card{
  position:relative;
  background:#fff;border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg);
  padding:1.5rem 1.5rem 1.6rem;
  display:flex;flex-direction:column;gap:.9rem;
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.gbp-card:hover{transform:translateY(-3px);box-shadow:var(--nms-shadow-md);border-color:transparent}
.gbp-card-head{display:flex;align-items:center;gap:.85rem}
.gbp-avatar{
  width:44px;height:44px;border-radius:999px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.02em;
  background:var(--nms-navy);
}
.gbp-avatar[data-color="navy"]{background:#1c2936}
.gbp-avatar[data-color="navy-2"]{background:#243446}
.gbp-avatar[data-color="teal"]{background:#1cb5bd}
.gbp-avatar[data-color="teal-2"]{background:#159ba2}
.gbp-avatar[data-color="orange"]{background:#ff6900}
.gbp-avatar[data-color="orange-2"]{background:#e65a00}
.gbp-who{display:flex;flex-direction:column;gap:.15rem;min-width:0}
.gbp-name{font-weight:700;color:var(--nms-navy);font-size:.95rem;letter-spacing:-.005em}
.gbp-meta{display:flex;align-items:center;gap:.6rem;font-size:.78rem;color:var(--nms-text-3)}
.gbp-meta .gbp-stars{color:var(--nms-yellow);letter-spacing:.04em;line-height:1}
.gbp-meta .gbp-date::before{content:"·";margin-right:.5rem;color:var(--nms-text-3)}
.gbp-text{color:var(--nms-text);font-size:.95rem;line-height:1.6;margin:0;
  display:-webkit-box;-webkit-line-clamp:7;line-clamp:7;-webkit-box-orient:vertical;overflow:hidden;
}

.gbp-foot{text-align:center;margin-top:2.5rem}

/* ---------- IMAGE SLOTS (Edit 5 — placeholders for Blaine's real PNGs)
   Two reserved slots on the homepage at /assets/img/home/replacements/.
   Modern treatment per the brief — 12px radius, subtle shadow, hover
   scale 1.02 over 200ms. Empty placeholder rendering: solid cream
   backstop (no broken-image icon) + a faint dashed outline so the
   slot reads as intentional. */
.image-slot-section{padding:5rem clamp(1rem,3vw,2.5rem);background:var(--nms-cream)}
.image-slot-section > .container{max-width:1280px}
.image-slot-section .section-head{text-align:center;max-width:680px;margin:0 auto 2.5rem}
.image-slot-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media (max-width:760px){.image-slot-grid{grid-template-columns:1fr}}
.image-slot{
  position:relative;display:block;
  aspect-ratio:16/10;
  border-radius:12px;overflow:hidden;
  background:#f3f1ea;
  box-shadow:0 6px 16px -6px rgba(28,41,54,.12), 0 20px 40px -20px rgba(28,41,54,.18);
  outline:1px dashed rgba(28,41,54,.18);outline-offset:-1px;
  transition:transform .2s var(--ease), box-shadow .2s;
}
.image-slot:hover{transform:scale(1.02);box-shadow:var(--nms-shadow-lg)}
.image-slot img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- "COME SEE THE DIFFERENCE" (Edit 6) -------------------
   - Stagger entry: cards fade-up with 0/150/300ms delays via the
     existing nms-reveal handler (--delay var, IntersectionObserver).
     Override the global 800ms duration to 400ms ease-out per the brief.
   - Icon scale-bounce: after the card lands (entry done, ~+450ms),
     the icon does 0.85 → 1.05 → 1.0 over 600ms.
   - Ambient solar bg: a faint yellow radial sun-pulse breathing
     scale 1.0 → 1.08 over 8s loop in the section background.
   All CSS-only. prefers-reduced-motion zeros it out. */
.difference-section{position:relative;overflow:hidden;isolation:isolate}
.difference-section::before{
  content:"";
  position:absolute;
  top:-15%;right:-10%;
  width:60vw;height:60vw;max-width:900px;max-height:900px;
  background:radial-gradient(circle, rgba(255,193,7,.08) 0%, rgba(255,193,7,.04) 35%, transparent 65%);
  border-radius:999px;
  pointer-events:none;z-index:-1;
  animation:diff-sun-breathe 8s ease-in-out infinite;
  transform-origin:center;
}
.difference-section::after{
  content:"";
  position:absolute;
  bottom:-20%;left:-15%;
  width:50vw;height:50vw;max-width:700px;max-height:700px;
  background:radial-gradient(circle, rgba(255,204,0,.06) 0%, rgba(255,204,0,.02) 40%, transparent 70%);
  border-radius:999px;
  pointer-events:none;z-index:-1;
  animation:diff-sun-breathe 10s ease-in-out infinite reverse;
  transform-origin:center;
}
@keyframes diff-sun-breathe{
  0%,100%{transform:scale(1);opacity:.9}
  50%{transform:scale(1.08);opacity:1}
}

/* Entry: tighter 400ms vs the global 800ms reveal */
.difference-section .nms-reveal{
  transition:opacity .4s var(--ease-out), transform .4s var(--ease-out);
}

/* Icon bounce — kicks off as the card lands. The card's transition-delay
   (set via --delay on each card) staggers the entry; the icon animation
   itself uses a fixed 450ms delay-from-card-land to fire after the fade-up
   completes (.4s entry + ~50ms breathing room). */
.difference-section .difference-card.is-in .icon{
  animation:diff-icon-pop .6s cubic-bezier(.34,1.56,.64,1) var(--icon-delay,450ms) backwards;
}
.difference-section .difference-card:nth-child(1){--icon-delay:450ms}
.difference-section .difference-card:nth-child(2){--icon-delay:600ms}
.difference-section .difference-card:nth-child(3){--icon-delay:750ms}
@keyframes diff-icon-pop{
  0%{transform:scale(.85);opacity:.6}
  60%{transform:scale(1.05);opacity:1}
  100%{transform:scale(1);opacity:1}
}

/* Reduced-motion: kill the bg pulse + icon bounce entirely. The
   global media query at the bottom of this file already neutralizes
   .nms-reveal; this just covers the new keyframes. */
@media (prefers-reduced-motion: reduce){
  .difference-section::before,
  .difference-section::after{animation:none !important;opacity:0 !important}
  .difference-section .difference-card .icon{animation:none !important}
}

/* ---------- OFFICE MAP (Round 4 Edit 3 — global pre-footer) ----------
   Sits above the footer on every page. Two-column on desktop (info
   left, iframe right), stacks on mobile. .section-tight handles the
   vertical rhythm via the new spacing-token system. */
.office-map-section{background:var(--nms-cream)}
.office-map-grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:var(--space-xl);align-items:center}
@media (max-width:880px){.office-map-grid{grid-template-columns:1fr;gap:var(--space-lg)}}
.office-map-info{padding-right:var(--space-md)}
.office-map-title{font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:800;letter-spacing:-.02em;margin-top:.6rem;margin-bottom:1.25rem}
.office-map-addr{font-size:1.05rem;line-height:1.65;color:var(--nms-text);font-weight:500;margin-bottom:1.25rem}
.office-map-meta{margin-bottom:1.5rem}
.office-map-phone{display:inline-flex;align-items:center;gap:.5rem;font-size:1.02rem;font-weight:700;color:var(--nms-navy);text-decoration:none;letter-spacing:-.005em}
.office-map-phone:hover{color:var(--nms-navy-2)}
.office-map-cta{padding:.95rem 1.5rem;font-size:.95rem}
.office-map-frame{position:relative;border-radius:12px;overflow:hidden;box-shadow:var(--nms-shadow-md);border:1px solid var(--nms-line);background:var(--nms-cream-2)}
.office-map-frame iframe{display:block;width:100%;height:400px;border:0}
@media (max-width:880px){.office-map-frame iframe{height:320px}}

/* ---------- ABOUT PAGE (Round 5 Edit 1) ----------------------------- */
/* Story prose breathing room — paragraphs were rendering nearly flush. */
.about-story-prose p{margin-bottom:var(--space-md);line-height:1.7}
.about-story-prose p:last-child{margin-bottom:0}
/* Vimeo embed — 16:9, max-width caps so it doesn't dominate the column. */
.about-story-video{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;box-shadow:var(--nms-shadow-lg);background:#000;max-width:560px;margin:0 auto}
.about-story-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.about-story-caption{margin:.85rem auto 0;max-width:560px;font-size:.85rem;color:var(--nms-text-3);text-align:center;letter-spacing:.04em}

/* Team 2+3 layout — top row is Dominic+Greg featured (larger), bottom
   row is the other 3. Cards in the top row get extra padding + a
   slightly bigger photo aspect to read as the leadership card. */
.team-row{display:grid;gap:var(--space-md)}
.team-row-top{grid-template-columns:1fr 1fr;max-width:880px;margin:0 auto}
.team-row-bottom{grid-template-columns:repeat(3,1fr);margin-top:var(--space-lg)}
@media (max-width:760px){
  .team-row-top,.team-row-bottom{grid-template-columns:1fr}
}
@media (min-width:761px) and (max-width:980px){
  .team-row-bottom{grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}
}
.team-card-feature .team-photo{aspect-ratio:5/4}
.team-card-feature .team-meta{padding:1.5rem 1.5rem 1.75rem}
.team-card-feature .team-meta p{font-size:.95rem;line-height:1.6}

/* Careers form — inherits .form-card baseline, adds resume file styling. */
.careers-form input[type="file"]{padding:.7rem 1rem;cursor:pointer;font-size:.85rem}
.careers-form input[type="file"]::file-selector-button{
  margin-right:.85rem;padding:.5rem .9rem;border:1px solid var(--nms-line-2);
  border-radius:8px;background:var(--nms-cream-2);color:var(--nms-navy);
  font-weight:600;cursor:pointer;font-size:.82rem;
}
.careers-form input[type="file"]::file-selector-button:hover{background:var(--nms-yellow);border-color:var(--nms-yellow)}
.careers-form select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%231c2936' stroke-width='2'><path d='M1 1l5 5 5-5'/></svg>");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px;padding-right:2.5rem}

/* ---------- PRODUCTS PAGE (Round 5 Edits 2 + 3) ---------- */
/* Card grid spacing — bumped via tokens. */
.products-card-grid{gap:var(--space-md)}
.products-financing,.products-videos{padding-top:var(--section-y);padding-bottom:var(--section-y)}

/* Vimeo financing-video grid */
.products-video-grid{gap:var(--space-md)}
@media (max-width:760px){.products-video-grid{grid-template-columns:1fr}}
.product-video-card{margin:0;display:flex;flex-direction:column;background:#fff;border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg);overflow:hidden;transition:transform .35s var(--ease), box-shadow .35s, border-color .35s}
.product-video-card:hover{transform:translateY(-4px);box-shadow:var(--nms-shadow-md);border-color:transparent}
.product-video-frame{position:relative;aspect-ratio:16/9;background:#000}
.product-video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.product-video-card figcaption{padding:1.1rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:.3rem}
.product-video-card figcaption strong{color:var(--nms-navy);font-size:1.05rem;font-weight:700;letter-spacing:-.005em}
.product-video-card figcaption span{color:var(--nms-text-2);font-size:.88rem;line-height:1.5}

/* ---------- Round 5 Edit 3: Products card animations ---------- */
/* Entry: fade-up + scale 0.95→1.0 over 500ms ease-out, 100ms stagger.
   Honored via the existing data-reveal IntersectionObserver handler —
   we just override the transform on .product-card. */
.product-card{transition:transform .25s var(--ease),box-shadow .25s,border-color .25s,filter .25s;position:relative;overflow:hidden;isolation:isolate}
.product-card[data-reveal]{opacity:0;transform:translateY(24px) scale(.95);transition:opacity .5s var(--ease-out), transform .5s var(--ease-out)}
.product-card[data-reveal].is-in{opacity:1;transform:none}

/* Hover: scale 1.02 + soft yellow glow ring + cursor-following light.
   The existing pointer handler on .feature-card already sets --mx/--my
   on the element on pointermove, so the ::before radial-gradient
   tracks the cursor for free. */
.product-card::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(280px 200px at var(--mx,50%) var(--my,50%), rgba(255,193,7,.18), rgba(255,193,7,.04) 35%, transparent 65%);
  opacity:0;transition:opacity .25s var(--ease);
}
.product-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px -8px rgba(28,41,54,.18), 0 0 0 1px rgba(255,193,7,.35), 0 0 28px rgba(255,193,7,.18)}
.product-card:hover::before{opacity:1}

/* Reduced motion: kill all the new motion. Existing transitions still
   work for state but no transforms / cursor-light. */
@media (prefers-reduced-motion: reduce){
  .product-card{transition:none}
  .product-card[data-reveal]{opacity:1;transform:none}
  .product-card:hover{transform:none;box-shadow:var(--nms-shadow-md)}
  .product-card::before{display:none}
}

/* ---------- LOCATIONS PAGE — Other NMS service areas (Round 5 Edit 4) ---- */
.other-locations{padding:var(--section-y) clamp(1rem,3vw,2.5rem)}
.other-locations .section-head{text-align:center;max-width:680px;margin:0 auto var(--space-xl)}
.other-locations-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--space-sm);max-width:1080px;margin:0 auto;padding:0;list-style:none;
}
.other-locations-grid li a{
  display:block;padding:.85rem 1rem;
  background:#fff;border:1px solid var(--nms-line);border-radius:var(--nms-radius);
  font-weight:600;font-size:.92rem;color:var(--nms-navy);
  text-decoration:none;letter-spacing:-.005em;
  transition:border-color .2s,background .2s,transform .2s;
}
.other-locations-grid li a:hover{border-color:var(--nms-yellow);background:var(--nms-cream-2);transform:translateY(-2px)}

/* ---------- CONTACT PAGE (Round 6 Edit 1) ---------------------------------
   Two-column layout: form on the left, address/map sidebar on the right.
   Suppresses the global pre-footer office map (rendered inside foot()) by
   passing show_office_map=False, so this featured map is the page's only
   map instance.

   Form contrast pass — Round 5 audit flagged the previous quote form's input
   borders + label color as 5C/3:1. Tokens used here put input borders at
   #6b7785 (>=4.5:1 on cream) and active-state at the yellow accent.       */
.contact-section{padding:var(--space-2xl) 0 var(--space-3xl)}
.contact-grid{
  display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);
  gap:clamp(1.5rem,3.5vw,3rem);align-items:start;
}
@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr;gap:var(--space-xl)}
}
.contact-form-col{min-width:0}
.contact-h2{
  font-size:clamp(1.6rem,2.4vw,2rem);font-weight:700;
  letter-spacing:-.015em;color:var(--nms-navy);
  margin-bottom:var(--space-xs);
}
.contact-sub{color:var(--nms-text-3);margin-bottom:var(--space-lg);font-size:1rem}

.contact-form{
  background:#fff;border:1px solid var(--nms-line);
  border-radius:var(--nms-radius-lg);padding:clamp(1.4rem,2.5vw,2rem);
  box-shadow:0 14px 40px -28px rgba(28,41,54,.25);
}
.contact-row{display:grid;gap:1rem;margin-bottom:1rem}
.contact-row.two{grid-template-columns:1fr 1fr}
@media (max-width:540px){.contact-row.two{grid-template-columns:1fr}}
.contact-form .field{position:relative}
.contact-form .field input,
.contact-form .field textarea,
.contact-form .field select{
  width:100%;padding:1.1rem 1rem .55rem;
  background:#fff;color:var(--nms-navy);
  border:1.5px solid #6b7785;border-radius:var(--nms-radius);
  font:inherit;font-size:1rem;letter-spacing:-.005em;
  transition:border-color .18s,box-shadow .18s;
  appearance:none;-webkit-appearance:none;
}
.contact-form .field textarea{padding-top:1.4rem;min-height:128px;resize:vertical}
.contact-form .field input:hover,
.contact-form .field textarea:hover,
.contact-form .field select:hover{border-color:var(--nms-navy)}
.contact-form .field input:focus,
.contact-form .field textarea:focus,
.contact-form .field select:focus{
  outline:none;border-color:var(--nms-yellow);
  box-shadow:0 0 0 3px rgba(255,204,0,.28);
}
.contact-form .field label{
  position:absolute;left:1rem;top:1rem;
  color:#5b6470;font-size:1rem;
  transition:top .18s,font-size .18s,color .18s;
  pointer-events:none;background:#fff;padding:0 .25rem;
}
.contact-form .field input:not(:placeholder-shown) + label,
.contact-form .field input:focus + label,
.contact-form .field textarea:not(:placeholder-shown) + label,
.contact-form .field textarea:focus + label,
.contact-form .field.select-field select:valid + label,
.contact-form .field.select-field select:focus + label{
  top:-.55rem;font-size:.72rem;color:var(--nms-navy);font-weight:600;letter-spacing:.04em;
}
/* select chevron */
.contact-form .field.select-field{position:relative}
.contact-form .field.select-field::after{
  content:"";position:absolute;right:1rem;top:50%;width:10px;height:10px;
  border-right:2px solid var(--nms-navy);border-bottom:2px solid var(--nms-navy);
  transform:translateY(-65%) rotate(45deg);pointer-events:none;
}
.contact-form .field.select-field select{padding-right:2.5rem}
.contact-submit{
  width:100%;justify-content:center;margin-top:.5rem;
  padding:1rem 1.4rem;font-size:.95rem;
}
.contact-note{
  font-size:.8rem;color:var(--nms-text-3);
  margin-top:.85rem;text-align:center;
}
.contact-note a{color:var(--nms-navy);font-weight:600;text-decoration:underline}

/* Sidebar — address card + featured map */
.contact-side{display:flex;flex-direction:column;gap:var(--space-md);min-width:0}
.contact-card{
  background:linear-gradient(180deg,#fff 0%,var(--nms-cream-2) 100%);
  border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg);
  padding:clamp(1.4rem,2.5vw,1.8rem);
}
.contact-card h3{
  font-size:1.25rem;font-weight:700;letter-spacing:-.015em;
  color:var(--nms-navy);margin-bottom:var(--space-sm);
}
.contact-addr{
  font-size:1rem;line-height:1.55;color:var(--nms-text);
  margin-bottom:var(--space-md);
}
.contact-meta{
  list-style:none;padding:0;margin:0 0 var(--space-md);
  display:flex;flex-direction:column;gap:.65rem;
}
.contact-meta li{
  display:flex;align-items:center;gap:.7rem;
  font-size:.95rem;color:var(--nms-text);
}
.contact-meta li svg{flex-shrink:0;color:var(--nms-navy)}
.contact-meta a{color:var(--nms-navy);font-weight:600;text-decoration:none}
.contact-meta a:hover{text-decoration:underline}
.contact-directions{width:100%;justify-content:center}
.contact-map{
  border-radius:var(--nms-radius-lg);overflow:hidden;
  border:1px solid var(--nms-line);
  box-shadow:0 14px 40px -28px rgba(28,41,54,.25);
  min-height:500px;
}
.contact-map iframe{display:block}
@media (prefers-reduced-motion: reduce){
  .contact-form .field input,
  .contact-form .field textarea,
  .contact-form .field select,
  .contact-form .field label{transition:none}
}

/* ---------- TESTIMONIALS HYBRID PAGE (Round 6 Edit 2) -------------------
   Aggregate stat bar + segmented Google block + Yelp block + submit CTA.
   Reuses existing .t-card / .t-grid scaffolding (already shipped); adds
   .t-aggregate, .t-block, .t-submit + a Yelp-flavored card variant.       */
.t-aggregate{padding:var(--space-2xl) 0 var(--space-xl)}
.t-aggregate-card{
  background:linear-gradient(135deg,#fff 0%,var(--nms-cream-2) 100%);
  border:1px solid var(--nms-line);border-radius:var(--nms-radius-lg);
  padding:clamp(1.5rem,3vw,2.25rem) clamp(1.5rem,3vw,2.5rem);
  display:flex;align-items:center;gap:clamp(1.5rem,3vw,2.5rem);
  flex-wrap:wrap;justify-content:center;
  box-shadow:0 14px 40px -28px rgba(28,41,54,.25);
}
.t-agg-rating{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}
.t-agg-stars{display:inline-flex;gap:.15rem}
.t-agg-stars svg{width:24px;height:24px;fill:var(--nms-yellow)}
.t-agg-num{
  font-size:clamp(2.4rem,5vw,3.4rem);font-weight:800;
  letter-spacing:-.03em;color:var(--nms-navy);line-height:1;
}
.t-agg-lbl{
  font-size:.85rem;color:var(--nms-text-3);
  text-transform:uppercase;letter-spacing:.08em;
  max-width:220px;font-weight:600;
}
.t-agg-divider{
  width:1px;align-self:stretch;background:var(--nms-line);
}
@media (max-width:680px){.t-agg-divider{display:none}}
.t-agg-platforms{display:flex;flex-wrap:wrap;gap:1rem}
.t-agg-platform{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.7rem 1rem;background:#fff;border:1px solid var(--nms-line);
  border-radius:var(--nms-radius);color:var(--nms-navy);
  text-decoration:none;font-size:.9rem;font-weight:600;
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.t-agg-platform:hover{
  transform:translateY(-2px);border-color:var(--nms-yellow);
  box-shadow:0 8px 24px -12px rgba(28,41,54,.2);
}
.t-agg-platform .src-badge{background:transparent;padding:0}
.t-agg-platform .src-badge svg{width:22px;height:22px}
.t-agg-platform strong{color:var(--nms-navy);margin-right:.2rem}

.t-block{padding:var(--space-2xl) 0}
.t-block-alt{background:var(--nms-cream-2)}
.t-block-head{
  text-align:center;max-width:680px;margin:0 auto var(--space-xl);
}
.t-block-head h2{
  font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;
  letter-spacing:-.02em;color:var(--nms-navy);margin-bottom:var(--space-xs);
}
.t-block-head p{color:var(--nms-text-3);font-size:1rem}
.t-block-cta{text-align:center;margin-top:var(--space-xl)}

/* Yelp flavor — slightly different border accent so the block reads as Yelp */
.t-card-yelp .src-badge.yelp{color:#af0606}
.t-card-yelp{border-top:3px solid #af0606}

/* Submit-your-own card */
.t-submit{padding:var(--space-2xl) 0 var(--space-3xl)}
.t-submit-card{
  background:var(--nms-navy);color:#fff;
  border-radius:var(--nms-radius-lg);
  padding:clamp(2rem,4vw,3rem);
  text-align:center;
  background-image:radial-gradient(circle at 80% 20%,rgba(255,204,0,.18) 0%,transparent 60%);
}
.t-submit-card h2{
  font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;
  letter-spacing:-.02em;margin-bottom:var(--space-sm);color:#fff;
}
.t-submit-card p{
  color:rgba(255,255,255,.78);font-size:1.05rem;
  max-width:540px;margin:0 auto var(--space-lg);
}
.t-submit-actions{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
}
.t-submit-actions .nms-btn-ghost{
  background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4);
}
.t-submit-actions .nms-btn-ghost:hover{
  border-color:#fff;background:rgba(255,255,255,.08);
}

/* Location-page landmark figure (Round 6 Edit 4) ----------------------- */
.loc-landmark{
  max-width:780px;margin:2.5rem auto 0;
  border-radius:var(--nms-radius-lg);overflow:hidden;
  background:#000;
  box-shadow:0 14px 40px -28px rgba(28,41,54,.35);
}
.loc-landmark img{
  width:100%;height:auto;display:block;
  aspect-ratio:16/9;object-fit:cover;
}
.loc-landmark figcaption{
  font-size:.78rem;color:var(--nms-text-3);font-style:italic;
  background:var(--nms-cream-2);padding:.6rem 1rem;border-top:1px solid var(--nms-line);
}
.loc-landmark figcaption code{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:.74rem;
  background:rgba(0,0,0,.04);padding:.05rem .35rem;border-radius:.25rem;
}

/* ---------- LOCATIONS INDEX (Round 7 Edit 1) ----------------------- */
.loc-idx-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:var(--space-md);
}
.loc-idx-card{
  display:flex;flex-direction:column;gap:.5rem;
  padding:1.6rem 1.4rem;border-radius:var(--nms-radius-lg);
  background:#fff;border:1px solid var(--nms-line);
  text-decoration:none;color:var(--nms-navy);
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.loc-idx-card:hover{
  transform:translateY(-3px);border-color:var(--nms-yellow);
  box-shadow:0 14px 40px -22px rgba(28,41,54,.18);
}
.loc-idx-meta{
  display:flex;align-items:center;justify-content:space-between;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
}
.loc-idx-state{color:var(--nms-text-3)}
.loc-idx-sun{color:var(--nms-yellow);background:rgba(255,204,0,.12);padding:.25rem .55rem;border-radius:999px;letter-spacing:.04em}
.loc-idx-card h3{
  font-size:1.35rem;font-weight:700;letter-spacing:-.015em;
  color:var(--nms-navy);margin:.15rem 0 .05rem;
}
.loc-idx-card p{
  font-size:.92rem;color:var(--nms-text-2);line-height:1.5;
  margin-bottom:.3rem;
}
.loc-idx-arrow{
  font-size:.85rem;font-weight:600;color:var(--nms-navy);
  margin-top:auto;
}
.loc-idx-card:hover .loc-idx-arrow{color:var(--nms-yellow)}

/* ---------- INSTALL PHOTO PLACEHOLDER (Round 8 wrap-up) ---------------
   Branded stand-in for spots that will receive real NMS install photos.
   Uses existing design tokens — no new colors / fonts / radii. Drop-in:
   when the real photo arrives, swap the .ipp-placeholder div for a
   plain <img src> at the same parent and the layout stays put.

   Visual language:
   - 1px border at 10% navy (matches site's --nms-line baseline)
   - 14px corner radius (matches --nms-radius)
   - Subtle cream-2 background with a faint diagonal grain so the
     placeholder reads as design-intentional, not "image broken"
   - Camera-line icon above a small uppercase tracked label           */
.ipp-placeholder{
  position:relative;width:100%;display:block;
  background:
    linear-gradient(135deg,var(--nms-cream-2) 0%,#fafaf7 100%);
  border:1px solid var(--nms-line);
  border-radius:var(--nms-radius);
  overflow:hidden;
  box-shadow:0 1px 0 rgba(28,41,54,.03);
}
/* faint repeating diagonal grain — telegraphs "intentional placeholder" */
.ipp-placeholder::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(
    -45deg,
    rgba(28,41,54,.025) 0,
    rgba(28,41,54,.025) 1px,
    transparent 1px,
    transparent 14px);
  border-radius:var(--nms-radius);
}
.ipp-placeholder .ipp-inner{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.85rem;padding:1.25rem;text-align:center;
  color:var(--nms-text-3);
}
.ipp-icon{
  width:38px;height:38px;display:block;
  color:var(--nms-text-3);opacity:.85;
}
.ipp-label{
  font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--nms-text-3);
}
/* tighter type on small placeholders */
.ipp-placeholder[style*="aspect-ratio:1/1"] .ipp-icon,
.ipp-placeholder[style*="aspect-ratio:4/5"] .ipp-icon{
  width:32px;height:32px;
}
.ipp-placeholder[style*="aspect-ratio:1/1"] .ipp-label,
.ipp-placeholder[style*="aspect-ratio:4/5"] .ipp-label{
  font-size:.6rem;letter-spacing:.16em;
}

/* ---------- REAL INSTALL PHOTO (drop-in replacement for .ipp-placeholder)
   Same aspect-ratio container, just renders a real <img> instead of the
   coming-soon graphic. Honors the parent's grid sizing and clips with
   object-fit:cover so portrait/landscape shots all sit cleanly in
   whatever aspect the call-site requested.                              */
.ipp-photo{
  position:relative;width:100%;display:block;margin:0;
  border:1px solid var(--nms-line);
  border-radius:var(--nms-radius);
  overflow:hidden;
  background:var(--nms-cream-2);
  box-shadow:0 1px 0 rgba(28,41,54,.04);
  transition:transform .25s var(--ease),box-shadow .25s;
}
.ipp-photo img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
}
.ipp-photo:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px -16px rgba(28,41,54,.22);
}
@media (prefers-reduced-motion: reduce){
  .ipp-photo{transition:none}
  .ipp-photo:hover{transform:none}
}

/* ---------- HOMEPAGE — SEE OUR WORK SECTION (Round 8) ---------------- */
.our-work-section{padding:var(--section-y) clamp(1rem,3vw,2.5rem)}
.our-work-section .container{max-width:1180px}
.our-work-head{
  text-align:center;max-width:680px;margin:0 auto var(--space-xl);
}
.our-work-head h2{
  font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;
  letter-spacing:-.02em;color:var(--nms-navy);
  margin-bottom:var(--space-xs);
}
.our-work-head p{color:var(--nms-text-2);font-size:1.05rem;line-height:1.55}

.our-work-video-wrap{
  margin:0 auto var(--space-lg);max-width:980px;
  border:1px solid var(--nms-line);border-radius:var(--nms-radius);
  overflow:hidden;
  box-shadow:0 24px 60px -28px rgba(28,41,54,.45),
             0 6px 14px -8px rgba(28,41,54,.18);
  background:#000;
  aspect-ratio:16/9;
}
.our-work-video-wrap iframe{
  width:100%;height:100%;display:block;border:0;
}
.our-work-caption{
  text-align:center;font-size:.72rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--nms-text-3);
  margin:0 auto var(--space-2xl);
}

.our-work-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);
}
@media (max-width:980px){.our-work-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.our-work-grid{grid-template-columns:1fr}}

/* ---------- ABOUT PAGE — INSTALL GALLERY STRIP (Round 8) ----------- */
.install-gallery-section{padding:var(--space-2xl) 0}
.install-gallery-head{
  text-align:center;max-width:600px;margin:0 auto var(--space-lg);
}
.install-gallery-head h2{
  font-size:clamp(1.5rem,2.5vw,1.85rem);font-weight:700;
  letter-spacing:-.02em;color:var(--nms-navy);
  margin-bottom:var(--space-xs);
}
.install-gallery-head p{
  color:var(--nms-text-2);font-size:1rem;line-height:1.55;
}
.install-gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);
  max-width:1080px;margin:0 auto;
}
@media (max-width:760px){.install-gallery-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.install-gallery-grid{grid-template-columns:1fr}}

/* ---------- HIGHLIGHT VARIANT — two side-by-side video cards (Round 8 follow-up) */
.our-work-highlight{padding-top:var(--space-2xl)}
.our-work-videos{
  display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-md);
  margin:0 auto var(--space-xl);max-width:1180px;
}
@media (max-width:880px){.our-work-videos{grid-template-columns:1fr;gap:var(--space-md)}}
.our-work-video-card{
  margin:0;display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--nms-line);
  border-radius:var(--nms-radius);overflow:hidden;
  box-shadow:0 14px 40px -22px rgba(28,41,54,.30);
}
.our-work-video-primary{
  border-color:rgba(255,204,0,.55);
  box-shadow:0 24px 60px -28px rgba(28,41,54,.45),
             0 0 0 2px rgba(255,204,0,.18);
}
.our-work-video-frame{
  position:relative;aspect-ratio:16/9;background:#000;
}
.our-work-video-frame iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;display:block;
}
.our-work-video-card figcaption{
  display:flex;flex-direction:column;gap:.25rem;
  padding:1rem 1.25rem 1.25rem;
}
.our-work-video-tag{
  font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--nms-yellow);
}
.our-work-video-card figcaption strong{
  font-size:1rem;font-weight:700;letter-spacing:-.005em;
  color:var(--nms-navy);
}
.our-work-video-sub{
  font-size:.85rem;color:var(--nms-text-2);line-height:1.45;
}
.our-work-grid-h{
  text-align:center;font-size:.78rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--nms-text-3);
  margin:0 0 var(--space-md);
}
.our-work-grid-6{
  grid-template-columns:repeat(6,1fr);
}
@media (max-width:1080px){.our-work-grid-6{grid-template-columns:repeat(3,1fr)}}
@media (max-width:680px){.our-work-grid-6{grid-template-columns:repeat(2,1fr)}}

/* ---------- INSTALL STRIP — scattered placeholder rows (Round 8 follow-up) */
.install-strip-section{padding:var(--space-2xl) 0}
.install-strip-h{
  text-align:center;font-size:clamp(1.35rem,2.2vw,1.65rem);
  font-weight:700;letter-spacing:-.015em;color:var(--nms-navy);
  margin-bottom:var(--space-lg);
}
.install-strip-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);
  max-width:1180px;margin:0 auto;
}
.install-strip-grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:880px){.install-strip-grid,.install-strip-grid-4{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.install-strip-grid,.install-strip-grid-4{grid-template-columns:1fr}}

/* ---------- SERVICE AREA BAND — California-focused (Round 8 follow-up)
   Replaces the prior 4-column text dump with a stylized SVG map of
   California (27 cities dotted in real geographic positions) plus a
   compact alphabetical CA list and a single inline "also installing in"
   line for FL/OK. Visual centerpiece, much cleaner.                     */
.service-area-band{
  padding:var(--space-2xl) clamp(1rem,3vw,2.5rem) var(--space-xl);
  background:var(--nms-cream-2);
  border-top:1px solid var(--nms-line);
  border-bottom:1px solid var(--nms-line);
}
.service-area-band .container{max-width:1180px}
.service-area-head{
  text-align:center;max-width:720px;margin:0 auto var(--space-xl);
}
.service-area-head h2{
  font-size:clamp(1.6rem,2.8vw,2.1rem);font-weight:700;
  letter-spacing:-.02em;color:var(--nms-navy);
  margin-bottom:var(--space-xs);
}
.service-area-head p{
  font-size:.95rem;color:var(--nms-text-2);line-height:1.55;
}

/* Two-column body: map on the left, alphabetical CA list on the right */
.service-area-body{
  display:grid;grid-template-columns:minmax(0,300px) minmax(0,1fr);
  gap:clamp(1.5rem,3vw,3rem);align-items:start;
  max-width:980px;margin:0 auto;
}
@media (max-width:760px){
  .service-area-body{grid-template-columns:1fr;gap:var(--space-lg)}
}

/* California SVG map */
.ca-map-wrap{margin:0;display:flex;flex-direction:column;align-items:center}
.ca-map{
  width:100%;max-width:260px;height:auto;display:block;
  filter:drop-shadow(0 8px 16px rgba(28,41,54,.08));
}
.ca-outline{
  fill:#fff;
  stroke:var(--nms-navy);stroke-width:1.6;
  stroke-linejoin:round;stroke-linecap:round;
}
.ca-dot circle{
  fill:var(--nms-navy);
  stroke:#fff;stroke-width:1.5;
  transition:fill .15s,r .15s ease-out;
  cursor:pointer;
}
.ca-dot:hover circle,.ca-dot:focus circle{
  fill:var(--nms-yellow);
  r:6;
}
.ca-dot-hq circle{
  fill:var(--nms-yellow);stroke:var(--nms-navy);stroke-width:1.8;
}
.ca-dot-hq:hover circle,.ca-dot-hq:focus circle{r:8}
.ca-map-caption{
  margin-top:.85rem;font-size:.78rem;color:var(--nms-text-3);
  letter-spacing:.04em;display:flex;align-items:center;gap:.45rem;
}
.ca-legend-hq{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  background:var(--nms-yellow);border:1.5px solid var(--nms-navy);
}

/* Alphabetical CA cities list — small, tight, 2 columns */
.ca-cities-panel h3.ca-cities-h{
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--nms-navy);margin:0 0 .85rem;
  padding-bottom:.5rem;border-bottom:1px solid var(--nms-line);
}
.ca-cities-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;
  gap:.4rem .9rem;
}
@media (max-width:480px){.ca-cities-list{grid-template-columns:1fr}}
.ca-cities-list a{
  font-size:.88rem;color:var(--nms-text-2);text-decoration:none;
  display:inline-block;transition:color .15s,transform .15s;
}
.ca-cities-list a:hover{
  color:var(--nms-navy);transform:translateX(2px);
}

/* "Also installing in" — single inline line below, FL/OK */
.other-cities-line{
  margin:var(--space-xl) auto 0;text-align:center;
  font-size:.85rem;color:var(--nms-text-3);line-height:1.7;
  max-width:880px;
}
.other-cities-line strong{
  color:var(--nms-navy);font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;font-size:.72rem;
  margin-right:.25rem;
}
.other-cities-line a{
  color:var(--nms-text-2);text-decoration:none;font-weight:500;
  transition:color .15s;
}
.other-cities-line a:hover{
  color:var(--nms-navy);
  text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:var(--nms-yellow);
}

/* ---------- STEP CIRCLES (Round 8 follow-up) -------------------------
   Replaces inline styles that referenced an undefined --grad-gold (= white
   on white) and an off-brand --nms-orange. Brand-pure palette only:
   yellow + navy. Reusable .step-circle.step-circle-{yellow,navy} so the
   same look ships everywhere these process-step lists appear.            */
.step-circle{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;flex-shrink:0;font-size:1rem;letter-spacing:-.01em;
  box-shadow:0 4px 10px -4px rgba(28,41,54,.25);
}
.step-circle-yellow{
  background:var(--nms-yellow);color:var(--nms-navy);
}
.step-circle-navy{
  background:var(--nms-navy);color:#fff;
}
