/* =====================================================
   LANDSCAPE AROUND YOU — Global Stylesheet
   ===================================================== */
:root {
  --green-dark:    #1b5e20;
  --green-mid:     #2e7d32;
  --green-bright:  #43a047;
  --green-light:   #81c784;
  --red:           #c62828;
  --red-hover:     #b71c1c;
  --dark:          #080808;
  --dark-2:        #111;
  --dark-3:        #1c1c1c;
  --dark-card:     #212121;
  --white:         #ffffff;
  --off-white:     #f7f7f5;
  --gray:          #e4e4e0;
  --text-gray:     #5a5a5a;
  --font-head:     'Oswald', sans-serif;
  --font-body:     'Open Sans', sans-serif;
  --ease:          all 0.3s cubic-bezier(.25,.8,.25,1);
  --shadow:        0 4px 28px rgba(0,0,0,.14);
  --shadow-xl:     0 12px 50px rgba(0,0,0,.28);
}

/* ===== RESET ===== */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font-body); color:#222; background:#fff; overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ===== UTILITIES ===== */
.container { max-width:1220px; margin:0 auto; padding:0 28px; }
.tag  { font-family:var(--font-head); font-size:.72rem; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--green-bright); }
.tag.light { color:var(--green-light); }
.h2  { font-family:var(--font-head); font-size:clamp(2rem,4vw,3rem); font-weight:700; text-transform:uppercase; line-height:1.08; }
.h2.white { color:#fff; }
.h2.dark  { color:var(--dark); }
.sub { font-size:.96rem; color:var(--text-gray); line-height:1.75; margin-top:14px; max-width:580px; }
.sub.white { color:rgba(255,255,255,.68); }
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 30px; font-family:var(--font-head); font-size:.88rem; font-weight:600; letter-spacing:1.6px; text-transform:uppercase; border-radius:3px; transition:var(--ease); }
.btn-red    { background:var(--red); color:#fff; }
.btn-red:hover { background:var(--red-hover); transform:translateY(-2px); box-shadow:0 6px 22px rgba(198,40,40,.42); }
.btn-green  { background:var(--green-mid); color:#fff; }
.btn-green:hover { background:var(--green-dark); transform:translateY(-2px); }
.btn-ghost  { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.7); }
.btn-ghost:hover { background:#fff; color:var(--dark); }
.btn-white  { background:#fff; color:var(--dark); }
.btn-white:hover { background:var(--off-white); transform:translateY(-2px); }
.btn-outline { background:transparent; color:var(--green-mid); border:2px solid var(--green-mid); }
.btn-outline:hover { background:var(--green-mid); color:#fff; }

/* ===== REVEAL ===== */
.rev   { opacity:0; transform:translateY(32px); transition:opacity .65s ease,transform .65s ease; }
.rev.in { opacity:1; transform:translateY(0); }
.rev-l  { opacity:0; transform:translateX(-40px); transition:opacity .7s ease,transform .7s ease; }
.rev-l.in { opacity:1; transform:translateX(0); }
.rev-r  { opacity:0; transform:translateX(40px); transition:opacity .7s ease,transform .7s ease; }
.rev-r.in { opacity:1; transform:translateX(0); }

/* ===== TOP BAR ===== */
.topbar { background:var(--dark); padding:9px 0; font-size:.78rem; }
.topbar-wrap { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.topbar-left { display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.topbar-left a { color:rgba(255,255,255,.72); display:flex; align-items:center; gap:6px; transition:var(--ease); }
.topbar-left a:hover { color:var(--green-light); }
.topbar-left span { color:rgba(255,255,255,.3); }
.topbar-right { display:flex; gap:10px; }
.topbar-right a { width:26px; height:26px; border-radius:50%; border:1px solid rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.6); transition:var(--ease); }
.topbar-right a:hover { background:var(--green-bright); border-color:var(--green-bright); color:#fff; }
.topbar-right svg { width:13px; height:13px; }

/* ===== HEADER (transparent over hero, solid on inner pages) ===== */
.header { position:absolute; top:44px; left:0; right:0; z-index:900; transition:var(--ease); }
.header.solid { position:sticky; top:0; background:#fff; box-shadow:0 2px 20px rgba(0,0,0,.1); }
.header.scrolled { position:fixed; top:0; background:#fff; box-shadow:0 2px 20px rgba(0,0,0,.1); }
.nav { display:flex; align-items:center; justify-content:space-between; padding:18px 0; gap:20px; }

/* Logo */
.logo-wrap { display:flex; align-items:center; gap:12px; }
.logo-img  { height:64px; width:auto; transition:var(--ease); }
.header.scrolled .logo-img, .header.solid .logo-img { filter:none; mix-blend-mode:normal; }
.logo-text { display:flex; flex-direction:column; line-height:1; }
.logo-name { font-family:var(--font-head); font-size:1.1rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:#fff; transition:var(--ease); }
.logo-sub-txt { font-size:.58rem; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,.6); margin-top:3px; transition:var(--ease); }
.header.scrolled .logo-name, .header.solid .logo-name { color:var(--green-dark); }
.header.scrolled .logo-sub-txt, .header.solid .logo-sub-txt { color:#999; }

/* Nav links */
.nav-links { display:flex; align-items:center; gap:26px; }
.nav-links a { font-family:var(--font-head); font-size:.82rem; font-weight:500; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.88); position:relative; transition:var(--ease); }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--green-bright); transition:var(--ease); }
.nav-links a:hover, .nav-links a.active { color:#fff; }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.header.scrolled .nav-links a, .header.solid .nav-links a { color:#333; }
.header.scrolled .nav-links a:hover, .header.solid .nav-links a:hover { color:var(--green-dark); }
.header.scrolled .nav-links a.active, .header.solid .nav-links a.active { color:var(--green-dark); }

/* Nav right */
.nav-right { display:flex; align-items:center; gap:14px; }
.nav-phone { font-family:var(--font-head); font-size:.9rem; font-weight:600; color:rgba(255,255,255,.88); display:flex; align-items:center; gap:6px; transition:var(--ease); }
.nav-phone svg { width:16px; height:16px; }
.header.scrolled .nav-phone, .header.solid .nav-phone { color:var(--green-dark); }
.btn-nav { background:rgba(255,255,255,.15); color:#fff; border:1px solid rgba(255,255,255,.4); backdrop-filter:blur(4px); }
.btn-nav:hover { background:#fff; color:var(--dark); }
.header.scrolled .btn-nav, .header.solid .btn-nav { background:var(--red); color:#fff; border-color:var(--red); }
.header.scrolled .btn-nav:hover, .header.solid .btn-nav:hover { background:var(--red-hover); }

/* Hamburger */
.ham { display:none; flex-direction:column; gap:5px; padding:4px; }
.ham span { display:block; width:23px; height:2px; background:#fff; transition:var(--ease); border-radius:2px; }
.header.scrolled .ham span, .header.solid .ham span { background:var(--dark); }

/* Mobile menu */
.mob { display:none; position:fixed; inset:0; background:rgba(0,0,0,.96); z-index:9999; flex-direction:column; align-items:center; justify-content:center; gap:26px; }
.mob.open { display:flex; }
.mob-close { position:absolute; top:22px; right:24px; color:#fff; font-size:2rem; line-height:1; }
.mob a { font-family:var(--font-head); font-size:1.5rem; font-weight:600; text-transform:uppercase; color:#fff; letter-spacing:2px; transition:var(--ease); }
.mob a:hover { color:var(--green-light); }

/* ===== TICKER ===== */
.ticker { background:var(--green-dark); padding:11px 0; overflow:hidden; white-space:nowrap; }
.tick-track { display:inline-flex; animation:tick 35s linear infinite; }
.tick-item { display:inline-flex; align-items:center; gap:10px; padding:0 30px; font-family:var(--font-head); font-size:.76rem; font-weight:500; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.88); }
.tick-dot { width:5px; height:5px; background:var(--green-light); border-radius:50%; flex-shrink:0; }
@keyframes tick { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ===== SECTION HEADER ===== */
.sec-head { text-align:center; margin-bottom:56px; }
.sec-head .sub { margin:14px auto 0; }

/* ===== SERVICES GRID ===== */
.services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }

/* Photo-based service cards */
.scard {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  min-height: 320px;
  background: var(--dark-card);
  box-shadow: 0 6px 28px rgba(0,0,0,.18);
  transition: transform .4s cubic-bezier(.25,.8,.25,1), box-shadow .4s ease;
}
.scard:hover { transform: translateY(-7px); box-shadow: 0 18px 50px rgba(0,0,0,.28); }
.scard-photo {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform .6s ease;
}
.scard:hover .scard-photo { transform: scale(1.07); }
.scard-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.3) 55%, rgba(0,0,0,.05) 100%);
  transition: var(--ease);
}
.scard:hover .scard-overlay {
  background: linear-gradient(to top, rgba(27,94,32,.92) 0%, rgba(0,0,0,.45) 65%, rgba(0,0,0,.08) 100%);
}
.scard-body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 26px 24px;
}
.scard-tag {
  display: inline-block;
  background: var(--green-bright);
  color: #fff;
  font-family: var(--font-head);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 2px;
  margin-bottom: 10px;
}
.scard-name { font-family:var(--font-head); font-size:1.1rem; font-weight:700; text-transform:uppercase; color:#fff; margin-bottom:8px; letter-spacing:.3px; }
.scard-desc { font-size:.83rem; color:rgba(255,255,255,.72); line-height:1.65; margin-bottom:14px; }
.scard-link { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-head); font-size:.75rem; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--green-light); transition:var(--ease); }
.scard-link:hover { gap:10px; color:#fff; }

/* Legacy icon card (fallback) */
.scard-icon { width:56px; height:56px; background:linear-gradient(135deg,var(--green-mid),var(--green-bright)); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; font-size:1.5rem; }

/* ===== BEFORE/AFTER SLIDER ===== */
.ba-slider {
  position: relative;
  height: 460px;
  border-radius: 8px;
  overflow: hidden;
  cursor: ew-resize;
  user-select: none;
  box-shadow: var(--shadow-xl);
}
.ba-after, .ba-before {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}
.ba-before { clip-path: inset(0 50% 0 0); }
.ba-handle {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  z-index: 4;
}
.ba-line { position: absolute; inset: 0; background: #fff; width: 4px; box-shadow: 0 0 12px rgba(0,0,0,.5); }
.ba-circle {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  left: 50%; transform: translate(-50%, -50%);
  width: 52px; height: 52px;
  background: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--green-dark);
  font-size: .9rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
  cursor: ew-resize;
  transition: transform .2s ease;
}
.ba-circle:hover { transform: translate(-50%, -50%) scale(1.1); }
.ba-label {
  position: absolute;
  top: 18px;
  padding: 5px 13px;
  background: rgba(0,0,0,.65);
  color: #fff;
  font-family: var(--font-head);
  font-size: .7rem;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  border-radius: 2px;
  z-index: 5;
  backdrop-filter: blur(4px);
}
.ba-label-before { left: 18px; }
.ba-label-after  { right: 18px; }
.ba-badge {
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--green-dark);
  color: #fff;
  padding: 14px 20px;
  border-radius: 6px;
  text-align: center;
  font-family: var(--font-head);
  z-index: 5;
  box-shadow: 0 6px 24px rgba(0,0,0,.4);
  white-space: nowrap;
}
.ba-badge .big { font-size: 1.7rem; font-weight: 700; line-height: 1; }
.ba-badge .sm  { font-size: .6rem; letter-spacing: 2px; text-transform: uppercase; opacity: .82; margin-top: 3px; }

/* ===== NAV DROPDOWN ===== */
.nav-links li { position: relative; }
.nav-links .has-drop > a::after { content: ' ▾'; font-size: .65rem; opacity: .7; }

/* Transparent bridge fills the gap so hover doesn't break mid-travel */
.nav-links .has-drop::before {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 18px;
  z-index: 1000;
}

.nav-drop {
  /* Use visibility/opacity so hover zone stays active while dropdown is open */
  display: block;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: calc(100% + 14px);
  left: 0;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 12px 40px rgba(0,0,0,.16);
  min-width: 240px;
  padding: 8px 0;
  z-index: 999;
  border-top: 3px solid var(--green-bright);
  transition: opacity .16s ease, visibility 0s .18s;
}
.nav-links .has-drop:hover .nav-drop {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transition: opacity .16s ease, visibility 0s;
}
.nav-drop li a {
  display: block;
  padding: 10px 18px;
  font-family: var(--font-head);
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .8px;
  text-transform: uppercase;
  color: #333 !important;
  transition: var(--ease);
}
.nav-drop li a:hover { background: var(--off-white); color: var(--green-dark) !important; padding-left: 24px; }
.nav-drop li a::after { display: none !important; }

/* Icon replacement helpers */
.why-ico svg { width: 2.2rem; height: 2.2rem; display: block; color: var(--green-bright); stroke: var(--green-bright); }
.diff-ico svg { width: 2.2rem; height: 2.2rem; display: block; color: var(--green-bright); stroke: var(--green-bright); }
.benefit-ico svg { width: 2rem; height: 2rem; display: block; color: var(--green-bright); stroke: var(--green-bright); }
.type-icon svg { width: 1.5rem; height: 1.5rem; display: block; flex-shrink: 0; }
.fci-ico svg { width: 14px; height: 14px; vertical-align: -2px; flex-shrink: 0; }
.float-btn svg { vertical-align: -3px; margin-right: 6px; }

/* ===== STATS ===== */
.stats {
  position: relative;
  padding: 68px 0;
  background: #111210;
  overflow: hidden;
}
/* Concrete form-board texture — horizontal joint lines */
.stats::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent 0px, transparent 27px,
      rgba(255,255,255,.07) 27px, rgba(255,255,255,.07) 28px,
      transparent 28px, transparent 56px,
      rgba(255,255,255,.04) 56px, rgba(255,255,255,.04) 57px
    ),
    repeating-linear-gradient(
      90deg,
      transparent 0px, transparent 54px,
      rgba(255,255,255,.05) 54px, rgba(255,255,255,.05) 55px,
      transparent 55px, transparent 108px,
      rgba(255,255,255,.035) 108px, rgba(255,255,255,.035) 109px
    );
  pointer-events: none;
}
/* Green radial glow + aggregate grain overlay */
.stats::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 90% 70% at 50% 50%, rgba(67,160,71,.11) 0%, transparent 68%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E") repeat;
  pointer-events: none;
}
.stats-grid { position:relative; z-index:1; display:grid; grid-template-columns:repeat(6,1fr); gap:28px; text-align:center; }
.stat-num { font-family:var(--font-head); font-size:2.6rem; font-weight:700; color:var(--green-light); line-height:1; }
.stat-label { font-size:.72rem; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,.5); margin-top:8px; }
.stat-divider { width:1px; background:rgba(255,255,255,.08); align-self:center; height:50px; display:block; }
@media(max-width:1100px) { .stats-grid { grid-template-columns:repeat(3,1fr); gap:32px; } }
@media(max-width:600px)  { .stats-grid { grid-template-columns:repeat(2,1fr); } }

/* ===== PROCESS ===== */
.proc-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:56px; }
.pstep {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  min-height: 420px;
  cursor: default;
  box-shadow: 0 10px 40px rgba(0,0,0,.4);
  transition: transform .4s cubic-bezier(.25,.8,.25,1), box-shadow .4s ease;
}
.pstep:hover { transform: translateY(-8px); box-shadow: 0 22px 56px rgba(0,0,0,.5); }
.pstep-photo {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform .7s ease;
}
.pstep:hover .pstep-photo { transform: scale(1.08); }
.pstep-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.55) 45%, rgba(0,0,0,.15) 100%);
  transition: background .4s ease;
}
.pstep:hover .pstep-overlay {
  background: linear-gradient(to top, rgba(20,70,20,.94) 0%, rgba(0,0,0,.65) 55%, rgba(0,0,0,.18) 100%);
}
.pstep-body {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 30px 26px;
}
.pstep-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--green-bright); color: #fff;
  font-family: var(--font-head); font-size: .62rem; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 2px; margin-bottom: 10px;
}
.pstep-num {
  font-family: var(--font-head); font-size: 5rem; font-weight: 700;
  color: rgba(129,199,132,.2); line-height: .9;
  position: absolute; top: 20px; right: 22px;
}
.pstep-title {
  font-family: var(--font-head); font-size: 1.12rem; font-weight: 700;
  text-transform: uppercase; color: #fff; letter-spacing: .5px; margin-bottom: 10px;
}
.pstep-desc { font-size: .84rem; color: rgba(255,255,255,.62); line-height: 1.72; }
.pstep-arrow {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 14px;
  font-family: var(--font-head); font-size: .72rem; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--green-light);
}
/* connector arrow between steps */
.proc-connector {
  display: flex; align-items: center; justify-content: center;
  color: var(--green-bright); font-size: 1.8rem; align-self: center;
  opacity: .6; margin-top: -30px;
}
@media(max-width:1100px) { .proc-steps { grid-template-columns: 1fr; } .pstep { min-height: 320px; } }

/* ===== GALLERY GRID ===== */
.gal-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:210px; gap:10px; margin-top:48px; }
.gal-item { position:relative; overflow:hidden; border-radius:5px; cursor:pointer; }
.gal-item:nth-child(1) { grid-column:span 2; grid-row:span 2; }
.gal-item:nth-child(6) { grid-column:span 2; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gal-item:hover img { transform:scale(1.07); }
.gal-ov { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.72) 0%,transparent 55%); opacity:0; transition:var(--ease); display:flex; align-items:flex-end; padding:18px; }
.gal-item:hover .gal-ov { opacity:1; }
.gal-label { font-family:var(--font-head); font-size:.84rem; font-weight:600; text-transform:uppercase; letter-spacing:1px; color:#fff; }

/* ===== REVIEWS ===== */
.rev-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rcard { background:var(--dark-card); border:1px solid rgba(255,255,255,.065); border-radius:6px; padding:26px; transition:var(--ease); }
.rcard:hover { border-color:rgba(67,160,71,.28); transform:translateY(-4px); }
.rcard-head { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.rav { width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--green-mid),var(--green-bright)); display:flex; align-items:center; justify-content:center; font-family:var(--font-head); font-weight:700; color:#fff; font-size:1rem; flex-shrink:0; }
.rname { font-family:var(--font-head); font-weight:600; color:#fff; font-size:.92rem; }
.rdate { font-size:.72rem; color:rgba(255,255,255,.38); margin-top:2px; }
.rstars { color:#FBBC05; font-size:.95rem; letter-spacing:1px; margin-bottom:10px; }
.rtext { font-size:.85rem; color:rgba(255,255,255,.6); line-height:1.72; }
.glogo { font-family:var(--font-head); font-size:1.6rem; font-weight:700; }
.glogo .ga{color:#4285F4} .glogo .go1{color:#EA4335} .glogo .go2{color:#FBBC05} .glogo .ga2{color:#4285F4} .glogo .gl{color:#34A853} .glogo .ge{color:#EA4335}

/* ===== SERVICE AREA MAP ===== */
.service-area {
  background-color: var(--dark);
  padding: 80px 0;
  /* masonry stone texture — same pattern as process section */
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 47px, rgba(255,255,255,.03) 47px, rgba(255,255,255,.03) 48px),
    repeating-linear-gradient(90deg, transparent, transparent 95px, rgba(255,255,255,.022) 95px, rgba(255,255,255,.022) 96px);
}

/* Process / Reviews global rules (active on about.html + other inner pages) */
.process {
  padding: 96px 0;
  background-color: var(--dark-2);
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 47px, rgba(255,255,255,.03) 47px, rgba(255,255,255,.03) 48px),
    repeating-linear-gradient(90deg, transparent, transparent 95px, rgba(255,255,255,.022) 95px, rgba(255,255,255,.022) 96px);
}
.reviews {
  padding: 96px 0;
  background-color: var(--dark);
  background-image:
    radial-gradient(ellipse at 10% 90%, rgba(43,122,47,.09) 0%, transparent 55%),
    radial-gradient(ellipse at 90% 10%, rgba(43,122,47,.07) 0%, transparent 55%),
    repeating-linear-gradient(-45deg, transparent, transparent 23px, rgba(255,255,255,.022) 23px, rgba(255,255,255,.022) 24px),
    repeating-linear-gradient(45deg, transparent, transparent 23px, rgba(255,255,255,.022) 23px, rgba(255,255,255,.022) 24px);
}
.sa-tabs { display:flex; flex-wrap:wrap; gap:0; border-bottom:2px solid rgba(255,255,255,.1); margin-bottom:0; justify-content:center; }
.sa-tab { padding:13px 26px; font-family:var(--font-head); font-size:.78rem; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.45); border:none; background:none; cursor:pointer; border-bottom:3px solid transparent; margin-bottom:-2px; transition:var(--ease); }
.sa-tab:hover { color:rgba(255,255,255,.85); }
.sa-tab.active { color:var(--green-bright); border-bottom-color:var(--green-bright); background:rgba(67,160,71,.07); }
.sa-map-wrap { width:100%; height:440px; border-radius:0 0 8px 8px; overflow:hidden; border:1px solid rgba(255,255,255,.08); border-top:none; }
.sa-map { width:100%; height:100%; border:none; display:block; }
.sa-city-info { display:flex; align-items:center; justify-content:space-between; gap:24px; padding:28px 0 0; flex-wrap:wrap; }
.sa-city-desc h3 { font-family:var(--font-head); font-size:1.35rem; font-weight:700; color:#fff; text-transform:uppercase; margin-bottom:8px; letter-spacing:.5px; }
.sa-city-desc p { color:rgba(255,255,255,.55); font-size:.88rem; max-width:540px; line-height:1.75; }
.sa-city-cta { display:flex; gap:12px; flex-wrap:wrap; }
@media(max-width:700px) { .sa-map-wrap { height:300px; } .sa-city-info { flex-direction:column; align-items:flex-start; } }

/* ===== CTA BANNER (city/service pages — keeps green solid) ===== */
.cta-banner { padding:80px 0; background:var(--green-dark); text-align:center; position:relative; overflow:hidden; }
.cta-banner::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 50%, rgba(0,0,0,.25) 0%, transparent 70%); pointer-events:none; }
.cta-inner { position:relative; z-index:1; }
.cta-title { font-family:var(--font-head); font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:700; text-transform:uppercase; color:#fff; line-height:1.1; margin-bottom:14px; }
.cta-sub { font-size:.92rem; color:rgba(255,255,255,.82); margin-bottom:30px; max-width:480px; margin-left:auto; margin-right:auto; line-height:1.7; }
.cta-btns { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* ===== CTA SPLIT (homepage — photo + text) ===== */
.cta-split { display:grid; grid-template-columns:1fr 1fr; min-height:540px; overflow:hidden; position:relative; }
.cta-split-text {
  background:var(--dark); padding:80px 64px;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; z-index:2;
}
.cta-split-text::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 25% 50%, rgba(67,160,71,.1) 0%, transparent 65%);
  pointer-events:none;
}
.cta-split-tag {
  font-family:var(--font-head); font-size:.68rem; font-weight:600;
  letter-spacing:3px; text-transform:uppercase; color:var(--green-bright);
  margin-bottom:16px; display:flex; align-items:center; gap:10px;
}
.cta-split-tag::before { content:'—'; opacity:.5; }
.cta-split-title {
  font-family:var(--font-head); font-size:clamp(1.9rem,3vw,3rem);
  font-weight:700; text-transform:uppercase; color:#fff;
  line-height:1.06; margin-bottom:18px; position:relative;
}
.cta-split-sub {
  font-size:.9rem; color:rgba(255,255,255,.6); margin-bottom:26px;
  max-width:400px; line-height:1.78;
}
.cta-split-trust { display:flex; flex-direction:column; gap:7px; margin-bottom:34px; }
.cst-item {
  font-size:.82rem; color:rgba(255,255,255,.6);
  display:flex; align-items:center; gap:8px;
}
.cst-item::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--green-bright); flex-shrink:0; }
.cta-split-btns { display:flex; gap:14px; flex-wrap:wrap; }
.cta-split-photos { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; overflow:hidden; }
.cta-sph {
  background-size:cover; background-position:center;
  transition:transform .6s ease; position:relative; overflow:hidden;
}
.cta-sph::after {
  content:''; position:absolute; inset:0;
  background:rgba(0,0,0,.15);
  transition:background .4s ease;
}
.cta-sph:hover::after { background:rgba(0,0,0,.05); }
.cta-sph:hover { transform:scale(1.04); z-index:1; }
@media(max-width:900px) {
  .cta-split { grid-template-columns:1fr; }
  .cta-split-photos { height:280px; grid-template-rows:1fr 1fr; }
  .cta-split-text { padding:60px 32px; }
}

/* ===== PAGE HERO (inner pages) ===== */
.page-hero { position:relative; padding:160px 0 80px; background:var(--dark); overflow:hidden; text-align:center; }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(.3); }
.page-hero-content { position:relative; z-index:2; }
.page-hero-title { font-family:var(--font-head); font-size:clamp(2.5rem,5vw,4rem); font-weight:700; color:#fff; text-transform:uppercase; line-height:1.06; }
.page-hero-title span { color:var(--green-light); }
.page-hero-sub { font-size:1rem; color:rgba(255,255,255,.65); margin-top:14px; max-width:540px; margin-left:auto; margin-right:auto; line-height:1.7; }
.breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-head); font-size:.76rem; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:16px; }
.breadcrumb a { color:rgba(255,255,255,.45); transition:var(--ease); }
.breadcrumb a:hover { color:var(--green-light); }
.breadcrumb span { color:var(--green-light); }

/* ===== FOOTER ===== */
.footer { background:var(--dark); padding:68px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.07); }
.footer-logo-img { height:72px; width:auto; margin-bottom:14px; mix-blend-mode:screen; }
.footer-desc { font-size:.83rem; color:rgba(255,255,255,.46); line-height:1.72; margin-bottom:22px; max-width:270px; }
.footer-soc { display:flex; gap:9px; }
.footer-soc a { width:34px; height:34px; border-radius:5px; background:rgba(255,255,255,.065); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.55); transition:var(--ease); }
.footer-soc a:hover { background:var(--green-bright); color:#fff; }
.footer-soc svg { width:14px; height:14px; }
.fcol-title { font-family:var(--font-head); font-size:.72rem; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:#fff; margin-bottom:18px; }
.fcol-links { display:flex; flex-direction:column; gap:9px; }
.fcol-links a { font-size:.83rem; color:rgba(255,255,255,.46); transition:var(--ease); }
.fcol-links a:hover { color:var(--green-light); padding-left:4px; }
.fcontact { display:flex; flex-direction:column; gap:11px; }
.fci { display:flex; gap:9px; align-items:flex-start; font-size:.83rem; color:rgba(255,255,255,.46); line-height:1.5; }
.fci-ico { color:var(--green-bright); flex-shrink:0; margin-top:2px; }
.footer-bot { padding:18px 0; display:flex; justify-content:space-between; align-items:center; font-size:.74rem; color:rgba(255,255,255,.28); flex-wrap:wrap; gap:10px; }
.footer-bot a { color:rgba(255,255,255,.35); transition:var(--ease); }
.footer-bot a:hover { color:var(--green-light); }

/* ===== FLOAT BTN ===== */
.float-btn { display:none; position:fixed; bottom:18px; left:50%; transform:translateX(-50%); z-index:800; background:var(--red); color:#fff; padding:13px 28px; border-radius:100px; font-family:var(--font-head); font-size:.86rem; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; box-shadow:0 8px 26px rgba(198,40,40,.52); animation:pulse 2.2s ease-in-out infinite; white-space:nowrap; }
@keyframes pulse { 0%,100%{box-shadow:0 8px 26px rgba(198,40,40,.52)} 50%{box-shadow:0 8px 40px rgba(198,40,40,.72)} }

/* ===== FORM STYLES ===== */
.form-section { padding:80px 0; background:var(--off-white); }
.form-wrap { max-width:700px; margin:0 auto; background:#fff; border-radius:8px; padding:48px 44px; box-shadow:var(--shadow); }
.form-title { font-family:var(--font-head); font-size:1.6rem; font-weight:700; text-transform:uppercase; color:var(--dark); margin-bottom:6px; }
.form-sub { font-size:.88rem; color:var(--text-gray); margin-bottom:28px; line-height:1.5; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fg { margin-bottom:15px; }
.fg label { display:block; font-size:.67rem; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:#888; margin-bottom:5px; }
.fg input,.fg select,.fg textarea { width:100%; padding:11px 14px; border:1.5px solid #e0e0e0; border-radius:3px; font-family:var(--font-body); font-size:.9rem; color:#222; background:#f8f8f7; transition:var(--ease); outline:none; appearance:none; }
.fg input:focus,.fg select:focus,.fg textarea:focus { border-color:var(--green-bright); background:#fff; box-shadow:0 0 0 3px rgba(67,160,71,.1); }
.fg textarea { resize:vertical; min-height:100px; }
.fg select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 13px center; padding-right:32px; }
.form-btn { width:100%; padding:15px; background:var(--red); color:#fff; border-radius:3px; font-family:var(--font-head); font-size:1rem; font-weight:600; letter-spacing:2px; text-transform:uppercase; transition:var(--ease); margin-top:6px; }
.form-btn:hover { background:var(--red-hover); transform:translateY(-2px); box-shadow:0 6px 22px rgba(198,40,40,.38); }
.form-btn:disabled { opacity:.65; cursor:not-allowed; transform:none; }
.form-note { font-size:.68rem; color:#aaa; text-align:center; margin-top:10px; line-height:1.5; }
.form-success { display:none; text-align:center; padding:32px 16px; }
.form-success-ico { font-size:3rem; margin-bottom:12px; }
.form-success h3 { font-family:var(--font-head); color:var(--green-dark); font-size:1.3rem; text-transform:uppercase; }
.form-success p { color:var(--text-gray); font-size:.9rem; margin-top:8px; line-height:1.6; }

/* ===== ABOUT SECTION ===== */
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:76px; align-items:center; }
.about-imgs { position:relative; height:520px; }
.about-img-a { position:absolute; top:0; left:0; width:72%; height:82%; object-fit:cover; border-radius:6px; box-shadow:var(--shadow-xl); }
.about-img-b { position:absolute; bottom:0; right:0; width:52%; height:52%; object-fit:cover; border-radius:6px; box-shadow:var(--shadow-xl); border:6px solid #fff; }
.about-badge { position:absolute; bottom:36%; left:56%; transform:translate(-50%,50%); background:var(--green-dark); color:#fff; padding:16px 18px; border-radius:6px; text-align:center; font-family:var(--font-head); z-index:2; box-shadow:0 8px 28px rgba(0,0,0,.3); }
.about-badge .big { font-size:1.9rem; font-weight:700; line-height:1; }
.about-badge .sm { font-size:.64rem; letter-spacing:2.5px; text-transform:uppercase; opacity:.82; margin-top:4px; }
.about-list { margin:24px 0; display:flex; flex-direction:column; gap:11px; }
.alist-item { display:flex; align-items:flex-start; gap:11px; font-size:.9rem; line-height:1.55; }
.alist-ico { width:21px; height:21px; background:var(--green-bright); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:#fff; font-size:.65rem; font-weight:700; margin-top:1px; }

/* ===== RESPONSIVE ===== */
@media(max-width:1100px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:24px; }
  .about-inner { grid-template-columns:1fr; gap:40px; }
  .about-imgs { height:360px; }
  .proc-steps { grid-template-columns:1fr; }
  .pstep::after { display:none; }
  .gal-grid { grid-template-columns:repeat(2,1fr); }
  .gal-item:nth-child(1) { grid-column:span 1; grid-row:span 1; }
  .gal-item:nth-child(6) { grid-column:span 1; }
  .rev-grid { grid-template-columns:repeat(2,1fr); }
  .areas-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .form-row { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  .topbar-left a:not(:first-child) { display:none; }
  .topbar-left span { display:none; }
  .nav-links,.nav-phone { display:none; }
  .ham { display:flex; }
  .services-grid { grid-template-columns:1fr; }
  .rev-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .float-btn { display:flex; }
  .cta-btns { flex-direction:column; align-items:center; }
  .form-wrap { padding:32px 22px; }
  .about-imgs { height:280px; }
  /* Page hero — reduce padding on mobile so title isn't buried */
  .page-hero { padding:110px 0 56px; }
  .page-hero-title { font-size:clamp(1.9rem,8vw,2.8rem); }
  /* Service detail sections */
  .sd-inner, .sd-inner.reverse { grid-template-columns:1fr !important; direction:ltr !important; gap:28px; }
  .sd-img { height:240px; }
  /* Stats tighter on phones */
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:18px; }
  /* SA map shorter on phones */
  .sa-map-wrap { height:260px; }
  /* Section vertical padding reduced */
  .about-section, .diff-section { padding:64px 0; }
  /* Diff-grid override for phones */
  .diff-grid { grid-template-columns:1fr; }
  /* Video/slider height on phones */
  .ba-slider { height:320px; }
  /* CTA banner buttons stack */
  .cta-btns { flex-direction:column; gap:10px; }
  /* Gal grid on phones */
  .gal-grid { grid-template-columns:1fr; }
  /* Areas grid */
  .areas-grid { grid-template-columns:1fr; }
}

/* =====================================================
   CUSTOM CURSOR — Masonry trowel
   Only on desktop / precise pointer devices
   ===================================================== */
@media (pointer: fine) {
  *, *::before, *::after { cursor: none !important; }

  #site-cursor {
    position: fixed;
    top: 0; left: 0;
    width: 28px; height: 28px;
    pointer-events: none;
    z-index: 999999;
    will-change: transform;
    transform: translate(-100px,-100px);
    transition: opacity 0.15s;
  }

  #site-cursor svg {
    display: block;
    transform-origin: 3px 3px;   /* pivot = blade tip = hot-spot */
    transition: transform 0.2s cubic-bezier(.34,1.56,.64,1),
                filter 0.2s ease;
  }

  /* Hover over links / buttons → trowel tilts and glows */
  #site-cursor.is-hovering svg {
    transform: scale(1.28) rotate(-15deg);
    filter: drop-shadow(0 0 5px rgba(198,40,40,.6));
  }

  /* Click → quick tap swing */
  #site-cursor.is-clicking svg {
    animation: trowel-tap 0.26s cubic-bezier(.22,.61,.36,1) forwards;
  }

  @keyframes trowel-tap {
    0%   { transform: scale(1.1)  rotate(-8deg); }
    32%  { transform: scale(0.86) rotate(20deg) translate(2px,2px); }
    66%  { transform: scale(1.18) rotate(-10deg); }
    100% { transform: scale(1.1)  rotate(-8deg); }
  }

  /* Red ring ripple on click */
  .cursor-ripple {
    position: fixed;
    pointer-events: none;
    z-index: 999998;
    border-radius: 50%;
    border: 1.5px solid rgba(198,40,40,.65);
    width: 34px; height: 34px;
    transform: scale(0.12);
    transform-origin: center;
    animation: cursor-ripple-out 0.52s ease-out forwards;
  }

  @keyframes cursor-ripple-out {
    0%   { transform: scale(0.12); opacity: 0.95; }
    100% { transform: scale(1);    opacity: 0;    }
  }
}
