html {
    scroll-behavior: smooth;
}

:root {
    --primary: #00853f;
    --dark: #111111;
    --black: #000;
    --grey: #5e5e5e;
    --white: #fff;
    --orange: #ff5a00;
    --green: #4ca978;
    --dark-green: #004721;
    --red: #d5262b;
    --claret: #851524;
    --ease: all 0.3s ease 0.02s;
    --yellow: #ffc000;
    --light: #f0f0f0;
    --blue: #188bd4;
    --turquoise: #57d5f8;
    --unset: unset !important;
    --text-color: #1a1a1a;
}

html, body {
    height: 100%;
}

@font-face {
    font-family: PoppinsBlack;
    src: url(../fonts/Poppins-Black.ttf);
}

@font-face {
    font-family: PoppinsBold;
    src: url(../fonts/Poppins-Bold.ttf);
}

@font-face {
    font-family: PoppinsLight;
    src: url(../fonts/Poppins-Light.ttf);
}

@font-face {
    font-family: PoppinsMedium;
    src: url(../fonts/Poppins-Medium.ttf);
}

@font-face {
    font-family: Poppins;
    src: url(../fonts/Poppins-Regular.ttf);
}

body {
    margin: 0px;
    font-size: 14px;
    color: var(--black);
    font-family: 'Poppins', sans-serif;
}

.container {
    max-width: 1390px;
}

h1 {
    font-weight: 700;
}

h2, h3, h4, h5, h6 {
    font-weight: 500 !important;
}

h2 a, h3 a, h4 a, h5 a, h6 a {
    font-weight: 500 !important;
}

button, a {
    text-decoration: none !important;
    transition: all 0.3s ease 0.02s;
    -webkit-transition: all 0.3s ease 0.02s;
    color: var(--black);
}

a:hover {
    color: var(--primary);
}

strong {
    font-weight: 400;
    font-family: 'PoppinsBold', sans-serif;
}

header {
    height: 96px;
    box-shadow: 0px 1px 10px 0px rgba(0, 0, 0, 0.17);
    background-color: var(--white);
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 100;
}

header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
}

header .navbar-toggler {
    color: #fff;
    border-radius: 5px;
    background-color: var(--primary);
    padding: 6px 8px;
    font-size: 20px;
    display: none;
    align-items: center;
    margin-right: 71px;
}

header .main-menu {
    font-size: 16px;
}

header .main-menu.navbar-expand-md .navbar-nav .nav-link {
    padding: 14px 25px 14px 25px;
}

.social-media {
    padding-left: 50px;
    margin-bottom: 0;
}

.social-media {
    padding-left: 30px;
    display: flex;
    list-style: none;
}

.social-media li {
    padding-left: 50px;
    display: flex;
    list-style: none;
    padding-left: 20px;
}

.social-media li a {
    font-size: 24px;
    color: var(--black);
}

.social-media li a:hover {
    color: var(--primary);
}

.slider .slider-item {
    width: 100%;
    height: 100%;
    max-height: 866px;
    display: inline-flex;
    text-align: center;
    justify-content: center;
    overflow: hidden;
}

.slider .slider-item a {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.slider .slider-item a img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    box-sizing: content-box;
}

.custom-section {
    padding: 120px 0 120px 0;
}

.custom-section .section-title {
    font-size: 37px;
    color: var(--primary);
    margin: 0 0 19px 0;
    text-align: center;
}

.custom-section .container>p {
    margin: 0;
    padding: 0;
    font-family: 'PoppinsLight', sans-serif;
    font-size: 21.5px;
    text-align: center;
}

.highlights {
    padding: 70px 0 140px 0;
}

.highlights .products {
    margin: 70px 0 0 0;
}

.products {
    display: flex;
    flex-wrap: wrap;
}

.products .product {
    flex: 0 0 100%;
    max-width: calc(25% - 40px * 3 / 4);
    margin: 0 40px 40px 0;
    border-radius: 10px;
    overflow: hidden;
    background-color: var(--white);
    box-shadow: 0px 40px 84px 0px rgba(0, 0, 0, 0.0);
    transition: var(--ease);
    -webkit-transition: var(--ease);
    padding: 20px 20px 24px 20px;
    text-align: center;
}

.products .product:hover {
    box-shadow: 0px 40px 84px 0px rgba(0, 0, 0, 0.6);
}

.products .product:nth-child(4n+4) {
    margin-right: 0;
}

.products .product .img {
    height: 280px;
    width: 100%;
}

.products .product .img a {
    overflow: hidden;
    height: 100%;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.products .product .img a img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    box-sizing: content-box;
    width: auto;
}

.reviews-summary {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 0;
}

.reviews-summary .stars {
    display: flex;
    justify-content: center;
    align-items: center;
    list-style: none;
    padding: 0;
    margin: 0;
}

.reviews-summary .stars li {
    padding: 0 3px;
    color: var(--yellow);
}

.reviews-summary a {
    font-size: 12px;
    color: var(--grey);
    padding-left: 5px;
}

.reviews-summary a:hover {
    color: var(--primary);
}

.products .product .item-title {
    margin-bottom: 18px;
    height: 54px;
}

.products .product .item-title a {
    color: var(--black);
    font-size: 18px;
}

.products .product .item-title a:hover {
    color: var(--primary);
}

.prices {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-bottom: 24px;
}

.prices .new-price {
    font-size: 26px;
    font-family: 'PoppinsBold', sans-serif;
    color: var(--black);
}

.prices .old-price {
    font-size: 22px;
    color: var(--black);
    text-decoration: line-through;
    padding-right: 12px;

}

.buttons {
    display: flex;
}

.buttons .green-btn {
    border-width: 2px;
    background-color: rgba(0, 133, 63, 0.702);
    color: var(--white);
}

.buttons .green-btn:hover {
    background-color: var(--black);
    border-color: var(--black);
}

.buttons .light-btn {
    border-width: 1px;
    background-color: var(--primary);
    color: var(--white);
}

.buttons .light-btn:hover {
    background-color: var(--black);
    border-color: var(--black);
}

.buttons>a {
    flex: 0 0 100%;
    max-width: calc(50% - 14px * 1 / 2);
    margin-right: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border-style: solid;
    border-color: var(--primary);
    height: 42px;
    border-radius: 5px;
    font-size: 19px;
    font-family: 'PoppinsBold', sans-serif;
}

.buttons>a:last-child {
    margin-right: 0px;
}

.home-content {
    background-image: url(../img/home/home-content-bg.png);
    background-size: cover;
    background-position: center;
    padding: 145px 0;
}

.home-content .home-content-container {
    max-width: 100%;
    width: 680px;
}

.home-content .title {
    font-size: 65px;
    color: var(--primary);
    margin-bottom: 36px;
}

.home-content p {
    font-size: 20px;
    margin: 0 0 36px 0;
    font-family: 'PoppinsLight', sans-serif;
}

.home-content a {
    font-size: 20px;
    padding: 4px 8px;
    border-width: 0 0 3px 0;
    border-style: solid;
    border-color: var(--primary);
    font-family: 'PoppinsLight', sans-serif;
    color: var(--primary);
}

.home-content a:hover {
    border-color: var(--black);
    color: var(--black);
}

.instagram-posts .posts {
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
}

.instagram-posts .posts .post {
    max-width: calc(100% / 4 - 20px * 3 / 4);
    margin: 0 20px 20px 0;
    max-height: 324px;
}

.instagram-posts .posts .post:nth-child(4n+4) {
    margin-right: 0;
}

.instagram-posts .posts .post a {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: 100%;
    height: 100%;
}

.instagram-posts .posts .post a img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    box-sizing: content-box;
    width: auto;
}

.home-blog {
    background-image: url(../img/blog/blog-bg.png);
    background-size: cover;
    background-position: center;
    padding: 105px 0;
}

.home-blog .title {
    font-size: 65px;
    color: var(--primary);
    margin-bottom: 36px;
}

.home-blog .container>p {
    font-size: 20px;
    margin: 0 0 36px 0;
    font-family: 'PoppinsLight', sans-serif;
}

.blog-posts {
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
}

.blog-posts .post {
    flex: 0 0 100%;
    max-width: calc(25% - 20px * 3 / 4);
    margin: 0 20px 20px 0;
    border-radius: 10px;
    overflow: hidden;
    background-color: transparent;
    box-shadow: 0px 40px 84px 0px rgba(0, 0, 0, 0.0);
    transition: var(--ease);
    -webkit-transition: var(--ease);
    padding: 20px 20px 24px 20px;
}

.blog-posts .post:hover {
    box-shadow: 0px 40px 84px 0px rgba(0, 0, 0, 0.6);
    background-color: var(--white);
}

.blog-posts .post:nth-child(4n+4) {
    margin-right: 0;
}

.blog-posts .post .img {
    height: 220px;
    width: 100%;
    margin-bottom: 15px;
}

.blog-posts .post .img a {
    overflow: hidden;
    height: 100%;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.blog-posts .post .img a img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    box-sizing: content-box;
}

.blog-posts .post .last-updated {
    font-size: 13px;
    margin-bottom: 2px;
}

.blog-posts .post .blog-title {
    font-size: 22px;
    margin-bottom: 4px;
    color: var(--dark-green);
}

.blog-posts .post .blog-title:hover {
    color: var(--green);
}

.blog-posts .post p {
    font-size: 16px;
    color: var(--grey);
    margin: 0 0 10px 0;
}

.blog-posts .post a.more {
    font-size: 14px;
    padding: 2px 6px;
    border-width: 0 0 2px 0;
    border-style: solid;
    border-color: var(--primary);
    font-family: 'PoppinsLight', sans-serif;
    color: var(--primary);
}

.blog-posts .post a.more:hover {
    color: var(--dark);
    border-color: var(--dark);
}

footer .copyright {
    background-color: #dce6e1;
    padding: 26px 0 23px 0;
    text-align: center;
    font-size: 14px;
}

footer .copyright strong {
    font-family: 'PoppinsBold', sans-serif;
}

footer .top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-width: 1px 0 0 0;
    border-style: solid;
    border-color: rgb(220, 230, 225);
    padding: 35px 0;
}

footer .company {
    width: 320px;
    color: #272727;
    font-family: 'PoppinsLight', sans-serif;
}

footer .company a,
footer .company .address,
footer .company .phone {
    padding-bottom: 12px;
    font-size: 15px;
}

footer .newsletter {
    width: 400px;
}

footer .newsletter .title {
    font-size: 20px;
    color: #222222;
}

footer .newsletter .title {
    font-size: 20px;
    color: #222222;
}

footer .newsletter p {
    color: var(--primary);
    font-size: 19px;
    font-family: 'PoppinsLight', sans-serif;
    margin: 0 0 20px 0;
}

footer .newsletter .form {
    border-style: solid;
    border-width: 2px;
    border-color: rgb(220, 224, 222);
    border-radius: 5px;
    background-color: rgb(255, 255, 255);
    padding: 7px;
    display: flex;
    height: 58px;
}

footer .newsletter .form input {
    border-width: 0;
    height: 100%;
    flex: 0 0 100%;
    max-width: calc(100% - 90px);
    font-size: 16px;
    color: #9c9c9c;
}

footer .newsletter .form input::placeholder {
    font-size: 16px;
    color: #9c9c9c;
}

footer .newsletter .form button {
    height: 100%;
    width: 90px;
    border-radius: 5px;
    background-color: rgb(134, 220, 175);
    color: var(--green);
    font-size: 16px;
    font-family: 'PoppinsBold', sans-serif;
    display: inline-flex;
    align-items: center;
    text-align: center;
    justify-content: center;
}

footer .newsletter .form button:hover {
    color: var(--white);
    background-color: var(--green);
}

footer .bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-width: 1px 0 0 0;
    border-style: solid;
    border-color: rgb(220, 230, 225);
    padding: 20px 0;
}

footer .bottom ul {
    display: flex;
    flex-direction: row;
    list-style: none;
    padding: 0;
    margin: 0;
}


footer .bottom ul.navbar-nav .nav-link {
    padding: 0 40px 0 0;
    font-size: 16px;
}

.page-top-content {
    background-image: url(../img/home/home-content-bg.png);
    background-size: cover;
    background-position: center;
    padding: 145px 0;
}

.page-top-content .page-top-content-container {
    max-width: 100%;
    width: 680px;
}

.page-top-content .title {
    font-size: 65px;
    line-height: 65px;
    color: var(--primary);
    margin-bottom: 30px;
    font-family: 'PoppinsLight', sans-serif;
}

.page-top-content .sub-title {
    color: var(--text-color);
    font-size: 23.5px;
    line-height: 23.5px;
    font-family: 'PoppinsLight', sans-serif;
    margin: 0 0 20px 0;
}

.page-top-content .sub-title strong {
    font-family: 'PoppinsBold', sans-serif;
    font-weight: 400;
}

.page-top-content p {
    font-size: 20px;
    margin: 0 0 0 0;
    font-family: 'PoppinsLight', sans-serif;
}

.page-top-content a {
    font-size: 20px;
    padding: 4px 8px;
    border-width: 0 0 3px 0;
    border-style: solid;
    border-color: var(--primary);
    font-family: 'PoppinsLight', sans-serif;
    color: var(--primary);
}

.page-top-content a:hover {
    border-color: var(--black);
    color: var(--black);
}

.page-top-content2 {
    padding: 100px 0;
}

.page-top-content3 {
    padding: 60px 0;
}

.page-top-content2 .title,
.page-top-content3 .title {
    margin: 0;
}

.about-contents {
    padding-bottom: 100px;
}

.contents .content {
    display: flex;
    flex: wrap;
    padding: 12px 0 0 0;
    align-items: center;
}

.contents .content .img {
    flex: 0 0 100%;
    max-width: 50%;
    overflow: hidden;
}

.contents .content .text-area {
    flex: 0 0 100%;
    max-width: 50%;
    padding: 0 0 0 60px;
}

.contents .content:nth-child(2n+2) .img {
    order: 1;
}

.contents .content:nth-child(2n+2) .text-area {
    padding: 0 60px 0 0;
}

.contents .content .text-area .content-title {
    font-size: 42px;
    font-family: 'PoppinsBold', sans-serif;
    line-height: 42px;
    color: var(--primary);
    margin-bottom: 30px;
}

.contents .content .text-area p {
    font-size: 20px;
    font-family: 'PoppinsLight', sans-serif;
    color: var(--text-color);
}

.products-page {
    padding: 70px 0 100px 0;
}

.product-details {
    padding: 50px 0 80px 0;
}

.product-details .container {
    display: flex;
}

.product-details .img {
    flex: 0 0 100%;
    max-width: calc(100% - 556px);
    display: flex;
}

.product-details .img .big-img {
    flex: 0 1 100%;
    border-style: solid;
    border-width: 1px;
    border-color: rgb(220, 230, 225);
    border-radius: 5px;
    background-color: rgb(255, 255, 255);
    overflow: hidden;
    height: 692px;
    transition: var(--ease);
    -webkit-transition: var(--ease);
}

.product-details .img .big-img:hover {
    border-color: var(--primary);
}

.product-details .img .big-img a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.product-details .img .big-img a img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    box-sizing: content-box;
    width: auto;
}

.product-details .img .thumbnails {
    flex: 0 0 16%;
    max-width: 125px;
    padding-left: 10px;
}

.product-details .img .thumbnails .thumbnail {
    height: 120px;
    border-style: solid;
    border-width: 1px;
    border-color: rgb(220, 230, 225);
    border-radius: 5px;
    background-color: rgb(255, 255, 255);
    overflow: hidden;
    margin: 0 0 10px 0;
    transition: var(--ease);
    -webkit-transition: var(--ease);
    padding: 5px;
}

.product-details .img .thumbnails .thumbnail.active {
    border-color: var(--primary);
}

.product-details .img .thumbnails .thumbnail a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.product-details .img .thumbnails .thumbnail a img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    box-sizing: content-box;
    width: auto;
}

.product-details .detail {
    flex: 0 0 100%;
    max-width: 556px;
    padding-left: 57px;
}

.product-details .detail .title {
    font-size: 23.5px;
    font-family: 'PoppinsLight', sans-serif;
    color: var(--primary);
    line-height: 23px;
    margin-bottom: 18px;
}

.product-details .detail .title strong {
    font-family: 'PoppinsBold', sans-serif;
    font-weight: 400;
}

.product-details .detail .product-title {
    font-size: 28px;
    line-height: 28px;
    margin-bottom: 28px;
}

.product-details .detail .prices-reviews {
    padding: 20px 0;
    border-width: 1px 0;
    border-style: solid;
    border-color: rgb(220, 229, 225);
    display: flex;
    justify-content: space-between;
    margin-bottom: 28px;
}

.product-details .prices {
    margin: 0 !important;
}

.product-details .description {
    color: var(--text-color);
    font-size: 16px;
    font-family: 'PoppinsLight', sans-serif;
    border-width: 0 0 1px 0;
    border-style: solid;
    border-color: rgb(220, 229, 225);
    margin-bottom: 34px;
    padding-bottom: 15px;
}

.product-details .description ul {
    padding: 0 0 0 25px;
}

.reviews .header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0 10px 0;
    border-width: 1px 0;
    border-style: solid;
    border-color: rgb(220, 229, 225);
    margin-bottom: 35px;
}

.reviews .header .title {
    display: flex;
    flex-direction: column;
    justify-content: left;
}

.reviews .header .title h2 {
    margin: 0;
}

.reviews .header .title .reviews-summary {
    justify-content: left;
}

.reviews .review {
    border-width: 0 0 1px 0;
    border-style: solid;
    border-color: rgb(220, 229, 225);
    margin-bottom: 35px;
    padding-bottom: 20px;
    font-size: 16px;
}

.reviews .review .user-name {
    font-size: 20px;
    font-family: 'PoppinsBold', sans-serif;
    font-weight: 400;
}

.reviews .review .stars {
    display: flex;
    justify-content: left;
    align-items: center;
    list-style: none;
    padding: 0;
    margin: 0 0 14px 0;
}

.reviews .review .stars li {
    padding: 0 3px;
    color: var(--yellow);
}

.similar-products {
    padding: 45px 0 100px 0;
}

.similar-products.custom-section .section-title {
    margin-bottom: 55px;
}

.blog-page {
    padding: 70px 0 100px 0;
}

.blog-page .blog-posts {
    margin-top: 0;
}

.blog-detail-page {
    padding: 60px 0 120px 0;
}

.blog-detail-page .container {
    max-width: 1100px;
}

.blog-detail-page.contents .content .text-area {
    max-width: 100%;
    padding: 0;
}

.map {
    margin: 20px 0;
    width: 100%;
}

.map iframe {
    width: 100%;
    height: 480px;
}

.contact-page {
    padding: 60px 0 40px 0;
}

.contact-page.contents .content .text-area {
    max-width: 100%;
    padding: 0;
}

.contact-form {
    padding: 0 0 80px 0;
}

.contact-form .container {
    max-width: 800px;
}

.contact-form textarea {
    resize: none;
}

.contact-form textarea,
.contact-form input[type='text'] {
    font-size: 14px;
}

.contact-form .btn-secondary {
    background-color: var(--primary);
    border-color: var(--primary);
}

.contact-form .btn-secondary:hover {
    background-color: var(--black);
    border-color: var(--black);
}

.sales-points-page {
    padding: 40px 0 120px 0;
}

.sales-points-page .container {
    display: flex;
    flex-wrap: wrap;
}

.sales-points-page .container .point {
    flex: 0 0 100%;
    max-width: calc(100% / 5 - 20px * 4 / 5);
    margin: 0 20px 20px 0;
    height: 200px;
}

.sales-points-page .container .point:nth-child(5n+5) {
    margin-right: 0;
}

.sales-points-page .container .point a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border: 1px solid #f0f0f0;
}

.sales-points-page .container .point a:hover {
    border: 1px solid #fff;
    box-shadow: 0px 1px 20px 0px rgba(0, 0, 0, 0.17);
}

.sales-points-page .container .point a img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    box-sizing: content-box;
    width: auto;
}

.slider-item .modal-dialog {
    max-width: calc(100% - 1rem);
    width: 714px;
}

.slider-item .close {
    position: absolute;
    right: -10px;
    top: -10px;
    background-color: #f00;
    padding: 2px 8px;
    border-radius: 8px;
    opacity: 1;
    font-size: 28px;
    color: #fff;
    box-shadow: 0 0 0 transparent;
    font-weight: 400;
}

.slider-item iframe {
    width: 100%;
    height: 400px;
}

.mobile-item {
    display: none;
}