/* ==========================================================================
   Total Lawn Care and Property Management — Landing page styles
   Merged theme: premium dark hero (Prime Edge) + clean light sections
   (Fresh Cut) + photographic dark accents.
   Self-contained: imagery is built from CSS gradients + inline SVG so the
   site renders perfectly offline. Swap any .photo-* background with a real
   image URL when you have photography.
   ========================================================================== */

/* ---------- Design tokens ---------- */
:root {
  --green-900: #0c2410;
  --green-800: #14300f;
  --green-700: #1e3d1c;   /* logo forest green — primary brand */
  --green-600: #2c5523;
  --green-500: #3a6b2e;
  --lime-500:  #6f9d3f;
  --lime-400:  #84b84a;
  --lime-300:  #a6cf63;
  --gold:      #c6a865;   /* logo tan / gold */
  --gold-dark: #a8884a;
  --gold-light:#d8c08a;

  --ink:       #14211a;
  --body:      #475a4f;
  --muted:     #6b7d72;
  --line:      #e3eadf;
  --cream:     #f6f9f2;
  --white:     #ffffff;
  --dark-bg:   #0d1711;
  --dark-card: #15241a;
  --dark-line: #25382b;

  --radius:    16px;
  --radius-sm: 10px;
  --shadow-sm: 0 2px 10px rgba(16,40,22,.06);
  --shadow-md: 0 12px 34px rgba(16,40,22,.12);
  --shadow-lg: 0 30px 70px rgba(0,0,0,.35);
  --maxw:      1180px;
  --ease:      cubic-bezier(.2,.7,.2,1);
  --font-display: "Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif;
  --font-body: "Inter", "Segoe UI", system-ui, sans-serif;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--body);
  background: var(--white);
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
h1, h2, h3, h4 { font-family: var(--font-display); color: var(--ink); line-height: 1.12; font-weight: 800; letter-spacing: -.02em; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: 92px 0; }
.section--tight { padding: 64px 0; }
.center { text-align: center; }

/* ---------- Reusable bits ---------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display);
  font-size: 12.5px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--gold-dark);
}
.eyebrow::before { content: ""; width: 16px; height: 16px; background: var(--gold);
  -webkit-mask: var(--leaf) center/contain no-repeat; mask: var(--leaf) center/contain no-repeat; }
.eyebrow--light { color: var(--gold); }

.section-title { font-size: clamp(28px, 4vw, 44px); margin: 12px 0 14px; }
.section-intro { max-width: 620px; margin: 0 auto; color: var(--muted); font-size: 17px; }
.section-head { margin-bottom: 52px; }

.btn {
  --bg: var(--green-600); --fg: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--bg); color: var(--fg);
  font-family: var(--font-display); font-weight: 700; font-size: 15px;
  padding: 15px 26px; border-radius: 999px; border: 0; cursor: pointer;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .2s;
  box-shadow: 0 8px 20px rgba(46,125,50,.28);
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(46,125,50,.36); }
.btn--lime { --bg: var(--lime-500); box-shadow: 0 8px 20px rgba(124,179,66,.32); }
.btn--ghost { --bg: transparent; --fg: #fff; box-shadow: none; border: 1.5px solid rgba(255,255,255,.55); }
.btn--ghost:hover { background: rgba(255,255,255,.12); box-shadow: none; }
.btn--outline { --bg: #fff; --fg: var(--green-700); border: 1.5px solid var(--line); box-shadow: var(--shadow-sm); }
.btn--lg { padding: 17px 32px; font-size: 16px; }
.btn .ico { width: 18px; height: 18px; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--line);
  transition: background .3s, box-shadow .3s;
}
.nav { display: flex; align-items: center; gap: 28px; height: 76px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 800; }
.brand__mark { width: 38px; height: 38px; flex: none; }
.brand__name { font-size: 18px; color: var(--ink); line-height: 1; }
.brand__name small { display: block; font-size: 9.5px; letter-spacing: .2em; color: var(--gold-dark); font-weight: 800; margin-top: 3px; }
.footer .brand__name small { color: var(--gold-light); }
.nav__links { display: flex; gap: 26px; margin-left: 14px; }
.nav__links a { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--ink); position: relative; padding: 6px 0; }
.nav__links a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 2px; background: var(--lime-500); transition: width .25s var(--ease); }
.nav__links a:hover::after { width: 100%; }
.nav__actions { display: flex; align-items: center; gap: 16px; margin-left: auto; }
.nav__phone { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display); font-weight: 700; color: var(--green-700); font-size: 15px; }
.nav__phone .ico { width: 17px; height: 17px; }
.nav__toggle { display: none; background: none; border: 0; cursor: pointer; padding: 6px; }
.nav__toggle span { display: block; width: 24px; height: 2.5px; background: var(--ink); border-radius: 2px; margin: 5px 0; transition: .3s; }

/* ---------- Hero (premium dark, cinematic) ---------- */
.hero { position: relative; color: #fff; isolation: isolate; }
.hero__bg {
  position: absolute; inset: 0; z-index: -2;
  background:
    radial-gradient(120% 90% at 75% 15%, #2c5e34 0%, #16341e 45%, #0b1d11 100%);
}
.hero__bg::after { /* layered "lawn + home" suggestion */
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(8,18,11,.15), rgba(8,18,11,.78)),
    repeating-linear-gradient(95deg, rgba(255,255,255,.035) 0 38px, rgba(0,0,0,.05) 38px 76px);
}
.hero__inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px; align-items: center; min-height: 640px; padding: 70px 0 90px; }
.hero__tag {
  display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-display);
  font-size: 12.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--lime-300); background: rgba(124,179,66,.14); border: 1px solid rgba(124,179,66,.32);
  padding: 8px 15px; border-radius: 999px; margin-bottom: 22px;
}
.hero h1 { color: #fff; font-size: clamp(40px, 6.2vw, 70px); letter-spacing: -.03em; }
.hero h1 .accent { color: var(--lime-400); }
.hero__sub { font-size: 19px; color: rgba(255,255,255,.86); max-width: 520px; margin: 22px 0 32px; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; }
.hero__trust-mini { display: flex; gap: 26px; margin-top: 38px; flex-wrap: wrap; }
.hero__trust-mini div { font-size: 14px; color: rgba(255,255,255,.8); }
.hero__trust-mini strong { display: block; font-family: var(--font-display); font-size: 26px; color: #fff; }

/* Hero visual card */
.hero__visual { position: relative; }
.hero__photo {
  position: relative; border-radius: 22px; overflow: hidden; box-shadow: var(--shadow-lg);
  aspect-ratio: 4/3.4; border: 1px solid rgba(255,255,255,.18);
}
.photo-lawn {
  background: url("https://images.pexels.com/photos/7546775/pexels-photo-7546775.jpeg?auto=compress&cs=tinysrgb&w=1200") center/cover no-repeat;
  background-color: #4f9e3f;
  position: absolute; inset: 0;
}
.photo-lawn::before, .photo-lawn::after { content: none; }
.hero__badge {
  position: absolute; left: -18px; bottom: 28px; background: #fff; color: var(--ink);
  border-radius: 14px; padding: 14px 18px; box-shadow: var(--shadow-md); display: flex; gap: 12px; align-items: center;
}
.hero__badge .stars { color: var(--gold); font-size: 14px; letter-spacing: 1px; }
.hero__badge strong { font-family: var(--font-display); font-size: 17px; display: block; }
.hero__badge small { color: var(--muted); font-size: 12.5px; }

/* ---------- Trust strip (light) ---------- */
.trust { background: var(--white); margin-top: -52px; position: relative; z-index: 5; }
.trust__grid {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow-md); display: grid; grid-template-columns: repeat(4, 1fr);
}
.trust__item { display: flex; gap: 14px; padding: 26px 24px; align-items: flex-start; }
.trust__item + .trust__item { border-left: 1px solid var(--line); }
.trust__ico { width: 44px; height: 44px; flex: none; border-radius: 12px; display: grid; place-items: center; background: var(--cream); color: var(--green-600); }
.trust__ico svg { width: 22px; height: 22px; }
.trust__item h4 { font-size: 15.5px; margin-bottom: 3px; }
.trust__item p { font-size: 13.5px; color: var(--muted); line-height: 1.45; }

/* ---------- Services (light cards) ---------- */
.services { background: var(--cream); }
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.svc-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.svc-card__photo { height: 150px; position: relative; }
.svc-card__photo .badge { position: absolute; left: 14px; bottom: -18px; width: 46px; height: 46px; border-radius: 12px; background: #fff; box-shadow: var(--shadow-sm); display: grid; place-items: center; color: var(--green-600); }
.svc-card__photo .badge svg { width: 24px; height: 24px; }
.svc-card__body { padding: 30px 22px 26px; }
.svc-card h3 { font-size: 19px; margin-bottom: 8px; }
.svc-card p { font-size: 14.5px; color: var(--muted); }
.svc-card a { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; color: var(--green-600); font-family: var(--font-display); font-weight: 700; font-size: 14px; }
.svc-card a .ico { width: 15px; height: 15px; transition: transform .25s var(--ease); }
.svc-card:hover a .ico { transform: translateX(4px); }

/* real photo fills for service cards */
.svc-card__photo { background-color: #2e7d32; background-size: cover; background-position: center; }
.pf-mow   { background-image: url("https://images.pexels.com/photos/4162011/pexels-photo-4162011.jpeg?auto=compress&cs=tinysrgb&w=800"); }
.pf-edge  { background-image: url("https://images.pexels.com/photos/24595771/pexels-photo-24595771.jpeg?auto=compress&cs=tinysrgb&w=800"); }
.pf-land  { background-image: url("https://images.pexels.com/photos/31912301/pexels-photo-31912301.jpeg?auto=compress&cs=tinysrgb&w=800"); }
.pf-sod   { background-image: url("https://images.pexels.com/photos/5231236/pexels-photo-5231236.jpeg?auto=compress&cs=tinysrgb&w=800"); }
.pf-bed   { background-image: url("https://images.pexels.com/photos/570041/pexels-photo-570041.jpeg?auto=compress&cs=tinysrgb&w=800"); }
.pf-season{ background-image: url("https://images.pexels.com/photos/33356825/pexels-photo-33356825.jpeg?auto=compress&cs=tinysrgb&w=800"); }
.svc-card__photo::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.18)); }

/* ---------- Results gallery (dark) ---------- */
.gallery { background: var(--dark-bg); color: #fff; }
.gallery .section-title, .gallery h3 { color: #fff; }
.gallery .section-intro { color: rgba(255,255,255,.7); }
.gal-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; gap: 16px; }
.gal-item { border-radius: 14px; overflow: hidden; position: relative; border: 1px solid var(--dark-line); }
.gal-item { background-size: cover; background-position: center; background-color:#15241a; }
.gal-item::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,0) 42%, rgba(0,0,0,.58)); }
.gal-item .cap { position: absolute; left: 14px; bottom: 12px; z-index: 2; font-family: var(--font-display); font-weight: 700; font-size: 14px; color:#fff; text-shadow: 0 2px 8px rgba(0,0,0,.5); }
.gal-item.tall { grid-row: span 2; }
.gal-item.wide { grid-column: span 2; }
.g1{background-image:url("https://images.pexels.com/photos/4846304/pexels-photo-4846304.jpeg?auto=compress&cs=tinysrgb&w=1200");}
.g2{background-image:url("https://images.pexels.com/photos/16787453/pexels-photo-16787453.jpeg?auto=compress&cs=tinysrgb&w=800");}
.g3{background-image:url("https://images.pexels.com/photos/13630739/pexels-photo-13630739.jpeg?auto=compress&cs=tinysrgb&w=800");}
.g4{background-image:url("https://images.pexels.com/photos/11364122/pexels-photo-11364122.jpeg?auto=compress&cs=tinysrgb&w=800");}
.g5{background-image:url("https://images.pexels.com/photos/5178034/pexels-photo-5178034.jpeg?auto=compress&cs=tinysrgb&w=800");}
.g6{background-image:url("https://images.pexels.com/photos/6728933/pexels-photo-6728933.jpeg?auto=compress&cs=tinysrgb&w=1200");}

/* ---------- Before / After ---------- */
.ba { background: var(--cream); }
.ba__wrap { max-width: 760px; margin: 0 auto; }
.ba__frame { position: relative; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); aspect-ratio: 16/8; user-select: none; }
.ba__layer { position: absolute; inset: 0; }
.ba__before, .ba__after {
  background: url("https://images.pexels.com/photos/7546775/pexels-photo-7546775.jpeg?auto=compress&cs=tinysrgb&w=1200") center/cover no-repeat;
}
.ba__before { filter: saturate(.4) brightness(.92) sepia(.28); }
.ba__before::after, .ba__after::after { content:none; }
.ba__after { clip-path: inset(0 50% 0 0); }
.ba__label { position: absolute; bottom: 14px; z-index: 4; background: rgba(0,0,0,.6); color:#fff; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: .1em; padding: 6px 12px; border-radius: 6px; }
.ba__label.l { left: 14px; } .ba__label.r { right: 14px; }
.ba__handle { position: absolute; top: 0; bottom: 0; left: 50%; width: 3px; background:#fff; z-index: 5; transform: translateX(-50%); }
.ba__handle::after { content:"⟺"; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 40px; height: 40px; background:#fff; color: var(--green-700); border-radius:50%; display:grid; place-items:center; box-shadow: var(--shadow-md); font-size: 16px; }
.ba__range { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: ew-resize; z-index: 6; }

/* ---------- Reviews ---------- */
.reviews__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.review {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 28px 26px; box-shadow: var(--shadow-sm);
}
.review .stars { color: var(--gold); letter-spacing: 2px; font-size: 16px; }
.review p { margin: 14px 0 18px; color: var(--ink); font-size: 15.5px; }
.review .who { display:flex; align-items:center; gap:12px; }
.review .ava { width: 42px; height:42px; border-radius:50%; background: linear-gradient(135deg,var(--lime-400),var(--green-600)); color:#fff; display:grid; place-items:center; font-family:var(--font-display); font-weight:700; }
.review .who b { font-family: var(--font-display); font-size: 15px; color: var(--ink); }
.review .who small { color: var(--muted); display:block; font-size: 13px; }

/* ---------- Why choose + FAQ ---------- */
.why { background: var(--cream); }
.why__grid { display: grid; grid-template-columns: 1fr 1.15fr; gap: 48px; align-items: start; }
.why__panel { background: var(--green-800); color:#fff; border-radius: var(--radius); padding: 38px 34px; box-shadow: var(--shadow-md); }
.why__panel h3 { color:#fff; font-size: 24px; margin-bottom: 22px; }
.why__list li { display:flex; gap:13px; padding: 11px 0; border-bottom: 1px solid rgba(255,255,255,.12); font-size: 15.5px; color: rgba(255,255,255,.92); }
.why__list li:last-child { border-bottom: 0; }
.why__list .tick { width:24px; height:24px; flex:none; border-radius:50%; background: var(--lime-500); color: var(--green-900); display:grid; place-items:center; }
.why__list .tick svg { width: 14px; height: 14px; }

.faq { }
.faq__item { background:#fff; border:1px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 12px; overflow: hidden; transition: box-shadow .25s; }
.faq__item[open] { box-shadow: var(--shadow-sm); }
.faq__q { list-style: none; cursor: pointer; padding: 18px 22px; display:flex; justify-content: space-between; align-items: center; gap: 16px; font-family: var(--font-display); font-weight: 700; color: var(--ink); font-size: 16px; }
.faq__q::-webkit-details-marker { display: none; }
.faq__q .pm { width: 26px; height: 26px; flex:none; border-radius: 50%; background: var(--cream); color: var(--green-600); display:grid; place-items:center; font-size: 18px; transition: transform .3s var(--ease); }
.faq__item[open] .faq__q .pm { transform: rotate(45deg); }
.faq__a { padding: 0 22px 20px; color: var(--muted); font-size: 14.5px; }

/* ---------- Process 1-2-3 ---------- */
.process__row { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; position: relative; }
.process__step { text-align: center; position: relative; }
.process__num { width: 74px; height: 74px; margin: 0 auto 18px; border-radius: 50%; background: var(--green-600); color:#fff; display:grid; place-items:center; font-family: var(--font-display); font-weight:800; font-size: 28px; box-shadow: 0 12px 26px rgba(46,125,50,.32); position: relative; z-index: 2; }
.process__step h3 { font-size: 20px; margin-bottom: 8px; }
.process__step p { color: var(--muted); font-size: 14.5px; max-width: 280px; margin: 0 auto; }
.process__row::before { content:""; position:absolute; top: 37px; left: 16%; right: 16%; height: 2px; background: repeating-linear-gradient(90deg, var(--line) 0 10px, transparent 10px 20px); z-index: 1; }

/* ---------- Service area ---------- */
.area { background: var(--dark-bg); color:#fff; }
.area__grid { display:grid; grid-template-columns: 1fr 1.1fr; gap: 46px; align-items: center; }
.area h2 { color:#fff; }
.area p.lead { color: rgba(255,255,255,.74); font-size: 16.5px; margin: 14px 0 26px; }
.area__cities { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 26px; margin-bottom: 28px; }
.area__cities li { display:flex; align-items:center; gap:10px; color: rgba(255,255,255,.9); font-size: 15px; }
.area__cities .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lime-400); flex:none; }
.area__map { position: relative; border-radius: var(--radius); overflow:hidden; aspect-ratio: 4/3.2; border:1px solid var(--dark-line); background: radial-gradient(120% 120% at 60% 40%, #1f3a26, #112016); }
.area__map .blob { position:absolute; inset: 18% 22% 24% 18%; background: radial-gradient(circle at 50% 45%, rgba(124,179,66,.55), rgba(124,179,66,.12) 70%); border:2px dashed rgba(124,179,66,.5); border-radius: 46% 54% 50% 50% / 52% 46% 54% 48%; }
.area__map .pin { position:absolute; top: 44%; left: 46%; width: 18px; height: 18px; background: var(--lime-400); border: 3px solid #fff; border-radius:50% 50% 50% 0; transform: rotate(-45deg); box-shadow: 0 6px 14px rgba(0,0,0,.4); }
.area__map .grid-lines { position:absolute; inset:0; background-image: linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px); background-size: 44px 44px; }

/* ---------- CTA quote form (dark) ---------- */
.cta { background: linear-gradient(135deg, var(--green-800), var(--green-700)); color:#fff; }
.cta__grid { display:grid; grid-template-columns: 1fr 1.05fr; gap: 50px; align-items: center; }
.cta h2 { color:#fff; font-size: clamp(28px,3.6vw,40px); }
.cta p { color: rgba(255,255,255,.85); font-size: 16.5px; margin: 14px 0 24px; }
.cta__list li { display:flex; gap:11px; align-items:center; margin-bottom: 12px; color:#fff; font-size: 15.5px; }
.cta__list .tick { width:22px;height:22px;border-radius:50%;background:var(--lime-500);color:var(--green-900);display:grid;place-items:center;flex:none;}
.cta__list .tick svg{width:13px;height:13px;}
.qform { background:#fff; border-radius: var(--radius); padding: 32px; box-shadow: var(--shadow-lg); }
.qform h3 { color: var(--ink); font-size: 22px; margin-bottom: 6px; }
.qform .small { color: var(--muted); font-size: 14px; margin-bottom: 20px; }
.qform .row { display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field { margin-bottom: 14px; }
.field label { display:block; font-family:var(--font-display); font-weight:600; font-size: 13px; color: var(--ink); margin-bottom: 6px; }
.field input, .field select, .field textarea {
  width:100%; padding: 13px 14px; border:1.5px solid var(--line); border-radius: var(--radius-sm);
  font-family: var(--font-body); font-size: 15px; color: var(--ink); background:#fff; transition: border-color .2s, box-shadow .2s;
}
.field textarea { resize: vertical; min-height: 92px; }
.field input:focus, .field select:focus, .field textarea:focus { outline:0; border-color: var(--green-500); box-shadow: 0 0 0 4px rgba(63,145,66,.12); }
.qform .btn { width: 100%; margin-top: 6px; }
.qform .alt { text-align:center; color: var(--muted); font-size: 13.5px; margin-top: 14px; }
.form-note { display:none; background: #e9f6e5; color: var(--green-700); border:1px solid #bfe3a0; border-radius: var(--radius-sm); padding: 12px 14px; font-size: 14px; margin-bottom: 14px; }
.form-note.show { display:block; }

/* ---------- Footer ---------- */
.footer { background: #0a140d; color: rgba(255,255,255,.7); padding: 70px 0 30px; }
.footer__grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer h4 { color:#fff; font-size: 14px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 18px; }
.footer a { display:block; padding: 5px 0; font-size: 14.5px; transition: color .2s; }
.footer a:hover { color: var(--lime-400); }
.footer .brand__name { color:#fff; }
.footer__about p { font-size: 14.5px; margin: 16px 0; max-width: 300px; }
.footer__contact li { display:flex; gap:10px; align-items:flex-start; margin-bottom: 12px; font-size: 14.5px; }
.footer__contact .ico { width:17px;height:17px;color:var(--lime-400);flex:none;margin-top:3px;}
.footer__social { display:flex; gap:12px; margin-top: 6px; }
.footer__social a { width: 38px; height:38px; border-radius:50%; background: rgba(255,255,255,.08); display:grid; place-items:center; }
.footer__social a:hover { background: var(--green-600); }
.footer__social svg { width: 17px; height:17px; color:#fff; }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 50px; padding-top: 24px; display:flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: 13px; }

/* ---------- Reveal on scroll ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; min-height: 0; padding: 56px 0 70px; }
  .hero__visual { display: none; }
  .trust__grid { grid-template-columns: 1fr 1fr; }
  .trust__item:nth-child(3) { border-left: 0; }
  .svc-grid { grid-template-columns: 1fr 1fr; }
  .gal-grid { grid-template-columns: repeat(2,1fr); }
  .why__grid, .area__grid, .cta__grid { grid-template-columns: 1fr; gap: 32px; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .nav__links, .nav__phone { display: none; }
  .nav__toggle { display: block; }
  .nav.open .nav__links { display: flex; position: absolute; top: 76px; left: 0; right: 0; flex-direction: column; background:#fff; padding: 18px 24px; border-bottom:1px solid var(--line); box-shadow: var(--shadow-md); }
  .trust__grid { grid-template-columns: 1fr; }
  .trust__item { border-left: 0 !important; border-top: 1px solid var(--line); }
  .trust__item:first-child { border-top: 0; }
  .svc-grid, .reviews__grid, .process__row { grid-template-columns: 1fr; }
  .process__row::before { display: none; }
  .gal-grid { grid-template-columns: 1fr; grid-auto-rows: 170px; }
  .gal-item.wide, .gal-item.tall { grid-column: auto; grid-row: auto; }
  .qform .row { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .section { padding: 64px 0; }
}
