body {
    font-family: 'Proxima Nova', sans-serif;
}

.container {
    overflow: visible;
}

.logo {
    margin: 13px 0 0;
    display: block;
}
.logo.mobile {
    display: none;
}

.leading {
    padding-top: 40px;
    padding-bottom: 106px;
    position: relative;
    overflow: hidden;
}
.leading .bg {
    position: absolute;
    right: -110px;
    top: 10px;
    z-index: -100;
}

.leading .title {
    font-size: 55px;
    font-weight: bold;
    color: #04061A;
    line-height: 55px;
}
.leading .title .green {
    color: #71B62F;
}
.leading .heading {
    font-size: 25px;
    font-weight: normal;
    color: #04061A;
    line-height: 25px;
    margin: 24px 0 30px;
}


.hero {
    position: relative;
    height: 618px;
    background-image: url(/images/bg_heading.jpg);
    background-position: center;
}
.hero .wrapper {
    position: absolute;
    right: 0;
    top: 255px;
    padding-right: 250px;
    height: 110px;
    line-height: 25px;
    border-radius: 55px 0 0 55px;
    background-color: #71B62F;
    color: #FFFFFF;
}
.hero .wrapper .text {
    width: 410px;
    padding: 30px 0 30px 195px;
    font-family: 'Proxima Nova';
    font-weight: bold;
    font-size: 25px;
}



.benefit {
    position: relative;
}
.benefit .bg {
    position: absolute;
    left: -25px;
    top: 80px;
    z-index: -100;
}
.benefit .row {
    overflow: visible;
}
.benefit .features {
    list-style: none;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
}
.benefit .features .item {
    width: 32%;
    height: 80px;
    position: relative;
}
.benefit .features .item > span {
    display: block;
    position: absolute;
    font-size: 55px;
    font-weight: 900;
    color: #71B62F;
    width: 55px;
    font-family: 'Proxima Nova';
    top: -15px;
    left: -10px;
}
.benefit .features .item > div {
    padding-left: 45px;
}


.portfolio .carousel {
    overflow: hidden;
}
.portfolio .carousel .wrapper {
    width: 300%;
    display: flex;
    flex-flow: row nowrap;
}
.portfolio .carousel .slide {
    display: inline-block;
    min-height: 450px;
    background-color: #00000030;
    margin-right: 20px;
}


.catalog {
    padding-bottom: 60px;
    /*display: none;*/
}
.catalog h2 {
    margin-top: 60px;
    margin-bottom: 60px;
}
.catalog .carousel {
    overflow: hidden;
    overflow-x: scroll;
}
.catalog .carousel .wrapper {
    height: 330px;
    width: 300%;
    display: flex;
    flex-flow: row nowrap;
    padding: 0 0 40px 0;
}
.catalog .carousel .slide {
    display: inline-block;
    height: 320px;
    /*background-color: #00000030;*/
    width: 1050px;
    margin-right: 20px;
}
.catalog .photo {
    /*width: 300px;*/
    height: 320px;
    padding: 10px 30px 0;
    float: left;
}
.catalog h3 {
    color: #71B62F;
    font-size: 25px;
    font-weight: bold;
    /*padding: 10px 0 0;*/
}
.catalog h4 {
    font-size: 14px;
    font-weight: bold;
    padding: 10px 0;
}
.catalog p {
    font-size: 14px;
    font-weight: normal;
}


.prices .bg {
    position: absolute;
    right: 0;
    top: -130px;
    z-index: 1;
}
.prices {
    position: relative;
    background-image: url(/images/bg_prices.jpg);
    background-position: center;
    height: 347px;
    color: #FFFFFF;
    font-size: 25px;
    font-weight: bold;
    overflow: hidden;
}
.prices .row {
    z-index: 100;
}
.prices .row:first-of-type {
    margin-top: 100px;
}
.prices .row:last-of-type {
    margin-top: 45px;
}
.prices .row .last {
    text-align: right;
}
.prices .sevencol {
    line-height: 25px;
}
.prices .price {
    display: inline-block;
    background-color: #71B62F;
    line-height: 45px;
    border-radius: 50px;
    width: 320px;
    text-align: center;
    position: relative;
}
.prices .price > span {
    font-family: sans-serif;
    /*font-size: 23.5px;*/
}


.reviews {
    margin-bottom: 60px;
}
.reviews h2 {
    margin-top: 60px;
    margin-bottom: 60px;
}
.reviews .carousel {
    height: 200px;
    overflow: hidden;
    overflow-x: scroll;
}
.reviews .carousel .wrapper {
    width: 300%;
    display: flex;
    flex-flow: row nowrap;
    padding-left: 30px;
}
.reviews .carousel .slide {
    display: inline-block;
    height: 190px;
    /*background-color: #00000030;*/
    width: 24vw;
    min-width: 460px;
    margin-right: 30px;
}
.reviews h3 {
    color: #71B62F;
    font-size: 25px;
    font-weight: bold;
    /*padding: 10px 0 0;*/
}
.reviews h4 {
    font-size: 14px;
    font-weight: bold;
    padding: 10px 0;
}
.reviews p {
    font-size: 14px;
    font-weight: normal;
}
.reviews img.userpic {
    float: left;
    width: 70px;
    height: 70px;
    margin: 0 30px 100px 0;
    border-radius: 35px;
}


.footer {
    overflow: hidden;
    position: relative;
    padding-bottom: 75px;
    color: #FFFFFF;
    background-color: #71B62F;
}
.footer .graphic {
    transform: scaleX(-1);
    position: absolute;
    left: -220px;
    bottom: -150px;
}
.footer .contacts {
    text-align: right;
    margin-top: 75px;
    padding-bottom: 30px;
}
.footer .contact {
    display: inline-block;
    margin: 0 0 0 60px;
}
.footer .contact a {
    font-size: 25px;
    font-weight: bold;
    color: #FFFFFF;
    text-decoration: none;
}
.footer .contact a:hover {
    text-decoration: underline;
}
.footer .contact.phone img {
    vertical-align: bottom;
    margin-right: 5px;
}
.footer .contact.mail img {
    vertical-align: bottom;
    margin-right: 10px;
}
.footer .credits {
    text-align: right;
    line-height: 30px;
}
.footer .copy {
    padding-top: 5px;
    font-weight: bold;
}




        h2 {
            font-size: 25px;
            font-weight: bold;
            margin-top: 100px;
            margin-bottom: 90px;
        }
        .color.green {
            background-color: #71B62F;
            color: #000000;
        }
        .color.gray {
            background-color: #E4E4E4;
            color: #000000;
        }
        .color.white {
            background-color: #FFFFFF;
            color: #000000;
            border-top: 1px solid #00000080;
            border-right: 1px solid #00000080;
            border-bottom: 1px solid #00000080;
        }
        .color.half-black {
            background-color: #04061A80;
            color: #FFFFFF;
        }
        .color.black {
            background-color: #04061A;
            color: #FFFFFF;
        }
/*        .button {
            height: 45px;
            width: 200px;
            line-height: 45px;
            border-radius: 50px;
            background-color: #71B62F;
            text-align: center;
            font-family: 'Proxima Nova';
            font-weight: normal;
            font-size: 14px;
            color: #FFFFFF;
        }
        .button:hover {
            background-color: #588D25;
        }
*/

                    .hcontacts {
                        text-align: right;
                        margin-right: -13px;
                    }
                    .hcontacts .contact {
                        display: inline-block;
                        margin-bottom: 20px;
                    }
                    .hcontacts .contact a {
                        text-decoration: none;
                        color: #04061A;
                    }
                    .hcontacts .contact a:hover {
                        text-decoration: underline;
                    }
                    .hcontacts .contact img {
                        vertical-align: middle;
                    }
                    .hcontacts .contact a {
                        display: inline-block;
                        font-family: 'Montserrat', sans-serif;
                        font-weight: normal;
                        /*text-shadow: 0px 0px 2px #04061A10;*/
                    }
                    .hcontacts .contact.phone a {
                        font-size: 15px;
                        transform: scale(.94, .94);
                        margin: 0 20px 0 5px;
                    }
                    .hcontacts .contact.mail a {
                        font-size: 14px;
                        margin: 0 20px 0 15px;
                    }


        .menu {
            text-align: right;
            padding-top: 35px;
            padding-bottom: 20px;
        }
        .menu a {
            display: inline-block;
            margin-left: 40px;
            color: #04061A;
            font-family: 'Montserrat', sans-serif;
            font-size: 14px;
            font-weight: normal;
            text-decoration: none;
            text-shadow: 0px 0px 2px #04061A08;
            transform: scale(1.03, 1);
        }
        .menu a:hover {
            text-decoration: underline;
        }
        .button {
            display: inline-block;
            height: 45px;
            width: 200px;
            line-height: 45px;
            border-radius: 50px;
            background-color: #71B62F;
            text-align: center;
            font-family: 'Proxima Nova';
            font-weight: normal;
            font-size: 14px;
            color: #FFFFFF;
            text-decoration: none;
        }
        .button:hover {
            background-color: #588D25;
        }








/*** CAROUSEL ***/

.control {
    text-align: center;
    margin-top: 60px;
}
.control .arrow {
    box-sizing: border-box;
    margin: 0 15px;
    transition: transform .3s;
    cursor: pointer;
}
.control .arrow.prev {
    transform: rotate(0deg) scale(1);
}
.control .arrow.prev:hover {
    transform: rotate(0deg) scale(1.03);
}
.control .arrow.next {
    transform: rotate(180deg) scale(1);
}
.control .arrow.next:hover {
    transform: rotate(180deg) scale(1.03);
}



.logo {
    animation: fadein .5s ease-out;
}
.menu * {
    animation: fadein 1.2s ease-in-out;
}
.contact {
    animation: fadein 1.5s ease-out;
}
.title {
    animation: arrived 1s;
}
.heading {
    animation: arrived 1.2s;
}
.button {
    animation: fadein 1.2s ease-in;
}

.swing {
    animation: swing ease-in-out 7s infinite alternate;
    transform-origin: center right;
}

@keyframes swing {
    0% { transform: rotate(1deg) translateX(-5px); }
    100% { transform: rotate(-2deg) translateX(3px); }
}

@keyframes arrived {
    from { opacity: 0; transform: translateY(10px) scale(.95); }
    to   { opacity: 1; transform: translateY(0px) scale(1); }
}
@keyframes fadein {
    from { opacity: 0; }
    to   { opacity: 1; }
}