#main section:first-child {
    margin-top: 60px;
}

section, footer {
    position: relative;
    z-index: 5;
    background-color: #fff;
}

#top-sec .container {
    padding-bottom: 80px;
}

#top-sec .sec-title {
    color: #fff;
    font-size: 32px;
    line-height: 1em;
    font-weight: 400;
    padding-top: 80px;
}

#top-sec .sec-title.text-shadow {
    text-shadow: 0 5px 5px rgb(0 0 0 / 60%);
}

.top-sec__bg-img,
.btns-sec__bg-img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.top-sec__bg-img > *,
.btns-sec__bg-img > * {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

#top-sec .container,
#btns-sec .container {
    position: relative;
    z-index: 2;
}

#btns-sec {
	padding: 30px 0;
	position: relative;
    z-index: 4;
}

.btns-sec__bg-img {
    position: fixed;
    top: 60px;
    left: 0;
    width: 100%;
    height: calc(100% - 60px);
    z-index: 1;
}

.btns-block {
	text-align: center;
}

.btns-block__btn {
	display: block;
	margin: 12px auto;
	padding: 9px 40px;
	color: #fff;
	font-family: 'Ogenblik', sans-serif;
	font-size: 22px;
	line-height: 26px;
	background-size: 100% 100%;
	background-position: center;
	background-repeat: no-repeat;
    transition: .3s all;
    width: fit-content;
}

.btns-block__btn.green {
	background-image: url(../images/btn_green.png);
}

.btns-block__btn.green:hover {
    background-image: url(../images/btn_dark.png);
    color: #fff;
}

.btns-block__btn.black {
	background-image: url(../images/btn_dark.png);
}

.btns-block__btn.black:hover {
    background-image: url(../images/btn_green.png);
    color: #000;
}

#buy-sec {
    padding: 30px 0 0;
}

/* For iOS START */
#buy-sec .row,
.testimonials-row {
    display: -webkit-flex;
    -webkit-flex-wrap: wrap;
}

@media screen and (min-width: 768px) {
    #buy-sec .col-md-6,
    #testimonials-sec .col-md-6 {
        -webkit-flex: 0 0 50%;
    }
}
/* For iOS END */

#buy-sec .title-col {
    text-align: center;
}

#buy-sec .sec-title {
    position: relative;
    display: inline-block;
    font-size: 32px;
    line-height: 1.17em;
    margin-bottom: 1.2em;
    padding: 0 1.8em;
}

#buy-sec .sec-title::before,
#buy-sec .sec-title::after {
    content: '';
    display: block;
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
}

#buy-sec .sec-title.jiggle-active::before {
    animation: jiggle_two ease-in-out .4s infinite;
}

#buy-sec .sec-title::before {
    width: 1.69em;
    height: 1.5em;
    background-image: url(../images/made-with-love.png);
    left: .6em;
    top: 50%;
    transform: rotate(-50deg) translate(0,-50%);
    -ms-transform: rotate(-50deg) translate(0,-50%);
    -webkit-transform: rotate(-50deg) translate(0,-50%);
}

#buy-sec .sec-title::after {
    height: 5px;
    width: calc(100% - 3.2em);
    background-image: url(../images/underline2.svg);
    background-position: center bottom;
    bottom: -15px;
    left: 1.6em;
}

.product-col {
    display: flex;
    display: -webkit-flex;
    margin-bottom: 50px;
}

.product-block {
    position: relative;
    padding-bottom: 90px;
}

.product-btns {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

.product__thumb {
    position: relative;
}

.product__thumb img {
    display: block;
    max-width: 100%;
}

.save-label {
    position: absolute;
    top: 6%;
    display: block;
    width: 120px;
    height: 38px;
    font-family: 'Ogenblik', sans-serif;
    font-size: 20px;
    line-height: 38px;
    text-align: center;
    color: #fff;
    background-image: url(../images/btn-red.png);
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    cursor: default;
}

.save-label:hover {
    animation: zoom ease-in-out .4s infinite;
}

.product-col:nth-child(2n) .save-label {
    left: -3%;
}

.product-col:nth-child(2n - 1) .save-label {
    right: -3%;
}

.product-title {
    display: block;
    text-align: center;
    font-size: 20px;
    line-height: 1.2em;
    font-weight: 600;
    margin: 18px 0 19px;
}

.product-price,
.product-add-to-cart,
.leave-to-review-col .btn {
    height: 44px;
    text-align: center;
    line-height: 42px;
    padding: 0 0 2px;
    font-family: 'Ogenblik', sans-serif;
    font-size: 22px;
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
}

.product-price,
.product-add-to-cart {
    display: block;
    width: 130px;
    margin: 0 auto 1px;
    color: #fff;
}

.leave-to-review-col .btn {
    display: inline-block;
    width: 157px;
    color: #000;
}

.product-price,
.leave-to-review-col .btn.green-btn {
    background-image: url(../images/btn_green.png);
    transition: .3s all;
}

.leave-to-review-col .btn.green-btn:hover {
    background-image: url(../images/btn_dark.png);
    color: #fff;
}

.product-add-to-cart {
    background-image: url(../images/btn_dark.png);
    transition: .3s all;
}

.product-add-to-cart:hover {
    background-image: url(../images/btn_green.png);
    color: #000;
}

.product-text {
    text-align: center;
    margin-bottom: 28px;
}

.product-text span {
    display: inline-block;
}

.product-text .green-text {
    font-weight: 500;
}

.product-text .green-text a {
    color: #8fb852;
}

#testimonials-sec {
    padding: 50px 0;
}

.testimonial-block {
    padding: 27px 0 20px 66px;
    position: relative;
    padding-bottom: 20px;
    border-bottom: 1px solid #E6E6E6;
    height: 100%;
}

.testimonial__thumb {
    width: 48px;
    height: 48px;
    background-size: cover;
    position: absolute;
    top: 27px;
    left: 0;
    border-radius: 50%;
    overflow: hidden;
}

.testimonial__name {
    display: block;
    font-size: 16px;
    line-height: 19px;
    font-weight: 600;
    margin-bottom: 6px;
}

.testimonial__stars {
    position: relative;
    width: 102px;
    height: 17px;
    margin-bottom: 12px;
}

.testimonial__stars::after {
    content: '';
    position: absolute;
    top: -1px;
    left: -1px;
    display: block;
    width: calc(100% + 2px);
    height: calc(100% + 2px);
    background-size: 20% 100%;
    background-position: left center;
    background-repeat: repeat-x;
    background-image: url(../images/star-empty.png);
    z-index: 2;
}

.testimonial__date {
    display: block;
    font-size: 12px;
    line-height: 15px;
    color: #666;
    margin-bottom: 13px;
}

.testimonials-slider__text {
    font-size: 16px;
    line-height: 1.625em;
    color: #3D3D3D;
}

.testimonials-slider__text >*:first-child {
    margin-top: 0;
}

.testimonials-slider__text >*:last-child {
    margin-bottom: 0;
}

.reviews-count {
    font-size: 16px;
    line-height: 44px;
}

.testimonials-row {
    margin-bottom: 34px;
}

.reviews-count-col {
    padding-right: 0;
}

.leave-to-review-col {
    text-align: right;
}

.reviews-rating {
    display: block;
}

.reviews-rating * {
    display: inline-block;
    line-height: 44px;
    vertical-align: middle;
}

.reviews-rating .star {
    width: 19px;
    height: 44px;
    margin-right: 7px;
    background-image: url(../images/star-empty.png);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}

.reviews-rating .total {
    font-size: 24px;
    font-weight: 700;
}

.reviews-rating .rating {
    margin-right: 11px;
}

.view-all-block {
    text-align: center;
}

.view-all-block .btn {
    position: relative;
    display: inline-block;
    padding: 0 8px 8px;
    color: #222;
    font-size: 22px;
}

.view-all-block .btn::after {
    content: '';
    display: block;
    width: 100%;
    height: 4px;
    position: absolute;
    bottom: 0;
    left: 0;
    background-image: url(../images/underline6.png);
    background-size: contain;
    background-position: center bottom;
    background-repeat: no-repeat;
}

.product-clouds {
    position: absolute;
    top: 0;
    left: 0;
    width: 23%;
    height: 100%;
    background-image: url(../images/product-clouds.png);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transform: translate(-17%,0);
    -ms-transform: translate(-17%,0);
    -webkit-transform: translate(-17%,0);
}

.product-clouds.jiggle-active {
    animation: jiggle_three_a ease-in-out .4s infinite;
}

@media screen and (min-width: 576px) {
    #top-sec .sec-title {
        font-size: 44px;
    }

    #btns-sec {
    	padding: 35px 0;
    }

    #buy-sec .sec-title {
        font-size: 42px;
    }

    #testimonials-sec {
        padding: 60px 0;
    }

    .reviews-count {
        font-size: 20px;
    }

    .btns-block__btn {
        display: inline-block;
        margin: 12px;
    }
}

@media screen and (min-width: 768px) {
    #btns-sec {
    	padding: 45px 0;
    }

    #buy-sec {
        padding: 40px 0 10px;
    }

    #buy-sec .sec-title {
        font-size: 46px;
    }

    .product-title {
        margin-top: 28px;
    }

    #testimonials-sec {
        padding: 70px 0;
    }

    .product-clouds {
        transform: translate(-50%,0);
        -ms-transform: translate(-50%,0);
        -webkit-transform: translate(-50%,0);
    }

    .product-clouds.jiggle-active {
        animation: jiggle_three ease-in-out .4s infinite;
    }
}

@media screen and (min-width: 992px) {
    #main section:first-child {
        margin-top: 100px;
    }

    #top-sec .sec-title {
        font-size: 50px;
        padding-top: 150px;
    }

    #btns-sec {
    	padding: 55px 0;
    }

    #buy-sec {
        padding: 50px 0 20px;
    }

    #buy-sec .sec-title {
        font-size: 48px;
    }

    #testimonials-sec {
        padding: 80px 0;
    }

    .save-label {
        top: 10%;
        width: 164px;
        height: 52px;
        line-height: 52px;
    }

    .product-col:nth-child(2n) .save-label {
        left: -9%;
    }

    .product-col:nth-child(2n - 1) .save-label {
        right: -9%;
    }

    .btns-sec__bg-img {
        top: 100px;
        height: calc(100% - 100px);
    }
}

@media screen and (min-width: 1200px) {
    #top-sec .sec-title {
        padding-top: 187px;
        font-size: 60px;
    }

    #btns-sec {
    	padding: 66px 0;
    }

    #buy-sec {
        padding: 68px 0 45px;
    }

    #buy-sec .sec-title {
        font-size: 52px;
    }

    #testimonials-sec {
        padding: 100px 0;
    }
}