:root{
  --forest:#2E5E3E;
  --forest-deep:#1F4029;
  --clay:#C4834A;
  --gold:#B8973C;
  --stone:#F7F4EF;
  --linen:#FDFBF8;
  --charcoal:#22281E;
  --slate:#6B7264;
  --line:rgba(34,40,30,.12);
  --line-soft:rgba(34,40,30,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter', system-ui, sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--charcoal);
  background:var(--stone);
  -webkit-font-smoothing:antialiased;
}
.serif{font-family:'Playfair Display', Georgia, serif}
.italic{font-style:italic}
.mono{font-family:ui-monospace, 'SF Mono', Menlo, monospace}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{max-width:1280px;margin:0 auto;padding:0 clamp(16px,4vw,40px)}
.wide{max-width:1440px;margin:0 auto;padding:0 clamp(16px,4vw,40px)}

/* ===== Top Bar ===== */
.topbar{
  background:var(--forest-deep);
  color:#E7E0D0;
  font-size:13px;
  padding:8px 0;
  letter-spacing:.02em;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.topbar-left{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.topbar-left span,.topbar-left a{display:inline-flex;align-items:center;gap:8px;opacity:.85;color:inherit;text-decoration:none;transition:opacity .15s,color .15s}
.topbar-left a:hover{opacity:1;color:var(--linen)}
.topbar-left svg{opacity:.7}

.whatsapp-fab{
  position:fixed;bottom:24px;right:24px;z-index:900;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;
  display:grid;place-items:center;
  box-shadow:0 8px 24px -4px rgba(37,211,102,.45),0 4px 12px rgba(34,40,30,.2);
  transition:transform .2s, box-shadow .2s;
}
.whatsapp-fab:hover{transform:scale(1.06);box-shadow:0 12px 28px -4px rgba(37,211,102,.6)}
.whatsapp-fab svg{width:30px;height:30px}
@media (max-width:980px){.whatsapp-fab{bottom:16px;right:16px;width:52px;height:52px}}
.topbar-right{display:flex;gap:18px;opacity:.7;font-size:12px;letter-spacing:.15em;text-transform:uppercase}

/* ===== Nav ===== */
nav.main{
  background:var(--linen);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:20px 0}
.logo{display:flex;align-items:center;gap:14px}
.logo-mark{
  width:52px;height:52px;
  display:block;
  flex-shrink:0;
}
.logo-mark svg{width:100%;height:100%;display:block}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:'Playfair Display', serif;font-size:20px;font-weight:700;color:var(--charcoal);letter-spacing:.01em}
.logo-name em{color:var(--clay);font-style:italic;font-weight:400}
.logo-sub{font-size:10px;letter-spacing:.28em;color:var(--slate);text-transform:uppercase;margin-top:4px}

.nav-links{display:flex;gap:36px;list-style:none;margin:0;padding:0}
.nav-links > li{position:relative}
.nav-links a{
  display:inline-flex;align-items:center;gap:6px;
  font-size:14px;color:var(--charcoal);font-weight:500;
  padding:8px 0;position:relative;letter-spacing:.01em;
  transition:color .2s;
  line-height:1;
}
.nav-links a:hover{color:var(--forest)}
.nav-links a.active{color:var(--forest)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;
  height:2px;background:var(--clay);
}
.nav-links .has-dropdown > a::after{
  content:"";width:6px;height:6px;
  border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  transition:transform .2s;
  opacity:.7;
}
.nav-links .has-dropdown:hover > a::after,
.nav-links .has-dropdown:focus-within > a::after{
  transform:rotate(225deg) translateY(-2px);
}
.dropdown{
  position:absolute;top:100%;left:-16px;
  min-width:260px;margin:0;padding:10px 0;
  list-style:none;
  background:var(--linen);
  border:1px solid var(--line);
  border-top:3px solid var(--clay);
  box-shadow:0 20px 40px -20px rgba(34,40,30,.25);
  opacity:0;visibility:hidden;
  transform:translateY(6px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  z-index:60;
}
.nav-links .has-dropdown:hover > .dropdown,
.nav-links .has-dropdown:focus-within > .dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
}
.dropdown li{display:block}
.dropdown a{
  display:block;
  padding:10px 22px !important;
  font-size:14px;color:var(--charcoal);
  letter-spacing:.01em;
  border-left:2px solid transparent;
  transition:background .15s, color .15s, border-color .15s;
}
.dropdown a:hover{
  background:var(--stone);color:var(--forest);
  border-left-color:var(--clay);
}
.dropdown a .dd-num{
  display:inline-block;width:28px;
  font-family:'Playfair Display',serif;font-style:italic;
  color:var(--clay);font-size:13px;
}

/* ===== Mobile nav toggle (hamburger) =====
   Checkbox hack: hidden <input> + label is tapped to toggle
   .nav-checkbox:checked ~ .nav-links shows the mobile panel.
   Base styles hide it on desktop; the 768px media query activates it. */
.nav-checkbox{display:none}
.nav-toggle{
  display:none;
  align-items:center;justify-content:center;
  width:44px;height:44px;
  margin-left:auto;
  cursor:pointer;color:var(--charcoal);
  border-radius:2px;
  transition:background .15s;
}
.nav-toggle:hover{background:var(--stone)}
.nav-toggle svg{width:24px;height:24px;display:block}
.nav-toggle svg line{
  transition:transform .2s ease, opacity .2s ease;
  transform-origin:center;
}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 22px;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  border-radius:2px;cursor:pointer;
  transition:all .2s;border:none;
}
.btn-primary{background:var(--forest);color:var(--linen)}
.btn-primary:hover{background:var(--forest-deep)}
.btn-outline{background:transparent;color:var(--charcoal);border:1px solid var(--charcoal)}
.btn-outline:hover{background:var(--charcoal);color:var(--linen)}
.btn-light{background:rgba(253,251,248,.1);color:var(--linen);border:1px solid rgba(253,251,248,.3)}
.btn-light:hover{background:var(--linen);color:var(--forest)}
.btn-clay{background:var(--clay);color:var(--linen)}
.btn-clay:hover{background:#a96e38}
.btn svg{width:14px;height:14px}

/* ===== Hero ===== */
.hero{
  position:relative;
  min-height:720px;
  overflow:hidden;
  background:var(--forest-deep);
}
.hero-bg{
  position:absolute;inset:0;
  background:
    linear-gradient(135deg, rgba(31,64,41,.72), rgba(34,40,30,.45) 50%, rgba(31,64,41,.55)),
    url("img/hero.webp") center/cover no-repeat;
}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(196,131,74,.22), transparent 50%),
    radial-gradient(ellipse at 85% 20%, rgba(184,151,60,.18), transparent 45%);
}
.hero-inner{
  position:relative;z-index:2;
  padding:96px 0 120px;
  color:var(--linen);
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:#E7E0D0;margin-bottom:32px;
}
.hero-eyebrow .bar{width:40px;height:1px;background:var(--clay)}
.hero-title{
  font-family:'Playfair Display', serif;
  font-size:clamp(44px, 6vw, 78px);
  line-height:1.05;
  font-weight:600;
  margin:0 0 28px;
  max-width:960px;
  letter-spacing:-.01em;
}
.hero-title em{color:var(--clay);font-weight:500}
.hero-sub{
  font-size:18px;line-height:1.6;
  color:#E7E0D0;
  max-width:560px;margin:0 0 44px;
  font-weight:300;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

.hero-badge{
  position:absolute;right:40px;top:96px;
  background:rgba(253,251,248,.08);
  backdrop-filter:blur(8px);
  border:1px solid rgba(253,251,248,.18);
  padding:20px 24px;border-radius:2px;
  color:var(--linen);width:260px;z-index:3;
}
.hero-badge-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.hero-badge-title{font-family:'Playfair Display',serif;font-size:22px;font-style:italic;line-height:1.3;margin-bottom:14px;color:var(--linen)}
.hero-badge-meta{font-size:12px;color:#E7E0D0;opacity:.8;border-top:1px solid rgba(253,251,248,.2);padding-top:12px;display:flex;justify-content:space-between}

.hero-metrics{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  display:grid;grid-template-columns:repeat(4,1fr);
  background:rgba(31,64,41,.65);
  backdrop-filter:blur(10px);
  border-top:1px solid rgba(253,251,248,.12);
}
.hero-metric{
  padding:24px 32px;
  color:var(--linen);
  border-right:1px solid rgba(253,251,248,.1);
  display:flex;flex-direction:column;gap:4px;
}
.hero-metric:last-child{border-right:none}
.hero-metric-num{font-family:'Playfair Display',serif;font-size:36px;font-weight:600;color:var(--gold);line-height:1}
.hero-metric-lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#E7E0D0;opacity:.75;margin-top:6px}

/* ===== Section scaffolding ===== */
section{padding:120px 0;position:relative}
.section-label{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--clay);font-weight:600;margin-bottom:20px;
}
.section-label .bar{width:40px;height:1px;background:var(--clay)}
.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(36px, 4vw, 54px);
  line-height:1.1;font-weight:600;
  margin:0 0 20px;max-width:780px;
  letter-spacing:-.01em;
}
.section-title em{color:var(--clay);font-weight:500}
.section-intro{font-size:17px;color:var(--slate);max-width:640px;line-height:1.65}

.section-header{display:flex;justify-content:space-between;align-items:start;gap:40px;margin-bottom:64px}

/* ===== Services ===== */
#services{background:var(--linen)}
.services-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.service-card{
  background:var(--stone);
  border:1px solid var(--line-soft);
  overflow:hidden;
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .3s, box-shadow .3s;
  cursor:pointer;
}
.service-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(34,40,30,.25)}
.service-card.big{grid-column:span 6;min-height:520px}
.service-card.small{grid-column:span 3;min-height:440px}
.service-card.wide{grid-column:span 6;min-height:440px}

.service-img{
  position:relative;height:260px;overflow:hidden;
  background:var(--forest);
}
.service-card.big .service-img{height:320px}
.svg-ph{
  width:100%;height:100%;
  display:grid;place-items:center;
  font-family:ui-monospace,monospace;font-size:10px;
  color:rgba(253,251,248,.45);letter-spacing:.1em;
  text-align:center;padding:0 20px;
}
.svg-ph.ph-landscape,.svg-ph.ph-maint,.svg-ph.ph-paint,.svg-ph.ph-solar,.svg-ph.ph-project{
  color:transparent;
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
.ph-landscape{background-image:url("img/service-landscaping.webp")}
.ph-maint{background-image:url("img/service-maintenance.webp")}
.ph-paint{background-image:url("img/service-painting.webp")}
.ph-solar{background-image:url("img/service-solar.webp")}
.ph-project{background-image:url("img/service-project.webp")}

.service-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(34,40,30,.45) 0%, rgba(34,40,30,0) 25%, rgba(34,40,30,0) 55%, rgba(34,40,30,.45) 100%);
  pointer-events:none;
}

.service-num{
  position:absolute;top:18px;left:20px;
  font-family:'Playfair Display',serif;font-size:14px;font-style:italic;
  color:var(--linen);opacity:.9;z-index:2;letter-spacing:.05em;
}
.service-num::before{content:"";display:inline-block;width:20px;height:1px;background:var(--gold);vertical-align:middle;margin-right:10px}

.service-body{padding:28px 28px 32px;flex:1;display:flex;flex-direction:column}
.service-name{
  font-family:'Playfair Display',serif;
  font-size:28px;font-weight:600;margin:0 0 10px;
  color:var(--charcoal);
}
.service-card.big .service-name{font-size:34px}
.service-desc{color:var(--slate);font-size:15px;line-height:1.6;margin:0 0 20px;flex:1}
.service-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.service-tag{
  font-size:11px;letter-spacing:.06em;
  padding:5px 10px;
  background:rgba(196,131,74,.08);
  color:var(--clay);border-radius:2px;
  font-weight:500;
}
.service-link{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--forest);font-weight:600;
  padding-top:16px;border-top:1px solid var(--line-soft);
}
.service-link svg{width:14px;height:14px;transition:transform .2s}
.service-card:hover .service-link svg{transform:translateX(4px)}

/* ===== About ===== */
#about{background:var(--stone);overflow:hidden}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{
  position:relative;
  aspect-ratio:4/5;
  background:var(--forest);
  overflow:hidden;
}
.about-visual .svg-ph{
  background:
    linear-gradient(135deg, rgba(31,64,41,.3), transparent),
    repeating-linear-gradient(98deg, #2E5E3E 0 18px, #3a6b48 18px 38px, #264E33 38px 62px, #466f4f 62px 88px);
}
.about-stamp{
  position:absolute;bottom:24px;right:24px;
  background:var(--linen);
  padding:20px 24px;
  max-width:260px;
}
.about-stamp-year{font-family:'Playfair Display',serif;font-style:italic;font-size:42px;font-weight:600;color:var(--forest);line-height:1}
.about-stamp-txt{font-size:12px;color:var(--slate);letter-spacing:.1em;text-transform:uppercase;margin-top:8px;border-top:1px solid var(--line);padding-top:10px}

.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:40px}
.vm-card{
  background:var(--linen);
  padding:32px 28px;
  border-top:3px solid var(--clay);
}
.vm-card.gold{border-top-color:var(--gold)}
.vm-label{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--slate);margin-bottom:12px;font-weight:600}
.vm-text{font-family:'Playfair Display',serif;font-style:italic;font-size:18px;line-height:1.5;color:var(--charcoal);margin:0}

.about-quote{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:22px;line-height:1.5;color:var(--charcoal);
  padding:0 0 0 24px;border-left:2px solid var(--clay);
  margin:32px 0 0;
}

/* ===== Approach ===== */
#approach{background:var(--forest-deep);color:var(--linen);overflow:hidden}
#approach .section-title{color:var(--linen)}
#approach .section-title em{color:var(--gold)}
#approach .section-intro{color:#E7E0D0}
#approach .section-label{color:var(--gold)}
#approach .section-label .bar{background:var(--gold)}

.steps{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:0;
  border-top:1px solid rgba(253,251,248,.15);
  margin-top:40px;
}
.step{
  padding:32px 24px 32px 0;
  border-right:1px solid rgba(253,251,248,.12);
  position:relative;
}
.step:last-child{border-right:none}
.step-num{
  font-family:'Playfair Display',serif;
  font-size:64px;font-style:italic;font-weight:400;
  color:var(--gold);line-height:1;margin-bottom:18px;
  display:flex;align-items:baseline;gap:8px;
}
.step-num sup{font-size:14px;color:#E7E0D0;font-style:normal;font-family:'Inter',sans-serif;letter-spacing:.2em;opacity:.6}
.step-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;margin:0 0 10px;color:var(--linen)}
.step-desc{font-size:14px;color:#E7E0D0;line-height:1.6;opacity:.85}

/* ===== Sectors ===== */
#sectors{background:var(--linen)}
.sectors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:40px;border:1px solid var(--line)}
.sector{background:var(--linen);padding:40px 32px;display:flex;flex-direction:column;gap:14px;min-height:240px;transition:background .2s}
.sector:hover{background:var(--stone)}
.sector-icon{
  width:48px;height:48px;
  display:grid;place-items:center;
  background:rgba(46,94,62,.08);color:var(--forest);
  border-radius:2px;
}
.sector-icon svg{width:24px;height:24px;stroke-width:1.5}
.sector-name{font-family:'Playfair Display',serif;font-size:24px;font-weight:600;margin:0;color:var(--charcoal)}
.sector-desc{font-size:14px;color:var(--slate);line-height:1.6;margin:0}

/* ===== Why Choose Us ===== */
#why{background:var(--stone)}
.why-grid{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
.why-list{display:grid;gap:2px;background:var(--line);border:1px solid var(--line)}
.why-item{
  background:var(--linen);
  padding:28px 32px;
  display:grid;grid-template-columns:60px 1fr auto;gap:24px;align-items:center;
  transition:background .2s;
}
.why-item:hover{background:#fffdf7}
.why-num{font-family:'Playfair Display',serif;font-style:italic;font-size:32px;color:var(--clay);font-weight:600;line-height:1}
.why-text h4{font-family:'Playfair Display',serif;font-size:20px;font-weight:600;margin:0 0 4px;color:var(--charcoal)}
.why-text p{font-size:14px;color:var(--slate);margin:0;line-height:1.55}
.why-arrow{color:var(--forest);opacity:.3}

/* ===== Contact ===== */
#contact{background:var(--linen);padding:120px 0 0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-form{display:grid;gap:20px;margin-top:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);margin-bottom:8px;font-weight:600}
.field input, .field select, .field textarea{
  width:100%;padding:14px 16px;
  border:1px solid var(--line);background:var(--stone);
  font-family:'Inter',sans-serif;font-size:15px;
  color:var(--charcoal);border-radius:2px;
  transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{outline:none;border-color:var(--forest)}
.field textarea{resize:vertical;min-height:120px;font-family:'Inter',sans-serif}

.contact-info{display:grid;gap:4px;margin-top:32px}
.ci{
  padding:22px 0;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:120px 1fr;align-items:baseline;gap:20px;
}
.ci:last-child{border-bottom:none}
.ci-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);font-weight:600}
.ci-value{font-family:'Playfair Display',serif;font-size:22px;color:var(--charcoal);font-weight:500}
.ci-value.small{font-size:18px}

.map-strip{
  margin-top:100px;
  height:420px;
  position:relative;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--stone);
  overflow:hidden;
}
.map-embed{
  position:absolute;inset:0;
  width:100%;height:100%;
  border:0;display:block;
  filter:saturate(.9) contrast(.95);
}
.map-directions{
  position:absolute;top:20px;right:20px;z-index:5;
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 20px;
  background:var(--clay);color:var(--linen);
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  border-radius:2px;
  box-shadow:0 8px 24px -6px rgba(34,40,30,.3);
  transition:background .2s, transform .2s;
}
.map-directions:hover{background:#a96e38;transform:translateY(-1px)}
.map-directions svg{width:14px;height:14px}
@media (max-width:980px){
  .map-strip{height:340px;margin-top:60px}
  .map-directions{top:12px;right:12px;padding:10px 16px;font-size:12px}
}

/* ===== Footer ===== */
footer{background:var(--charcoal);color:#D4D3CC;padding:80px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.footer-brand .logo-name{color:var(--linen)}
.footer-brand .logo-sub{color:rgba(253,251,248,.5)}
.footer-brand p{font-size:14px;color:rgba(253,251,248,.6);margin:18px 0 0;line-height:1.6;max-width:320px}
.footer-col h5{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin:0 0 20px;font-weight:600}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.footer-col a{font-size:14px;color:rgba(253,251,248,.75);transition:color .2s}
.footer-col a:hover{color:var(--linen)}
.footer-bar{border-top:1px solid rgba(253,251,248,.12);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:12px;color:rgba(253,251,248,.5);letter-spacing:.05em}
.footer-bar em{color:var(--clay);font-style:normal}

@media (max-width:980px){
  .about-grid,.contact-grid,.why-grid{grid-template-columns:1fr;gap:48px}
  .services-grid .service-card{grid-column:span 12}
  .steps{grid-template-columns:repeat(2,1fr)}
  .sectors-grid,.footer-grid{grid-template-columns:1fr 1fr}
  .hero-metrics{grid-template-columns:1fr 1fr}
  .hero-badge{display:none}
  /* Tablet: tighten nav gaps so it fits alongside logo + CTA */
  .nav-links{gap:22px}
  .nav-links a{font-size:13px}
}

/* ===== Mobile tier (phones + small tablets) ===== */
@media (max-width:768px){
  /* Activate hamburger, hide desktop-row nav-links + CTA */
  .nav-toggle{display:inline-flex}
  .nav-inner > .btn-primary{display:none}
  .nav-inner{padding:14px 0;position:relative}

  /* Mobile nav panel: full-width dropdown below sticky nav */
  .nav-links{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;gap:0;
    background:var(--linen);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    padding:6px 0;
    box-shadow:0 20px 30px -12px rgba(34,40,30,.18);
    z-index:55;
  }
  .nav-checkbox:checked ~ .nav-links{display:flex}
  .nav-links > li{border-bottom:1px solid var(--line-soft);width:100%}
  .nav-links > li:last-child{border-bottom:none}
  .nav-links a{
    padding:14px clamp(16px,4vw,40px);
    font-size:15px;width:100%;
  }
  .nav-links a.active::after{display:none}

  /* Flatten the services dropdown on mobile — show inline, no hover needed */
  .nav-links .dropdown{
    position:static;opacity:1;visibility:visible;
    transform:none;box-shadow:none;border:none;
    background:var(--stone);
    padding:4px 0 8px;min-width:0;
    border-top:1px solid var(--line-soft);
  }
  .nav-links .has-dropdown > a::after{display:none}
  .dropdown a{padding:10px clamp(28px,6vw,52px) !important;font-size:14px}

  /* Hamburger → X animation on checked */
  .nav-checkbox:checked ~ .nav-toggle .ham-top{transform:rotate(45deg) translate(3px,4px)}
  .nav-checkbox:checked ~ .nav-toggle .ham-mid{opacity:0}
  .nav-checkbox:checked ~ .nav-toggle .ham-bot{transform:rotate(-45deg) translate(3px,-4px)}

  /* Logo compacts slightly */
  .logo-mark{width:44px;height:44px}
  .logo-name{font-size:17px}
  .logo-sub{font-size:9px;letter-spacing:.22em}

  /* Topbar: hide hours, drop location to keep room for phone+email */
  .topbar-right{display:none}
  .topbar-left{gap:14px}
  .topbar-left > span{display:none}

  /* Steps: 2-col → 1-col with border flip (right → bottom) */
  .steps{grid-template-columns:1fr}
  .steps .step{
    padding:20px 0;
    border-right:none !important;
    border-bottom:1px solid var(--line-soft);
  }
  .steps .step:last-child{border-bottom:none}

  /* Footer: 2-col → 1-col */
  .footer-grid{grid-template-columns:1fr;gap:32px}

  /* Hero: tighter vertical padding, sub full-width */
  .hero-inner{padding:72px 0 96px}
  .hero-sub{max-width:100%}
  .hero-cta{flex-wrap:wrap;gap:10px}

  /* Hero metrics: tighten card padding, smaller number */
  .hero-metric{padding:16px 18px}
  .hero-metric-num{font-size:26px}

  /* Page-hero (service pages) */
  .page-hero{padding:60px 0 100px;min-height:320px}

  /* Forms */
  .form-row{grid-template-columns:1fr;gap:14px}
}

/* ===== Small phones (≤480px) ===== */
@media (max-width:480px){
  /* Topbar: only keep phone number; hide email + hours to prevent wrap */
  .topbar-left a[href^="mailto:"]{display:none}
  .topbar-left{gap:10px;font-size:12px}
  .topbar-left svg{width:11px;height:11px}

  /* Nav: drop sub-tagline, shrink logo */
  .logo-mark{width:40px;height:40px}
  .logo-name{font-size:15px}
  .logo-sub{display:none}
  .nav-inner{padding:12px 0}

  /* Sectors: 2-col → 1-col */
  .sectors-grid{grid-template-columns:1fr}

  /* Hero: more compact */
  .hero-inner{padding:56px 0 72px}
  .hero-metrics{gap:8px}
  .hero-metric{padding:12px 14px}
  .hero-metric-num{font-size:22px}
  .hero-metric-lbl{font-size:10px;letter-spacing:.12em}

  /* Buttons: slightly smaller so they don't overflow cards */
  .btn{padding:11px 18px;font-size:12px}

  /* About/contact gaps */
  .about-grid,.contact-grid,.why-grid{gap:32px}

  /* Page hero even tighter */
  .page-hero{padding:48px 0 72px;min-height:260px}
}

/* ===== Service Page Hero ===== */
.page-hero{
  position:relative;
  min-height:420px;
  overflow:hidden;
  background:var(--forest-deep);
  color:var(--linen);
  display:flex;align-items:center;
  padding:80px 0 140px;
}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(135deg, rgba(31,64,41,.88), rgba(34,40,30,.6) 50%, rgba(31,64,41,.45)),
    repeating-linear-gradient(115deg, #2E5E3E 0 14px, #264E33 14px 28px, #335E45 28px 46px, #3F6A51 46px 64px, #2E5E3E 64px 90px);
}
.page-hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(196,131,74,.18), transparent 45%),
    radial-gradient(ellipse at 85% 20%, rgba(184,151,60,.15), transparent 40%);
}
.page-hero .container{position:relative;z-index:3}
.page-hero-banner{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  height:120px;
  border-top:1px solid rgba(253,251,248,.12);
  opacity:.9;
}
.page-hero-banner.ph-landscape,
.page-hero-banner.ph-maint,
.page-hero-banner.ph-paint,
.page-hero-banner.ph-solar,
.page-hero-banner.ph-project{}

/* Per-service photographic page-hero backgrounds */
.page-hero[class*="ph-bg-"] .page-hero-banner{display:none}
.page-hero.ph-bg-landscaping::before{
  background:linear-gradient(135deg, rgba(31,64,41,.78), rgba(34,40,30,.55) 50%, rgba(31,64,41,.55)),
    url("img/hero-landscaping.webp") center/cover no-repeat;
}
.page-hero.ph-bg-maintenance::before{
  background:linear-gradient(135deg, rgba(31,64,41,.78), rgba(34,40,30,.55) 50%, rgba(31,64,41,.55)),
    url("img/hero-maintenance.webp") center/cover no-repeat;
}
.page-hero.ph-bg-painting::before{
  background:linear-gradient(135deg, rgba(31,64,41,.78), rgba(34,40,30,.55) 50%, rgba(31,64,41,.55)),
    url("img/hero-painting.webp") center/cover no-repeat;
}
.page-hero.ph-bg-solar::before{
  background:linear-gradient(135deg, rgba(31,64,41,.82), rgba(34,40,30,.6) 50%, rgba(31,64,41,.6)),
    url("img/hero-solar.webp") center/cover no-repeat;
}
.page-hero.ph-bg-project::before{
  background:linear-gradient(135deg, rgba(31,64,41,.78), rgba(34,40,30,.55) 50%, rgba(31,64,41,.55)),
    url("img/hero-project.webp") center/cover no-repeat;
}

.page-breadcrumb{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:#E7E0D0;opacity:.75;margin-bottom:20px;
  font-weight:500;
}
.page-breadcrumb a{color:#E7E0D0;transition:color .2s}
.page-breadcrumb a:hover{color:var(--clay)}
.page-breadcrumb .sep{margin:0 10px;color:var(--clay);opacity:.7}
.page-breadcrumb .cur{color:var(--linen);opacity:.9}

.page-hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:#E7E0D0;margin-bottom:20px;
}
.page-hero-eyebrow .bar{width:40px;height:1px;background:var(--clay)}
.page-hero-title{
  font-family:'Playfair Display', serif;
  font-size:clamp(40px, 5vw, 64px);
  line-height:1.05;font-weight:600;
  margin:0 0 18px;max-width:820px;
  letter-spacing:-.01em;color:var(--linen);
}
.page-hero-title em{color:var(--clay);font-weight:500}
.page-hero-sub{
  font-size:17px;line-height:1.6;
  color:#E7E0D0;max-width:620px;margin:0;
  font-weight:300;
}

/* ===== Content Sections ===== */
.content-section{
  padding:120px 0;position:relative;
  background:var(--linen);
}
.content-section.alt{background:var(--stone)}
.content-section.dark{background:var(--forest-deep);color:var(--linen)}
.content-section.dark .section-title{color:var(--linen)}
.content-section.dark .section-title em{color:var(--gold)}
.content-section.dark .section-intro{color:#E7E0D0}
.content-section.dark .section-label{color:var(--gold)}
.content-section.dark .section-label .bar{background:var(--gold)}

.prose{max-width:780px}
.prose p{font-size:17px;line-height:1.75;color:var(--slate);margin:0 0 20px}
.prose p:last-child{margin-bottom:0}
.prose p strong{color:var(--charcoal);font-weight:600}

/* ===== Scope List ===== */
.scope-list{
  list-style:none;padding:0;margin:40px 0 0;
  display:grid;grid-template-columns:1fr 1fr;gap:16px 40px;
}
.scope-list li{
  position:relative;
  padding:16px 0 16px 36px;
  border-bottom:1px solid var(--line-soft);
  font-size:15px;line-height:1.55;color:var(--charcoal);
}
.scope-list li::before{
  content:"";position:absolute;left:0;top:22px;
  width:18px;height:10px;
  border-left:2px solid var(--clay);
  border-bottom:2px solid var(--clay);
  transform:rotate(-45deg);
}
.scope-list li strong{font-family:'Playfair Display',serif;font-weight:600;color:var(--charcoal);display:block;margin-bottom:2px;font-size:16px}
.scope-list li span{color:var(--slate);font-size:14px}

/* ===== Gallery Grid ===== */
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin-top:40px;
}
.gallery-grid .svg-ph{
  aspect-ratio:4/3;height:auto;
}

/* ===== FAQ ===== */
.faq{margin-top:40px;max-width:820px}
.faq details{
  border-bottom:1px solid var(--line);
  padding:22px 0;
  transition:border-color .2s;
}
.faq details[open]{border-bottom-color:var(--clay)}
.faq summary{
  font-family:'Playfair Display',serif;
  font-size:20px;font-weight:600;color:var(--charcoal);
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  transition:color .2s;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";
  font-family:'Inter',sans-serif;font-weight:300;font-size:28px;
  color:var(--clay);line-height:1;
  transition:transform .2s;
}
.faq details[open] summary{color:var(--clay)}
.faq details[open] summary::after{content:"–"}
.faq .faq-body{
  margin-top:14px;font-size:15px;line-height:1.7;color:var(--slate);
}
.faq .faq-body p{margin:0 0 12px}
.faq .faq-body p:last-child{margin:0}

/* ===== CTA Strip ===== */
.cta-strip{
  background:var(--forest-deep);
  color:var(--linen);
  padding:140px 0;
  text-align:center;
  position:relative;overflow:hidden;
}
.cta-strip::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(196,131,74,.12), transparent 60%);
}
.cta-strip .container{position:relative;z-index:2}
.cta-strip h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(32px, 3.6vw, 48px);
  line-height:1.15;font-weight:600;
  margin:0 0 16px;color:var(--linen);
  letter-spacing:-.01em;
}
.cta-strip h2 em{color:var(--gold);font-weight:500}
.cta-strip p{
  font-size:17px;color:#E7E0D0;
  max-width:560px;margin:0 auto 32px;line-height:1.6;font-weight:300;
}

@media (max-width:980px){
  .scope-list{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .page-hero{padding:60px 0 120px;min-height:380px}
  .content-section{padding:80px 0}
  .cta-strip{padding:100px 0}
}
