/* ============================================================
   Detroit Kitchen Reface — Main Stylesheet
   Inspired by LeMica Doors: clean white header, airy layout,
   strong typography, prominent circular logo
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,700;0,900;1,700&family=Inter:wght@400;500;600;700;800&display=swap');

/* --- Variables --- */
:root {
  --navy:      #1A3A5C;
  --navy-dark: #0F2337;
  --gold:      #C0902A;
  --gold-light:#FDF3E3;
  --dark:      #1C2B3A;
  --gray:      #5A6A78;
  --light-bg:  #F4F8FB;
  --mint:      #EAF6F6;
  --border:    #DDE6EE;
  --white:     #FFFFFF;
  --shadow:    0 2px 16px rgba(26,58,92,0.08);
  --shadow-md: 0 6px 30px rgba(26,58,92,0.12);
  --radius:    10px;
  --radius-sm: 6px;
  --transition: 0.22s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Inter',sans-serif; color:var(--dark); line-height:1.7; background:#fff; }
img  { max-width:100%; height:auto; display:block; }
a    { color:inherit; text-decoration:none; }
ul   { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* --- Typography --- */
h1,h2,h3,h4 { line-height:1.2; }
h1 { font-family:'Merriweather',Georgia,serif; font-size:clamp(2rem,4.5vw,3rem); font-weight:900; }
h2 { font-family:'Merriweather',Georgia,serif; font-size:clamp(1.6rem,3vw,2.25rem); font-weight:700; }
h3 { font-family:'Inter',sans-serif; font-size:1.15rem; font-weight:700; }
p  { color:var(--gray); margin-bottom:1rem; }
p:last-child { margin-bottom:0; }

/* --- Buttons --- */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.8rem 1.75rem; border-radius:var(--radius-sm);
  font-weight:700; font-size:.95rem; transition:all var(--transition);
  white-space:nowrap; font-family:'Inter',sans-serif;
}
.btn-primary   { background:var(--navy); color:#fff; }
.btn-primary:hover { background:var(--navy-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-gold      { background:var(--gold); color:#fff; }
.btn-gold:hover { background:#a07820; transform:translateY(-2px); }
.btn-outline   { border:2px solid var(--navy); color:var(--navy); }
.btn-outline:hover { background:var(--navy); color:#fff; }
.btn-outline-white { border:2px solid #fff; color:#fff; }
.btn-outline-white:hover { background:#fff; color:var(--navy); }
.btn-lg { padding:1rem 2.25rem; font-size:1.05rem; }

/* ============================================================
   HEADER / NAVIGATION  — LeMica style: white, clean, logo-prominent
   ============================================================ */
.site-header {
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 12px rgba(26,58,92,0.06);
  position:sticky; top:0; z-index:1000;
}
.nav-inner {
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:.75rem 2rem;
}

/* Logo — large and prominent like LeMica */
.nav-logo-img {
  display:flex; align-items:center;
  transition:opacity var(--transition); flex-shrink:0;
}
.nav-logo-img:hover { opacity:.85; }
.nav-logo-img img   { height:80px; width:auto; display:block; }

/* Nav links — dark text on white, like LeMica */
.nav-menu {
  display:flex; align-items:center; gap:.1rem;
}
.nav-menu > li { position:relative; }
.nav-menu a {
  display:block; padding:.55rem .9rem;
  color:var(--navy); font-size:.9rem; font-weight:600;
  border-radius:var(--radius-sm); transition:all var(--transition);
  letter-spacing:.2px;
}
.nav-menu a:hover { color:var(--gold); background:var(--gold-light); }

/* Dropdown */
.has-dropdown > a::after { content:' ▾'; font-size:.68rem; opacity:.6; }
.dropdown {
  position:absolute; top:calc(100% + .4rem); left:0;
  background:#fff; border-radius:var(--radius-sm);
  box-shadow:var(--shadow-md); min-width:230px;
  opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:all var(--transition); z-index:200;
  border:1px solid var(--border);
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a {
  color:var(--dark)!important; padding:.75rem 1.1rem;
  border-bottom:1px solid var(--border); border-radius:0!important;
  font-size:.87rem; font-weight:500;
}
.dropdown a:last-child { border-bottom:none; }
.dropdown a:hover { background:var(--gold-light)!important; color:var(--navy)!important; }

/* CTA phone button in nav */
.nav-cta { margin-left:1rem; }
.nav-cta .btn {
  background:var(--navy); color:#fff;
  padding:.6rem 1.25rem; font-size:.88rem;
}
.nav-cta .btn:hover { background:var(--gold); }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; padding:.5rem; }
.hamburger span { display:block; width:24px; height:2.5px; background:var(--navy); border-radius:2px; transition:all var(--transition); }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ============================================================
   HERO — Light mint/teal background, two-column, LeMica style
   ============================================================ */
.hero {
  background:var(--mint);
  padding:5.5rem 2rem 5rem;
}
.hero-inner {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center;
}
.hero-left { }
.hero-eyebrow {
  font-size:.78rem; font-weight:700; color:var(--gold);
  letter-spacing:2px; text-transform:uppercase; margin-bottom:1rem;
}
.hero h1 { color:var(--navy); margin-bottom:1.5rem; }
.hero h1 em { font-style:italic; color:var(--gold); }
.hero-right p { font-size:1.05rem; color:var(--gray); line-height:1.8; margin-bottom:2rem; }
.hero-divider {
  width:60px; height:4px; background:var(--navy);
  margin:1.25rem 0 1.5rem; border-radius:2px;
}
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.75rem; }
.hero-trust {
  display:flex; gap:1.5rem; flex-wrap:wrap;
}
.trust-item {
  display:flex; align-items:center; gap:.4rem;
  color:var(--gray); font-size:.8rem; font-weight:600;
}
.trust-dot { width:8px; height:8px; background:var(--gold); border-radius:50%; flex-shrink:0; }

/* Right side stat card */
.hero-stat-card {
  background:#fff; border-radius:16px;
  padding:2.5rem; box-shadow:var(--shadow-md);
  border:1px solid var(--border);
}
.hero-stat-card h3 { color:var(--navy); margin-bottom:1.5rem; font-size:1.05rem; font-weight:700; }
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.stat-box {
  background:var(--light-bg); border-radius:var(--radius-sm);
  padding:1.25rem; text-align:center;
  border:1px solid var(--border);
}
.stat-num   { font-size:2.1rem; font-weight:800; color:var(--navy); display:block; line-height:1; font-family:'Merriweather',serif; }
.stat-label { font-size:.75rem; color:var(--gray); margin-top:.35rem; display:block; font-weight:600; }

/* ============================================================
   SECTION COMMONS
   ============================================================ */
.section     { padding:5.5rem 2rem; }
.section-alt { background:var(--light-bg); }
.section-mint{ background:var(--mint); }
.container   { max-width:1280px; margin:0 auto; }

/* Section label / eyebrow */
.section-label {
  display:block; font-size:.72rem; font-weight:700;
  color:var(--gold); letter-spacing:2px; text-transform:uppercase;
  margin-bottom:.6rem;
}
.section-title { color:var(--navy); margin-bottom:.5rem; }

/* LeMica-style dot decorator */
.dot-line {
  display:flex; gap:5px; margin:1rem 0 1.75rem;
}
.dot-line span {
  width:8px; height:8px; border-radius:50%; background:var(--navy);
}
.dot-line span:nth-child(2) { background:var(--gold); }
.dot-line span:nth-child(3) { background:var(--navy); opacity:.4; }
.dot-line span:nth-child(4) { background:var(--navy); opacity:.2; }
.dot-line span:nth-child(5) { background:var(--navy); opacity:.1; }

.section-sub { font-size:1rem; color:var(--gray); max-width:600px; }
.section-header { margin-bottom:3.5rem; }
.section-header.center { text-align:center; }
.section-header.center .section-sub  { margin:0 auto; }
.section-header.center .dot-line { justify-content:center; }

/* ============================================================
   SERVICES
   ============================================================ */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.service-card {
  background:#fff; border-radius:var(--radius);
  padding:2.25rem 2rem; border:1px solid var(--border);
  transition:all var(--transition);
  display:flex; flex-direction:column;
}
.service-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--navy); }
.service-icon {
  width:60px; height:60px; background:var(--mint);
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  margin-bottom:1.5rem; font-size:1.85rem;
  border:1px solid var(--border);
}
.service-card h3 { color:var(--navy); margin-bottom:.6rem; }
.service-card p  { flex:1; font-size:.93rem; }
.learn-more {
  display:inline-flex; align-items:center; gap:.35rem;
  color:var(--gold); font-weight:700; font-size:.88rem; margin-top:1.25rem;
  letter-spacing:.3px;
}
.service-card:hover .learn-more { gap:.6rem; }

/* ============================================================
   TWO-COLUMN INTRO SECTIONS (LeMica "Who We Are" style)
   ============================================================ */
.split-section {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center;
}
.split-section.reverse { direction:rtl; }
.split-section.reverse > * { direction:ltr; }
.split-img {
  aspect-ratio:4/3; background:var(--light-bg);
  border-radius:var(--radius); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gray); font-size:.88rem; flex-direction:column; gap:.75rem;
  overflow:hidden;
}
.split-img img { width:100%; height:100%; object-fit:cover; }
.split-img .placeholder-icon { font-size:3rem; opacity:.25; }

/* ============================================================
   WHY CHOOSE US
   ============================================================ */
.why-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem; }
.why-item {
  display:flex; gap:1rem; align-items:flex-start;
  padding:1.5rem; border-radius:var(--radius);
  background:#fff; border:1px solid var(--border);
}
.why-icon {
  width:46px; height:46px; background:var(--navy); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:1.3rem;
}
.why-item h4 { color:var(--navy); margin-bottom:.3rem; font-size:.95rem; }
.why-item p  { font-size:.87rem; margin:0; }

/* ============================================================
   PROCESS
   ============================================================ */
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:1.75rem; }
.step { text-align:center; }
.step-num {
  width:64px; height:64px; background:var(--navy); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; font-weight:800; margin:0 auto 1.25rem;
  font-family:'Merriweather',serif;
  border:4px solid var(--border); box-shadow:var(--shadow);
}
.step h4 { color:var(--navy); margin-bottom:.4rem; font-size:.95rem; }
.step p  { font-size:.85rem; }

/* ============================================================
   SAVINGS BANNER
   ============================================================ */
.savings-banner {
  background:var(--navy); padding:5rem 2rem; text-align:center;
}
.savings-banner h2 { color:#fff; margin-bottom:1rem; }
.savings-banner p  { color:rgba(255,255,255,.72); max-width:620px; margin:0 auto 2.5rem; }
.savings-numbers   { display:flex; justify-content:center; gap:4rem; flex-wrap:wrap; margin-bottom:2.75rem; }
.savings-num .big  { font-size:3.25rem; font-weight:900; color:var(--gold); display:block; line-height:1; font-family:'Merriweather',serif; }
.savings-num .lbl  { font-size:.82rem; color:rgba(255,255,255,.6); margin-top:.3rem; display:block; }

/* ============================================================
   SERVICE AREAS
   ============================================================ */
.areas-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1rem; }
.area-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:1.1rem .75rem; text-align:center; transition:all var(--transition);
}
.area-card:hover { border-color:var(--navy); background:var(--mint); transform:translateY(-3px); box-shadow:var(--shadow); }
.area-card .city-name { font-weight:700; color:var(--navy); font-size:.9rem; }
.area-card .city-sub  { font-size:.73rem; color:var(--gray); margin-top:.2rem; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.review-card {
  background:#fff; padding:2rem; border-radius:var(--radius);
  border:1px solid var(--border); box-shadow:var(--shadow);
}
.stars { color:var(--gold); font-size:1.1rem; margin-bottom:.85rem; letter-spacing:3px; }
.review-text { font-style:italic; margin-bottom:1.1rem; font-size:.93rem; color:var(--gray); line-height:1.7; }
.reviewer { display:flex; align-items:center; gap:.75rem; }
.reviewer-avatar {
  width:44px; height:44px; background:var(--navy); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:700; font-size:1rem; flex-shrink:0;
}
.reviewer-name { font-weight:700; color:var(--navy); font-size:.88rem; }
.reviewer-loc  { font-size:.76rem; color:var(--gray); }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list { max-width:820px; margin:0 auto; }
.faq-item {
  border:1px solid var(--border); border-radius:var(--radius-sm);
  margin-bottom:.75rem; overflow:hidden;
}
.faq-question {
  display:flex; justify-content:space-between; align-items:center;
  padding:1.15rem 1.25rem; cursor:pointer;
  font-weight:700; color:var(--navy); background:#fff;
  transition:background var(--transition); font-size:.93rem;
}
.faq-question:hover { background:var(--mint); }
.faq-question .icon { font-size:1.2rem; color:var(--gold); transition:transform var(--transition); flex-shrink:0; margin-left:1rem; }
.faq-item.open .faq-question .icon { transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height .35s ease; background:var(--light-bg); }
.faq-answer-inner { padding:0 1.25rem; }
.faq-item.open .faq-answer { max-height:300px; }
.faq-item.open .faq-answer-inner { padding:1.15rem 1.25rem; }
.faq-answer p { font-size:.9rem; margin:0; }

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section { background:var(--gold); padding:4.5rem 2rem; text-align:center; }
.cta-section h2 { color:#fff; margin-bottom:.85rem; }
.cta-section p  { color:rgba(255,255,255,.88); margin-bottom:2.25rem; font-size:1.05rem; }
.cta-actions    { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.contact-info h2  { color:var(--navy); margin-bottom:.5rem; }
.contact-detail {
  display:flex; align-items:flex-start; gap:1rem;
  margin-bottom:1.1rem; padding:1.25rem;
  background:#fff; border-radius:var(--radius-sm); border:1px solid var(--border);
}
.contact-detail-icon {
  width:44px; height:44px; background:var(--mint);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; flex-shrink:0; border:1px solid var(--border);
}
.contact-detail h4 { color:var(--navy); margin-bottom:.2rem; font-size:.88rem; font-weight:700; }
.contact-detail a, .contact-detail span { color:var(--gray); font-size:.92rem; }
.contact-detail a:hover { color:var(--gold); }

.quote-form {
  background:#fff; padding:2.25rem; border-radius:var(--radius);
  box-shadow:var(--shadow-md); border:1px solid var(--border);
}
.quote-form h3 { color:var(--navy); margin-bottom:1.5rem; font-size:1.1rem; }
.form-row  { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1rem; }
.form-group label { display:block; margin-bottom:.4rem; font-size:.83rem; font-weight:700; color:var(--dark); letter-spacing:.2px; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:.8rem 1rem;
  border:1.5px solid var(--border); border-radius:var(--radius-sm);
  font-family:'Inter',sans-serif; font-size:.93rem; color:var(--dark);
  transition:border-color var(--transition); background:#fff;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(26,58,92,0.08); }
.form-group textarea { resize:vertical; min-height:100px; }
.form-submit { width:100%; padding:1rem; font-size:1rem; margin-top:.5rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background:var(--navy-dark); color:rgba(255,255,255,.65); padding:4rem 2rem 1.5rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; max-width:1280px; margin:0 auto; }
.footer-brand p { font-size:.85rem; line-height:1.8; margin:1.1rem 0 1.5rem; }
.footer-col h4 { color:#fff; margin-bottom:1.1rem; font-size:.92rem; letter-spacing:.3px; }
.footer-col ul li { margin-bottom:.55rem; }
.footer-col ul a  { font-size:.84rem; transition:color var(--transition); }
.footer-col ul a:hover { color:var(--gold); }
.footer-bottom {
  max-width:1280px; margin:2.5rem auto 0;
  padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.08);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:1rem; font-size:.78rem;
}
.footer-bottom a { color:rgba(255,255,255,.4); }
.footer-bottom a:hover { color:var(--gold); }

/* ============================================================
   INNER PAGE HERO
   ============================================================ */
.page-hero { background:var(--mint); padding:4rem 2rem; border-bottom:1px solid var(--border); }
.page-hero-inner { max-width:1280px; margin:0 auto; }
.breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:var(--gray); margin-bottom:1.25rem; }
.breadcrumb a { color:var(--gray); transition:color var(--transition); }
.breadcrumb a:hover { color:var(--navy); }
.breadcrumb span { color:var(--border); }
.page-hero h1 { color:var(--navy); margin-bottom:.75rem; }
.page-hero p  { color:var(--gray); font-size:1.05rem; max-width:700px; margin-bottom:1.75rem; }

/* ============================================================
   SERVICE DETAIL PAGE
   ============================================================ */
.service-detail-grid { display:grid; grid-template-columns:3fr 2fr; gap:3.5rem; align-items:start; }
.service-detail h2 { color:var(--navy); margin-bottom:1rem; }
.service-detail h3 { color:var(--navy); margin:1.75rem 0 .6rem; }
.benefit-list li {
  display:flex; align-items:flex-start; gap:.85rem;
  padding:.85rem 0; border-bottom:1px solid var(--border); font-size:.93rem;
}
.benefit-list li:last-child { border-bottom:none; }
.check { color:var(--gold); font-size:1.1rem; flex-shrink:0; margin-top:.1rem; }
.sidebar-card {
  background:#fff; border-radius:var(--radius); padding:1.85rem;
  box-shadow:var(--shadow-md); border:1px solid var(--border);
  position:sticky; top:110px;
}
.sidebar-card h3 { color:var(--navy); margin-bottom:1.25rem; }
.sidebar-phone {
  display:flex; align-items:center; gap:.75rem;
  background:var(--mint); padding:1rem; border-radius:var(--radius-sm);
  margin-bottom:1rem; font-weight:700; color:var(--navy); font-size:1.05rem;
  border:1px solid var(--border);
}

/* ============================================================
   CITY PAGE
   ============================================================ */
.city-intro { display:grid; grid-template-columns:3fr 2fr; gap:3.5rem; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.gallery-item {
  aspect-ratio:4/3; background:var(--light-bg);
  border-radius:var(--radius-sm); overflow:hidden;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gray); font-size:.83rem; text-align:center; padding:1.25rem;
  flex-direction:column; gap:.6rem;
}
.gallery-item .placeholder-icon { font-size:2.5rem; opacity:.3; }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.about-img-placeholder {
  aspect-ratio:4/3; background:var(--light-bg);
  border-radius:var(--radius); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gray); font-size:.88rem; flex-direction:column; gap:.6rem;
}
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin-top:3.5rem; }
.value-card  {
  background:var(--mint); padding:1.75rem; border-radius:var(--radius-sm);
  text-align:center; border:1px solid var(--border);
}
.value-card .icon { font-size:2rem; margin-bottom:.85rem; }
.value-card h4 { color:var(--navy); margin-bottom:.4rem; }
.value-card p  { font-size:.85rem; }

/* ============================================================
   UTILITIES
   ============================================================ */
.text-center { text-align:center; }
.mt-2 { margin-top:1rem; }
.mt-3 { margin-top:1.5rem; }
.divider { height:1px; background:var(--border); margin:1.75rem 0; }
.highlight-box {
  padding:1.5rem; background:var(--mint);
  border-radius:var(--radius-sm); border-left:4px solid var(--navy);
  margin-top:2rem;
}
.highlight-box strong { color:var(--navy); }
.highlight-box a { color:var(--navy); font-weight:700; text-decoration:underline; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid   { grid-template-columns:1fr 1fr; }
  .areas-grid    { grid-template-columns:repeat(3,1fr); }
  .hero-inner    { grid-template-columns:1fr; gap:2.5rem; }
  .hero-stat-card{ display:none; }
  .split-section { grid-template-columns:1fr; gap:2.5rem; }
  .split-section.reverse { direction:ltr; }
}
@media (max-width:768px) {
  .nav-menu, .nav-cta { display:none; }
  .nav-menu.open {
    display:flex; flex-direction:column;
    position:absolute; top:100%; left:0; right:0;
    background:#fff; padding:1rem; gap:.1rem;
    border-top:1px solid var(--border);
    box-shadow:0 8px 20px rgba(0,0,0,0.1);
  }
  .nav-menu.open .dropdown {
    position:static; opacity:1; visibility:visible; transform:none;
    box-shadow:none; border:none; background:var(--light-bg);
  }
  .nav-menu.open .dropdown a { color:var(--navy)!important; }
  .hamburger { display:flex; }
  .nav-inner  { position:relative; }

  .services-grid  { grid-template-columns:1fr; }
  .why-grid       { grid-template-columns:1fr; }
  .process-steps  { grid-template-columns:repeat(2,1fr); }
  .reviews-grid   { grid-template-columns:1fr; }
  .contact-grid   { grid-template-columns:1fr; }
  .service-detail-grid { grid-template-columns:1fr; }
  .city-intro     { grid-template-columns:1fr; }
  .about-grid     { grid-template-columns:1fr; }
  .values-grid    { grid-template-columns:1fr; }
  .gallery-grid   { grid-template-columns:repeat(2,1fr); }
  .areas-grid     { grid-template-columns:repeat(2,1fr); }
  .savings-numbers{ gap:2rem; }
  .footer-grid    { grid-template-columns:1fr; }
  .footer-bottom  { flex-direction:column; text-align:center; }
  .form-row       { grid-template-columns:1fr; }
  .stat-grid      { grid-template-columns:1fr 1fr; }
  .hero-actions   { flex-direction:column; align-items:flex-start; }
  .cta-actions    { flex-direction:column; align-items:center; }
  .section        { padding:3.5rem 1.25rem; }
  .hero           { padding:3.5rem 1.25rem; }
  .nav-logo-img img { height:60px; }
}
@media (max-width:480px) {
  .gallery-grid { grid-template-columns:1fr; }
  .areas-grid   { grid-template-columns:1fr 1fr; }
  h1 { font-size:1.85rem; }
  h2 { font-size:1.5rem; }
  .savings-num .big { font-size:2.5rem; }
}
