
  @font-face { font-family: "Josefin Sans"; src: url("/fonts/josefin-sans.woff2") format("woff2"); font-weight: 100 900; font-display: swap; }

    @font-face { font-family: "Inter"; src: url("/fonts/inter-400.woff2") format("woff2"); font-weight: 400; font-display: swap; }
  @font-face { font-family: "Inter"; src: url("/fonts/inter-500.woff2") format("woff2"); font-weight: 500; font-display: swap; }
  @font-face { font-family: "Inter"; src: url("/fonts/inter-600.woff2") format("woff2"); font-weight: 600; font-display: swap; }
  @font-face { font-family: "Inter"; src: url("/fonts/inter-700.woff2") format("woff2"); font-weight: 700; font-display: swap; }
  @font-face { font-family: "Cormorant Garamond"; src: url("/fonts/cormorant-500.woff2") format("woff2"); font-weight: 500; font-display: swap; }
  @font-face { font-family: "Cormorant Garamond"; src: url("/fonts/cormorant-600.woff2") format("woff2"); font-weight: 600; font-display: swap; }
  @font-face { font-family: "Cormorant Garamond"; src: url("/fonts/cormorant-700.woff2") format("woff2"); font-weight: 700; font-display: swap; }

    
  @font-face { font-family: "Caveat"; src: url("/fonts/caveat-700.woff2") format("woff2"); font-weight: 700; font-display: swap; }
  @font-face { font-family: "Caveat"; src: url("/fonts/caveat-600.woff2") format("woff2"); font-weight: 600; font-display: swap; }
  
  
  

  :root {
    --primary-green: #73B96B;
    --primary-green-hover: #5DA856;
    --secondary-blue: #00384D;
    --secondary-blue-hover: #002a3a;
    --ink: #1F1F1B;
    --ink-soft: #3F3E36;
    --paper: #FFFFFF;
    --paper-deep: #F4F9F1;
    --paper-card: #FFFFFF;
    --green-real: #83C57E;       /* matches the green in the real logo */
    --green-deep: #73B96B;
    --green-darker: #00384D;
    --clay: #73B96B;
    --clay-soft: #D9EAD4;
    --gold: #D89B26;
    --navy: #00384D;
    --rule: rgba(31,31,27,0.16);
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  body { background: var(--paper); color: var(--ink); font-family: "Josefin Sans", "Inter", system-ui, sans-serif; min-height: 100vh; }
  a { color: inherit; }
  .page { background: var(--paper); }

  /* ===== Top banner ===== */
  .banner { background: var(--green-darker); color: var(--paper); font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 500; font-size: 13.5px; letter-spacing: 0.06em; line-height: 1.5; display: flex; align-items: center; justify-content: center; gap: 28px; padding: 13px 24px; white-space: nowrap; }
  .banner-stars { color: #FFD970; letter-spacing: 0.06em; }
  .banner .sep { opacity: 0.45; }
  .banner-strong { font-weight: 700; letter-spacing: 0.06em; }

  /* ===== Header ===== */
  .header { display: flex; align-items: center; justify-content: space-between; padding: 20px max(56px, calc((100% - 1328px) / 2)); border-bottom: 1px solid var(--rule); background: var(--paper); line-height: 1.4; }
  .logo img { height: 78px; width: auto; display: block; }
  .nav { display: flex; gap: 34px; font-weight: 500; font-size: 15px; }
  .nav a { color: var(--ink); text-decoration: none; padding-bottom: 3px; position: relative; }
  .nav a.active:after { content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 2px; background: var(--green-deep); border-radius: 999px; }
  .header-ctas { display: flex; align-items: center; gap: 16px; }
  .header-phone { font-weight: 700; font-size: 17px; color: var(--ink); text-decoration: none; }
.header-btn { background: var(--clay); color: var(--paper); padding: 13px 26px; font-weight: 700; font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none; border-radius: 999px; transition: background 0.2s; }
  .header-btn:hover { background: var(--green-deep); }

  /* ===== Hero - full-bleed photo, light wash overlay (mountain line + lake visible across entire hero) ===== */
  .hero { position: relative; min-height: 540px;
    background-image: url("/source-hero.webp");
    background-size: cover;
    background-position: center 30%;
    overflow: hidden;
  }
  /* Brand-blue wash, same left-heavy fade as the previous cream wash.
     Text side sits on solid brand-blue (matches the banner above), photo opens up on the right. */
  .hero:before {
    content: "";
    position: absolute; inset: 0;
    background:
      linear-gradient(to right,
        rgba(0,56,77,1) 0%,
        rgba(0,56,77,1) 38%,
        rgba(0,56,77,0.96) 50%,
        rgba(0,56,77,0.55) 70%,
        rgba(0,56,77,0.10) 100%),
      linear-gradient(to bottom, rgba(0,56,77,0.10) 0%, rgba(0,56,77,0.04) 60%, rgba(0,56,77,0.28) 100%);
    pointer-events: none;
    z-index: 1;
  }
  .hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr 1fr; gap: 24px; align-items: stretch; min-height: 540px; max-width: 1440px; margin: 0 auto; }

  /* ===== Left column - text content ===== */
  .hero-left { padding: 40px 24px 40px 64px; display: flex; flex-direction: column; justify-content: center; max-width: 720px; }
  .hero-above { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 14px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,254,250,0.85); margin-bottom: 20px; }
  .hero-above .pipe { color: rgba(255,255,255,0.40); margin: 0 12px; }
  h1.hero-eyebrow { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 15px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--green-deep, #73B96B); margin-bottom: 18px; }
  .hero-display-wrap { display: inline-block; max-width: 660px; }
  .hero-display { font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 52px; line-height: 1.05; letter-spacing: -0.01em; color: var(--paper, #FFFEFA); }
  .hero-display .yours-wrap { color: var(--green-deep, #73B96B); position: relative; display: inline-block; }
  .hero-display .yours-underline { position: absolute; left: 0; right: 0; bottom: -6px; width: 100%; height: 14px; }
  .hero-display { margin-top: 4px; }
  .hero-intro { margin-top: 22px; max-width: 560px; }
  .hero-motto { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 18px; line-height: 1.55; letter-spacing: 0; color: rgba(255,254,250,0.92); margin: 0; }
  .hero-intro .hero-subhead { margin: 10px 0 0; }
  .hero-signature-row { display: flex; justify-content: flex-end; margin-top: 18px; max-width: 100%; }
  .hero-signature { font-family: "Caveat", cursive; font-weight: 700; font-size: 32px; line-height: 1.05; color: var(--clay); text-align: right; }
  .hero-signature-credit { display: block; font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 500; font-size: 13px; letter-spacing: 0.10em; color: rgba(255,254,250,0.72); text-transform: uppercase; margin-top: 2px; }
  .hero-subhead { font-size: 18px; line-height: 1.55; color: rgba(255,254,250,0.92); max-width: 580px; margin: 22px 0 22px; font-weight: 400; }
  .hero-bullets { list-style: none; padding: 0; margin: 26px 0 0; display: flex; flex-direction: column; gap: 11px; max-width: 620px; }
  .hero-bullets li { display: flex; align-items: flex-start; gap: 10px; font-size: 16px; line-height: 1.4; color: rgba(255,254,250,0.92); font-weight: 500; }
  .hero-bullets li:before { content: ""; display: inline-block; width: 16px; height: 16px; flex-shrink: 0; margin-top: 3px; background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M8 1 L4 8 L7 8 L6 15 L12 7 L9 7 Z' fill='%23FFFEFA'/></svg>") no-repeat center / contain; }
  .hero-cta-row { display: flex; gap: 14px; margin-top: 26px; }
  .cta-primary { background: var(--clay); color: var(--paper); padding: 19px 34px; font-weight: 700; font-size: 17px; letter-spacing: 0.04em; text-transform: uppercase; text-decoration: none; border-radius: 8px; transition: background 0.2s, transform 0.15s; display: inline-flex; align-items: center; gap: 10px; box-shadow: 0 6px 22px rgba(0,0,0,0.30); }
  .cta-primary:hover { background: var(--green-deep); transform: translateY(-1px); }
  .cta-secondary { background: rgba(255,254,250,0.10); color: var(--paper); padding: 19px 30px; font-weight: 700; font-size: 17px; letter-spacing: 0.04em; text-decoration: none; border: 2px solid rgba(255,254,250,0.85); border-radius: 8px; transition: all 0.2s; display: inline-flex; align-items: center; gap: 8px; backdrop-filter: blur(2px); }
.cta-secondary:hover { background: var(--paper); color: var(--green-darker, #00384D); border-color: var(--paper); }

  /* ===== Right column - brand anchor floats over the photo ===== */
  .hero-right { padding: 28px 56px 28px 24px; display: flex; flex-direction: column; align-items: flex-end; gap: 16px; }
  /* Pills sit at the TOP-LEFT of the anchor area, squared to match review-card / stats-card vocabulary */
  .cred-stack-top { align-self: flex-start; display: flex; flex-direction: column; gap: 10px; }
  .cred-chip { display: inline-flex; align-items: center; gap: 10px; background: var(--paper-card); padding: 12px 16px; border-radius: 8px; font-weight: 700; font-size: 13.5px; letter-spacing: 0.02em; color: var(--ink); box-shadow: 0 6px 18px rgba(31,31,27,0.20); border: 1px solid var(--rule); white-space: nowrap; }
  .cred-chip .icon { width: 24px; height: 24px; border-radius: 5px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 13px; }
  .cred-chip .icon.green { background: var(--green-deep); color: var(--paper); }
  .cred-chip .icon.clay { background: var(--green-deep); color: var(--paper); }
  .cred-chip .icon.gold { background: var(--gold); color: var(--green-darker); }

  /* Stats block - moved up to top-right, alongside pills */
  .hero-stats { position: absolute; top: 36px; right: 56px; background: var(--paper-card, #FFFEFA); color: var(--ink); padding: 16px 20px; border-radius: 8px; display: flex; gap: 24px; box-shadow: 0 12px 28px rgba(0,0,0,0.34); border: 1px solid rgba(255,255,255,0.55); z-index: 3; }
  .hero-stat { text-align: center; }
  .hero-stat .num { font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 38px; line-height: 1; color: var(--green-deep, #73B96B); letter-spacing: -0.01em; }
  .hero-stat .num small { font-size: 16px; vertical-align: super; }
  .hero-stat .lbl { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase; margin-top: 6px; color: var(--ink-soft); }

  /* Review card - bottom right of hero */
  .review-card { background: var(--paper-card); padding: 18px 22px 18px 26px; border-radius: 8px; max-width: 410px; position: relative; box-shadow: 0 14px 32px rgba(31,31,27,0.22); border: 1px solid var(--rule); align-self: flex-end; margin-top: auto; }
  .review-card:before { content: "“"; position: absolute; left: 12px; top: 4px; font-family: "Caveat", cursive; font-weight: 700; font-size: 56px; color: var(--clay); line-height: 1; }
  .review-stars { color: var(--gold); letter-spacing: 0.06em; font-size: 14px; margin-bottom: 5px; padding-left: 26px; }
  .review-quote { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 14.5px; line-height: 1.45; color: var(--ink); margin-bottom: 7px; padding-left: 26px; font-style: italic; }
  .review-meta { font-size: 11.5px; letter-spacing: 0.06em; color: var(--ink-soft); padding-left: 26px; }
  .review-meta .source-pill { background: var(--green-deep); color: var(--paper); padding: 2px 7px; border-radius: 3px; margin-left: 6px; font-weight: 700; letter-spacing: 0.10em; }

  .variant-tag { position: fixed; top: 8px; left: 8px; background: var(--clay); color: var(--paper); font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase; padding: 6px 10px; border-radius: 2px; z-index: 99; font-weight: 700; }

  /* ===== Mobile sticky bottom bar (≤ 768px) ===== */
  .sticky-bar { display: none; }
  @media (max-width: 768px) {
    /* Reserve space so the footer bottom strip (Privacy/Terms/Sitemap + "by Grow Your Trade")
       isn't covered by the sticky CTA bar when the user scrolls to the very bottom. */
    body { padding-bottom: 96px; }
    .sticky-bar {
      display: flex;
      position: fixed;
      left: 0; right: 0; bottom: 0;
      z-index: 50;
      gap: 10px;
      padding: 10px 14px;
      padding-bottom: calc(10px + env(safe-area-inset-bottom));
      background: var(--paper-card);
      border-top: 2px solid var(--green-real);
      box-shadow: 0 -8px 22px rgba(31,31,27,0.18);
      opacity: 0;
      transform: translateY(100%);
      pointer-events: none;
      transition: opacity 0.25s ease, transform 0.25s ease;
    }
    .sticky-bar.is-visible {
      opacity: 1;
      transform: translateY(0);
      pointer-events: auto;
    }
    .sticky-bar__cta {
      flex: 1 1 0;
      min-height: 48px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 14px 12px;
      border-radius: 8px;
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 15px;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      text-decoration: none;
      text-align: center;
      line-height: 1;
      white-space: nowrap;
    }
    .sticky-bar__cta--call {
      background: var(--clay);
      color: var(--paper);
      border: 2px solid var(--clay);
      box-shadow: 0 2px 8px rgba(168,107,64,0.25);
    }
    .sticky-bar__cta--schedule {
      background: var(--paper-card);
      color: var(--ink);
      border: 2px solid var(--ink);
    }
    .sticky-bar__cta:focus-visible {
      outline: 3px solid var(--green-deep);
      outline-offset: 2px;
    }
  }

/* ===== Mobile hero (display below 769px only) ===== */
@media (min-width: 769px) { .m-hero-wrap { display: none !important; } }
@media (max-width: 768px) { .hero, .page > .banner, .page > .header, .page > .hero { display: none !important; } }
.m-hero-wrap { width: 100%; max-width: 100%; background: var(--paper); }

  :root {
    --ink: #1F1F1B;
    --ink-soft: #3F3E36;
    --paper: #FFFFFF;
    --paper-deep: #F4F9F1;
    --paper-card: #FFFFFF;
    --green-real: #83C57E;
    --green-deep: #73B96B;
    --green-darker: #00384D;
    --clay: #73B96B;
    --gold: #D89B26;
    --rule: rgba(31,31,27,0.16);
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  
  

  .m-banner { background: var(--green-darker); color: var(--paper); font-size: 12px; font-weight: 500; letter-spacing: 0.05em; display: flex; align-items: center; justify-content: center; gap: 10px; padding: 8px 10px; white-space: nowrap; }
  .m-banner-stars { color: #FFD970; }
  .m-banner-strong { font-weight: 700; }
  .m-banner .m-sep { opacity: 0.5; }

  .m-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border-bottom: 1px solid var(--rule); }
  .m-logo img { height: 56px; display: block; }
  .m-header-ctas { display: flex; align-items: center; gap: 8px; }
  .m-header-call { background: var(--clay); color: var(--paper); padding: 11px 16px; border-radius: 8px; font-weight: 700; font-size: 13px; letter-spacing: 0.04em; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; }
  .m-header-hamburger { width: 40px; height: 40px; background: var(--ink); color: var(--paper); border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; }
  .m-header-hamburger span { display: block; width: 18px; height: 2px; background: var(--paper); position: relative; }
  .m-header-hamburger span:before, .m-header-hamburger span:after { content: ""; position: absolute; left: 0; width: 18px; height: 2px; background: var(--paper); }
  .m-header-hamburger span:before { top: -6px; }
  .m-header-hamburger span:after { top: 6px; }

  /* ===== Hero core (text content) ===== */
  .m-hero-core { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 14px; background: #00384D; }
  .m-hero-above { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 11.5px; letter-spacing: 0.13em; text-transform: uppercase; color: rgba(255,254,250,0.85); text-align: left; }
  .m-hero-above .m-pipe { color: rgba(255,255,255,0.40); margin: 0 6px; }
  h1.m-hero-eyebrow { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 12px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--green-deep, #73B96B); text-align: left; white-space: nowrap; }
  .m-hero-display-wrap { display: flex; flex-direction: column; align-items: stretch; }
  .m-hero-display { font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 32px; line-height: 1.08; letter-spacing: -0.005em; color: var(--paper, #FFFEFA); text-align: left; }
  .m-hero-display .m-yours-wrap { color: var(--green-deep, #73B96B); position: relative; display: inline-block; }
  .m-hero-display .m-yours-underline { position: absolute; left: 0; right: 0; bottom: -3px; width: 100%; height: 8px; }
  .m-hero-intro { display: flex; flex-direction: column; gap: 10px; }
  .m-hero-motto { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 500; font-size: 16px; line-height: 1.5; letter-spacing: 0; color: rgba(255,254,250,0.92); text-align: left; margin: 0; overflow-wrap: break-word; }
  .m-hero-signature-row { display: flex; justify-content: flex-end; padding-right: 4px; margin-top: 4px; }
  .m-hero-signature { font-family: "Caveat", cursive; font-weight: 700; font-size: 24px; color: var(--clay); text-align: right; line-height: 1.05; }
  .m-hero-signature-credit { display: block; font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 500; font-size: 10px; letter-spacing: 0.10em; color: rgba(255,254,250,0.72); text-transform: uppercase; margin-top: 0; }
  .m-hero-subhead { font-size: 16px; line-height: 1.5; color: rgba(255,254,250,0.92); text-align: left; padding: 0; font-weight: 500; }
  .m-hero-cta-row { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; }
  .m-cta-primary { background: var(--clay); color: var(--paper); padding: 18px 22px; font-weight: 700; font-size: 17px; letter-spacing: 0.04em; text-transform: uppercase; text-decoration: none; border-radius: 8px; text-align: center; display: flex; align-items: center; justify-content: center; gap: 8px; box-shadow: 0 6px 18px rgba(0,0,0,0.34); }
.m-cta-secondary { background: rgba(255,254,250,0.10); color: var(--paper); padding: 16px 22px; font-weight: 700; font-size: 16px; letter-spacing: 0.04em; text-decoration: none; border: 2px solid rgba(255,254,250,0.85); border-radius: 8px; text-align: center; display: block; }

  /* ===== Brand anchor - full-bleed photo with light wash, pills sit on the sky (top-left), stats overlay; review sits BENEATH the image ===== */
  .m-hero-anchor { position: relative; margin-top: 18px; height: 360px;
    background-image: url("/source-hero.webp");
    background-size: cover;
    background-position: center 32%;
    overflow: hidden;
  }
  .m-hero-anchor:before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(
      to bottom,
      rgba(255,255,255,0.25) 0%,
      rgba(255,255,255,0.05) 40%,
      rgba(255,255,255,0.10) 100%
    );
    z-index: 1;
  }
  .m-hero-anchor-inner { position: relative; z-index: 2; padding: 16px 18px; display: flex; flex-direction: column; height: 100%; }
  .m-cred-chips-top { display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
  .m-cred-chip { display: inline-flex; align-items: center; gap: 8px; background: var(--paper-card); padding: 10px 13px; border-radius: 8px; font-weight: 700; font-size: 12.5px; letter-spacing: 0.02em; color: var(--ink); box-shadow: 0 4px 12px rgba(31,31,27,0.20); border: 1px solid var(--rule); white-space: nowrap; }
  .m-cred-chip .m-icon { width: 22px; height: 22px; border-radius: 5px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 11px; }
  .m-cred-chip .m-icon.green { background: var(--green-deep); color: var(--paper); }
  .m-cred-chip .m-icon.clay { background: var(--green-deep); color: var(--paper); }

  .m-hero-stats { margin-top: auto; align-self: flex-end; background: rgba(0,56,77,0.95); color: var(--paper); padding: 10px 14px; border-radius: 10px; display: flex; gap: 14px; box-shadow: 0 8px 18px rgba(0,56,77,0.28); }
  .m-hero-stat { text-align: center; }
  .m-hero-stat .m-num { font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 22px; line-height: 1; color: var(--green-real); }
  .m-hero-stat .m-num small { font-size: 10px; vertical-align: super; }
  .m-hero-stat .m-lbl { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; margin-top: 3px; }

  /* Review BELOW the image */
  .m-review-band { background: var(--paper-deep); padding: 16px 18px; }
  .m-review-card { background: var(--paper-card); padding: 14px 16px 14px 30px; border-radius: 10px; position: relative; box-shadow: 0 8px 18px rgba(31,31,27,0.14); border: 1px solid var(--rule); }
  .m-review-card:before { content: "“"; position: absolute; left: 6px; top: 2px; font-family: "Caveat", cursive; font-weight: 700; font-size: 50px; color: var(--clay); line-height: 1; }
  .m-review-stars { color: var(--gold); font-size: 13px; letter-spacing: 0.05em; margin-bottom: 4px; }
  .m-review-quote { font-size: 14.5px; line-height: 1.45; color: var(--ink); margin-bottom: 6px; font-style: italic; }
  .m-review-meta { font-size: 11px; letter-spacing: 0.06em; color: var(--ink-soft); }
  .m-review-meta .m-source-pill { background: var(--green-deep); color: var(--paper); padding: 2px 6px; border-radius: 2px; margin-left: 4px; font-weight: 700; letter-spacing: 0.10em; }

  /* Bullets below the review */
  .m-hero-bullets-wrap { padding: 20px 18px 28px; background: var(--paper); }
  .m-hero-bullets-title { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--green-darker); text-align: center; margin-bottom: 14px; }
  .m-hero-bullets { list-style: none; padding: 16px 18px; background: var(--paper-deep); border-radius: 10px; display: flex; flex-direction: column; gap: 10px; }
  .m-hero-bullets li { display: flex; align-items: flex-start; gap: 10px; font-size: 14.5px; line-height: 1.4; color: var(--ink); font-weight: 500; }
  .m-hero-bullets li:before { content: ""; display: inline-block; width: 14px; height: 14px; flex-shrink: 0; margin-top: 3px; background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M8 1 L4 8 L7 8 L6 15 L12 7 L9 7 Z' fill='%23A86B40'/></svg>") no-repeat center / contain; }

  

@media (max-width: 768px) {
  .s3-h2-underline, .s3 .s3-emphasis-underline, .s3-underline { display: none !important; }
  /* Hide any clay-coloured stroke SVG inside the s3 H2 */
  .s3-h2 svg { display: none !important; }
}

@media (max-width: 768px) {
  .s5-hammer, .s5-hammer-strip { text-align: left !important; }
  .s5-hammer-list, .s5-hammer-items { flex-direction: column !important; align-items: flex-start !important; gap: 6px !important; }
  .s5-hammer .sep, .s5-hammer-sep { display: none !important; }
}

  /* Single-column Services on mobile */
  .s6-grid, .s6-services-grid, .s6-grid-secondary, .s6-grid-bottom {
    grid-template-columns: 1fr !important;
  }
}

/* Areas section - featured Sandpoint card aligns top + bottom with 4-row supporting grid */
.s7-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 22px; align-items: stretch; }
.s7-featured { display: flex; flex-direction: column; height: 100%; }
.s7-right { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; align-content: stretch; }
.s7-city-card { display: flex; flex-direction: column; justify-content: center; }
.s7-state-tag--mt { background: var(--clay) !important; color: var(--paper) !important; }
@media (max-width: 768px) {
  .s7-grid { grid-template-columns: 1fr; }
  .s7-right { grid-template-columns: 1fr 1fr; }
}

/* Mobile: 2-col × 3 rows */
@media (max-width: 768px) {
  .s6-grid, .s6-services-grid, .s6-row-top, .s6-row-bot {
    grid-template-columns: 1fr 1fr !important;
  }
  .s6-card-featured {
    grid-column: 1 / -1 !important;
  }
  
}

@media (max-width: 768px) {
  .s5-eyebrow { font-size: 11.5px !important; letter-spacing: 0.12em !important; white-space: nowrap; }
}

@media (max-width: 768px) {
  .s4-head { display: grid !important; grid-template-columns: 1fr !important; gap: 16px !important; }
  .s4-head-left { grid-row: 1; }
  .s4-badge { grid-row: 2 !important; justify-self: end !important; align-self: auto !important; }
}

/* Photo treatment - all 6 regular cards get a banner image at top */
/* V3.2: removed duplicate left/right padding - relies on .s6-card-inner padding */

.s6-card.residential .s6-card-link, .s6-card.commercial .s6-card-link, .s6-card.generators .s6-card-link,
.s6-card.smart-home .s6-card-link, .s6-card.outdoor .s6-card-link, .s6-card.panel-upgrades .s6-card-link {
  margin-top: auto;
}

/* Mobile: 2-col × 3-row */
@media (max-width: 768px) {
  .s6-row-top, .s6-row-bot { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  .s6-card { min-height: auto; }

  .s6-card.residential .s6-card-body-text, .s6-card.commercial .s6-card-body-text, .s6-card.generators .s6-card-body-text,
  .s6-card.smart-home .s6-card-body-text, .s6-card.outdoor .s6-card-body-text, .s6-card.panel-upgrades .s6-card-body-text {
    font-size: 13px;
  }
  .s6-card.residential .s6-card-link, .s6-card.commercial .s6-card-link, .s6-card.generators .s6-card-link,
  .s6-card.smart-home .s6-card-link, .s6-card.outdoor .s6-card-link, .s6-card.panel-upgrades .s6-card-link {
    font-size: 12px;
  }
}

/* ===== Services cards - clean rebuild (Phase 8.7) ===== */
.s6-row-top, .s6-row-bot {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.s6-card {
  background: var(--paper-card);
  border: 1px solid var(--rule);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 320px;
  padding: 0;
}
.s6-card-photo-img {
  width: 100%;
  margin: 0;
  height: 140px;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
  border-radius: 0;
}
.s6-card-inner {
  padding: 14px 14px 0 14px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 8px;
}
.s6-card .s6-card-head { padding: 0; display: flex; align-items: center; gap: 10px; }
.s6-card .s6-card-head h3 { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 17px; color: var(--ink); line-height: 1.25; }
.s6-card .s6-icon-wrap { width: 28px; height: 28px; background: var(--green-deep); color: var(--paper); border-radius: 6px; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; }
.s6-card .s6-icon-wrap svg { width: 15px; height: 15px; stroke: currentColor; }
.s6-card .s6-card-body-text { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 14px; line-height: 1.5; color: var(--ink-soft); padding: 0; margin: 0; }
.s6-card .s6-card-link { display: inline-flex; align-items: center; gap: 4px; font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 12.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-deep); text-decoration: none; padding: 10px 0 14px; margin-top: auto; white-space: nowrap; }
.s6-card .s6-card-link:hover { color: var(--green-darker); }
.s6-card-inner { padding-bottom: 0; }

/* Mobile: 2-col × 3-row */
@media (max-width: 768px) {
  .s6-row-top, .s6-row-bot { grid-template-columns: 1fr 1fr; gap: 12px; }
  .s6-card { min-height: auto; }
  .s6-card-photo-img { height: 100px; }
  .s6-card-inner { padding: 14px 14px 0; gap: 6px; }
  .s6-card .s6-card-head h3 { font-size: 15px; }
  .s6-card .s6-card-body-text { font-size: 12.5px; }
  .s6-card .s6-card-link { font-size: 11.5px; padding: 10px 14px 16px; }
}

/* Footer link styling - plain text, no green, no underline */
.s10 .s10-list a, .s10-list a, footer .s10-list a {
  color: inherit !important;
  text-decoration: none !important;
}
.s10 .s10-list a:hover, .s10-list a:hover, footer .s10-list a:hover {
  color: var(--paper, #fff) !important;
  text-decoration: none !important;
  opacity: 1;
}

/* Pass 9: Services single-column on mobile (user explicit) */
@media (max-width: 768px) {
  .s6-row-top, .s6-row-bot { grid-template-columns: 1fr !important; gap: 14px !important; }
  .s6-card-featured { grid-column: 1 / -1; }
  .s6-card { min-height: auto !important; }
  .s6-card-photo-img { height: 180px !important; }
  .s6-card-inner { padding: 18px 18px 0 !important; gap: 8px !important; }
  .s6-card .s6-card-head h3 { font-size: 18px !important; }
  .s6-card .s6-card-body-text { font-size: 15px !important; line-height: 1.5 !important; }
  .s6-card .s6-card-link { font-size: 13px !important; padding: 14px 18px 18px !important; }
}

/* V3.2: show/hide helpers */
.show-mobile { display: none; }
@media (max-width: 768px) {
  .show-mobile { display: inline; }
  .hide-mobile { display: none; }
}

/* Pass 9: Mobile menu (functional) */
@media (max-width: 768px) {
  .m-header-hamburger { cursor: pointer; }
  .m-nav-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.40); z-index: 100; }
  .m-nav-overlay.is-open { display: block; }
  .m-nav-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 78%; max-width: 300px; background: #fff; transform: translateX(100%); transition: transform 0.25s ease; z-index: 101; padding: 24px 24px 32px; display: flex; flex-direction: column; gap: 0; box-shadow: -20px 0 50px rgba(0,0,0,0.18); }
  .m-nav-overlay.is-open .m-nav-drawer { transform: translateX(0); }
  .m-nav-drawer-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
  .m-nav-drawer-close { background: none; border: 0; font-size: 28px; line-height: 1; color: var(--ink); cursor: pointer; padding: 4px 8px; }
  .m-nav-drawer a { display: block; padding: 14px 0; font-family: "Josefin Sans", sans-serif; font-weight: 600; font-size: 16px; color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--rule); }
  .m-nav-drawer a:last-child { border-bottom: 0; }
  .m-nav-drawer-cta { background: var(--primary-green, #73B96B); color: #fff !important; text-align: center; border-radius: 8px; margin-top: 18px; padding: 14px 20px !important; border: 0 !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: 0.04em !important; font-size: 14px !important; }
  .m-nav-section-head { font-family: "Josefin Sans", sans-serif; font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); padding: 14px 0 6px; border-bottom: 0 !important; }
}

/* Lucide phone icon (replaces 📞 emoji throughout) */
.icon-phone { display: inline-block; width: 1em; height: 1em; vertical-align: -0.14em; flex-shrink: 0; }
a .icon-phone, button .icon-phone { margin-right: 0.5em; }

  /* All s3-* scoped. Tokens inherit from deploy/index.html :root. */
  .s3 {
    background: var(--paper, #FFFFFF);
    padding: 80px 56px;
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    color: var(--ink, #1F1F1B);
  }
  .s3-inner { max-width: 1240px; margin: 0 auto; }

  .s3-head { max-width: 880px; margin: 0 auto 56px; text-align: center; }
  .s3-eyebrow {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-darker, #00384D);
    margin: 0 0 18px;
  }
  .s3-h2 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -0.005em;
    color: var(--ink, #1F1F1B);
    margin: 0 0 22px;
  }
  .s3-h2 .s3-emph {
    color: var(--green-deep, #73B96B);
    position: relative;
    display: inline-block;
  }
  .s3-emph-underline {
    position: absolute;
    left: 0; right: 0;
    bottom: -6px;
    width: 100%;
    height: 10px;
    pointer-events: none;
  }
  .s3-intro {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.55;
    color: var(--ink-soft, #3F3E36);
    max-width: 620px;
    margin: 0 auto;
  }

  /* ===== 4-card grid ===== */
  .s3-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
  }
  .s3-card {
    position: relative;
    background: var(--paper-card, #FFFFFF);
    border: 1px solid var(--rule, rgba(31,31,27,0.16));
    border-radius: 10px;
    padding: 28px 24px 26px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
  }
  .s3-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(31,31,27,0.08);
  }

  /* Editorial numerals - design specificity */
  .s3-card-num {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-soft, #3F3E36);
    opacity: 0.55;
    margin-bottom: -4px;
  }

  /* Icon square - alternating brand greens + clay accent */
  .s3-icon {
    width: 44px;
    height: 44px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--paper, #FFFFFF);
    flex-shrink: 0;
  }
  .s3-icon svg { width: 22px; height: 22px; display: block; }
  .s3-icon--green-deep   { background: var(--green-deep, #73B96B); }
  .s3-icon--clay         { background: var(--clay, #73B96B); }
  .s3-icon--green-darker { background: var(--green-darker, #00384D); }

  .s3-card-title {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 19px;
    line-height: 1.3;
    letter-spacing: 0.01em;
    color: var(--ink, #1F1F1B);
    margin: 0;
  }
  .s3-card-body {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 15px;
    line-height: 1.5;
    color: var(--ink-soft, #3F3E36);
    margin: 0;
  }

  /* ===== Mobile (≤ 760px): 2×2 grid, tighter padding, smaller H2 ===== */
  @media (max-width: 760px) {
    .s3 { padding: 44px 18px; }
    .s3-head { margin-bottom: 36px; }
    .s3-eyebrow { font-size: 12px; letter-spacing: 0.14em; margin-bottom: 14px; }
    .s3-h2 { font-size: 30px; line-height: 1.05; }
    .s3-emph-underline { bottom: -4px; height: 7px; }
    .s3-intro { font-size: 15px; line-height: 1.55; }
    .s3-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
    .s3-card { padding: 22px 18px 20px; gap: 12px; border-radius: 10px; }
    .s3-icon { width: 38px; height: 38px; border-radius: 7px; }
    .s3-icon svg { width: 19px; height: 19px; }
    .s3-card-num { font-size: 10px; letter-spacing: 0.14em; }
    .s3-card-title { font-size: 17px; line-height: 1.3; }
    .s3-card-body { font-size: 14.5px; line-height: 1.45; }
  }

    /* === Scoped self-hosted fonts (idempotent - also declared at hero) === */
    
    @font-face { font-family: "Caveat"; src: url("/fonts/caveat-700.woff2") format("woff2"); font-weight: 700; font-display: swap; }
    
    
    

    /* === Scope: every selector below is .s4-* === */
    .s4 {
      /* tokens (mirrored from brand-spec; locally redeclared for fragment portability) */
      --s4-ink: #1F1F1B;
      --s4-ink-soft: #3F3E36;
      --s4-paper: #FFFFFF;
      --s4-paper-deep: #F4F9F1;
      --s4-paper-card: #FFFFFF;
      --s4-green-real: #83C57E;
      --s4-green-deep: #73B96B;
      --s4-green-darker: #00384D;
      --s4-clay: #73B96B;
      --s4-gold: #D89B26;
      --s4-rule: rgba(31,31,27,0.16);

      background: var(--s4-paper-deep);
      color: var(--s4-ink);
      font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
      /* straight-band-shift transition INTO Section 4: hairline at the boundary */
      border-top: 1px solid var(--s4-rule);
      padding: 88px 56px 96px;
      position: relative;
    }
    .s4 *, .s4 *::before, .s4 *::after { box-sizing: border-box; }

    .s4-inner { max-width: 1200px; margin: 0 auto; }

    /* ---------- H2 row with right-aligned mini-badge ---------- */
    .s4-head {
      display: grid;
      grid-template-columns: 1fr auto;
      align-items: end;
      gap: 24px;
      margin-bottom: 14px;
    }
    .s4-head-left { min-width: 0; }
    .s4-eyebrow {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 14px;
      line-height: 1.3;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--s4-green-darker);
      margin: 0 0 14px;
    }
    .s4-h2 {
      font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-size: 56px;
      line-height: 1.02;
      letter-spacing: -0.005em;
      color: var(--s4-ink);
      margin: 0;
    }

    /* ---------- Average-rating mini-badge (square stamp variant of .hero-stats) ---------- */
    .s4-badge {
      background: rgba(0,56,77,0.95);
      color: var(--s4-paper);
      padding: 12px 16px;
      border-radius: 8px;
      display: inline-flex;
      align-items: center;
      gap: 12px;
      box-shadow: 0 10px 24px rgba(0,56,77,0.22);
      align-self: end;
    }
    .s4-badge .stars {
      color: var(--s4-green-real);
      letter-spacing: 0.10em;
      font-size: 16px;
      line-height: 1;
    }
    .s4-badge .num {
      font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-size: 28px;
      line-height: 1;
      letter-spacing: -0.01em;
      color: var(--s4-green-real);
    }
    .s4-badge .lbl {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 10.5px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--s4-paper);
      line-height: 1.1;
    }

    /* ---------- Intro line ---------- */
    .s4-intro {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-size: 16px;
      line-height: 1.55;
      color: var(--s4-ink-soft);
      max-width: 680px;
      margin: 0 0 40px;
    }
    .s4-intro strong { color: var(--s4-ink); font-weight: 700; }

    /* ---------- Review grid ---------- */
    .s4-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
    }

    /* ---------- Review card link wrapper ---------- */
    .s4-card-link {
      text-decoration: none;
      color: inherit;
      display: block;
      transition: transform 0.18s ease, box-shadow 0.18s ease;
    }
    .s4-card-link:focus-visible {
      outline: 3px solid var(--s4-green-deep);
      outline-offset: 3px;
      border-radius: 10px;
    }
    .s4-card-link:hover { transform: translateY(-2px); }
    .s4-card-link:hover .s4-card { box-shadow: 0 18px 36px rgba(31,31,27,0.18); }

    /* ---------- Review card (locked .review-card vocabulary, taller & quote-led) ---------- */
    .s4-card {
      background: var(--s4-paper-card);
      padding: 26px 24px 22px 30px;
      border-radius: 8px;
      border: 1px solid var(--s4-rule);
      box-shadow: 0 8px 22px rgba(31,31,27,0.10);
      position: relative;
      height: 100%;
      display: flex;
      flex-direction: column;
      transition: box-shadow 0.18s ease;
    }
    .s4-card::before {
      content: "\201C"; /* left double quotation mark */
      position: absolute;
      left: 14px;
      top: 6px;
      font-family: "Caveat", "Brush Script MT", cursive;
      font-weight: 700;
      font-size: 62px;
      line-height: 1;
      color: var(--s4-clay);
      pointer-events: none;
    }

    .s4-stars {
      color: var(--s4-gold);
      letter-spacing: 0.10em;
      font-size: 15px;
      line-height: 1;
      padding-left: 30px;
      margin-bottom: 12px;
    }
    .s4-quote {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-style: italic;
      font-size: 15.5px;
      line-height: 1.55;
      color: var(--s4-ink);
      padding-left: 30px;
      margin: 0 0 18px;
      flex: 1;
    }
    .s4-meta {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 500;
      font-size: 12.5px;
      letter-spacing: 0.06em;
      color: var(--s4-ink-soft);
      padding-left: 30px;
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px;
      margin: 0;
    }
    .s4-meta-name { font-weight: 700; color: var(--s4-ink); letter-spacing: 0.04em; }
    .s4-source-pill {
      background: var(--s4-green-deep);
      color: var(--s4-paper);
      padding: 2px 8px;
      border-radius: 3px;
      font-weight: 700;
      font-size: 11px;
      letter-spacing: 0.10em;
      text-transform: uppercase;
      margin-left: auto;
    }

    /* ---------- Read-all link ---------- */
    .s4-readall-row { text-align: center; margin-top: 44px; }
    .s4-readall {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 16px;
      letter-spacing: 0.04em;
      color: var(--s4-green-deep);
      text-decoration: none;
      border-bottom: 1.5px solid transparent;
      padding-bottom: 2px;
      transition: border-color 0.15s, color 0.15s;
    }
    .s4-readall:hover { border-bottom-color: var(--s4-green-deep); }
    .s4-readall:focus-visible {
      outline: 3px solid var(--s4-green-deep);
      outline-offset: 4px;
      border-radius: 2px;
    }
    .s4-readall .arrow { display: inline-block; margin-left: 6px; transition: transform 0.18s; }
    .s4-readall:hover .arrow { transform: translateX(3px); }

    /* ============== Tablet ============== */
    @media (max-width: 1024px) {
      .s4 { padding: 56px 32px 60px; }
      .s4-h2 { font-size: 44px; }
      .s4-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
    }

    /* ============== Mobile (≤ 720px) ============== */
    @media (max-width: 720px) {
      .s4 { padding: 42px 18px 48px; }
      .s4-head {
        grid-template-columns: 1fr;
        align-items: start;
        gap: 18px;
        margin-bottom: 14px;
      }
      .s4-eyebrow { font-size: 12px; letter-spacing: 0.14em; margin-bottom: 12px; }
      .s4-h2 { font-size: 30px; line-height: 1.05; letter-spacing: -0.005em; }
      .s4-intro { font-size: 15px; margin-bottom: 28px; }
      .s4-badge {
        justify-self: end;
        padding: 10px 14px;
        gap: 10px;
      }
      .s4-badge .stars { font-size: 14px; }
      .s4-badge .num { font-size: 22px; }
      .s4-badge .lbl { font-size: 9.5px; letter-spacing: 0.12em; }

      .s4-grid { grid-template-columns: 1fr; gap: 14px; }
      .s4-card { padding: 22px 20px 20px 26px; }
      .s4-card::before { font-size: 52px; left: 12px; top: 4px; }
      .s4-stars { font-size: 14px; padding-left: 26px; margin-bottom: 8px; }
      .s4-quote { font-size: 14.5px; line-height: 1.5; padding-left: 26px; margin-bottom: 14px; }
      .s4-meta { font-size: 11.5px; padding-left: 26px; }
      .s4-source-pill { font-size: 10px; padding: 2px 7px; }

      .s4-readall-row { margin-top: 32px; }
      .s4-readall { font-size: 15px; }
    }
  

  /* Section 5 - About Us. Scope: .s5-* */
  .s5 {
    position: relative;
    background: var(--paper);
    color: var(--ink);
  }

  /* === Transition (4 → 5): wash-into-paper-with-photo-strip === */
  .s5-transition {
    position: relative;
    height: 80px;
    width: 100%;
    overflow: hidden;
  }
  .s5-transition__photo {
    position: absolute; inset: 0;
    background-image: url("/source-hero.webp");
    background-size: cover;
    background-position: center 60%;
  }
  .s5-transition__wash {
    position: absolute; inset: 0;
    background:
      linear-gradient(to bottom,
        rgba(244,236,215,0.92) 0%,
        rgba(251,246,233,0.82) 50%,
        rgba(251,246,233,1.00) 100%);
  }

  .s5-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 88px 64px 96px;
  }

  /* === Grid: text + photo === */
  .s5-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 64px;
    align-items: start;
  }

  /* === Text column === */
  .s5-eyebrow {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-darker);
    margin: 0 0 18px;
  }
  .s5-h2 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -0.005em;
    color: var(--ink);
    margin: 0 0 28px;
  }

  .s5-story {
    display: flex;
    flex-direction: column;
    gap: 18px;
    max-width: 640px;
  }
  .s5-story p {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 500;
    font-size: 18px;
    line-height: 1.6;
    color: var(--ink);
    margin: 0;
  }

  .s5-signature-row {
    display: flex;
    justify-content: flex-end;
    margin-top: 28px;
    max-width: 640px;
  }
  .s5-signature {
    font-family: "Caveat", cursive;
    font-weight: 700;
    font-size: 32px;
    line-height: 1.05;
    color: var(--clay);
    text-align: right;
    margin: 0;
  }
  .s5-signature-credit {
    display: block;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.10em;
    color: var(--ink-soft);
    text-transform: uppercase;
    margin-top: 2px;
  }

  /* === Photo column === */
  .s5-photo-col {
    position: relative;
    padding-top: 8px;
  }
  .s5-photo-card {
    position: relative;
    margin: 0;
    aspect-ratio: 3 / 4;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 18px 40px rgba(31,31,27,0.22);
    background: var(--paper-deep);
  }
  .s5-photo-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 28%;
    display: block;
  }
  .s5-photo-tag {
    position: absolute;
    left: 18px;
    bottom: 18px;
    padding: 6px 14px 8px;
    background: rgba(255,255,255,0.92);
    border-radius: 6px;
    font-family: "Caveat", cursive;
    font-weight: 700;
    font-size: 24px;
    line-height: 1;
    color: var(--clay);
    box-shadow: 0 6px 18px rgba(31,31,27,0.18);
  }

  /* === Hammering-home strip === */
  .s5-hammer {
    margin-top: 56px;
    background: var(--green-darker);
    color: var(--paper);
    border-radius: 8px;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 14px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    text-align: center;
    box-shadow: 0 10px 24px rgba(25,78,45,0.22);
  }
  .s5-hammer__dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--green-real);
    margin-right: 4px;
    flex-shrink: 0;
  }
  .s5-hammer__sep {
    color: var(--green-real);
    opacity: 0.85;
  }

  /* === Mobile (≤ 760px) === */
  @media (max-width: 760px) {
    .s5-transition { height: 56px; }
    .s5-inner { padding: 42px 20px 48px; }

    .s5-grid {
      grid-template-columns: 1fr;
      gap: 32px;
    }

    /* Per playbook mobile-stack: design element goes after heading + body.
       We keep eyebrow + H2 first, then photo, then story, then signature.
       To get this order without re-ordering DOM, use flex on the inner. */
    .s5-text { display: contents; }
    .s5-eyebrow { order: 1; margin: 0 0 14px; }
    .s5-h2 {
      order: 2;
      font-size: 30px;
      line-height: 1.05;
      margin: 0 0 8px;
    }
    .s5-photo-col { order: 3; padding-top: 8px; }
    .s5-story { order: 4; gap: 14px; max-width: none; margin-top: 18px; }
    .s5-story p { font-size: 16px; line-height: 1.6; }
    .s5-signature-row { order: 5; margin-top: 22px; max-width: none; }
    .s5-signature { font-size: 22px; }
    .s5-signature-credit { font-size: 12px; }

    .s5-photo-card { max-width: 340px; margin: 0 auto; }
    .s5-photo-tag {
      left: 14px;
      bottom: 14px;
      font-size: 22px;
      padding: 5px 12px 7px;
    }

    .s5-hammer {
      margin-top: 36px;
      padding: 16px 18px;
      font-size: 12.5px;
      letter-spacing: 0.10em;
      gap: 10px;
    }
  }

  /* All s6-* scoped. Tokens inherit from deploy/index.html :root. */
  .s6 {
    background: var(--paper-deep, #F4F9F1);
    border-top: 1px solid var(--rule, rgba(31,31,27,0.16));
    padding: 80px 56px;
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    color: var(--ink, #1F1F1B);
  }
  .s6-inner { max-width: 1240px; margin: 0 auto; }

  .s6-head { max-width: 860px; margin: 0 0 48px; }
  .s6-eyebrow {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-darker, #00384D);
    margin: 0 0 16px;
  }
  .s6-h2 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -0.005em;
    color: var(--ink, #1F1F1B);
    margin: 0 0 18px;
  }
  .s6-intro {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 1.55;
    color: var(--ink-soft, #3F3E36);
    margin: 0;
    max-width: 720px;
  }

  /* ===== Top row: 2fr featured + 3 secondary ===== */
  .s6-row-top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
  }
  /* ===== Bottom row: 3 even secondary ===== */
  .s6-row-bot {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
  }

  /* ===== Featured Alt-Energy card ===== */
  .s6-card-featured {
    background: var(--green-darker, #00384D);
    color: var(--paper, #FFFFFF);
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    grid-row: span 1;
    box-shadow: 0 10px 30px rgba(25,78,45,0.18);
    position: relative;
  }
  .s6-card-featured-photo {
    width: 100%;
    height: 180px;
    background-image: url("/assets/solar-roof.webp");
    background-size: cover;
    background-position: center;
    position: relative;
  }
  .s6-pill {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--clay, #73B96B);
    color: var(--paper, #FFFFFF);
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 999px;
    z-index: 2;
  }
  .s6-card-featured-body {
    padding: 26px 28px 28px;
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .s6-card-featured-head {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 12px;
  }
  .s6-icon-wrap-featured {
    width: 40px;
    height: 40px;
    background: rgba(125,181,98,0.18);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .s6-icon-wrap-featured svg { stroke: var(--green-real, #83C57E); width: 22px; height: 22px; }
  .s6-card-featured h3 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 28px;
    line-height: 1.05;
    letter-spacing: -0.005em;
    color: var(--paper, #FFFFFF);
    margin: 0;
  }
  .s6-card-featured-body p {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 15.5px;
    line-height: 1.55;
    color: rgba(255,255,255,0.92);
    margin: 0 0 18px;
  }
  .s6-tesla-credit {
    color: var(--green-real, #83C57E);
    font-weight: 700;
  }
  .s6-featured-list {
    list-style: none;
    margin: 0 0 22px;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 9px 22px;
  }
  .s6-featured-list li {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 500;
    font-size: 14.5px;
    line-height: 1.4;
    color: var(--paper, #FFFFFF);
    display: flex;
    align-items: flex-start;
    gap: 9px;
  }
  .s6-check {
    color: var(--green-real, #83C57E);
    font-weight: 700;
    flex-shrink: 0;
    font-size: 15px;
    line-height: 1.3;
  }
  .s6-featured-link {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--green-real, #83C57E);
    text-decoration: none;
    margin-top: auto;
    align-self: flex-start;
    border-bottom: 1px solid rgba(125,181,98,0.40);
    padding-bottom: 2px;
    transition: color 0.2s, border-color 0.2s;
  }
  .s6-featured-link:hover { color: var(--paper, #FFFFFF); border-color: var(--paper, #FFFFFF); }

  /* ===== Secondary cards ===== */
  .s6-card {
    background: var(--paper-card, #FFFFFF);
    border: 1px solid var(--rule, rgba(31,31,27,0.16));
    border-radius: 10px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .s6-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(31,31,27,0.08);
  }
  .s6-card.has-photo { padding: 0; overflow: hidden; }
  .s6-card.has-photo .s6-card-photo {
    width: 100%;
    height: 130px;
    background-image: url("/assets/generator.webp");
    background-size: cover;
    background-position: center;
    margin-bottom: 0;
  }
  .s6-card.has-photo .s6-card-body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
  .s6-card-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
  }
  .s6-icon-wrap {
    width: 36px;
    height: 36px;
    background: rgba(44,122,74,0.10);
    border-radius: 7px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .s6-icon-wrap svg { stroke: var(--green-deep, #73B96B); width: 20px; height: 20px; }
  .s6-card h3 {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 20px;
    line-height: 1.25;
    letter-spacing: 0.01em;
    color: var(--ink, #1F1F1B);
    margin: 0;
  }
  .s6-card-body-text {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--ink-soft, #3F3E36);
    margin: 0 0 14px;
  }
  .s6-card-link {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--green-deep, #73B96B);
    text-decoration: none;
    margin-top: auto;
    align-self: flex-start;
    border-bottom: 1px solid transparent;
    padding-bottom: 2px;
    transition: border-color 0.2s;
  }
  .s6-card-link:hover { border-color: var(--green-deep, #73B96B); }

  /* ===== Focus state (universal) ===== */
  .s6 a:focus-visible {
    outline: 3px solid var(--green-deep, #73B96B);
    outline-offset: 2px;
    border-radius: 2px;
  }

  /* ===== Tablet (≤ 1024px) - collapse top row to featured + 1 col + 2 cards, bot row stays 3 ===== */
  @media (max-width: 1024px) {
    .s6 { padding: 48px 28px; }
    .s6-row-top {
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .s6-card-featured { grid-column: 1 / -1; }
    .s6-row-bot {
      grid-template-columns: 1fr 1fr 1fr;
      gap: 16px;
    }
    .s6-h2 { font-size: 42px; }
  }

  /* ===== Mobile (≤ 640px) - 2-col grid; featured spans both ===== */
  @media (max-width: 640px) {
    .s6 { padding: 36px 18px; }
    .s6-head { margin-bottom: 32px; }
    .s6-eyebrow { font-size: 12px; letter-spacing: 0.14em; margin-bottom: 14px; }
    .s6-h2 { font-size: 30px; line-height: 1.05; margin-bottom: 14px; }
    .s6-intro { font-size: 15px; }
    .s6-row-top, .s6-row-bot {
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin-bottom: 12px;
    }
    .s6-row-bot { margin-bottom: 0; }
    .s6-card-featured { grid-column: 1 / -1; }
    .s6-card-featured-photo { height: 150px; }
    .s6-card-featured-body { padding: 22px 22px 24px; }
    .s6-card-featured h3 { font-size: 24px; }
    .s6-card-featured-body p { font-size: 14.5px; margin-bottom: 14px; }
    .s6-featured-list {
      grid-template-columns: 1fr;
      gap: 7px;
      margin-bottom: 18px;
    }
    .s6-featured-list li { font-size: 14px; }
    .s6-card { padding: 18px; }
    .s6-card.has-photo .s6-card-photo { height: 100px; }
    .s6-card.has-photo .s6-card-body { padding: 16px 18px 18px; }
    .s6-card-head { gap: 10px; margin-bottom: 10px; }
    .s6-icon-wrap { width: 32px; height: 32px; }
    .s6-icon-wrap svg { width: 18px; height: 18px; }
    .s6-card h3 { font-size: 17px; }
    .s6-card-body-text { font-size: 13.5px; line-height: 1.5; margin-bottom: 12px; }
    .s6-card-link { font-size: 12px; }
    .s6-pill { font-size: 10px; padding: 3px 9px; top: 12px; left: 12px; }
  }

    .finance-band { background: var(--paper-deep); padding: 12px max(56px, calc((100% - 1328px) / 2)) 80px; }
    .finance-card { background: linear-gradient(135deg, #00384D 0%, #73B96B 100%); color: var(--paper); border-radius: 14px; padding: 36px 40px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; align-items: stretch; box-shadow: 0 18px 40px rgba(0,56,77,0.18); position: relative; overflow: hidden; }
    .finance-card::before { content: ""; position: absolute; right: -50px; bottom: -50px; width: 240px; height: 240px; border-radius: 50%; background: radial-gradient(circle, rgba(131,197,126,0.25) 0%, transparent 70%); pointer-events: none; }
    .finance-eyebrow { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: #D9EAD4; margin-bottom: 10px; position: relative; z-index: 1; }
    .finance-h3 { font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 34px; line-height: 1.05; color: var(--paper); margin-bottom: 12px; position: relative; z-index: 1; }
    .finance-body { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 15.5px; line-height: 1.55; color: rgba(255,255,255,0.92); margin-bottom: 18px; position: relative; z-index: 1; }
    .finance-bullets { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px 22px; position: relative; z-index: 1; }
    .finance-bullets li { display: flex; align-items: flex-start; gap: 8px; font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 500; font-size: 14px; line-height: 1.4; color: rgba(255,255,255,0.92); }
    .finance-bullets li::before { content: "✓"; color: #D9EAD4; font-weight: 700; flex-shrink: 0; }
    .finance-right { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 14px; }
    .finance-partner-card { background: rgba(255,255,255,0.10); border: 1px solid rgba(217,234,212,0.50); border-radius: 10px; padding: 20px; backdrop-filter: blur(6px); flex: 1; }
    .finance-partner-label { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: #D9EAD4; margin-bottom: 6px; }
    .finance-partner-name { font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 400; font-size: 28px; color: var(--paper); margin-bottom: 6px; }
    .finance-partner-meta { font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,0.92); line-height: 1.5; }
    .finance-cta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; background: var(--clay); color: var(--paper); padding: 14px 22px; font-family: "Josefin Sans", "Inter", system-ui, sans-serif; font-weight: 700; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; text-decoration: none; border-radius: 8px; transition: background 0.2s; }
    .finance-cta:hover { background: #5DA856; }
    @media (max-width: 768px) {
      .finance-band { padding: 8px 18px 36px; }
      .finance-card { grid-template-columns: 1fr; padding: 24px 20px; gap: 20px; }
      .finance-h3 { font-size: 24px; }
      .finance-body { font-size: 14.5px; }
      .finance-bullets { grid-template-columns: 1fr; gap: 7px; }
      .finance-partner-name { font-size: 22px; }
      .finance-cta { width: 100%; }
    }
  

    /* === Scoped self-hosted fonts (idempotent - also declared at hero) === */
    
    
    
    

    /* === Scope: every selector below is .s7-* === */
    .s7 {
      /* tokens (mirrored from brand-spec; locally redeclared for fragment portability) */
      --s7-ink: #1F1F1B;
      --s7-ink-soft: #3F3E36;
      --s7-paper: #FFFFFF;
      --s7-paper-deep: #F4F9F1;
      --s7-paper-card: #FFFFFF;
      --s7-green-real: #83C57E;
      --s7-green-deep: #73B96B;
      --s7-green-darker: #00384D;
      --s7-clay: #73B96B;
      --s7-rule: rgba(31,31,27,0.16);

      background: var(--s7-paper);
      color: var(--s7-ink);
      font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
      /* straight-band-shift transition INTO Section 7 (from Section 6 paper-deep) */
      border-top: 1px solid var(--s7-rule);
      padding: 88px 56px 96px;
    }

    .s7-inner { max-width: 1240px; margin: 0 auto; }

    /* === Section head === */
    .s7-head { max-width: 860px; margin: 0 0 44px; }
    .s7-eyebrow {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 14px;
      line-height: 1.3;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--s7-green-darker);
      margin: 0 0 16px;
    }
    .s7-h2 {
      font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-size: 56px;
      line-height: 1.02;
      letter-spacing: -0.005em;
      color: var(--s7-ink);
      margin: 0 0 16px;
    }
    .s7-intro {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-size: 18px;
      line-height: 1.55;
      color: var(--s7-ink-soft);
      margin: 0;
      max-width: 720px;
    }

    /* === Asymmetric split: 1.4fr featured + 1fr right grid === */
    .s7-grid {
      display: grid;
      grid-template-columns: 1.4fr 1fr;
      gap: 24px;
      align-items: stretch;
    }

    /* === Featured Sandpoint card - green-darker ground, full column height === */
    .s7-featured {
      background: var(--s7-green-darker);
      color: var(--s7-paper);
      border-radius: 10px;
      padding: 40px 38px 36px;
      display: flex;
      flex-direction: column;
      position: relative;
      overflow: hidden;
      box-shadow: 0 14px 32px rgba(25,78,45,0.22);
      min-height: 380px;
    }
    /* subtle inset glow at top-right echoing the hero-stats stamp */
    .s7-featured::before {
      content: "";
      position: absolute;
      top: -120px; right: -120px;
      width: 320px; height: 320px;
      background: radial-gradient(circle, rgba(125,181,98,0.18) 0%, rgba(125,181,98,0) 70%);
      pointer-events: none;
    }
    .s7-featured-head {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 18px;
      position: relative;
    }
    .s7-pin {
      width: 22px;
      height: 22px;
      stroke: var(--s7-green-real);
      flex-shrink: 0;
    }
    .s7-featured-label {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 12px;
      line-height: 1.3;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--s7-green-real);
      margin: 0;
    }
    .s7-featured-city {
      font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 400;
      font-size: 64px;
      line-height: 1.0;
      letter-spacing: -0.005em;
      color: var(--s7-paper);
      margin: 0 0 18px;
      position: relative;
    }
    .s7-featured-tagline {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 500;
      font-size: 18px;
      line-height: 1.5;
      color: rgba(255,255,255,0.92);
      margin: 0 0 22px;
      max-width: 460px;
      position: relative;
    }
    .s7-featured-meta {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      position: relative;
    }
    .s7-meta-row {
      display: flex;
      align-items: baseline;
      gap: 12px;
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-size: 14.5px;
      line-height: 1.4;
      color: rgba(251,246,233,0.86);
    }
    .s7-meta-key {
      font-weight: 700;
      font-size: 11.5px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--s7-green-real);
      flex-shrink: 0;
      min-width: 78px;
    }
    .s7-meta-val { color: rgba(255,255,255,0.92); font-weight: 500; }

    /* === Right column: 2×2 grid + Montana strip === */
    .s7-right {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-auto-rows: min-content;
      gap: 12px;
      align-content: start;
    }
    .s7-city-card {
      background: var(--s7-paper-card);
      border: 1px solid var(--s7-rule);
      border-radius: 10px;
      padding: 22px 22px 20px;
      display: flex;
      flex-direction: column;
      gap: 8px;
      transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
    }
    .s7-city-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 10px 22px rgba(31,31,27,0.08);
      border-color: rgba(31,31,27,0.26);
    }
    .s7-city-name {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 20px;
      line-height: 1.25;
      letter-spacing: 0.01em;
      color: var(--s7-ink);
      margin: 0;
    }
    .s7-state-tag {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 11px;
      line-height: 1;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--s7-green-deep);
      align-self: flex-start;
      padding: 4px 8px;
      border: 1px solid rgba(44,122,74,0.30);
      border-radius: 4px;
      background: rgba(44,122,74,0.06);
    }

    /* Montana strip - spans both columns of right grid */
    .s7-montana {
      grid-column: 1 / -1;
      background: var(--s7-paper-card);
      border: 1px solid var(--s7-rule);
      border-radius: 10px;
      padding: 22px 24px 22px;
      display: flex;
      align-items: center;
      gap: 16px;
      transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
      position: relative;
    }
    .s7-montana:hover {
      transform: translateY(-2px);
      box-shadow: 0 10px 22px rgba(31,31,27,0.08);
      border-color: rgba(31,31,27,0.26);
    }
    .s7-montana-icon {
      width: 36px;
      height: 36px;
      background: rgba(44,122,74,0.10);
      border-radius: 8px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .s7-montana-icon svg { stroke: var(--s7-green-deep); width: 20px; height: 20px; }
    .s7-montana-body { display: flex; flex-direction: column; gap: 3px; }
    .s7-montana-title {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 18px;
      line-height: 1.25;
      letter-spacing: 0.01em;
      color: var(--s7-ink);
      margin: 0;
    }
    .s7-montana-meta {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 500;
      font-size: 12.5px;
      line-height: 1.4;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--s7-ink-soft);
      margin: 0;
    }
    .s7-montana-meta strong {
      color: var(--s7-green-deep);
      font-weight: 700;
    }

    /* === "Call us anyway" line === */
    .s7-callout {
      margin: 44px auto 0;
      max-width: 760px;
      text-align: center;
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 500;
      font-size: 17px;
      line-height: 1.55;
      color: var(--s7-ink-soft);
    }
    .s7-callout-phone {
      font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
      font-weight: 700;
      font-size: 17px;
      letter-spacing: 0.01em;
      color: var(--s7-green-deep);
      text-decoration: none;
      border-bottom: 1px solid rgba(44,122,74,0.40);
      padding-bottom: 1px;
      transition: border-color 0.2s, color 0.2s;
      white-space: nowrap;
    }
    .s7-callout-phone:hover {
      color: var(--s7-green-darker);
      border-color: var(--s7-green-darker);
    }

    /* === Focus state (universal) === */
    .s7 a:focus-visible {
      outline: 3px solid var(--s7-green-deep);
      outline-offset: 2px;
      border-radius: 2px;
    }

    /* === Tablet (≤ 1024px) === */
    @media (max-width: 1024px) {
      .s7 { padding: 54px 28px 60px; }
      .s7-grid { grid-template-columns: 1.25fr 1fr; gap: 18px; }
      .s7-featured { padding: 32px 30px 30px; min-height: 320px; }
      .s7-featured-city { font-size: 52px; }
      .s7-featured-tagline { font-size: 16.5px; }
      .s7-h2 { font-size: 44px; }
      .s7-right { gap: 10px; }
      .s7-city-card { padding: 18px 18px 16px; }
      .s7-city-name { font-size: 18px; }
    }

    /* === Mobile (≤ 720px) === */
    @media (max-width: 720px) {
      .s7 { padding: 42px 18px 48px; }
      .s7-head { margin-bottom: 28px; }
      .s7-eyebrow { font-size: 12px; letter-spacing: 0.14em; margin-bottom: 12px; }
      .s7-h2 { font-size: 30px; line-height: 1.05; margin-bottom: 12px; }
      .s7-intro { font-size: 15px; }

      .s7-grid {
        grid-template-columns: 1fr;
        gap: 16px;
      }
      .s7-featured {
        padding: 28px 24px 26px;
        min-height: 0;
      }
      .s7-featured-head { margin-bottom: 14px; }
      .s7-featured-label { font-size: 11px; }
      .s7-pin { width: 20px; height: 20px; }
      .s7-featured-city { font-size: 44px; margin-bottom: 14px; }
      .s7-featured-tagline { font-size: 15px; margin-bottom: 18px; }
      .s7-meta-key { min-width: 70px; font-size: 10.5px; }
      .s7-meta-row { font-size: 13.5px; }

      .s7-right {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
      }
      .s7-city-card { padding: 16px 16px 14px; }
      .s7-city-name { font-size: 16px; }
      .s7-state-tag { font-size: 10px; padding: 3px 7px; }

      .s7-montana { padding: 18px 18px; gap: 12px; }
      .s7-montana-icon { width: 32px; height: 32px; }
      .s7-montana-icon svg { width: 18px; height: 18px; }
      .s7-montana-title { font-size: 16px; }
      .s7-montana-meta { font-size: 11.5px; }

      .s7-callout {
        margin-top: 32px;
        font-size: 15px;
        line-height: 1.5;
      }
      .s7-callout-phone { font-size: 15px; }
    }
  

    .s7b { background: var(--paper, #FFFFFF); padding: 80px max(56px, calc((100% - 1328px) / 2)); font-family: "Josefin Sans", "Inter", system-ui, sans-serif; color: var(--ink, #1F1F1B); }
    .s7b-inner { max-width: 1240px; margin: 0 auto; }
    .s7b-head { text-align: center; max-width: 760px; margin: 0 auto 40px; }
    .s7b-eyebrow { font-weight: 700; font-size: 14px; line-height: 1.3; letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-darker, #00384D); margin: 0 0 14px; }
    .s7b-h2 { font-weight: 400; font-size: 48px; line-height: 1.04; letter-spacing: -0.005em; color: var(--ink); margin: 0 0 16px; }
    .s7b-intro { font-size: 16px; line-height: 1.55; color: var(--ink-soft, #3F3E36); }
    .s7b-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
    .s7b-card { background: var(--paper-card, #FFFFFF); border: 1px solid var(--rule); border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: var(--ink); transition: transform 0.15s, box-shadow 0.2s, border-color 0.15s; }
    .s7b-card:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(31,31,27,0.12); border-color: var(--green-deep, #73B96B); }
    .s7b-card-photo { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; flex-shrink: 0; }
    .s7b-card-body { padding: 18px 20px 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
    .s7b-meta { display: flex; gap: 8px; align-items: center; font-weight: 700; font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-darker, #00384D); }
    .s7b-meta .sep { color: rgba(31,31,27,0.30); }
    .s7b-card h3 { font-weight: 700; font-size: 19px; line-height: 1.25; color: var(--ink); margin: 2px 0 0; }
    .s7b-card p { font-weight: 400; font-size: 14.5px; line-height: 1.55; color: var(--ink-soft); margin: 0; }
    .s7b-footer { text-align: center; margin-top: 36px; }
    .s7b-cta { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 14px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--green-deep, #73B96B); text-decoration: none; padding: 14px 24px; border: 2px solid var(--green-deep, #73B96B); border-radius: 8px; transition: background 0.15s, color 0.15s; }
    .s7b-cta:hover { background: var(--green-deep, #73B96B); color: var(--paper, #FFFFFF); }
    @media (max-width: 1024px) { .s7b-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 768px) {
      .s7b { padding: 44px 18px; }
      .s7b-h2 { font-size: 30px; }
      .s7b-grid { grid-template-columns: 1fr; gap: 14px; }
      .s7b-card-photo { aspect-ratio: 3/2; }
    }
  

  /* All s8-* scoped. Tokens inherit from deploy/index.html :root. */
  .s8 {
    background: var(--paper-deep, #F4F9F1);
    border-top: 1px solid var(--rule, rgba(31,31,27,0.16));
    padding: 80px 56px;
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    color: var(--ink, #1F1F1B);
  }
  .s8-inner { max-width: 1100px; margin: 0 auto; }

  /* ===== Section head - centred over FAQ stack ===== */
  .s8-head { max-width: 840px; margin: 0 auto 44px; text-align: center; }
  .s8-eyebrow {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-darker, #00384D);
    margin: 0 0 14px;
  }
  .s8-h2 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -0.005em;
    color: var(--ink, #1F1F1B);
    margin: 0;
  }

  /* ===== FAQ stack ===== */
  .s8-faq-stack {
    max-width: 880px;
    margin: 0 auto 56px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  /* Native details/summary accordion */
  .s8-faq {
    background: var(--paper-card, #FFFFFF);
    border: 1px solid var(--rule, rgba(31,31,27,0.16));
    border-radius: 8px;
    padding: 0;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
  }
  .s8-faq[open] {
    border-color: rgba(44,122,74,0.32);
    box-shadow: 0 4px 14px rgba(25,78,45,0.08);
  }

  .s8-faq > summary {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    list-style: none;
    cursor: pointer;
    padding: 20px 22px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 17px;
    line-height: 1.4;
    color: var(--ink, #1F1F1B);
    -webkit-tap-highlight-color: transparent;
  }
  .s8-faq > summary::-webkit-details-marker { display: none; }
  .s8-faq > summary::marker { content: ""; }
  .s8-faq > summary:hover .s8-q { color: var(--green-deep, #73B96B); }
  .s8-faq > summary:focus-visible {
    outline: 3px solid var(--green-deep, #73B96B);
    outline-offset: 2px;
  }

  .s8-q { flex: 1; transition: color 0.15s; }

  .s8-toggle {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--green-deep, #73B96B);
    font-family: "Fjalla One", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 26px;
    line-height: 1;
    margin-top: -2px;
    user-select: none;
  }
  .s8-toggle::before { content: "+"; }
  .s8-faq[open] .s8-toggle::before { content: "−"; }

  .s8-a {
    padding: 0 22px 22px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 15px;
    line-height: 1.6;
    color: var(--ink-soft, #3F3E36);
    max-width: 760px;
  }
  .s8-a strong { color: var(--ink, #1F1F1B); font-weight: 500; }

  /* Operator-flag inline note styling - keeps brackets visible to fact-check pass */
  .s8-flag {
    display: block;
    margin-top: 10px;
    font-size: 13.5px;
    font-style: italic;
    color: var(--ink-soft, #3F3E36);
    opacity: 0.8;
  }

  /* ===== Financing block ===== */
  .s8-financing {
    background: var(--paper-card, #FFFFFF);
    border: 1px solid var(--rule, rgba(31,31,27,0.16));
    border-radius: 10px;
    padding: 28px 32px;
    max-width: 1100px;
    margin: 0 auto;
    box-shadow: 0 6px 22px rgba(25,78,45,0.06);
  }
  .s8-financing-eyebrow {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-darker, #00384D);
    margin: 0 0 10px;
  }
  .s8-financing-h3 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 30px;
    line-height: 1.05;
    letter-spacing: -0.005em;
    color: var(--ink, #1F1F1B);
    margin: 0 0 22px;
    max-width: 720px;
  }

  .s8-financing-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 32px;
    margin: 0 0 22px;
    padding: 0;
    list-style: none;
  }
  .s8-financing-grid li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.4;
    color: var(--ink, #1F1F1B);
  }
  .s8-financing-grid li::before {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    margin-top: 3px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M8 1 L4 8 L7 8 L6 15 L12 7 L9 7 Z' fill='%23A86B40'/></svg>") no-repeat center / contain;
  }

  .s8-financing-link {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 15px;
    color: var(--green-deep, #73B96B);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s, color 0.2s;
  }
  .s8-financing-link:hover {
    color: var(--green-darker, #00384D);
    border-bottom-color: var(--green-deep, #73B96B);
  }
  .s8-financing-link:focus-visible {
    outline: 3px solid var(--green-deep, #73B96B);
    outline-offset: 2px;
    border-radius: 2px;
  }
  .s8-financing-link .arrow { font-weight: 400; }

  /* ===== Mobile ===== */
  @media (max-width: 760px) {
    .s8 { padding: 42px 18px; }
    .s8-head { margin-bottom: 32px; }
    .s8-h2 { font-size: 30px; }
    .s8-eyebrow { font-size: 12px; letter-spacing: 0.14em; }

    .s8-faq-stack { gap: 10px; margin-bottom: 40px; }
    .s8-faq > summary { padding: 16px 18px; font-size: 16px; gap: 14px; }
    .s8-toggle { width: 24px; height: 24px; font-size: 22px; }
    .s8-a { padding: 0 18px 18px; font-size: 15px; }
    .s8-flag { font-size: 13px; }

    .s8-financing { padding: 24px 22px; border-radius: 8px; }
    .s8-financing-h3 { font-size: 24px; margin-bottom: 18px; }
    .s8-financing-grid { grid-template-columns: 1fr; gap: 12px; margin-bottom: 18px; }
    .s8-financing-grid li { font-size: 15px; }
    .s8-financing-link { font-size: 14.5px; }
  }

  /* All s9-* scoped. Tokens inherit from deploy/index.html :root. */
  .s9 {
    position: relative;
    background: var(--green-darker, #00384D);
    color: var(--paper, #FFFFFF);
    padding: 96px 56px;
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    text-align: center;
    /* Quiet 1px hairline at the top boundary - the "full-bleed-darker" transition mark.
       --green-real on --green-darker reads as a tonal ledge, not a decorative divider. */
    border-top: 1px solid var(--green-real, #83C57E);
  }

  .s9-inner {
    max-width: 1100px;
    margin: 0 auto;
  }

  .s9-eyebrow {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-real, #83C57E);
    margin: 0 0 18px;
  }

  .s9-h2 {
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -0.005em;
    color: var(--paper, #FFFFFF);
    margin: 0 0 28px;
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
  }

  .s9-trust {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.4;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--paper, #FFFFFF);
    opacity: 0.86;
    margin: 0 0 36px;
  }
  .s9-trust .s9-sep {
    display: inline-block;
    margin: 0 10px;
    opacity: 0.55;
  }

  .s9-cta-row {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 14px;
    margin: 0 0 40px;
    flex-wrap: wrap;
  }

  .s9-cta-primary {
    background: var(--clay, #73B96B);
    color: var(--paper, #FFFFFF);
    padding: 19px 34px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 17px;
    line-height: 1.0;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 8px;
    border: none;
    box-shadow: 0 4px 14px rgba(115,185,107,0.28);
    transition: background 0.2s ease, transform 0.15s ease;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap;
  }
  .s9-cta-primary:hover {
    background: var(--green-real, #83C57E);
    color: var(--green-darker, #00384D);
    transform: translateY(-1px);
  }
  .s9-cta-primary:focus-visible {
    outline: 3px solid var(--paper, #FFFFFF);
    outline-offset: 2px;
  }

  .s9-cta-secondary {
    background: var(--paper, #FFFFFF);
    color: var(--green-darker, #00384D);
    padding: 17px 30px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 17px;
    line-height: 1.0;
    letter-spacing: 0.04em;
    text-decoration: none;
    border: 2px solid var(--paper, #FFFFFF);
    border-radius: 8px;
    transition: background 0.2s ease, color 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
  }
  .s9-cta-secondary:hover {
    background: var(--clay, #73B96B);
    color: var(--paper, #FFFFFF);
    border-color: var(--clay, #73B96B);
  }
  .s9-cta-secondary:focus-visible {
    outline: 3px solid var(--paper, #FFFFFF);
    outline-offset: 2px;
  }

  .s9-signature {
    font-family: "Caveat", "Brush Script MT", cursive;
    font-weight: 700;
    font-size: 32px;
    line-height: 1.05;
    letter-spacing: 0em;
    /* clay-soft (#D9EAD4) - the page's only use of this token.
       On --green-darker ground, clay-soft sits at AA-readable contrast where --clay would muddy. */
    color: var(--clay-soft, #D9EAD4);
    margin: 0;
  }

  /* ===== Mobile (≤ 720px) =====
     56px 18px padding; CTAs stack vertical, primary first;
     H2 30px Fjalla; trust strip 12px tracked. */
  @media (max-width: 720px) {
    .s9 {
      padding: 56px 18px;
    }
    .s9-eyebrow {
      font-size: 12px;
      letter-spacing: 0.14em;
      margin-bottom: 14px;
    }
    .s9-h2 {
      font-size: 30px;
      line-height: 1.05;
      margin-bottom: 22px;
    }
    .s9-trust {
      font-size: 12px;
      letter-spacing: 0.08em;
      margin-bottom: 28px;
      /* let it wrap to 2-3 lines gracefully */
      line-height: 1.6;
    }
    .s9-trust .s9-sep {
      margin: 0 6px;
    }
    .s9-cta-row {
      flex-direction: column;
      align-items: stretch;
      gap: 12px;
      margin-bottom: 32px;
    }
    .s9-cta-primary,
    .s9-cta-secondary {
      width: 100%;
      justify-content: center;
      padding: 18px 22px;
    }
    .s9-cta-secondary {
      padding: 16px 22px;
      font-size: 16px;
    }
    .s9-signature {
      font-size: 26px;
    }
  }

  /* All s10-* scoped. Tokens inherit from deploy/index.html :root. */
  .s10 {
    background: var(--ink, #1F1F1B);
    color: var(--paper, #FFFFFF);
    padding: 64px 56px 36px;
    font-family: "Josefin Sans", "Josefin Sans", "Inter", system-ui, sans-serif;
    /* Transition INTO from §9 (green-darker) - clean band shift; no decorative divider. */
  }
  .s10-inner { max-width: 1240px; margin: 0 auto; }

  .s10-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 40px;
    align-items: start;
  }

  /* ===== Column 1 - Logo + NAP ===== */
  .s10-brand-col { display: flex; flex-direction: column; gap: 18px; }
  .s10-logo-wrap {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 2px solid var(--green-real, #83C57E);
    width: fit-content;
  }
  .s10-logo {
    height: 80px;
    width: auto;
    display: block;
    /* Invert dark-on-light logo to render white on ink ground (footer-only treatment per brief). */
    filter: brightness(0) invert(1);
  }
  .s10-brand-name {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--green-real, #83C57E);
    margin: 0;
  }
  .s10-nap { display: flex; flex-direction: column; gap: 14px; margin: 0; padding: 0; }
  .s10-nap-row { display: flex; flex-direction: column; gap: 2px; }
  .s10-nap-label {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(251,246,233,0.55);
  }
  .s10-nap-value {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 1.55;
    color: rgba(251,246,233,0.85);
  }
  a.s10-nap-link {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 500;
    font-size: 15px;
    line-height: 1.45;
    color: var(--paper, #FFFFFF);
    text-decoration: none;
    transition: color 0.15s, text-decoration 0.15s;
  }
  a.s10-nap-link:hover { text-decoration: underline; text-underline-offset: 3px; color: var(--green-real, #83C57E); }
  a.s10-nap-link:focus-visible { outline: 3px solid var(--green-real, #83C57E); outline-offset: 2px; border-radius: 2px; }
  .s10-address-line { display: block; }

  /* ===== Shared column header + lists ===== */
  .s10-col h4 {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--green-real, #83C57E);
    margin: 0 0 18px;
  }
  .s10-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 9px;
  }
  .s10-list li {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255,255,255,0.92);
  }
  .s10-list .s10-list-note {
    font-style: italic;
    color: rgba(251,246,233,0.62);
  }

  /* ===== Column 4 - Licenses + Follow ===== */
  .s10-col--meta { display: flex; flex-direction: column; gap: 28px; }
  .s10-social {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .s10-social li { display: flex; }
  .s10-social a, .s10-social-disabled {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 500;
    font-size: 14px;
    color: rgba(251,246,233,0.85);
    text-decoration: none;
    transition: color 0.15s;
  }
  .s10-social a:hover { color: var(--green-real, #83C57E); }
  .s10-social a:focus-visible { outline: 3px solid var(--green-real, #83C57E); outline-offset: 2px; border-radius: 2px; }
  .s10-social-disabled { color: rgba(251,246,233,0.55); cursor: default; }
  .s10-social-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  /* ===== Bottom strip ===== */
  .s10-bottom {
    margin-top: 56px;
    padding-top: 22px;
    border-top: 1px solid rgba(255,255,255,0.25);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
  }
  .s10-copy, .s10-legal {
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 13px;
    line-height: 1.5;
    color: rgba(251,246,233,0.55);
    margin: 0;
  }
  .s10-legal { display: inline-flex; gap: 6px; flex-wrap: wrap; align-items: center; }
  .s10-legal a {
    color: rgba(251,246,233,0.55);
    text-decoration: none;
    transition: color 0.15s;
  }
  .s10-legal a:hover { color: var(--paper, #FFFFFF); text-decoration: underline; text-underline-offset: 3px; }
  .s10-legal a:focus-visible { outline: 3px solid var(--green-real, #83C57E); outline-offset: 2px; border-radius: 2px; }
  .s10-legal .s10-legal-sep { opacity: 0.6; }
  .s10-credit {
    margin-top: 12px;
    font-family: "Josefin Sans", "Inter", system-ui, sans-serif;
    font-weight: 400;
    font-size: 12px;
    color: rgba(251,246,233,0.38);
    flex-basis: 100%;
    text-align: left;
  }

  /* ===== Tablet ===== */
  @media (max-width: 1024px) {
    .s10 { padding: 44px 28px 28px; }
    .s10-grid { grid-template-columns: 1.4fr 1fr 1fr; gap: 32px; }
    .s10-col--meta { grid-column: 1 / -1; flex-direction: row; gap: 56px; flex-wrap: wrap; padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.10); margin-top: 8px; }
  }

  /* ===== Mobile ===== */
  @media (max-width: 720px) {
    .s10 { padding: 40px 18px 28px; }
    .s10-grid { grid-template-columns: 1fr; gap: 0; }
    .s10-col {
      padding: 24px 0;
      border-top: 1px solid rgba(255,255,255,0.10);
    }
    .s10-brand-col { padding: 0 0 24px; gap: 18px; border-top: none; }
    .s10-col--meta { flex-direction: column; gap: 24px; padding: 24px 0; border-top: 1px solid rgba(255,255,255,0.10); margin-top: 0; }
    .s10-col--meta .s10-licenses,
    .s10-col--meta .s10-follow { padding: 0; }
    .s10-logo { height: 68px; }
    .s10-address-line { display: block; }
    .s10-bottom {
      margin-top: 28px;
      padding-top: 20px;
      flex-direction: column;
      align-items: flex-start;
      gap: 14px;
    }
    .s10-copy, .s10-legal { font-size: 12.5px; }
    .s10-credit { margin-top: 6px; }
  }
