.elementor-195 .elementor-element.elementor-element-af87d9d{--display:flex;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}/* Start custom CSS for html, class: .elementor-element-3ed2b4c *//* =========================================
   HEADER — FINAL (LOCK BACKGROUND + SCROLLABLE DRAWER LINKS)
   - X ABOVE logo (separate container)
   - Drawer header sticky, links scroll
   - No horizontal overflow
========================================= */

/* ✅ Stop any horizontal overflow site-wide */
html, body{
  overflow-x:hidden;
  width:100%;
  max-width:100%;
}

.jsl-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
  overflow-x:clip;
}

.jsl-header .jsl-container{
  max-width:1180px;
  margin:0 auto;
  padding:0 18px;
}

/* =========================
   DESKTOP LAYOUT
========================= */

.jsl-header .jsl-header-inner{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  column-gap:14px;
  padding:12px 0;
}

/* Logo */
.jsl-header .jsl-brand{ display:flex; align-items:center; }
.jsl-header .jsl-brand-link{ display:flex; align-items:center; line-height:0; }
.jsl-header .jsl-logo{
  height:150px !important;
  max-height:150px !important;
  width:auto;
  object-fit:contain;
}

/* =========================
   DESKTOP NAV
========================= */

.jsl-header nav.jsl-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  justify-self:center;
  gap:18px;
}

.jsl-drawer-top{ display:none; }

.jsl-drawer-links{
  display:flex;
  align-items:center;
  gap:18px;
  justify-content:center;
}

.jsl-header nav.jsl-nav > .jsl-drawer-links > a{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  padding:10px 12px;
  font-weight:600;
  font-size:.95rem;
  text-decoration:none;
  color:#1a1a1a;
  white-space:nowrap;
  transition:color .2s ease, transform .2s ease;
}

.jsl-header nav.jsl-nav > .jsl-drawer-links > a:hover{
  color:#2E7D32;
  transform:translateY(-1px);
}

/* Dropdown parent */
.jsl-header .jsl-nav-dropdown{
  position:relative;
  display:inline-flex;
  align-items:center;
}

.jsl-header .jsl-nav-link.jsl-nav-parent{
  background:none !important;
  border:none !important;
  min-height:44px;
  padding:10px 12px;
  font:inherit;
  font-weight:600;
  font-size:.95rem;
  color:#1a1a1a;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}

.jsl-header .jsl-submenu{ display:none; }

/* Desktop dropdown */
@media (min-width:981px){
  .jsl-header .jsl-nav-dropdown .jsl-submenu{
    position:absolute;
    top:calc(100% + 4px);
    left:0;
    min-width:260px;
    background:#fff;
    border:1px solid rgba(0,0,0,.08);
    border-radius:14px;
    box-shadow:0 18px 40px rgba(0,0,0,.12);
    padding:10px;
    z-index:1002;
  }

  .jsl-header .jsl-nav-dropdown:hover > .jsl-submenu,
  .jsl-header .jsl-nav-dropdown:focus-within > .jsl-submenu{
    display:block;
  }

  .jsl-header .jsl-submenu a{
    display:block;
    padding:12px;
    border-radius:12px;
    text-decoration:none;
    font-weight:700;
    color:#1a1a1a;
  }

  .jsl-header .jsl-submenu a:hover{
    background:#2E7D32;
    color:#fff;
  }
}

/* =========================
   CTA
========================= */

.jsl-header .jsl-header-cta{
  display:flex;
  align-items:center;
  gap:10px;
  justify-self:end;
}

.jsl-header .jsl-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:12px;
  font-weight:800;
  font-size:.92rem;
  text-decoration:none;
  min-height:44px;
  transition:all .25s ease;
  border:1px solid transparent;
}

.jsl-header .jsl-btn-whatsapp{
  background:#25D366;
  border-color:#25D366;
  color:#fff;
}

.jsl-header .jsl-btn-primary{
  background:linear-gradient(180deg,#2e7d32,#1b5e20);
  border-color:rgba(27,94,32,.35);
  color:#fff;
}

/* =========================
   HAMBURGER
========================= */

.jsl-header .jsl-nav-toggle{
  display:none;
  width:46px;
  height:46px;
  border-radius:16px;
  border:1px solid rgba(46,125,50,.18);
  background:#fff;
  cursor:pointer;
  justify-self:end;
}

.jsl-header .jsl-nav-toggle span{
  display:block;
  width:22px;
  height:2px;
  background:#2e7d32;
  margin:4px auto;
  border-radius:2px;
}

/* =========================
   BACKDROP
========================= */

.jsl-nav-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .25s ease, visibility .25s ease;
  z-index:1001;
}

.jsl-nav-backdrop.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

/* ✅ Lock background scroll (do NOT disable touch actions) */
html.jsl-nav-open,
body.jsl-nav-open{
  overflow:hidden !important;
  height:100% !important;
}

/* =========================
   MOBILE DRAWER
========================= */

@media (max-width:980px){

  /* ✅ TOP BAR LAYOUT: CTA (left) | LOGO (centre) | MENU (right) */
  .jsl-header .jsl-header-inner{
    grid-template-columns:auto 1fr auto; /* left | centre | right */
    align-items:center;
  }

  /* Put buttons on the LEFT */
  .jsl-header .jsl-header-cta{
    grid-column:1;
    justify-self:start;
    order:1;
  }

  /* Put logo in the CENTRE */
  .jsl-header .jsl-brand{
    grid-column:2;
    justify-self:center;
    order:2;
  }

  /* Put hamburger on the RIGHT */
  .jsl-header .jsl-nav-toggle{
    grid-column:3;
    justify-self:end;
    order:3;
    display:block;
  }

  /* Your existing mobile drawer rules (unchanged) */
  .jsl-header .jsl-nav-toggle{ display:block; }

  /* Drawer panel */
  .jsl-header nav.jsl-nav{
    position:fixed;
    top:0;
    right:0;
    left:auto;

    width:min(75vw, 100vw);
    max-width:min(420px, 100vw);
    height:100vh;

    background:rgba(255,255,255,.99);
    z-index:1002;

    display:flex;
    flex-direction:column;

    overflow:hidden;
    -webkit-overflow-scrolling:touch;

    box-sizing:border-box;
    padding:16px;

    transform:translate3d(100%,0,0);
    transition:transform .28s ease, opacity .2s ease;

    opacity:0;
    visibility:hidden;
    pointer-events:none;
  }

  .jsl-header nav.jsl-nav.is-open{
    transform:translate3d(0,0,0);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }

  /* Drawer header */
  .jsl-drawer-top{
    display:flex;
    flex-direction:column;
    gap:6px; /* 👈 reduced gap */

    position:sticky;
    top:0;
    z-index:10;

    background:rgba(255,255,255,.99);

    margin:-16px -16px 4px -16px; /* 👈 reduced bottom margin */
    padding:12px 16px 6px 16px;   /* 👈 reduced bottom padding */

    border-bottom:1px solid rgba(0,0,0,.08);

    width:calc(100% + 32px);
    box-sizing:border-box;
  }

  .jsl-drawer-actions{
    display:flex;
    justify-content:flex-end;
    width:100%;
  }

  .jsl-nav-close{
    width:44px;
    height:44px;
    border-radius:14px;
    border:1px solid rgba(46,125,50,.18);
    background:#fff;
    box-shadow:0 10px 22px rgba(0,0,0,.06);
    cursor:pointer;
    font-size:18px;
    font-weight:900;
    color:#2e7d32;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    line-height:1;
  }

  .jsl-drawer-logo{
    height:90px;
    max-height:none;
    width:auto;
    display:block;
    align-self:flex-start;
  }

  /* Scroll area */
  .jsl-drawer-links{
    display:flex !important;
    flex-direction:column !important;
    gap:8px !important;          /* 👈 slightly tighter link spacing */
    padding-top:4px !important;  /* 👈 reduced space under logo */
    width:100%;

    flex:1 1 auto;
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    touch-action:pan-y;
  }

  .jsl-header .jsl-nav-dropdown{
    width:100% !important;
    display:block !important;
  }

  .jsl-header .jsl-nav-link.jsl-nav-parent,
  .jsl-header nav.jsl-nav > .jsl-drawer-links > a{
    width:100% !important;
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
    padding:12px !important;
    border-radius:12px !important;
    background:rgba(46,125,50,.06) !important;
    font-weight:800 !important;
  }

  .jsl-header .jsl-submenu{
    position:static !important;
    width:100% !important;
    margin:6px 0 0 0 !important; /* 👈 slightly tighter */
    padding:0 !important;

    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;

    display:none !important;
    flex-direction:column !important;
    gap:6px !important; /* 👈 tighter submenu gap */
  }

  .jsl-header .jsl-nav-dropdown.is-open > .jsl-submenu{
    display:flex !important;
  }

  .jsl-header .jsl-submenu a{
    width:100% !important;
    display:block !important;
    padding:12px !important;
    border-radius:12px !important;
    text-decoration:none !important;
    font-weight:800 !important;
    color:#1a1a1a !important;
    background:#fff !important;
    border:1px solid rgba(0,0,0,.08) !important;
  }
}

/* =========================================
   SMALL MOBILE CTA FIX
========================================= */

@media (max-width:520px){

  .jsl-header .jsl-header-cta .jsl-btn{
    width:42px;
    height:42px;
    min-height:42px;
    padding:0;
    border-radius:12px;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  /* Hide text but keep icon */
  .jsl-btn-text{
    display:none !important;
  }

  .jsl-header .jsl-btn-icon svg{
    width:20px;
    height:20px;
  }

  /* ✅ logo stays centred and sized nicely */
  .jsl-header .jsl-logo{
    height:100px !important;
    max-height:100px !important;
  }
}/* End custom CSS */