.elementor-923 .elementor-element.elementor-element-e1935a4{--display:flex;}/* Start custom CSS for html, class: .elementor-element-f06117c *//* =========================================================
   LANDSCAPING SERVICES — PAGE CSS
========================================================= */

/* HERO glow */
.jsl-landscaping-hero{
  position:relative;
}
.jsl-landscaping-hero:before{
  content:"";
  position:absolute;
  inset:-40px 0 -40px 0;
  background:
    radial-gradient(900px 420px at 15% 10%, rgba(46,125,50,.10), rgba(255,255,255,0) 60%),
    radial-gradient(760px 420px at 85% 30%, rgba(143,188,143,.16), rgba(255,255,255,0) 62%),
    radial-gradient(900px 520px at 45% 95%, rgba(34,139,34,.08), rgba(255,255,255,0) 60%);
  pointer-events:none;
  z-index:0;
}
.jsl-landscaping-hero .jsl-container,
.jsl-landscaping-hero .jsl-hero-wrap{
  position:relative;
  z-index:1;
}

/* Hero collage (3 stacked) */
.jsl-landscaping-hero .jsl-hero-media{
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}
.jsl-landscaping-hero .jsl-hero-collage{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:0;
}
.jsl-landscaping-hero .jsl-hero-collage figure{
  margin:0;
  border-radius:16px;
  overflow:hidden;
  position:relative;
  background:#ddd;
  box-shadow:0 10px 22px rgba(0,0,0,.10);
  border:1px solid rgba(0,0,0,.06);
}
.jsl-landscaping-hero .jsl-hero-collage img{
  width:100%;
  aspect-ratio: 16 / 9;
  height:auto;
  object-fit:cover;
  display:block;
  transform:scale(1.01);
  filter:saturate(1.06) contrast(1.02);
}
.jsl-landscaping-hero .jsl-hero-collage figure:after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(46,125,50,.06));
  pointer-events:none;
}

/* =========================================================
   SERVICES GRID
========================================================= */

.jsl-landscaping-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:18px;
  margin-top:22px;
  align-items:stretch;
}
@media (max-width: 1100px){
  .jsl-landscaping-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px){
  .jsl-landscaping-grid{ grid-template-columns: 1fr; }
}

/* =========================================================
   CARD
========================================================= */

.jsl-land-card{
  background:#fff;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  text-decoration:none !important;
  color:#1a1a1a !important;
  display:flex;
  flex-direction:column;
  height:100%;
  transition: transform .3s ease, box-shadow .3s ease;
}
.jsl-land-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(0,0,0,.12);
}

/* =========================================================
   IMAGE LOCK (ALL IMAGES SAME SIZE)
========================================================= */

.jsl-land-image{
  width:100%;
  height:240px;              /* 🔒 hard locked height */
  aspect-ratio: 16 / 9;      /* 🔒 reserves consistent ratio */
  overflow:hidden;
  background:#ddd;
  flex:0 0 auto;
  position:relative;
}

/* Force image to completely fill container */
.jsl-land-image img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block;
  transition: transform .6s ease;
}

/* Hover zoom */
.jsl-land-card:hover .jsl-land-image img{
  transform:scale(1.05);
}

/* Mobile image sizing */
@media (max-width: 700px){
  .jsl-land-image{
    height:220px;  /* consistent mobile height */
    aspect-ratio:16/9;
  }
}

/* =========================================================
   CONTENT
========================================================= */

.jsl-land-content{
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1 1 auto;
}
.jsl-land-content .jsl-small{
  opacity:.75;
  margin-top:auto;
}

/* Keep headings green like your pages */
.jsl-site h1,
.jsl-site h2,
.jsl-site h3{
  color:#1b5e20 !important;
}

/* =========================================================
   BUTTONS — UPDATED TO MATCH DESIGN
========================================================= */

.jsl-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 24px;
  border-radius:999px;
  font-weight:700;
  text-decoration:none !important;
  line-height:1;
  transition: all .25s ease;
  white-space:nowrap;
}

/* Request a quote */
.jsl-btn-primary{
  background:#2E7D32 !important;
  border:2px solid #2E7D32 !important;
  color:#ffffff !important;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
}
.jsl-btn-primary:hover{
  background:#256628 !important;
  border-color:#256628 !important;
  transform:translateY(-2px);
  box-shadow:0 14px 26px rgba(0,0,0,.18);
}

/* WhatsApp */
.jsl-btn-whatsapp{
  background:#25D366 !important;
  border:2px solid #25D366 !important;
  color:#ffffff !important;
  box-shadow:0 8px 18px rgba(37,211,102,.30);
}
.jsl-btn-whatsapp:hover{
  background:#1EBE5D !important;
  border-color:#1EBE5D !important;
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(37,211,102,.35);
}/* End custom CSS */