*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    background: #000;
    overflow-x: hidden;
}

.page-loader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #000;
    opacity: 1;
    visibility: visible;
    transition: opacity 0.35s ease, visibility 0.35s ease;
}

.page-loader.is-hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.page-loader__spinner {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(255, 255, 255, 0.15);
    border-top-color: #fff;
    border-radius: 50%;
    animation: page-loader-spin 0.75s linear infinite;
}

@keyframes page-loader-spin {
    to {
        transform: rotate(360deg);
    }
}

.app-root {
    --vw: clamp(375px, 100vw, 430px);
    --scale: calc(var(--vw) / 402px);
    width: var(--vw);
    margin: 0 auto;
    overflow: hidden;
}

.app-root .page {
    width: 402px;
    transform: scale(var(--scale));
    transform-origin: top left;
}

.app-root .page--landing {
    height: 2028px;
    margin-bottom: calc(2028px * (var(--scale) - 1));
}

.app-root .page--form {
    height: 874px;
    margin-bottom: calc(874px * (var(--scale) - 1));
}

.app-root .page--member-success {
    height: 874px;
    margin-bottom: calc(874px * (var(--scale) - 1));
}

.page {
    background: #000000;
    opacity: 1;
    position: relative;
    overflow: hidden;
}

.page.is-hidden {
    display: none;
}

.page__hero {
    position: relative;
    z-index: 0;
    display: block;
    width: 100%;
    max-width: 402px;
    height: 873px;
    margin-left: 0;
    opacity: 1;
    object-fit: cover;
}

.page__hero--form {
    width: 402px;
    height: 874px;
    margin-left: 0;
    object-fit: cover;
    object-position: center top;
}

.page__form-panel {
    position: absolute;
    top: 312px;
    left: 0;
    width: 402px;
    height: 562px;
    border-radius: 32px 32px 0 0;
    background: #ffffff;
    opacity: 1;
    z-index: 2;
}

.page__form-logo {
    position: absolute;
    top: 369px;
    left: 164px;
    width: 75px;
    height: 52px;
    opacity: 1;
    z-index: 3;
}

.page__form-question {
    position: absolute;
    top: 460px;
    left: 49px;
    margin: 0;
    width: 272px;
    height: 138px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 42px;
    line-height: 110%;
    letter-spacing: -0.04em;
    color: #376284;
    opacity: 1;
    z-index: 3;
}

.page__register-head {
    position: absolute;
    top: 460px;
    left: 49px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 272px;
    height: 116px;
    z-index: 3;
}

.page__register-title {
    margin: 0;
    width: 272px;
    height: 46px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 42px;
    line-height: 110%;
    letter-spacing: -0.04em;
    color: #376284;
}

.page__register-subtitle {
    margin: 0;
    width: 272px;
    height: 58px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 26px;
    line-height: 110%;
    letter-spacing: -0.04em;
    color: #376284;
    opacity: 0.5;
}

.page__register-head--tall {
    height: auto;
}

.page__register-title--tall {
    height: auto;
}

.page__register-subtitle--tall {
    height: auto;
}

.page__register-sub-line {
    white-space: nowrap;
}

.page__phone-field {
    position: absolute;
    top: 598px;
    left: 49px;
    width: 304.5px;
    height: 53.5px;
    border-radius: 287px;
    background: rgba(0, 134, 240, 0.14);
    cursor: text;
    z-index: 3;
}

#page-already .page__phone-field {
    top: 630px;
}

#page-not-found .page__phone-field {
    top: auto;
    bottom: 166.65px;
}

.page__phone-idle,
.page__phone-edit {
    width: 100%;
    height: 100%;
}

.page__phone-idle {
    position: relative;
    display: block;
}

.page__phone-edit {
    display: none;
    align-items: center;
    gap: 14px;
    padding: 17px 18px 17px 18px;
}

.page__phone-field.is-active .page__phone-idle {
    display: none;
}

.page__phone-field.is-active .page__phone-edit {
    display: flex;
}

.page__phone-icon {
    position: absolute;
    top: 17px;
    left: 18px;
    width: 19.5px;
    height: 19.5px;
}

.page__phone-label {
    position: absolute;
    top: 18.25px;
    left: 51.5px;
    width: 105px;
    height: 17px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 120%;
    letter-spacing: -0.04em;
    color: #0086f0;
    white-space: nowrap;
}

.page__phone-prefix {
    flex-shrink: 0;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 26px;
    line-height: 110%;
    letter-spacing: -0.04em;
    color: #376284;
}

.page__phone-input {
    flex: 1;
    min-width: 0;
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
    outline: none;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 26px;
    line-height: 110%;
    letter-spacing: -0.04em;
    color: #376284;
    width: 100%;
}

.page__register-btn {
    position: absolute;
    top: 764px;
    left: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 307px;
    height: 53px;
    padding: 12px 44px;
    border: none;
    border-radius: 287px;
    background: #0086f0;
    opacity: 1;
    cursor: pointer;
    z-index: 3;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 24px;
    line-height: 120%;
    letter-spacing: -0.04em;
    color: #ffffff;
    text-decoration: none;
}

.page__member-card {
    position: absolute;
    top: 343px;
    left: 8px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 34px;
    width: 387px;
    height: 188px;
    z-index: 3;
}

.page__member-logo {
    width: 75px;
    height: 52px;
}

.page__member-title {
    margin: 0;
    width: 387px;
    height: 102px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 32px;
    line-height: 105%;
    letter-spacing: -0.04em;
    text-align: center;
    color: #2d72a9;
}

.page__form-actions {
    position: absolute;
    top: 695px;
    left: 47px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 307px;
    height: 122px;
    z-index: 3;
}

.page__form-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 307px;
    height: 53px;
    padding: 12px 44px;
    border: none;
    border-radius: 287px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 24px;
    line-height: 120%;
    letter-spacing: -0.04em;
    cursor: pointer;
}

.page__form-btn--primary {
    background: #0086f0;
    color: #ffffff;
}

.page__form-btn--secondary {
    padding: 12px 52px;
    background: rgba(0, 134, 240, 0.14);
    color: #0086f0;
}

.page__cloud {
    position: absolute;
    width: 475px;
    pointer-events: none;
    z-index: 1;
}

.page__cloud--1 {
    top: -20px;
    left: -237px;
    height: 259px;
}

.page__cloud--2 {
    top: 605px;
    left: -189px;
    height: 259.0234375px;
}

.page__cloud--3 {
    top: 294px;
    left: 134px;
    height: 259.0234375px;
}

.page__main__group {
    position: absolute;
    top: 134px;
    left: 0;
    width: 402px;
    height: auto;
}

.page__logo {
    position: absolute;
    top: 94px;
    left: 164px;
    width: 75px;
    height: 52px;
    z-index: 1;
}

.page__arrow {
    position: absolute;
    top: 443px;
    left: 268px;
    width: 18.436388px;
    height: 73px;
    opacity: 1;
    z-index: 1;
}

.page__promo {
    position: absolute;
    top: 485px;
    left: 37px;
    display: flex;
    flex-direction: column;
    gap: 22px;
    width: 315px;
    height: 239px;
    opacity: 1;
    z-index: 1;
}

.page__promo-title {
    margin: 0;
    width: 315px;
    height: 165px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 52px;
    line-height: 105%;
    letter-spacing: -0.04em;
    color: #2d72a9;
}

.page__promo-footer {
    width: 315px;
    height: 52px;
}

.page__promo-sub {
    width: 314px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 22px;
    line-height: 120%;
    letter-spacing: -0.04em;
    color: #2d72a9;
}

.page__promo-sub-row {
    display: flex;
    align-items: center;
    gap: 6px;
    padding-left: 2px;
}

.page__promo-icon {
    flex-shrink: 0;
    width: 5.5px;
    height: 11.5px;
}

.page__promo-sub-line {
    display: block;
}

.page__promo-sub-line--wide {
    white-space: nowrap;
}

.page__btn {
    position: absolute;
    top: 768.26px;
    left: 79px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 245px;
    height: 70px;
    padding: 16px 32px;
    border: none;
    border-radius: 18px;
    background: radial-gradient(50% 50% at 50% 50%, #3ca9ff 0%, #0086f0 100%);
    box-shadow: 0 0 32px 0 rgba(0, 134, 240, 0.6);
    cursor: pointer;
    z-index: 1;
}

.page__btn-text {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 181px;
    height: 38px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 32px;
    line-height: 120%;
    letter-spacing: -0.04em;
    color: #ffffff;
}

.page__how {
    position: absolute;
    top: 900px;
    left: 40px;
    display: flex;
    flex-direction: column;
    gap: 32px;
    width: 323px;
    height: 580px;
    z-index: 1;
}

.page__how-title {
    margin: 0;
    width: 323px;
    height: 80px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 38px;
    line-height: 105%;
    letter-spacing: -0.04em;
    color: #ffffff;
}

.page__how-card {
    width: 323px;
    height: 468px;
    padding: 42px 29px 42px 28px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.1);
}

.page__how-list {
    display: flex;
    flex-direction: column;
    gap: 22px;
    width: 266px;
    height: 384px;
}

.page__how-step {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 266px;
    height: 90px;
}

.page__how-step--lg {
    height: 116px;
}

.page__how-step-badge {
    width: 73.5px;
    height: 26px;
}

.page__how-step-text {
    margin: 0;
    width: 266px;
    height: 52px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 22px;
    line-height: 120%;
    letter-spacing: -0.04em;
    color: #ffffff;
}

.page__how-step-text--lg {
    height: 78px;
}

.page__how-divider {
    display: block;
    width: 266px;
    height: 1px;
}

.page__success {
    position: absolute;
    top: 1532px;
    left: 47px;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 8px;
    width: 324px;
    height: 120px;
    z-index: 1;
}

.page__success-star {
    flex-shrink: 0;
    margin-top: 4px;
    width: 32px;
    height: 32px;
}

.page__success-text {
    margin: 0;
    flex: 1;
    min-width: 0;
    height: 120px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-size: 38px;
    line-height: 105%;
    letter-spacing: -0.04em;
    color: #ffffff;
}

.page__divider {
    position: absolute;
    top: 1704px;
    left: 68px;
    width: 266px;
    height: 1px;
    border: none;
    opacity: 1;
    z-index: 1;
}

.page__info {
    position: absolute;
    top: 1756px;
    left: 47px;
    display: flex;
    flex-direction: column;
    gap: 22px;
    width: 310px;
    height: 178px;
    z-index: 1;
}

.page__info-text {
    margin: 0;
    width: 310px;
    height: 78px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 22px;
    line-height: 120%;
    letter-spacing: -0.04em;
    color: #ffffff;
    opacity: 0.5;
}