:root {
  --ink: #191513;
  --charcoal: #26211e;
  --charcoal-2: #342c27;
  --copper: #a86f4c;
  --copper-light: #d7a783;
  --copper-pale: #ecd3be;
  --ivory: #f8f6f1;
  --paper: #fffefa;
  --line: rgba(87, 61, 45, .18);
  --muted: #6e635d;
  --success: #1f714d;
  --danger: #9a3636;
  --shadow: 0 24px 60px rgba(45, 30, 22, .14);
  --shadow-soft: 0 14px 34px rgba(45, 30, 22, .09);
  --content: 1240px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background-color: var(--ivory);
  background-image:
    linear-gradient(rgba(120, 92, 72, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120, 92, 72, .035) 1px, transparent 1px);
  background-size: 54px 54px;
  font-family: "Avenir Next", Avenir, "Segoe UI", Arial, sans-serif;
  letter-spacing: 0;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  opacity: .48;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 8%, rgba(255,255,255,.95), transparent 32%),
    radial-gradient(circle at 86% 35%, rgba(184,135,98,.11), transparent 23%);
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
:focus-visible { outline: 3px solid var(--copper); outline-offset: 3px; }

.ambient { display: none; }

.top-ribbon {
  min-height: 34px;
  padding: 7px max(20px, calc((100vw - var(--content)) / 2));
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: #f4dfcc;
  background: var(--ink);
  font-size: 12px;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 80;
  min-height: 96px;
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(620px, 1.8fr) auto;
  align-items: center;
  padding-left: max(20px, calc((100vw - var(--content)) / 2));
  background: rgba(255,254,250,.96);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 10px 30px rgba(42,28,20,.06);
  backdrop-filter: blur(16px);
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.brand img { width: 74px; height: 74px; object-fit: contain; }
.brand span { display: grid; }
.brand b {
  color: var(--charcoal);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 24px;
  letter-spacing: 0;
}
.brand small { color: var(--muted); font-size: 11px; }

.site-nav {
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 0 34px 0 64px;
  color: #eee3d9;
  background: var(--charcoal);
  clip-path: polygon(42px 0, 100% 0, 100% 100%, 0 100%, 0 35px);
}
.site-nav a {
  position: relative;
  padding: 14px 11px;
  color: rgba(255,255,255,.82);
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
}
.site-nav a::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 7px;
  height: 2px;
  background: var(--copper-light);
  transform: scaleX(0);
  transition: transform .2s ease;
}
.site-nav a:hover,
.site-nav a.active { color: #fff; }
.site-nav a:hover::after,
.site-nav a.active::after { transform: scaleX(1); }

.header-call {
  height: 96px;
  display: grid;
  place-items: center;
  padding: 0 max(24px, calc((100vw - var(--content)) / 2));
  padding-left: 24px;
  color: #fff;
  background: var(--copper);
  font-weight: 900;
  white-space: nowrap;
}
.nav-toggle { display: none; }

main { overflow: hidden; }
.hero {
  min-height: 830px;
  margin: 0;
  padding: 0;
  background: var(--paper);
}
.mobile-home {
  position: relative;
  min-height: 830px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 440px);
  align-items: end;
  gap: 48px;
  padding: 92px max(28px, calc((100vw - var(--content)) / 2)) 54px;
  overflow: hidden;
  isolation: isolate;
  color: #fff;
  background-image: url('../images/hero-new-era.webp');
  background-size: cover;
  background-position: center;
}
.mobile-home::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: rgba(18,14,12,.45);
}
.mobile-home::after {
  content: "";
  position: absolute;
  inset: 0 36% 0 0;
  z-index: -1;
  background: linear-gradient(90deg, rgba(17,13,11,.94), rgba(17,13,11,.68), transparent);
}
.mobile-home-shade { display: none; }
.mobile-home-copy { align-self: center; max-width: 670px; }
.mobile-home-copy > img {
  width: 116px;
  height: 116px;
  margin-bottom: 24px;
  padding: 8px;
  object-fit: contain;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(255,255,255,.45);
  border-radius: 4px;
}
.eyebrow {
  margin: 0 0 12px;
  color: var(--copper);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}
.mobile-home-copy .eyebrow { color: var(--copper-pale); }
.mobile-home-copy h1,
.page-hero h1 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 500;
  letter-spacing: 0;
}
.mobile-home-copy h1 {
  max-width: 620px;
  font-size: 82px;
  line-height: .96;
}
.mobile-home-copy > p:not(.eyebrow) {
  max-width: 580px;
  margin: 24px 0 0;
  color: rgba(255,255,255,.86);
  font-size: 18px;
  line-height: 1.62;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.btn {
  min-height: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 22px;
  border: 1px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn:disabled { opacity: .62; cursor: wait; transform: none; }
.btn.primary {
  color: #211915;
  background: linear-gradient(135deg, #e5bd9c, #a86f4c);
  box-shadow: 0 16px 34px rgba(103,60,34,.26), inset 0 1px rgba(255,255,255,.55);
}
.btn.secondary {
  color: var(--ink);
  background: var(--paper);
  border-color: var(--line);
}
.mobile-home .btn.secondary { color: #fff; background: rgba(20,16,14,.56); border-color: rgba(255,255,255,.34); }

.mobile-service-links {
  display: grid;
  gap: 10px;
  align-self: end;
}
.mobile-service-links a {
  min-height: 86px;
  display: grid;
  grid-template-columns: 86px 1fr;
  align-items: center;
  overflow: hidden;
  color: var(--ink);
  background: rgba(255,254,250,.94);
  border: 1px solid rgba(215,167,131,.66);
  border-radius: 5px;
  box-shadow: var(--shadow);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 21px;
  transition: transform .2s ease, background .2s ease;
}
.mobile-service-links a:hover { transform: translateX(-8px); background: #fff; }
.mobile-service-links span {
  height: 100%;
  display: grid;
  place-items: center;
  color: var(--copper-pale);
  background: var(--charcoal);
  font-size: 30px;
}

.section {
  width: min(100%, var(--content));
  margin: 0 auto;
  padding: 88px 28px;
}
.section.compact { padding-top: 0; padding-bottom: 42px; }
.section.dark,
.shield-section {
  width: 100%;
  max-width: none;
  padding-left: max(28px, calc((100vw - var(--content)) / 2));
  padding-right: max(28px, calc((100vw - var(--content)) / 2));
  color: #fff;
  background: var(--charcoal);
}
.section-heading {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr) auto;
  align-items: end;
  gap: 28px;
  margin-bottom: 38px;
}
.section-heading h2,
.section h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 60px;
  font-weight: 500;
  line-height: 1.03;
  letter-spacing: 0;
}
.section-heading > a { color: var(--copper); font-weight: 900; }
.section p { line-height: 1.72; }

.metric-row {
  position: relative;
  z-index: 4;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: -32px;
  background: var(--paper);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}
.metric-row div { min-height: 126px; display: grid; place-content: center; padding: 20px 26px; border-right: 1px solid var(--line); }
.metric-row div:last-child { border-right: 0; }
.metric-row strong { font-family: Georgia, "Times New Roman", serif; font-size: 38px; }
.metric-row span { color: var(--muted); font-size: 13px; font-weight: 700; }

.maison-section,
.signature-living,
.craft-section,
.split,
.service-profile,
.concierge,
.contact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 56px;
  align-items: center;
}
.maison-copy p,
.craft-copy p,
.signature-copy p { color: var(--muted); font-size: 17px; }
.maison-proof { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.maison-proof article {
  min-height: 160px;
  padding: 24px;
  background: linear-gradient(145deg, #e6c1a3, #a96f4c);
  border: 1px solid rgba(102,62,38,.28);
  border-radius: 5px;
  box-shadow: var(--shadow-soft), inset 0 1px rgba(255,255,255,.5);
}
.maison-proof article span { display: block; width: 38px; height: 4px; margin-bottom: 16px; background: var(--charcoal); }
.maison-proof article p { margin: 0; color: #231a15; font-weight: 800; }

.service-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 15px;
}
.service-card {
  min-height: 510px;
  display: grid;
  grid-template-rows: 230px 1fr;
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 5px;
  box-shadow: var(--shadow-soft);
}
.service-card img { width: 100%; height: 230px; object-fit: cover; }
.service-card > div { padding: 24px; display: flex; flex-direction: column; }
.service-card h3 { margin: 4px 0 14px; font-family: Georgia, "Times New Roman", serif; font-size: 27px; font-weight: 500; }
.service-card p { margin: 0; color: var(--copper); font-size: 10px; font-weight: 900; text-transform: uppercase; }
.service-card span { color: var(--muted); font-size: 14px; line-height: 1.6; }
.card-link { margin-top: auto; padding-top: 20px; color: var(--copper); font-weight: 900; }

.shield-section {
  display: grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap: 56px;
  align-items: center;
}
.shield-copy h2 { color: #fff; }
.reason-list { display: grid; gap: 14px; margin-top: 26px; }
.reason-list p { margin: 0; display: grid; }
.reason-list b { color: var(--copper-light); }
.reason-list span { color: rgba(255,255,255,.66); }
.shield-mark {
  aspect-ratio: 1;
  display: grid;
  place-content: center;
  text-align: center;
  border: 2px solid var(--copper);
  clip-path: polygon(50% 0, 93% 20%, 86% 77%, 50% 100%, 14% 77%, 7% 20%);
  background: rgba(255,255,255,.04);
}
.shield-mark span { font-family: Georgia, "Times New Roman", serif; font-size: 76px; color: var(--copper-light); }
.shield-mark b { max-width: 140px; margin: auto; font-size: 12px; text-transform: uppercase; }
.shield-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.shield-stats article { min-height: 130px; display: grid; place-content: center; padding: 18px; text-align: center; border: 1px solid rgba(215,167,131,.34); background: rgba(255,255,255,.035); }
.shield-stats strong { color: var(--copper-light); font-size: 34px; }
.shield-stats span { color: rgba(255,255,255,.66); font-size: 12px; }

.timeline { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); background: var(--paper); }
.timeline-step { min-height: 230px; padding: 28px; border-right: 1px solid var(--line); }
.timeline-step:last-child { border-right: 0; }
.timeline-step > span { display: block; color: var(--copper); font-family: Georgia, "Times New Roman", serif; font-size: 42px; }
.timeline-step strong { display: block; margin: 10px 0; font-size: 18px; }
.timeline-step p { margin: 0; color: var(--muted); font-size: 14px; }

.signature-living { align-items: stretch; }
.signature-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.signature-tags span { padding: 9px 12px; border: 1px solid var(--line); background: var(--paper); font-size: 12px; font-weight: 800; }
.signature-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.signature-gallery figure { margin: 0; min-height: 230px; overflow: hidden; }
.signature-gallery .wide { grid-column: 1 / -1; min-height: 310px; }
.signature-gallery img { width: 100%; height: 100%; object-fit: cover; }

.project-rail { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; }
.project-rail article { min-width: 0; background: var(--paper); border: 1px solid var(--line); }
.project-rail img { width: 100%; height: 230px; object-fit: cover; }
.project-rail article div { display: grid; padding: 14px; }
.project-rail span { color: var(--muted); font-size: 12px; }

.craft-image { min-height: 560px; overflow: hidden; }
.craft-image img { width: 100%; height: 100%; min-height: 560px; object-fit: cover; }
.logo-strip,
.partner-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.logo-strip img,
.partner-grid article { min-height: 120px; padding: 18px; background: var(--paper); border: 1px solid var(--line); }
.logo-strip img { width: 100%; height: 120px; object-fit: contain; }
.partner-grid img { width: 100%; height: 110px; object-fit: contain; }

.review-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.review-grid article { min-height: 250px; padding: 25px; background: var(--paper); border: 1px solid var(--line); }
.review-grid article > span { color: var(--copper); }
.review-grid p { color: var(--muted); font-size: 14px; }
.review-grid b { display: block; margin-top: 18px; }
.rating-card { display: grid; place-content: center; text-align: center; color: #fff; background: var(--charcoal) !important; }
.rating-card strong { color: var(--copper-light); font-size: 52px; }

.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.feature-grid > div { padding: 28px; border: 1px solid rgba(215,167,131,.32); background: rgba(255,255,255,.035); }
.feature-grid h3 { color: var(--copper-light); }
.feature-grid p { color: rgba(255,255,255,.7); }

.page-hero {
  position: relative;
  min-height: 500px;
  display: grid;
  align-content: end;
  padding: 72px max(28px, calc((100vw - var(--content)) / 2));
  color: #fff;
  background: var(--charcoal) center/cover no-repeat;
  isolation: isolate;
}
.page-hero::before { content: ""; position: absolute; inset: 0; z-index: -1; background: rgba(22,17,14,.68); }
.page-hero::after { content: ""; position: absolute; inset: 0 45% 0 0; z-index: -1; background: linear-gradient(90deg, rgba(20,15,12,.9), transparent); }
.page-hero h1 { max-width: 900px; font-size: 76px; line-height: .98; }
.page-hero > p:last-child { max-width: 680px; margin: 22px 0 0; color: rgba(255,255,255,.8); font-size: 18px; line-height: 1.6; }
body[data-page="about"] .page-hero,
body[data-page="our-vision"] .page-hero { background-image: url('../images/Home_Remodeling_Fixrus.webp'); }
body[data-page="services"] .page-hero,
body[data-page="our-craft"] .page-hero { background-image: url('../images/hero-new-era.webp'); }
body[data-page="plumbing"] .page-hero { background-image: url('../design/plumbing-hero-clean.webp'); }
body[data-page="electrical"] .page-hero { background-image: url('../design/electrical-hero-clean.webp'); }
body[data-page="hvac"] .page-hero { background-image: url('../design/hvac-hero-clean.webp'); }
body[data-page="remodeling"] .page-hero { background-image: url('../images/bathroom-new-era.webp'); }
body[data-page="gallery"] .page-hero,
body[data-page="recent-spaces"] .page-hero { background-image: url('../images/craft-detail-new-era.webp'); }
body[data-page="awards"] .page-hero { background-image: url('../images/home-exterior-new-era.webp'); }
body[data-page="service-area"] .page-hero { background-image: url('../images/home-exterior-new-era.webp'); }
body[data-page="service-area"] .page-hero h1 { font-size: 64px; }
body[data-page="ai-concierge"] .page-hero { background-image: url('../images/hero-new-era.webp'); }
body[data-page="contact"] .page-hero,
body[data-page="get-your-quote"] .page-hero { background-image: url('../images/Home_Remodeling_Fixrus.webp'); }

.service-profile { align-items: stretch; }
.service-showcase { min-height: 560px; }
.service-showcase img { width: 100%; height: 100%; min-height: 560px; object-fit: cover; }
.service-profile > div:last-child { align-self: center; }
.service-profile p { color: var(--muted); }
.service-feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 24px 0; }
.service-feature-grid span { min-height: 70px; display: grid; align-items: center; padding: 14px 16px; color: #2b211b; background: linear-gradient(145deg, #e7c4a8, #b67c56); border: 1px solid rgba(99,59,35,.22); font-weight: 800; }

.service-detail-list { display: grid; gap: 42px; }
.service-detail { display: grid; grid-template-columns: minmax(340px, .9fr) 1.1fr; gap: 40px; align-items: center; padding-bottom: 42px; border-bottom: 1px solid var(--line); }
.service-detail:nth-child(even) img { order: 2; }
.service-detail img { width: 100%; height: 430px; object-fit: cover; }
.service-detail h2 { font-size: 54px; }
.service-detail li { margin: 8px 0; color: var(--muted); }

.faq-list { display: grid; gap: 9px; max-width: 1000px; }
.faq-list details { background: var(--paper); border: 1px solid var(--line); }
.faq-list summary { padding: 20px 22px; cursor: pointer; font-weight: 900; }
.faq-list details p { margin: 0; padding: 0 22px 22px; color: var(--muted); }
.service-area-note { color: var(--muted); }
.service-area-note a { color: var(--copper); font-weight: 900; }

.filter-bar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.filter-bar button { min-height: 42px; padding: 10px 15px; color: var(--ink); background: var(--paper); border: 1px solid var(--line); cursor: pointer; font-weight: 800; }
.filter-bar button.active { color: #fff; background: var(--charcoal); }
.gallery-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.gallery-card { overflow: hidden; background: var(--paper); border: 1px solid var(--line); }
.gallery-card img { width: 100%; height: 300px; object-fit: cover; transition: transform .4s ease; }
.gallery-card:hover img { transform: scale(1.025); }
.gallery-card div { display: grid; padding: 16px; }
.gallery-card span { color: var(--muted); font-size: 12px; }

.award-carousel { position: relative; }
.carousel-controls { display: flex; justify-content: flex-end; gap: 8px; margin-bottom: 14px; }
.carousel-controls button { width: 46px; height: 46px; color: var(--copper-pale); background: var(--charcoal); border: 1px solid var(--copper); border-radius: 50%; cursor: pointer; font-size: 21px; }
.award-track { display: grid; grid-auto-columns: minmax(240px, 30%); grid-auto-flow: column; gap: 14px; padding: 3px 2px 20px; overflow-x: auto; scroll-snap-type: x mandatory; }
.award-slide { min-height: 320px; display: grid; align-content: space-between; padding: 24px; background: var(--paper); border: 1px solid var(--line); scroll-snap-align: start; }
.award-slide img { width: 100%; height: 230px; object-fit: contain; }

.area-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.area-cloud span { padding: 12px 15px; background: linear-gradient(145deg, #e7c4a8, #b67c56); border: 1px solid rgba(99,59,35,.2); font-weight: 800; }

.assistant-box,
.assistant-result,
.contact-panel,
.lead-form {
  padding: 30px;
  background: var(--paper);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}
.assistant-box label,
.lead-form label { display: grid; gap: 7px; color: var(--ink); font-size: 13px; font-weight: 900; }
input, select, textarea { width: 100%; min-height: 48px; padding: 12px 14px; color: var(--ink); background: #fff; border: 1px solid rgba(87,61,45,.25); border-radius: 3px; }
textarea { resize: vertical; }
.lead-form { display: grid; gap: 14px; }
.contact-panel a { color: var(--copper); font-weight: 900; }
.form-trap { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.form-status { padding: 13px; border: 1px solid currentColor; }
.form-status.success { color: var(--success); background: #eef8f2; }
.form-status.error { color: var(--danger); background: #fff1f1; }
.form-note { color: var(--muted); font-size: 12px; }

.legal-copy { max-width: 920px; }
.legal-copy h2 { margin-top: 34px; font-size: 34px; }
.legal-copy p { color: var(--muted); }

/* ── Unified FAB ─────────────────────────────────────────────────────────── */
.fab-wrap { position: fixed; right: 20px; bottom: 20px; z-index: 200; display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.fab-trigger {
  width: 58px; height: 58px;
  border-radius: 50%;
  background: var(--copper, #a86f4c);
  color: #fff;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(0,0,0,.28);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 900; font-family: inherit;
  transition: background .2s, transform .2s;
  position: relative; z-index: 2;
}
.fab-trigger:hover { background: #8f5c3c; transform: scale(1.07); }
.fab-logo { display: block; transition: opacity .15s, transform .15s; }
.fab-close { display: none; font-size: 1.6rem; line-height: 1; }
.fab-wrap.open .fab-logo { display: none; }
.fab-wrap.open .fab-close { display: block; }
.fab-wrap.open .fab-trigger { background: #555; }

.fab-menu { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.fab-menu[hidden] { display: none; }
.fab-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px 10px 14px;
  border-radius: 28px;
  color: #fff; background: #211b18;
  font: inherit; font-size: 13px; font-weight: 700;
  text-decoration: none; border: none; cursor: pointer;
  box-shadow: 0 3px 12px rgba(0,0,0,.22);
  transition: background .18s, transform .18s;
  white-space: nowrap;
}
.fab-item:hover { transform: translateX(-3px); }
.fab-chat  { background: var(--copper, #a86f4c); }
.fab-call  { background: #1a7f4b; }
.fab-wa    { background: #25d366; }
.fab-callback { background: #2a4fa3; }
.fab-icon { font-size: 16px; line-height: 1; flex-shrink: 0; }
.fab-wa-icon { display: flex; align-items: center; }

/* ── Inline AI Chat Panel ────────────────────────────────────────────────── */
.chat-panel {
  position: fixed; right: 20px; bottom: 90px; z-index: 199;
  width: min(360px, calc(100vw - 32px));
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 8px 40px rgba(0,0,0,.22);
  display: flex; flex-direction: column;
  overflow: hidden;
  max-height: 70vh;
}
.chat-panel[hidden] { display: none; }
.chat-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  background: var(--copper, #a86f4c);
  color: #fff; font-weight: 700; font-size: .95rem;
}
.chat-close {
  background: none; border: none; color: #fff;
  font-size: 22px; line-height: 1; cursor: pointer; padding: 2px 6px;
}
.chat-messages {
  flex: 1; overflow-y: auto; padding: 14px 14px 8px;
  display: flex; flex-direction: column; gap: 10px;
  background: #f7f4f1;
}
.chat-msg { max-width: 90%; }
.chat-ai  { align-self: flex-start; }
.chat-user { align-self: flex-end; }
.chat-ai  p { background: #fff; color: #211b18; border-radius: 0 12px 12px 12px; padding: 10px 13px; margin: 0; font-size: .88rem; line-height: 1.55; box-shadow: 0 1px 4px rgba(0,0,0,.08); }
.chat-user p { background: var(--copper, #a86f4c); color: #fff; border-radius: 12px 12px 0 12px; padding: 10px 13px; margin: 0; font-size: .88rem; line-height: 1.55; }
.chat-thinking p { background: #e8e2db; color: #666; font-style: italic; border-radius: 0 12px 12px 12px; padding: 10px 13px; margin: 0; font-size: .85rem; }
.chat-input-row { display: flex; gap: 8px; padding: 10px 12px; background: #fff; border-top: 1px solid #e8e2db; }
.chat-input-row textarea { flex: 1; resize: none; border: 1px solid #d5ccc5; border-radius: 8px; padding: 8px 10px; font: inherit; font-size: .85rem; color: #211b18; }
.chat-input-row textarea:focus { outline: none; border-color: var(--copper, #a86f4c); }
.chat-send { padding: 8px 14px; font-size: .82rem; border-radius: 8px; white-space: nowrap; flex-shrink: 0; }
.chat-note { margin: 0; padding: 6px 12px 8px; font-size: .72rem; color: #888; background: #fff; border-top: 1px solid #f0ebe6; text-align: center; }
.chat-note a { color: var(--copper, #a86f4c); }

.site-footer {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 42px;
  padding: 64px max(28px, calc((100vw - var(--content)) / 2));
  color: rgba(255,255,255,.68);
  background: var(--ink);
}
.site-footer img { width: 120px; margin-bottom: 14px; padding: 8px; background: #fff; }
.site-footer strong { display: block; margin-bottom: 12px; color: var(--copper-light); }
.site-footer a { display: block; margin: 8px 0; color: rgba(255,255,255,.76); }

.consent-banner,
.callback-drawer {
  position: fixed;
  z-index: 100;
  color: #fff;
  background: var(--charcoal);
  border: 1px solid rgba(215,167,131,.45);
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
}
.consent-banner { left: 18px; bottom: 18px; width: min(440px, calc(100vw - 36px)); padding: 22px; }
.consent-banner[hidden], .callback-drawer[hidden] { display: none; }
.consent-banner h2, .callback-drawer h2 { margin: 0 0 8px; font-family: Georgia, "Times New Roman", serif; font-size: 25px; }
.consent-banner p, .callback-drawer p { color: rgba(255,255,255,.72); font-size: 13px; line-height: 1.55; }
.consent-actions { display: flex; gap: 8px; margin-top: 15px; }
.consent-actions button { min-height: 42px; padding: 10px 13px; color: #fff; background: var(--copper); border: 1px solid var(--copper); cursor: pointer; font-weight: 800; }
.consent-actions button:last-child { background: transparent; border-color: rgba(255,255,255,.3); }
.callback-drawer { right: 18px; bottom: 18px; width: min(390px, calc(100vw - 36px)); padding: 25px; }
.callback-drawer form { display: grid; gap: 10px; }
.callback-drawer label { display: grid; gap: 5px; font-size: 12px; font-weight: 800; }
.callback-drawer small { color: rgba(255,255,255,.58); font-size: 10px; line-height: 1.5; }
.callback-drawer .drawer-close { position: absolute; top: 10px; right: 10px; width: 36px; height: 36px; color: #fff; background: transparent; border: 0; cursor: pointer; font-size: 22px; }

@media (max-width: 1120px) {
  .site-header { grid-template-columns: 1fr auto; padding: 10px 18px; min-height: 80px; }
  .brand img { width: 60px; height: 60px; }
  .nav-toggle { display: inline-flex; min-height: 44px; padding: 10px 14px; color: #fff; background: var(--charcoal); border: 1px solid var(--copper); cursor: pointer; font-weight: 900; }
  .site-nav { position: absolute; top: 80px; left: 0; right: 0; height: auto; display: none; align-items: stretch; padding: 18px; flex-direction: column; clip-path: none; }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 11px 14px; }
  .header-call { display: none; }
  .mobile-home { grid-template-columns: 1fr 370px; }
  .mobile-home-copy h1 { font-size: 66px; }
  .section-heading h2, .section h2 { font-size: 50px; }
  .page-hero h1 { font-size: 62px; }
  .service-detail h2 { font-size: 48px; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .shield-section { grid-template-columns: 1fr 260px; }
  .shield-stats { grid-column: 1 / -1; grid-template-columns: repeat(4, 1fr); }
  .project-rail { grid-template-columns: repeat(3, 1fr); }
  .review-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 760px) {
  .top-ribbon { justify-content: center; text-align: center; }
  .top-ribbon span:last-child { display: none; }
  .brand span { display: none; }
  .mobile-home { min-height: 980px; grid-template-columns: 1fr; align-content: space-between; gap: 40px; padding: 58px 20px 34px; background-position: 62% center; }
  .mobile-home::after { inset: 0; background: rgba(18,14,12,.65); }
  .mobile-home-copy > img { width: 90px; height: 90px; }
  .mobile-home-copy h1 { font-size: 48px; }
  .mobile-service-links a { min-height: 64px; grid-template-columns: 62px 1fr; font-size: 17px; }
  .section { padding: 64px 20px; }
  .section-heading { grid-template-columns: 1fr; gap: 10px; }
  .section-heading h2, .section h2 { font-size: 42px; }
  .metric-row { grid-template-columns: 1fr 1fr; margin-top: 0; }
  .metric-row div:nth-child(2) { border-right: 0; }
  .maison-section, .signature-living, .craft-section, .split, .service-profile, .concierge, .contact-grid { grid-template-columns: 1fr; gap: 34px; }
  .maison-proof { grid-template-columns: 1fr; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 0; }
  .shield-section { grid-template-columns: 1fr; }
  .shield-mark { width: 230px; margin: auto; }
  .shield-stats { grid-column: auto; grid-template-columns: 1fr 1fr; }
  .timeline { grid-template-columns: 1fr; }
  .timeline-step { min-height: 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .project-rail, .review-grid, .feature-grid, .gallery-grid, .partner-grid, .logo-strip { grid-template-columns: 1fr; }
  .service-detail { grid-template-columns: 1fr; }
  .service-detail:nth-child(even) img { order: 0; }
  .service-detail img { height: 320px; }
  .service-feature-grid { grid-template-columns: 1fr; }
  .page-hero { min-height: 430px; padding: 54px 20px; }
  .page-hero h1 { font-size: 50px; }
  .award-track { grid-auto-columns: 86%; }
  .site-footer { grid-template-columns: 1fr; padding: 54px 20px 110px; }
  .fab-wrap { right: 12px; bottom: 12px; }
  .fab-trigger { width: 52px; height: 52px; }
  .chat-panel { right: 12px; bottom: 76px; width: calc(100vw - 24px); max-height: 65vh; }
  .consent-banner { left: 10px; bottom: 80px; width: calc(100vw - 20px); }
  .callback-drawer { right: 10px; bottom: 80px; width: calc(100vw - 20px); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition: none !important; animation: none !important; }
}

/* Authoritative copper / marble design system */
:root {
  --ink: #171412;
  --charcoal: #292827;
  --charcoal-2: #373431;
  --copper: #a76743;
  --copper-light: #d59b72;
  --copper-pale: #efd4bd;
  --teal: #0e2a2b;
  --teal-light: #62d4d4;
  --ivory: #f4f2ee;
  --paper: #fcfbf8;
  --line: rgba(108, 64, 39, .24);
  --muted: #665f5a;
  --shadow: 0 24px 58px rgba(42, 28, 20, .16);
  --shadow-soft: 0 14px 32px rgba(42, 28, 20, .1);
}

body {
  background-color: var(--ivory);
  background-image:
    linear-gradient(112deg, transparent 0 46%, rgba(143, 126, 113, .055) 47%, transparent 49%),
    linear-gradient(68deg, transparent 0 63%, rgba(255, 255, 255, .84) 64%, transparent 66%);
  background-size: 360px 360px, 480px 480px;
}
body::before { display: none; }
.top-ribbon { color: var(--copper-pale); background: #1d1c1b; border-bottom: 1px solid rgba(213,155,114,.28); }

.site-header {
  min-height: 92px;
  grid-template-columns: minmax(210px, 1fr) minmax(520px, 1.55fr) auto;
  padding-left: max(18px, calc((100vw - var(--content)) / 2));
  background: rgba(252,251,248,.97);
}
.brand { height: 92px; gap: 7px; overflow: hidden; }
.brand-name { display: grid; }
.brand-name b { color: #5d321e; font-size: 23px; text-transform: uppercase; }
.brand-name small { color: #625b56; }
.copper-logo {
  position: relative;
  width: 82px;
  height: 82px;
  flex: 0 0 82px;
  overflow: hidden;
  background: #fff url('../images/logo_1.webp') center / contain no-repeat;
  filter: sepia(.85) saturate(.8) contrast(1.05);
}
.site-nav {
  height: 92px;
  gap: 12px;
  padding: 0 42px 0 70px;
  background: #2b2a29;
  clip-path: polygon(44px 0, 100% 0, 100% 100%, 0 100%, 0 40px);
}
.site-nav a { color: rgba(255,255,255,.8); font-size: 14px; font-weight: 650; }
.site-nav a::after { background: var(--copper-light); }
.header-call { height: 92px; background: linear-gradient(145deg, #c9875d, #825037); }

.service-dock {
  position: relative;
  z-index: 45;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: 920px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 0;
  box-shadow: var(--shadow-soft);
}
.service-dock a {
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 8px 12px;
  border-right: 1px solid var(--line);
  color: #4d3427;
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}
.service-dock a:last-child { border-right: 0; }
.service-dock span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  color: var(--copper-pale);
  background: var(--charcoal);
  border: 1px solid var(--copper);
  border-radius: 50%;
  font-family: Georgia, serif;
}
.service-dock a:hover { color: #fff; background: var(--teal); }

.hero { min-height: 760px; background: transparent; }
.mobile-home {
  min-height: 760px;
  grid-template-columns: minmax(340px, .82fr) minmax(480px, 1.18fr);
  grid-template-areas: "copy art" "links links";
  align-items: center;
  gap: 18px 48px;
  padding: 52px max(28px, calc((100vw - var(--content)) / 2)) 34px;
  color: var(--ink);
  background: transparent;
}
.mobile-home::before {
  background: linear-gradient(125deg, rgba(255,255,255,.92), rgba(236,229,222,.42));
  opacity: 1;
}
.mobile-home::after { inset: 0; background: rgba(252,251,248,.58); }
.mobile-home-copy { grid-area: copy; position: relative; z-index: 2; }
.mobile-home-copy > img { display: none; }
.mobile-home-copy .eyebrow { color: var(--copper); }
.mobile-home-copy h1 { color: #211d1a; font-size: 76px; line-height: .94; text-transform: uppercase; }
.mobile-home-copy > p:not(.eyebrow) { color: #5f5751; }
.mobile-home .btn.secondary { color: var(--ink); background: rgba(255,255,255,.78); border-color: var(--line); }
.home-hero-art { grid-area: art; position: relative; z-index: 1; min-width: 0; }
.home-hero-art img { width: 100%; max-height: 540px; object-fit: contain; filter: drop-shadow(0 22px 28px rgba(45,29,20,.18)); }
.mobile-service-links { grid-area: links; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.mobile-service-links a {
  min-height: 74px;
  grid-template-columns: 64px 1fr;
  background: rgba(255,255,255,.9);
  border-color: var(--copper);
  font-family: "Avenir Next", Avenir, sans-serif;
  font-size: 15px;
  font-weight: 850;
}
.mobile-service-links a:hover { color: #fff; background: var(--teal); transform: translateY(-4px); }
.mobile-service-links span { color: var(--copper-light); background: #292827; }

.metric-row { border-color: var(--copper); }
.metric-row strong { color: #714028; }
.maison-proof article,
.service-feature-grid span,
.area-cloud span { background: linear-gradient(145deg, #dfad89, #a96843); }
.service-card { border-color: rgba(167,103,67,.38); }
.service-card > div { background: linear-gradient(180deg, #fff, #f4f0ea); }
.service-card h3 { color: #442a1d; }
.card-link { color: #875036; }
.shield-section,
.section.dark { background: #21201f; }
.shield-mark { border-color: var(--teal-light); background: rgba(14,42,43,.76); }
.shield-mark span { color: var(--copper-light); }
.timeline { border: 2px solid var(--copper); box-shadow: var(--shadow-soft); }
.timeline-step > span { color: var(--copper); }
.timeline-step::after { content: ""; display: block; width: 54px; height: 3px; margin-top: 18px; background: var(--teal-light); }
.project-rail article,
.gallery-card,
.award-slide,
.review-grid article { border-color: rgba(167,103,67,.35); }
.partner-grid article,
.logo-strip img { background: rgba(255,255,255,.88); }

.page-hero {
  min-height: 600px;
  grid-template-columns: minmax(320px, .82fr) minmax(440px, 1.18fr);
  grid-template-areas: "eyebrow art" "title art" "copy art";
  align-content: center;
  gap: 12px 52px;
  padding-top: 70px;
  padding-bottom: 70px;
  color: var(--ink);
  background: transparent !important;
}
.page-hero::before {
  background: linear-gradient(120deg, rgba(255,255,255,.92), rgba(246,242,237,.76));
}
.page-hero::after { display: none; }
.page-hero > .eyebrow { grid-area: eyebrow; align-self: end; }
.page-hero > h1 { grid-area: title; color: #28221e; font-size: 66px; line-height: .96; text-transform: uppercase; }
.page-hero > p:last-of-type { grid-area: copy; align-self: start; color: #615852; }
.page-art {
  grid-area: art;
  position: relative;
  min-width: 0;
  height: 470px;
  overflow: hidden;
  background-position: center;
  background-repeat: no-repeat;
  filter: drop-shadow(0 22px 30px rgba(53,33,22,.17));
}
.page-art img { width: 100%; height: 100%; object-fit: contain; }
.vision-art img, .services-art img, .portfolio-art img, .contact-art img { object-fit: cover; border: 7px solid rgba(167,103,67,.18); }
.plumbing-art img, .electrical-art img, .hvac-art img, .remodeling-art img, .ai-art img { object-fit: cover; object-position: center; }
.awards-art img,
.area-art img { width: 100%; height: 100%; object-fit: cover; border: 7px solid rgba(167,103,67,.18); }
.ai-art img { transform: scale(1.08); }
body[data-page="privacy"] .page-hero,
body[data-page="not-found"] .page-hero { grid-template-columns: 1fr; grid-template-areas: "eyebrow" "title" "copy"; }

.service-profile { position: relative; }
.service-showcase { border: 10px solid rgba(167,103,67,.2); box-shadow: var(--shadow); }
.service-showcase img { filter: saturate(.78) contrast(1.04); }
.service-feature-grid span { border-color: rgba(70,39,23,.35); }
.service-detail { background: rgba(255,255,255,.54); padding: 28px; border: 1px solid var(--line); }
.service-detail img { border: 6px solid rgba(167,103,67,.16); }
.filter-bar button { border-color: var(--copper); }
.filter-bar button.active { background: var(--teal); }

body[data-page="gallery"] main,
body[data-page="recent-spaces"] main { color: #fff; background: #081718; }
body[data-page="gallery"] .page-hero::before,
body[data-page="recent-spaces"] .page-hero::before { background: linear-gradient(120deg, rgba(7,20,21,.94), rgba(11,36,37,.7)); }
body[data-page="gallery"] .page-hero > h1,
body[data-page="recent-spaces"] .page-hero > h1 { color: #fff; }
body[data-page="gallery"] .page-hero > p:last-of-type,
body[data-page="recent-spaces"] .page-hero > p:last-of-type { color: rgba(255,255,255,.72); }
body[data-page="gallery"] .gallery-card,
body[data-page="recent-spaces"] .gallery-card { color: #fff; background: #122425; border-color: var(--copper); cursor: pointer; }
body[data-page="gallery"] .gallery-card span,
body[data-page="recent-spaces"] .gallery-card span { color: rgba(255,255,255,.62); }

/* Gallery lightbox */
.gallery-card { cursor: pointer; }
.lb-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.92);
  align-items: center;
  justify-content: center;
}
.lb-overlay.open { display: flex; }
.lb-overlay img {
  max-width: min(1200px, 96vw);
  max-height: 92vh;
  object-fit: contain;
  border: 3px solid var(--copper);
  box-shadow: 0 30px 80px rgba(0,0,0,.7);
}
.lb-close {
  position: absolute;
  top: 18px;
  right: 22px;
  background: none;
  border: none;
  color: #fff;
  font-size: 38px;
  cursor: pointer;
  line-height: 1;
  opacity: .8;
}
.lb-close:hover { opacity: 1; }
.lb-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 18px 24px;
  background: linear-gradient(transparent, rgba(0,0,0,.85));
  color: #fff;
  font-size: 15px;
  text-align: center;
}
.lb-prev, .lb-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(168,111,76,.7);
  border: none;
  color: #fff;
  font-size: 28px;
  padding: 10px 18px;
  cursor: pointer;
  border-radius: 4px;
}
.lb-prev { left: 14px; }
.lb-next { right: 14px; }
.lb-prev:hover, .lb-next:hover { background: var(--copper); }

/* Tankless / Water Heater specialist section */
.tankless-section {
  background: linear-gradient(135deg, #041620 0%, #082030 40%, #0a1a2e 100%);
  color: #fff;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  overflow: hidden;
  min-height: 440px;
  margin: 0 calc(-1 * max(20px, calc((100vw - var(--content)) / 2)));
  padding: 0 max(20px, calc((100vw - var(--content)) / 2));
}
.tankless-visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: radial-gradient(ellipse at center, rgba(0,100,180,.18), transparent 70%);
  overflow: hidden;
  min-height: 380px;
}
.tankless-visual img { width: 100%; height: 100%; object-fit: cover; opacity: .85; }
.tankless-badge {
  position: absolute;
  bottom: 28px;
  left: 28px;
  background: rgba(0,0,0,.7);
  border: 1px solid rgba(96,196,196,.35);
  color: #fff;
  padding: 10px 16px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}
.tankless-badge-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #29b6d4, #0e6070);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}
.tankless-copy {
  padding: 56px 48px;
  display: grid;
  align-content: center;
  gap: 16px;
}
.tankless-copy .eyebrow { color: #29b6d4; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }
.tankless-copy h2 {
  font-family: Georgia, serif;
  font-size: 42px;
  line-height: 1.1;
  color: #fff;
  margin: 0;
}
.tankless-copy h2 span { color: #29b6d4; }
.tankless-copy p { color: rgba(255,255,255,.78); line-height: 1.65; margin: 0; }
.tankless-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 20px;
}
.tankless-feature {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
}
.tankless-feature-icon {
  width: 30px;
  height: 30px;
  border: 1px solid rgba(41,182,212,.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
}
.tankless-feature span { color: rgba(255,255,255,.85); }
.tankless-feature b { display: block; font-size: 12px; color: rgba(255,255,255,.5); }
.tankless-cta { margin-top: 8px; }
.tankless-cta .btn { background: #c59620; color: #fff; border-color: #c59620; font-weight: 700; letter-spacing: .05em; }
.tankless-cta .btn:hover { background: #e8b82a; border-color: #e8b82a; }

/* Signature tankless banner */
.tankless-banner {
  background: linear-gradient(135deg, #08111a 0%, #0d1e2e 50%, #0a1520 100%);
  color: #fff;
  padding: 80px max(20px, calc((100vw - var(--content)) / 2));
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 60px;
  align-items: center;
}
.tankless-banner-visual img {
  width: 100%;
  max-height: 360px;
  object-fit: contain;
  filter: drop-shadow(0 20px 50px rgba(197,150,32,.25));
}
.tankless-banner-copy { display: grid; gap: 18px; }
.tankless-banner-copy .eyebrow { color: rgba(197,150,32,.7); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; }
.tankless-banner-copy h2 { font-family: Georgia, serif; font-size: 52px; line-height: 1.05; margin: 0; }
.tankless-banner-copy h2 em { color: #c59620; font-style: normal; display: block; }
.tankless-banner-subtitle { font-size: 20px; font-weight: 600; color: rgba(255,255,255,.9); }
.tankless-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 24px; }
.tankless-check { font-size: 14px; color: rgba(255,255,255,.82); display: flex; align-items: center; gap: 8px; }
.tankless-check::before { content: "✓"; color: #c59620; font-weight: 700; }
.tankless-learn-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  border: 2px solid rgba(255,255,255,.6);
  color: #fff;
  padding: 14px 28px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  transition: border-color .25s, background .25s;
  margin-top: 4px;
}
.tankless-learn-btn:hover { border-color: #fff; background: rgba(255,255,255,.08); }
.tankless-badge-round {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  border: 2px solid #c59620;
  background: radial-gradient(circle, #12233a, #08111a);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #c59620;
  line-height: 1.3;
  margin-bottom: 8px;
}

/* Footer bottom bar */
.footer-bar {
  background: #111;
  color: rgba(255,255,255,.5);
  font-size: 12px;
  text-align: center;
  padding: 14px 20px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer-bar a { color: var(--copper-light); text-decoration: underline; }

.contact-grid { align-items: stretch; }
.contact-panel,
.lead-form,
.assistant-box,
.assistant-result {
  background: rgba(14,42,43,.97);
  border: 2px solid var(--copper);
  box-shadow: 0 20px 48px rgba(14,42,43,.22), inset 0 0 0 6px rgba(213,155,114,.08);
  color: #fff;
}
.contact-panel h2,
.contact-panel strong,
.lead-form label,
.assistant-box label { color: #fff; }
.contact-panel a { color: var(--copper-light); }
.lead-form input,
.lead-form select,
.lead-form textarea,
.assistant-box textarea {
  color: #fff;
  background: #142a29;
  border-color: var(--copper);
}
.lead-form option { color: #fff; background: var(--teal); }
.contact-time { display: flex; flex-wrap: wrap; gap: 12px 20px; margin: 0; padding: 14px; border: 1px solid rgba(213,155,114,.45); }
.contact-time legend { padding: 0 7px; color: var(--copper-light); font-weight: 800; }
.contact-time label { display: flex; grid-template-columns: auto 1fr; align-items: center; gap: 6px; }
.contact-time input { width: auto; min-height: 0; }
.lead-form .form-note { color: rgba(255,255,255,.66); }

.chat-panel { background: #1a1a1a; }
.chat-header { background: #8f5c3c; }
.chat-messages { background: #242424; }
.chat-ai p { background: #2e2e2e; color: #e8ddd4; }
.chat-input-row { background: #1a1a1a; border-top-color: #333; }
.chat-input-row textarea { background: #2a2a2a; border-color: #444; color: #e8ddd4; }
.chat-note { background: #1a1a1a; border-top-color: #333; color: #888; }
.site-footer { background: #1d1c1b; border-top: 3px solid var(--copper); }
.site-footer img { filter: sepia(1) saturate(.7); }
.footer-logo { display: flex !important; align-items: center; gap: 8px; }
.footer-logo .copper-logo { width: 82px; height: 82px; flex-basis: 82px; }
.footer-logo strong { margin: 0; color: var(--copper-light); font-family: Georgia, serif; font-size: 24px; }

@media (max-width: 760px) {
  body[data-page="service-area"] .page-hero h1 { min-width: 0; font-size: 50px; }
  .tankless-section, .tankless-banner { grid-template-columns: 1fr; }
  .tankless-visual { min-height: 260px; }
  .tankless-copy { padding: 36px 24px; }
  .tankless-copy h2 { font-size: 30px; }
  .tankless-banner-copy h2 { font-size: 36px; }
  .tankless-features, .tankless-checks { grid-template-columns: 1fr; }
  .lb-prev, .lb-next { display: none; }
}

@media (max-width: 1120px) {
  .site-header { grid-template-columns: 1fr auto; }
  .site-nav { top: 92px; background: #292827; }
  .mobile-home { grid-template-columns: .8fr 1.2fr; }
  .mobile-home-copy h1 { font-size: 60px; }
  .page-hero { grid-template-columns: .85fr 1.15fr; }
  .page-hero > h1 { font-size: 54px; }
}

@media (max-width: 760px) {
  .site-header { min-height: 76px; }
  .brand { height: 76px; }
  .copper-logo { width: 68px; height: 68px; flex-basis: 68px; }
  .site-nav { top: 76px; }
  .service-dock { grid-template-columns: repeat(4, 1fr); overflow-x: auto; }
  .service-dock a { min-width: 92px; padding: 7px 5px; font-size: 9px; }
  .service-dock span { width: 22px; height: 22px; }
  .mobile-home {
    min-height: auto;
    grid-template-columns: 1fr;
    grid-template-areas: "copy" "art" "links";
    padding: 52px 20px 28px;
  }
  .mobile-home-copy h1 { font-size: 45px; }
  .home-hero-art img { max-height: 390px; }
  .mobile-service-links { grid-template-columns: 1fr 1fr; }
  .mobile-service-links a { min-height: 58px; grid-template-columns: 48px 1fr; font-size: 12px; }
  .page-hero {
    min-height: auto;
    grid-template-columns: 1fr;
    grid-template-areas: "eyebrow" "title" "copy" "art";
    gap: 10px;
    padding: 52px 20px 28px;
  }
  .page-hero > h1 { font-size: 44px; }
  .page-art { height: 350px; margin-top: 20px; }
  .vision-art, .services-art { background-size: 230% auto; }
  .electrical-art { background-size: 270% auto; }
  .portfolio-art { background-size: 175% auto; }
  .contact-art { background-size: 220% auto; }
  .contact-time { display: grid; grid-template-columns: 1fr 1fr; }
}

/* ── Maintenance Plan page ───────────────────────────────────────────────── */
.maint-plan-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: 1rem; }
.maint-card { background: var(--surface, #f7f4f1); border: 1px solid var(--line, #e8ddd4); border-radius: 8px; padding: 2rem; }
.maint-icon { font-size: 2.5rem; margin-bottom: 1rem; }
.maint-card h3 { font-size: 1.2rem; margin: 0 0 1rem; color: var(--ink, #211b18); }
.maint-card ul { margin: 0; padding-left: 1.2rem; display: flex; flex-direction: column; gap: .5rem; }
.maint-card li { font-size: .9rem; color: var(--muted, #555); line-height: 1.5; }
@media (max-width: 860px) { .maint-plan-grid { grid-template-columns: 1fr; } }

/* ── Cost Estimator ──────────────────────────────────────────────────────── */
.estimator-wrap { max-width: 700px; margin: 0 auto; }
.estimator-step { display: none; }
.estimator-step.active { display: block; }
.est-options { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; margin: 1.5rem 0; }
@media (max-width: 500px) { .est-options { grid-template-columns: 1fr; } }
.est-opt {
  display: flex; align-items: center; gap: .75rem;
  padding: 1rem 1.25rem;
  border: 2px solid var(--line, #e8ddd4);
  border-radius: 8px; cursor: pointer;
  background: #fff; font: inherit; font-size: .95rem; font-weight: 600;
  color: var(--ink, #211b18);
  transition: border-color .18s, background .18s;
  text-align: left;
}
.est-opt:hover, .est-opt.selected { border-color: var(--copper, #a86f4c); background: #fdf8f5; }
.est-opt-icon { font-size: 1.5rem; flex-shrink: 0; }
.est-back { background: none; border: none; cursor: pointer; color: var(--copper, #a86f4c); font: inherit; font-size: .9rem; font-weight: 700; padding: 0; margin-bottom: 1.5rem; }
.est-back:hover { text-decoration: underline; }
.est-result {
  background: var(--ink, #211b18); color: #e8ddd4;
  border-radius: 10px; padding: 2rem 2.5rem; margin-top: 1.5rem;
  text-align: center;
}
.est-result .est-range { font-size: 2.5rem; font-weight: 900; color: var(--copper-light, #c9986a); display: block; margin: .5rem 0; }
.est-result p { font-size: .9rem; color: rgba(255,255,255,.7); margin: .5rem 0 0; }
.est-result .btn { margin-top: 1.5rem; }
.est-disclaimer { font-size: .8rem; color: var(--muted, #888); margin-top: 1rem; text-align: center; }

/* ── Before/After Slider ─────────────────────────────────────────────────── */
.ba-section { text-align: center; }
.ba-slider {
  position: relative;
  width: 100%;
  max-width: 860px;
  margin: 2rem auto 0;
  aspect-ratio: 16/9;
  overflow: hidden;
  border-radius: 10px;
  box-shadow: 0 6px 32px rgba(0,0,0,.18);
  cursor: ew-resize;
  user-select: none;
  touch-action: pan-y;
}
.ba-before, .ba-after {
  position: absolute; inset: 0;
  pointer-events: none;
}
.ba-before img, .ba-after img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.ba-before { clip-path: inset(0 50% 0 0); }
.ba-after  { clip-path: inset(0 0 0 50%); }
.ba-handle {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center;
  width: 44px;
  pointer-events: none;
  z-index: 4;
}
.ba-range {
  position: absolute;
  inset: 0;
  z-index: 5;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: ew-resize;
}
.ba-range:focus-visible { opacity: .01; outline: 3px solid #fff; outline-offset: -5px; }
.ba-handle-line { flex: 1; width: 2px; background: #fff; opacity: .85; }
.ba-handle-circle {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: #333;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
  flex-shrink: 0;
}
.ba-label {
  position: absolute; bottom: 14px;
  background: rgba(0,0,0,.55);
  color: #fff; font-size: .75rem; font-weight: 700;
  padding: 4px 10px; border-radius: 4px;
  pointer-events: none; letter-spacing: .06em; text-transform: uppercase;
}
.ba-label-before { left: 14px; }
.ba-label-after  { right: 14px; }
@media (max-width: 640px) { .ba-slider { aspect-ratio: 4/3; } }

/* ── Review platform links ───────────────────────────────────────────────── */
.review-platform-links {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1.5rem;
  margin-top: .6rem;
}
.review-platform-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: #a86f4c;
  font-size: .95rem;
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .2s;
}
.review-platform-link:hover { border-bottom-color: #a86f4c; }
.google-stars { color: #f4b400; font-size: 1rem; letter-spacing: .05em; }

/* ── Financing section ───────────────────────────────────────────────────── */
.financing-section {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 3rem;
  align-items: center;
}
.financing-copy h2 { margin-bottom: .75rem; }
.financing-points { margin: 1.5rem 0; display: flex; flex-direction: column; gap: .9rem; }
.financing-points p { display: grid; grid-template-columns: auto 1fr; gap: .25rem .75rem; margin: 0; }
.financing-points b { grid-column: 1; font-weight: 700; color: #191513; }
.financing-points span { grid-column: 2; color: #555; font-size: .9rem; }
.financing-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  background: #191513;
  color: #e0c9b0;
  border-radius: 50%;
  width: 180px;
  height: 180px;
  text-align: center;
  flex-shrink: 0;
}
.financing-badge span { font-size: 2rem; font-weight: 900; color: #a86f4c; }
.financing-badge b { font-size: .85rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.financing-badge small { font-size: .7rem; color: #888; }
@media (max-width: 640px) {
  .financing-section { grid-template-columns: 1fr; }
  .financing-badge { display: none; }
}

/* ── Service map ─────────────────────────────────────────────────────────── */
.service-map-wrapper {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.12);
  margin-top: 1.5rem;
}
