.hero {

    position: relative;

    margin-top: -75px;

    background-color: #f2f1f1;

}



.hero-content {

    min-height: calc(100vh - 38px);

    position: relative;

    display: flex;

    align-items: flex-end;

}



.hero-content__background {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    opacity: .95;

}



.hero-content__background-desktop {

    display: none;

}



.hero-content__text {

    position: relative;

    padding: 50px 0 30px;

    width: 100%;

    background: rgb(255,255,255);

    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.8) 50%);

}



.hero-content__text h2 {

    line-height: 1.2;

    font-weight: normal;

}



.hero-content__text h2, .hero-content__text p {

    margin: 0;

}



.hero-content__text a.lspo-btn {

    margin-top: 15px;

}



.hero .slick-dots {

    padding: 0;

    list-style: none;

    margin: 0;

    position: absolute;

    bottom: 0;

    left: 0;

    width: 100%;

    display: flex;

    flex-wrap: nowrap;

    justify-content: space-between;

}



.hero .slick-dots li {

    display: block;

    width: 100%;

}



.hero .slick-dots button {

    text-indent: -99999px;

    display: block;

    padding: 0;

    background-color: rgba(0,0,0,.15);

    width: 100%;

    height: 5px;

    border: 0;

}



.hero .slick-active button {

    background-color: rgba(154,200,74,.3);

}



.hero .slick-btn {

    padding: 10px 20px;

    height: 50px;

    position: absolute;

    top: calc(50% - 25px);

    left: 0;

    z-index: 1;

    background-color: transparent;

    border: 0;

}



.hero .slick-btn.slick-prev {

    transform: scaleX(-1);

    filter: FlipH; /* For IE/Edge browsers */

}



.hero .slick-btn.slick-next {

    left: auto;

    right: 0;

}



.hero .slick-btn svg path {

    fill: #5b5657;

}



.hero .slick-btn:hover svg path {

    fill: #98c747;

}



@media screen and (min-width: 768px) {



    .hero-content__text h2 {

        font-size: 32px;

    }



    .hero-content__text p {

        font-size: 18px;

    }



}



@media screen and (min-width: 769px) {



    .hero-content__background-mobile {

        display: none;

    }



    .hero-content__background-desktop {

        display: block;

    }



}



@media screen and (min-width: 1024px) {



    .hero-content__text {

        padding: 55px 0;

        background: rgb(255,255,255);

        background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.5) 50%);

    }



}



@media screen and (min-width: 1440px) {



    .hero {

        margin-top: -115px;

    }



    .hero-content__text h2 {

        font-size: 38px;

    }



    .hero-content__text p {

        font-size: 22px;

    }



}



.home-products {

    padding: 40px 0;

}



.home-products__title {

    margin-top: 0;

    text-align: center;

}



.home-products__description {

    text-align: center;

    max-width: 670px;

    margin: 0 auto;

}



/* .home-products__slider {

    position: relative;

}



.home-products__slider .slick-btn {

    width: 35px;

    height: 35px;

    border-radius: 50%;

    padding: 0;

    background-color: #514b4d;

    border: 0;

    position: absolute;

    bottom: 50%;

    cursor: pointer;

}



.home-products__slider .slick-btn:hover {

    background-color: #99c848;

}



.home-products__slider .slick-btn.slick-prev {

    left: -45px;

    transform: scaleX(-1);

}



.home-products__slider .slick-btn.slick-next {

    right: -45px;

} */



.home-products__slider {

    display: flex;

    flex-wrap: wrap;

    margin-right: -20px;

}



.home-products__slide {

    margin-right: 20px;

    margin-bottom: 20px;

    width: calc(50% - 20px);

}



.home-product {

    position: relative;

    display: block;

}



.home-product__thumbnail {

    position: relative;

    background-color: #fff;

    border: 1px solid #e8e8e8;

}



.home-product__thumbnail canvas {

    width: 100%;

    height: auto;

    display: block;

}



.home-product__thumbnail img {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    object-fit: cover;

}



.home-product__title {

    margin: 10px 0 0;

    font-size: .9em;

}



.home-product__price {

    color: #99c848;

    font-weight: bold;

    margin: 0;

    font-size: .8em;

}



.flagship-stores__title {

    text-transform: uppercase;

    font-weight: bold;  

    color: #a4a4a4;

    margin-top: 40px;

}



.flagship-stores a {

    display: inline-block;

    margin: 0 5px;

}



@media screen and (min-width: 768px) {



    .home-products__title {

        font-size: 2.2em;

    }



    .home-products__slide {

        width: calc(25% - 20px);

    }

    

}



@media screen and (min-width: 1440px) {



    .home-products {

        padding-top: 100px;

        padding-bottom: 100px;

    }



    /* .home-products .container {

        max-width: 1280px;

    } */



    .home-products__slide {

        width: calc(20% - 20px);

    }



    .home-product__title {

        font-size: 1.03em;

    }



}



.about {

    text-align: center;

    padding: 40px 0;

    background-color: #514b4d;

    color: #fff;

}



.about__content p {

    font-size: 0.9375em;

}



.about__image img {

    display: block;

    margin: 0 auto;

}



@media screen and (min-width: 768px) {



    .about__title {

        font-size: 2.2em;

    }



}



@media screen and (min-width: 1024px) {



    .about {

        text-align: left;

        padding: 0;

    }



    .about__col {

        display: flex;

        flex-direction: row-reverse;

        align-content: stretch;

    }

    .about__content {
        width: 50%;
    }



    .about__content:first-child {

        padding: 30px 0;

        padding-left: 25px;

    }



}



@media screen and (min-width: 1440px) {



    .about {

        padding: 100px 0;

    }



}



.frames {

    background: #f8f8f8;

    padding: 40px 0 220px;

    background: #f8f8f8 url('../images/online/frames-bg-mobile.jpg') bottom center no-repeat;

    background-size: 100% auto;

    display: none;

}



.frames__boxes {

    display: flex;

    pointer-events: none;

}



.frames__box {

    width: 40%;

    display: block;

    max-width: 145px;

}



.frames__box img {

    display: block;

}



@media screen and (min-width: 768px) {



    .frames h2 {

        font-size: 2.2em;

    }



    .frames__content {

        max-width: 50%;

    }



}



@media screen and (min-width: 1024px) {



    .frames {

        background: url('../images/online/frames-bg.jpg') center no-repeat;

        background-size: cover;

        padding: 100px 0;

        border-bottom: 1px solid #e5e1e1;

    }



    .frames .container {

        position: relative;

        max-width: 1024px;

    }



    .frames__boxes {

        flex-direction: column;

        position: absolute;

        width: 100%;

    }



    .frames__content {

        max-width: calc(100% - 340px);

        margin: 0 auto;

    }



    .frames h2 {

        margin-top: 0;

    }



}



@media screen and (min-width: 1440px) {



    .frames {

        padding: 165px 0;

    }



    .frames .container {

        max-width: 1250px;

    }



    .frames__box {

        max-width: 245px;

    }



    .frames__content {

        max-width: calc(100% - 560px);

        min-height: 490px;

        padding: 100px 0;

    }



}



.our-brands {

    padding: 40px 0;

}



.brand-gallery {

    display: flex;

    flex-wrap: wrap;

    margin-right: -20px;

}



.brand-gallery__item {

    width: calc(50% - 20px);

    margin-right: 20px;

    margin-bottom: 20px;

}



@media screen and (min-width: 768px) {



    .our-brands {

        padding: 100px 0;

    }



    .our-brands .container {

        max-width: 980px;

    }



    .our-brands__title {

        font-size: 2.2em;

        margin-top: 0;

    }



    .brand-gallery__item {

        width: calc(25% - 20px);

    }



}



.services {

    padding: 40px 0;

    background-color: #f8f8f8;

    position: relative;

}



.services:before {

    width: 100%;

    height: 250px;

    background-color: #514b4d;

    content: '';

    display: block;

    position: absolute;

    bottom: 0;

    left: 0;

}



.services__title {

    margin-top: 0;

    font-size: 1.75em;

    line-height: 1.2;

    margin-bottom: 15px;

}



.services__sub-title {

    text-transform: uppercase;

    color: #99c848;

    margin-bottom: 0;

}



.services__thumbnails {

    display: none;

}



.service {

    background-color: #fff;

    border-radius: 15px;

    overflow: hidden;

}



.service__image {

    position: relative;

}



.service__image canvas {

    width: 100%;

    height: auto;

    display: block;

}



.service__image img {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    object-fit: cover;

}



.service__content {

    padding: 20px;

}



.service__title {

    margin-top: 0;

}



.service__description a {

    font-weight: bold;

    color: #99c848;

    text-decoration: none;

}



.services__slider .slick-dots {

    margin: 0;

    padding: 0;

    list-style: none;

    text-align: center;

    margin-top: 40px;

}



.services__slider .slick-dots li {

    display: inline-block;

    margin: 0 3px;

}



.services__slider .slick-dots button {

    padding: 0;

    text-indent: -99999px;

    background-color: #fff;

    border: 3px solid #fff;

    width: 12px;

    height: 12px;

    border-radius: 50%;

}



.services__slider .slick-dots li.slick-active button {

    background-color: transparent;

}



@media screen and (min-width: 768px) {



    .services__title {

        font-size: 2.2em;

    }



}



@media screen and (min-width: 1024px) {



    .services {

        background-color: #f8f8f8;

        padding: 100px 0;

    }



    .services__row {

        display: flex;

        width: 100%;

        max-width: 1200px;

        margin: 0 auto;

    }



    .services__col {

        width: 50%;

    }



    .services__col:first-child {

        padding-right: 60px;

    }



    .services:before {

        width: calc(50% - 100px);

        height: 100%;

        right: 0;

        top: 0;

        left: unset;

        bottom: unset;

    }



    .services__thumbnails {

        display: block;

        max-width: 300px;

    }



    .services__thumbnail {

        margin-bottom: 8px;

    }



    .services__thumbnail h3 {

        margin: 0;

        padding: 10px 15px;

        color: #fff;

        background-color: #514b4d;

        font-size: 16px;

        cursor: pointer;

    }



    .services__thumbnail--active h3 {

        background-color: #99c848;

    }



    .services__slider {

        max-width: 610px;

    }



}



@media screen and (min-width: 1440px) {



    .services__col:nth-child(1) {

        width: 40%;

    }

    

    .services__col:nth-child(2) {

        width: 60%;

    }



}



.lens {

    background: #fff;

    padding: 40px 0;

    background-size: 100% auto;

    display: none;

}



.lens__boxes {

    display: flex;

}



.lens__box {

    width: 40%;

    max-width: 145px;

    display: block;

}



.lens__box img {

    display: block;

}



@media screen and (min-width: 768px) {



    .lens h2 {

        font-size: 2.2em;

    }



}



@media screen and (min-width: 1024px) {



    .lens {

        padding: 100px 0;

        border-bottom: 1px solid #e5e1e1;

        background: url('../images/online/lens-bg.jpg') center no-repeat;

        background-size: cover;

        position: relative;

    }



    .lens:before {

        position: absolute;

        top: 0;

        left: 0;

        width: 100%;

        height: 100%;

        background-color: rgba(255,255,255,.4);

        content: '';

        display: block;

    }



    .lens .container {

        position: relative;

        max-width: 1024px;

    }



    .lens__boxes {

        flex-direction: column;

        position: absolute;

        max-width: 145px;

        right: 20px;

    }



    .lens__box {

        width: 100%;

        max-width: none;

    }



    .lens__content {

        max-width: calc(100% - 340px);

        margin: 0 auto;

    }



    .lens h2 {

        margin-top: 0;

    }



}







@media screen and (min-width: 1440px) {



    .lens {

        padding: 165px 0;

    }



    .lens .container {

        max-width: 1250px;

    }



    .lens__boxes {

        max-width: 245px;

    }



    .lens__content {

        max-width: calc(100% - 560px);

        min-height: 490px;

        padding: 100px 0;

    }



}



.consultation {

    background: url('../images/consultation-bg.jpg') center no-repeat;

    background-size: cover;

    padding: 60px 0;

    color: #fff;

    text-align: center;

}



.consultation__title {

    margin-top: 0;

}



.consultation a.lspo-btn {

    color: #99c848;

}



.consultation img {

    display: none;

}



@media screen and (min-width: 1024px) {



    .consultation {

        text-align: left;

        padding: 20px 0 0;

    }



    .consultation .container {

        max-width: 1000px;

    }



    .consultation img {

        display: block;

        position: relative;

        margin-left: -50px;

    }



    .consultation__row {

        display: flex;

        align-items: center;

    }



    .consultation__col {

        width: 50%;

    }



    .consultation__title {

        font-size: 3.4375em;

        margin-bottom: 0;

    }



    .consultation p {

        font-size: 1.375em;

        margin-top: 0;

    }



}