.loading[data-v-d48af81c] {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    background: rgba(0,0,0,.25)
}

.relative[data-v-d48af81c] {
    margin: auto;
    display: flex;
    position: relative
}

@keyframes scale-d48af81c {
    0% {
        transform: scale(0)
    }
}

@keyframes translate-d48af81c {
    to {
        transform: translate(200%)
    }
}

.ellipsis[data-v-d48af81c] {
    width: .5rem;
    height: .5rem;
    border-radius: 50%;
    background: var(--red-color)
}

.dark-blue .ellipsis[data-v-d48af81c] {
    background: var(--blue-color)
}

.ellipsis[data-v-d48af81c]:nth-child(n+3) {
    margin-left: .5rem
}

.ellipsis[data-v-d48af81c]:nth-child(1) {
    position: absolute;
    animation: scale-d48af81c .6s infinite
}

.ellipsis[data-v-d48af81c]:nth-child(2),.ellipsis[data-v-d48af81c]:nth-child(3) {
    animation: translate-d48af81c .6s infinite
}

.ellipsis[data-v-d48af81c]:nth-child(4) {
    animation: scale-d48af81c .6s infinite reverse
}

@media screen and (min-width: 1200px) {
    .ellipsis[data-v-d48af81c] {
        width:.25rem;
        height: .25rem
    }

    .ellipsis[data-v-d48af81c]:nth-child(n+3) {
        margin-left: .25rem
    }
}

html {
    box-sizing: border-box;
    line-height: 1.2;
    -webkit-text-size-adjust: none
}

*,*:before,*:after {
    box-sizing: inherit
}

body,h1,h2,h3,h4,h5,h6,p,ol,ul {
    margin: 0;
    padding: 0;
    font-weight: 400
}

ol,ul {
    list-style: none
}

img {
    max-width: 100%;
    height: auto;
    display: block
}

button,input,optgroup,select,textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.2;
    margin: 0;
    outline: none
}

:root {
    --red-color: #d43831;
    --blue-color: #0f7ce4;
    --bg-color: #fafafa;
    --main-bg-color: #fff;
    --input-bg-color: #fff;
    --error-text-color: #ff4d4f;
    --text-1-color: #2a2d2f;
    --text-2-color: #676e76;
    --text-3-color: rgba(0, 0, 0, .25);
    --line-color: #d9d9d9
}

.dark,.dark-blue {
    --bg-color: #1b1119;
    --main-bg-color: #242024;
    --input-bg-color: #352f35;
    --text-1-color: #fff;
    --text-2-color: #999;
    --text-3-color: #ccc;
    --line-color: #444
}

.in-app {
    --bg-color: #fff
}

html {
    height: 100%;
    font-size: 312.5%
}

body {
    height: 100%;
    background: var(--bg-color) url(/universal/assets/bg-light-mobile-2c1194ef.png) center/cover repeat !important;
    font-size: .32rem;
    font-family: Roboto,sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.dark body,.dark-blue body {
    background-image: none
}

.in-app body {
    background: var(--bg-color)
}

#app {
    min-height: 100%;
    display: flex;
    flex-direction: column
}

input,select {
    -webkit-appearance: none;
    -moz-appearance: none
}

main {
    width: 100%;
    margin: .6rem auto
}

@media screen and (min-width: 1200px) {
    html {
        font-size:625%
    }

    body {
        background-image: url(/universal/assets/bg-light-pc-e161bf84.png)
    }

    .dark body {
        background-image: url(/universal/assets/bg-dark-pc-f9fda9ae.png)
    }

    main {
        margin: .3rem auto;
        max-width: 6.2rem
    }
}

form {
    padding: 0 .4rem;
    display: flex;
    flex-direction: column
}

h2 {
    margin-bottom: .32rem;
    color: var(--text-1-color);
    font-size: .36rem;
    font-weight: 700;
    text-align: center
}

.field {
    position: relative
}

.field.required:before {
    position: absolute;
    top: 0;
    left: 0;
    width: .1rem;
    height: .34rem;
    content: "*";
    color: var(--red-color);
    font-size: .22rem;
    transform: translate(-100%) translate(-.06rem)
}

.field+.field {
    margin-top: .24rem
}

.error .message {
    margin-top: .08rem;
    padding-left: .28rem;
    background: url(/universal/assets/exclamation-d4037144.svg) center left/.24rem no-repeat;
    color: var(--error-text-color);
    font-size: .22rem;
    line-height: .34rem
}

.password {
    position: relative
}

.peek {
    position: absolute;
    top: 0;
    right: .24rem;
    bottom: 0;
    width: .32rem;
    padding: 0;
    border: none;
    background: center/contain no-repeat
}

input[type=text]+.peek {
    background-image: url(/universal/assets/eye-invisible-7d9f2af9.svg)
}

input[type=password]+.peek {
    background-image: url(/universal/assets/eye-visible-a840a7b6.svg)
}

.dark input[type=text]+.peek {
    background-image: url(/universal/assets/eye-invisible-dark-c4e8f6f1.svg)
}

.dark input[type=password]+.peek {
    background-image: url(/universal/assets/eye-visible-dark-d2aecc97.svg)
}

.verification {
    display: flex
}

.verification button {
    margin-left: .08rem;
    flex: 0 0 auto
}

.mobile {
    display: flex
}

.mobile input {
    flex: 1 0 auto
}

.mobile input,.mobile select {
    width: auto
}

input {
    background: var(--input-bg-color)
}

input::placeholder {
    color: var(--text-3-color)
}

select {
    background: var(--input-bg-color) url(/universal/assets/down-c7427533.svg) right .24rem center/.32rem no-repeat
}

.dark select {
    background-image: url(/universal/assets/down-dark-d8315a5f.svg)
}

input,select {
    width: 100%;
    display: block;
    padding: .24rem;
    border: .01rem solid var(--line-color);
    border-radius: .02rem;
    color: var(--text-1-color);
    font-size: .26rem;
    line-height: .4rem
}

input[type=password],select[type=password] {
    padding-right: .56rem
}

input:focus:not(:disabled),input:hover:not(:disabled),select:focus:not(:disabled),select:hover:not(:disabled) {
    border-color: var(--red-color);
    box-shadow: 0 0 0 .02rem rgba(212,56,49,.2)
}

.error input,.error select {
    border-color: var(--error-text-color)
}

.hint {
    margin-top: .08rem;
    color: var(--text-2-color);
    font-size: .22rem
}

.collapse {
    background: var(--input-bg-color);
    padding: .24rem
}

.collapse-hint {
    font-size: .28rem;
    color: var(--text-2-color);
    cursor: pointer
}

.collapse-arrow {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: .32rem;
    cursor: pointer;
    background: url(/universal/assets/down-c7427533.svg) right center/.32rem no-repeat
}

.dark .collapse-arrow {
    background-image: url(/universal/assets/down-dark-d8315a5f.svg)
}

.collapse-arrow.expanded {
    transform: rotate(180deg)
}

hr {
    margin: .24rem 0;
    border: none;
    height: .01rem;
    background: var(--line-color);
    opacity: .25
}

button {
    padding: .24rem;
    border-radius: .02rem;
    font-size: .26rem;
    line-height: .4rem
}

button[type=submit] {
    width: 100%
}

.secondary {
    background: var(--main-bg-color);
    border: .01rem solid var(--line-color);
    color: var(--text-2-color)
}

.secondary:focus:not(:disabled),.secondary:hover:not(:disabled) {
    border-color: var(--red-color);
    box-shadow: 0 0 0 .02rem rgba(212,56,49,.2);
    color: var(--red-color)
}

.primary {
    background: var(--red-color);
    border: .01rem solid var(--red-color);
    color: #fff
}

.primary:focus:not(:disabled),.primary:hover:not(:disabled) {
    box-shadow: 0 0 0 .02rem rgba(212,56,49,.2)
}

.agreement {
    margin: .24rem 0 .4rem;
    color: var(--text-3-color);
    font-size: .22rem;
    text-align: center
}

a {
    color: var(--blue-color);
    text-decoration: none
}

a:focus,a:hover {
    text-decoration: underline
}

@media screen and (min-width: 1200px) {
    form {
        padding:.6rem 1rem;
        background: var(--main-bg-color)
    }

    h2 {
        font-size: .16rem
    }

    .field.required:before {
        font-size: .12rem
    }

    .field+.field {
        margin-top: .16rem
    }

    .error .message {
        margin-top: .04rem;
        padding-left: .2rem;
        font-size: .12rem;
        line-height: .16rem;
        background-size: .16rem
    }

    select {
        background-position: right .12rem center;
        background-size: .16rem
    }

    input,select {
        padding: .08rem .12rem;
        font-size: .16rem;
        line-height: .24rem
    }

    .hint {
        margin-top: .04rem;
        font-size: .12rem
    }

    .collapse {
        padding: 0;
        background: transparent
    }

    .collapse-hint {
        margin-top: .08rem;
        font-size: .14rem
    }

    .collapse-arrow {
        background-size: .16rem;
        width: .4rem;
        right: .12rem
    }

    .collapse-arrow.expanded {
        right: -.12rem
    }

    .peek {
        right: .12rem;
        width: .16rem
    }

    button {
        padding: .08rem .12rem;
        border-radius: .02rem;
        font-size: .16rem;
        line-height: .24rem
    }

    hr {
        margin: .12rem 0
    }

    .agreement {
        margin: .16rem .32rem;
        font-size: .14rem
    }
}
