    /* ═══════════════════════════════════════════════
       CSS VARIABLES
    ═══════════════════════════════════════════════ */
    :root {
      --red:       #C8102E;
      --red-dark:  #9E0B22;
      --navy:      #002868;
      --navy-dark: #001845;
      --silver:    #B0B8C4;
      --silver-lt: #E4E8EE;
      --white:     #FFFFFF;
      --off-white: #F5F6F8;
      --charcoal:  #1C2228;
      --text:      #2A3240;
      --text-muted:#4A5461;

      --ek-gold:   #F5C400;
      --roth-blue: #4DA3E8;

      --font-display: 'Oswald', sans-serif;
      --font-sub:     'Barlow Condensed', sans-serif;
      --font-body:    'Barlow', sans-serif;

      --section-pad: 100px 0;
      --radius:      6px;
      --radius-lg:   12px;
      --shadow:      0 4px 24px rgba(0,40,104,.08);
      --shadow-lg:   0 16px 48px rgba(0,40,104,.14);
    }

    /* ═══════════════════════════════════════════════
       RESET
    ═══════════════════════════════════════════════ */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: var(--font-body);
      color: var(--text);
      background: var(--white);
      line-height: 1.6;
      overflow-x: hidden;
    }
    /* Subtle grain texture overlay */
    body::after {
      content: '';
      position: fixed; inset: 0; z-index: 1;
      pointer-events: none;
      opacity: 0.028;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      background-repeat: repeat;
      background-size: 256px 256px;
    }
    img { display: block; max-width: 100%; }
    a { color: inherit; text-decoration: none; }
    ul { list-style: none; }

    /* ═══════════════════════════════════════════════
       UTILITIES
    ═══════════════════════════════════════════════ */
    .container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
    .sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
    .hero-breadcrumb { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
    /* Skip to content link for accessibility */
    .skip-link {
      position: absolute; top: -100%; left: 16px;
      background: var(--red); color: var(--white);
      padding: 12px 24px; border-radius: var(--radius);
      font-family: var(--font-sub); font-weight: 700; font-size: .9rem;
      letter-spacing: .05em; text-transform: uppercase;
      z-index: 10000; transition: top .2s;
    }
    .skip-link:focus { top: 12px; }

    .btn {
      display: inline-flex; align-items: center; gap: 8px;
      font-family: var(--font-sub); font-weight: 700; font-size: 1rem;
      letter-spacing: .05em; text-transform: uppercase;
      padding: 16px 36px; border-radius: var(--radius);
      cursor: pointer; border: none;
      transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s cubic-bezier(.16,1,.3,1), background .2s, border-color .2s, color .2s;
    }
    .btn:focus-visible { outline: 2px solid var(--red); outline-offset: 3px; }
    .btn:active { transform: translateY(1px) scale(0.97); }
    .btn-red    { background: var(--red); color: var(--white); }
    .btn-red:hover { background: var(--red-dark); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(200,16,46,.3); }
    .btn-navy   { background: var(--navy); color: var(--white); }
    .btn-navy:hover { background: var(--navy-dark); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,40,104,.2); }
    .btn-outline { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,.6); }
    .btn-outline:hover { background: var(--white); color: var(--navy); border-color: var(--white); }

    /* HouseCall Pro booking button — override default widget styles */
    .hcp-button,
    button.hcp-button {
      display: inline-flex; align-items: center; gap: 8px;
      font-family: var(--font-sub) !important; font-weight: 700 !important; font-size: 1rem !important;
      letter-spacing: .05em; text-transform: uppercase;
      padding: 16px 36px !important; border-radius: var(--radius) !important;
      cursor: pointer; border: none !important;
      background: var(--red) !important; color: var(--white) !important;
      transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s cubic-bezier(.16,1,.3,1), background .2s !important;
      line-height: 1 !important;
    }
    .hcp-button:hover,
    button.hcp-button:hover {
      background: var(--red-dark) !important;
      transform: translateY(-3px);
      box-shadow: 0 8px 24px rgba(200,16,46,.3) !important;
    }
    .hcp-button:active,
    button.hcp-button:active { transform: translateY(1px) scale(0.97); }
    .hcp-button:focus-visible,
    button.hcp-button:focus-visible { outline: 2px solid var(--red); outline-offset: 3px; }
    /* Nav-specific .nav-book and .nav .hcp-button styles moved to nav.css */
    /* Override HouseCall Pro widget default button styles and hide injected elements */
    .hcp-widget:not(.hcp-widget--visible) { display: none !important; }
    /* Hero-specific booking button — calendar icon spacing */
    .hero-book {
      font-size: 1rem !important;
      padding: 16px 36px !important;
    }

    .section-label {
      font-family: var(--font-sub); font-weight: 700; font-size: .8rem;
      letter-spacing: .2em; text-transform: uppercase; color: var(--red);
      display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
    }
    .section-label::before {
      content: ''; display: block; width: 32px; height: 2px; background: var(--red);
    }
    .section-title {
      font-family: var(--font-display); font-weight: 700;
      font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.08;
      letter-spacing: -.01em;
      color: var(--charcoal); margin-bottom: 18px;
      text-wrap: balance;
    }
    .section-title span { color: var(--red); }
    .section-sub {
      font-size: 1.08rem; color: var(--text-muted);
      max-width: 600px; line-height: 1.75;
      text-wrap: pretty;
    }

    /* Topbar + Nav styles moved to nav.css */

    /* ═══════════════════════════════════════════════
       HERO
    ═══════════════════════════════════════════════ */
    .hero {
      background: var(--navy-dark);
      position: relative; overflow: hidden;
      min-height: 620px;
      display: flex; align-items: center;
    }
    /* Diagonal stripe decoration */
    .hero::before {
      content: '';
      position: absolute; inset: 0;
      background:
        repeating-linear-gradient(
          -55deg,
          transparent 0, transparent 30px,
          rgba(255,255,255,.015) 30px, rgba(255,255,255,.015) 60px
        );
    }
    .hero::after {
      content: '';
      position: absolute; right: -80px; top: 0; bottom: 0;
      width: 55%;
      background: var(--navy);
      clip-path: polygon(12% 0, 100% 0, 100% 100%, 0% 100%);
      z-index: 0;
    }
    .hero .container {
      position: relative; z-index: 2;
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 56px; align-items: center;
      padding-top: 72px; padding-bottom: 72px;
    }
    .hero-tag {
      font-family: var(--font-sub); font-weight: 700; font-size: .78rem;
      letter-spacing: .22em; text-transform: uppercase;
      color: var(--silver); display: flex; align-items: center; gap: 8px;
      margin-bottom: 16px;
    }
    .hero-tag::before {
      content: ''; width: 24px; height: 2px;
      background: var(--red);
    }
    .hero h1 {
      font-family: var(--font-display); font-weight: 700;
      font-size: clamp(2.6rem, 5vw, 4rem);
      line-height: 1.02; letter-spacing: -.02em;
      color: var(--white);
      margin-bottom: 24px;
      text-wrap: balance;
    }
    .hero h1 .accent { color: var(--red); }
    .hero h1 .underline-red {
      position: relative; display: inline-block;
    }
    .hero h1 .underline-red::after {
      content: ''; position: absolute;
      left: 0; bottom: -4px; right: 0; height: 3px;
      background: var(--red);
    }
    .hero-sub {
      color: rgba(255,255,255,.72); font-size: 1.08rem;
      line-height: 1.7; margin-bottom: 36px;
      max-width: 500px; text-wrap: pretty;
    }
    .hero-btns { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 40px; }
    .hero-trust {
      display: flex; gap: 28px; flex-wrap: wrap;
    }
    .hero-trust-item {
      display: flex; flex-direction: column;
    }
    .hero-trust-item strong {
      font-family: var(--font-display); font-size: 1.6rem;
      color: var(--white); line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .hero-trust-item span {
      font-size: .78rem; color: rgba(255,255,255,.55);
      letter-spacing: .05em; text-transform: uppercase;
    }
    .hero-trust-icon { display: none; }

    /* Hero right panel — service cards */
    .hero-cards {
      position: relative; z-index: 2;
      display: grid; gap: 14px;
    }
    .hero-card {
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.1);
      border-left: 4px solid var(--red);
      border-radius: var(--radius);
      padding: 18px 22px;
      display: flex; align-items: center; gap: 16px;
      transition: border-color .25s cubic-bezier(.16,1,.3,1), background .25s, transform .25s cubic-bezier(.16,1,.3,1);
      cursor: pointer;
    }
    .hero-card:hover {
      background: rgba(255,255,255,.12);
      border-left-color: var(--white);
      transform: translateX(4px);
    }
    .hero-card-icon {
      font-size: 1.6rem; line-height: 1; flex-shrink: 0;
    }
    .hero-card strong {
      font-family: var(--font-sub); font-weight: 700; font-size: 1rem;
      letter-spacing: .04em; color: var(--white); display: block;
    }
    .hero-card span { font-size: .82rem; color: rgba(255,255,255,.55); }
    .hero-emerg-badge {
      background: var(--red); color: var(--white);
      text-align: center; padding: 14px 16px;
      border-radius: var(--radius);
      font-family: var(--font-sub); font-weight: 700; font-size: .95rem;
      letter-spacing: .08em; text-transform: uppercase;
    }
    .hero-emerg-badge a { color: inherit; }
    .hero-emerg-badge .phone {
      display: block; font-family: var(--font-display); font-size: 1.6rem; font-weight: 700;
      letter-spacing: .04em; margin-top: 2px;
    }

    /* Trust strip removed — indicators consolidated into hero + why */

    /* ═══════════════════════════════════════════════
       SERVICES
    ═══════════════════════════════════════════════ */
    .services { padding: var(--section-pad); background: var(--white); }
    .services-head { margin-bottom: 64px; }
    .services-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
    }
    /* Offset anchors for sticky nav */
    section[id] { scroll-margin-top: 20px; }
    .service-card[id] { scroll-margin-top: 80px; }
    #installations { scroll-margin-top: 100px; }

    .service-card {
      background: var(--white);
      border-radius: var(--radius-lg);
      overflow: hidden;
      transition: box-shadow .3s cubic-bezier(.16,1,.3,1), transform .3s cubic-bezier(.16,1,.3,1);
      box-shadow: var(--shadow);
    }
    .service-card:hover {
      box-shadow: var(--shadow-lg);
      transform: translateY(-6px);
    }
    /* Make the last card (Emergency) span full width */
    .service-card:last-child {
      grid-column: 1 / -1;
    }
    /* Featured service card — annual maintenance highlight */
    .service-card-featured {
      border: 2px solid var(--red);
      position: relative;
    }
    .service-card-featured::after {
      content: 'Book Online — Schedule Now';
      position: absolute; top: 0; right: 0;
      font-family: var(--font-sub); font-weight: 700; font-size: .68rem;
      letter-spacing: .1em; text-transform: uppercase;
      background: var(--red); color: var(--white);
      padding: 5px 14px; border-radius: 0 0 0 var(--radius);
    }
    /* EK callout inside boiler installation card */
    .ek-callout {
      margin-top: 16px; padding: 14px 16px;
      background: var(--off-white); border-left: 3px solid var(--ek-gold);
      border-radius: 0 var(--radius) var(--radius) 0;
      display: flex; align-items: center; gap: 14px;
    }
    .ek-callout img { height: 28px; width: auto; flex-shrink: 0; }
    .ek-callout p {
      font-size: .82rem !important; color: var(--text) !important;
      line-height: 1.5 !important; margin: 0 !important;
    }
    .ek-callout a {
      color: var(--red); font-weight: 600;
      text-decoration: none; white-space: nowrap;
    }
    .ek-callout a:hover { text-decoration: underline; }
    .roth-callout {
      margin-top: 16px; padding: 14px 16px;
      background: var(--off-white); border-left: 3px solid var(--navy);
      border-radius: 0 var(--radius) var(--radius) 0;
      display: flex; align-items: flex-start; gap: 14px;
    }
    .roth-callout img { height: 32px; width: auto; flex-shrink: 0; margin-top: 2px; }
    .roth-callout strong {
      display: block; font-family: var(--font-sub); font-weight: 700;
      font-size: .82rem; letter-spacing: .04em; color: var(--charcoal); margin-bottom: 4px;
    }
    .roth-callout p {
      font-size: .8rem !important; color: var(--text-muted) !important;
      line-height: 1.5 !important; margin: 0 !important;
    }
    .service-card-top {
      background: var(--navy);
      padding: 32px 32px 24px;
      position: relative; overflow: hidden;
    }
    .service-card-top::after {
      content: attr(data-num);
      position: absolute; right: 20px; top: 10px;
      font-family: var(--font-display); font-size: 4.5rem; font-weight: 700;
      color: rgba(255,255,255,.05); line-height: 1;
      user-select: none;
    }
    .service-icon {
      width: 48px; height: 48px; background: var(--red); border-radius: var(--radius);
      display: flex; align-items: center; justify-content: center;
      font-size: 1.5rem; margin-bottom: 16px;
      transition: transform .3s cubic-bezier(.16,1,.3,1);
    }
    .service-card:hover .service-icon { transform: scale(1.08); }
    .service-card-top h3 {
      font-family: var(--font-display); font-weight: 700; font-size: 1.35rem;
      color: var(--white); line-height: 1.2; letter-spacing: -.01em;
    }
    .service-card-body { padding: 28px 32px; }
    .service-card-body p {
      color: var(--text-muted); font-size: .95rem; line-height: 1.75; margin-bottom: 20px;
      text-wrap: pretty;
    }
    .service-card-body ul { display: flex; flex-direction: column; gap: 8px; }
    .service-card-body li {
      font-size: .9rem; color: var(--text);
      display: flex; align-items: flex-start; gap: 10px;
    }
    .service-card-body li::before {
      content: ''; width: 6px; height: 6px; border-radius: 50%;
      background: var(--red); flex-shrink: 0; margin-top: 8px;
    }

    /* ═══════════════════════════════════════════════
       WHY CHOOSE US
    ═══════════════════════════════════════════════ */
    .why {
      padding: 112px 0;
      background: var(--charcoal);
      position: relative; overflow: hidden;
    }
    .why::before {
      content: '';
      position: absolute; left: 0; top: 0; bottom: 0; width: 8px;
      background: repeating-linear-gradient(to bottom, var(--red) 0 30%, var(--white) 30% 60%, var(--navy) 60% 100%);
    }
    .why .container {
      display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
    }
    .why .section-title { color: var(--white); }
    .why .section-sub { color: var(--silver); }
    .why-points { display: flex; flex-direction: column; gap: 18px; margin-top: 32px; }
    .why-point {
      display: flex; gap: 16px; align-items: flex-start;
    }
    .why-point-num {
      width: 36px; height: 36px; border-radius: 50%;
      background: var(--red); color: var(--white);
      font-family: var(--font-display); font-weight: 700; font-size: 1rem;
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; margin-top: 2px;
    }
    .why-point-text strong {
      display: block; font-family: var(--font-sub); font-weight: 700; font-size: .98rem;
      letter-spacing: .03em; color: var(--white); margin-bottom: 3px;
    }
    .why-point-text span { font-size: .88rem; color: var(--silver); line-height: 1.5; }
    .why-stats {
      display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
    }
    .why-stat {
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.08);
      border-top: 3px solid var(--red);
      border-radius: var(--radius-lg);
      padding: 32px 24px; text-align: center;
      transition: background .2s;
    }
    .why-stat:hover { background: rgba(255,255,255,.1); }
    .why-stat big {
      display: block; font-family: var(--font-display); font-weight: 700;
      font-size: 2.6rem; color: var(--white); line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .why-stat span {
      font-size: .8rem; letter-spacing: .1em; text-transform: uppercase;
      color: var(--silver); margin-top: 6px; display: block;
    }
    .why-cta-box {
      grid-column: 1 / -1; /* full width on mobile */
    }

    /* ═══════════════════════════════════════════════
       EMERGENCY BANNER
    ═══════════════════════════════════════════════ */
    .emerg-banner {
      background: var(--red);
      padding: 26px 0;
    }
    .emerg-banner .container {
      display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 16px;
    }
    .emerg-banner-text {
      font-family: var(--font-display); font-weight: 700;
      font-size: clamp(1.3rem, 3vw, 1.8rem);
      color: var(--white); line-height: 1.2;
    }
    .emerg-banner-text span {
      font-family: var(--font-body); font-weight: 300;
      font-size: .95rem; display: block;
      color: rgba(255,255,255,.8); margin-bottom: 4px;
    }

    /* ═══════════════════════════════════════════════
       SERVICE AREA
    ═══════════════════════════════════════════════ */
    .service-area { padding: var(--section-pad); background: var(--off-white); }
    .service-area .container { display: grid; grid-template-columns: 1fr 1.6fr; gap: 56px; align-items: start; }
    .area-intro { position: sticky; top: 90px; }
    .area-map {
      border-radius: 6px;
      margin-bottom: 20px;
      overflow: hidden;
      border: 3px solid var(--silver-lt);
    }
    .area-map img {
      width: 100%; height: auto; display: block;
    }
    .town-grid {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
    }
    .town-pill {
      background: var(--white); border: 1px solid var(--silver-lt);
      border-radius: 3px; padding: 10px 18px;
      font-size: .82rem; font-weight: 500; color: var(--text);
      transition: all .15s; cursor: default; text-align: center;
    }
    .town-pill:hover {
      background: var(--navy); color: var(--white); border-color: var(--navy);
    }
    .town-pill.highlight {
      background: var(--navy); color: var(--white); border-color: var(--navy); font-weight: 600;
    }
    a.town-pill {
      display: block; cursor: pointer;
    }
    a.town-pill::after {
      content: ' →';
      font-size: .75rem;
      opacity: .55;
    }
    a.town-pill:hover::after {
      opacity: 1;
    }
    .town-toggle { display: none; }
    .area-note {
      margin-top: 16px; font-size: .85rem; color: var(--text-muted);
      background: var(--white); border-left: 3px solid var(--red);
      padding: 10px 14px; border-radius: 0 3px 3px 0;
    }

    /* ═══════════════════════════════════════════════
       TESTIMONIALS
    ═══════════════════════════════════════════════ */
    .testimonials { padding: var(--section-pad); background: var(--off-white); }
    .testimonials-head { margin-bottom: 56px; }
    .stars { color: #D97706; font-size: .95rem; letter-spacing: 2px; margin-bottom: 6px; }
    .testimonials-grid {
      columns: 2; column-gap: 24px;
    }
    .testimonial-card {
      break-inside: avoid; margin-bottom: 24px;
      background: var(--white); border-radius: var(--radius-lg);
      padding: 32px; border-left: 3px solid var(--navy);
      transition: box-shadow .3s cubic-bezier(.16,1,.3,1), transform .3s cubic-bezier(.16,1,.3,1);
      box-shadow: 0 1px 3px rgba(0,40,104,.06);
    }
    .testimonial-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
    .testimonial-card p {
      font-size: .95rem; color: var(--text); line-height: 1.75;
      margin-bottom: 20px; font-style: italic;
      text-wrap: pretty;
    }
    .testimonial-card p::before { content: '\201C'; font-size: 1.6em; color: var(--red); font-weight: 700; }
    .testimonial-card p::after  { content: '\201D'; font-size: 1.6em; color: var(--red); font-weight: 700; }
    .testimonial-author {
      font-family: var(--font-sub); font-weight: 700; font-size: .88rem;
      letter-spacing: .05em; color: var(--charcoal);
    }
    .testimonial-author span {
      display: block; font-weight: 400; color: var(--text-muted); font-size: .82rem;
    }
    .carousel-dots { display: none; }
    .rating-bar {
      display: flex; align-items: center; gap: 10px; justify-content: center;
      margin-top: 44px;
      font-family: var(--font-sub); font-size: .95rem; color: var(--text-muted);
    }
    .rating-bar strong { font-size: 1.5rem; color: var(--charcoal); }

    /* Google Reviews CTA Block */
    .google-reviews-cta {
      margin-top: 48px; text-align: center;
      background: var(--white); border: 1px solid var(--silver-lt);
      border-radius: var(--radius-lg); padding: 36px 32px;
      box-shadow: var(--shadow);
      display: flex; align-items: center; justify-content: center; gap: 32px;
      flex-wrap: wrap;
    }
    .google-reviews-rating {
      display: flex; align-items: center; gap: 16px;
    }
    .google-reviews-rating .g-score {
      font-family: var(--font-display); font-weight: 700;
      font-size: 3.2rem; color: var(--charcoal); line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .google-reviews-rating .g-detail {
      display: flex; flex-direction: column; text-align: left;
    }
    .google-reviews-rating .g-detail .stars {
      font-size: 1.1rem; letter-spacing: 2px; margin-bottom: 2px;
    }
    .google-reviews-rating .g-detail span {
      font-size: .82rem; color: var(--text-muted);
    }
    .google-reviews-rating .g-label {
      font-family: var(--font-sub); font-weight: 700; font-size: .78rem;
      letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted);
      display: flex; align-items: center; gap: 6px;
    }
    .google-reviews-rating .g-label svg { flex-shrink: 0; }
    .btn-google {
      display: inline-flex; align-items: center; gap: 10px;
      font-family: var(--font-sub); font-weight: 700; font-size: .95rem;
      letter-spacing: .05em; text-transform: uppercase;
      background: var(--navy); color: var(--white);
      padding: 14px 28px; border-radius: var(--radius);
      transition: all .25s cubic-bezier(.16,1,.3,1);
    }
    .btn-google:hover {
      background: var(--navy-dark); transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(0,40,104,.2);
    }
    @media (max-width: 640px) {
      .google-reviews-cta { flex-direction: column; gap: 20px; padding: 28px 20px; }
    }

    /* ═══════════════════════════════════════════════
       CONTACT
    ═══════════════════════════════════════════════ */
    .contact { padding: 112px 0; background: var(--navy); }
    .contact .container { display: grid; grid-template-columns: 1fr 1.4fr; gap: 72px; align-items: start; }
    .contact-info .section-title { color: var(--white); }
    .contact-info .section-sub { color: var(--silver); }
    .contact-blocks { margin-top: 36px; display: flex; flex-direction: column; gap: 20px; }
    .contact-block {
      display: flex; gap: 14px; align-items: flex-start;
    }
    .contact-block-icon {
      width: 44px; height: 44px; background: var(--red); border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.2rem; flex-shrink: 0;
    }
    .contact-block-text strong {
      display: block; font-family: var(--font-sub); font-weight: 700; font-size: .82rem;
      letter-spacing: .12em; text-transform: uppercase; color: var(--silver);
    }
    .contact-block-text a, .contact-block-text p {
      color: var(--white); font-size: 1.05rem; font-weight: 500;
      transition: color .15s;
    }
    .contact-block-text a:hover { color: var(--silver-lt); }
    .contact-block-text .hours { font-size: .88rem; color: rgba(255,255,255,.6); }

    /* Contact Form */
    .contact-form-wrap {
      background: var(--white); border-radius: var(--radius-lg);
      padding: 44px; box-shadow: 0 24px 64px rgba(0,24,69,.25);
    }
    .contact-form-wrap h3 {
      font-family: var(--font-display); font-weight: 700; font-size: 1.5rem;
      color: var(--charcoal); margin-bottom: 6px; letter-spacing: -.01em;
    }
    .contact-form-wrap p { font-size: .9rem; color: var(--text-muted); margin-bottom: 28px; }
    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    .form-group { display: flex; flex-direction: column; gap: 5px; }
    .form-group label {
      font-family: var(--font-sub); font-weight: 600; font-size: .78rem;
      letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted);
    }
    .form-group input,
    .form-group select,
    .form-group textarea {
      font-family: var(--font-body); font-size: .95rem;
      padding: 13px 16px; border-radius: var(--radius);
      border: 1.5px solid var(--silver-lt); color: var(--charcoal);
      background: var(--off-white); outline: none;
      transition: border-color .2s, box-shadow .2s, background .2s;
      width: 100%;
    }
    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus {
      border-color: var(--navy); border-left: 3px solid var(--navy); background: var(--white);
      box-shadow: 0 0 0 3px rgba(0,40,104,.12);
    }
    .form-group input.error,
    .form-group select.error,
    .form-group textarea.error {
      border-color: var(--red); background: #FFF5F5;
    }
    .form-error {
      font-size: .78rem; color: var(--red); margin-top: 2px;
      font-weight: 500; display: none;
    }
    .form-group.has-error .form-error { display: block; }
    .form-group textarea { resize: vertical; min-height: 90px; }
    .form-full { grid-column: 1 / -1; }
    .form-submit { margin-top: 8px; width: 100%; justify-content: center; font-size: 1rem; padding: 15px; }

    /* ═══════════════════════════════════════════════
       FOOTER
    ═══════════════════════════════════════════════ */
    .footer { background: var(--charcoal); padding: 64px 0 28px; }
    .footer-grid {
      display: grid; grid-template-columns: 1.5fr 2fr; gap: 48px;
      margin-bottom: 48px;
    }
    .footer-columns {
      display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
    }
    .footer-brand .logo-text strong { font-size: 1.2rem; }
    .footer-brand p {
      font-size: .88rem; color: var(--silver); line-height: 1.6; margin-top: 12px;
    }
    .footer h4, .footer-heading {
      font-family: var(--font-sub); font-weight: 700; font-size: .82rem;
      letter-spacing: .15em; text-transform: uppercase; color: var(--red);
      margin-bottom: 14px;
    }
    .footer-links { display: flex; flex-direction: column; gap: 8px; }
    .footer-links a {
      font-size: .9rem; color: var(--silver); transition: color .15s;
    }
    .footer-links a:hover { color: var(--white); }
    .footer-svc-link { display: none; }
    .footer-svc-summary { display: block; }
    .footer-bottom {
      border-top: 1px solid rgba(255,255,255,.08);
      padding-top: 20px;
      display: flex; justify-content: space-between; align-items: center;
      flex-wrap: wrap; gap: 8px;
      font-size: .8rem; color: rgba(255,255,255,.35);
    }
    .footer-bottom a { color: rgba(255,255,255,.4); }
    .footer-bottom a:hover { color: var(--silver); }
    .footer-flag {
      display: flex; gap: 4px; align-items: center;
    }
    .flag-stripe {
      width: 8px; height: 16px; border-radius: 1px;
    }

    /* ═══════════════════════════════════════════════
       ANIMATIONS
    ═══════════════════════════════════════════════ */
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(24px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .fade-up { animation: fadeUp .6s cubic-bezier(.16,1,.3,1) both; }
    .fade-up-1 { animation-delay: .1s; }
    .fade-up-2 { animation-delay: .2s; }
    .fade-up-3 { animation-delay: .3s; }
    .fade-up-4 { animation-delay: .4s; }

    /* Scroll-triggered reveals */
    .reveal {
      opacity: 0; transform: translateY(32px);
      transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
    }
    .reveal.visible {
      opacity: 1; transform: translateY(0);
    }
    .reveal-stagger > .reveal { transition-delay: calc(var(--i, 0) * 100ms); }

    /* ═══════════════════════════════════════════════
       MOBILE RESPONSIVE
    ═══════════════════════════════════════════════ */
    /* EK Spotlight — 2-col with product image */
    .ek-spotlight {
      background: var(--navy-dark);
      border-radius: var(--radius-lg);
      padding: 0; overflow: hidden;
      margin-bottom: 56px;
      box-shadow: var(--shadow-lg);
      display: grid; grid-template-columns: 1fr 1fr;
    }
    .ek-spotlight-content {
      padding: 48px 44px;
      display: flex; flex-direction: column; justify-content: center; gap: 20px;
    }
    .ek-spotlight-logo {
      display: flex; align-items: center; gap: 14px;
    }
    .ek-spotlight-logo img {
      height: 44px; width: auto; object-fit: contain;
      background: var(--white); border-radius: 4px; padding: 6px 12px;
    }
    .ek-spotlight-logo .ek-dealer-label {
      font-family: var(--font-sub); font-weight: 700; font-size: .72rem;
      letter-spacing: .12em; text-transform: uppercase;
      color: var(--ek-gold); line-height: 1.3;
    }
    .ek-spotlight-content h3 {
      font-family: var(--font-display); font-weight: 700;
      font-size: clamp(1.4rem, 2.5vw, 1.8rem);
      color: var(--white); line-height: 1.15; letter-spacing: -.01em;
      text-wrap: balance;
    }
    .ek-spotlight-content h3 em {
      font-style: normal; color: var(--ek-gold);
    }
    .ek-spotlight-content > p {
      font-size: .92rem; color: var(--silver); line-height: 1.7;
      text-wrap: pretty;
    }
    .ek-stats {
      display: flex; gap: 24px; margin-top: 4px;
    }
    .ek-stat {
      display: flex; flex-direction: column;
    }
    .ek-stat strong {
      font-family: var(--font-display); font-size: 1.5rem; font-weight: 700;
      color: var(--ek-gold); line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .ek-stat span {
      font-size: .72rem; color: var(--silver); letter-spacing: .06em;
      text-transform: uppercase; margin-top: 2px;
    }
    .ek-spotlight-content .btn-ek {
      display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
      font-family: var(--font-sub); font-weight: 700; font-size: .9rem;
      letter-spacing: .05em; text-transform: uppercase;
      background: var(--ek-gold); color: var(--charcoal);
      padding: 14px 28px; border-radius: var(--radius);
      transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s cubic-bezier(.16,1,.3,1), background .2s;
      white-space: nowrap;
    }
    .ek-spotlight-content .btn-ek:hover {
      background: #D4A800; transform: translateY(-3px);
      box-shadow: 0 8px 24px rgba(245,196,0,.25);
    }
    .ek-spotlight-content .btn-ek:active { transform: translateY(1px) scale(0.97); }
    .ek-spotlight-media {
      position: relative; overflow: hidden;
      background: linear-gradient(135deg, #F5C400 0%, #D4A800 100%);
      display: flex; align-items: center; justify-content: center;
      padding: 32px;
      min-height: 340px;
    }
    .ek-spotlight-media img {
      max-height: 320px; width: auto; object-fit: contain;
      filter: drop-shadow(0 16px 32px rgba(0,0,0,.35));
      transition: transform .4s cubic-bezier(.16,1,.3,1);
    }
    .ek-spotlight:hover .ek-spotlight-media img {
      transform: scale(1.03);
    }
    .ek-spotlight-media .ek-energy-star {
      position: absolute; bottom: 16px; right: 16px;
      font-family: var(--font-sub); font-weight: 700; font-size: .68rem;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--charcoal); background: rgba(255,255,255,.9);
      padding: 5px 10px; border-radius: 3px;
    }
    /* EK + Roth spotlight responsive — see consolidated block after Roth section */

    /* ═══════════════════════════════════════════════
       ROTH SPOTLIGHT
    ═══════════════════════════════════════════════ */
    .roth-spotlight {
      background: var(--charcoal);
      border-radius: var(--radius-lg);
      padding: 0; overflow: hidden;
      margin-bottom: 56px;
      box-shadow: var(--shadow-lg);
      display: grid; grid-template-columns: 1fr 1fr;
    }
    .roth-spotlight-content {
      padding: 48px 44px;
      display: flex; flex-direction: column; justify-content: center; gap: 20px;
    }
    .roth-spotlight-logo {
      display: flex; align-items: center; gap: 14px;
    }
    .roth-spotlight-logo img {
      height: 44px; width: auto; object-fit: contain;
      background: var(--white); border-radius: 4px; padding: 6px 12px;
    }
    .roth-spotlight-logo .roth-dealer-label {
      font-family: var(--font-sub); font-weight: 700; font-size: .72rem;
      letter-spacing: .12em; text-transform: uppercase;
      color: var(--navy); line-height: 1.3;
    }
    .roth-spotlight-content h3 {
      font-family: var(--font-display); font-weight: 700;
      font-size: clamp(1.4rem, 2.5vw, 1.8rem);
      color: var(--white); line-height: 1.15; letter-spacing: -.01em;
      text-wrap: balance;
    }
    .roth-spotlight-content h3 em {
      font-style: normal; color: var(--roth-blue);
    }
    .roth-spotlight-content > p {
      font-size: .92rem; color: var(--silver); line-height: 1.7;
      text-wrap: pretty;
    }
    .roth-stats {
      display: flex; gap: 24px; margin-top: 4px;
    }
    .roth-stat {
      display: flex; flex-direction: column;
    }
    .roth-stat strong {
      font-family: var(--font-display); font-size: 1.5rem; font-weight: 700;
      color: var(--roth-blue); line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .roth-stat span {
      font-size: .72rem; color: var(--silver); letter-spacing: .06em;
      text-transform: uppercase; margin-top: 2px;
    }
    .roth-spotlight-content .btn-roth {
      display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
      font-family: var(--font-sub); font-weight: 700; font-size: .9rem;
      letter-spacing: .05em; text-transform: uppercase;
      background: var(--roth-blue); color: var(--white);
      padding: 14px 28px; border-radius: var(--radius);
      transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s cubic-bezier(.16,1,.3,1), background .2s;
      white-space: nowrap;
    }
    .roth-spotlight-content .btn-roth:hover {
      background: #3A8DD0; transform: translateY(-3px);
      box-shadow: 0 8px 24px rgba(77,163,232,.25);
    }
    .roth-spotlight-content .btn-roth:active { transform: translateY(1px) scale(0.97); }
    .roth-spotlight-media {
      position: relative; overflow: hidden;
      background: linear-gradient(135deg, #4DA3E8 0%, #2B7BBF 100%);
      display: flex; align-items: center; justify-content: center;
      padding: 32px;
      min-height: 340px;
    }
    .roth-spotlight-media img {
      max-height: 280px; width: auto; object-fit: contain;
      filter: drop-shadow(0 16px 32px rgba(0,0,0,.35));
      transition: transform .4s cubic-bezier(.16,1,.3,1);
    }
    .roth-spotlight:hover .roth-spotlight-media img {
      transform: scale(1.03);
    }
    .roth-spotlight-media .roth-warranty-badge {
      position: absolute; bottom: 16px; right: 16px;
      font-family: var(--font-sub); font-weight: 700; font-size: .68rem;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--charcoal); background: rgba(255,255,255,.9);
      padding: 5px 10px; border-radius: 3px;
    }
    @media (max-width: 900px) {
      .ek-spotlight, .roth-spotlight { grid-template-columns: 1fr; }
      .ek-spotlight-media, .roth-spotlight-media { min-height: 240px; padding: 24px; }
      .ek-spotlight-media img, .roth-spotlight-media img { max-height: 220px; }
      .ek-spotlight-content, .roth-spotlight-content { padding: 36px 28px; }
    }
    @media (max-width: 640px) {
      .ek-spotlight-content, .roth-spotlight-content { padding: 28px 20px; }
      .ek-stats, .roth-stats { flex-wrap: nowrap; gap: 16px; }
      .roth-stat-double { display: none; }
    }

    /* ═══════════════════════════════════════════════
       BRANDS SECTION
    ═══════════════════════════════════════════════ */
    .brands { padding: 72px 0; background: var(--white); }
    .brands-head { text-align: center; margin-bottom: 48px; }
    .brands-head .section-label { justify-content: center; }
    .brands-head .section-label::before { display: none; }
    .brands-head .section-sub { margin: 0 auto; }

    /* Featured 3 burner brands */
    .burner-trio {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
      margin-bottom: 56px;
    }
    .burner-card {
      border: 1px solid var(--silver-lt);
      border-top: 4px solid var(--red);
      border-radius: var(--radius-lg);
      padding: 36px 28px 28px;
      text-align: center;
      transition: box-shadow .3s cubic-bezier(.16,1,.3,1), transform .3s cubic-bezier(.16,1,.3,1);
      background: var(--white);
      display: flex; flex-direction: column; align-items: center; gap: 16px;
      box-shadow: 0 1px 3px rgba(0,40,104,.06);
    }
    .burner-card:hover {
      box-shadow: var(--shadow-lg); transform: translateY(-6px);
    }
    .burner-card-logo {
      height: 56px; width: auto; max-width: 180px;
      object-fit: contain; filter: none;
      transition: transform .2s;
    }
    .burner-card:hover .burner-card-logo { transform: scale(1.04); }
    .burner-card h3 {
      font-family: var(--font-display); font-weight: 700; font-size: 1.1rem;
      color: var(--charcoal); letter-spacing: .02em;
    }
    .burner-card p {
      font-size: .88rem; color: var(--text-muted); line-height: 1.6;
    }
    .burner-dots { display: none; }
    /* brand-tag removed */

    /* Scrolling logo marquee */
    .brands-divider {
      display: flex; align-items: center; gap: 16px; margin-bottom: 28px;
    }
    .brands-divider span {
      font-family: var(--font-sub); font-weight: 700; font-size: .78rem;
      letter-spacing: .18em; text-transform: uppercase; color: var(--text-muted);
      white-space: nowrap;
    }
    .brands-divider::before,
    .brands-divider::after {
      content: ''; flex: 1; height: 1px; background: var(--silver-lt);
    }
    .logo-marquee {
      overflow: hidden;
      position: relative;
      -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
      mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
    }
    .logo-marquee:hover .logo-marquee-track { animation-play-state: paused; }
    .logo-marquee-track {
      display: flex; gap: 32px; width: max-content;
      animation: marquee-scroll 45s linear infinite;
      will-change: transform;
    }
    @keyframes marquee-scroll {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }
    .logo-marquee-item {
      flex-shrink: 0;
      background: var(--off-white);
      border: 1px solid var(--silver-lt);
      border-radius: 5px;
      padding: 14px 20px;
      display: flex; align-items: center; justify-content: center;
      min-width: 140px; height: 64px;
      transition: background .15s, border-color .15s;
    }
    .logo-marquee-item:hover {
      background: var(--white);
      border-color: var(--silver);
    }
    .logo-marquee-item img {
      max-height: 34px; width: auto; max-width: 110px;
      object-fit: contain;
      filter: grayscale(100%) contrast(0.7);
      transition: filter .3s;
    }
    .logo-marquee-item:hover img { filter: grayscale(0%) contrast(1); }
    .brands-note {
      text-align: center; margin-top: 24px;
      font-size: .88rem; color: var(--text-muted);
    }
    .brands-note strong { color: var(--charcoal); }

    @media (prefers-reduced-motion: reduce) {
      .logo-marquee-track { animation: none; }
    }

    /* ═══════════════════════════════════════════════
       OUR WORK / INSTALL GALLERY
    ═══════════════════════════════════════════════ */
    .our-work { padding: var(--section-pad); background: var(--off-white); }
    .our-work .section-sub {
      max-width: 600px; margin: 0 auto 40px; text-align: center;
      color: var(--text-muted); font-size: 1.05rem;
    }
    .install-gallery {
      display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px;
    }
    .install-gallery figure {
      margin: 0; position: relative; overflow: hidden;
      border-radius: var(--radius-lg); background: var(--silver-lt);
    }
    .install-gallery img {
      width: 100%; height: 360px; object-fit: cover;
      display: block; border-radius: var(--radius-lg);
      transition: transform .3s ease;
    }
    .install-gallery figure:hover img { transform: scale(1.03); }
    .install-gallery figcaption {
      position: absolute; bottom: 0; left: 0; right: 0;
      padding: 8px 12px; font-family: var(--font-sub);
      font-size: .75rem; font-weight: 600; letter-spacing: .04em;
      color: var(--white); background: linear-gradient(transparent, rgba(0,0,0,.6));
      border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    }

    /* Before/After Pair */
    .before-after-pair {
      display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
      margin-top: 32px;
    }
    .before-after-item {
      position: relative; overflow: hidden;
      border-radius: var(--radius-lg); background: var(--silver-lt);
    }
    .before-after-item img {
      width: 100%; height: 360px; object-fit: cover; display: block;
      border-radius: var(--radius-lg);
    }
    .before-after-label {
      position: absolute; top: 12px; left: 12px;
      padding: 4px 14px; border-radius: 20px;
      font-family: var(--font-sub); font-weight: 700;
      font-size: .72rem; letter-spacing: .08em; text-transform: uppercase;
    }
    .before-after-label--before {
      background: rgba(200,16,46,.9); color: var(--white);
    }
    .before-after-label--after {
      background: rgba(16,140,60,.9); color: var(--white);
    }

    /* Why Choose Us — Photo */
    .why-photo {
      border-radius: var(--radius-lg); overflow: hidden;
      margin-bottom: 24px; box-shadow: 0 8px 32px rgba(0,24,69,.15);
    }
    .why-photo img {
      width: 100%; height: 320px; object-fit: cover; display: block;
    }
    .why-photo-caption {
      padding: 10px 16px; background: var(--navy);
      font-family: var(--font-sub); font-size: .78rem; font-weight: 600;
      letter-spacing: .04em; color: rgba(255,255,255,.7); text-align: center;
    }

    /* Responsive */
    @media (max-width: 640px) {
      .install-gallery { grid-template-columns: repeat(2, 1fr); gap: 8px; }
      .install-gallery img { height: auto; aspect-ratio: 1 / 1; }
      .before-after-pair { grid-template-columns: 1fr 1fr; gap: 8px; }
      .why-photo img { height: 240px; }
    }

    @media (max-width: 760px) {
      .burner-trio {
        display: flex;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: 0;
        scrollbar-width: none;
        max-width: none;
        margin-bottom: 32px;
        touch-action: pan-x;
      }
      .burner-trio::-webkit-scrollbar { display: none; }
      .burner-card {
        flex: 0 0 calc(100% - 16px);
        scroll-snap-align: start;
        margin-right: 16px;
        padding: 20px 24px;
        gap: 10px;
        border-top: 3px solid var(--red);
      }
      .burner-card:hover { transform: none; }
      .burner-card-logo { height: 36px; }
      .burner-card h3 { font-size: 1rem; }
      .burner-card p { font-size: .82rem; line-height: 1.5; margin: 0; }
      .burner-dots {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-bottom: 32px;
      }
      .burner-dot {
        width: 10px; height: 10px;
        border-radius: 50%;
        background: var(--silver);
        border: none; cursor: pointer;
        transition: background .2s;
        padding: 0;
      }
      .burner-dot.is-active { background: var(--red); }
    }

    @media (max-width: 900px) {
      .hero .container { grid-template-columns: 1fr; }
      .hero::after { display: none; }
      .hero-cards { display: none; }
      .services-grid { grid-template-columns: 1fr; gap: 8px; }
      .service-card:last-child { grid-column: auto; }
      .service-card { box-shadow: 0 2px 8px rgba(0,0,0,.08); }
      .service-card:hover { transform: none; box-shadow: 0 2px 8px rgba(0,0,0,.08); }
      .service-card-top { padding: 16px 20px; display: flex; align-items: center; gap: 12px; cursor: pointer; }
      .service-card-top::after { content: ''; display: none; }
      .service-icon { width: 36px; height: 36px; margin-bottom: 0; font-size: 1.2rem; flex-shrink: 0; }
      .service-card-top h3 { font-size: 1rem; flex: 1; }
      .service-card-chevron {
        width: 24px; height: 24px; flex-shrink: 0;
        transition: transform .3s ease;
        color: var(--white);
      }
      .service-card.is-open .service-card-chevron { transform: rotate(90deg); }
      .service-card-body {
        max-height: 0; overflow: hidden;
        padding-top: 0; padding-bottom: 0;
        transition: max-height .35s ease, padding .35s ease;
      }
      .service-card.is-open .service-card-body {
        max-height: none;
        padding-top: 28px; padding-bottom: 28px;
      }
      .service-card-featured { border: none; }
      .service-card-featured::after { display: none; }
      .why .container { grid-template-columns: 1fr; gap: 40px; }
      .service-area .container { grid-template-columns: 1fr; gap: 20px; }
      .area-intro { position: static; }
      .contact .container { grid-template-columns: 1fr; }
      .footer-grid { grid-template-columns: 1fr 1fr; }
    }
    /* Mobile menu, bottom bar, and nav responsive rules moved to nav.css */

    @media (max-width: 960px) {
      body { padding-bottom: 68px; }
    }

    @media (max-width: 640px) {
      :root { --section-pad: 48px 0; }
      .container { padding: 0 20px; }
      /* Center "Book Online Instead" button on mobile */
      .contact-form-header { justify-content: center !important; text-align: center; }
      .contact-form-header .hcp-button { width: 100%; text-align: center; justify-content: center; }
      /* Hero mobile: hide Call Now, show trust icons as 3-across with red circles */
      .hero-call-btn { display: none; }
      .hero-btns { margin-bottom: 32px; }
      .hero-book { width: 100%; text-align: center; justify-content: center; }
      .hero-trust {
        display: grid; grid-template-columns: repeat(3, 1fr);
        gap: 16px; text-align: center;
        margin-top: 8px;
        justify-items: center;
      }
      .hero-trust-item {
        align-items: center; justify-content: flex-start;
      }
      .hero-trust-item strong {
        font-size: 1.8rem;
      }
      .hero-trust-item span {
        font-size: .65rem; line-height: 1.2;
      }
      .hero-trust-item:nth-child(3) { display: none; }
      .hero-trust-icon {
        display: flex; align-items: center; justify-content: center;
        width: 48px; height: 48px; background: var(--red);
        border-radius: 50%; margin: 0 auto 10px;
      }
      .services-head { margin-bottom: 32px; }
      .testimonials-head { margin-bottom: 32px; }
      .form-row { grid-template-columns: 1fr; }
      .footer-grid { grid-template-columns: 1fr; gap: 32px; }
      .footer-brand { text-align: center; }
      .footer-brand a { display: inline-block; }
      .footer-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
      .area-cta-text { display: none; }
      .town-grid { grid-template-columns: repeat(3, 1fr); gap: 6px; }
      .town-pill { padding: 8px 12px; font-size: .75rem; }
      a.town-pill::after { display: none; }
      .town-pill.town-pill-more { display: none; }
      .town-pill.town-pill-more.is-visible { display: block; }
      .area-note.town-pill-more { display: none; }
      .area-note.town-pill-more.is-visible { display: block; }
      .town-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        margin: 12px auto 0;
        padding: 8px 20px;
        background: none;
        border: 1px solid var(--silver);
        border-radius: 4px;
        font-family: var(--font-sub);
        font-weight: 600;
        font-size: .8rem;
        color: var(--text-muted);
        cursor: pointer;
        letter-spacing: .04em;
        transition: all .2s;
      }
      .town-toggle:hover { border-color: var(--navy); color: var(--navy); }
      .town-toggle-chevron { transition: transform .3s ease; }
      .town-toggle.is-open .town-toggle-chevron { transform: rotate(180deg); }
      .town-toggle.is-open .town-toggle-text::after { content: ''; }
      .why-stats { display: none; }
      /* Uniform section padding on mobile */
      .why { padding: 48px 0; }
      .contact { padding: 48px 0; }
      /* Emergency banner redundant with bottom bar */
      .emerg-banner { display: none; }
      .testimonials-grid {
        columns: unset;
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: 0;
        scrollbar-width: none;
        padding-bottom: 8px;
      }
      .testimonials-grid::-webkit-scrollbar { display: none; }
      .testimonial-card {
        flex: 0 0 calc(100% - 16px);
        scroll-snap-align: start;
        margin-bottom: 0;
        margin-right: 16px;
      }
      .testimonial-card:hover { transform: none; }
      .carousel-dots {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-top: 20px;
      }
      .carousel-dot {
        width: 10px; height: 10px;
        border-radius: 50%;
        background: var(--silver);
        border: none; cursor: pointer;
        transition: background .2s;
        padding: 0;
      }
      .carousel-dot.is-active { background: var(--red); }
      .contact-form-wrap { padding: 28px; }
    }

    /* 560px nav rules moved to nav.css */
