/* ------------------------
    Color Variable
------------------------*/
:root {
  --primary: #00A344;
  --primary-hover: #04451C;
  --white: #ffffff;
  --text-dark: #000000;
  --title-color: #04451C;
  --bg-light: #E1F4E0;
}
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap');
body { font-family: 'Outfit', sans-serif; font-style: normal; font-size: 17px; font-weight: 400; line-height: 28px; color: var(--text-dark); overflow-x: hidden; padding: 0; margin: 0; }

/* ------------------------
    Typography
------------------------*/
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 { font-weight: normal; margin-top: 0px; margin-bottom: 0px; font-weight: 800; color: var(--title-color) }
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a { color: inherit; }
h1, .h1 { font-size: 72px; font-style: normal; line-height: 80px; }
h2, .h2 { font-size: 60px; font-style: normal; line-height: 68px; margin-bottom: 10px; }
h3, .h3 { font-size: 44px; font-style: normal; line-height: 52px; }
h4, .h4 { font-size: 30px; font-style: normal; margin-bottom: 10px; line-height: 38px; }
h5, .h5 { font-size: 24px; font-style: normal; margin-bottom: 10px; line-height: 32px; }
h6, .h6 { font-size: 1rem; font-style: normal; line-height: 1.5rem; margin-bottom: 10px; }
ul { margin: 0px; padding: 0px; }
.lead { font-size: 20px; line-height: 28px; font-weight: 500; }
.text-dark { color: var(--text-dark) !important; }
.text-primary { color: var(--primary) !important; }
.z-index-1 { z-index: 9; position: relative; }
.z-index-2 { z-index: 99; position: relative; }
section { padding: 5rem 0 }

/* ------------------------
Transition
------------------------*/
a, i, .btn, button, img, span { -webkit-transition: all 0.5s ease-in-out 0s; -moz-transition: all 0.5s ease-in-out 0s; -ms-transition: all 0.5s ease-in-out 0s; -o-transition: all 0.5s ease-in-out 0s; transition: all 0.5s ease-in-out 0s; }
a, a:hover { text-decoration: none; color: var(--primary) }

/* ------------------------
Pre Loader
------------------------*/
#preloader { background: var(--white); bottom: 0; height: 100%; left: 0; overflow: hidden !important; position: fixed; right: 0; text-align: center; top: 0; width: 100%; z-index: 99999; }
.clear-loader { transform: translateX(-50%) translateY(-50%); -webkit-transform: translateX(-50%) translateY(-50%); -o-transform: translateX(-50%) translateY(-50%); -ms-transform: translateX(-50%) translateY(-50%); -moz-transform: translateX(-50%) translateY(-50%); z-index: 999; box-sizing: border-box; display: inline-block; left: 50%; position: absolute; text-align: center; top: 50%; }
.loader { position: absolute; top: 50%; left: 50%; margin: auto; text-align: center; transform: translateX(-50%) translateY(-50%); -webkit-transform: translateX(-50%) translateY(-50%); -o-transform: translateX(-50%) translateY(-50%); -ms-transform: translateX(-50%) translateY(-50%); -moz-transform: translateX(-50%) translateY(-50%); }
.loader img { animation: beat 0.9s infinite; }
@keyframes beat {
  0% { transform: scale(1); }
  20% { transform: scale(1.02); }
  40% { transform: scale(1.04); }
}

/* ------------------------
Button
------------------------*/
.btn { padding: 20px 25px; border-radius: 12px; font-weight: 700; font-size: 20px; line-height: 28px; }
.btn-primary { color: var(--white); background-color: var(--primary); border-color: var(--primary); }
.btn-primary:hover, .btn:focus, .btn.show:focus, .btn-outline-primary:not(:disabled):not(.disabled).active, .btn-outline-primary:not(:disabled):not(.disabled):active, .show > .btn-outline-primary.dropdown-toggle { color: var(--white); background-color: var(--primary-hover); border-color: var(--primary-hover); }
.btn.focus, .btn:focus, .btn.show:focus, .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .btn-outline-primary:not(:disabled):not(.disabled):active:focus, .show > .btn-outline-primary.dropdown-toggle:focus { box-shadow: none; }
button:focus { outline: none; }
.btn-white { color: var(--primary); background-color: var(--white); border-color: var(--white); }
.btn-white:hover { color: var(--white); background-color: var(--primary-hover); border-color: var(--primary-hover); }
.btn i { font-size: 14px; margin-left: 15px; line-height: 24px; width: 24px; height: 24px; display: inline-block; background: var(--white); color: var(--primary); border-radius: 50%; }
.btn.btn-white i { font-size: 14px; line-height: 24px; width: 24px; height: 24px; display: inline-block; background: var(--primary); color: var(--white); border-radius: 50%; }

/* ------------------------
Background 
------------------------*/
.bg-primary { background-color: var(--primary) !important; }
.bg-light { background-color: var(--bg-light) !important; }

/* ------------------------
  Header
------------------------*/
#site-header {padding: 10px 0; position: absolute; top: 0; z-index: 999; width: 100%; left: 0; }
#site-header.sticked { padding: 5px 0; position: fixed !important; top: 0; left: 0; width: 100%; background: var(--bg-light) !important; animation: smoothScroll 1s forwards; }

@keyframes smoothScroll {
  0% {
    transform: translateY(-40px);
  }

  100% {
    transform: translateY(0px);
  }

}

/*--navigation--*/
.navbar { padding: 0; }
.navbar-brand { margin-right: 0; }
.navbar-nav .nav-item { margin: 0 15px }
.navbar-nav .nav-link { font-weight: 400; font-size: 18px !important; color: var(--text-dark); padding: 0 !important; border-radius: 0; text-transform: capitalize; position: relative; }
.navbar-nav .nav-link:hover, .navbar-nav .nav-link.active, .navbar-nav .show > .nav-link { color: var(--text-dark); }
@media (max-width:991.98px) {
  /*Header*/
  .navbar-toggler { background: #ffffff; height: 40px; width: 40px; padding: 0; border-radius: 0; margin-right: 0; font-size: 32px;}
  .navbar-nav .nav-item { margin: 0; }
  .navbar-nav .nav-link { padding: 5px 0 !important; border-radius: 0; }
  .navbar-collapse { border-radius: .25rem; background: var(--white); max-height: 400px; left: 0; padding: 10px; position: absolute; z-index: 99; top: 100%; width: 100%; overflow: auto; border: medium none; -webkit-box-shadow: 0 10px 55px 5px rgba(137, 173, 255, .15); -moz-box-shadow: 0 10px 55px 5px rgba(137, 173, 255, .15); box-shadow: 0 10px 55px 5px rgba(137, 173, 255, .15); }
  .navbar-toggler:focus { box-shadow: 0 0 0 var(--primary); }
}

/* ------------------------
Scroll to Top
------------------------*/
.scroll-top { position: fixed; visibility: hidden; opacity: 0; right: 15px; bottom: 15px; z-index: 995; background: var(--primary); width: 40px; height: 40px; border-radius: 4px; transition: all 0.4s; }
.scroll-top i { font-size: 24px; color: var(--white); line-height: 0; }
.scroll-top.active { visibility: visible; opacity: 1; }

/* ------------------------
Banner
------------------------*/
[data-bg-img]{background-size: cover; background-repeat: no-repeat; background-position: center center;}
.hero-section { background: #DEEAD0;}
.hero-content { padding-top: 14rem; padding-bottom: 12rem; }

/* ------------------------
Featured item
------------------------*/
.featured-item .featured-icon { position: relative; display: inline-block; margin-bottom: 30px; width: 70px; height: 70px }
.featured-item .featured-icon:before { width: 120%; height: 120%; background: rgba(0, 163, 68, 0.1); border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; animation: morphing 10s infinite; content: ""; position: absolute; left: -5%; top: -5%; z-index: -1; }
@keyframes morphing {
  0% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; }
  25% { border-radius: 50% 50% 50% 70% / 50% 80% 70% 60%; }
  50% { border-radius: 70% 50% 50% 70% / 50% 40% 70% 60%; }
  75% { border-radius: 50% 30% 50% 70% / 50% 50% 70% 60%; }
  100% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; }
}
.featured-item:hover .featured-icon img{transform: scale(1.1);}


/* ------------------------
Other
------------------------*/
.who-we-are { background: linear-gradient(180deg, #EDF5EE 0%, #EDF5EE 57.29%, #FFFFFF 100%); }
.social-icons li a { color: var(--white); background: #BAC6B8; height: 30px; width: 30px; line-height: 30px; display: inline-block; font-size: 16px; text-align: center; border-radius: 50%; }
.social-icons li a:hover { background: var(--primary) }
.parallax {position: relative; background-attachment: fixed; background-position: top left;}


.subscribe-btn { background: #014737; color: var(--white); font-weight: normal; border-radius: .375rem !important; }
.subscribe-btn:hover { background: var(--primary); color: var(--white); }
.form-control { background-color: #def7ec; border: 1px solid #def7ec; }
.form-control:focus { color: #212529; background-color: #def7ec; border-color: var(--primary); outline: 0; box-shadow: none; }

#subscribe-popup.show {
  display: flex !important;
  align-items: center;
}
@media (min-width:576px) {
  .modal-dialog { max-width: 700px; }
}

/* ------------------------
    Responsive Css
------------------------*/
@media (max-width:1200px) {
  h1, .h1 { font-size: 50px; line-height: 58px; }
  h2, .h2 { font-size: 45px; line-height: 55px; }
  h3, .h3 { font-size: 40px; line-height: 48px; }
  header .navbar-nav .nav-item { margin: 0 10px; }
}
@media (max-width:992px) {
  .hero-content { padding-bottom: 5rem; }
  .hero-img { min-height: 100vh; }
  .lawn-img { position: relative !important; }
}
  @media (max-width:767px) {
    .greener-img img:nth-child(1), .greener-img img:nth-child(3) { width: 30% }
  }
  @media (max-width:576px) {
    .site-header .btn { padding: 10px; font-size: 14px; line-height: 24px; }
    .site-header .btn i { font-size: 14px; margin-left: 5px; }
    .hero-content { padding-top: 10rem; }
  }