@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── Design Tokens ── */
:root {
  --ink:       #1A1A18;
  --ink-mid:   #3C3C38;
  --ink-lite:  #6E6E68;
  --cream:     #FAF8F4;
  --warm:      #F4EFE6;
  --sand:      #E8DFD0;
  --terra:     #C05A28;
  --terra-lt:  #D4713E;
  --terra-bg:  #FBF0EB;
  --white:     #FFFFFF;
  --green:     #2E6B3E;

  --ff-serif:  'Playfair Display', Georgia, serif;
  --ff-sans:   'DM Sans', system-ui, sans-serif;

  --r:   10px;
  --r-lg: 18px;
  --r-xl: 28px;

  --sh:    0 2px 12px rgba(26,26,24,.08);
  --sh-md: 0 6px 28px rgba(26,26,24,.12);
  --sh-lg: 0 16px 56px rgba(26,26,24,.18);

  --w: 1160px;
  --gap: clamp(16px,3vw,40px);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth }
body { font-family:var(--ff-sans); background:var(--cream); color:var(--ink); line-height:1.65; overflow-x:hidden }
img  { display:block; max-width:100% }
a    { text-decoration:none; color:inherit }
ul   { list-style:none }
button { font-family:var(--ff-sans); cursor:pointer; background:none; border:none }

/* grain overlay */
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9998;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.022
}

/* ── Layout ── */
.wrap         { max-width:var(--w); margin:0 auto; padding:0 var(--gap) }
.section      { padding:clamp(56px,7vw,96px) 0 }
.section-warm { background:var(--warm) }
.section-sand { background:var(--sand) }
.section-dark { background:var(--ink); color:var(--white) }

/* ── Typography ── */
.eyebrow {
  font-size:11px; font-weight:600; letter-spacing:3.5px; text-transform:uppercase;
  color:var(--terra); margin-bottom:12px; display:flex; align-items:center; gap:10px
}
.eyebrow::before { content:''; width:24px; height:2px; background:currentColor; border-radius:2px; flex-shrink:0 }
.eyebrow-light { color:rgba(255,255,255,.5) }
.eyebrow-light::before { background:rgba(255,255,255,.35) }

h1,h2,h3,h4 { font-family:var(--ff-serif); line-height:1.1 }
.display { font-size:clamp(36px,5.5vw,68px); font-family:var(--ff-serif); line-height:1.07 }
.h2      { font-size:clamp(26px,3.5vw,44px) }
.h3      { font-size:clamp(20px,2.5vw,30px) }
.lead    { font-size:clamp(16px,1.5vw,19px); color:var(--ink-lite); line-height:1.8 }
.body    { font-size:15px; color:var(--ink-lite); line-height:1.8 }
.text-terra  { color:var(--terra) }

/* ── Buttons ── */
.btn-cta {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--terra); color:var(--white);
  font-size:14px; font-weight:600; font-family:var(--ff-sans);
  padding:13px 26px; border-radius:100px; border:none;
  transition:background .2s,transform .2s,box-shadow .2s;
  white-space:nowrap; box-shadow:0 4px 16px rgba(192,90,40,.3)
}
.btn-cta:hover { background:var(--terra-lt); transform:translateY(-2px); box-shadow:0 8px 24px rgba(192,90,40,.4) }
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; border:1.5px solid var(--ink); color:var(--ink);
  font-size:14px; font-weight:600; font-family:var(--ff-sans);
  padding:12px 24px; border-radius:100px;
  transition:background .2s,color .2s
}
.btn-outline:hover { background:var(--ink); color:var(--white) }
.btn-outline-light {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; border:1.5px solid rgba(255,255,255,.4); color:var(--white);
  font-size:14px; font-weight:600; font-family:var(--ff-sans);
  padding:12px 24px; border-radius:100px;
  transition:background .2s,color .2s
}
.btn-outline-light:hover { background:var(--white); color:var(--ink) }

/* ── Topbar ── */
.topbar { background:var(--ink); color:rgba(255,255,255,.55); font-size:12px; font-weight:500; padding:8px 0 }
.topbar .wrap { display:flex; justify-content:space-between; align-items:center }
.topbar a { color:rgba(255,255,255,.55); transition:color .2s }
.topbar a:hover { color:var(--terra-lt) }
.topbar-right { display:flex; gap:16px }

/* ── Header ── */
.site-header {
  position:sticky; top:0; z-index:100;
  background:rgba(250,248,244,.93); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--sand); transition:box-shadow .3s
}
.site-header.scrolled { box-shadow:var(--sh-md) }
.nav-wrap { display:flex; align-items:center; height:66px; gap:16px }
.logo img { height:40px; width:auto }
.main-nav { display:flex; align-items:center; gap:2px; margin-left:auto }
.main-nav > a, .nav-drop-label {
  font-size:14px; font-weight:500; color:var(--ink-mid);
  padding:7px 12px; border-radius:8px;
  transition:color .2s,background .2s; cursor:pointer;
  display:flex; align-items:center; gap:4px; white-space:nowrap
}
.main-nav > a:hover, .nav-drop-label:hover, .main-nav > a.active {
  color:var(--terra); background:var(--terra-bg)
}
.nav-drop { position:relative }
.dropdown {
  display:none; position:absolute; top:calc(100% + 10px); left:0;
  background:var(--white); border:1px solid var(--sand);
  border-radius:var(--r-lg); min-width:220px; padding:8px;
  box-shadow:var(--sh-lg); z-index:200
}
.nav-drop:hover .dropdown { display:grid; grid-template-columns:1fr 1fr; gap:2px }
.dropdown a {
  display:block; padding:9px 12px; font-size:13px; font-weight:500;
  color:var(--ink-mid); border-radius:8px;
  transition:background .15s,color .15s; white-space:nowrap
}
.dropdown a:hover { background:var(--terra-bg); color:var(--terra) }
.header-cta { flex-shrink:0; font-size:13px; padding:10px 20px }
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px }
.hamburger span { display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:.3s }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px) }
.hamburger.open span:nth-child(2) { opacity:0 }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px) }

/* ── Page Hero ── */
.page-hero {
  padding:clamp(48px,6vw,80px) 0; position:relative; overflow:hidden;
  background:var(--ink)
}
.page-hero::after {
  content:''; position:absolute; right:-80px; top:-80px;
  width:360px; height:360px; border-radius:50%;
  background:radial-gradient(circle,rgba(192,90,40,.14),transparent 70%); pointer-events:none
}
.page-hero h1  { font-size:clamp(28px,4vw,52px); color:var(--white); margin-bottom:10px }
.hero-sub      { color:rgba(255,255,255,.6); font-size:16px; margin-top:8px; max-width:560px }
.breadcrumb    { font-size:12px; color:rgba(255,255,255,.35); margin-bottom:14px; display:flex; gap:6px; align-items:center }
.breadcrumb a  { color:rgba(255,255,255,.35) }
.breadcrumb a:hover { color:rgba(255,255,255,.6) }

/* ── Home Hero ── */
.home-hero { background:var(--ink); position:relative; overflow:hidden; min-height:90vh; display:flex; align-items:center }
.home-hero-bg { position:absolute; inset:0; object-fit:cover; width:100%; height:100%; opacity:.18 }
.home-hero-overlay { position:absolute; inset:0; background:linear-gradient(105deg,rgba(26,26,24,.96) 45%,rgba(26,26,24,.5)) }
.home-hero .wrap {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;
  padding-top:40px; padding-bottom:40px
}
.hero-title { font-family:var(--ff-serif); font-size:clamp(36px,5vw,64px); color:var(--white); line-height:1.07; margin-bottom:20px }
.hero-title em { color:var(--terra-lt); font-style:italic }
.hero-desc { font-size:17px; color:rgba(255,255,255,.65); line-height:1.8; margin-bottom:32px; max-width:500px }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:40px }
.hero-stats { display:flex; gap:28px; padding-top:28px; border-top:1px solid rgba(255,255,255,.1); flex-wrap:wrap }
.hero-stat-num   { font-family:var(--ff-serif); font-size:38px; color:var(--white); line-height:1 }
.hero-stat-label { font-size:11px; color:rgba(255,255,255,.4); letter-spacing:1.5px; text-transform:uppercase; margin-top:4px }

/* Audience chooser */
.hero-audience {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-xl); padding:28px; backdrop-filter:blur(8px)
}
.hero-audience h3 { font-family:var(--ff-serif); font-size:20px; color:var(--white); margin-bottom:16px }
.audience-card {
  display:block; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r); padding:18px; margin-bottom:12px;
  transition:background .2s,border-color .2s
}
.audience-card:last-child { margin-bottom:0 }
.audience-card:hover { background:rgba(192,90,40,.18); border-color:rgba(192,90,40,.5) }
.audience-card-title { font-weight:600; color:var(--white); font-size:15px; margin-bottom:4px }
.audience-card-desc  { font-size:13px; color:rgba(255,255,255,.5); line-height:1.5 }
.audience-card-link  { font-size:12px; color:var(--terra-lt); font-weight:600; margin-top:8px }

/* ── Section heads ── */
.section-head { text-align:center; max-width:680px; margin:0 auto 48px }
.section-head .eyebrow { justify-content:center }
.section-head .h2 { margin-bottom:14px }

/* ── Feature grid ── */
.feature-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.feature-card {
  background:var(--white); border:1px solid var(--sand); border-radius:var(--r-lg); padding:28px;
  transition:transform .25s,box-shadow .25s
}
.feature-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md) }
.feature-icon  { font-size:32px; margin-bottom:14px }
.feature-title { font-family:var(--ff-serif); font-size:19px; color:var(--ink); margin-bottom:8px }
.feature-body  { font-size:14px; color:var(--ink-lite); line-height:1.75 }

/* ── Split section ── */
.split { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center }
.split-img { border-radius:var(--r-xl); overflow:hidden }
.split-img img { width:100%; height:440px; object-fit:cover }
.split-content .eyebrow { margin-bottom:14px }
.split-content .h2 { margin-bottom:18px }
.split-content .body { margin-bottom:24px }

/* ── Stats ── */
.stat-row { display:grid; grid-template-columns:repeat(4,1fr); gap:20px }
.stat-card { text-align:center; padding:28px 20px; background:var(--white); border:1px solid var(--sand); border-radius:var(--r-lg) }
.stat-num   { font-family:var(--ff-serif); font-size:48px; color:var(--terra); line-height:1; margin-bottom:6px }
.stat-label { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--ink-lite) }

/* ── Gallery ── */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px }
.gallery-img  { border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/3 }
.gallery-img img { width:100%; height:100%; object-fit:cover; transition:transform .45s }
.gallery-img:hover img { transform:scale(1.05) }

/* ── Projects ── */
.project-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.project-card { border-radius:var(--r-lg); overflow:hidden; position:relative; display:block; background:var(--ink) }
.project-card img { width:100%; height:280px; object-fit:cover; opacity:.75; transition:transform .5s,opacity .3s }
.project-card:hover img { transform:scale(1.05); opacity:.55 }
.project-info { position:absolute; bottom:0; left:0; right:0; padding:22px; background:linear-gradient(to top,rgba(26,26,24,.85),transparent) }
.project-tag  { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--terra-lt); margin-bottom:4px }
.project-name { font-family:var(--ff-serif); font-size:19px; color:#fff }
.project-sub  { font-size:13px; color:rgba(255,255,255,.75); margin-top:4px }
.filter-bar   { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px }
.filter-btn   {
  padding:8px 18px; border-radius:100px; font-size:13px; font-weight:600;
  border:1.5px solid var(--sand); color:var(--ink-mid); background:var(--white);
  cursor:pointer; transition:all .2s
}
.filter-btn.active, .filter-btn:hover { background:var(--terra); border-color:var(--terra); color:var(--white) }

/* ── Testimonials ── */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.testi-card {
  background:var(--white); border:1px solid var(--sand); border-radius:var(--r-lg);
  padding:32px; position:relative
}
.testi-card::before {
  content:'"'; font-family:var(--ff-serif); font-size:80px; color:var(--terra-bg);
  position:absolute; top:6px; left:20px; line-height:1; pointer-events:none
}
.testi-text   { font-size:15px; color:var(--ink-mid); line-height:1.8; font-style:italic; margin-bottom:18px; padding-top:30px }
.testi-author { font-family:var(--ff-serif); font-size:16px; color:var(--ink) }
.testi-role   { font-size:12px; color:var(--terra); font-weight:600; letter-spacing:.5px; text-transform:uppercase; margin-top:2px }

/* ── City pills ── */
.city-grid { display:flex; flex-wrap:wrap; gap:10px; justify-content:center }
.city-pill {
  background:var(--white); border:1.5px solid var(--sand); border-radius:100px;
  padding:10px 22px; font-size:14px; font-weight:600; color:var(--ink-mid);
  transition:border-color .2s,color .2s,background .2s
}
.city-pill:hover { border-color:var(--terra); color:var(--terra); background:var(--terra-bg) }

/* ── Trust badges ── */
.trust-row  { display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:center }
.trust-badge {
  background:var(--white); border:1px solid var(--sand); border-radius:100px;
  padding:8px 18px; font-size:13px; font-weight:600; color:var(--ink-mid)
}

/* ── CTA Strip ── */
.cta-strip { background:var(--terra); padding:clamp(36px,5vw,60px) 0 }
.cta-inner {
  display:flex; justify-content:space-between; align-items:center;
  gap:32px; flex-wrap:wrap; position:relative
}
.cta-inner::before {
  content:''; position:absolute; right:-40px; top:-40px;
  width:220px; height:220px; border-radius:50%;
  background:rgba(255,255,255,.07); pointer-events:none
}
.cta-strip h2 { font-family:var(--ff-serif); font-size:clamp(20px,2.8vw,34px); color:var(--white); margin-bottom:6px }
.cta-strip p  { color:rgba(255,255,255,.75); font-size:15px }
.cta-btns     { display:flex; gap:12px; flex-wrap:wrap; flex-shrink:0; position:relative }

/* ── Pricing ── */
.price-hero-nums { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:32px }
.price-box {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r-lg); padding:24px; text-align:center
}
.price-range { font-family:var(--ff-serif); font-size:36px; color:var(--white); margin-bottom:6px }
.price-label { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.45) }

/* ── Calculator ── */
.calc-box {
  background:var(--ink); border-radius:var(--r-xl); padding:36px; color:var(--white)
}
.calc-box label {
  display:block; font-size:11px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:10px
}
.calc-box select {
  width:100%; background:rgba(255,255,255,.07); border:1.5px solid rgba(255,255,255,.14);
  color:var(--white); padding:14px 44px 14px 16px; border-radius:var(--r);
  font-family:var(--ff-sans); font-size:15px; outline:none; cursor:pointer;
  transition:border-color .2s; appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%23999' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center
}
.calc-box select:focus { border-color:var(--terra-lt) }
.calc-box select option { background:var(--ink-mid) }
.saving-block  { display:none; margin-top:20px }
.saving-result {
  background:var(--terra); border-radius:var(--r-lg); padding:28px; text-align:center
}
.saving-amount { font-family:var(--ff-serif); font-size:52px; color:var(--white); line-height:1; margin-bottom:6px }
.saving-label  { font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.7) }
.saving-note   { font-size:13px; color:rgba(255,255,255,.6); margin-top:10px; line-height:1.6 }

/* ── Compare table ── */
.compare-table { width:100%; border-collapse:collapse; border-radius:var(--r-lg); overflow:hidden }
.compare-table th {
  padding:14px 18px; font-size:11px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; text-align:left; background:var(--ink); color:rgba(255,255,255,.6)
}
.compare-table th.hl { background:var(--terra); color:var(--white) }
.compare-table td { padding:13px 18px; font-size:14px; border-bottom:1px solid var(--sand) }
.compare-table tr:nth-child(odd) td  { background:var(--white) }
.compare-table tr:nth-child(even) td { background:var(--warm) }
.compare-table tr:last-child td { border-bottom:none }
.yes { color:var(--green); font-weight:700 }
.no  { color:#c0392b; font-weight:700 }

/* ── FAQ ── */
.faq-list { max-width:760px; margin:0 auto }
.faq-item { border-bottom:1px solid var(--sand) }
.faq-q {
  width:100%; text-align:left; padding:20px 0;
  font-family:var(--ff-serif); font-size:18px; color:var(--ink);
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  cursor:pointer; transition:color .2s; background:none; border:none
}
.faq-q:hover { color:var(--terra) }
.faq-q .icon { color:var(--terra); font-size:22px; flex-shrink:0; transition:transform .3s; font-style:normal }
.faq-q.open .icon { transform:rotate(45deg) }
.faq-a { display:none; padding-bottom:20px; color:var(--ink-lite); line-height:1.8; font-size:15px }
.faq-a.open { display:block }

/* ── Contact / Forms ── */
.form-wrap {
  background:var(--white); border-radius:var(--r-xl); padding:clamp(28px,4vw,48px);
  box-shadow:var(--sh-lg); border:1px solid var(--sand)
}
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:16px }
.form-group label { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--ink-mid) }
.form-group input,
.form-group select,
.form-group textarea {
  padding:12px 16px; border:1.5px solid var(--sand); border-radius:var(--r);
  font-family:var(--ff-sans); font-size:15px; color:var(--ink); background:var(--cream);
  transition:border-color .2s,box-shadow .2s; outline:none
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--terra); box-shadow:0 0 0 3px rgba(192,90,40,.1); background:var(--white)
}
.form-group textarea { min-height:100px; resize:vertical }
.form-note { font-size:12px; color:var(--ink-lite); margin-bottom:20px; line-height:1.6 }

/* ── Location pages ── */
.loc-benefits { display:grid; grid-template-columns:repeat(3,1fr); gap:18px }
.loc-card { background:var(--white); border:1px solid var(--sand); border-radius:var(--r-lg); padding:24px; text-align:center }
.loc-card .icon { font-size:32px; margin-bottom:12px }
.loc-card h3 { font-family:var(--ff-serif); font-size:18px; color:var(--terra); margin-bottom:8px }
.loc-card p  { font-size:13px; color:var(--ink-lite); line-height:1.7 }

/* ── Contact info cards ── */
.contact-card {
  background:var(--white); border:1px solid var(--sand); border-radius:var(--r-lg);
  padding:24px; display:flex; gap:16px; align-items:flex-start; transition:box-shadow .2s
}
.contact-card:hover { box-shadow:var(--sh-md) }
.contact-card .icon { font-size:28px; flex-shrink:0 }
.contact-card-title { font-family:var(--ff-serif); font-size:17px; margin-bottom:6px }
.contact-card a { color:var(--terra); font-weight:600; font-size:16px }
.contact-card p { font-size:13px; color:var(--ink-lite); margin-top:4px }

/* ── Footer ── */
.site-footer { background:var(--ink); color:rgba(255,255,255,.55); padding:clamp(48px,6vw,80px) 0 0 }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px;
  padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.08)
}
.footer-brand p { font-size:14px; line-height:1.8; margin-bottom:16px; max-width:260px }
.footer-contact { display:flex; flex-direction:column; gap:8px; font-size:14px }
.footer-contact a { color:rgba(255,255,255,.65); transition:color .2s }
.footer-contact a:hover { color:var(--terra-lt) }
.footer-heading { font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:16px }
.footer-col ul li { margin-bottom:9px }
.footer-col ul li a { font-size:14px; color:rgba(255,255,255,.55); transition:color .2s }
.footer-col ul li a:hover { color:var(--terra-lt) }
.footer-bottom {
  padding:18px 0; display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:8px; font-size:12px; color:rgba(255,255,255,.3)
}
.footer-bottom a { color:rgba(255,255,255,.3) }
.footer-bottom a:hover { color:var(--terra-lt) }

/* ── Reveal animations ── */
.reveal { opacity:0; transform:translateY(22px); transition:opacity .65s ease,transform .65s ease }
.revealed { opacity:1; transform:none }
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
.fade-up   { animation:fadeUp .7s ease both }
.fade-up-2 { animation:fadeUp .7s .15s ease both }
.fade-up-3 { animation:fadeUp .7s .3s ease both }

/* ── Responsive ── */
@media(max-width:1024px) {
  .feature-grid { grid-template-columns:repeat(2,1fr) }
  .footer-grid  { grid-template-columns:1fr 1fr }
  .stat-row     { grid-template-columns:repeat(2,1fr) }
  .price-hero-nums { grid-template-columns:1fr 1fr }
}
@media(max-width:768px) {
  .home-hero .wrap,.split { grid-template-columns:1fr }
  .feature-grid,.project-grid,.testi-grid,.loc-benefits,.gallery-grid { grid-template-columns:1fr }
  .stat-row { grid-template-columns:repeat(2,1fr) }
  .footer-grid { grid-template-columns:1fr }
  .form-row { grid-template-columns:1fr }
  .price-hero-nums { grid-template-columns:1fr }
  .main-nav,.header-cta { display:none }
  .main-nav.open {
    display:flex; flex-direction:column;
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:var(--cream); padding:0; padding-top:70px;
    z-index:101; overflow-y:auto; gap:0;
    box-shadow: 0 4px 40px rgba(0,0,0,.18)
  }
  .main-nav.open > a,
  .main-nav.open .nav-drop-label {
    display:block; padding:14px 24px;
    font-size:17px; font-weight:500; color:var(--ink);
    border-bottom:1px solid var(--stone);
    white-space:normal; border-radius:0
  }
  .main-nav.open > a:hover,
  .main-nav.open .nav-drop-label:hover { background:var(--stone); color:var(--terra) }
  .main-nav.open .nav-drop { border-bottom:1px solid var(--stone) }
  .main-nav.open .nav-drop-label { border-bottom:none }
  .main-nav.open .nav-drop .dropdown {
    display:flex; flex-direction:column;
    position:static; box-shadow:none; border:none;
    padding:0 0 8px 0; gap:0; background:var(--cream)
  }
  .main-nav.open .nav-drop .dropdown a {
    padding:10px 24px 10px 40px; font-size:15px;
    color:#555; border-bottom:none
  }
  .main-nav.open .nav-drop .dropdown a:hover { color:var(--terra) }
  /* Mobile CTA button inside open nav */
  .main-nav.open::after {
    content:''; display:block; height:24px
  }
  .hamburger { display:flex; z-index:102 }
  .hamburger.open { position:fixed; top:16px; right:16px; z-index:102 }
  .cta-inner { flex-direction:column; text-align:center }
  .cta-btns  { justify-content:center }
  /* Mobile CTA in nav */
  .header-cta.mobile-cta {
    display:block !important; margin:16px 24px;
    text-align:center; padding:14px; font-size:16px
  }
}
@media(max-width:480px) {
  .hero-btns { flex-direction:column; align-items:flex-start }
  .hero-stats { gap:18px }
  .topbar-right { display:none }
  /* Prevent horizontal overflow on small screens */
  .compare-table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch }
  .price-table   { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch }
  table          { min-width:0 }
  .filter-bar    { gap:6px }
  .filter-btn    { font-size:12px; padding:6px 12px }
}
@media(prefers-reduced-motion:reduce) {
  .reveal,.fade-up,.fade-up-2,.fade-up-3 { animation:none; opacity:1; transform:none }
}

/* ── Logo wordmark (header) ── */
.logo { display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0 }
.logo img { width:44px; height:44px; object-fit:contain; flex-shrink:0 }
@media(max-width:400px) {
  .logo span:last-child { display:none }
}

/* ── Global mobile overflow protection ── */
html { overflow-x:hidden }
body { overflow-x:hidden }

/* Tables on mobile — always scrollable */
table {
  width:100%;
  border-collapse:collapse;
}
@media(max-width:768px) {
  table {
    display:block;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    white-space:nowrap;
  }
  table th, table td {
    min-width:100px;
  }
  /* Blog layout: stack on mobile */
  .blog-body .wrap {
    grid-template-columns: 1fr !important;
  }
  .blog-sidebar {
    position: static !important;
  }
  /* Blog featured card */
  .blog-card.featured {
    grid-column: auto !important;
    grid-template-columns: 1fr !important;
  }
  /* Prevent wide inline grids */
  [style*="grid-template-columns"] {
    /* Can't override inline easily — handled per-section */
  }
  /* Page hero decorative element clipped */
  .page-hero { overflow:hidden }
  .home-hero { overflow:hidden }
  /* Savings blocks */
  .saving-block { overflow-x:auto }
}

/* Savings calculator responsive grid */
@media(max-width:768px) {
  .calc-grid { grid-template-columns:1fr !important }
}
