a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block
}

body {
    line-height: 1
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
    content: "";
    content: none
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

@font-face {
    font-family: Inter;
    src: url(../fonts/Inter-SemiBold.ttf) format("ttf");
    font-weight: 700
}

@font-face {
    font-family: Inter;
    src: url(../fonts/Inter-ExtraBold.ttf) format("ttf");
    font-weight: 800
}

@font-face {
    font-family: Inter;
    src: url(../fonts/Inter-ExtraBold.ttf) format("ttf");
    font-weight: 800
}

@font-face {
    font-family: "SF Pro Display";
    src: url(../fonts/SF-Pro-Display-Semibold.otf) format("otf");
    font-weight: 600
}

@font-face {
    font-family: "SF Pro Display";
    src: url(../fonts/SF-Pro-Display-Regular.otf) format("otf");
    font-weight: 400
}

* {
    box-sizing: border-box;
    outline: 0;
    border: none;
    color: #fff;
    font-weight: 400;
    margin: 0;
    padding: 0
}

body {
    font-family: Inter, sans-serif;
    font-size: 16px;
    background: #111;
    min-height: 100vh;
    position: relative;
    overflow-x: hidden
}

.header {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 26px;
    margin-bottom: 45px
}

.header-logo {
    border-radius: 55px;
    padding: 8px 12px;
    background: #161616
}

@media (max-width:575px) {
    .header {
        margin-bottom: 100px
    }
}

.footer {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 26px 0
}

.footer-text {
    font-weight: 500;
    font-size: 14px;
    color: rgba(255, 255, 255, .8)
}

.footer-text span {
    font-weight: 600;
    color: #fff
}

.button {
    width: 100%;
    border-radius: 10px;
    padding: 10px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: linear-gradient(272deg, #86bd3d 0, #23d39c 55.5%, #07b5ff 100%);
    font-family: "SF Pro Display", sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 162%;
    color: #2c2c2c;
    cursor: pointer;
    transition: .2s ease
}

.button:hover {
    opacity: .8
}

@media (max-width:575px) {
    .button {
        font-size: 14px
    }
}

.input-wrapper {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
    width: 100%;
    margin-top: 15px
}

.input-wrapper .label {
    font-family: "SF Pro Display", sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 162%;
    text-align: center;
    color: rgba(255, 255, 255, .4)
}

.input-wrapper .input {
    border: 1px solid rgba(255, 255, 255, .04);
    border-radius: 10px;
    padding: 12px;
    background: #1c1c1c;
    width: 100%;
    font-family: "SF Pro Display", sans-serif;
    font-weight: 500;
    font-size: 15px;
    line-height: 165%;
    color: #7e7e7e;
    transition: .3s ease-in-out
}

.input-wrapper .input::before {
    transition: .3s ease-in-out
}

.input-wrapper .input:focus {
    border: 1px solid #86bd3d;
    transition: .3s ease-in-out
}

.input-wrapper .input-icon {
    position: absolute;
    left: 12px;
    bottom: 17px
}

.input-wrapper .input-prefix {
    position: absolute;
    left: 45px;
    bottom: 17px;
    color: #6d6d6d;
    font-size: 16px;
    line-height: 102%;
    font-family: "SF Pro Display", sans-serif;
    font-weight: 500
}

.input-wrapper .input-action {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    right: 16px;
    bottom: 17px;
    background: 0 0;
    cursor: pointer;
    transition: .2s ease
}

.input-wrapper .input-action:hover {
    opacity: .6
}

.page {
    position: relative;
    width: 100vw;
    min-height: 100vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center
}

.page .content {
    position: relative;
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 890px;
    width: 100%;
    padding: 0 10px
}

.page .content .hero {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    padding: 80px 80px 110px;
    background: rgba(255, 255, 255, .04);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-radius: 38px;
    transition: .2s ease
}

.page .content .hero-error {
    max-width: 630px;
    width: 100%;
    gap: 40px;
    padding: 60px;
    margin-bottom: 100px
}

.page .content .hero-sms {
    max-width: 630px;
    width: 100%;
    gap: 0;
    padding: 60px;
    margin-bottom: 100px
}

.page .content .hero-sms-form {
    display: flex;
    flex-direction: column;
    max-width: 350px;
    width: 100%;
    margin-bottom: 52px
}

@media (max-width:575px) {
    .page .content .hero-sms-form {
        margin-bottom: 0
    }
}

.page .content .hero-auth {
    max-width: 630px;
    width: 100%;
    gap: 0;
    padding: 60px;
    margin-bottom: 100px
}

.page .content .hero-auth .title {
    font-family: Inter, sans-serif;
    font-weight: 600;
    font-size: 36px;
    line-height: 116%;
    letter-spacing: -.02em;
    text-align: center;
    margin-bottom: 42px
}

.page .content .hero-auth-form {
    display: flex;
    flex-direction: column;
    max-width: 350px;
    width: 100%;
    margin-bottom: 52px
}

.page .content .hero-auth-form .input-wrapper-auth {
    margin-bottom: 16px
}

.page .content .hero-auth-form .input-wrapper-phone .input {
    padding-left: 85px
}

.page .content .hero-auth-form .input-wrapper-edit .input {
    padding-right: 40px
}

@media (max-width:575px) {
    .page .content .hero-auth-form {
        margin-bottom: 0
    }
}

.page .content .hero-auth .separator {
    width: 100%;
    height: 1px;
    background: #282828;
    margin-bottom: 45px
}

@media (max-width:575px) {
    .page .content .hero-auth .separator {
        margin-bottom: 0
    }
}

.page .content .hero-auth .qr {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-bottom: 44px
}

.page .content .hero-auth .qr-label {
    font-family: "SF Pro Display", sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 162%;
    text-align: center;
    color: rgba(255, 255, 255, .65)
}

.page .content .hero-auth .download {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px
}

.page .content .hero-auth .download-button {
    padding: 12px;
    background: #212121;
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    transition: .2s ease
}

.page .content .hero-auth .download-button-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.page .content .hero-auth .download-button-text__label {
    font-weight: 400;
    font-size: 14px;
    line-height: 116%;
    letter-spacing: -.02em;
    color: rgba(255, 255, 255, .65)
}

.page .content .hero-auth .download-button-text__title {
    font-weight: 500;
    font-size: 16px;
    line-height: 116%;
    letter-spacing: -.001em
}

.page .content .hero-auth .download-button:hover {
    opacity: .8
}

.page .content .hero-text {
    max-width: 370px;
    display: flex;
    flex-direction: column;
    justify-items: center;
    align-items: center;
    gap: 20px
}

.page .content .hero-text__title {
    font-weight: 800;
    font-size: 30px;
    line-height: 116%;
    letter-spacing: -.04em;
    text-align: center
}

@media (max-width:575px) {
    .page .content .hero-text__title {
        font-size: 30px
    }
}

.page .content .hero-text__image {
    width: 160px;
    height: 160px
}

.page .content .hero-text__description {
    font-family: "SF Pro Display", sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 162%;
    text-align: center;
    color: rgba(255, 255, 255, .65)
}

@media (max-width:575px) {
    .page .content .hero-text {
        gap: 16px;
        max-width: 320px
    }
}

.page .content .hero-action {
    width: 100%;
    max-width: 400px
}

@media (max-width:575px) {
    .page .content .hero-action {
        max-width: 260px
    }
}

.page .content .hero-grid {
    width: 100%;
    height: 50%;
    overflow: hidden;
    z-index: -1;
    perspective: 300px;
    position: absolute;
    bottom: 0;
    left: 0;
    opacity: .1
}

.page .content .hero-grid__fade {
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 11;
    background: linear-gradient(180deg, #171717 0, rgba(23, 23, 23, 0) 100%)
}

.page .content .hero-grid__lines {
    width: 100%;
    height: 200%;
    background-image: linear-gradient(to right, rgba(255, 255, 255, .3) 1px, transparent 0), linear-gradient(to bottom, rgba(255, 255, 255, .3) 1px, transparent 0);
    background-size: 30px 6px;
    background-repeat: repeat;
    transform-origin: 100% 0 0;
    animation: play 20s linear infinite
}

@keyframes play {
    0% {
        transform: rotateX(45deg) translateY(-50%)
    }

    100% {
        transform: rotateX(45deg) translateY(0)
    }
}

.page .content .hero-light::before {
    content: "";
    display: block;
    width: 430px;
    height: 230px;
    border-radius: 100%;
    background: #86bd3d;
    filter: blur(150px);
    position: absolute;
    bottom: calc(100% + 24px)
}

.page .content .hero-code {
    padding: 50px;
    max-width: 520px;
    width: 100%
}

.page .content .hero-code .code {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px
}

.page .content .hero-code .code-progress {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px
}

.page .content .hero-code .code-progress__label {
    font-family: "SF Pro Display", sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 162%;
    text-align: center;
    color: rgba(255, 255, 255, .8)
}

.page .content .hero-code .code-progress-points {
    display: flex;
    gap: 8px
}

.page .content .hero-code .code-progress-points .code-point {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #515151;
    transition: .2s ease
}

.page .content .hero-code .code-progress-points .code-point--active {
    background: rgba(255, 255, 255, .8)
}

.page .content .hero-code .code-buttons {
    max-width: 290px;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 10px
}

.page .content .hero-code .code-buttons .code-button {
    flex: 1 0 30%;
    background: 0 0;
    font-family: "SF Pro Display", sans-serif;
    font-weight: 600;
    font-size: 48px;
    line-height: 162%;
    text-align: center;
    color: rgba(255, 255, 255, .8);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: .2s ease
}

.page .content .hero-code .code-buttons .code-button:hover {
    opacity: .6
}

@media (max-width:575px) {
    .page .content .hero-code {
        padding: 0
    }
}

.page .content .hero-loader {
    max-width: 630px;
    width: 100%;
    height: 260px;
    padding: 0;
    margin: auto 0;
    display: flex;
    align-items: center;
    justify-content: center
}

.page .content .hero-loader .progress-wrapper {
    position: relative;
    width: 210px;
    height: 10px;
    border-radius: 93px;
    overflow: hidden;
    background: rgba(255, 255, 255, .1)
}

.page .content .hero-loader .progress-wrapper .progress {
    position: absolute;
    background: linear-gradient(272deg, #86bd3d 0, #23d39c 55.5%, #07b5ff 100%);
    width: 100%;
    height: 100%;
    border-radius: 93px;
    animation: loader 3s ease-in-out infinite
}

@keyframes loader {
    0% {
        width: 0;
        left: 0
    }

    50% {
        width: 100%;
        left: 0
    }

    100% {
        width: 0;
        left: 100%
    }
}

.page .content .hero::after {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: 38px;
    border: 1px solid transparent;
    background: linear-gradient(-25deg, rgba(255, 255, 255, .25), rgba(255, 255, 255, 0), rgba(255, 255, 255, .25)) border-box;
    -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none
}

@media (max-width:575px) {
    .page .content .hero::after {
        display: none
    }
}

@media (max-width:575px) {
    .page .content .hero {
        padding: 0;
        background: 0 0;
        -webkit-backdrop-filter: unset;
        backdrop-filter: unset;
        border-radius: 0;
        gap: 32px
    }

    .page .content .hero-grid {
        display: none
    }

    .page .content .hero::before {
        display: none
    }
}

.page .content::before {
    content: "";
    display: block;
    border-radius: 100%;
    background: rgba(134, 189, 61, .15);
    /* filter: blur(150px); */
    width: 500px;
    height: 500px;
    position: absolute;
    right: 120%;
    bottom: -150px;
    z-index: -1
}

@media (max-width:575px) {
    .page .content::before {
        right: 80%
    }
}

.page .content::after {
    content: "";
    display: block;
    border-radius: 100%;
    background: rgba(134, 189, 61, .15);
    /* filter: blur(150px); */
    width: 500px;
    height: 500px;
    position: absolute;
    left: 120%;
    top: -300px;
    z-index: -1
}

@media (max-width:575px) {
    .page .content::after {
        left: 80%
    }
}

.page .figures-item {
    z-index: -1;
    border-radius: 30px;
    background: linear-gradient(180deg, #86bd3d 37%, #527129 100%);
    transition: .2s ease;
    position: absolute
}

@media (max-width:575px) {
    .page .figures-item {
        border-radius: 15px;
        display: none
    }
}

.page .figures-item-first {
    width: 220px;
    height: 440px;
    transform: rotate(-65deg);
    opacity: .23;
    top: -220px;
    left: -180px
}

@media (max-width:575px) {
    .page .figures-item-first {
        width: 84px;
        height: 102px;
        left: -60px;
        top: 100px;
        transform: rotate(-115deg)
    }
}

.page .figures-item-second {
    width: 130px;
    height: 200px;
    transform: rotate(-136deg);
    top: 50%;
    right: 80%
}

@media (max-width:1000px) {
    .page .figures-item-second {
        right: 100%
    }
}

@media (max-width:575px) {
    .page .figures-item-second {
        width: 110px;
        height: 135px;
        left: -50px
    }
}

.page .figures-item-third {
    width: 225px;
    height: 130px;
    transform: rotate(19deg);
    right: 80px;
    top: 50px
}

@media (max-width:1000px) {
    .page .figures-item-third {
        right: -180px
    }
}

@media (max-width:575px) {
    .page .figures-item-third {
        width: 110px;
        height: 135px;
        right: -70px;
        top: 150px
    }
}

.page .figures-item-fourth {
    border-radius: 71px;
    width: 420px;
    height: 920px;
    transform: rotate(-30deg);
    opacity: .11;
    bottom: -600px;
    right: -300px
}

@media (max-width:1000px) {
    .page .figures-item-fourth {
        right: -500px;
        bottom: -800px
    }
}

@media (max-width:575px) {
    .page .figures-item-fourth {
        width: 240px;
        height: 334px;
        border-radius: 30px;
        top: 560px;
        bottom: auto;
        right: -200px
    }
}

@media (max-width:575px) {
    .page-auth .content .title {
        margin-bottom: 0 !important
    }
}

@media (max-width:575px) {

    .page-auth .content::after,
    .page-auth .content::before {
        display: none
    }
}

@media (max-width:575px) {
    .page-auth .figures-item {
        display: none
    }
}

.page-login .content {
    max-width: 650px;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-login .content .hero {
    width: 100%;
    margin-bottom: 100px
}

.flex-row {
    flex-direction: row;
}

select {
    -webkit-appearance: none;
    appearance: none;
  }