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, #F1F0F0 0%, #EBEBE6 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: #AAA;
    font-size: 64px;
    font-weight: 350;
    line-height: 40px;
    width: max-content;
    margin: 0 auto;
}
.orange-span {
 color: #EE741E;
 font-weight: 700;
}

/* main */

#main {
    border-radius: 0px 0px 200px 200px;
    background: linear-gradient(180deg, #F2F3F3 0%, #E0E5E5 100%);
    position: relative;
    overflow: hidden;
    z-index: 2;
}
.main-wrp {
    display: flex;
    align-items: flex-end;
    position: relative;
    z-index: 2;
    gap: 100px;
}
#main:before {
    content: "";
    border-radius: 1000px;
    background: rgba(255, 255, 255, 0.40);
    width: 1000px;
    height: 1000px;
    position: absolute;
    top: 58px;
    left: calc(100% / 2 - 434px);
}
.main-logo {
    position: absolute;
    top: 44px;
    right: 0;
}
.main-info {
    padding: 40px 0 130px 0;
}
.main-info-top {
    width: max-content;
    margin-bottom: 45px;
    position: relative;
    font-size: 32px;
    font-weight: 350;
    line-height: 32px;
    padding: 15px 0 15px 31px;
}
.main-info-top:before {
    content: "";
    background: #EE741E;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    position: absolute;
    top: 17px;
    right: 27px;
}
.main-info-top:after {
    content: "";
    width: 33px;
    height: 173px;
    background: url(../img/white-border.svg) no-repeat top left / 100%;
    position: absolute;
    top: -1px;
    left: 0;
}
.main-info-top span {
    color: rgba(0, 0, 0, 0.50);
}
.main-info-text {
    margin-top: 35px;
    font-size: 36px;
    line-height: 36px;
}
.main-info-text .tablet-br,
.main-info-text .mobile-br {
    display: none;
}
.main-info-text span {
    font-weight: 100;
}

.modal-button {
    display: block;
    width: 306px;
    height: 306px;
    border-radius: 306px;
    background: linear-gradient(139deg, #F79642 13.85%, #ED6E00 86.41%);
    backdrop-filter: blur(30px);
    text-align: center;
    padding-top: 125px;
    position: absolute;
    top: 600px;
    right: calc(50% - 763px);
    z-index: 4;
}
.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;
}
.modal-button:before {
    content: "";
    width: 100%;
    height: 100%;
    background: linear-gradient(139deg, #F79642 13.85%, #ED6E00 86.41%);
    backdrop-filter: blur(30px);
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 50%;
    transform: scale(-1,1);
    opacity: 0;
    transition: .4s;
}
.modal-button:hover:before {
    opacity: 1;
}

@media (max-width: 1560px) {
    .main-wrp {
        width: 1340px;
        gap: 16px;
    }
    #main:before {
        left: calc(100% / 2 - 328px);
    }
    .main-info-text .tablet-br {
        display: block;
    }
    .modal-button {
        right: calc(50% - 672px);
    }
}
@media (max-width: 1390px) {
    .main-wrp {
        width: 1180px;
    }
    .modal-button {
        right: calc(50% - 589px);
    }
}
@media (max-width: 1206px) {
    .main-wrp {
        width: calc(100% - 100px);
    }
    .main-info {
        padding: 44px 0 228px 0;
    }
    .main-info-top {
        left: -75px;
        margin-bottom: 28px;
    }
    #main:before {
        width: 782px;
        height: 782px;
        top: 208px;
        left: auto;
        right: 50px;
    }
    .modal-button {
        right: 50px;
    }
}
@media (max-width: 1023px) {
    .main-img {
        margin-left: -75px;
    }
    .main-info-top {
        left: -117px;
    }
    .main-info-logo {
        margin-left: -78px;
    }
    #main:before {
        width: 540px;
        height: 540px;
        top: 355px;
    }
}
@media (max-width: 768px) {
    #main {
        border-radius: 0 0 26vw 26vw;
    }
    .main-logo {
        width: 23vw;
        top: 5.72vw;
    }
    .main-img {
        margin-left: -11vw;
        width: 45.7vw;
    }
    .main-wrp {
        gap: 3.64vw;
    }
    .main-info {
        padding: 8vw 0 25.6vw 0;
    }
    .main-info-top {
        left: -15vw;
        font-size: 4.1vw;
        line-height: 4.1vw;
        margin-bottom: 3.64vw;
        padding: 2vw 0 2vw 4vw;
    }
    .main-info-top:before {
        width: 2.86vw;
        height: 2.86vw;
        top: 2.4vw;
        right: 3vw;
    }
    .main-info-top:after {
        width: 4.1vw;
        height: 23vw;
        top: -0.15vw;
    }
    .main-info-logo {
        margin-left: -10vw;
        width: 54.4vw;
    }
    .main-info-text {
        margin-top: 3.64vw;
        font-size: 4.6vw;
        line-height: 4.6vw;
        margin-left: -1.5vw;
    }
    .main-info-text .mobile-br{
        display: block;
    }
    #main:before {
        width: 70.5vw;
        height: 69.9vw;
        top: 48.8vw;
        right: 6.5vw;
    }
}

/* about */

#about {
    position: relative;
    z-index: 1;
}
#about:before {
    content: "";
    width: 1213px;
    height: 1213px;
    border-radius: 1213.664px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.40) 46.5%);
    position: absolute;
    top: -370px;
    left: calc(100% / 2 - 634px);
    transform: rotate(180deg);
}
#about:after {
    content: "";
    width: 726px;
    height: 719px;
    border-radius: 726.901px;
    background: radial-gradient(50% 50% at 50% 50%, rgba(238, 116, 30, 0.10) 0%, rgba(238, 116, 30, 0.00) 100%);
    position: absolute;
    left: -360px;
    top: 578px;
    z-index: -1;
}
#about .wrp {
    position: relative;
    z-index: 2;
}
.about-arrow {
    display: block;
    margin: 60px auto;
}
.about-main {
    display: flex;
    gap: 100px;
    align-items: flex-start;
}
.about-main img {
    position: relative;
    top: -125px;
}
.about-main-text div:not(:last-child) {
    margin-bottom: 36px;
}
.about-main-text div {
    font-size: 36px;
    line-height: 36px;
}
.about-main-text div span {
    font-weight: 100;
}
#about h2 {
    margin-bottom: 51px;
    position: relative;
    left: -10px;
    margin-top: -60px;
}
#about h2 .orange-span {
    margin-left: -56px;
}
#about .list-with-bullets {
    width: 485px;
    margin-left: 507px;
}
.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: #EE741E;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    left: 10px;
    top: 9px;
}
.about-price {
    font-size: 32px;
    font-weight: 350;
    line-height: 32px;
    margin-top: -54px;
    width: max-content;
}
.about-price .orange-span {
    font-size: 96px;
    font-weight: 700;
    line-height: 32px;
    letter-spacing: -2.88px;
}

@media (max-width: 1206px) {
    #about:before {
        left: calc((100% - 1200px) / 2);
    }
    .about-main img {
        width: 387px;
        top: -89px;
    }
    .about-main {
        gap: 75px;
    }
    #about h2 {
        margin-top: -10px;
    }
    #about .list-with-bullets {
        margin-left: 450px;
    }
}
@media (max-width: 1023px) {
    .about-arrow {
        margin-left: 100px;
    }
    .about-main {
        display: block;
    }
    .about-main img {
        top: 0;
        margin-bottom: 50px;
    }
    #about h2 {
        margin-top: 45px;
    }
    #about .list-with-bullets {
        margin-left: 86px;
    }
    .about-price {
       margin: 60px auto 0 auto;
   }
}
@media (max-width: 768px) {
    .about-arrow {
        width: 25.9vw;
        margin: 7.8vw 0 6vw 0;
    }
    .about-main img {
        top: 0;
        margin-bottom: 4.9vw;
        width: 50.3vw;
        margin-left: 4.4vw;
    }
    .about-main-text div:not(:last-child) {
        margin-bottom: 4.6vw;
    }
    .about-main-text div {
        font-size: 4.6vw;
        line-height: 4.6vw;
    }
    #about h2 {
        margin-top: 7.8vw;
        left: 5vw;
        margin-bottom: 7.8vw;
    }
    #about .list-with-bullets {
        margin-left: 0;
    }
    .list-with-bullets li:not(:last-child) {
        margin-bottom: 3.9vw;
    }
    .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:after {
        width: 94vw;
        height: 94vw;
        left: -47vw;
        top: 62vw;
    }
}

/* video */

#video {
    padding: 95px 0 105px 0;
    position: relative;
}
#video:before {
    content: "";
    width: 555px;
    height: 493px;
    border-radius: 555px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.40) 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(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.40) 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: 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: 98px;
    position: relative;
}
#lektor:before {
    content: "";
    width: 726px;
    height: 719px;
    border-radius: 726.901px;
    background: radial-gradient(50% 50% at 50% 50%, rgba(238, 116, 30, 0.10) 0%, rgba(238, 116, 30, 0.00) 100%);
    position: absolute;
    z-index: -1;
    top: 117px;
    right: -351px;
}
#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-head {
    font-size: 32px;
    font-weight: 700;
    line-height: 30px;
    margin-bottom: 54px;
}

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

/* footer */

#footer {
    background: #F3F3F3;
    padding: 52px 0;
}
#footer .wrp {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.footer-info {
    text-align: center;
    color: #303030;
    font-size: 16px;
    line-height: 24px;
}
.footer-info a {
    text-decoration: underline !important;
    color: #303030;
    font-size: 16px;
    line-height: 24px;
}
.footer-contacts {
    text-align: right
}
.footer-contacts-phone {
    color: #303030;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
}
.footer-contacts-email {
    display: block;
    color: #303030;
    font-size: 16px;
    line-height: 24px;
}
@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-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: #F9F9F9;
    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, #F59038 0%, #EE7309 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(245, 144, 56, 0.30) 0%, rgba(238, 115, 9, 0.00) 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(245, 144, 56, 0.50) 0%, rgba(238, 115, 9, 0.50) 100%);
}
.backcall-form-button.disabled {
    background: linear-gradient(180deg, rgba(245, 144, 56, 0.50) 0%, rgba(238, 115, 9, 0.50) 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;
}
.backcall-form .input.no-valid {
    border: 2px solid #F00;
}
.backcall-form .input.valid {
    border: 2px solid #F28222;
}
.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: #303030;
    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 #F28222;
    }
    .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% - 36.4vw);
    }
    .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;
    }
}