/*! Generated by Font Squirrel (https://www.fontsquirrel.com) on June 16, 2017 */
@font-face {
    font-family: 'Geometria';
    src: url("../fonts/geometria.eot");
    src: url("../fonts/geometria.eot?#iefix") format("embedded-opentype"), url("../fonts/geometria.woff2") format("woff2"), url("../fonts/geometria.woff") format("woff"), url("../fonts/geometria.ttf") format("truetype");
    font-weight: 400;
    font-style: normal; }

@font-face {
    font-family: 'Geometria';
    src: url("../fonts/geometria-bold.eot");
    src: url("../fonts/geometria-bold.eot?#iefix") format("embedded-opentype"), url("../fonts/geometria-bold.woff2") format("woff2"), url("../fonts/geometria-bold.woff") format("woff"), url("../fonts/geometria-bold.ttf") format("truetype");
    font-weight: 700;
    font-style: normal; }

@font-face {
    font-family: 'Geometria';
    src: url("../fonts/geometria-extablack.eot");
    src: url("../fonts/geometria-extablack.eot?#iefix") format("embedded-opentype"), url("../fonts/geometria-extablack.woff2") format("woff2"), url("../fonts/geometria-extablack.woff") format("woff"), url("../fonts/geometria-extablack.ttf") format("truetype");
    font-weight: 800;
    font-style: normal; }

@font-face {
    font-family: 'Geometria';
    src: url("../fonts/geometria-heavy.eot");
    src: url("../fonts/geometria-heavy.eot?#iefix") format("embedded-opentype"), url("../fonts/geometria-heavy.woff2") format("woff2"), url("../fonts/geometria-heavy.woff") format("woff"), url("../fonts/geometria-heavy.ttf") format("truetype");
    font-weight: 600;
    font-style: normal; }

@font-face {
    font-family: 'Geometria';
    src: url("../fonts/geometria-medium.eot");
    src: url("../fonts/geometria-medium.eot?#iefix") format("embedded-opentype"), url("../fonts/geometria-medium.woff2") format("woff2"), url("../fonts/geometria-medium.woff") format("woff"), url("../fonts/geometria-medium.ttf") format("truetype");
    font-weight: 500;
    font-style: normal; }

input::-webkit-input-placeholder {
    color: #666; }

input::-moz-placeholder {
    color: #666; }

/* Firefox 19+ */
input:-moz-placeholder {
    color: #666; }

/* Firefox 18- */
input:-ms-input-placeholder {
    color: #666; }

body {
    font-family: 'Geometria', sans-serif;
    font-size: 16px;
    line-height: 1.2em;
    color: #000;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-text-size-adjust: 100%;
    background: #fff; }

header {
    min-height: 1280px;
    background: url("../images/bg-header.jpg") no-repeat center;
    background-size: cover;
    padding-top: 120px; }
header .top_header {
    position: absolute;
    width: 100%;
    min-height: 120px;
    top: 0;
    left: 0;
    background: rgba(255, 255, 255, 0.9);
    padding-bottom: 20px;
    z-index: 2; }
header .top_header .logo {
    margin-top: 30px; }
header .top_header .colapse-menu-button {
    position: absolute;
    right: 0;
    top: 40px;
    display: none;
    z-index: 10; }
header .top_header nav {
    text-align: right;
    margin-top: 44px; }
header .top_header nav .menu {
    padding: 0;
    margin: 0; }
header .top_header nav .menu li {
    display: inline-block; }
header .top_header nav .menu li:first-child a {
    margin-left: 0; }
header .top_header nav .menu li:last-child a {
    margin-right: 0; }
header .top_header nav .menu li a {
    font-size: 18px;
    font-weight: 500;
    color: #030303;
    text-decoration: none;
    margin: 0 22px; }
header .top_header nav .menu li a:hover {
    color: #202d61;
    text-decoration: underline; }
header .block_title {
    position: relative;
    min-height: 810px;
    padding-top: 330px;
    padding-bottom: 20px; }
header .block_title .shadow {
    position: absolute;
    top: 0;
    height: 170px;
    width: 100%;
    background: url("../images/shadow.png") repeat-x center; }
header .block_title .title h1 {
    font-size: 55px;
    line-height: 1.2em;
    font-weight: 800;
    color: #fff;
    text-transform: uppercase;
    text-shadow: 3.8px 3.2px 10px rgba(0, 0, 0, 0.25);
    margin: 0; }
header .block_title .title h1 span {
    font-size: 80px; }
header .block_title .title p {
    font-size: 27px;
    line-height: 1.5em;
    font-weight: 400;
    color: #fff;
    margin-bottom: 0;
    margin-top: 20px; }
header .block_title .wrap_btn {
    text-align: center;
    margin-top: 72px; }
header .block_title .wrap_btn a {
    display: inline-block;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: 3px solid #fff;
    font-size: 30px;
    line-height: 60px;
    color: #fff;
    text-decoration: none; }
header .block_title .wrap_btn a:hover {
    opacity: 0.8; }
header .services {
    min-height: 350px;
    background: rgba(17, 28, 62, 0.8);
    padding-bottom: 20px; }
header .services .title {
    text-align: center;
    margin: 39px 0; }
header .services .title h2 {
    color: #fff;
    font-size: 40px;
    font-weight: 500;
    margin: 0; }
header .services .wrap_services {
    text-align: center; }
header .services .wrap_services .icon {
    margin-bottom: 17px; }
header .services .wrap_services p {
    font-size: 16px;
    line-height: 1.2em;
    font-weight: 500;
    color: #fff; }

.about {
    min-height: 547px;
    background: #fff url("../images/bg-about.jpg") no-repeat center bottom;
    padding-top: 55px;
    padding-bottom: 30px; }
.about .title {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    margin: -4px 0 16px; }
.about .title h2 {
    display: block;
    font-size: 40px;
    font-weight: 500;
    color: #333;
    margin: 0 35px 0 0;
    -webkit-flex-shrink: 0;
    -ms-flex-negative: 0;
    flex-shrink: 0; }
.about .title h2 span {
    opacity: 0; }
.about .title hr {
    width: 100%;
    height: 3px;
    background: rgba(0, 0, 0, 0.2);
    margin: 0;
    border: none; }
.about .about_block img {
    display: inline-block;
    float: left;
    margin-right: 15px;
    margin-bottom: 5px;
    margin-top: 5px; }
.about .about_block p {
    font-size: 16px;
    font-weight: 400;
    line-height: 21px;
    margin-bottom: 5px; }
.about .about_block a {
    display: inline-block;
    width: 178px;
    height: 45px;
    background-color: #ffffff;
    border: solid 1px #202d61;
    font-size: 14px;
    line-height: 45px;
    font-weight: 500;
    text-transform: uppercase;
    color: #222f62;
    text-align: center;
    text-decoration: none;
    margin-top: 10px; }
.about .about_block a:hover {
    color: #fff;
    background: #222f62; }
.about .forma {
    text-align: center;
    max-width: 445px;
    min-height: 411px;
    background: #3c4872 url("../images/mail.jpg") no-repeat center bottom;
    padding-bottom: 50px; }
.about .forma h5 {
    display: inline-block;
    font-size: 30px;
    font-weight: 500;
    color: #fff;
    margin: 25px 0 18px;
    border-bottom: 3px solid rgba(255, 255, 255, 0.2);
    padding-bottom: 10px; }
.about .forma form input {
    width: 235px;
    height: 36px;
    background-color: #ffffff;
    border: none;
    margin-bottom: 4px;
    padding-left: 15px;
    font-size: 14px;
    font-weight: 400;
    color: #666;
    outline: none; }
.about .forma form div {
    text-align: left;
    display: inline-block;
    width: 235px;
    margin: 5px 0 20px; }
.about .forma form label {
    width: 100%;
    position: relative;
    text-align: left;
    margin: 0;
    padding-left: 30px; }
.about .forma form label span {
    position: relative;
    display: inline-block;
    font-size: 14px;
    font-weight: 400;
    color: #7589d9;
    text-decoration: underline;
    cursor: pointer; }
.about .forma form label span:after {
    position: absolute;
    top: 50%;
    margin-top: -10px;
    left: -30px;
    content: url("../images/load-icon.png"); }
.about .forma form label div.delete {
    color: red;
    float: right;
    margin: 0;
    width: 10px;
    display: none;
    cursor: pointer;
}
.about .forma form input[type=file] {
    display: none; }
.about .forma form button {
    width: 235px;
    height: 45px;
    background-color: #7589d9;
    border: none;
    font-family: 'Rubik';
    text-transform: uppercase;
    font-size: 18px;
    color: #fff;
    outline: none; }
.about .forma form button:hover {
    background: #6178d3; }

.path {
    min-height: 520px;
    background: url("../images/bg-path.jpg") no-repeat center;
    background-size: cover;
    padding: 20px 0; }
.path .wrap_path {
    background: url("../images/path.png") no-repeat center top 38px;
    padding-top: 80px;
    background-size: 100%; }
.path .wrap_path .path_step {
    position: relative;
    text-align: center;
    min-height: 160px; }
.path .wrap_path .path_step p {
    font-size: 18px;
    font-weight: 700;
    color: #afcdff;
    margin-bottom: 0; }
.path .wrap_path .path_step.mh {
    min-height: auto; }
.path .wrap_path .path_step.big_block {
    width: 380px; }
.path .wrap_path .path_step.s1 {
    margin-left: -70px; }
.path .wrap_path .path_step.s2 {
    margin-left: -70px; }
.path .wrap_path .path_step.s3 {
    margin-left: -35px; }
.path .wrap_path .path_step.s4 {
    margin-left: -70px; }
.path .wrap_path .path_step.s5 {
    margin-left: -75px; }
.path .wrap_path .path_step.s6 {
    margin-left: -35px; }
.path .wrap_path .path_step.s7 {
    margin-left: -70px; }
.path .wrap_path .path_step.s8 {
    margin-left: -75px; }
.path .wrap_path .path_step.s9 {
    margin-left: -35px; }

.offer {
    min-height: 1150px;
    padding-top: 45px; }
.offer .title {
    text-align: center;
    position: relative;
    margin-bottom: 35px; }
.offer .title:after {
    position: absolute;
    width: 100%;
    height: 3px;
    top: 50%;
    margin-top: -1px;
    left: 0;
    background: rgba(0, 0, 0, 0.2);
    content: ''; }
.offer .title h2 {
    position: relative;
    z-index: 2;
    display: inline-block;
    margin: 0;
    padding: 0 20px;
    background: #fff;
    font-size: 40px;
    font-weight: 500;
    color: #333; }
.offer .wrap_offer .our_offer {
    min-height: 195px;
    text-align: center; }
.offer .wrap_offer .our_offer p {
    font-family: 'Rubik';
    font-size: 14px;
    line-height: 22px;
    font-weight: 700;
    color: #333;
    margin-bottom: 0;
    margin-top: 10px; }
.offer .wrap_offer .wrap_btn {
    text-align: right;
    margin-top: 50px; }
.offer .wrap_offer .wrap_btn a {
    text-align: center;
    display: inline-block;
    width: 378px;
    height: 76px;
    border-radius: 20px;
    background-color: #7589d9;
    font-family: 'Rubik';
    font-weight: 700;
    font-size: 30px;
    text-transform: uppercase;
    line-height: 76px;
    color: #fff;
    text-decoration: none; }
.offer .wrap_offer .wrap_btn a:hover {
    background: #6178d3; }

.cost_block {
    padding-top: 50px;
    padding-bottom: 50px;
    display: none; }
.cost_block .title {
    position: relative;
    text-align: center; }
.cost_block .title:after {
    position: absolute;
    top: 50%;
    margin-top: -1px;
    left: 0;
    width: 100%;
    height: 3px;
    background: rgba(0, 0, 0, 0.2);
    content: ''; }
.cost_block .title h2 {
    position: relative;
    display: inline-block;
    font-size: 40px;
    font-weight: 700;
    color: #333;
    padding: 0px 15px;
    background: #fff;
    margin: 0;
    z-index: 2; }
.cost_block .wrapper {
    padding: 0px 0px 0px 30px; }
.cost_block .wrapper table {
    width: 100%;
    margin: 50px 0 30px; }
.cost_block .wrapper table tr td {
    vertical-align: top;
    padding: 7px 0;
    border-bottom: 1px solid #cecece;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.2em;
    color: #333; }
.cost_block .wrapper table tr td:last-child {
    width: 100px;
    text-align: right; }

.map {
    position: relative;
    min-height: 500px;
    padding: 50px 0 40px; }
.map .container {
    pointer-events: none; }
.map #map {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #161f3e;
    -webkit-box-shadow: inset 0 0 70px 0 rgba(0, 0, 0, 0.7);
    box-shadow: inset 0 0 70px 0 rgba(0, 0, 0, 0.7); }
.map #map #mapkit-3937 {
    width: 100%;
    height: 100%;
    opacity: 0.5; }
.map #map:after {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    -webkit-box-shadow: inset 0 0 70px 0 rgba(0, 0, 0, 0.7);
    box-shadow: inset 0 0 70px 0 rgba(0, 0, 0, 0.7);
    content: '';
    pointer-events: none; }
.map .contacts {
    display: inline-block;
    text-align: center;
    width: 350px;
    height: 350px;
    background-color: rgba(28, 37, 67, 0.7);
    -webkit-box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.3);
    box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.3);
    padding: 0 50px;
    pointer-events: auto; }
.map .contacts h5 {
    display: inline-block;
    font-size: 30px;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
    margin: 30px 0 40px;
    border-bottom: 3px solid rgba(255, 255, 255, 0.2);
    padding-bottom: 10px; }
.map .contacts .address {
    text-align: left;
    margin-bottom: 20px; }
.map .contacts .address p {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
    margin-bottom: 0; }
.map .contacts .phones {
    text-align: left;
    margin-bottom: 20px; }
.map .contacts .phones p {
    font-size: 16px;
    line-height: 23px;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
    margin-bottom: 0; }
.map .contacts .phones p a {
    display: inline-block;
    color: #fff;
    background: none;
    text-decoration: none; }
.map .contacts .call {
    display: inline-block;
    width: 100%;
    height: 45px;
    background-color: #7589d9;
    border: none;
    font-family: 'Rubik';
    text-transform: uppercase;
    font-size: 18px;
    line-height: 45px;
    color: #fff;
    outline: none;
    text-decoration: none; }
.map .contacts .call:hover {
    background: #6178d3; }
.map .forma {
    display: inline-block;
    float: right;
    text-align: center;
    width: 445px;
    min-height: 411px;
    background: #3c4872 url("../images/mail.jpg") no-repeat center bottom;
    pointer-events: auto;
    padding-bottom: 50px; }
.map .forma h5 {
    display: inline-block;
    font-size: 30px;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
    margin: 25px 0 18px;
    border-bottom: 3px solid rgba(255, 255, 255, 0.2);
    padding-bottom: 10px; }
.map .forma form input {
    width: 235px;
    height: 36px;
    background-color: #ffffff;
    border: none;
    margin-bottom: 4px;
    padding-left: 15px;
    font-size: 14px;
    font-weight: 400;
    color: #666;
    outline: none; }
.map .forma form div {
    text-align: left;
    display: inline-block;
    width: 235px;
    margin: 5px 0 20px; }
.map .forma form label {
    width: 100%;
    position: relative;
    text-align: left;
    margin: 0;
    padding-left: 30px; }
.map .forma form label span {
    position: relative;
    display: inline-block;
    font-size: 14px;
    font-weight: 400;
    color: #7589d9;
    text-decoration: underline;
    cursor: pointer; }
.map .forma form label span:after {
    position: absolute;
    top: 50%;
    margin-top: -10px;
    left: -30px;
    content: url("../images/load-icon.png"); }
.map .forma form label div.delete {
    color: red;
    float: right;
    margin: 0;
    width: 10px;
    display: none;
    cursor: pointer;
}
.map .forma form input[type=file] {
    display: none; }
.map .forma form button {
    width: 235px;
    height: 45px;
    background-color: #7589d9;
    border: none;
    font-family: 'Rubik';
    text-transform: uppercase;
    font-size: 18px;
    color: #fff;
    outline: none; }
.map .forma form button:hover {
    background: #6178d3; }

footer {
    min-height: 100px;
    background-color: #1a2342;
    border: solid 1px #000000;
    padding: 20px 0; }
footer .wrap_logo_copy {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: 10px; }
footer .wrap_logo_copy .logo {
    margin-right: 25px; }
footer .wrap_logo_copy p {
    font-family: 'Rubik';
    font-size: 14px;
    font-weight: 400;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 0; }
footer .social {
    text-align: right;
    margin-top: 20px; }
footer .social ul {
    margin: 0;
    padding: 0; }
footer .social ul li {
    display: inline-block; }
footer .social ul li a {
    font-size: 18px;
    color: #fff;
    text-decoration: none;
    margin: 0 0 0 13px; }
footer .social ul li a:hover {
    opacity: 0.8; }

#more {
    display: none; }
#more .wrapper {
    padding: 0 10px; }
#more .wrapper h3 {
    text-align: center;
    font-size: 30px;
    font-weight: 700;
    margin: 0 0 30px; }
#more .wrapper .text {
    position: relative; }
#more .wrapper .text img {
    display: inline-block;
    float: left;
    margin: 0 20px 5px 0; }
#more .wrapper .text p {
    font-size: 16px;
    font-weight: 400;
    line-height: 21px; }

#call, #callprice {
    display: none; }
#call .forma,#callprice .forma {
    display: inline-block;
    float: right;
    text-align: center;
    width: 445px;
    min-height: 411px;
    background: #3c4872 url("../images/mail.jpg") no-repeat center bottom;
    pointer-events: auto;
    padding-bottom: 50px; }
#call .forma h5,#callprice .forma h5 {
    display: inline-block;
    font-size: 30px;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
    margin: 35px 0 45px;
    border-bottom: 3px solid rgba(255, 255, 255, 0.2);
    padding-bottom: 10px; }
#call .forma form input,    #callprice .forma form input {
    width: 235px;
    height: 36px;
    background-color: #ffffff;
    border: none;
    margin-bottom: 4px;
    padding-left: 15px;
    font-size: 14px;
    font-weight: 400;
    color: #666;
    outline: none; }
#call .forma form button,     #callprice .forma form button {
    width: 235px;
    height: 45px;
    background-color: #7589d9;
    border: none;
    font-family: 'Rubik';
    text-transform: uppercase;
    font-size: 18px;
    color: #fff;
    outline: none;
    margin-top: 40px; }
#call .forma form button:hover,      #callprice .forma form button:hover {
    background: #6178d3; }

.clasicStyle .fancybox-skin {
    padding: 25px !important; }

.mailStyle .fancybox-skin {
    padding: 0 !important; }

#success {
    padding: 100px 40px 0 40px;
} 

#success h4 {
    color: #fff;
    font-size: 40px;
    font-weight: 500;
    margin: 0;
}
#success h5 {
    color: #fff;
    font-size: 25px;
    font-weight: 500;
    margin: 0;
}
#re_request, #re_request2, #re_request3 {
	margin:0!important;
}
.forma form textarea {
	width: 235px;
	height: 85px;
	background-color: #ffffff;
	border: none;
	margin-bottom: 4px;
	padding-left: 15px;
	font-size: 14px;
	font-weight: 400;
	color: #666;
	outline: none;
}