@font-face {
  font-family: 'Orbitron';
  src: url('../fonts/Orbitron.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}
html {
  font-family: 'Orbitron', sans-serif;
  font-size: 10px;
}
.container {
  max-width: 1200px;
  padding: 0 12rem;
  margin: 0 auto;
}
.btn {
  color: #fff;
  font-size: 2rem;
  padding: 1.5rem 2.5rem;
  background-color: #003D5B;
  transition: background-color 0.25s;
  margin-top: 10rem;
}
.btn:hover {
  background-color: #DE6600;
}
/*INDEX*/
body {
  opacity: 0;
  transition: 0.5s;
  line-height: 1.3;
}
.header {
  position: fixed;
  z-index: 10;
  width: 100%;
}
.header .nav-bg {
  background: #003D5B;
}
.header .language {
  float: right;
  background: white;
  width: 13.6rem;
  height: 13.6rem;
  border-radius: 50%;
  position: absolute;
  top: -8.8rem;
  right: -8.5rem;
  border: 3px solid #DE6600;
  font-size: 1.5rem;
}
.header .language a:hover {
  color: #DE6600;
}
.header .language a.ru {
  position: absolute;
  bottom: 2rem;
  left: 2.3rem;
}
.header .language:hover {
  top: -6.5rem;
  right: -6rem;
}
.header .language:hover a.ru {
  bottom: 3.8rem;
  left: 4.8rem;
}
.header .language:hover a.en {
  position: absolute;
  bottom: 4rem;
  left: 1.5rem;
}
.header .language:hover a.de {
  position: absolute;
  bottom: 1.5rem;
  left: 4rem;
}
.header .nav {
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header .nav button.btn-menu {
  display: none;
  color: #fff;
}
.header .nav a {
  flex: 0 0 7rem;
  transition: color 0.25s;
}
.header .nav .nav-logo {
  text-align: -webkit-center;
  text-align: -moz-center;
}
.header .nav a:hover {
  color: #DE6600;
}
.home {
  padding: 35rem 0 50rem 0;
  background: url("../img/bg-home.jpg") no-repeat center / cover;
}
.home .home-wrap {
  line-height: 1;
  color: #fff;
  font-size: 2.8rem;
}
.home .home-wrap p {
  display: inline-block;
}
.home .home-wrap p::after {
  content: "";
  display: block;
  height: 3px;
  width: 100%;
  background: #fff;
}
.home .home-wrap h1 {
  display: inline-block;
  font-size: 3rem;
  text-transform: uppercase;
  margin: 2rem 0;
}
.home .home-wrap h1::after {
  content: "";
  display: block;
  height: 4px;
  width: 100%;
  background: #DE6600;
}
.home .home-wrap p.title {
  display: inline-block;
  font-size: 3rem;
}
.home .home-wrap p.title::after {
  content: "";
  display: block;
  height: 4px;
  width: 100%;
  background: #DE6600;
}
#about {
  padding-bottom: 10rem;
}
#about h2 {
  font-size: 3.6rem;
  margin-bottom: 12.5rem;
  text-transform: uppercase;
}
#about .about-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#about .about-wrap .description {
  flex: 0 1 700px;
  font-size: 1.8rem;
  padding-right: 12rem;
}
#about .about-wrap .description ul {
  margin: 2rem 0 0 2rem;
  list-style-type: disc;
}
#about .about-wrap .description ul li {
  margin-bottom: 1rem;
}
#services {
  text-align: center;
}
#services span::after {
  content: "";
  display: block;
  height: 7px;
  width: 100%;
  background: #003D5B;
}
#services span::before {
  content: "";
  display: block;
  height: 7px;
  width: 100%;
  background: #DE6600;
  margin-bottom: 1.2rem;
}
#services h2 {
  font-size: 3.6rem;
  margin: 10rem 0 7rem;
  text-transform: uppercase;
}
#services .services-wrap {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
#services .services-wrap .service-item {
  position: relative;
  width: 180px;
  height: 180px;
  margin: 1rem 0.5rem;
  border-radius: 50%;
}
#services .services-wrap .service-item:first-child {
  background: url("../img/tech1.jpg") no-repeat center / cover;
}
#services .services-wrap .service-item:nth-child(2) {
  background: url("../img/logist.jpg") no-repeat center / cover;
}
#services .services-wrap .service-item:nth-child(3) {
  background: url("../img/repairship.jpg") no-repeat center / cover;
}
#services .services-wrap .service-item:nth-child(4) {
  background: url("../img/fire-fighting1.jpg") no-repeat center / cover;
}
#services .services-wrap .service-item:last-child {
  background: url("../img/food.jpg") no-repeat center / cover;
}
#services .services-wrap .service-item .wrap {
  padding: 1rem;
  border-radius: 50%;
  width: 100%;
  height: 100%;
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 16px;
  border: 5px solid transparent;
  transition: border 0.25s;
}
#services .services-wrap .service-item .wrap:hover {
  border: 5px solid #DE6600;
}
#services .services-wrap .service-item .wrap a {
  padding: 4rem 1.5rem;
}
.map {
  text-align: center;
}
.map .wrap-title {
  background: url("../img/bg-services.jpg") no-repeat top / cover;
}
.map .wrap-title .btn {
  display: inline-block;
  margin-top: 20rem;
  margin-bottom: 35rem;
}
.map .wrap-title .btn a {
  padding: 1.5rem 0;
}
.map .wrap-title .description {
  font-size: 1.8rem;
  margin: 0 auto;
  padding-bottom: 10rem;
}
.map .wrap-title .description h2 {
  font-size: 3.6rem;
  margin-bottom: 5.5rem;
  text-transform: uppercase;
}
.map .map-navigation {
  margin-top: 10rem;
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.map .map-navigation .left-nav {
  display: flex;
}
.map .map-navigation .left-nav span::before {
  content: "";
  display: block;
  width: 7px;
  height: 100%;
  background: #DE6600;
  margin-left: 5px;
}
.map .map-navigation .left-nav span {
  border-left: 7px solid #003D5B;
}
.map .map-navigation .right-nav {
  display: flex;
}
.map .map-navigation .right-nav span::before {
  content: "";
  display: block;
  width: 7px;
  height: 100%;
  background: #DE6600;
  margin-right: 5px;
}
.map .map-navigation .right-nav span {
  border-right: 7px solid #003D5B;
}
.map .map-navigation ul {
  color: #003D5B;
  font-size: 2.4rem;
  padding: 6.5rem 0;
}
.map .map-navigation ul li {
  margin: 1rem 3rem;
}
.map .map-navigation ul li a {
  cursor: pointer;
  transition: color 0.25s;
}
.map .map-navigation ul li a:hover {
  color: #DE6600;
}
.map .map-navigation .icon-bus {
  width: 224px;
  height: 224px;
  background: #003D5B;
  border: 11px solid #DE6600;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.order {
  padding-bottom: 10rem;
  margin-top: 4rem;
  background: url("../img/bg-order.jpg") no-repeat top / cover;
  text-align: center;
}
.order .btn {
  margin-bottom: 19rem;
}
footer {
  background: #003D5B;
  padding: 2rem 0;
  color: #fff;
  font-size: 1.4rem;
}
footer .container {
  padding: 0 30px;
}
footer .wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
footer .wrap .nav ul li {
  margin: 1rem 0;
  transition: color 0.25s;
}
footer .wrap .nav ul li:hover {
  color: #DE6600;
}
footer .wrap .contacts {
  flex: 0 0 60rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
footer .wrap .contacts ul li {
  margin-top: 0.3rem;
}
footer .wrap .contacts p {
  text-align: right;
}
footer .wrap .contacts h3 {
  font-size: 1.6rem;
  margin-top: 1.5rem;
  margin-bottom: 1rem;
  color: #DE6600;
  text-align: left;
}
footer .wrap .contacts .rus {
  flex: 0 0 23rem;
}
footer .wrap .contacts .block-info {
  flex: 0 0 23rem;
}
footer .wrap .contacts .block-info div h3 {
  color: #000;
  font-size: 2.6rem;
}
footer .wrap .contacts .block-info div a {
  line-height: 1.5;
  font-size: 1.6rem;
  color: #DE6600;
}
footer .wrap .contacts .block-info div p {
  text-align: left;
}
footer .wrap .contacts .block-info div p a {
  color: #003D5B;
  font-size: 1.4rem;
}
/*SERVICES*/
.home-services {
  background: url("../img/bg-home-services.png") no-repeat center / cover;
  height: 20rem;
}
#services-items {
  text-align: center;
}
#services-items h2 {
  color: #003D5B;
  font-size: 3.6rem;
  margin: 9rem 0 11.5rem;
  text-transform: uppercase;
}
#services-items .block-items .item {
  cursor: pointer;
  border: 7px solid transparent;
  padding: 10px;
  display: flex;
  align-items: center;
  margin-bottom: 7.5rem;
  position: relative;
}
#services-items .block-items .item a {
  position: absolute;
  width: 100%;
  height: 100%;
}
#services-items .block-items .item img {
  width: 100%;
}
#services-items .block-items .item .description {
  color: #003D5B;
  font-size: 1.8rem;
  padding: 0 2.5rem;
  text-align: left;
}
#services-items .block-items .item .description h3 {
  color: #003D5B;
  font-size: 2.4rem;
  margin-bottom: 1.4rem;
}
#services-items .block-items .item:hover {
  border-color: #DE6600;
}
/*ABOUT-SERVICES*/
.home-about-services {
  background: url("../img/bg-home-about-services.jpg") no-repeat top / cover;
  text-align: center;
}
.home-about-services h1 {
  color: #fff;
  font-size: 3.6rem;
  margin: 25rem 0 6rem;
}
.service-description {
  padding-top: 13.5rem;
}
.service-description .subtitle {
  width: 80%;
  text-align: center;
  margin: 0 auto 8.3rem;
  color: #003D5B;
  font-size: 1.8rem;
}
.service-description .item {
  display: flex;
  align-items: center;
  margin-bottom: 7rem;
}
.service-description .item .description {
  flex: 0 1 63rem;
}
.service-description .item .description h3 {
  color: #003D5B;
  font-size: 2.4rem;
  margin-bottom: 2.4rem;
}
.service-description .item .description li {
  margin: 1.5rem 0;
  color: #003D5B;
  font-size: 1.8rem;
}
.service-description .item .description .description-wrap:nth-child(odd) {
  padding: 2.4rem 2rem 0 12rem;
  text-align: right;
}
.service-description .item .description:nth-child(odd) {
  display: flex;
  justify-content: flex-start;
}
.service-description .item .description:nth-child(odd) span::before {
  content: "";
  display: block;
  width: 7px;
  height: 100%;
  background: #DE6600;
  margin-left: 5px;
}
.service-description .item .description:nth-child(odd) span {
  border-left: 7px solid #003D5B;
}
.service-description .item .description .description-wrap:nth-child(even) {
  padding: 2.4rem 12rem 0 2rem;
  text-align: left;
}
.service-description .item .description:nth-child(even) {
  display: flex;
  justify-content: flex-end;
  align-items: right;
}
.service-description .item .description:nth-child(even) span::before {
  content: "";
  display: block;
  width: 7px;
  height: 100%;
  background: #DE6600;
  margin-right: 5px;
}
.service-description .item .description:nth-child(even) span {
  border-right: 7px solid #003D5B;
}
.service-description .item .img {
  flex: 0 1 47rem;
}
.service-description .item .img img {
  width: 100%;
}
/*MODAL WINDOW*/
.overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.3);
  display: none;
}
.overlay .wrap {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.overlay .popup {
  position: relative;
  padding: 0 7rem;
  border: 7px solid #DE6600;
}
.overlay .popup-wrap {
  margin: 0 auto;
  color: #000;
  font-size: 1.8rem;
  padding: 5px;
  max-width: 93rem;
  background: #fff;
  border: 7px solid #003D5B;
  text-align: center;
}
.overlay .popup-wrap button.close {
  position: absolute;
  right: 1.5rem;
  top: 1.5rem;
  font-size: 2.5rem;
}
.overlay .popup-wrap .title {
  margin: 3rem 0;
}
.overlay .popup-wrap .title h2 {
  font-size: 2.4rem;
}
.overlay .popup-wrap form div {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.8rem;
}
.overlay .popup-wrap form div label {
  padding-top: 1rem;
}
.overlay .popup-wrap form div input {
  font-family: 'Open Sans', sans-serif;
  flex: 0 0 34.5rem;
  padding: 0.8rem;
  border: 0.5px solid #000000;
  border-radius: 5px;
}
.overlay .popup-wrap form div input::placeholder {
  font-style: italic;
  color: #8A8A8A;
  font-size: 1.8rem;
}
.overlay .popup-wrap form div input:focus,
.overlay .popup-wrap form div input:active {
  background: #F7F7F7;
  border: 0.5px solid #A7A7A7;
}
.overlay .popup-wrap form div textarea {
  font-family: 'Open Sans', sans-serif;
  flex: 0 0 34.5rem;
  border: 0.5px solid #000000;
  border-radius: 5px;
  padding: 0.8rem;
  height: 10rem;
}
.overlay .popup-wrap form div textarea::placeholder {
  font-style: italic;
  color: #8A8A8A;
  font-size: 1.8rem;
}
.overlay .popup-wrap form div textarea:focus,
.overlay .popup-wrap form div textarea:active {
  background: #F7F7F7;
  border: 0.5px solid #A7A7A7;
}
.overlay .popup-wrap form button.modal-btn {
  margin: 4rem 0 2rem;
}
.overlay .popup-wrap .contact {
  margin-bottom: 3rem;
}
.overlay .popup-wrap .contact p {
  margin-bottom: 2rem;
}
.overlay .popup-wrap .contact span {
  font-size: 2.4rem;
}
.alert-success {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.3);
  display: none;
}
.alert-success .wrap {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.alert-success .success-popup {
  position: relative;
  padding: 12rem 4rem;
  border: 7px solid #DE6600;
}
.alert-success .success-popup-wrap {
  margin: 0 auto;
  max-width: 55rem;
  color: #003D5B;
  font-size: 2.4rem;
  background: #fff;
  border: 7px solid #003D5B;
  text-align: center;
}
.alert-success .success-popup-wrap button.close {
  position: absolute;
  right: 1.5rem;
  top: 1.5rem;
  font-size: 2.5rem;
}
.impressum-overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.3);
  display: none;
}
.impressum-overlay .popup {
  overflow: auto;
  height: 100vh;
  margin: 0 auto;
  width: 80%;
  position: relative;
  padding: 4rem 12rem;
  background: #fff;
  color: #000;
  font-size: 1.4rem;
}
.impressum-overlay .popup p {
  margin-top: 1rem;
  line-height: 1.5;
}
.impressum-overlay .popup h2 {
  text-align: center;
  color: #000;
  font-size: 3rem;
  padding: 1.5rem 0;
}
.impressum-overlay .popup h4 {
  padding: 2rem 0 1rem;
  font-size: 2rem;
}
.impressum-overlay .popup h5 {
  padding: 1.5rem 0 0.5rem;
  font-size: 1.6rem;
}
.impressum-overlay .popup button.close {
  position: absolute;
  right: 1.5rem;
  top: 1.5rem;
  font-size: 2.5rem;
}
.haftungsausschluss-overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.3);
  display: none;
}
.haftungsausschluss-overlay .popup {
  overflow: auto;
  height: 100vh;
  margin: 0 auto;
  width: 80%;
  position: relative;
  padding: 4rem 12rem;
  background: #fff;
  color: #000;
  font-size: 1.4rem;
}
.haftungsausschluss-overlay .popup p {
  margin-top: 1rem;
  line-height: 1.5;
}
.haftungsausschluss-overlay .popup h2 {
  text-align: center;
  color: #000;
  font-size: 3rem;
  padding: 1.5rem 0;
}
.haftungsausschluss-overlay .popup h4 {
  padding: 2rem 0 1rem;
  font-size: 2rem;
}
.haftungsausschluss-overlay .popup h5 {
  padding: 1.5rem 0 0.5rem;
  font-size: 1.6rem;
}
.haftungsausschluss-overlay .popup button.close {
  position: absolute;
  right: 1.5rem;
  top: 1.5rem;
  font-size: 2.5rem;
}
.datenschutzerklärung-overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.3);
  display: none;
}
.datenschutzerklärung-overlay .popup {
  overflow: auto;
  height: 100vh;
  margin: 0 auto;
  width: 80%;
  position: relative;
  padding: 4rem 12rem;
  background: #fff;
  color: #000;
  font-size: 1.4rem;
}
.datenschutzerklärung-overlay .popup p {
  margin-top: 1rem;
  line-height: 1.5;
}
.datenschutzerklärung-overlay .popup h2 {
  text-align: center;
  color: #000;
  font-size: 3rem;
  padding: 1.5rem 0;
}
.datenschutzerklärung-overlay .popup h4 {
  padding: 2rem 0 1rem;
  font-size: 2rem;
}
.datenschutzerklärung-overlay .popup h5 {
  padding: 1.5rem 0 0.5rem;
  font-size: 1.6rem;
}
.datenschutzerklärung-overlay .popup button.close {
  position: absolute;
  right: 1.5rem;
  top: 1.5rem;
  font-size: 2.5rem;
}
/*@MEDIA QUERIES*/
@media screen and (min-width: 1441px) {
  .map .wrap-title .btn {
    margin-top: 25rem;
    margin-bottom: 40rem;
  }
  .map .wrap-title .btn a {
    padding: 1.5rem 0;
  }
  .map .wrap-title .description {
    width: 80%;
  }
}
@media screen and (max-width: 1024px) {
  #services .services-wrap .service-item {
    width: 200px;
    height: 200px;
  }
  .map .wrap-title .btn {
    margin-top: 10rem;
    margin-bottom: 30rem;
  }
}
@media screen and (max-width: 920px) {
  .container {
    padding: 0 20px;
  }
  .map .wrap-title .description {
    width: 75%;
  }
}
@media screen and (max-width: 768px) {
  html {
    font-size: 7px;
  }
  /*HOME*/
  .home {
    background: url("../img/bg-home2.jpg") no-repeat center / cover;
  }
  .header {
    background: #003D5B;
  }
  .header .language {
    display: none;
  }
  .header .container {
    padding: 5px 14px;
  }
  .header .container .nav {
    flex-wrap: wrap;
  }
  .header .container .nav .nav-logo-responsive {
    font-size: 14px;
    display: flex;
    align-items: center;
  }
  .header .container .nav .nav-logo-responsive span {
    text-align: left;
    margin-left: 5px;
  }
  .header .container .nav button.btn-menu {
    display: block;
  }
  .header .container .nav .nav-hide {
    margin-top: 37px;
    flex: 1 0 100%;
    display: none;
  }
  .header .container .nav .nav-hide li {
    margin: 16px 0;
  }
  .header .container .nav .nav-hide li .language-mob {
    margin-top: 30px;
    display: flex;
    justify-content: center;
  }
  .header .container .nav .nav-hide li .language-mob li {
    color: #003D5B;
    padding: 10px;
    border-radius: 50%;
    background: #fff;
    margin: 0 30px;
  }
  .header .container .nav .nav-hide li .language-mob li:first-child {
    margin-left: 0;
  }
  .header .container .nav .nav-hide li .language-mob li:last-child {
    margin-right: 0;
  }
  #about {
    text-align: center;
  }
  #about h2 {
    margin-bottom: 2.8rem;
  }
  #about .about-wrap {
    flex-wrap: wrap;
    justify-content: center;
  }
  #about .about-wrap .description {
    padding-right: 0;
  }
  #about .about-wrap .description ul {
    list-style-type: none;
  }
  #about .about-wrap .logo img {
    width: 100%;
  }
  /*SERVICES*/
  #services-items .block-items .item {
    flex-wrap: wrap;
    justify-content: center;
  }
  #services-items .block-items .item img {
    padding: 1rem 0;
  }
  #services-items .block-items .item .description {
    text-align: center;
    padding: 1rem 0;
    border-bottom: 3px solid #003D5B;
  }
  #services-items .block-items .item .description:nth-child(even) {
    order: 1;
  }
  /*MODAL*/
  .overlay .popup {
    padding: 0 1.5rem;
  }
}
@media screen and (max-width: 670px) {
  footer .wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  footer .wrap .nav-logo {
    display: none;
  }
  footer .wrap .nav {
    display: none;
  }
  footer .wrap .contacts {
    flex: 100%;
  }
}
@media screen and (max-width: 560px) {
  /*INDEX*/
  .home .home-wrap p {
    width: 140px;
  }
  .home .home-wrap p::after {
    display: none;
  }
  .map .wrap-title .btn {
    margin-top: 25rem;
    margin-bottom: 20rem;
  }
  .map .map-navigation .icon-bus {
    display: none;
  }
  #services .services-wrap {
    flex-direction: column;
    align-items: center;
  }
  .map .wrap-title .btn {
    margin-bottom: 30rem;
  }
  .order .btn {
    margin-bottom: 10rem;
  }
  /*ABOUT-SERVICES*/
  .service-description .subtitle {
    width: 100%;
  }
  .service-description .item {
    flex-wrap: wrap;
    justify-content: center;
  }
  .service-description .item .description {
    flex: 1 1 100%;
    margin-bottom: 10px;
  }
  .service-description .item .description .description-wrap:nth-child(odd) {
    padding-left: 0;
  }
  .service-description .item .description .description-wrap:nth-child(even) {
    padding-right: 0;
  }
  .service-description .item .description:nth-child(even) {
    order: -1;
  }
  .service-description .item .img {
    flex: 1 1 100%;
  }
  /*MODAL*/
  .overlay .popup-wrap form div {
    justify-content: center;
  }
  .overlay .popup-wrap form div label {
    display: none;
  }
  /*IMPRESSUM*/
  .impressum-overlay .popup {
    padding: 2rem 4rem;
  }
  .haftungsausschluss-overlay .popup {
    padding: 2rem 4rem;
  }
  .datenschutzerklärung-overlay .popup {
    padding: 2rem 4rem;
  }
}
@media screen and (max-width: 375px) {
  .container {
    padding: 0 10px;
  }
}
