
.button {
  min-width: 152px;
  font-size: 14px;
  font-weight: 500;
  line-height: 100%;
  text-align: left;
  padding: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: unset;
}
.button:hover {
  text-decoration: none !important;
}
.button_white {
  color: #fff;
  border: 1px solid #fff;
}
.button_white:hover {
  color: #fff !important;
}
.button_blue {
  color: rgb(29, 92, 161);
  border: 1px solid rgb(29, 92, 161);
}
.button_blue:hover {
  color: rgb(29, 92, 161) !important;
}
.button_bluefill {
  background-color: rgb(29, 92, 161);
  color: #fff;
  border: 1px solid rgb(29, 92, 161);
}
.button_bluefill:hover {
  background-color: rgb(29, 92, 161) !important;
  color: #fff !important;
}
.button_upper {
  text-transform: uppercase;
}
.button_transparent {
  background-color: transparent;
}

.about {
  background-color: #153049;
  padding: 78px 0;
  position: relative;
}
@media (width < 768px) {
  .about {
    padding: 0 0 60px 0;
  }
}
.about__decore {
  position: absolute;
  bottom: 0;
  right: 0;
}
@media (width < 768px) {
  .about__decore {
    width: 100%;
  }
}
.about__decore img {
  aspect-ratio: 2/1;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.about__inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: clamp(1.25rem, -0.089rem + 3.571vw, 3.125rem);
  align-items: start;
}
@media (width < 768px) {
  .about__inner {
    grid-template-columns: 1fr;
  }
}
@media (width < 768px) {
  .about__image {
    width: calc(100% + 30px);
    margin-left: -15px;
  }
}
.about__image img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 3/2;
}
.about__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  height: 100%;
}
.about__content p {
  color: rgb(255, 255, 255);
  font-size: 16px;
  font-weight: 400;
  text-align: left;
  line-height: 26px;
  margin: 0 0 20px 0;
}
@media (width < 768px) {
  .about__content p {
    font-size: 14px;
  }
}

.section_advantage {
  background-repeat: no-repeat;
  background-size: cover;
}
.section_feedback {
  background-color: #153049;
  background-repeat: no-repeat;
  background-size: cover;
}
.section_news {
  overflow: hidden;
}
.section_news .section__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-auto-rows: auto;
  grid-template-areas: "title link" "news news";
  justify-content: space-between;
  gap: 30px 20px;
}
@media (width < 1024px) {
  .section_news .section__inner {
    grid-template-areas: "title" "news" "link";
  }
}
.section_news .section__inner .title {
  grid-area: title;
  padding: 0;
}
.section_news .section__inner .box_news {
  grid-area: news;
}
.section_news .section__inner .news-link {
  grid-area: link;
}
@media (width < 1024px) {
  .section_news .section__inner {
    width: calc(100% + 15px);
  }
}
.section_contact {
  position: relative;
  overflow: hidden;
}
.section_contact .map {
  position: absolute;
  top: 0;
  left: 0;
}
.section_contact .section__inner {
  display: flex;
  justify-content: flex-end;
  padding: 0 30px;
  height: 100%;
}
@media (width < 768px) {
  .section_contact .section__inner {
    padding: 0 15px;
    flex-direction: column;
  }
  .section_contact .section__inner:before {
    content: "";
    display: block;
    background-color: transparent;
    height: 300px;
  }
}
.section__inner {
  max-width: 1440px;
  padding: 60px 15px;
  margin: 0 auto;
}
@media (width < 767px) {
  .section__inner {
    padding: 40px 15px;
  }
}

.title {
  padding: 0 0 30px 0;
}
.title h1,
.title h2 {
  font-size: 34px;
  font-weight: 700;
  letter-spacing: 0px;
  text-align: left;
  text-transform: uppercase;
  margin: 0 0 20px 0;
  color: black;
  margin: 0;
  padding: 0;
}
.title_white h1,
.title_white h2 {
  color: white;
}

.advantage {
  border: 1px solid rgba(0, 0, 0, 0.15);
  background-color: #fff;
}
@media (width < 767px) {
  .advantage {
    border: unset;
  }
}
.advantage__image {
  position: relative;
}
.advantage__image img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 334/298;
}
@media (width < 767px) {
  .advantage__image img {
    aspect-ratio: 370/240;
  }
}
.advantage__icon {
  background: rgba(29, 92, 161, 0.85);
  padding: 23px;
  height: 86px;
  width: 86px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 17px;
  right: 17px;
}
@media (width < 767px) {
  .advantage__icon {
    top: 9px;
    right: 9px;
  }
}
.advantage__content {
  padding: 30px;
}
@media (width < 767px) {
  .advantage__content {
    padding: 16px 0;
  }
}
.advantage__title {
  color: rgb(34, 34, 34);
  font-size: 20px;
  font-weight: 600;
  line-height: 24px;
  letter-spacing: -0.02em;
  text-align: left;
  text-transform: uppercase;
  margin-bottom: 13px;
}
.advantage__text {
  color: rgb(34, 34, 34);
  font-size: 16px;
  font-weight: 400;
  line-height: 20px;
  text-align: left;
}
.advantage__text p {
  padding: 0;
  margin: 0;
}
@media (width < 767px) {
  .advantage__text {
    font-size: 14px;
  }
}
.news-link {
  display: flex;
  align-items: center;
  color: rgb(29, 92, 161);
  font-size: 14px;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0%;
  text-align: left;
  text-transform: uppercase;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 4px;
}
.news-link:hover {
  color: rgb(29, 92, 161) !important;
}
.news-link svg {
  height: 10px;
  width: 10px;
  flex: 0 0 10px;
}

.news {
  background-color: #fff;
}
.news__image {
  position: relative;
  margin-bottom: 17px;
  display: flex;
}
.news__image img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 3/2;
}
.news__date {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(29, 92, 161, 0.85);
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.news__date svg {
  height: 12px;
  width: 12px;
  flex: 0 0 12px;
}
.news__date span {
  color: rgb(255, 255, 255);
  font-size: 14px;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0%;
  text-align: left;
}
.news__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.news__content .button {
  margin-top: 20px;
}
.news__title {
  color: rgb(34, 34, 34);
  font-size: 20px;
  font-weight: 600;
  line-height: 24px;
  letter-spacing: -0.02em;
  text-align: left;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.news__text {
  color: rgb(34, 34, 34);
  font-family: Roboto;
  font-size: 16px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: 0%;
  text-align: left;
}
.news__text p {
  padding: 0;
  margin: 0;
}

form.form-feedback input,
form.form-feedback textarea,
form.form-feedback select,
form.form-feedback button {
  outline: none;
  border: none;
  margin: 0;
}
form.form-feedback button,
form.form-feedback input {
  line-height: normal;
}
form.form-feedback fieldset {
  border: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 24px;
}
@media (width < 1024px) {
  form.form-feedback fieldset {
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 10px 24px;
  }
}
@media (width < 768px) {
  form.form-feedback fieldset {
    grid-template-columns: 1fr;
    grid-gap: 10px;
  }
}
form.form-feedback label {
  display: flex;
  flex-direction: column;
  position: relative;
  padding: 0 0 30px 0;
}
@media (width < 768px) {
  form.form-feedback label {
    padding: 0 0 16px 0;
  }
}
form.form-feedback input:not([type=checkbox]) {
  border: 1px solid rgb(226, 232, 240);
  background: rgb(255, 255, 255);
  height: 52px;
  padding: 0 20px;
  color: rgb(108, 126, 147);
  font-size: 16px;
  font-weight: normal;
}
form.form-feedback input:not([type=checkbox]).error {
  border-color: red;
  background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23e74c3c"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"/></svg>');
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 20px;
  background-color: #fef7f7;
}
form.form-feedback button[type=submit] {
  height: 52px;
  cursor: pointer;
}
form.form-feedback span.error {
  position: absolute;
  color: #fff;
  bottom: 4px;
  font-size: 14px;
}
@media (width < 768px) {
  form.form-feedback span.error {
    font-size: 12px;
    bottom: -2px;
  }
}
form.form-feedback .form__policy {
  display: flex;
  justify-content: flex-end;
}
@media (width < 768px) {
  form.form-feedback .form__policy {
    padding: 20px 0 0 0;
  }
}
form.form-feedback .form__policy label {
  flex-direction: row;
  padding: 0;
  color: rgba(255, 255, 255, 0.5);
  font-size: 12px;
  font-weight: 400;
  line-height: 100%;
  text-align: left;
}
form.form-feedback .form__policy label input {
  margin-right: 10px;
  height: 13px;
  width: 13px;
  flex: 0 0 13px;
}
form.form-feedback .form__policy label a {
  color: rgba(255, 255, 255, 0.5);
}
form.form-feedback .form__policy label a:hover {
  color: #fff;
}

.map {
  width: 100%;
  height: 100%;
}
.map iframe {
  height: 100%;
}

.contact {
  position: relative;
  background: rgba(21, 48, 73, 0.85);
  padding: 64px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (width < 768px) {
  .contact {
    width: calc(100% + 30px);
    margin-left: -15px;
    padding: 34px 15px;
  }
}
.contact__title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.contact__title svg {
  height: 20px;
  width: 20px;
  flex: 0 0 20px;
}
.contact__title span {
  color: #fff;
  font-size: 14px;
  font-weight: 400;
  text-align: left;
}
.contact__item ul {
  padding: 0;
  margin: 0;
}
.contact__item ul li {
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 35px;
  text-align: left;
  color: #fff;
}
.contact__item ul li a {
  color: #fff;
  text-decoration: none;
}
.contact__item ul li a:hover {
  color: #fff !important;
}
.contact__item ul li a[href^=tel] {
  font-size: 21px;
}

.footer_2025 {
  background: rgb(21, 48, 73);
}
.footer_2025 .section__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-gap: 24px;
  grid-template-areas: "logo nav buttons" "link nav developer";
}
@media (width < 1110px) {
  .footer_2025 .section__inner {
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "logo buttons" "nav nav" "link developer";
  }
}
@media (width < 600px) {
  .footer_2025 .section__inner {
    grid-template-columns: 1fr;
    grid-template-areas: "logo" "nav" "buttons" "link" "developer";
  }
}
.footer_2025 .footer__box[data-footer=logo] {
  grid-area: logo;
}
.footer_2025 .footer__box[data-footer=nav] {
  grid-area: nav;
  display: flex;
  gap: 70px;
  justify-content: center;
}
@media (width < 600px) {
  .footer_2025 .footer__box[data-footer=nav] {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
}
.footer_2025 .footer__box[data-footer=buttons] {
  grid-area: buttons;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-end;
}
@media (width < 600px) {
  .footer_2025 .footer__box[data-footer=buttons] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    justify-content: space-between;
  }
}
.footer_2025 .footer__box[data-footer=buttons] .button {
  max-width: 208px;
  width: 100%;
}
@media (width < 600px) {
  .footer_2025 .footer__box[data-footer=buttons] .button {
    max-width: unset;
  }
}
.footer_2025 .footer__box[data-footer=developer] {
  grid-area: developer;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
}
@media (width < 600px) {
  .footer_2025 .footer__box[data-footer=developer] {
    align-items: center;
    justify-content: center;
  }
}
.footer_2025 .footer__box[data-footer=link] {
  grid-area: link;
  display: flex;
  align-items: center;
}
@media (width < 600px) {
  .footer_2025 .footer__box[data-footer=link] {
    align-items: center;
    justify-content: center;
  }
}
.footer_2025 .footer__box[data-footer=link] a {
  color: rgba(255, 255, 255, 0.5);
  font-size: 11px;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0%;
  text-align: left;
  text-decoration-line: underline;
}
.footer_2025 .footer__logo {
  display: flex;
  gap: 10px;
  align-items: center;
}
@media (width < 600px) {
  .footer_2025 .footer__logo {
    flex-direction: column;
    align-items: center;
  }
}
.footer_2025 .footer__logo strong {
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  line-height: 33.1px;
  text-align: left;
}
.footer_2025 .footer__logo p {
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  font-weight: normal;
}
@media (width < 600px) {
  .footer_2025 .footer__logo p {
    text-align: center;
  }
}
.footer_2025 .footer__developer {
  display: flex;
  align-items: center;
  gap: 8px;
  color: rgba(255, 255, 255, 0.7);
  font-size: 12px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: 0%;
  text-align: left;
  text-decoration: none;
}
.footer_2025 .footer__developer span span {
  text-decoration: underline;
}

.nav-footer[data-nav=upper] {
  text-transform: uppercase;
}
.nav-footer:not([data-nav=upper]) {
  -moz-column-count: 2;
       column-count: 2;
  -moz-column-gap: 40px;
       column-gap: 40px;
}
@media (width < 600px) {
  .nav-footer:not([data-nav=upper]) {
    -moz-columns: unset;
         columns: unset;
  }
}
.nav-footer ul {
  padding: 0;
  margin: 0;
}
.nav-footer ul li {
  padding: 0;
  margin: 0;
  list-style: none;
}
@media (width < 600px) {
  .nav-footer ul li {
    text-align: center;
  }
}
.nav-footer a {
  color: rgb(255, 255, 255);
  font-size: 14px;
  font-weight: 400;
  line-height: 33.1px;
  letter-spacing: 0px;
  text-align: left;
  text-decoration: none;
}