html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}
:focus {
    outline: 0;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
    display: block;
}
ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
    -webkit-appearance: none;
    -moz-appearance: none;
}
input[type=search] {
    -webkit-appearance: none;
    -moz-appearance: none;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
}
textarea {
    overflow: auto;
    vertical-align: top;
    resize: vertical;
}
audio,
canvas,
video {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    max-width: 100%;
}
audio:not([controls]) {
    display: none;
    height: 0;
}
[hidden] {
    display: none;
}
html {
    font-size: 100%; /* 1 */
    -webkit-text-size-adjust: 100%; /* 2 */
    -ms-text-size-adjust: 100%; /* 2 */
}
a:focus {
    outline: thin dotted;
}
a:active,
a:hover {
    outline: 0;
}
img {
    border: 0; /* 1 */
    -ms-interpolation-mode: bicubic; /* 2 */
}
figure {
    margin: 0;
}
form {
    margin: 0;
}
fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}
legend {
    border: 0; /* 1 */
    padding: 0;
    white-space: normal; /* 2 */
    *margin-left: -7px; /* 3 */
}
button,
input,
select,
textarea {
    font-size: 100%; /* 1 */
    margin: 0; /* 2 */
    vertical-align: baseline; /* 3 */
    *vertical-align: middle; /* 3 */
}
button,
input {
    line-height: normal;
}
button,
select {
    text-transform: none;
}
button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button; /* 2 */
    cursor: pointer; /* 3 */
    *overflow: visible;  /* 4 */
}
button[disabled],
html input[disabled] {
    cursor: default;
}
input[type="checkbox"],
input[type="radio"] {
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
    *height: 13px; /* 3 */
    *width: 13px; /* 3 */
}
input[type="search"] {
    -webkit-appearance: textfield; /* 1 */
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box; /* 2 */
    box-sizing: content-box;
}
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0;
}
textarea {
    overflow: auto; /* 1 */
    vertical-align: top; /* 2 */
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
html,
button,
input,
select,
textarea {
    color: #222;
}
::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}
::selection {
    background: #b3d4fc;
    text-shadow: none;
}
img {
    vertical-align: middle;
}
fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}
textarea {
    resize: vertical;
}
* {
    box-sizing: border-box;
}
html {
    overflow-x: hidden;
    text-rendering: optimizeLegibility;
}
body {
    padding-right: 0 !important;
    background: linear-gradient(180deg, #181818 0%, #031E7B 100%);
    position: relative;
    overflow-x: hidden;
    transition: .4s;
}
body * {
    transition: .4s;
}
body.no-scroll {
    overflow: hidden;
    height: 100vh;
}
a, a:hover, a:active, a:focus, textarea,
button, input, button:hover, button:active, button:focus,
input:focus, input:active {
    text-decoration: none !important;
    outline: none !important;
}
p,a,li,div,button,input,textarea {
    font-family: "Stem", sans-serif;
    color: #fff;
    font-size: 24px;
    font-weight: 300;
    line-height: 30px;
}
strong {
    font-weight: 500;
}
i {
    font-style: italic;
}
input.button,
button {
    border: none;
}
a {
    cursor: pointer;
}
.compensate-for-scrollbar {
    margin-right: 0 !important;
}
.wrp {
    width: 1067px;
    margin: 0 auto;
}
.main-wrp {
    width: 1520px;
}
h2 {
 color: #CCC;
 font-size: 64px;
 font-weight: 350;
 line-height: 40px;
 width: max-content;
 margin: 0 auto;
}
.orange-span {
 color: #89D9FF;
 font-weight: 700;
}

.modal-button {
    display: block;
    width: 306px;
    height: 306px;
    border-radius: 306px;
    background: linear-gradient(139deg, #86E8A0 13.85%, #018DED 86.41%);
    backdrop-filter: blur(30px);
    text-align: center;
    padding-top: 125px;
    position: absolute;
    top: 846px;
    right: calc(50% - 763px);
    z-index: 4;
}
.modal-button:before {
    content: "";
    width: 386px;
    height: 386px;
    border-radius: 50%;
    background: url(../img/backcall-ellipse2.png) no-repeat center bottom / 100%;
    position: absolute;
    top: -40px;
    left: -40px;
    animation: spin2 5s linear 0s infinite forwards;
}
.modal-button:after {
    content: "";
    width: 486px;
    height: 486px;
    border-radius: 50%;
    background: url(../img/backcall-ellipse1.png) no-repeat center center / 580px;
    position: absolute;
    top: -89px;
    left: -89px;
    animation: spin 5s linear 0s infinite forwards;
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  16.67% {
    transform: rotate(60deg);
  }
  33.33% {
    transform: rotate(120deg);
  }
  50% {
    transform: rotate(180deg);
  }
  66.67% {
    transform: rotate(240deg);
  }
  83.33% {
    transform: rotate(300deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes spin2 {
  0% {
    transform: rotate(0deg);
  }
  16.67% {
    transform: rotate(-60deg);
  }
  33.33% {
    transform: rotate(-120deg);
  }
  50% {
    transform: rotate(-180deg);
  }
  66.67% {
    transform: rotate(-240deg);
  }
  83.33% {
    transform: rotate(-300deg);
  }
  100% {
    transform: rotate(-360deg);
  }
}
.modal-button span:nth-child(1) {
    color: #FFF;
    font-size: 64px;
    font-weight: 700;
    line-height: 20px;
    display: block;
    position: relative;
    z-index: 2;
}
.modal-button span:nth-child(2) {
    color: #FFF;
    font-size: 21px;
    font-weight: 700;
    line-height: 52px;
    display: block;
    margin-bottom: 0px;
    position: relative;
    z-index: 2;
}
.modal-button img {
    position: relative;
    z-index: 2;
}
@media (max-width: 1560px) {
    .modal-button {
        right: calc(50% - 572px);
    }
}
@media (max-width: 768px) {
    .modal-button:before {
        width: 50vw;
        height: 50vw;
        top: -5vw;
        left: -5vw;
    }
    .modal-button:after {
        width: 55vw;
        height: 55vw;
        background: url(../img/backcall-ellipse1.png) no-repeat center center / 75vw;
        top: -7.5vw;
        left: -7.5vw;
    }
}

/* about */

#about {
    padding-bottom: 250px;
    position: relative;
}
#about:before {
    content: "";
    width: 100%;
    height: 200%;
    background: url("../img/circles.svg") no-repeat top center;
    position: absolute;
    top: -1200px;
}
#about .wrp {
    width: calc(100% - 200px);
    max-width: 1534px;
    position: relative;
    z-index: 3;
}

.about-module {
    position: relative;
}
.about-module p {
    color: #FFF;
    font-size: 36px;
    font-weight: 700;
    line-height: 40px;
    margin-bottom: 45px;
}
.about-module ul {
    padding-left: 60px;
}
.about-module ul li {
    color: #FFF;
    font-size: 24px;
    font-weight: 300;
    line-height: normal;
    padding-left: 20px;
    position: relative;
}
.about-module ul li:before {
    content: "";
    width: 3px;
    height: 3px;
    border-radius: 50%;
    position: absolute;
    background: #fff;
    top: 13px;
    left: 0;
}

#module-1 {
    padding-bottom: 86px;
}
#module-1 .date {
    width: 935px;
    height: 150px;
    background: url("../img/date-1.svg") no-repeat center center / 100%;
    margin-bottom: 98px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    left: 30px;
}
#module-1 > .about-module-text {
    padding-left: 493px;
}
#module-1 > img {
    position: absolute;
    left: 0;
    top: 140px;
}
#module-1 .bottom {
    display: flex;
    justify-content: space-between;
    padding-top: 86px;
    position: relative;
}
#module-1 .bottom .about-module-text:nth-child(1) {
    width: 650px;
}
#module-1 .bottom .about-module-text:nth-child(2) {
    width: 837px;
}
#module-1 .bottom img {
    position: absolute;
    left: 763px;
    bottom: 42px;
}

#module-2 {
    padding-bottom: 86px;
}
#module-2 .date {
    width: 935px;
    height: 150px;
    background: url("../img/date-2.svg") no-repeat center center / 100%;
    margin-bottom: 98px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    left: 30px;
}
#module-2 .about-module-text {
    margin-left: auto;
    width: 567px;
}
#module-2 .about-module-text ul {
    padding-right: 70px;
}
#module-2 img:nth-child(3) {
    position: absolute;
    top: 0;
    right: 0;
}
#module-2 img:nth-child(4) {
    position: absolute;
    left: 0;
    top: 160px;
}
#module-2 img:nth-child(5) {
    position: absolute;
    left: 485px;
    top: 280px;
}

#module-3 {
    padding-bottom: 132px;
}
#module-3 .date {
    width: 935px;
    height: 150px;
    background: url("../img/date-3.svg") no-repeat center center / 100%;
    margin-bottom: 98px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    left: 30px;
}
#module-3 .about-module-text {
    margin-left: auto;
    width: 567px;
}
#module-3 img {
    position: absolute;
    left: 0;
    bottom: 236px;
}
#module-3 .img-1440 {
    display: none;
}
#module-3 .img-1024 {
    display: none;
}
#module-3 .img-768 {
    display: none;
}

@media (max-width: 1600px) {
    #about {
        padding-bottom: 200px;
    }
    #about .wrp {
        width: calc(100% - 100px);
    }
    #module-1 .bottom .about-module-text:nth-child(2) {
        width: 650px;
    }
    #module-1 .bottom img {
        top: 400px;
        bottom: auto;
    }
    #module-2 img:nth-child(5) {
        display: none;
    }
    #module-2 img:nth-child(4) {
        left: 50px;
    }
    #module-2 .about-module-text {
        margin-right: 200px;
    }
    #module-2 img:nth-child(3) {
        top: 316px;
        right: 30px;
    }
    #module-3 .img-1920 {
        display: none;
    }
    #module-3 .img-1440 {
        display: block;
    }
    #module-3.about-module ul {
        padding-left: 150px;
    }
    #module-3 img {
        bottom: 100px;
    }
}
@media (max-width: 1438px) {
    #about {
        padding-bottom: 120px;
    }
    #module-1 .bottom .about-module-text:nth-child(1) {
        width: 424px;
    }
    #module-1 .bottom img {
        top: 450px;
        left: 80px;
    }
    #module-1 .bottom .about-module-text:nth-child(2) {
        width: 545px;
    }
    #module-2 img:nth-child(4) {
        left: 0;
    }
    #module-2 .about-module-text {
        margin-right: 119px;
    }
    #module-2 img:nth-child(3) {
        top: 340px;
        right: 0;
    }
    #module-3 img {
        width: 750px;
        bottom: 160px;
    }
    #module-3.about-module ul {
        padding-left: 192px;
    }
}
@media (max-width: 1278px) {
    #about {
        padding-bottom: 80px;
    }
    #about .wrp {
        width: calc(100% - 72px);
    }
    #module-1.about-module ul {
        padding-left: 140px;
    }
    #module-1 > .about-module-text {
        padding-left: 273px;
    }
    #module-1 > img {
        top: 240px;
    }
    #module-1 .bottom {
        padding-top: 46px;
    }
    #module-1.about-module .bottom ul {
        padding-left: 60px;
    }
    #module-1 .bottom img {
        top: 380px;
    }
    #module-1 {
        padding-bottom: 43px;
    }
    #module-2 .about-module-text {
        margin-right: 10px;
        width: 468px;
    }
    #module-2 img:nth-child(4) {
        width: 409px;
        top: 220px;
    }
    #module-2 img:nth-child(3) {
        top: 497px;
        right: 465px;
        width: 143px;
    }
    #module-2 {
        padding-bottom: 43px;
    }
    #module-3.about-module ul {
        padding-left: 186px;
    }
    #module-3 .img-1440 {
        display: none;
    }
    #module-3 .img-1024 {
        display: block;
        width: 604px;
        bottom: 50px;
        left: -50px;
    }
    #module-3 {
        padding-bottom: 0;
    }
}
@media (max-width: 1022px) {
    #module-1 .bottom img {
        top: 500px;
    }
    #module-1 .date,
    #module-2 .date,
    #module-3 .date {
        width: 100%;
    }
    #module-2 .about-module-text {
        margin-right: 0;
        width: 100%;
        padding-bottom: 340px;
    }
    #module-2 img:nth-child(4) {
        top: 550px;
    }
    #module-2 img:nth-child(3) {
        top: 700px;
        right: 100px;
        width: 143px;
    }
    #module-3 .img-1024 {
        width: 350px;
    }
}
@media (max-width: 768px) {
    #about {
        padding-bottom: 0;
    }
    body:before {
        content: "";
        width: 100%;
        height: calc(100% - 110.188vw);
        background: url(../img/circles.svg) no-repeat top center;
        position: absolute;
        top: 110.188vw;
    }
    #about:before {
        display: none;
    }
    #about .wrp {
        width: calc(100vw - 9.3vw);
    }
    #module-1 {
        padding-bottom: 12.63vw;
    }
    #module-1 .date, #module-2 .date, #module-3 .date {
        width: 88.54vw;
        left: -0.5vw;
    }
    #module-1 .date {
        margin-bottom: 4.68vw;
        height: 26vw;
        background: url("../img/date-1-mob.svg") no-repeat center left / 100%;
    }
    #module-1 > .about-module-text {
        padding-left: 0;
    }
    .about-module p {
        font-size: 4.68vw;
        line-height: 5.208vw;
        margin-bottom: 5.86vw;
    }
    .about-module ul li {
        font-size: 3.125vw;
        padding-left: 2.604vw;
    }
    .about-module ul li:before {
        width: 0.391vw;
        height: 0.391vw;
        top: 1.693vw;
    }
    #module-1.about-module ul {
        padding-left: 44.792vw;
    }
    #module-1 > img {
        top: 42.057vw;
        width: 42.578vw;
        left: -1.302vw;
    }
    #module-1 .bottom {
        padding-top: 0;
        display: block;
    }
    #module-1 .bottom .about-module-text:nth-child(1) {
        width: 54vw;
        padding-left: 1.302vw;
        position: relative;
        top: -14.5vw;
    }
    #module-1 .bottom .about-module-text:nth-child(2) {
        width: 100%;
        margin-top: -8.5vw;
    }
    #module-1.about-module .bottom ul {
        padding-left: 7.813vw;
    }
    #module-1 .bottom img {
        top: 6vw;
        width: 25.521vw;
        left: 57vw;
    }
    #module-1.about-module .bottom ul {
        padding-left: 7.813vw;
        padding-right: 2.604vw;
    }
    #module-2 .date {
        height: 26vw;
        background: url(../img/date-2-mob.svg) no-repeat center left / 100%;
        margin-bottom: 51.953vw;
    }
    #module-2 img:nth-child(4) {
        top: 31.25vw;
        width: 53.255vw;
    }
    #module-2 img:nth-child(3) {
        top: 44.661vw;
        right: 1.302vw;
        width: 27.083vw;
    }
    #module-2 .about-module-text {
        padding-bottom: 0;
    }
    #module-2 {
        padding-bottom: 12.76vw;
    }
    #module-3 {
        padding-bottom: 50vw;
    }
    #module-3 .date {
        height: 26vw;
        background: url(../img/date-3-mob.svg) no-repeat center left / 100%;
        margin-bottom: 7.161vw;
    }
    #module-3 .about-module-text {
        width: 100%;
    }
    #module-3.about-module ul {
        padding-left: 7.292vw;
    }
    #module-3 .img-1024 {
        width: 91.667vw;
        bottom: 0;
    }
    #module-3 .img-1024 {
        display: none;
    }
    #module-3 .img-768 {
        display: block;
    }
    #module-3 .img-768 {
        display: block;
        width: 91.667vw;
        bottom: 0;
    }
}


/* video */

#video {
    padding: 55px 0 105px 0;
    position: relative;
    z-index: 4;
}
#video:before {
    content: "";
    width: 555px;
    height: 493px;
    border-radius: 555px;
    background: linear-gradient(180deg, rgba(137, 217, 255, 0.00) 0%, rgba(137, 217, 255, 0.10) 46.5%);
    position: absolute;
    left: calc(50% - 270px);
    top: -99px;
}
#video:after {
    content: "";
    width: 555px;
    height: 493px;
    border-radius: 555px;
    background: linear-gradient(180deg, rgba(137, 217, 255, 0.00) 0%, rgba(137, 217, 255, 0.10) 46.5%);
    position: absolute;
    left: calc(50% - 270px);
    bottom: -240px;
    transform: rotate(180deg);
}
#video .wrp {
    position: relative;
    z-index: 2;
}
#video h2 {
    position: relative;
    left: 60px;
    margin-bottom: 51px;
}
#video h2 .orange-span {
    display: block;
    margin-left: -105px;
}
#player {
    border-radius: 25px;
}

@media (max-width: 1206px) {
    #video .wrp {
        width: 100%;
    }
}
@media (max-width: 768px) {
    #video {
        padding: 13vw 0;
    }
    #video h2 .orange-span {
        margin-left: -13vw;
    }
    #video h2 {
        left: 11vw;
        margin-bottom: 6.5vw;
    }
    .plyr__control--overlaid {
        width: 16.14vw !important;
        height: 16.14vw !important;
    }
    #player {
        border-radius: 3.25vw;
    }
    #video:before {
        width: 72.2vw;
        height: 64.1vw;
        left: 13.9vw;
        top: -18vw;
    }
    #video:after {
        width: 72.2vw;
        height: 64.1vw;
        left: 14.4vw;
        bottom: -34vw;
    }
}

/* lektor */

#lektor {
    padding-bottom: 89px;
    position: relative;
}
#lektor .wrp {
    position: relative;
    z-index: 2;
}
#lektor h2 {
    margin-bottom: 96px;
}
.lektors {
    display: flex;
    justify-content: center;
    gap: 100px;
}
.lektor {
    width: 446px;
    position: relative;
}
.lektor-img {
    width: 100%;
    object-fit: cover;
    margin-bottom: 34px;
}
.lektor-text-head {
    font-size: 40px;
    font-weight: 700;
    line-height: 40px;
    margin-bottom: 14px;
    text-align: center;
}

#lektors-2 {
    padding: 103px 0;
    position: relative;
    z-index: 3;
}
#lektors-2 h2 {
    margin-bottom: 68px;
}
#lektors-2 .lektor-img {
    margin-bottom: 0;
}

@media (max-width: 1206px) {
    #lektor .wrp,
    #lektors-2 .wrp {
        width: calc(100% - 100px);
    }
    .lektors {
        gap: 32px;
    }
}
@media (max-width: 1023px) {
    #lektor .wrp,
    #lektors-2 .wrp {
        width: calc(100% - 70px);
    }
    .lektor {
        width: calc(50% - 16px);
    }
}
@media (max-width: 768px) {
    #lektors-2 {
        padding: 32vw 0 13.41vw 0;
    }
    #lektor .wrp,
    #lektors-2 .wrp {
        width: calc(100% - 7.81vw);
    }
    #lektor h2 {
        margin-bottom: 7.8vw;
    }
    #lektors-2 h2 {
        margin-bottom: 7.2vw;
    }
    .lektors {
        gap: 3.9vw;
    }
    .lektor {
        width: calc(50% - 1.8vw);
    }
    .lektor-img {
        margin-bottom: 3.25vw;
        border-radius: 3.9vw;
    }
    .lektor-text-head {
        font-size: 5.2vw;
        line-height: 5.2vw;
        margin-bottom: 3.125vw;
    }
    #lektor {
        padding-bottom: 10vw;
    }
}

/* contacts */

#contacts {
    padding-bottom: 150px;
}
#contacts .wrp {
    display: flex;
    gap: 80px;
    position: relative;
}
.contacts-info-head {
    color: #89D9FF;
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 54px;
    line-height: 30px; 
}
.contacts-info-adress {
    margin-bottom: 53px;
}
.contacts-info-adress,
.contacts-info-phone,
.contacts-info-email {
    display: block;
    width: max-content;
    margin-left: 36px;
}
.contacts-info-email {
    margin-top: 32px;
}
#contacts .modal-button {
    top: 55px;
    right: 75px;
}
@media (max-width: 1206px) {
    #contacts {
        padding-bottom: 103px;
    }
    #contacts .modal-button {
        top: 34px;
        right: 25px;
    }
}
@media (max-width: 1023px) {
    #contacts .wrp {
        display: block;
        padding-left: 110px;
    }
    #contacts .modal-button {
        top: 0;
        right: 0;
        position: relative;
        margin-top: 100px;
        margin-left: 100px;
        margin-bottom: 50px;
    }
    #contacts {
        padding-bottom: 90px;
    }
    .contacts-info-adress, .contacts-info-phone, .contacts-info-email {
        width: 100%;
    }
}
@media (max-width: 768px) {
    #contacts .wrp {
        width: calc(100% - 10.67vw);
    }
    #contacts {
        padding-bottom: 10.4vw;
    }
    #contacts .wrp {
        padding-left: 0;
    }
    .contacts-info-head {
        font-size: 4.1vw;
        margin-bottom: 7vw;
        line-height: 3.9vw;
    }
    .contacts-info-adress, .contacts-info-phone, .contacts-info-email {
        margin-left: 4.6vw;
    }
    .contacts-info-adress {
        margin-bottom: 6.9vw;
        width: 77vw;
    }
    .contacts-info-email {
        margin-top: 4.1vw;
    }
    #contacts .modal-button {
        margin-top: 14.4vw;
        right: -22vw;
        margin-left: 0;
        margin-bottom: 11vw;
        transform: scale(1);
    }
}

/* footer */

#footer {
    background: #181818;
    padding: 52px 0;
}
#footer .wrp {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.footer-logo img {
    width: 189px;
}
.footer-info {
    text-align: center;
    color: #fff;
    font-size: 16px;
    line-height: 24px;
}
.footer-info a {
    text-decoration: underline !important;
    color: #fff;
    font-size: 16px;
    line-height: 24px;
}
.footer-contacts {
    text-align: right
}
.footer-contacts-phone {
    color: #B2AEBF;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
}
.footer-contacts-email {
    display: block;
    color: #B2AEBF;
    font-size: 16px;
    line-height: 24px;
}
@media (max-width: 1640px) {
    #footer .wrp {
        max-width: calc(100% - 13.02vw);
    }
}
@media (max-width: 1023px) {
    #footer .wrp {
        flex-flow: wrap;
        position: relative;
        text-align: right;
    }
    .footer-contacts {
        width: 100%;
    }
    .footer-info {
        width: 100%;
        text-align: right;
        margin-top: 4px;
        order: 5;
    }
    .footer-logo {
        position: absolute;
    }
}
@media (max-width: 768px) {
    #footer {
        padding: 3.5vw 0;
    }
    .footer-logo {
        width: 23.4vw;
        margin-top: 1vw;
    }
    .footer-logo img {
        width: 100%;
    }
    .footer-info {
        margin-top: -1vw;
        font-size: 2vw;
        line-height: 3.125vw;
    }
    .footer-contacts {
        margin-bottom: 3.125vw;
    }
    .footer-info a {
        font-size: 2vw;
        line-height: 3.125vw;   
    }
    .footer-contacts-phone,
    .footer-contacts-email {
        font-size: 2vw;
        line-height: 3.125vw;
    }
}

/* MODAL */

#backcall-modal {
    width: 980px;
    border-radius: 30px;
    background: linear-gradient(180deg, #406BD0 0%, #031E7B 100%);
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    padding: 60px 70px;
    display: flex;
    justify-content: space-between;
    flex-flow: wrap;
    overflow: hidden;
}
.fancybox-close-small {
    display: none;
}
.backcall-form {
    display: flex;
    justify-content: space-between;
    flex-flow: wrap;
}
.backcall-form-left,
.backcall-form-right {
    width: calc(50% - 20px);
}
.backcall-form-check {
    margin: 20px 0;
}
.backcall-form-check input {
    display: none;
}
.backcall-form-text {
    color: #fff;
    font-size: 20px;
    font-weight: 300;
    line-height: 22px; 
    width: 100%;
    padding-left: 34px;
    position: relative;
    display: block;
}
.backcall-form-text a {
    font-size: 20px;
    font-weight: 300;
    line-height: 22px; 
    text-decoration: underline !important;
}
.backcall-form-text:before {
    content: "";
    width: 22px;
    height: 22px;
    background: #fff;
    border: 2px solid #fff;
    position: absolute;
    left: 0;
    border-radius: 4px;
    top: 2px;
}
.backcall-form-check input:checked + .backcall-form-text:before {
    background: #fff url("../img/check-icon.svg") no-repeat center center / 80%;
}
.backcall-form-check.no-valid .backcall-form-text:before {
    border: 2px solid #F00;
}
.date-select {
    position: relative;
    z-index: 4;
}
.date-select-button {
    border-radius: 10px;
    background: #FFF;
    padding: 20px 30px;
    display: flex;
    align-items: center;
    gap: 18px;
    cursor: pointer;
    border: 2px solid transparent;
    color: #000;
}
.date-select.no-valid .date-select-button {
    border: 2px solid #F00;
}
.date-select-list {
    position: absolute;
    top: 70px;
    background: #fff;
    border-radius: 0 0 10px 10px;
    padding: 20px 28px;
    width: 100%;
    opacity: 0;
    pointer-events: none;
}
.date-select-button.active + .date-select-list {
    opacity: 1;
    pointer-events: initial;
}
.date-select-list .item {
    display: block;
    font-size: 32px;
    color: #000;
}
.date-select-list .item input {
    display: none;
}
.date-select-list .item:not(:last-child) {
    margin-bottom: 30px;
}
@media (max-width: 768px) {
    .date-select-button {
        border-radius: 1.3vw;
        padding: 2.6vw 3.9vw;
        gap: 2.3vw;
        border: 0.26vw solid transparent;
    }
    .date-select-button svg {
        height: auto;
        width: 3vw;
    }
    .date-select.no-valid .date-select-button {
        border: 0.26vw solid #F00;
    }
    .date-select-list {
        top: 9.1vw;
        border-radius: 0 0 1.3vw 1.3vw;
        padding: 2.6vw 3.6vw;
    }
    .date-select-list .item {
        font-size: 4.16vw;
    }
    .date-select-list .item:not(:last-child) {
        margin-bottom: 3.9vw;
    }
}


.backcall-form-button {
    border-radius: 109px;
    background: linear-gradient(180deg, #86E8A0 0%, #018DED 100%);
    padding: 38px 51px;
    text-align: center;
    display: block;
    width: max-content;
    color: #FFF;
    font-size: 40px;
    font-weight: 500;
    line-height: 22px;
    margin: 24px auto 0 auto;
    transition: .4s;
    transition: .4s;
    position: relative;
}
.backcall-form-button:before {
    content: "";
    border-radius: 109px;
    background: linear-gradient(180deg, rgb(134 232 160 / 15%) 0%, rgb(1 141 237 / 15%) 100%);
    position: absolute;
    width: 300px;
    height: 100px;
    left: 0;
    bottom: -104px;
    z-index: 0;
    transition: .4s;
}
.backcall-form-button:hover {
    background: linear-gradient(180deg, rgb(134 232 160 / 65%) 0%, rgb(1 141 237 / 65%) 100%);
}
.backcall-form-button.disabled {
    background: linear-gradient(180deg, rgb(134 232 160 / 65%) 0%, rgb(1 141 237 / 65%) 100%);
    pointer-events: none;
}
.backcall-form-button.disabled:before {
    opacity: 0;
}
.backcall-form .input {
    border-radius: 10px;
    background: #FFF;
    width: 100%;
    margin-bottom: 20px;
    transition: .4s;
    border: 2px solid transparent;
    font-size: 32px;
    font-weight: 300;
    line-height: 22px;
    padding: 10px 28px;
    line-height: 32px;
    color: #181818;
}
.backcall-form .input.no-valid {
    border: 2px solid #F00;
}
.backcall-form .input.valid {
    border: 2px solid #f3b5a0;
}
.backcall-form .input::placeholder {
    color: rgba(0, 0, 0, 0.30);
}
.backcall-form .input:last-child {
    margin-bottom: 0;
}
.backcall-form textarea.input {
    resize: none;
    height: 100%;
}
.backcall-form.hidden {
    display: none;
}

.backcall-form-success {
    text-align: center;
    display: none;
    height: 100%;
}
.backcall-form-success.visible {
    display: flex;
    align-items: center;
    justify-content: center;
}
.backcall-form-success img {
    margin-top: 56px;
}
.backcall-form-success .head {
    color: #fff;
    font-size: 36px;
    font-weight: 500;
    line-height: 48px;
    letter-spacing: 1.08px;
    margin-bottom: 0px;
}
.backcall-form-success .text {
    font-size: 20px;
}
@media (max-width: 1023px) {
    #backcall-modal {
        height: auto;
    }
    .backcall-form-left, .backcall-form-right {
        width: 100%;
    }
    .backcall-form-left {
        margin-bottom: 20px;
    }
}
@media (max-width: 768px) {
    #backcall-modal {
        width: 94.7vw;
        border-radius: 3.9vw;
        padding: 7.8vw 9.1vw;
    }
    .backcall-form-left,
    .backcall-form-right {
        width: 52vw;
        margin: 0 auto;
    }
    .backcall-form-left {
        margin-bottom: 2.6vw;
    }
    .backcall-form .input {
        border-radius: 1.3vw;
        margin-bottom: 2.6vw;
        border: 0.26vw solid transparent;
        font-size: 4.1vw;
        padding: 1.3vw 3.6vw;
        line-height: 4.1vw;
    }
    .backcall-form .input.no-valid {
        border: 0.26vw solid #F00;
    }
    .backcall-form .input.valid {
        border: 0.26vw solid #00BFEB;
    }
    .backcall-form-text {
        margin: 1vw 0;
        font-size: 2.6vw;
        line-height: 2.8vw;
    }
    .backcall-form-text a {
        font-size: 2.6vw;
    }
    .backcall-form-button {
        border-radius: 14vw;
        padding: 4.9vw 9.3vw;
        font-size: 4.1vw;
        line-height: 2.8vw;
    }
    .backcall-form-success .head {
        font-size: 4.6vw;
        line-height: 6.25vw;
        letter-spacing: 0.13vw;
    }
    .backcall-form-success .text {
        font-size: 2.6vw;
    }
    .backcall-form-success img {
        width: 13vw;
        margin-top: 7.2vw;
    }
    .backcall-form textarea.input {
        height: 28.6vw;
    }

    .modal-button {
        width: 39.8vw;
        height: 39.8vw;
        border-radius: 50%;
        padding-top: 15.2vw;
        right: 6.5vw;
        top: 80vw;
    }
    .modal-button span:nth-child(1) {
        font-size: 8.3vw;
        line-height: 2.6vw;
    }
    .modal-button span:nth-child(2) {
        font-size: 2.7vw;
        line-height: 6.7vw;
    }
    .modal-button img {
        width: 20.4vw;
    }
    .backcall-form-button {
        margin-top: 0;
    }
    .backcall-form-button:before {
        border-radius: 14.19vw;
        width: 100%;
        height: 13vw;
        bottom: -14vw;
    }
}

@media (max-width: 1206px) {
    .wrp {
        width: calc(100% - 100px);
    }
}
@media (max-width: 768px) {
    .wrp {
        width: calc(100%);
    }
    .main-wrp {
        width: calc(100% - 13vw);
    }
    h2 {
        font-size: 8.33vw;
        line-height: 5.2vw;
    }
    p,a,li,div,button,input,textarea {
        font-size: 3.125vw;
        line-height: 3.9vw;
    }

    .backcall-form-check {
        width: 52vw;
        margin: 1vw auto 1vw auto;
    }
    .backcall-form-text {
        font-size: 2.604vw;
        line-height: 2.865vw;
        padding-left: 4.427vw;
    }
    .backcall-form-text:before {
        width: 2.865vw;
        height: 2.865vw;
        border: 0.26vw solid #fff;
        border-radius: 0.521vw;
    }
    .backcall-form-check.no-valid .backcall-form-text:before {
        border: 0.26vw solid #F00;
    }

}

/* main */

#main {
    height: 1000px;
    position: relative;
    background: url("../img/main-bg.svg") no-repeat center center / cover;
    z-index: 2;
    max-width: 1920px;
    margin: 0 auto;
    overflow: hidden;
}
#main * {
    position: absolute;
    z-index: 3;
}
#main .logo {
    left: 201px;
    top: 60px;
}
.main-block-1 {
   left: 674px;
   top: 60px;
}
.main-block-2 {
    right: 200px;
    top: 60px;
}
.main-block-3 {
    left: 198px;
    top: 321px;
}
.main-block-4 {
    width: 363px;
    right: 607px;
    top: 207px;
}
.main-block-5 {
    left: 201px;
    bottom: 196px;
}
.main-block-6 {
    width: 480px;
    right: 178px;
    bottom: 135px;
}
#main .mob {
    display: none;
}
.main-block-7 {
    left: 860px;
    bottom: 60px;
}
@media (max-width: 1918px) {
    #main {
        zoom: .75;
    }
    body > .modal-button {
        right: calc(50% - 572px);
        top: 600px;
        transform: scale(.8);
    }
}
@media (max-width: 1438px) {
    #main {
        zoom: .67;
    }
    body > .modal-button {
        right: calc(50% - 500px);
        top: 534px;
        transform: scale(.8);
    }
}
@media (max-width: 1278px) {
    #main {
        zoom: .533;
    }
    body > .modal-button {
        right: calc(50% - 500px);
        top: 386px;
        transform: scale(.6);
    }
}
@media (max-width: 1022px) {
    #main {
        zoom: .399;
    }
    body > .modal-button {
        right: calc(50% - 400px);
        top: 260px;
        transform: scale(.5);
    }
}
@media (max-width: 768px) {
    #main {
        zoom: 1;
        background: url("../img/main-mobile-bg.svg") no-repeat center top / cover;
        height: 117.188vw;
    }
    #main .mob {
        display: block;
    }
    .main-block-4:not(.mob),
    .main-block-6:not(.mob) {
        display: none;
    }
    #main .logo {
        left: 6.51vw;
        top: 3.906vw;
        width: 25.487vw;
    }
    .main-block-1 {
        left: 35.547vw;
        top: 4.042vw;
        width: 57.813vw;
    }
    .main-block-2 {
        right: 6.641vw;
        top: 20.703vw;
        width: 23.438vw;
    }
    .main-block-3 {
        width: 43.88vw;
        left: 6.51vw;
        top: 22.656vw;
    }
    .main-block-4 {
        width: 32.161vw;
        right: auto;
        top: 37.11vw;
        left: 6.51vw;
    }
    .main-block-5 {
        left: 6.51vw;
        bottom: 30.469vw;
        width: 87.031vw;
    }
    .main-block-6 {
        width: 39.453vw;
        right: 6.771vw;
        bottom: 58.594vw;
    }
    body > .modal-button {
        right: calc(50% - 19.594vw);
        top: 93.844vw;
        transform: scale(1);
    }
}