body, html {
    height: 100%;
    margin: 0;
}

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

@font-face {
    font-family:Ultima;
    src:url(/pics/fonts/2C7E28_0_0.eot);
    src:url(/pics/fonts/2C7E28_0_0.eot?#iefix) format('embedded-opentype'),
        url(/pics/fonts/2C7E28_0_0.woff2) format('woff2'),
        url(/pics/fonts/2C7E28_0_0.woff) format('woff'),
        url(/pics/fonts/2C7E28_0_0.ttf) format('truetype');
    font-weight:400
}

@font-face {
    font-family:Ultima;
    src:url(/pics/fonts/2C7E31_0_0.eot);
    src:url(/pics/fonts/2C7E31_0_0.eot?#iefix) format('embedded-opentype'),
        url(/pics/fonts/2C7E31_0_0.woff2) format('woff2'),
        url(/pics/fonts/2C7E31_0_0.woff) format('woff'),
        url(/pics/fonts/2C7E31_0_0.ttf) format('truetype');
    font-weight:700
}

@font-face {
    font-family:BravoRG;
    src:url(/pics/fonts/bravorg.eot);
    src:url(/pics/fonts/bravorg.eot?#iefix) format('embedded-opentype'),
        url(/pics/fonts/bravorg.woff2) format('woff2'),
        url(/pics/fonts/bravorg.woff) format('woff'),
        url(/pics/fonts/bravorg.ttf) format('truetype');
    font-weight:700
}

@font-face {
    font-family:BebasNueBold;
    src:url(/pics/fonts/bebasneuebold.eot);
    src:url(/pics/fonts/bebasneuebold.eot?#iefix) format('embedded-opentype'),
        url(/pics/fonts/bebasneuebold.woff2) format('woff2'),
        url(/pics/fonts/bebasneuebold.woff) format('woff'),
        url(/pics/fonts/bebasneuebold.ttf) format('truetype');
    font-weight:400
}

@font-face {
    font-family:RobotoCondensedLight;
    src:url(/pics/fonts/roboto_condensed_light.eot);
    src:url(/pics/fonts/roboto_condensed_light.eot?#iefix) format('embedded-opentype'),
        url(/pics/fonts/roboto_condensed_light.woff2) format('woff2'),
        url(/pics/fonts/roboto_condensed_light.woff) format('woff'),
        url(/pics/fonts/roboto_condensed_light.ttf) format('truetype');
    font-weight:400
}


a.border-bottom-none {
    border-bottom:4px solid transparent!important;
    font-weight: bold;
}

a.border-bottom-none:hover {
    border-bottom:4px solid red!important;
}

a.top-logo, a.top-logo:hover {
    text-decoration: none;
}

.main-top-block {
    min-height: 415px;
    position: relative;
    background: url(/pics/index_top_photo.jpg) no-repeat bottom center;
    background-size: cover;
}

#topbar {
    height: 108px;
    background-color: rgba(255, 255, 255, 0.81);
    -webkit-box-shadow: 0 2px 4px #6d6d6d;
    box-shadow: 0 2px 4px #6d6d6d; /* #525252 */
    transition: height 0.4s , background-color 0.4s;
    z-index: 10;
}

.main-top-block-line-2 {
    height: 23px;
    width: 100%;
    position: absolute;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.52);
}

#logo {
    width: 27%;
    font-size: 43px;
    color: #61759A;
    text-transform: uppercase;
    -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=2, Direction=135, Color=#c0baba)";
    text-shadow: 4px 4px 2px #c0baba;
    transition: font-size 0.4s
}
.main-top-phone {
    width: 22%;
    font-size: 22px;
    color: #000000;
    text-align: center;
}

.main-top-phone-small {
    font-size: 17px;
    color: #000000;
    padding-bottom: 10px;
}

.main-big-block {
    background: url(/pics/top_fon_0.png) repeat top center;
}

.main-line-under-top-block {
    width: 100%;
    height: 57px;
    font-size: 26px;
    font-family: /*BebasNueBold, BravoRG,*/ 'Noto Sans', Arial, Verdana, sans-serif;
    letter-spacing: 1px;
    /*text-transform: uppercase;*/
    font-style: italic;

    background: url(/pics/top_fon_1.png) repeat top center;
    -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=6, Direction=180, Color=#888888)";
    -webkit-box-shadow: 0 3px 6px #888888;
    box-shadow: 0 3px 6px #888888;
}

.main-blur {
    cursor: pointer;
    transform: scale(1);
    transition: 0.3s linear;
}

.main-blur:hover {
    transform: scale(1.02);
}

.main-service-block {
    min-height: 260px;
    border-left: 1px solid #bbb;
    border-right: 1px solid #bbb;
    border-bottom: 1px solid #bbb;
}

.main-service-block_2 {
    min-height: 280px;
    border-left: 1px solid #bbb;
    border-right: 1px solid #bbb;
    border-bottom: 1px solid #bbb;
}

.main-services-block-1 {
    padding-top: 24px;
}

.main-services-block-2 {
    padding-top: 24px;
}

.main-services-block-3 {
    padding-top: 24px;
    padding-bottom: 48px;
}

.main-services-block-4 {
    padding-top: 24px;
    padding-bottom: 48px;
}

.main-service-ph-1 {
    background: url(/pics/main-service-ph-1.jpg) no-repeat bottom center;
    background-size: cover;
    height: 123px;
}

.main-service-ph-2 {
    background: url(/pics/main-service-ph-2.jpg) no-repeat bottom center;
    background-size: cover;
    height: 123px;
}

.main-service-ph-3 {
    background: url(/pics/main-service-ph-3.jpg) no-repeat bottom center;
    background-size: cover;
    height: 123px;
}

.main-service-ph-4 {
    background: url(/pics/main-service-ph-4.jpg) no-repeat bottom center;
    background-size: cover;
    height: 123px;
}

.main-service-title {
    font-size: 14px;
    font-weight:  bold;
    padding-left: 5px;
}

.main-service-list {
    font-size: 12px;
    padding-left: 18px;
}

.main-service-list li {
    padding-left: 10px;
}

.main-service-block-left {
    padding-right: 10px;
}

.main-service-block-right {
    padding-right: 5px;
}

.main-title {
    font-size: 18px;
}

.main-our-prod-title {
    font-size: 26px;
    font-family: /*BebasNueBold, BravoRG,*/ 'Noto Sans', Arial, Verdana, sans-serif;
    letter-spacing: 1px;
    /*text-transform: uppercase;*/
    font-style: italic;
}

.main-owl-item {
    height: 240px;
    overflow: hidden;
    border: 1px solid #ccc;
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
}

.main-owl-item-title {
    background-color: #EAEAEA;
    font-size: 12px;
    color: #444;
    font-weight: bold;
    padding-bottom: 2px;
}
.main-owl-item-img {
    width: 30%;
}
.main-owl-item-info-title {
    font-weight: bold;
}
.main-owl-item-info-txt {
    font-size: 11px;
    color: #444;
}

.main-map {
    height: 700px;
    width: 100%;
}

.main-bottom-menu {
    background: url(/pics/bottom-menu-fon.png) repeat ;
}

.main-bottom-menu-2 {
    background: url(/pics/bottom-menu-fon-firm-name.png) no-repeat bottom right ;
}

.bottom-menu-block {
    min-height: 230px;
    border-left: 1px dashed #888;
}

.main-bottom-title {
    color: #FFFFBB;
    font-size: 15px;
    font-weight: bold;
    padding-bottom: 18px;
}

.main-bottom-title-2 {
    /*padding-bottom: 1px;*/
    border-bottom: 1px solid #FFFFBB;
}

.main-bottom-list {
    color: white;
    font-size: 12px;
    line-height: 25px;
}

.main-bottom-list li {
    padding-left: 10px;
}

a.main-bottom-list-link {
    text-decoration: none;
}

a.main-bottom-list-link:hover {
    color: #FFFFBB;
    text-decoration: underline;
}

a.main-bottom-list-mail {
    text-decoration: underline;
}

a.main-bottom-list-mail:hover {
    color: #FFFFBB;
    text-decoration: none;
}

.main-bottom-list-row {
}

.main-dop {
    color: #aaa;
}

.main-dop-2 {
    padding-top: 10px;
    line-height: 12px;
}

.main-copyrights-1 {
    float: left;
    color: #777;
    font-size: 13px;
}

.main-copyrights-2 {
    float: right;
    color: #777;
    font-size: 13px;
}

a.dlogic {
    font-weight: bold;
    text-decoration: none;
}

a.dlogic:hover {
    color: white;
}

/* ///////////////////////////////// inner ///////////////////////////////// */


.inner-top-block-1 {
    min-height: 415px;
    position: relative;
    background: url(/pics/inner_top_photo_1.jpg) no-repeat bottom center;
    background-size: cover;
}

.inner-top-block-2 {
    min-height: 415px;
    position: relative;
    background: url(/pics/inner_top_photo_2-3.jpg) no-repeat bottom center;
    background-size: cover;
}

.inner-top-block-3 {
    min-height: 415px;
    position: relative;
    background: url(/pics/inner_top_photo_3-2.jpg) no-repeat bottom center;
    background-size: cover;
}

.inner-top-block-4 {
    min-height: 415px;
    position: relative;
    background: url(/pics/inner_top_photo_4.jpg) no-repeat bottom center;
    background-size: cover;
}

.inner-top-line-1 {
    height: 3px;
    z-index: 15;
    background-color: #61759A;
}

.inner-top-block-line-2 {
    width: 100%;
    position: absolute;
    bottom: 10px;
    background: url(/pics/inner-top-fon-1.png) repeat center;
    font-size: 30px;
    font-family: 'Noto Sans', Arial, Verdana, sans-serif;
    letter-spacing: 1px;
    font-style: italic;
    text-align: right;
}

.inner-top-block-line-3 {
    padding-right: 30px;
}

.inner-brcr {
    font-size: 11px;
    color: #aaa;
}

a.inner-brcr-link {
    color: black;
    text-decoration: none;
}

a.inner-brcr-link:hover {
    color: brown;
    text-decoration: none;
}

.inner-info-block {
    padding-right: 30px;
    min-height: 100px;
}

.inner-line {
    height: 4px;
    background: url(/pics/inner-line.png) repeat;
}

.inner-info-block-text {
    font-size: 12px;
    color: #444;
    line-height: 1.7em;
}

.inner-text-justify {
    text-align: justify;
}

.inner-text-gap {
    height: 8px;
}

.inner-list li {
    padding-left: 10px;
}

.inner-owl-item-row, .inner-button-row {
    text-align: center;
}

.inner-owl-item {
    height: 240px;
    width: 355px;
    overflow: hidden;
    border: 1px solid #ccc;
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    display: inline-block;
    cursor: pointer;
}

.inner-owl-item-biger {
    height: 260px;
    width: 410px;
    overflow: hidden;
    border: 1px solid #ccc;
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    display: inline-block;
    cursor: pointer;
}

.inner-button-1 {
    display: inline-block;
    width: 210px;
    background-color: #eee;
    border-top: 1px solid #aaa;
    border-right: 4px solid red;
    border-bottom: 1px solid #aaa;
    border-left: 1px solid #aaa;
    padding: 5px 10px;
    margin: 8px 8px;
    font-size: 14px;
    text-decoration: none;
}

.inner-button-2 {
    display: inline-block;
    width: 210px;
    background-color: #eee;
    border-top: 1px solid #aaa;
    border-right: 4px solid #007FFF;
    border-bottom: 1px solid #aaa;
    border-left: 1px solid #aaa;
    padding: 5px 10px;
    margin: 8px 8px;
    font-size: 14px;
    text-decoration: none;
}

.inner-button-3 {
    display: inline-block;
    width: 210px;
    background-color: #eee;
    border-top: 1px solid #aaa;
    border-right: 4px solid #4CAF50;
    border-bottom: 1px solid #aaa;
    border-left: 1px solid #aaa;
    padding: 5px 10px;
    margin: 8px 8px;
    font-size: 14px;
    text-decoration: none;
}

.inner-after-info-block {
    height: 60px;
    background: url(/pics/white_logo.png) no-repeat right bottom;
}

.inner-after-info-block-line {
    height: 8px;
    background: url(/pics/inner-line-2.png) repeat;
}

.inner-panel {
    -webkit-box-shadow: 2px 3px 6px #afafaf;
    box-shadow: 2px 3px 6px #afafaf;
    border-top: 1px solid white!important;
    border-right: 1px solid white!important;
    border-bottom: 1px solid white!important;
    background-color: #e5e5e5;
    padding-left: 30px;
}

.inner-table-cell-1 {
    background-color: #bfd7c9 !important;
    border: 1px solid #fff !important;
}

.inner-table-cell-2 {
    background-color: #bee0e6 !important;
    border: 1px solid #fff !important;
}

.inner-submenu-item {
    cursor: pointer;
    border: 1px solid #333;
    /*-moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;*/
    transform: scale(1);
    transition: 0.3s;
}

.inner-submenu-item:hover {
    transform: scale(1.03);
}

.inner-submenu-bass-title {
    text-align: center;
    font-size: 12px;
    font-weight: bold;
}

.inner-submenu-bass-photo-1 {
    height: 150px;
    background: url(/photos/2-dlya-basseynov/buss1.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-bass-photo-2 {
    height: 150px;
    background: url(/photos/2-dlya-basseynov/buss2.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-bass-photo-3 {
    height: 150px;
    background: url(/photos/2-dlya-basseynov/buss3.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-bass-photo-4 {
    height: 150px;
    background: url(/photos/2-dlya-basseynov/buss4.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-title {
    text-align: center;
    font-size: 13px;
    font-weight: bold;
    height: 60px;
    display: flex;
}

.inner-decor-tit {
    margin: auto;
}

.inner-submenu-decor-photo-1 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor1.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-2 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor2.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-3 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor3.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-4 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor4.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-5 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor5.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-6 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor6.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-7 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor7.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-8 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor8.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-decor-photo-9 {
    height: 150px;
    background: url(/photos/3-fasadnyi-decor/decor9.jpg) no-repeat center;
    background-size: cover;
}

a.inner-decor-link {
    color: #003399;
    text-decoration: underline;
    font-weight: bold;
}

a.inner-decor-link:hover {
    color: #992b35;
    text-decoration: none;
}

.inner-submenu-fasad-title {
    text-align: center;
    font-size: 13px;
    font-weight: bold;
    height: 60px;
    display: flex;
}

.inner-submenu-fasad-photo-1 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad1.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-2 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad2.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-3 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad3.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-4 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad4.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-5 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad5.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-6 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad6.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-7 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad7.jpg) no-repeat center;
    background-size: cover;
}

.inner-submenu-fasad-photo-8 {
    height: 150px;
    background: url(/photos/4-uteplenie-fasadov/fasad8.jpg) no-repeat center;
    background-size: cover;
}

.feedback-top-block {
    min-height: 415px;
    position: relative;
    background: url(/pics/feedback-1.jpg) no-repeat bottom center;
    background-size: cover;
}

.feedback-info {
    font-size: 14px;
}

.feedback-title {
    font-size: 26px;
    font-family: /*BebasNueBold, BravoRG,*/ 'Noto Sans', Arial, Verdana, sans-serif;
    letter-spacing: 1px;
    /*text-transform: uppercase;*/
    font-style: italic;
    color: #7b24ae;
}

.about-company {
    text-align: right;
}

.feedback-map {
    height: 500px;
    width: 100%;
}

.feedback-map-title {
    font-weight: bold;
    /*text-decoration: underline;*/
    border-bottom: 1px solid purple;
}

.feedback-gps {
    font-size: 12px;
    text-align: right;
}

.feedback-gps span {
    color: #aaa;
}

.inner_feedback_mail {
    font-size: 14px;
    text-decoration: underline;
}

.inner_feedback_mail:hover {
    color: red;
    text-decoration: none;
}

.inner_search {
    height: 26px;
    width: 50%;
    border: 1px dashed #2196F3;
    border-radius: 5px;
    padding-left: 10px;
    padding-right: 10px;

    color: #686868;
    background-color: transparent;
    font-family: Verdana, Arial, sans-serif;
    font-size: 12px;
}

.search_result {
    color: #507aa9;
    text-decoration: none;
}

.search_result:hover {
    color: #7b1cb3;
    text-decoration: underline;
}

.search_result_row {
    width: 50%;
}

.top_search_line {
    padding-bottom: 10px;
}

.top_search {
    height: 25px;
    width: 250px;
    border: 1px dotted #555;
    border-radius: 5px;
    padding-left: 10px;
    padding-right: 10px;
    margin-right: 10px;

    color: #000000;
    background-color: transparent;
    font-family: Verdana, Arial, sans-serif;
    font-size: 12px;
    transition: all 0.3s linear;
}

.top_search:hover, .top_search:focus {
    border: 1px solid #555;
    background-color: #f3f3f3;
}

.top_search_butt {
    height: 25px;
    color: #000000;
    padding: 1px 30px 1px 1px;
    background-color: transparent!important;
}

.top_search_butt:hover {
    height: 25px;
    color: blue!important;
    background-color: transparent!important;
}

#id02 {
    z-index: 20;
}

.modal_top_search {
    height: 26px;
    width: 70%;
    border: 1px dashed #2196F3;
    border-radius: 5px;
    padding-left: 10px;
    padding-right: 10px;

    color: #686868;
    background-color: transparent;
    font-family: Verdana, Arial, sans-serif;
    font-size: 12px;
}

.map_info {
    color: #7b1cb3;
    font-size: 15px;
    font-weight: bold;
}









/*------------------------- overlay menu ------------------------*/

.overlay {
    height: 0%;
    width: 100%;
    position: fixed;
    z-index: 20;
    top: 0;
    left: 0;
    background-color: rgb(0,0,0);
    background-color: rgba(0,0,0, 0.9);
    overflow-y: hidden;
    transition: 0.5s;
}

.overlay-content {
    position: relative;
    /*top: 25%;*/
    top: 15%;
    width: 100%;
    text-align: center;
    margin-top: 30px;
}

.overlay a {
    padding: 8px;
    text-decoration: none;
    font-size: 24px;
    color: #818181;
    display: block;
    transition: 0.3s;
}

.overlay a:hover, .overlay a:focus {
    color: #f1f1f1;
}

.overlay .closebtn {
    position: absolute;
    top: 20px;
    right: 45px;
    font-size: 60px;
}

@media screen and (max-height: 450px) {
    .overlay {overflow-y: auto;}
    .overlay a {font-size: 20px}
    .overlay .closebtn {
        font-size: 40px;
        top: 15px;
        right: 35px;
    }
}

/*------------------------- #overlay menu ------------------------*/



/* ---- for testing ---- */
.visible {
    border: 1px dashed #d3d3d3;
    background-color: #eaeaea;
}



@media all and (min-width: 1300px) {

    .main-services-block-1 {
        padding-left: 5%;
    }

    .main-services-block-2 {
        padding-right: 5%;
    }

    .main-services-block-3 {
        padding-left: 5%;
    }

    .main-services-block-4 {
        padding-right: 5%;
    }

    .left-right-flex-pad, .left-right-flex-pad-top, .left-right-flex-pad-bottom {
        width: 1280px;
        margin: auto;
    }
}

@media all and (min-width: 993px) and (max-width: 1300px) {

    .main-service-block {
        min-height: 280px;
    }
}

@media all and  (max-width: 992px) {

    .main-top-phone {
        width: 40%;
    }

    .main-service-block {
        min-height: 230px;
    }

    .main-service-block_2 {
        min-height: 230px;
    }

    .main-bottom-list ul {
        padding-left: 10px;
    }

    .main-copyrights {
        display: flex;
        flex-direction: column-reverse;
    }

    .main-copyrights-1 {
        float: none;
        text-align: center;
    }

    .main-copyrights-2 {
        float: none;
        text-align: center;
    }

    .inner-info-block {
        padding-right: 16px;
    }

    .about-company {
        text-align: center;
    }

    .feedback-top-block {
        background: url(/pics/feedback-1m.jpg) no-repeat left center;
    }

    .top_search_butt {
        padding: 1px 20px 1px 1px;
    }

}

/* -------------------------------- details ------------------------------------ */

@media all and (min-width: 768px) and (max-width: 992px) {

    .bottom-menu-block {
        min-height: 240px;
    }

    .main-services-block-3 {
        padding-bottom: 24px;
    }

    .main-services-block-4 {
        padding-top: 0;
    }

    .inner_search {
        width: 75%;
    }

    .search_result_row {
        width: 75%;
    }
}


@media all and (min-width: 480px) and (max-width: 768px) {

    .bottom-menu-block {
        min-height: 280px;
    }

    .main-services-block-3 {
        padding-bottom: 24px;
    }

    .main-services-block-4 {
        padding-top: 0;
    }

    .inner_search {
        width: 75%;
    }

    .search_result_row {
        width: 100%;
    }
}


@media all and (min-width: 480px) and (max-width: 600px) {

    .bottom-menu-block {
        min-height: 100px;
        border-left: 0 dashed #777;
    }

    .inner_search {
        width: 80%;
    }

    .search_result_row {
        width: 100%;
    }
}

@media all and (max-width: 480px) {
    
    .bottom-menu-block {
        min-height: 230px;
        border-left: 0 dashed #777;
    }

    .main-services-block-3 {
        padding-bottom: 24px;
    }

    .main-services-block-4 {
        padding-top: 0;
    }

    .inner-owl-item, .inner-owl-item-biger {
        width: 90%;
        height: auto;
    }

    .inner_search {
        width: 70%;
    }

    .search_result_row {
        width: 100%;
    }
}