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(227deg, #D7DAE4 0%, #FFF3F3 99.22%);
    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: #000;
    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: #211F2C;
    font-size: 64px;
    font-weight: 350;
    line-height: 40px;
    width: max-content;
    margin: 0 auto;
}
.orange-span {
 color: #939DAB;
 font-weight: 700;
}

/* main */

#main {
    border-radius: 0px 0px 250px 250px;
    background: linear-gradient(180deg, #D7DAE4 0%, #EFF0F3 100%);
    height: 968px;
    padding-top: 51px;
    position: relative;
    z-index: 5;
    overflow: hidden;
}
#main:after {
    content: "";
    width: 938px;
    height: 938px;
    background: rgba(250, 247, 253, 0.45);
    position: absolute;
    bottom: -470px;
    left: calc((100% - 938px)/2);
    border-radius: 50%;
}
#main .main-wrp {
    width: 1620px;
    position: relative;
    z-index: 2;
    height: 100%;
}
.main-img1 {
    position: absolute;
    bottom: 0;
    left: 0;
}
.main-img2 {
    position: absolute;
    top: 0;
    right: 100px;
}
.main-img3 {
    position: absolute;
    top: 190px;
    right: 230px;
}
.main-img4 {
    position: absolute;
    bottom: 100px;
    right: 130px;
}
.main-img5 {
    position: absolute;
    right: 0;
    top: 280px;
}

@media (max-width: 1700px) {
    #main {
        height: 726px;
        padding-top: 38px;
        border-radius: 0px 0px 180px 180px;
    }
    #main .main-wrp {
        width: calc(100% - 300px);
    }
    .main-logo {
        width: 206px;
    }
    .main-img1 {
        width: 504px;
    }
    .main-img2 {
        width: 399px;
        right: 180px;
    }
    .main-img3 {
        top: 140px;
        right: 300px;
        width: 426px;
    }
    .main-img4 {
        bottom: 100px;
        right: 200px;
        width: 328px;
    }
    .main-img5 {
        width: 396px;
        top: 210px;
    }
    #main:after {
        width: 704px;
        height: 704px;
        left: calc((100% - 704px)/2);
        bottom: -350px;
    }
    .modal-button.main-button {
        top: 572px !important;
        transform: scale(.9);
    }
}
@media (max-width: 1390px) {
    #main {
        height: 645px;
        padding-top: 34px;
        border-radius: 0px 0px 150px 150px;
    }
    #main .main-wrp {
        width: calc(100% - 260px);
    }
    .main-logo {
        width: 183px;
    }
    .main-img2 {
        width: 355px;
        right: 130px;
    }
    .main-img1 {
        width: 448px;
    }
    .main-img3 {
        top: 140px;
        right: 230px;
        width: 370px;
    }
    .main-img4 {
        bottom: 60px;
        right: 120px;
        width: 290px;
    }
    .main-img5 {
        width: 350px;
        top: 180px;
    }
    #main:after {
        width: 626px;
        height: 626px;
        left: calc((100% - 626px) / 2);
        bottom: -313px;
    }
    .modal-button.main-button {
        top: 488px !important;
        transform: scale(.75);
    }
}
@media (max-width: 1200px) {
    #main {
        border-radius: 0px 0px 120px 120px;
        height: 516px;
        padding-top: 27px;
    }
    #main .main-wrp {
        width: calc(100% - 214px);
    }
    .main-logo {
        width: 146px;
    }
    .main-img2 {
        width: 284px;
        right: 120px;
    }
    .main-img1 {
        width: 358px;
    }
    .main-img3 {
        top: 100px;
        right: 200px;
        width: 303px;
    }
    .main-img4 {
        bottom: 54px;
        right: 120px;
        width: 233px;
    }
    .main-img5 {
        width: 282px;
        top: 149px;
    }
    .modal-button.main-button {
        top: 363px !important;
        transform: scale(.5);
    }
    #main:after {
        width: 500px;
        height: 500px;
        left: calc((100% - 500px) / 2);
        bottom: -250px;
    }
}
@media (max-width: 1023px) {
    #main .main-wrp {
        width: calc(100% - 100px);
    }
    #main {
        height: 700px;
    }
    .main-img3 {
        right: auto;
        left: 0;
    }
    .main-img2 {
        right: 0;
    }
    .main-img4 {
        bottom: 250px;
    }
    .modal-button.main-button {
        top: 548px !important;
    }
}
@media (max-width: 768px) {
    #main {
        height: 120vw;
        border-radius: 0 0 15.62vw 15.62vw;
        padding-top: 3.9vw;
        overflow: hidden;
    }
    #main .main-wrp {
        width: calc(100% - 13vw);
    }
    .main-logo {
        width: 26vw;
        position: absolute;
        right: 0;
        top: 0;
    }
    .main-img2 {
        right: auto;
        width: 54vw;
        left: 0;
    }
    .main-img3 {
        right: auto;
        left: 0;
        position: relative;
        margin-top: 20vw;
        top: auto;
        width: 48vw;
    }
    .main-img5 {
        width: 40.8vw;
        top: 23vw;
    }
    .main-img1 {
        width: 62.5vw;
    }
    .main-img4 {
        bottom: 38vw;
        right: 0;
        width: 40.3vw;
    }
    .modal-button.main-button {
        top: 100vw !important;
        transform: scale(1);
        right: calc(100% / 2 - 20vw);
    }
    #main:after {
        display: none;
    }
}

.modal-button {
    display: block;
    width: 306px;
    height: 306px;
    border-radius: 306px;
    background: linear-gradient(139deg, #769BC2 13.85%, #FA3641 86.41%);
    backdrop-filter: blur(30px);
    text-align: center;
    padding-top: 125px;
    position: absolute;
    top: 798px;
    right: calc(50% - 150px);
    z-index: 15;
}
.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: 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 {
    position: relative;
    z-index: 1;
    padding-top: 276px;
}
#about:after {
    content: "";
    background: radial-gradient(50% 50% at 50% 50%, rgba(255, 255, 255, 0.70) 0%, rgba(255, 255, 255, 0.00) 100%);
    width: 882px;
    height: 873px;
    position: absolute;
    left: -440px;
    top: 400px;
}
#about:before {
    content: "";
    width: 1250px;
    height: 1250px;
    border-radius: 50%;
    background: rgba(244, 243, 247, 0.47);
    position: absolute;
    top: -625px;
    left: calc((100% - 1250px)/2);
    transform: rotate(180deg);
}
#about .wrp {
    position: relative;
    z-index: 2;
}
.about-arrow {
    display: block;
    margin: 50px auto;
}
#about h2 {
    margin-bottom: 80px;
    text-align: center;
}
#about h2 span:last-child {
    position: relative;
    left: -120px;
}
.list-with-bullets li {
    padding-left: 36px;
    position: relative;
}
.list-with-bullets li:not(:last-child) {
    margin-bottom: 30px;
}
.list-with-bullets li:before {
    content: "";
    background: #FA3641;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    left: 10px;
    top: 9px;
}
.about-main {
    padding-left: 518px;
    position: relative;
}
.about-main img {
    position: absolute;
    left: -60px;
    top: -52px;
    width: 550px;
}


.about-prices {
    display: flex;
    justify-content: space-between;
}
.about-prices-left {
    padding-top: 198px;
    padding-left: 128px;
}
.about-prices-left p {
    margin: 0 0 77px 64px;
    color: #FFF;
    font-size: 20px;
    font-weight: 300;
    line-height: 18px; 
}
.about-price {
    font-size: 32px;
    font-weight: 350;
    line-height: 32px;
    margin-top: -54px;
    width: max-content;
}
.about-price .orange-span {
    color: #FA3641;
    font-size: 96px;
    font-weight: 700;
    line-height: 32px;
    letter-spacing: -2.88px;
}
.about-price:last-child {
    margin-left: 64px;
    font-size: 20px;
    font-weight: 300;
}
.about-prices-img {
    width: 468px;
}
@media (max-width: 1700px) {
    #about:before {
        width: 938px;
        height: 938px;
        top: -470px;
        left: calc((100% - 938px)/2);
    }
    #about {
        padding-top: 212px;
    }
}
@media (max-width: 1390px) {
    #about:before {
        width: 833px;
        height: 833px;
        top: -415px;
        left: calc((100% - 833px) / 2);
    }
    #about {
        padding-top: 194px;
    }
}
@media (max-width: 1200px) {
    #about:before {
        width: 666px;
        height: 666px;
        top: -333px;
        left: calc((100% - 666px) / 2);
    }
    #about {
        padding-top: 166px;
    }
    #about h2 {
        margin-bottom: 60px;
    }
    .about-main img {
        width: 500px;
    }
    .about-main {
        padding-left: 416px;
    }
    .about-prices-left {
        padding-top: 120px;
        padding-bottom: 100px;
    }
}
@media (max-width: 1023px) {
    .about-prices {
        display: block;
    }
    .about-prices-left {
        padding-top: 0;
        width: max-content;
        margin: 0 auto;
    }
    .about-prices-left p {
        margin: 0 0 -38px 64px;
    }
    .about-prices-img {
        display: block;
        margin: 50px auto 0 auto;
    }
    .about-main {
        padding-left: 100px;
    }
    .about-main img {
        width: 500px;
        position: relative;
        left: 0;
        top: 0;
        margin-bottom: 60px;
    }
    .about-prices-left {
        padding-left: 0;
        position: relative;
        left: -20px;
    }
}
@media (max-width: 768px) {
    .list-with-bullets li {
        padding-left: 4.6vw;
    }
    .list-with-bullets li:before {
        width: 1.3vw;
        height: 1.3vw;
        left: 1.3vw;
        top: 1.1vw;
    }
    .about-price {
        font-size: 4.1vw;
        line-height: 4.1vw;
    }
    .about-price .orange-span {
        font-size: 12.5vw;
        line-height: 4.1vw;
        letter-spacing: -0.36vw;
        margin-right: -1vw;
    }
    .about-price {
        margin: 7.8vw auto 0 8vw;
    }
    #about {
        padding-top: 38.4vw;
    }
    #about:before {
        width: 63.8vw;
        height: 63.8vw;
        top: -32vw;
        left: calc((100% - 63.8vw) / 2);
    }
    #about h2 {
        margin-bottom: 7.8vw;
    }
    #about h2 span:last-child {
        left: 0;
    }
    .about-main {
        padding-left: 12vw;
    }
    .about-main img {
        width: 110vw;
        position: relative;
        left: -24vw;
        top: 0;
        margin-bottom: 0;
        max-width: initial;
        margin-top: -5vw;
        margin-bottom: -10vw;
    }
    .about-prices-left {
        left: -4vw;
        padding-bottom: 10vw;
    }
}

/* video */

#video {
    padding: 75px 0 105px 0;
    position: relative;
}
#video:before {
    content: "";
    width: 555px;
    height: 555px;
    border-radius: 555px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.70) 46.5%);
    position: absolute;
    left: calc(50% - 270px);
    top: -99px;
}
#video:after {
    content: "";
    width: 555px;
    height: 555px;
    border-radius: 50%;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.70) 46.5%);
    position: absolute;
    left: calc(50% - 270px);
    bottom: -240px;
}
#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 {
        left: 8vw;
        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;
    }
    #video h2 .orange-span {
        margin-left: -11vw;
    }
}

/* lektor */

#lektor {
    padding-bottom: 98px;
    position: relative;
}
/*
#lektor:before {
    content: "";
    width: 1520px;
    height: 1520px;
    background: rgba(153, 189, 215, 0.02);
    border-radius: 50%;
    position: absolute;
    top: -345px;
    left: calc((100% - 1520px) / 2);
}
*/
#lektor .wrp {
    position: relative;
    z-index: 2;
}
#lektor h2 {
    margin-bottom: 63px;
}
.lektor {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}
.lektor-img {
    width: 457px;
    object-fit: cover;
}
.lektor-text {
    padding-top: 0;
}
.lektor-text-head {
    font-size: 32px;
    font-weight: 700;
    line-height: 30px;
    margin-bottom: 54px;
}

@media (max-width: 1500px) {
    #lektor:before {
        display: none;
    }
}
@media (max-width: 1206px) {
    .lektor-img {
        width: 421px;
    }
    #lektor .wrp {
        width: calc(100% - 70px);
    }
    .lektor {
        padding-left: 15px;
    }
}
@media (max-width: 1023px) {
    .lektor {
        display: block;
        padding-left: 135px;
    }
    .lektor-img {
        margin-bottom: 40px;
    }
    .lektor-text {
        padding-top: 0;
    }
}
@media (max-width: 768px) {
    #lektor .wrp {
        width: calc(100% - 40.6vw);
    }
    .lektor {
        padding-left: 0;
    }
    .lektor-img {
        margin-bottom: 7.8vw;
    }
    .lektor-text-head {
        font-size: 4.1vw;
        line-height: 3.9vw;
        margin-bottom: 7vw;
        padding-left: 4vw;
        text-align: center;
    }
    #lektor:before {
        width: 94.5vw;
        height: 94.5vw;
        border-radius: 50%;
        top: 78vw;
        right: -47vw;
    }
}

/* contacts */

#contacts {
    padding-bottom: 93px;
}
#contacts .wrp {
    display: flex;
    gap: 80px;
    justify-content: space-between;
}
.contacts-info-head {
    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 {
    position: relative;
    top: -60px;
    right: 50px;
    margin-top: 26px;
}
@media (max-width: 1500px) {
    #contacts .modal-button {
        right: 100px;
    }
}
@media (max-width: 1279px) {
    #contacts {
        padding-bottom: 193px;
    }
    #contacts .modal-button {
        right: 50px;
        top: -175px;
    }

}
@media (max-width: 1023px) {
    #contacts .wrp {
        display: block;
        padding-left: 135px;
    }
    #contacts .modal-button {
        right: -50px;
        top: 82px;
    }
}
@media (max-width: 768px) {
    #contacts {
        padding-bottom: 24vw;
    }
    #contacts .wrp {
        padding-left: 0;
        width: calc(100% - 44.6vw);
    }
    .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;
    }
    .contacts-info-email {
        margin-top: 4.1vw;
    }
    #contacts .modal-button {
        margin-top: 10.4vw;
        right: -9.7vw;
        top: 5vw;
    }
}

/* footer */

#footer {
    background: #F4F7FE;
    padding: 52px 0;
}
#footer .wrp {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.footer-info {
    color: #303030;
    text-align: center;
    font-size: 16px;
    line-height: 24px;
}
.footer-info a {
    text-decoration: underline !important;
    font-size: 16px;
    line-height: 24px;
}
.footer-contacts {
    text-align: right
}
.footer-contacts a {
    color: #303030;
}
.footer-contacts-phone {
    color: #B2AEBF;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
}
.footer-contacts-email {
    color: #B2AEBF;
    display: block;
    font-size: 16px;
    line-height: 24px;
}
@media (max-width: 1700px) {
    #footer .main-wrp {
        width: calc(100% - 100px);
    }
    .footer-info,
    .footer-info a {
        color: #B2AEBF;
    }
}
@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 .wrp {
        width: calc(100% - 13vw);
    }
    .footer-logo {
        width: 23.4vw;
        margin-top: 1vw;
    }
    .footer-info {
        margin-top: -1vw;
        font-size: 2vw;
        line-height: 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, #D8DBE4 0%, #FFF0ED 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;
    height: 700px;
    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-text {
    text-align: center;
    margin: 43px 0 56px 0;
    color: rgba(0, 0, 0, 0.30);
    font-size: 20px;
    font-weight: 300;
    line-height: 22px; 
    width: 100%;
}
.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;
}
.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;
}
.date-select-list .item input {
    display: none;
}
.date-select-list .item:not(:last-child) {
    margin-bottom: 30px;
}
.backcall-form-button {
    border-radius: 109px;
    background: linear-gradient(180deg, #769BC2 0%, #FA3641 100%);
    padding: 38px 72px;
    text-align: center;
    display: block;
    width: max-content;
    color: #FFF;
    font-size: 32px;
    font-weight: 500;
    line-height: 22px;
    margin: 0 auto;
    transition: .4s;
    transition: .4s;
    position: relative;
}
.backcall-form-button:before {
    content: "";
    border-radius: 109px;
    background: linear-gradient(180deg, rgba(250, 54, 65, 0.10) 0%, rgba(250, 54, 65, 0.10) 100%);
    position: absolute;
    width: 300px;
    height: 100px;
    left: 0;
    bottom: -104px;
    z-index: 0;
    transition: .4s;
}
.backcall-form-button:hover {
    background: linear-gradient(180deg, rgba(250, 54, 65, 0.20) 0%, rgba(250, 54, 65, 0.20) 100%);
}
.backcall-form-button.disabled {
    background: linear-gradient(180deg, rgba(250, 54, 65, 0.20) 0%, rgba(250, 54, 65, 0.20) 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: #000;
}
.backcall-form .input.no-valid {
    border: 2px solid #F00;
}
.backcall-form .input.valid {
    border: 2px solid #769BC2;
}
.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 #018DEC;
    }
    .backcall-form-text {
        margin: 5.5vw 0 7.2vw 0;
        font-size: 2.6vw;
        line-height: 2.8vw;
    }
    .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:before {
        border-radius: 14.19vw;
        width: 100%;
        height: 13vw;
        bottom: -14vw;
    }

    .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;
    }
}

@media (max-width: 1206px) {
    .wrp {
        width: calc(100% - 100px);
    }
}
@media (max-width: 768px) {
    .wrp {
        width: calc(100% - 13vw);
    }
    .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;
    }
}