@charset "utf-8";
/* CSS Document */
html {
  color: #000;
  background: #FFF;
}
html, body {
  width: 100%;
  font-family: 'Rubik', 'Roboto', 'Tahoma', sans-serif;
  /*    color: #efefef;*/
  font-size: 21px;
  background-color: #2c3647;
  font-weight: 300;
  color: #e2deec;
  overflow-x: hidden;
}
html, body, ul, ol, li, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, select, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
fieldset, img {
  border: 0;
}
address, caption, cite, code, dfn, em, th, var, optgroup {
  font-style: inherit;
  font-weight: inherit;
}
del, ins {
  text-decoration: none;
}
li {
  list-style: none;
}
caption, th {
  text-align: left;
}
h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  text-align: left;
}
div, h1, h2, h3, h4, h5, h6 {
  box-sizing: border-box
}
.hidden {
  display: none;
}
.clearfix {
  *zoom: 1;
}
.clearfix:before, .clearfix:after {
  display: table;
  line-height: 0;
  content: "";
}
.clearfix:after {
  clear: both;
}
.text-left {
  text-align: left
}
.text-right {
  text-align: right
}
.text-center {
  text-align: center
}
input, button, textarea, select, optgroup, option {
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
}
input, button, textarea, select {
  font-size: 100%;
}
button:focus {
  outline: none !important;
}
input:focus {
  outline: none !important;
  border-bottom: 1px solid #fff !important;
}
select:focus {
  outline: none !important;
}
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 50px #2c3647 inset !important;
  -webkit-text-fill-color: #fff !important;
  font-size: 21px !important;
}
input:-internal-autofill-previewed {
  -webkit-font-size: 1rem !important;
  font-size: 21px !important;
}
p {
  font-size: 1rem;
  line-height: 1.3rem;
  font-weight: 300;
  padding: 1rem 2rem;
}
.bbox p {
  padding: 1%
}
h1 {
  font-size: 3rem;
  font-weight: normal;
  padding: 1% 2rem;
  text-align: center;
  text-transform: uppercase;
  color: #fff;
  margin: 10vh 0;
}
.bbox h2 {
  font-size: 1rem;
  padding: 10px 1%;
  margin: 0;
}
h2 {
  font-size: 1.5rem;
  /*  line-height: 1.2rem;*/
  font-weight: 500;
  padding: 3rem 2rem 1rem;
}
h2.ordhead1 {
  font-size: 2.2rem;
  font-weight: 500;
  max-width: 1000px;
}
.loader {
  padding-top: 30%;
}
.loader h2 {
  margin: auto;
  text-align: center;
  opacity: 0.5;
}
h3 {
  font-size: 2rem;
  font-weight: normal;
  padding: 2rem;
}
strong, b {
  font-weight: normal;
}
a {
  color: #efefef;
}
a:hover {
  color: #fff;
}
.no-br {
  white-space: nowrap;
}
ul, ol {
  /*  font-size: 1.2rem;*/
  /*  padding: 0.5% 4vw;*/
  padding: 1rem 2rem 1rem 3rem;
}
ol.lx li {
  list-style: outside decimal;
}
ul.lx li:before {
  content: "—";
  position: relative;
  left: -14px;
  padding-right: 0;
  margin-left: -15px;
  text-align: left;
}
.textbox1 ul {
  font-size: 1.2em;
}
li {
  padding: 0 0 1rem 0;
  list-style-position: outside;
  text-indent: -20px;
}
.back {
  background-size: cover;
  position: absolute;
  z-index: 1;
  height: 100vh;
  width: 100%;
  overflow: hidden;
}
.b1 {
  background: url("img/khoroshevskoe.jpg") no-repeat center top fixed;
}
.b2 {
  background: url("img/spbche.jpg") no-repeat center top fixed;
}
.b3 {
  background: url("img/luber.jpg") no-repeat center top fixed;
}
.b4 {
  background: url("img/oneback4.jpg") no-repeat center top fixed;
}
.vinet {
  position: absolute;
  height: 100vh;
  width: 100%;
  z-index: 2;
  background: linear-gradient(0deg, rgba(44, 54, 71, 1) 0%, rgba(44, 54, 71, 0) 100%);
  overflow: hidden;
}
.noisex {
  animation: nis 40s ease-in-out 0s infinite alternate;
  padding-top: 3rem;
}
@keyframes nis {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-500px);
  }
}
.flash {
  animation: nisflash 40s ease-in-out 3s infinite alternate;
}
@keyframes nisflash {
  0%, 1%, 1.1%, 23%, 23.1%, 25%, 25.1%, 28%, 28.1%, 45%, 45.1%, 46%, 46.1%, 55%, 55.1%, 57%, 57.1%, 60%, 60.1%, 62%, 62.1%, 72%, 72.1%, 75%, 75.1%, 80%, 80.1%, 85%, 85.1%, 90%, 90.1%, 95%, 95.1%, 95.08%, 1.3%, 1.3%, 23%, 23.3%, 25%, 25.3%, 28%, 28.3%, 45%, 45.3%, 46%, 46.3%, 55%, 55.3%, 57%, 57.3%, 60%, 60.3%, 62%, 62.3%, 72%, 72.13%, 75%, 75.3%, 80%, 80.3%, 85%, 85.3%, 90%, 90.3%, 95%, 95.3%, 96.08% {
    opacity: .5;
    transform: scaleY(1);
    transform: translateY(-1px);
  }
  0.5%, 1.05%, 23.05%, 25.05%, 28.05%, 45.05%, 46.05%, 55.05%, 57.05%, 60.05%, 62.05%, 72.05%, 75.05%, 80.05%, 85.05%, 90.05%, 95.05%, 0.6%, 1.2%, 23.05%, 25.2%, 28.2%, 45.2%, 46.2%, 55.2%, 57.2%, 60.2%, 62.2%, 72.2%, 75.2%, 80.2%, 85.2%, 90.2%, 95.2% {
    opacity: 1;
    transform: scaleY(0.9);
    transform: translateY(0px);
  }
}
.mn0 {
  position: absolute;
  z-index: 5;
  width: 100%;
  height: 100%;
}
.mn1 {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: baseline;
  align-content: flex-start;
  background: linear-gradient(0deg, rgba(44, 54, 71, 0) 50%, rgba(44, 54, 71, .2) 100%);
  /*  padding: 0 0 2rem 0;*/
}
.mn1 div.tel, .mn1 div.prc {
  flex: 0 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: baseline;
  align-content: space-between;
  text-align: center;
  padding-top: 1rem;
}
.mn1 div.prc {
  background: url('img/buble.svg') no-repeat center;
  background-size: contain;
}
.mn1 div.prc.dark {
  background: url('img/buble_dark.svg') no-repeat center;
  background-size: contain;
}
.mn1 div.prc a, .mn1 div.tel a {
  font-size: 1rem;
  text-decoration: none;
  padding: 27px 2rem 1.7rem;
  display: block;
  min-width: 350px;
  box-sizing: border-box;
}
.mn1 div.prc.dark a, .mn1 div.tel.dark a {
  color: rgb(44 54 71);
}
.mn1 a.logo {
  display: block;
  position: relative;
  flex: 0 0 100%;
  background: url('img/logoSledizastroikoy-01.svg') no-repeat center;
  background-size: 15rem;
  height: 25rem;
  overflow: hidden;
}
.krug {
  background: url(img/krug.svg) no-repeat center;
  background-size: contain;
  position: absolute;
  width: 500px;
  height: 500px;
  margin: auto;
  top: 10px;
  left: calc(50% - 250px);
  z-index: 0;
  opacity: 0.5;
}
.krugline {
  background: url(img/krugline.svg) no-repeat center;
  background-size: contain;
  position: absolute;
  width: 520px;
  height: 520px;
  margin: auto;
  top: inherit;
  left: calc(50% - 260px);
  z-index: 0;
  opacity: 0.5;
}
.bankfav {
  background: url(img/bankfav.svg) no-repeat center;
  background-size: contain;
  position: absolute;
  width: 200px;
  height: 100px;
  margin: auto;
  top: 350px;
  left: calc(50% - 100px);
  z-index: 1;
  opacity: 0.9;
}
.noisedimbox {
  width: 100%;
  background: url(img/grphc.gif) repeat-x center;
  padding: 3vw 0;
}
.noise_bn {
  display: flex;
  max-width: 370px;
  border: solid 1px #305e80;
  border-radius: 2px;
  margin: 0 auto;
  justify-content: center;
  align-items: center;
  text-decoration: none;
}
.noise_bn:hover {
  border: solid 1px #3574a1;
}
.noise_bn .ttt {
  font-size: 1.3rem;
  text-transform: uppercase;
  color: #fff;
  font-weight: 600;
  text-align: center;
  flex: 1 0 auto;
}
div.noiseico {
  background: url(img/noiseconstructionman.jpg) no-repeat center;
  background-size: contain;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  margin: 0.5rem;
  flex: 0 0 auto;
}
.mn1 div.dinamicbox {
  /*  height: 500px;*/
  max-width: 1200px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: baseline;
  align-content: flex-start;
  text-align: center;
  overflow: hidden;
  width: 100%;
}
.mn1 div.bbox {
  /*	width: 33%;*/
  text-align: center;
}
.mn1 div.bbox h2 {
  /*	text-align: center;*/
  width: 100%;
  font-size: 0.9rem;
  letter-spacing: 1px;
}
.desk2 {
  background: url('img/1.svg') no-repeat left center;
  background-size: 90px;
  flex: 0 1 300px;
  padding: 80px 20px 80px 90px;
}
.desk3 {
  background: url('img/2.svg') no-repeat left center;
  background-size: 90px;
  flex: 0 1 250px;
  padding: 80px 20px 80px 100px;
}
.desk4 {
  background: url('img/3.svg') no-repeat left center;
  background-size: 90px;
  flex: 0 1 250px;
  padding: 80px 20px 80px 100px;
}
.desk5 {
  background: url('img/map.svg') no-repeat center top;
  background-size: 100px;
  flex: 1 1 50%;
  padding: 80px 20px 80px 20px;
  margin-top: 100px;
  cursor: pointer;
}
.desk6 {
  background: url('img/smart.svg') no-repeat center top;
  background-size: 100px;
  flex: 1 1 50%;
  padding: 80px 20px 60px 20px;
  margin-top: 100px;
  cursor: pointer;
}
.desk5 h2, .desk6 h2 {
  text-align: center
}
.topln {
  background: url('img/line.svg') no-repeat center top;
  background-size: 40vw;
}
.addrss {
  color: #95d7ed;
  background: url('img/logo_exdesign_square_white.svg') no-repeat 2rem 2.1rem;
  background-size: 2.5rem;
  padding: 2vw 0 5vw 6rem;
}
#smrt {
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  z-index: 20;
  bottom: 0;
  height: 20vh;
  background-color: #00000080;
  transition: all 0.5s ease;
}
#smrt a {
  display: block;
  width: 150px;
  margin: 10px;
  padding: 5px 15px;
  text-align: center;
  border-radius: 10px;
  background-color: #00000080;
}
#cboxOverlay {
  background-color: #2c3647 !important;
}
/*.mn1 div.bbox div {
  margin: 4%;
  padding: 6%;
  border: 4px solid #fff;
  display: block;
}
.mn1 div.bbox div h1 {
  text-align: center;
  color: #fff;
}
.mn1 div.bbox div p {
  text-align: center;
  color: #fff;
}*/
.mn2 {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 90%;
  margin: auto;
  justify-content: space-around;
  align-items: baseline;
  align-content: flex-start;
}
.mn2 a {
  display: block;
  flex: 0 1 460px;
  text-align: center;
  height: 150px;
  text-decoration: none;
  margin: 5vw 1vw;
  font-size: 1.1rem;
  letter-spacing: 2px;
  font-weight: 400;
  color: #ccc;
}
.mn2 a span {
  display: block;
  background-color: #2c3647;
  padding: 10px 5px;
  text-transform: uppercase;
  margin-top: 1px;
  -webkit-box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
}
.mn2 a div {
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
}
.aboulink div {
  background: url("img/about_px.jpg") no-repeat center;
  background-size: cover
}
.aerolink div {
  background: url("img/aero_px.jpg") no-repeat center;
  background-size: cover
}
.camlink div {
  background: url("img/cam_px.jpg") no-repeat center;
  background-size: cover
}
.content {
  flex: none;
  width: 90%;
  max-width: 1000px;
  display: block;
  margin: auto;
}
.backbtn {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-content: center;
  max-width: 900px;
  margin: auto;
}
.backbtn a {
  display: block;
  font-size: 0.8rem;
  flex: 1 1 auto;
  text-decoration: none;
  padding: 0.5rem 0;
  text-transform: uppercase;
  letter-spacing: 1px;
  white-space: nowrap;
  text-align: center;
  color: #ffffff95;
}
.backbtn span:after {
  content: '\203a';
}
.backbtn span {
  padding: 0.4rem 0;
  font-size: 0.8rem;
}
.backbtn a {
  background: radial-gradient(100% 1px, rgba(256, 256, 256, 1) 0%, rgba(256, 256, 256, 0) 0%);
  background-repeat: no-repeat;
  background-position: 0 -1rem;
  transition: background 0.2s ease;
}
.backbtn a:hover {
  background: radial-gradient(100% 1px, rgba(256, 256, 256, 1) 0%, rgba(256, 256, 256, 0) 80%);
  background-position: 0 0.7rem;
  background-repeat: no-repeat;
  transition: background 0.2s ease;
  color: #fff;
}
/*.backbtn {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
 align-content: center;
  max-width: 700px;
  margin: auto;
  border-radius: 20px;
  background: linear-gradient(90deg, rgba(57, 64, 143, 0.7) 20%, rgba(0, 153, 204, 0.6) 100%);
  cursor: pointer;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
}
.backbtn a {
  display: block;
  font-size: 18px;
  flex: 1 1 auto;
  text-decoration: none;
  padding: 0.7rem 1rem 0.5rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  white-space: nowrap;
  background: rgb(0, 153, 204, 0);
  transition: background 0.5s ease;
	text-align: center;
}
.backbtn a:first-child {
	border-radius: 20px 0 0 20px;
}
.backbtn a:last-child {
	border-radius: 0 20px 20px 0;
}
.backbtn a:hover {
  transition: background 0.5s ease;
  background: rgb(0, 153, 204, 0.5);
}*/
/*.backbtn {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
 align-content: center;
  max-width: 700px;
  margin: auto;
  border-radius: 20px;
  background: linear-gradient(90deg, rgba(57, 64, 143, 0.7) 20%, rgba(0, 153, 204, 0.6) 100%);
  cursor: pointer;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
}
.backbtn a {
  display: block;
  font-size: 18px;
  flex: 1 1 auto;
  text-decoration: none;
  padding: 0.7rem 1rem 0.5rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  white-space: nowrap;
  background: rgb(0, 153, 204, 0);
  transition: background 0.5s ease;
	text-align: center;
}
.backbtn a:first-child {
	border-radius: 20px 0 0 20px;
}
.backbtn a:last-child {
	border-radius: 0 20px 20px 0;
}
.backbtn a:hover {
  transition: background 0.5s ease;
  background: rgb(0, 153, 204, 0.5);
}*/
.select {
  width: 80%;
  background-color: #0099cc;
  margin: 2rem;
  border: 0.5vw solid #0099cc10;
}
.b_video {
  min-width: 100%;
  min-height: 100%;
  opacity: 0.7;
}
.imgtxtblock {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  height: 600px;
  width: 100%;
}
.imgtxtblock div.curt {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  width: 100%;
  height: 100%;
  z-index: 3;
  background: rgba(44, 54, 71, .4);
}
.imgtxtblock h2 {
  font-size: 2.5rem;
  position: absolute;
  z-index: 10;
  text-align: center;
  text-shadow: 0 0 20px #2c3647;
}
.flextxtblock {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  align-content: center;
  /*  padding: 4% 0;*/
  width: 90%;
  max-width: 1500px;
  margin: 5vw auto;
}
.flextxtblock h3 {
  flex: 1 0 100%;
}
.txt_block {
  flex: 1 1 60%;
  padding: 0 2rem 0 0;
}
.txt_block.let {
  padding: 0 2rem 0 5vw;
}
.onecolumn_border {
  max-width: 95%;
  margin: 2rem 0;
  padding: 3rem 5rem;
}
.im_block {
  flex: 1 1 40%;
  text-align: center;
  padding: 4rem 0 2rem 0;
  display: flex;
  justify-content: center;
}
.im_block img {
  max-width: 500px;
}
.triplepose {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: baseline;
  align-content: flex-start;
  text-align: center;
}
.triplepose div {
  flex: 1 1 33%;
}
.triplepose h2 {
  text-align: center;
  flex: 0 0 100%;
}
.bluedisc div {
  padding: 5rem 2rem;
  font-size: 1.1rem;
  text-transform: uppercase;
}
.blockover {
  width: 100%;
  position: relative;
  /*  margin: auto;*/
  background: #fff;
  overflow: hidden;
  margin: 10vh 0;
}
.lgsbox {
  position: relative;
  left: -300px;
  height: 90px;
}
.lgsbox div {
  width: 300px;
  position: absolute;
  text-align: center;
  padding: 20px 0;
}
.lgsbox div img {
  height: 50px;
  width: auto;
}
/*.marqueeleft_opt {
	width: 2500px;
	margin-left: 200px;
}*/
.brikselect {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: baseline;
  align-content: flex-start;
  width: 90%;
  max-width: 1500px;
}
.blueselect1, .subselect2, .subselect3 {
  padding: 8vw 5vw 6vw;
  /*  border: 2vw solid #0099cc10;*/
}
.blueselect1 {
  text-align: center;
  flex: 1 1 100%;
  font-size: 1.4rem;
  background-color: #2c3647;
  /* background: rgb(0, 153, 204);
   background: linear-gradient(30deg, rgba(0, 153, 204, 1) 3%, rgba(44, 54, 71, 1) 100%);*/
  -webkit-box-shadow: 0px 50px 62px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 50px 62px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 50px 62px 0px rgba(0, 0, 0, 0.4);
  margin: 4vw 0;
}
.subselect2, .subselect3 {
  text-align: center;
  flex: 1 1 50%;
  font-size: 1.1rem;
  /*  padding-left: 5rem;*/
}
.subselect2 {
  background: url('img/share.svg') no-repeat center 1vw;
  background-size: 5rem;
}
.subselect3 {
  background: url('img/control.svg') no-repeat center 1vw;
  background-size: 5rem;
}
.footer {
  /*  background: #202636;*/
  position: absolute;
  padding-top: 4rem;
}
.foval {
  width: 100%;
  height: 800px;
  overflow: hidden;
  display: flex;
  position: relative;
  justify-content: center;
}
.curvelback {
  width: 150%;
  top: 200px;
  height: 1500px;
  background: #202636;
  border-radius: 50%;
  position: absolute;
}
.flowi {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-content: flex-start;
  align-items: baseline;
}
.fcall {
  text-align: center;
  color: #ffffff95;
  max-width: 800px;
  margin: 0 auto;
}
.smenu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  width: 100%;
  /*  max-width: 1100px;*/
  border-radius: 50px;
  /*  background: #00000020; */
  padding: 0.2rem 0.5rem;
  margin: 0 auto 5vw;
  border: solid 0.5px #BABABA60;
}
.smenu a {
  display: block;
  font-size: 16px;
  flex: none;
  /* background-color: #0099cc; */
  color: #BABABA;
  text-decoration: none;
  padding: 10px 20px 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  white-space: nowrap;
  transition-duration: .5s;
}
.smenu a:hover {
  color: #ffffff;
  transition-duration: .5s;
}
/*.smenu a {
  display: block;
  padding: 0.5rem 2rem;
  margin: 2vw;
  border-radius: 35px;
  color: #ffffff95;
  text-transform: uppercase;
  text-decoration: none;
  -webkit-box-shadow: 0px 1px 5px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.4);
  transition-duration: .2s;
}
.smenu a:hover {
  -webkit-box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.4);
  transition-duration: .1s;
}*/
.flowi div.ftel1, .flowi div.ftel2 {
  flex: 1 1 auto;
  padding: 2rem 2vw;
  text-align: center;
}
.flowi div.ftel1 a, .flowi div.ftel2 a {
  white-space: nowrap;
  text-decoration: none;
  border-bottom: solid 1px #ffffff20;
}
.flowi div.forder {
  flex: 3 1 auto;
  padding: 0.5rem 2vw;
  text-align: center;
}
.zayavka, .btn {
  display: inline-block;
  text-decoration: none;
  border: 0;
  color: #fff;
  background: rgb(44, 54, 71);
  background: linear-gradient(25deg, rgba(40, 47, 65, 1) 52%, rgba(57, 64, 143, 1) 69%, rgba(0, 153, 204, 1) 100%);
  border-radius: 50px;
  padding: 0.4rem 2rem;
  margin: auto;
  cursor: pointer;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  transition-duration: .2s;
}
.zayavka:hover, .btn:hover {
  -webkit-box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.4);
  transition-duration: .1s;
}
.zayavka:active, .btn:active {
  -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  transition-duration: .1s;
}
.flogo {
  padding: 2rem 2vw;
  margin: auto;
  text-align: center;
}
.flogo img {
  width: 225px;
  height: auto;
}
.fcity {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
}
.fcity a {
  text-decoration: none;
  display: inline-block;
  font-size: 0.7rem;
  margin: 0.2rem;
  color: #BABABA60;
}
.telfr {
  font-size: 0.7rem;
  color: #BABABA60
}
.flybox img {
  width: 100%;
  height: auto;
  background: #f0f0f0;
}
ul.flybox {
  padding: 0;
  list-style: none;
}
.flybox li {
  flex-shrink: 0;
  width: clamp(400px, 60%, 800px);
  padding-right: 1rem;
}
.loader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: black;
  color: white;
  width: 100%;
}
.flybox {
  display: flex;
}
/*.fly-gallery:not(.last) {
  padding-bottom: 1rem;
}*/
.fly-gallery {
  overflow: hidden;
  position: relative;
}
.fly-text {
  color: #0099cc;
  max-width: 1500px;
  margin: 5vw auto;
  width: 90%;
  overflow: hidden;
}
.fly-text .flyletter1, .fly-text .flyletter2 {
  display: inline-block;
  font-size: clamp(2rem, 7vw, 6rem);
  line-height: 1.1;
  padding: 0 0 0 2rem;
  /*  white-space: nowrap;*/
  /*    font-weight: ;*/
  /*  opacity: .3;*/
}
.flyletter2 {
  color: #95d7ed;
}
.clickto {
  border: 1px solid #ffffff50;
  border-radius: 50px;
  padding: 0.8rem 3rem;
  -webkit-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.4);
  margin: 2rem auto 0;
  font-size: 1.1rem;
  display: inline-block;
  cursor: pointer;
  transition-duration: .2s;
}
.clickto:active {
  -webkit-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.4);
  transition-duration: .2s;
}
.name-flybox {
  overflow: hidden;
  width: 100vw;
}
/*path start*/
svg {
  overflow: visible;
  height: 100%;
  /* Fix Safari rendering bug */
  transform: translateZ(0);
}
path {
  stroke-width: 1;
  stroke: gray;
  fill: none;
}
.flpont {
  stroke-width: 2;
  stroke: #fff;
  fill: none;
}
.pathbox {
  position: absolute;
  height: 25vw;
  left: 40vw;
  width: 100%;
  margin-top: -4vw
}
/*path end*/
/*change start redisign_n*/
.upper-menu-wrapper {
  background-color: rgba(224, 236, 242, 0.6);
  font-size: 1.2em;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 10px 1vw;
  text-align: center;
  color: #FFFFFF;
  -webkit-backdrop-filter: saturate(180%) blur(5px);
  backdrop-filter: saturate(180%) blur(5px);
  position: fixed;
  width: 100%;
  min-width: 635px;
  z-index: 100;
  border-bottom: 1px solid rgba(224, 236, 242, 0.3);
  /*text-transform: uppercase;*/
  /*font-weight: bold;*/
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  align-content: center;
}
.filterbox {
  text-align: center;
  padding: 1em 0 2em;
}
.filterbox div {
  display: inline-block;
  border: #D0D0D0 1px solid;
  width: 250px;
  height: 30px;
  margin: 0 1%
}
.filterbox select {
  padding: 5px;
  border-radius: 3px;
  margin: 2% 0;
}
.filterbox form {
  max-width: 935px;
  margin: auto;
  border-radius: 8px;
  padding: 10px 5px;
  border-bottom: 1px solid #c5cce310;
  background: #2c3647 center top no-repeat;
  box-shadow: 0px 0px 30px #00000050;
}
.camlistbox {
  text-align: center;
  width: 100%;
  /*  min-width: 635px;*/
  padding-bottom: 5vh;
}
.camlistbox .onecam {
  display: inline-block;
  position: relative;
  width: 300px;
  height: 270px;
  margin: 0.5%;
  padding-top: 0;
  box-sizing: border-box;
  border-radius: 8px;
  border-bottom: 1px solid #c5cce310;
  text-decoration: none;
  overflow: hidden;
  text-align: left;
  background: #2c3647 center top no-repeat;
  -webkit-box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 3px 23px 0px rgba(0, 0, 0, 0.4);
  transition: 0.5s;
}
.camlistbox .onecam:hover {
  background-color: #5d6681;
  -webkit-box-shadow: 0px 3px 23px 5px rgba(0, 0, 0, 0.5);
  -moz-box-shadow: 0px 3px 23px 5px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 3px 23px 5px rgba(0, 0, 0, 0.5);
}
.play {
  background: url('img/play.png') 0 20px no-repeat;
  width: 300px;
  height: 190px;
}
.camlistbox .onecam:hover .play {
  background-position: -300px 20px;
}
.camlistbox .onecam .cover {
  width: 300px;
  height: 190px;
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
}
.camlistbox .onecam h2 {
  color: #fff;
  font-size: 1rem;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  text-align: center;
  line-height: 1rem;
  font-weight: 300;
  padding: 3px 0;
}
.camlistbox .onecam .cny {
  font-size: 0.7rem;
  padding: 15px 5px;
  color: #b5bfe0;
  overflow: hidden;
  position: absolute;
  top: 190px;
  width: 300px;
  text-align: center;
  box-shadow: 0 -7px -12px -5px #2c3647;
}
.camlistbox .onecam .player {
  width: 300px;
  height: 250px;
}
/*change finish*/
/*форма обратного звонка*/
.callback-wrapper {
  display: none;
}
#callback_content {
  padding: 20px;
}
/*.btn {
  display: inline-block;
  font-weight: 300;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  border: 1px solid transparent;
  padding: 0.5rem 1.5rem;
  font-size: 1.2rem;
  line-height: 1.35;
  -webkit-border-radius: 0.5rem;
  border-radius: 0.5rem;
  -webkit-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  -o-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
}
.btn:hover {
  background-color: #00a1d0;
}*/
.orderformbox h3, .dronformbox h3 {
  margin: 2rem 5% 0rem;
  padding: 0;
}
.fclose {
  position: absolute;
  width: 20px;
  height: 20px;
  margin: 5px;
  cursor: pointer;
  background: url('img/close.svg') no-repeat center;
  background-size: contain;
  right: 0%;
}
#smrt .fclose {
  right: 5%;
}
.callBackModal-success {
  text-align: center;
  padding-top: 50px;
}
.orderformbox, .dronformbox {
  /*  position: absolute;*/
  width: 100%;
  z-index: 30;
  height: 100vh;
  display: flex;
  justify-content: center;
  background-color: #00000080;
  position: fixed;
}
#callback {
  position: relative;
  width: 90%;
  max-width: 600px;
  margin: auto;
  box-shadow: 0 5px 5px 5px #00000020;
  background-color: #2c3647
}
input.form-control {
  width: 90%;
  margin: 0.2rem 5%;
  padding: 0 0 5px;
  display: block;
  box-sizing: border-box;
  font-size: 1rem !important;
  color: #fff;
  font-weight: 300;
  background-color: #2c3647;
  border: none;
  border-bottom: #fff 1px solid;
}
::-webkit-input-placeholder {
  color: #fffff20;
}
::-moz-placeholder {
  color: #fffff20;
}
/* Firefox 19+ */ :-moz-placeholder {
  color: #fffff20;
}
/* Firefox 18- */ :-ms-input-placeholder {
  color: #fffff20;
}
.orderformbox label, .dronformbox label {
  margin: 4vh 5% 0.2rem;
  display: block;
  color: #fff;
  font-size: 0.7rem;
  letter-spacing: 1px;
  line-height: 1.35;
  text-transform: uppercase;
}
#inputQuant {}
.invalid-callback {
  font-size: 80%;
  color: red;
  margin: 0.2rem 5%;
}
.btnbox {
  width: 90%;
  margin: auto;
  text-align: center;
  padding: 2rem 2rem 0;
}
/*.btn {
  display: inline-block;
  font-weight: 300;
  text-align: center;
  white-space: nowrap;
  border: 1px solid transparent;
  padding: 0.2rem 1.5rem;
  font-size: 1.2rem;
  line-height: 1.35;
  border-radius: 1rem;
  background-color: #0099cc;
  -webkit-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  -o-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  cursor: pointer;
}
.btn:hover {
  background-color: #00a1d0;
}*/
.callBackModal-success {
  text-align: center;
  padding-top: 50px;
}
.ps {
  font-size: 0.8rem;
  padding: 1rem 5%;
}
.fdback {
  position: relative;
  width: 90%;
  max-width: 600px;
  margin: auto;
  box-shadow: 0 5px 5px 5px #00000020;
  background-color: #2c3647;
}
.fdback p {
  text-align: center;
  padding: 10%;
}
.fdback .btnbox {
  padding: 0 5% 5%;
}
/*форма обратного звонка. Конец*/
@media screen and (max-width: 1024px) {
  .txt_block {
    flex: 1 1 100%;
  }
  .blueselect1, .subselect2, .subselect3 {
    padding: 6vw 5vw;
    flex: 1 1 100%;
  }
  .txt_block.let {
    padding: 0 1rem;
  }
  .onecolumn_border {
    max-width: none;
  }
}
@media screen and (max-width: 1024px) and (orientation: portrait) {
  .mn1 div.bbox div h2 {
    font-size: 1.2rem;
    margin: auto;
    line-height: 1.3rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .mn1 div.bbox div p {
    font-size: 1rem;
    line-height: 1.2rem;
  }
  .mn1 div.bbox {
    width: 90%;
  }
  /*  .mn1 div.bbox div {
    margin: 3% 0;
    padding: 4%;
    height: 400px;
    display: flex;
    align-items: center;
    align-content: center;
    flex-wrap: wrap;
  }*/
  .txt_block, .im_block {
    flex: 1 1 100%;
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  .im_block img {
    position: relative;
  }
}
@media screen and (max-width: 700px) {
  /*  .mn1 a.logo {
    height: 15rem;
  }*/
  .backbtn {
    margin: -5rem auto 5rem;
  }
  .backbtn a, .backbtn span {
    display: block;
    flex: 0 1 100%;
    text-decoration: none;
    padding: 0.5rem 0;
  }
  .backbtn span:after {
    content: '';
  }
  .backbtn span {
    border-bottom: 1px solid #ffffff10;
    padding: 0;
    font-size: 0.8rem;
  }
  .backbtn a {
    background: none;
  }
  .backbtn a:hover {
    background: none;
  }
  .smenu {
    border: none;
  }
  .smenu a {
    flex: 0 1 100%;
    text-align: center;
    border: solid 0.5px #BABABA60;
    border-radius: 50px;
    margin: 2px;
  }
  .txt_block {
    flex: 1 1 100%;
  }
  .txt_block.let {
    padding: 0;
  }
  .pathbox {
    position: absolute;
    height: 46vw;
    left: 20vw;
    width: 100%;
    margin-top: -4vw;
  }
}
@media screen and (max-width: 510px) {
  body {
    font-size: 19px;
    line-height: normal;
  }
  h1 {
    padding: 1rem;
    font-size: 2rem;
    text-align: left;
    margin: 0;
  }
  .orderformbox h3, .dronformbox h3 {
    text-align: center;
  }
  p {
    padding: 0.5rem 1rem;
  }
  h2 {
    padding: 2rem 1rem 0.5rem;
  }
  h3 {
    font-size: 1.4rem;
    font-weight: normal;
    padding: 1rem;
  }
  .smenu {
    border-radius: 10px;
  }
  .mn1 div.tel, .mn1 div.prc, .mn1 div.dinamicbox {
    flex: 0 1 auto;
    display: flex;
    /*    flex-direction: column;*/
    justify-content: center;
    align-content: center;
    flex-wrap: wrap;
  }
  .mn1 div.bbox {
    background-color: rgba(44, 54, 71, 0.6);
  }
  .mn1 div.desk2, .mn1 div.desk3, .mn1 div.desk4 {
    flex: 0 1 100%;
    background-position: center top;
    background-size: 90px;
    padding: 100px 20px 20px;
    font-size: 1.1rem;
  }
  /*  .mn1 div br {
    display: none;
  }*/
  .mn1 div.desk5, .mn1 div.desk6 {
    flex: 0 1 100%;
    background-position: center top;
    background-size: 130px;
    padding: 100px 20px 20px;
    font-size: 1.1rem;
  }
  .mn1 div.tel {
    flex-direction: column;
  }
  .mn1 div.prc a {
    font-size: 1rem;
    text-decoration: none;
    padding: 10px 1rem 23px;
    display: block;
  }
  .mn1 div.tel a {
    font-size: 1rem;
    text-decoration: none;
    padding: 10px 1rem;
    display: block;
  }
  .fly-text .flyletter1, .fly-text .flyletter2 {
    font-size: clamp(1rem, 10vw, 4rem);
    padding: 0 0 0 1rem;
  }
  .flowi div.ftel1, .flowi div.ftel2 {
    flex: 1 1 50%;
    padding: 1rem 1rem;
    text-align: center;
  }
  .flowi div.forder {
    flex: 3 1 auto;
    padding: 0.5rem 1rem;
    text-align: center;
  }
  .clickto {
    border: 1px solid #ffffff50;
    border-radius: 50px;
    padding: 0.5rem 2rem;
    font-size: 0.8rem;
    margin: 1rem auto 0;
  }
  .subselect2, .subselect3 {
    text-align: center;
    flex: 1 1 100%;
    font-size: 1.1rem;
    padding: 6rem 1rem 1rem;
  }
  h1 {
    text-align: center
  }
  txt_block {
    padding: 0
  }
  .mn2 a {
    display: block;
    flex: 0 1 95%;
    text-align: center;
    height: 170px;
    margin: 10vw 1vw;
  }
  /*  .im_block {
    height: 300px;
  }*/
  .pathbox {
    position: absolute;
    height: 46vw;
    left: 20vw;
    width: 100%;
    margin-top: -4vw;
  }
  .let ul {
    padding: 1rem 2rem 1rem 2.5rem;
  }
  .krugline {
    width: 450px;
    height: 450px;
    top: 60px;
    left: calc(50% - 225px)
  }
  .krug {
    width: 440px;
    height: 440px;
    top: 65px;
    left: calc(50% - 220px)
  }
  .addrss {
    background: url(img/logo_exdesign_square_white.svg) no-repeat 1rem 2.1rem;
    background-size: 4rem;
    padding: 6rem 1rem 0.5rem;
  }
  #smrt {
    flex-wrap: wrap;
  }
  #smrt fclose {
    right: calc(50% - 10px);
  }
  #smrt a {
    flex: 1 1 90%;
    max-width: 200px;
  }
  .blueselect1 {
    padding: 6vh 5vw;
  }
  .onecolumn_border {
    padding: 0.3rem;
  }
  .txt_block {
    padding: 0 0 0 0;
  }
}