@charset "utf-8";
@import "bootstrap.css";
@import "normalize.css";
@import "styleTS.css";
@import "../node_modules/slick-carousel/slick/slick.css";
@import "../node_modules/magnific-popup/dist/magnific-popup.css";
@import "callback-btn.css";
@import "callback-modal.css";
@import "typography.css";

/* Класс для увеличения картинки */

.zoom-img {}


/* Класс для галлереи */

.gallery {}


/* Класс для формы */

.form-submit-toggle {}


/* Класс для кнопки заказать звонок */

.callback-toggle {}

.fnc-nav__control {
    width: 118px;
}


/******** Magnific-Popup *********/

.mfp-fade.mfp-bg {
    opacity: 0;
    transition: all 0.15s ease-out;
}

.mfp-fade.mfp-bg.mfp-ready {
    opacity: 0.8;
}

.mfp-fade.mfp-bg.mfp-removing {
    opacity: 0;
}

.mfp-fade.mfp-wrap .mfp-content {
    opacity: 0;
    transition: all 0.15s ease-out;
}

.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
    opacity: 1;
}

.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
    opacity: 0;
}


/******* Image Cover ********/

.img-cover {
    background-size: cover;
    background-position: center;
}

.img-cover_inited>img {
    visibility: hidden;
}


/**********************************/

.main {
    display: flex;
}

.component {
    width: 100%;
}

.left,
.right {
    width: 30%;
}

@font-face {
    font-family: 'ProximaNova-Bold';
    src: url(../fonts/ProximaNova-Bold.ttf) format('truetype');
}

@font-face {
    font-family: 'ProximaNova-Light';
    src: url(../fonts/ProximaNova-Light.ttf) format('truetype');
}

@font-face {
    font-family: 'ProximaNova-Regular';
    src: url(../fonts/ProximaNova-Regular.ttf) format('truetype');
}

@font-face {
    font-family: 'ProximaNova-Semibold';
    src: url(../fonts/ProximaNova-Semibold.ttf) format('truetype');
}

@font-face {
    font-family: 'Akrobat';
    src: url(../fonts/Akrobat.ttf) format('truetype');
}

body {
    color: #000;
    font-size: 18px;
    font-family: "ProximaNova-Light";
}

body p {
    margin-top: 0;
    margin-bottom: 10px;
}

p.h1,
h1 {
    text-align: center;
    font-family: "ProximaNova-Bold";
    font-size: 30px;
    margin-bottom: 55px;
    color: #3c3c3b;
    line-height: 1;
    text-transform: uppercase;
    margin-top: 0;
}

.wrapper {
    max-width: 1920px;
    margin: 0 auto;
    min-height: 100vh;
    position: relative;
    overflow: hidden;
    min-width: 320px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.flexSA {
    display: flex;
    justify-content: space-around;
}

.flexSB {
    display: flex;
    justify-content: space-between;
}

.flexCenter {
    display: flex;
    justify-content: center;
}

.flexAI {
    display: flex;
    align-items: center;
}

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

.flexColumn {
    display: flex;
    flex-direction: column;
}

.flexStart {
    display: flex;
    justify-content: flex-start;
}

.flexEnd {
    display: flex;
    justify-content: flex-end;
}


/*header*/

header {
    background: url(../images/headerBg.jpg);
    padding: 20px 0;
}

.logo {
    text-align: center;
    display: block;
}

.logo:hover {
    color: #fff;
    text-decoration: none;
}

.logo img {
    margin-bottom: 7px;
}

.logo span {
    font-size: 11px;
    color: #fff;
    font-family: "ProximaNova-Light";
    text-transform: uppercase;
    text-align: center;
    line-height: 1;
    display: block;
}

header ul {
    display: flex;
    justify-content: center;
    margin: 0;
    flex-wrap: wrap;
    width: 500px;
}

header ul li {
    position: relative;
}

header ul li:hover ul {
    display: block;
}

header ul li ul {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: url(../images/headerBg.jpg);
    z-index: 2;
    padding-top: 10px;
}

header ul ul a {
    margin-right: 0;
    padding: 10px 15px;
    border-bottom: 1px solid #72c166;
    white-space: nowrap;
    display: block;
}

header ul ul li:last-child a {
    border-bottom: none;
}

header ul a {
    font-size: 16px;
    font-family: "ProximaNova-Light";
    color: #fff;
    margin-right: 20px;
    display: block;
    text-transform: uppercase;
    line-height: 1;
    transition: all 0.3s;
    margin-bottom: 15px;
}

header ul li:last-child a {
    margin-right: 0;
}

header ul a:hover {
    text-decoration: none;
    color: #72c166;
}

header .infoBlockH {
    background: url(../images/phoneIconH.png) no-repeat left top;
    padding-left: 50px;
}

header .infoBlockH a {
    display: block;
    font-size: 20px;
    color: #fff;
    line-height: 1;
    margin-bottom: 5px;
}

header .infoBlockH a span {
    color: #72c166;
}

header .infoBlockH p {
    font-size: 20px;
    text-decoration: underline;
    margin-bottom: 0;
    color: #fff;
    line-height: 1;
    cursor: pointer;
}


/*End header*/


/*topSlider*/


/*End topSlider*/


/*bannerMainBlock*/

.bannerMainBlock {
    padding: 85px 0 45px;
}

.wrapBM {
    display: grid;
    grid-template-columns: repeat(4, 283px);
    grid-gap: 3px;
}

.doubleRow {
    grid-row: span 2;
}

.nucBM {
    position: relative;
    display: block;
}

.nucBM .name {
    font-size: 19px;
    position: absolute;
    left: 0;
    bottom: 0;
    height: 65px;
    display: flex;
    align-items: center;
    padding: 10px 20px;
    color: #fff;
    background: rgba(61, 55, 57, 0.8);
    text-transform: uppercase;
    width: 100%;
    line-height: 1.1;
    transition: all 0.3s;
}

.nucBM:hover .name {
    background: rgba(53, 137, 41, 0.9);
}


/*End bannerMainBlock*/


/*specOffersBlock*/

.specOffersBlock {
    padding: 40px 0 55px;
}

.nucSO {
    width: 22.5%;
    overflow: hidden;
    position: relative;
    transition: all 0.3s;
}

.nucSO:hover {
    width: 30%;
}

.nucSO .txtBlock {
    position: absolute;
    left: 20px;
    bottom: 45px;
    width: calc(100% - 40px);
    transition: all 0.3s;
}

.nucSO .sale {
    font-size: 18px;
    font-family: "ProximaNova-Bold";
    display: inline-block;
    color: #fff;
    background: rgba(53, 137, 41, 0.9);
    padding: 10px;
    margin-bottom: 10px;
    line-height: 1;
}

.nucSO .name {
    font-size: 22px;
    font-family: "ProximaNova-Semibold";
    color: #fff;
    text-transform: uppercase;
    text-shadow: 2px 2px 2px #000;
    margin-bottom: 55px;
    line-height: 1.2;
}

.nucSO .name span {
    color: #439638;
}

.nucSO .more {
    font-size: 14px;
    color: #fff;
    text-transform: uppercase;
    padding-right: 40px;
    display: inline-block;
    background: url(../images/moreSO.png) no-repeat right center;
    opacity: 0;
    transition: all 0.3s;
}

.nucSO:hover .more {
    opacity: 1;
}


/*End specOffersBlock*/


/*cbBlock1*/

.cbBlock1 {
    background: url(../images/cbBlock1Bg.png) no-repeat top center;
    min-height: 653px;
    padding: 120px 0 30px;
}

.cbBlock1 img {
    margin-bottom: 25px;
}

.cbBlock1 p {
    font-size: 18px;
    font-family: "ProximaNova-Light";
    color: #fff;
    line-height: 1.1;
}

.cbBlock1 .name {
    font-size: 30px;
    text-transform: uppercase;
    font-family: "ProximaNova-Semibold";
}

.cbBlock1 button {
    border: 1px solid #fff;
    margin-top: 25px;
    display: inline-block;
    padding: 15px 20px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    font-family: "ProximaNova-Light";
    background: rgba(0, 0, 0, 0.6);
    transition: all 0.3s;
}

.cbBlock1 button:hover {
    color: #000;
    background: rgba(255, 255, 255, 1);
}


/*End cbBlock1*/


/*printBlock*/

.printBlock {
    padding: 80px 0;
}

.printBlock .title {
    margin-bottom: 50px;
    text-align: center;
}

.printBlock .title p:not(.h1) {
    font-size: 20px;
}

.wrapTabsImgGal {
    display: none;
}

.wrapTabsImgGal.active {
    display: block;
}

.printBlock .title h1,
.printBlock .title p.h1 {
    margin-bottom: 30px;
}

.wrapPring .leftBlock {
    width: 400px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.wrapPring .rightBlock {
    width: 690px;
}

.wrapPring .topImg {
    margin-bottom: 15px;
}

.topImg {
    width: 100%;
    height: 500px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.wrapPring .topImg img {
    max-width: 100%;
    box-shadow: 3px 4px 13px 0 rgba(0, 0, 0, 0.4);
}

.wrapPring .smallPhote img {
    max-width: 100%;
    box-shadow: 2px 2px 5px 0 rgba(0, 0, 0, 0.4);
}

.wrapPring .smallPhote .imgW {
    width: 145px;
}

.wrapPring ul li {
    font-size: 18px;
    font-family: "ProximaNova-Light";
    text-transform: uppercase;
    padding: 10px 0 10px 50px;
    color: #828180;
    border-left: 2px solid transparent;
    line-height: 1;
    cursor: pointer;
    transition: all 0.3s;
}

.wrapPring ul li:hover {
    color: #439638;
}

.wrapPring ul li.active {
    font-family: "ProximaNova-Semibold";
    color: #439638;
    padding-left: 90px;
    border-left: 2px solid #439638;
}

.wrapPring ul {
    width: 100%;
    border-bottom: 1px solid #000;
    padding-bottom: 20px;
    margin-bottom: 40px;
}

.saleBlock .topSaleBlock {
    margin-bottom: 20px;
}

.saleBlock .topSaleBlock p {
    text-transform: uppercase;
    font-size: 18px;
    font-family: "ProximaNova-Bold";
    margin-bottom: 0;
    line-height: 1;
}

.saleBlock .topSaleBlock a {
    font-size: 14px;
    color: #439638;
    line-height: 1;
}

.saleBlock .nucSale {
    padding: 5px;
    background: #fff;
    box-shadow: 2px 2px 6px 0 rgba(0, 0, 0, 0.3);
    width: calc(100% - 44px);
}

.saleBlock .nucSale .txtBlock {
    padding: 10px 15px 5px 10px;
}

.saleBlock .nucSale p {
    font-size: 13px;
    font-family: "ProximaNova-Light";
}

.saleBlock .nucSale p.sale {
    font-size: 14px;
    color: #439638;
    line-height: 1;
    text-transform: uppercase;
}

.saleBlock .nucSale a {
    font-size: 12px;
    color: #383838;
}

.wrapNucSale>a {
    background: #818181;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 33px;
}

.morePG {
    margin-top: 10px;
}

.morePG a {
    text-transform: uppercase;
    color: #439638;
    line-height: 1;
    font-family: "ProximaNova-Regular";
    font-size: 18px;
}


/*End printBlock*/


/*catABlock*/

.catABlock {
    background: url(../images/catABlockBg.png) no-repeat top center;
    min-height: 582px;
    padding: 225px 0 30px;
}

.catABlock .wrapsP {
    padding-left: 35px;
    border-left: 5px solid #439638;
    min-height: 180px;
    margin-bottom: 25px;
}

.catABlock p {
    font-size: 20px;
    font-family: "ProximaNova-Light";
    line-height: 1;
    color: #fff;
}

.catABlock .name {
    font-size: 30px;
    font-family: "ProximaNova-Semibold";
    text-transform: uppercase;
}

.catABlock .name span {
    color: #3c9831;
}

.catABlock .cat {
    font-family: "ProximaNova-Light";
    color: #439638;
    text-transform: uppercase;
    display: inline-block;
    border: 1px solid #439638;
    line-height: 1;
    padding: 15px 45px;
    background: rgba(0, 0, 0, 0.3);
    margin-left: 35px;
    transition: all 0.3s;
}

.catABlock .cat:hover {
    background: rgba(0, 0, 0, 1);
    text-decoration: none;
}


/*End catABlock*/


/*aboutCompanyBlock*/

.aboutCompanyBlock {
    padding: 90px 0;
}

.aboutCompanyBlock p.h1,
.aboutCompanyBlock h1 {
    text-align: left;
}

.aboutCompanyBlock .leftBlock {
    width: 430px;
}

.aboutCompanyBlock .rightBlock {
    width: 650px;
}

.aboutCompanyBlock .leftBlock .txtBlock {
    padding-left: 20px;
    border-left: 1px solid #000;
    margin-bottom: 20px;
}

.aboutCompanyBlock .leftBlock p.name {
    font-size: 32px;
    color: #3a403d;
    font-family: "ProximaNova-Bold";
    line-height: 1;
    margin-bottom: 15px;
}

.aboutCompanyBlock .leftBlock p.name span {
    color: #429538;
}

.aboutCompanyBlock .leftBlock p {
    color: rgba(0, 0, 0, 0.8);
    font-size: 16px;
    font-family: "ProximaNova-Light";
}

.aboutCompanyBlock .preBlock img {
    filter: grayscale(1);
    transition: all 0.3s;
}

.aboutCompanyBlock .preBlock img:hover {
    filter: grayscale(0);
}

.aboutCompanyBlock .rightBlock .txtBlock {
    margin-bottom: 35px;
}

.aboutCompanyBlock .rightBlock .txtBlock p {
    font-family: "ProximaNova-Light";
}

.aboutCompanyBlock .formWrap {
    width: 100%;
    position: relative;
    background: url(../images/bgformWrapBlcok.png) no-repeat center bottom;
}

.aboutCompanyBlock .formWrap p {
    font-size: 20px;
    font-family: "ProximaNova-Semibold";
    line-height: 1;
    margin-bottom: 15px;
    text-align: center;
}

.txtForm {
    background: url(../images/formPBg.png) no-repeat center 57px;
}

.aboutCompanyBlock .formWrap p.name {
    font-size: 26px;
    margin-bottom: 0;
}

.aboutCompanyBlock .formWrap a.phone {
    text-align: center;
    font-size: 28px;
    font-family: "ProximaNova-Bold";
    color: #439638;
    display: block;
}

.aboutCompanyBlock form {
    width: 500px;
    padding-top: 15px;
}

.aboutCompanyBlock .wrapInputs input {
    width: 49%;
    border: none;
    background: none;
    border-bottom: 1px solid #000;
    padding: 10px;
    line-height: 1;
    color: #439638;
    font-size: 16px;
    font-family: "ProximaNova-Light";
    transition: all 0.3s;
    margin-bottom: 10px;
}

.aboutCompanyBlock .wrapInputs input:hover {
    border-bottom: 1px solid #439638;
}

.aboutCompanyBlock .wrapInputs input::-webkit-input-placeholder {
    /* Chrome/Opera/Safari */
    color: #000;
    opacity: 1;
    transition: all 0.3s;
}

.aboutCompanyBlock .wrapInputs input::-moz-placeholder {
    /* Firefox 19+ */
    color: #000;
    opacity: 1;
    transition: all 0.3s;
}

.aboutCompanyBlock .wrapInputs input:-ms-input-placeholder {
    /* IE 10+ */
    color: #000;
    opacity: 1;
    transition: all 0.3s;
}

.aboutCompanyBlock .wrapInputs input:-moz-placeholder {
    /* Firefox 18- */
    color: #000;
    opacity: 1;
    transition: all 0.3s;
}

.aboutCompanyBlock .wrapInputs input:hover::-webkit-input-placeholder,
.aboutCompanyBlock .wrapInputs input:focus::-webkit-input-placeholder {
    /* Chrome/Opera/Safari */
    color: #439638;
}

.aboutCompanyBlock .wrapInputs input:hover::-moz-placeholder,
.aboutCompanyBlock .wrapInputs input:focus::-moz-placeholder {
    /* Firefox 19+ */
    color: #439638;
}

.aboutCompanyBlock .wrapInputs input:hover:-ms-input-placeholder,
.aboutCompanyBlock .wrapInputs input:focus:-ms-input-placeholder {
    /* IE 10+ */
    color: #439638;
}

.aboutCompanyBlock .wrapInputs input:hover:-moz-placeholder,
.aboutCompanyBlock .wrapInputs input:focus:-moz-placeholder {
    /* Firefox 18- */
    color: #439638;
}

.wrapLabel {
    position: relative;
}

.wrapLabel input {
    width: 1px;
    height: 1px;
    opacity: 0;
    position: absolute;
    left: 0;
    top: 0;
}

.aboutCompanyBlock .wrapLabel {
    padding: 0 20px;
}

.aboutCompanyBlock label {
    position: relative;
    padding-left: 30px;
    text-align: center;
    font-weight: normal;
    margin-bottom: 20px;
}

.aboutCompanyBlock label,
.aboutCompanyBlock label a {
    font-size: 12px;
    color: rgba(0, 0, 0, 0.3);
}

.aboutCompanyBlock button {
    font-size: 14px;
    font-family: "ProximaNova-Light";
    text-transform: uppercase;
    width: 260px;
    border: none;
    text-align: center;
    line-height: 1;
    color: #fff;
    padding: 17px;
    background: #439638;
    margin-bottom: -15px;
}

#checkF:checked+label::before {
    font-size: 17px;
    color: #439638;
    text-align: center;
    content: "\2713";
    line-height: 20px;
    font-family: "ProximaNova-Semibold";
}

.aboutCompanyBlock label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 20px;
    height: 20px;
    border-radius: 4px;
    border: 1px solid rgba(0, 0, 0, 0.3);
    ;
}


/*End aboutCompanyBlock*/


/*photoGallBlock*/

.photoGallBlock img {
    max-width: 100%;
    transition: all 0.3s;
}

.photoGallBlock .imgW {
    width: 20%;
}

.photoGallBlock img:hover {
    transform: scale(1.1);
}


/*End photoGallBlock*/


/*infoBlock*/

.infoBlock {
    background: url(../images/headerBg.jpg);
    padding: 30px 0;
    border-bottom: 1px solid #515350;
}

.nucIB {
    border-left: 4px solid #73c167;
    padding-left: 20px;
}

.nucIB .name {
    font-size: 24px;
    color: #73c167;
    line-height: 1;
    text-transform: uppercase;
    margin-bottom: 25px;
    font-family: "ProximaNova-Regular";
}

.nucIB .phoneBlock {
    background: url(../images/iconPhone.png) no-repeat left 3px;
    padding-left: 35px;
}

.nucIB .navBlock {
    background: url(../images/iconNav.png) no-repeat left 3px;
    padding-left: 35px;
}

.nucIB .mailBlock {
    background: url(../images/iconMail.png) no-repeat left 3px;
    padding-left: 35px;
}

.nucIB p,
.nucIB a {
    color: #fff;
    display: block;
    font-family: "ProximaNova-Light";
    margin-bottom: 0;
    line-height: 1.1;
}


/*End infoBlock*/


/* Страница отзывов */

#testimonail-form105 {
    width: 500px;
    margin: 0 auto;
}

#testimonail-form105 form label {
    font-size: 18px;
    font-family: "ProximaNova-Light";
    text-transform: uppercase;
    padding: 10px 0 10px 0px;
    color: #828180;
    border-left: 2px solid transparent;
    line-height: 1;
    cursor: pointer;
    transition: all 0.3s;
}

#testimonail-form105 form input,
#testimonail-form105 form textarea {
    width: 100%;
    border: 1px solid #bcbaba;
    color: #bcbaba;
    line-height: 1;
    background: none;
    padding: 15px !important;
    font-size: 16px;
    font-family: "ProximaNova-Light";
    margin-bottom: 7px;
    border-radius: 0px;
    -webkit-border-radius: 0px;
    -moz-border-radius: 0px;
    -ms-border-radius: 0px;
    -o-border-radius: 0px;
}

.tpm-showcase.rtp-1 {
    display: flex;
    flex-direction: column-reverse;
}

.tpm-showcase-bubble-top,
.tpm-showcase-top {
    padding: 10px;
}

.tpm-additional-info-top {
    font-size: 16px;
}


/* Страница отзывов */


/*footer*/

footer .wrapFooterBlock {
    background: url(../images/headerBg.jpg);
    padding: 30px 0 45px;
}

footer .logo img {
    margin-bottom: 5px;
}

footer .logo span {
    font-size: 11px;
    color: #bcbaba;
    font-family: "ProximaNova-Light";
    display: block;
    text-align: center;
}

footer .mainBlock .name {
    font-size: 16px;
    font-family: "ProximaNova-Semibold";
    color: #fff;
    text-transform: uppercase;
    line-height: 1;
    margin-bottom: 15px;
}

footer .mainBlock a {
    color: #bcbaba;
    display: block;
    font-size: 16px;
    font-family: "ProximaNova-Light";
    margin-bottom: 5px;
    line-height: 1;
    transition: all 0.3s;
}

footer .mainBlock a:hover {
    color: #fff;
}

footer .formWrap {
    width: 265px;
}

footer .formWrap p {
    font-size: 16px;
    font-family: "ProximaNova-Semibold";
    color: #fff;
    text-transform: uppercase;
    line-height: 1;
    margin-bottom: 25px;
    text-align: center;
}

footer form input {
    width: 100%;
    border: 1px solid #bcbaba;
    color: #bcbaba;
    line-height: 1;
    background: none;
    padding: 15px;
    font-size: 16px;
    font-family: "ProximaNova-Light";
    margin-bottom: 7px;
}

footer form button {
    width: 100%;
    border: 1px solid #000;
    background: #000;
    padding: 15px;
    text-align: center;
    color: #fff;
    line-height: 1;
    font-size: 16px;
    font-family: "ProximaNova-Light";
    text-transform: uppercase;
}

.copyrightBlock {
    padding: 25px 0;
    background: #1d1d1d;
    text-align: center;
}

.copyrightBlock .container {
    position: relative;
}

.copyrightBlock p {
    font-size: 16px;
    text-align: center;
    color: #fff;
    font-family: "ProximaNova-Light";
    line-height: 1.1;
    margin-bottom: 0;
}

.copyrightBlock p span,
.copyrightBlock p a {
    font-size: 14px;
    color: #bfbdbd;
    font-family: "ProximaNova-Light";
}

.copyrightBlock .socBlock {
    position: absolute;
    right: 0;
    top: calc(50% - 21px);
}

.copyrightBlock .socBlock a {
    filter: grayscale(1);
    transition: all 0.3s;
}

.copyrightBlock .socBlock a:hover {
    filter: grayscale(0);
}


/*End footer*/


/*insidePage*/

.insidepage .item-page {
    padding: 50px 0 20px;
    min-height: 300px;
}


/*End insidePAge*/


/* --- Media styles --- */

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

@media screen and (max-width:1199px) {}

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

@media screen and (max-width:991px) {}

@media screen and (max-width:767px) {}

@media screen and (max-width:675px) {}

@media screen and (max-width:640px) {}

@media screen and (max-width:600px) {}

@media screen and (max-width:485px) {}

@media screen and (max-width:425px) {}

@media screen and (max-width:400px) {}

@media screen and (max-width:370px) {}