@font-face {
  font-family: "PH Caps";
  font-display: swap;
  src: url("../fonts/PH600RegularCaps.woff") format("woff"), url("../fonts/PH600RegularCaps.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
}

@font-face {
  font-family: "PH Caps";
  font-display: swap;
  src: url("../fonts/PH400RegularCaps.woff") format("woff"), url("../fonts/PH400RegularCaps.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: "PH Caps";
  font-display: swap;
  src: url("../fonts/PH300CondCaps.woff") format("woff"), url("../fonts/PH300CondCaps.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family: "PH Caps";
  font-display: swap;
  src: url("../fonts/PH100CondCaps.woff") format("woff"), url("../fonts/PH100CondCaps.woff2") format("woff2");
  font-weight: 100;
  font-style: normal;
}

html {
  font-size: 10px;
}

body {
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.4;
  min-height: 100vh;
  display: -ms-flexbox !important;
  display: -webkit-box !important;
  display: flex !important;
  -ms-flex-direction: column !important;
  -webkit-box-orient: vertical !important;
  -webkit-box-direction: normal !important;
          flex-direction: column !important;
  margin: 0;
  padding: 0;
}

main {
  position: relative;
  overflow: hidden;
}

main .bg-fluid-start,
main .bg-fluid-end {
  position: relative;
}

main .bg-fluid-start::before,
main .bg-fluid-end::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  height: 100%;
  width: 100%;
  background-color: inherit;
}

main .bg-fluid-start::before {
  margin-left: -100%;
  left: 0;
}

main .bg-fluid-end::before {
  margin-right: -100%;
  right: 0;
}

footer .footer-top {
  background-image: url(../img/bg-footer-top.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 19rem;
}

footer .footer-top .title {
  letter-spacing: -0.05rem;
}

footer .footer-middle {
  background-image: url(../img/bg-footer-middle.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  min-height: 40rem;
}

.nav.menu .nav-link {
  font-weight: 600;
  text-transform: uppercase;
}

.nav.menu .submenu .nav-link {
  text-transform: none;
}

#navbar {
  background-color: #f5f6f6;
  height: 4rem;
}

#navbar.backdrop::before {
  content: "";
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1015;
  background-color: rgba(255, 255, 255, 0.702);
  filter: alpha(opacity=7);
  -webkit-transition: opacity 0.15s linear;
  -o-transition: opacity 0.15s linear;
  transition: opacity 0.15s linear;
}

#navbarNav .nav-link {
  text-transform: uppercase;
  color: #646464;
  font-size: 1.8rem;
  font-weight: 400;
  min-height: 4rem;
}

#navbarNav .nav-link:hover,
#navbarNav .nav-link:focus {
  text-decoration: none;
  color: #fff;
  background-color: #646464;
}

#navbarMobile .nav-link {
  color: #96c7fd;
  font-size: 1.6rem;
  line-height: 1;
  min-height: 4rem;
}

.fixed-top#navbar {
  -webkit-animation: my_animation 0.2s linear;
          animation: my_animation 0.2s linear;
  background-color: #364657;
}

.fixed-top #navbarNav .nav-link {
  color: #96c7fd;
  font-size: 1.6rem;
  min-height: 4rem;
}

.fixed-top #navbarNav .nav-link:hover,
.fixed-top #navbarNav .nav-link:focus {
  text-decoration: none;
  color: #fff;
  background-color: #2b3846;
}

.fixed-top #navbarMobile .phone {
  display: block !important;
}

.section {
  position: relative;
}

.section .section__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
}

.section .section__title {
  font-family: "PH Caps", sans-serif;
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: -0.05rem;
}

.section .title {
  text-transform: uppercase;
  font-weight: 700;
}

.section .caption {
  text-shadow: 0 0 0;
  font-weight: 400;
}

.section .accent {
  position: relative;
}

.section .accent::after {
  content: "";
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  margin-bottom: -0.75em;
}

.section.section__banner {
  background-image: url(../img/bg-banner.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  min-height: 61.5rem;
}

.section.section__banner .accent::after {
  background-image: url(../img/border1.png);
}

.section.section__client {
  background-image: url(../img/bg-client.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  min-height: 57rem;
}

.section.section__client .img-book {
  position: absolute;
  top: -25px;
}

.section.section__comment {
  background-image: url(../img/bg-comment.jpg);
  background-repeat: repeat-y;
  background-size: auto;
  background-position: top;
}

.section.section__support {
  background-image: url(../img/bg-support.jpg);
  background-repeat: repeat-y;
  background-size: auto;
  background-position: top;
}

.section.section__support .bg-clips {
  background-image: url(../img/bg-clips.jpg);
  background-repeat: no-repeat;
  background-size: auto;
  background-position: bottom right;
  min-height: 23rem;
}

.section.section__director {
  background-image: url(../img/bg-director.jpg);
  background-repeat: no-repeat;
  background-size: auto;
  background-position: bottom right;
}

.section.section__panel {
  min-height: 20rem;
}

.section.section__panel.panel1 .accent::after {
  background-image: url(../img/border2.png);
}

.section.section__panel.panel2 .accent::after {
  background-image: url(../img/border5.png);
}

.section.section__panel .img-computer {
  position: absolute;
  right: 15px;
  top: 0;
}

.section.section__panel .img-flower {
  position: absolute;
  right: 0;
  top: -7rem;
}

.section.section__panel .img-books {
  position: absolute;
  right: 0;
  top: -5rem;
}

.section.section__panel .img-girl {
  position: absolute;
  right: 0;
  bottom: 0;
}

.section.section__metr .table .thead > div > div,
.section.section__metr .table .tbody > div > div {
  min-height: 8rem;
}

.section.section__metr .table-metr .tbody > div > div:last-child {
  border: none !important;
}

.section.section__metr .table-metr .tbody > div:first-child > div:last-child {
  position: relative;
}

.section.section__metr .table-metr .tbody > div:first-child > div:last-child::before {
  content: "";
  background-image: url(../img/img-loupe.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  height: 43rem;
  width: 25rem;
  position: absolute;
  right: 0;
  top: -50px;
}

.section.section__metr .table-pay .tbody > div:first-child > div {
  border-top: none !important;
}

.section.section__metr .table-pay .tbody > div:last-child > div {
  border-bottom: none !important;
}

.section.section__metr .table-pay .accent::after {
  background-image: url(../img/border4.png);
  left: -30px;
  height: 135%;
  margin-bottom: -1.5em;
}

.section.section__metr .img-loupe {
  position: absolute;
  right: 0;
  top: -50px;
}

.section.section__metr .caption .accent::after {
  background-image: url(../img/border3.png);
  left: 0;
  margin-bottom: -1.25em;
}

.section.section__calculator .table .thead > div > div,
.section.section__calculator .table .tbody > div > div {
  min-height: 6rem;
}

.section.section__calculator .accent::after {
  background-image: url(../img/border6.png);
}

.section.section__calculator .img-calculator {
  position: absolute;
  bottom: 5rem;
  left: 3px;
}

.article {
  color: #646464;
}

.article::before,
.article::after {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  clear: both;
  content: "";
}

.article h1,
.article h2 {
  color: #000;
  font-weight: 700;
}

.article h3,
.article h4,
.article h5,
.article h6 {
  color: #000;
  font-weight: 400;
  text-shadow: 0 0 0;
}

.article p {
  margin-bottom: 2.5rem;
}

.article > img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-bottom: 25px;
}

.article > * {
  margin-bottom: 1.5rem;
}

.article > *:last-child {
  margin-bottom: 0;
}

.article blockquote,
.article .blockquote {
  font-family: "Balsamiq Sans", cursive;
  font-weight: 700;
  padding-left: 7rem;
  position: relative;
}

.article blockquote::before,
.article .blockquote::before {
  content: "";
  background-image: url(../img/icon-blockquote.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  height: 3rem;
  width: 3rem;
  position: absolute;
  left: 0;
  top: 0;
}

.card {
  background-color: transparent;
  border-radius: 1rem;
}

.card .card-picture {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}

.card .card-title {
  color: #353a3e;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.05rem;
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.card .card-text {
  line-height: 1.2;
}

.card .card-header,
.card .card-footer {
  background-color: #e8e8e8;
  border: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.table .thead > div,
.table .tbody > div {
  margin: 0;
  position: relative;
  -webkit-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.table .thead > div > div,
.table .tbody > div > div {
  margin: 0;
  padding: 0.5rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.table-row .tbody > div > div {
  border-top: 1px solid;
  border-color: #000;
}

.table-row .tbody > div:last-child > div {
  border-bottom: 1px solid;
  border-color: #000;
}

.table-row.tblack .tbody > div + div > div {
  border-color: #000;
}

.table-row.tblack .tbody > div:first-child > div {
  border-color: #000;
}

.table-row.twhite .tbody > div + div > div {
  border-color: #f5f6f6;
}

.table-row.twhite .tbody > div:first-child > div {
  border-color: #f5f6f6;
}

.table-row.tgray .tbody > div + div > div {
  border-color: #adb5bd;
}

.table-row.tgray .tbody > div:first-child > div {
  border-color: #adb5bd;
}

.table-painted .thead > div >,
.table-painted .tbody > div > {
  margin: -2px;
}

.table-painted .thead > div > div,
.table-painted .tbody > div > div {
  border: 2px solid #FFF;
  background-color: #f6f6f6;
}

.table-striped .thead > div > div,
.table-striped thead > tr > td,
.table-striped thead > th > td {
  background-color: #ebebeb;
}

.table-striped .tbody > div > div,
.table-striped tbody > tr > tr {
  background-color: #FFF;
}

.table-striped .tbody > div:nth-of-type(even) > div,
.table-striped tbody > tr:nth-of-type(even) > td {
  background-color: #ebebeb;
}

.table-dotted .tbody > div:before {
  content: "";
  display: block;
  border-bottom: 2px dotted;
  border-color: inherit;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}

.table-dotted .tbody > div > div {
  display: inline;
  -ms-flex-pack: end;
  -webkit-box-pack: end;
          justify-content: flex-end;
}

.table-dotted .tbody > div > div > span {
  position: relative;
  z-index: 1;
  background-color: #FFF;
}

.icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  text-decoration: none;
  background-repeat: no-repeat;
  background-position: center;
  -webkit-box-shadow: none;
          box-shadow: none;
  opacity: 1;
}

.icon-group-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}

.icon-group-links .icon {
  border-radius: 50%;
  min-height: auto;
  height: 4rem;
  width: 4rem;
  font-size: 2.6rem;
  font-weight: 600;
  color: #FFF;
  text-decoration: none;
  opacity: 1;
  -webkit-transition: all 0.15s ease-in-out;
  -o-transition: all 0.15s ease-in-out;
  transition: all 0.15s ease-in-out;
}

.icon-group-links .icon:hover {
  color: #FFF;
  opacity: 0.8;
}

/* form */

.form textarea:focus,
.form input:focus {
  outline: none !important;
}

.form-simple .form-control {
  background-color: transparent;
  border: none;
  border-bottom: 1px solid #414141;
  border-radius: 0;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  color: #414141;
}

/* select */

.select .dropdown-menu {
  padding: 0;
}

.select .dropdown-menu > .inner {
  overflow-y: hidden !important;
}

/* phone input */

.phoneinput {
  font-family: Arial, sans-serif;
  line-height: 1;
  padding-top: 0;
  padding-bottom: 0;
}

.phoneinput::-webkit-input-placeholder {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

.phoneinput::-moz-placeholder {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

.phoneinput:-ms-input-placeholder {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

.phoneinput::-ms-input-placeholder {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

.phoneinput::placeholder {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

.phoneinput.phoneinput[placeholder] {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

/* check label */

.check-label {
  line-height: 1;
  margin-bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.check-label.disabled {
  cursor: default;
}

.check-label .btn-check {
  height: 2rem;
  width: 2rem;
  background-image: url(../img/icon-check1.png);
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  clip: none;
}

.check-label .btn-checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #FFF;
  height: 1.7rem;
  width: 1.7rem;
  font-size: 0;
  border: 1px solid #ced4da;
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}

.check-label .btn-checkbox::after {
  content: "";
  background-image: url(../img/icon-check.svg);
  background-size: 100%;
  display: block;
  height: 1.7rem;
  width: 1.7rem;
  position: absolute;
  top: -1px;
  left: -1px;
  opacity: 0;
  -webkit-transition: opacity 0.15s ease-in-out;
  -o-transition: opacity 0.15s ease-in-out;
  transition: opacity 0.15s ease-in-out;
}

.check-label .btn-radio {
  background-color: #FFF;
  height: 1.7rem;
  width: 1.7rem;
  font-size: 0;
  border: 2px solid #B0A6B8;
  border-radius: 50%;
  position: relative;
  vertical-align: middle;
  overflow: hidden;
  margin-right: 0.5rem;
}

.check-label .btn-radio::after {
  content: "";
  display: block;
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -0.3125rem;
  margin-top: -0.3125rem;
  background: transparent;
}

.check-label input {
  display: none;
}

.check-label input:checked + .btn-check {
  background-image: url(../img/icon-check2.png);
}

.check-label input:checked + .btn-checkbox::after {
  opacity: 1;
}

.check-label input:checked + .btn-radio {
  border-color: #FF6699;
}

.check-label input:checked + .btn-radio::after {
  background: #FF6699;
}

.check-label input:checked + .btn-light {
  border-color: #b0b0b0;
  background-color: #e8e8e8;
}

.owl-carousel.owl-banner .owl-stage-outer {
  overflow: visible;
}

.owl-carousel .owl-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  text-align: center;
  margin-top: 1.5rem;
  gap: 1.5rem !important;
}

.owl-carousel .owl-dots button span {
  display: block;
  height: 0.5rem;
  width: 3rem;
  background-color: #c8c8c8;
  border-radius: 0.5rem;
  -webkit-transition: all 200ms ease;
  -o-transition: all 200ms ease;
  transition: all 200ms ease;
}

.owl-carousel .owl-dots button:hover span,
.owl-carousel .owl-dots button.active span {
  background-color: #c95e1c;
}

.owl-carousel .owl-nav button {
  position: absolute;
  top: 50%;
  margin-top: -30px;
  z-index: 1;
  -webkit-transition: all 200ms ease;
  -o-transition: all 200ms ease;
  transition: all 200ms ease;
}

.owl-carousel .owl-nav button svg {
  height: 3rem;
  width: 3rem;
  -webkit-transition: all 200ms ease;
  -o-transition: all 200ms ease;
  transition: all 200ms ease;
}

.owl-carousel .owl-nav button.owl-next,
.owl-carousel .owl-nav button.owl-prev {
  display: block;
  height: 6rem;
  width: 3rem;
  background-color: #e8e8e8;
}

.owl-carousel .owl-nav button.owl-next {
  right: 0;
}

.owl-carousel .owl-nav button.owl-prev {
  left: 0;
}

.owl-carousel .owl-nav button:hover.owl-next,
.owl-carousel .owl-nav button:hover.owl-prev {
  background-color: #e16b21;
}

.owl-carousel .owl-nav button:hover svg {
  color: #FFF;
}

.owl-carousel.owl-product .owl-nav button {
  margin-top: -50px;
}

.owl-carousel.owl-product .owl-nav button.owl-next {
  right: 0;
}

.owl-carousel.owl-product .owl-nav button.owl-prev {
  left: 0;
}

.owl-carousel.owl-banner {
  overflow: visible;
}

.owl-carousel.owl-banner .owl-nav button {
  opacity: 0;
}

.owl-carousel.owl-banner .owl-nav button.owl-next,
.owl-carousel.owl-banner .owl-nav button.owl-prev {
  height: 6rem;
  width: 6rem;
  border-radius: 50%;
}

.owl-carousel.owl-banner .owl-nav button.owl-next {
  -webkit-clip-path: polygon(0 0, 50% 0, 50% 100%, 0% 100%);
          clip-path: polygon(0 0, 50% 0, 50% 100%, 0% 100%);
  right: -3rem;
}

.owl-carousel.owl-banner .owl-nav button.owl-next svg {
  margin-right: 3rem;
}

.owl-carousel.owl-banner .owl-nav button.owl-prev {
  -webkit-clip-path: polygon(50% 0, 100% 0%, 100% 100%, 50% 100%);
          clip-path: polygon(50% 0, 100% 0%, 100% 100%, 50% 100%);
  left: -3rem;
}

.owl-carousel.owl-banner .owl-nav button.owl-prev svg {
  margin-left: 3rem;
}

.owl-carousel:hover .owl-nav button {
  opacity: 1;
}

.owl-banner .item::before {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: rgba(255, 255, 255, 0.5);
  opacity: 1;
  -webkit-transition: 0.3s all;
  -o-transition: 0.3s all;
  transition: 0.3s all;
}

.owl-banner .owl-item.active .item::before {
  opacity: 0;
}

.owl-stretch .owl-stage {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 0;
}

.owl-nav.disabled {
  display: none;
}

.owl-carousel {
  overflow: hidden;
}

.modal {
  background-image: url(../img/bg-modal.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.modal .carousel__button {
  color: var(--fancybox-color, #000);
  top: 70px;
  right: 70px;
}

.modal .carousel__button svg {
  stroke: #000;
}

.modal#fancybox-request-result .bg-request-result {
  background-image: url(../img/bg-request-result.jpg);
  background-repeat: no-repeat;
  background-position: right;
  background-size: cover;
  min-height: 40rem;
}

.fancybox__content > .carousel__button.is-close {
  top: 70px;
  right: 70px;
}

.fancybox__slide {
  padding: 0;
}

.fancybox__container.backdrop .fancybox__content {
  padding: 0;
}

.fancybox__backdrop {
  background: var(--fancybox-bg, rgba(255, 255, 255, 0.702));
}

*[data-fancybox=youtube] {
  position: relative;
}

*[data-fancybox=youtube] svg {
  position: absolute;
  left: 50%;
  top: 50%;
  height: 30% !important;
  width: 30% !important;
  margin-top: -15%;
  margin-left: -15%;
  color: red;
}

*[data-fancybox=youtube]:hover::after {
  opacity: 0.9;
}

.list-circle {
  position: relative;
}

.list-circle > * {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
}

.list-circle > *:before {
  content: "";
  display: inline-block;
  padding: 4px;
  height: 8px;
  width: 8px;
  border-radius: 4px;
  margin-right: 0.5em;
  margin-top: 0.45em;
  position: relative;
}

.list-circle.circle-black > *:before {
  background-color: #000;
}

.list-circle.circle-blue > *:before {
  background-color: #6c9be0;
}

.list-check {
  position: relative;
}

.list-check > * {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
}

.list-check > *:before {
  content: "";
  display: block;
  height: 1em;
  width: 1em;
  padding: 0.5em;
  background-repeat: no-repeat;
  background-size: 100%;
  margin-top: 0.2em;
  margin-right: 0.5em;
  position: relative;
}

.list-check.check-white > *:before {
  background-image: url(../img/check-white.png);
}

.list-check.check-blue > *:before {
  background-image: url(../img/check-blue.png);
}

*[class*=animation] {
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

[class*=a__flter] {
  position: relative;
}

.animation:hover [class*=a__flter]:before,
.animation:hover [class*=a__flter]:after {
  opacity: 1;
}

[class*=a__flter]:hover:before,
[class*=a__flter]:hover:after {
  opacity: 1;
}

.a__scale:hover,
.animation:hover .a__scale {
  -webkit-transform: scale(1.2);
      -ms-transform: scale(1.2);
          transform: scale(1.2);
}

.animation.a__top {
  position: relative;
  top: 0;
}

.animation *[class*=a__flter]:before,
.animation *[class*=a__flter]::after {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  width: 100%;
  font-size: 0;
  top: 0;
  left: 0;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease-in-out;
  -o-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
}

.animation .a__flterlight:after {
  background-color: rgba(255, 255, 255, 0.25);
}

.animation .a__flterdark:after {
  background-color: rgba(0, 0, 0, 0.15);
}

.animation:hover.a__top {
  top: -1rem;
}

.animation:hover.a__shadow {
  -webkit-box-shadow: 0px 5px 6.65px 0.35px rgba(0, 0, 0, 0.2);
          box-shadow: 0px 5px 6.65px 0.35px rgba(0, 0, 0, 0.2);
}

@-webkit-keyframes my_animation {
  0% {
    -webkit-transform: translateY(-40px);
            transform: translateY(-40px);
  }

  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes my_animation {
  0% {
    -webkit-transform: translateY(-40px);
            transform: translateY(-40px);
  }

  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@media (max-width: 1199.98px) {
  body {
    font-size: 1.4rem;
  }

  h1,
  .h1 {
    font-size: 2.4rem;
  }

  h2,
  .h2 {
    font-size: 2.4rem;
  }

  h3,
  .h3 {
    font-size: 1.8rem;
  }

  h4,
  .h4 {
    font-size: 1.8rem;
  }

  h5,
  .h5 {
    font-size: 1.6rem;
  }

  footer .footer-top {
    height: 11rem;
  }

  footer .footer-middle {
    min-height: 28rem;
  }

  #navbarNav .nav-link {
    font-size: 1.4rem;
  }

  #navbarMobile .nav-link {
    font-size: 1.25rem;
  }

  .fixed-top #navbarNav .nav-link {
    font-size: 1.25rem;
  }

  .section .caption .icon {
    max-width: 36px;
  }

  .section.section__banner {
    min-height: 40rem;
  }

  .section.section__client {
    min-height: 46rem;
  }

  .section.section__client .img-book {
    top: -25px;
    max-width: 100px;
  }

  .section.section__panel {
    min-height: 12rem;
  }

  .section.section__panel .img-computer {
    max-width: 26rem;
  }

  .section.section__panel .img-flower {
    top: -4rem;
    max-width: 17rem;
  }

  .section.section__panel .img-books {
    top: -2rem;
    max-width: 14rem;
  }

  .section.section__panel .img-girl {
    max-width: 28rem;
  }

  .section.section__metr .table-metr .tbody > div:first-child > div:last-child {
    position: relative;
  }

  .section.section__metr .table-metr .tbody > div:first-child > div:last-child::before {
    top: -60px;
    max-width: 20rem;
  }

  .section.section__metr .img-metr {
    max-width: 20rem;
  }

  .section.section__metr .img-loupe {
    max-width: 20rem;
    top: -15px;
  }

  .section.section__calculator .img-calculator {
    max-width: 16rem;
    bottom: 2.5rem;
  }

  .article blockquote,
  .article .blockquote {
    padding-left: 4rem;
  }

  .article blockquote::before,
  .article .blockquote::before {
    content: "";
    height: 2.5rem;
    width: 2.5rem;
  }

  .modal#fancybox-request-result {
    max-width: 500px !important;
    font-weight: 700;
  }

  .modal#fancybox-request-result .caption {
    font-weight: 700;
  }

  .modal#fancybox-request-result .bg-request-result {
    min-height: auto;
    background-position: right;
  }

  .fancybox__content > .carousel__button.is-close {
    top: 50px;
    right: 50px;
  }
}

@media (max-width: 991.98px) {
  #navbarNav .nav-link {
    font-size: 1rem;
  }

  #navbarMobile .nav-link {
    font-size: 0.9rem;
  }

  .fixed-top #navbarNav .nav-link {
    font-size: 0.9rem;
  }

  .section.section__metr .table .thead > div > div,
  .section.section__metr .table .tbody > div > div {
    min-height: 6rem;
  }

  .section.section__metr .table-metr .tbody > div:first-child > div:last-child {
    position: relative;
  }

  .section.section__metr .table-metr .tbody > div:first-child > div:last-child::before {
    top: -80px;
    max-width: 17rem;
    right: -30px;
  }

  .section.section__metr .table-pay .accent::after {
    background-size: 85%;
  }
}

@media (max-width: 767.98px) {
  h1,
  .h1 {
    font-size: 2rem;
  }

  h2,
  .h2 {
    font-size: 2rem;
  }

  footer .footer-top {
    height: auto;
    text-align: center;
  }

  footer .footer-top .title {
    font-weight: 400;
  }

  footer .footer-middle {
    min-height: auto;
    text-align: center;
  }

  footer .footer-middle .logo {
    display: block;
    max-width: 20rem;
    margin: 0 auto;
  }

  footer .icon-group-links .icon {
    height: 2.5rem;
    width: 2.5rem;
    font-size: 1.6rem;
  }

  #navbar {
    background-color: #364657;
    height: 3rem;
  }

  #navbar .icon-group-links .icon {
    height: 2rem;
    width: 2rem;
    font-size: 1.4rem;
  }

  #navbarNav {
    position: fixed;
    top: 0;
    left: 0;
    -webkit-box-shadow: 3px 1px 0px 0px rgba(0, 0, 0, 0.47);
            box-shadow: 3px 1px 0px 0px rgba(0, 0, 0, 0.47);
    width: 25rem;
    background-color: #2b3846;
    z-index: 1055;
  }

  #navbarNav nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
  }

  #navbarNav .nav-item {
    margin-top: 0;
    width: 100%;
  }

  #navbarNav .nav-item + .nav-item {
    border-top: 1px solid #3d4f62;
  }

  #navbarNav .nav-item .nav-link {
    font-size: 1.6rem;
    color: #96c7fd;
    padding: 0.75rem 1.5rem;
    min-height: 5rem;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    text-align: left;
    text-decoration: none !important;
  }

  #navbarNav .nav-item .nav-link:hover,
  #navbarNav .nav-item .nav-link:focus {
    color: #96c7fd;
    background-color: #202a34;
  }

  #navbarMobile .nav-link {
    color: #fff !important;
    font-size: 1.6rem !important;
    min-height: 3rem;
  }

  #navbarMobile .phone .nav-link {
    padding-right: 0;
  }

  .fixed-top#navbar {
    -webkit-animation: none !important;
            animation: none !important;
  }

  .section.section__banner {
    min-height: auto;
    background-position: 62% 0;
  }

  .section.section__client {
    min-height: auto;
  }

  .section.section__client .img-book {
    top: -25px;
    right: 15px;
    max-width: 65px;
  }

  .section.section__client .icon {
    max-width: 36px;
  }

  .section.section__director {
    background-position: 30% 0;
    background-position-x: 80%;
    background-position-y: 100%;
  }

  .section.section__panel {
    min-height: auto;
  }

  .section.section__panel .img-computer {
    max-width: 11rem;
  }

  .section.section__metr .table-metr .tbody > div:first-child > div:last-child {
    position: relative;
  }

  .section.section__metr .table-metr .tbody > div:first-child > div:last-child::before {
    max-width: 12rem;
    top: -107px;
    right: 50%;
    margin-right: -6rem;
  }

  .section.section__metr .table-pay .accent::after {
    background-size: 95%;
    left: -20px;
  }

  .section.section__support .bg-clips {
    background-size: contain;
    min-height: 12rem;
  }

  .section.section__calculator .img-calculator {
    max-width: 14rem;
    bottom: 5px;
  }

  .article blockquote,
  .article .blockquote {
    padding-left: 3rem;
  }

  .article blockquote::before,
  .article .blockquote::before {
    content: "";
    height: 2rem;
    width: 2rem;
  }

  .fancybox__content > .carousel__button.is-close {
    top: 20px;
    right: 15px;
  }
}

.webp footer .footer-top { background-image: url(../img/bg-footer-top.webp); }

.webp footer .footer-middle { background-image: url(../img/bg-footer-middle.webp); }

.webp .section.section__banner { background-image: url(../img/bg-banner.webp); }

.webp .section.section__banner .accent::after { background-image: url(../img/border1.webp); }

.webp .section.section__client { background-image: url(../img/bg-client.webp); }

.webp .section.section__comment { background-image: url(../img/bg-comment.webp); }

.webp .section.section__support { background-image: url(../img/bg-support.webp); }

.webp .section.section__support .bg-clips { background-image: url(../img/bg-clips.webp); }

.webp .section.section__director { background-image: url(../img/bg-director.webp); }

.webp .section.section__panel.panel1 .accent::after { background-image: url(../img/border2.webp); }

.webp .section.section__panel.panel2 .accent::after { background-image: url(../img/border5.webp); }

.webp .section.section__metr .table-metr .tbody > div:first-child > div:last-child::before { background-image: url(../img/img-loupe.webp); }

.webp .section.section__metr .table-pay .accent::after { background-image: url(../img/border4.webp); }

.webp .section.section__metr .caption .accent::after { background-image: url(../img/border3.webp); }

.webp .section.section__calculator .accent::after { background-image: url(../img/border6.webp); }

.webp .article blockquote::before, .webp .article .blockquote::before { background-image: url(../img/icon-blockquote.webp); }

.webp .check-label .btn-check { background-image: url(../img/icon-check1.webp); }

.webp .check-label input:checked + .btn-check { background-image: url(../img/icon-check2.webp); }

.webp .modal { background-image: url(../img/bg-modal.webp); }

.webp .modal#fancybox-request-result .bg-request-result { background-image: url(../img/bg-request-result.webp); }

.webp .list-check.check-white > *:before { background-image: url(../img/check-white.webp); }

.webp .list-check.check-blue > *:before { background-image: url(../img/check-blue.webp); }


/*Header*/

.standard-logo {
    float: left;
    vertical-align: middle;
	margin-right: 10px;
}
 
.slogan {
    padding-left: 10px;
    border-left: 1px solid #364657;
    display: inline-block;
    position: relative;
    top: 7px;
 
}

#header-wrap{
    margin: 15px 0 20px;
}

.headadress {
	font-size: 14px;
	    line-height: 1.3;
}

.headphone .tel {
	font-size: 18px;
    color: #646464;
    line-height: 1.5;
}

.head-zakaz {
	padding: 0;
}

.head-zakaz .btn-blue {
    position: relative;
    top: 5px;	
    min-width: 154px;
    text-align: center;
    padding: 10px 16px;
}

.head-zakaz .top-but {
    margin-top: 10px;	
}

.top-but {
    display: block;
    margin-left: 30px;
    color: #5c7591;	
}

/*Menu*/

.navbar-blue {
    background-color: #364657;
    border-color: #364657;
    margin: 0;
    border: 0;
    height: 50px;
}

.navbar-blue .navbar-nav > li > a {
    color: #fff;
	    text-align: center;
    line-height: 20px;
    font-weight: 400;
    font-size: 16px;
	border-bottom: 3px solid transparent;
}

.navbar-blue .navbar-nav > li > a:hover, .navbar-blue .navbar-nav > li > a:focus {
    color: #fff;
    background-color: #465B71;
	border-bottom: 3px solid #FFDD2E;
}

.navbar-blue .navbar-nav > li:last-child> a {
    padding-top: 9px;
    padding-bottom: 9px;
    line-height: 1;	
}

.navbar-blue .navbar-nav > .open > a, .navbar-blue .navbar-nav > .open > a:hover, .navbar-blue .navbar-nav > .open > a:focus {
    color: #fff;
    background-color: #465B71;
	border-bottom: 3px solid #FFDD2E;
}

.navbar-blue .navbar-nav > .active > a, .navbar-blue .navbar-nav > .active > a:hover, .navbar-blue .navbar-nav > .active > a:focus {
    color: #fff;
    background-color: #465B71;
	border-bottom: 3px solid #FFDD2E;
}


.navbar-blue .dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    display: none;
    float: left;
    min-width: 160px;
    padding: 0px 0;
    margin: 0px 0 0;
    font-size: 16px;
    text-align: left;
    list-style: none;
    background-color: #465B71;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    border: 1px solid #ccc;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: 0px;
    -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
    box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
}
.navbar-blue  .open > .dropdown-menu {
    display: block;
}


.navbar-blue .dropdown-menu > li > a {
    display: block;
    padding: 15px 24px;
    clear: both;
    font-weight: normal;
    line-height: 1.42857143;
    color: #fff;
    white-space: nowrap;
	border-bottom: 1px solid #262626;
}

.navbar-blue .dropdown-menu > li > a:hover, .navbar-blue .dropdown-menu > li > a:focus {
    color: #fff;
    text-decoration: none;
    background-color: #5C748E;
}

.navbar-blue .dropdown-menu > li > a:hover span, .navbar-blue .dropdown-menu > li > a:focus span {
    border-bottom: 3px solid #FFDD2E;
}
