@import url(https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,500;0,700;1,700&display=swap);

.top-content {
    display: flex;
    flex-direction: column;
    flex-basis: 100%;
    justify-content: space-between
}

.start-page__wrapper, .top-content__body{
    display: flex;
    flex-direction: column;
    align-items: center
}

.start-page__wrapper {
    width: 100%;
    min-height: 100%;
    justify-content: flex-start;
    padding: 20px;
}

.start-page__title {
    margin: 0 0 40px;
    padding: 0;
    font-style: italic;
    font-weight: 700;
    font-size: 38px;
    line-height: 49px;
    text-shadow: 1px 1px #6df1ef, 2px 3px #ea375c;
    text-transform: capitalize;
    text-align: start;
    color: #ffffff;
}

.start-page__title span {
    color: #f3275a
}
.progress-page__wrapper{
    padding: 20px;
}
@media (max-width: 450px) {
    .start-page__title {
        margin-bottom: 15px;
        font-size: 25px;
        line-height: 28px
    }
}

@media (max-width: 320px) {
    .start-page__title {
        font-size: 20px;
        line-height: 23px
    }
}
.btn {
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    line-height: 30px;
}
.start-page__subtitle {
    padding: 16px 14px;
    margin: 0 0 31px;
    display: flex;
    font-style: normal;
    font-weight: 500;
    border-radius: 0 15px 15px 15px;
    background: linear-gradient(90deg,#7e80b6,#c53d69 0,#60c2ca);
    color: #ffffff;
}

@media (max-width: 450px) {
    .start-page__subtitle {
        margin-bottom: 20px;
        padding: 2px 20px;
        font-size: 16px;
        line-height: 21px
    }
}

@media (max-width: 320px) {
    .start-page__subtitle {
        font-size: 14px;
        line-height: 18px
    }
}

.start-page__text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-bottom: 25px;
    color: #ffffff;
}

@media (max-width: 450px) {
    .start-page__text {
        margin-bottom: 15px
    }
}

.start-page__text span {
    font-size: 20px;
    line-height: 24px;
    text-align: center;
    color: #dbdbdb
}

.start-page__text span:not(:last-child) {
    margin-bottom: 8px
}

.start-page__text span .purple {
    font-weight: 700;
    color: #6658d9
}

@media (max-width: 450px) {
    .start-page__text span {
        font-size: 16px;
        line-height: 21px
    }
}

@media (max-width: 320px) {
    .start-page__text span {
        font-size: 14px;
        line-height: 18px
    }
}

.start-page__block {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 350px;
    padding: 15px;
    background: #292929;
    box-shadow: 0 4px 4px rgba(0, 0, 0, .25);
    border-radius: 10px
}

@media (max-width: 450px) {
    .start-page__block {
        padding: 10px 7.5px;
        width: 265px
    }
}

@media (max-width: 320px) {
    .start-page__block {
        padding: 10px 7.5px;
        width: 230px
    }
}

.start-page__block img {
    margin-bottom: 15px;
    width: 100%;
    border-radius: 5px
}

.start-page__block p {
    font-weight: 500;
    font-size: 20px;
    line-height: 30px;
    color: #fff;
    text-align: center
}

@media (max-width: 450px) {
    .start-page__block p {
        font-size: 16px;
        line-height: 21px
    }
}

.start-page__block p .purple-text {
    color: #6658d9
}

.start-page__block p .purple-block {
    margin: 0 5px;
    padding: 1px 10px;
    background: #7a6dde;
    border-radius: 43px
}

.start-page__button {
    margin: auto auto 60px;
    text-align: center;
    display: inline-block;
    padding: 16px 8px;
    width: 90%;
    font-weight: 500;
    font-size: 30px;
    line-height: 1.23;
    color: #000;
    border-radius: 10px;
    background-color: #fff;
    box-shadow: 8px 0 #ea375c, 12px 5px 17px 1px rgba(195,63,107,.61), -8px 0 #6df1ef, -9px -2px 13px 1px rgba(115,229,230,.61);
    animation: scale-btn 1s infinite alternate;
}

@media (max-width: 450px) {
    .start-page__button {
        margin-top: 20px;
        font-size: 20px;
        line-height: 24px
    }
}

@media (max-width: 350px) {
    .start-page__button {
        max-width: 250px;
        font-size: 18px;
        line-height: 21px
    }
}

.test-page__wrapper {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
}

.test-page__progress {
    display: flex;
    justify-content: space-between;
    padding: 10px 10px;
    margin-bottom: 25px;
    width: 100%;
    background: #292929;
    box-shadow: 0 4px 4px rgba(0, 0, 0, .25);
    border-radius: 10px
}

.test-page__item {
    width: 37px;
    height: 5px;
    background: #565656;
    border-radius: 5px
}

@media (max-width: 450px) {
    .test-page__item {
        width: 28px
    }
}

@media (max-width: 375px) {
    .test-page__item {
        width: 22px
    }
}

.test-page__item.selected {
    background: #7a6dde
}

.test-page__quest {
    padding: 0;
    margin: 0;
    margin-bottom: 16px;
    font-style: italic;
    font-weight: 700;
    font-size: 15px;
    line-height: 18px;
    text-align: start;
    text-shadow: -1px 1px #6df1ef, 1px 2px #ea375c;
    color: #ffffff;
}

@media (max-width: 450px) {
    .test-page__quest {
        margin-bottom: 25px;
        font-size: 18px;
        line-height: 27px
    }
}

@media (max-width: 320px) {
    .test-page__quest {
        font-size: 18px;
        line-height: 23px
    }
}

.test-page__content {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto;
}

@media (max-width: 450px) {
    .test-page__content {
        margin-bottom: 25px;
        width: 170px;
        height: 170px;
        width: 130px;
        height: 130px
    }
}

.test-page__img{
    margin-bottom: 33px;
    border-radius: 15px;
}
img {
    display: block;
    max-width: 100%;
    height: auto;
}

@media (max-width: 450px) {
    .test-page__img{
        max-height: 200px;
        margin-bottom: 18px;
    }
    .test-page__img{
        margin-bottom: 33px;
        border-radius: 15px;
    }
}

.test-page__column-list {
    width: 100%
}
.test-page__column-item:not(last-of-type) {
    margin-bottom: 16px;
}
.test-page__column-item{
    display: flex;
    align-items: center;
    justify-content: center;
}
@media (min-width: 570px) {
    .test-page__column-answer-btn:hover {
        background-image: linear-gradient(90deg, #c43e6a, #63bfc7);
        color: #000;
    }
}
.test-page__column-answer-btn {
    position: relative;
    width: 100%;
    padding: 16px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-style: normal;
    font-weight: 500;
    font-size: 15px;
    line-height: 18px;
    text-align: start;
    background-clip: padding-box;
    border-radius: 15px;
    border: 2px solid transparent;
    z-index: 0;
}

.test-page__column-answer-btn:before {
    content: "";
    position: absolute;
    top: -1px;
    left: -1px;
    right: 0;
    bottom: 0;
    border-radius: 15px;
    padding: 3px;
    background: linear-gradient(90deg,#c43e6a,#63bfc7) border-box;
    -webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
    -webkit-mask-composite: destination-out;
    mask-composite: exclude;
    z-index: -1;
    height: 104%;
    width: 100.5%;
}
.test-page__column-answer-btn.selected {
    background: #7a6dde !important
}

@media (max-width: 450px) {
    .test-page__column-answer-btn {
        margin-bottom: 10px;
        padding: 10px;
        font-weight: 500;
        font-size: 16px;
        line-height: 21px;
        text-align: center
    }
}

@media (max-width: 320px) {
    .test-page__column-answer-btn {
        font-size: 14px;
        line-height: 18px;
        padding: 10px;
    }
}

.test-page__column-answer-btn.ios-btn {
    background: #292929
}

.test-page__column-answer-btn.ios-btn:before {
    display: none
}

.footer {
    max-width: 550px;
    padding: 0 20px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    font-family: SF Pro Display, serif;
    font-weight: 500;
    font-size: 11px;
    line-height: 13px;
    color: #ffffff;
    min-height: 300px;
    margin-top: 3rem;
}

.footer p {
    margin: 0
}

.footer a {
    color: #ffffff;
}

.result-page__sms {
    margin: 0 auto;
    margin-top: 7px
}

.calculate-page__wrapper {
    width: 100%;
    height: 100%;
    padding-top: 150px;
    display: flex;
    flex-direction: column;
    will-change: transform
}

.calculate__progress {
    position: relative;
    margin-bottom: 90px
}

.calculate__progress .checkmark {
    display: block;
    margin: 0 auto;
    width: 143px;
    height: 143px;
    transform: rotate(-90deg)
}

.calculate__progress .checkmark__border {
    stroke: #dfdcf9;
    stroke-width: 2;
    stroke-miterlimit: 10;
    stroke-dasharray: 0;
    fill: transparent;
    filter: drop-shadow(-1px 0 2px rgb(0, 0, 0))
}

.calculate__progress .checkmark__circle {
    stroke: #f3275a;
    stroke-width: 1;
    stroke-miterlimit: 10;
    transition: all .4s;
    fill: transparent;
    filter: drop-shadow(0 0 1.5px rgba(170, 183, 198, .9));
    border-radius: 10px
}

.calculate__progress .number {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    font-family: EB Garamond, serif;
    font-size: 61px;
    line-height: 69px;
    color: #7a6dde
}

@keyframes blink-70c01bb3 {
    50% {
        opacity: 0
    }
}

.like-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: no-repeat;
    border: none;
    width: 30px;
    height: 36px;
    transition: color .2s;
    cursor: pointer
}

.like-btn .like-icon {
    width: 18px;
    height: 18px;
    margin-bottom: 4px;
    transition: fill .2s
}

.comments-wrapper {
    display: flex;
    flex-direction: column;
    position: relative;
    width: 100%;
    background-color: #f5f5f3;
    border-radius: 15px 15px 0 0;
    color: #000;
    bottom: 0
}

.comments-wrapper .comments-header {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 40px
}

.comments-wrapper .comments-header .comments-counter {
    font-weight: 700
}

.comments-wrapper .comments-content {
    padding: 0 20px;
    background-color: #f5f5f3
}

.comments-wrapper .comments-content .comment {
    display: flex;
    align-items: flex-start;
    margin-bottom: 20px;
    width: calc(100% - 60px)
}

.comments-wrapper .comments-content .comment .avatar {
    min-width: 60px
}

.comments-wrapper .comments-content .comment .avatar img {
    width: 50px;
    height: 50px;
    border-radius: 25px;
    -o-object-fit: cover;
    object-fit: cover
}

@media (max-width: 320px) {
    .comments-wrapper .comments-content .comment .avatar img {
        width: 40px;
        height: 40px
    }
}

.comments-wrapper .comments-content .comment .content {
    font-size: 12px !important;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%
}

.comments-wrapper .comments-content .comment .content .text{
    font-size: 12px !important;
    text-align: left !important;
    color: #000 !important;
}

.comments-wrapper .comments-content .comment .content .content-body {
    width: calc(100% - 30px)
}

.comments-wrapper .comments-content .comment .content .content-body .login {
    color: #909092
}

.comments-wrapper .comments-footer {
    text-align: center;
    position: sticky;
    background-color: #fff;
    left: 0;
    right: 0;
    bottom: 30px;
    margin: 0 -20px;
    padding: 10px 20px
}

.result-top {
    flex-basis: 100%;
    display: flex;
    flex-direction: column;
}
.text_underline{
    padding: 0;
    margin: 0;
    margin-bottom: 24px;
    font-style: normal;
    font-weight: 500;
    font-size: 12px;
    line-height: 15px;
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
    color: #ffffff;
}
.comments-window {
    width: 100%;
    overflow-x: scroll;
    height: 300px;
    border-radius: 15px
}

.comments-window::-webkit-scrollbar {
    display: none
}

.result-page__wrapper {
    width: 100%;
    height: 100%;
    padding: 5px 0 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
}

.result-page__title {
    margin-bottom: 15px;
    font-family: EB Garamond, serif;
    font-weight: 700;
    font-size: 28px;
    line-height: 35px;
    text-align: center;
    text-transform: uppercase;
    color: #6658d9
}

@media (max-width: 450px) {
    .result-page__title {
        margin-bottom: 0;
        font-size: 25px;
        line-height: 28px
    }
}

@media (max-width: 350px) {
    .result-page__title {
        font-size: 20px;
        line-height: 23px
    }
}

.result-page__subtitle {
    margin-bottom: 15px;
    font-size: 20px;
    line-height: 25px;
    color: #fff
}

@media (max-width: 450px) {
    .result-page__subtitle {
        margin-bottom: 5px;
        font-size: 18px;
        line-height: 23px
    }
}

@media (max-width: 350px) {
    .result-page__subtitle {
        font-size: 16px;
        line-height: 19px
    }
}

.result-page__attention {
    padding: 0;
    margin: 0;
    margin-bottom: 14px;
    display: flex;
    justify-content: center;
    font-size: 28px;
    line-height: 37px;
    text-align: start;
    text-shadow: -1px 1px #6df1ef, 1px 2px #ea375c;
    color: #ffffff;
}

@media (max-width: 450px) {
    .result-page__attention {
        margin-bottom: 5px;
        font-size: 24px;
        line-height: 27px
    }
}

.result-page__small {
    font-size: 16px;
    line-height: 21px
}

@media (max-width: 450px) {
    .result-page__small {
        font-size: 14px;
        line-height: 19px
    }
}

@media (max-width: 350px) {
    .result-page__small {
        margin-bottom: 10px;
        font-size: 12px;
        line-height: 17px
    }
}

.result-page__callBtn {
    width: 100%;
    min-height: 59px;
    padding: 16px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    font-style: normal;
    font-weight: 500;
    font-size: 16px;
    line-height: 20px;
    border-radius: 10px;
    background-color: #36be57;
    box-shadow: 4px 5px 17px 1px hsla(0,0%,100%,.15), -1px -2px 13px 1px hsla(0,0%,100%,.15);
    animation: scale-btn 1s infinite alternate;
    border-color: transparent;
    color: #ffffff;
}

.result-page__callBtn img {
    margin-right: 10px
}

@media (max-width: 450px) {
    .result-page__callBtn {
        font-size: 18px;
        line-height: 20px
    }
}

@media (max-width: 350px) {
    .result-page__callBtn {
        margin-bottom: 10px;
        font-size: 16px;
        line-height: 18px
    }
}

.text {
    margin-bottom: 15px;
    font-weight: 400;
    font-size: 20px;
    line-height: 25px;
    text-align: center;
    color: #fff
}

.text .purple {
    font-weight: 500;
    color: #6658d9
}

@media (max-width: 450px) {
    .text {
        font-size: 18px;
        line-height: 23px
    }
}

@media (max-width: 350px) {
    .text {
        margin-bottom: 10px;
        font-size: 14px;
        line-height: 19px
    }
}

.block-white {
    padding: 16px 14px;
    margin: 0 0 24px;
    display: flex;
    font-style: normal;
    font-weight: 500;
    border-radius: 0 15px 15px 15px;
    background: linear-gradient(90deg,#7e80b6,#c53d69 0,#60c2ca);
    color: #ffffff;
}
.result-page__timer-wrapper{
    margin-bottom: 15px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
@media (min-width: 570px) {
    .result-page__timer-text{
        text-align: center;
    }
}
.result-page__timer-text{
    width: 100%;
    padding: 0;
    margin: 0;
    font-style: normal;
    font-weight: 700;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
    padding-top: 10px;
    color: #ffffff;
}
@media (max-width: 450px) {
    .block-white {
        margin-bottom: 15px;
        padding: 7px
    }
}

.block-white img {
    margin-bottom: 15px;
    width: 65px;
    height: 67px
}

@media (max-width: 350px) {
    .block-white img {
        margin-bottom: 5px;
        width: 45px;
        height: 47px
    }
}

.block-white .block-text {
    font-weight: 400;
    font-size: 18px;
    line-height: 23px;
    text-align: center;
    color: #222833
}

.block-white .block-text .bold {
    font-weight: 500
}

.block-white .block-text .purple {
    font-weight: 700;
    color: #6658d9
}

@media (max-width: 450px) {
    .block-white .block-text {
        font-size: 16px;
        line-height: 20px
    }
}

@media (max-width: 350px) {
    .block-white .block-text {
        margin-bottom: 10px;
        font-size: 14px;
        line-height: 19px
    }
}

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    position: relative;
    margin: 0;
}

body {
    font-family: Montserrat,sans-serif;
    font-size: 15px;
    position: relative;
    background-color: #000;
}

body, html {
    height: 100%
}
body:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 85px;
    height: 85px;
    border-radius: 50%;
    background: #7f1f24;
    box-shadow: 1px 4px 37px 52px #ff3d4780;
    z-index: -1
}
body:after {
    content: "";
    position: absolute;
    bottom: 30px;
    left: 0;
    width: 85px;
    height: 85px;
    border-radius: 50%;
    background: #285b5c;
    box-shadow: 1px 4px 37px 52px #43979999;
    z-index: -1
}
main {
    display: block
}
h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b, strong {
    font-weight: bolder
}

code, kbd, samp {
    font-family: monospace, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

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

button, input {
    overflow: visible
}

button, select {
    text-transform: none
}

[type=button], [type=reset], [type=submit], button {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox], [type=radio] {
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

[hidden], template {
    display: none
}

:root {
    --fon-color: #1f232c;
    --animation-duration: 0.8s;
    --circle-diameter: 15px;
    --circle-scale-percent: 0.2
}

a {
    text-decoration: none;
    color: inherit;
    font: inherit
}

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

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

html {
    box-sizing: border-box
}

.content-box-component {
    box-sizing: content-box
}

.visually-hidden:not(:focus):not(:active), input[type=checkbox].visually-hidden, input[type=radio].visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    border: 0;
    padding: 0;
    white-space: nowrap;
    -webkit-clip-path: inset(100%);
    clip-path: inset(100%);
    clip: rect(0 0 0 0);
    overflow: hidden
}

.list {
    margin: 0;
    padding: 0;
    list-style: none
}
.quiz__question{
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 30px 80px;
}
.quiz__butn:hover {
    box-shadow: -5px -5px #6df1ef, -6px -7px 13px 1px rgba(115,229,230,.61), 5px 5px #ea375c, 9px 10px 17px 1px rgba(195,63,107,.61);
}
.quiz__butn{
    max-height: 100%;
    border-radius: 15px;
    padding: 0;
    overflow: hidden;
}
.content_progress{
    width: 100%;
}
.test-page__quest{
    text-align: center;
}
p {
    margin: 0
}

@font-face {
    font-family: SF Pro Display;
    font-style: normal;
    font-weight: 500
}

@font-face {
    font-family: Futura PT;
    font-style: normal;
    font-weight: 400
}

@font-face {
    font-family: Futura PT;
    font-style: normal;
    font-weight: 500
}

@font-face {
    font-family: Futura PT;
    font-style: normal;
    font-weight: 700
}

@keyframes scale-btn {
    0% {
        transform: scale(.9);
    }
    to {
        transform: scale(1.05);
    }
}

* {
    flex-shrink: 0
}

html {
    font-family: Futura PT, sans-serif;
    font-weight: 400
}

.firstPage__quot{
    position: relative;
    padding: 0 30px;
    margin-bottom: 30px;
    font-weight: 500;
    font-size: 12px;
    line-height: 15px;
    color: #ffffff;
}
.firstPage__quot:before {
    content: "“";
    left: 0;
    top: 0;
}
.firstPage__quot:after {
    content: "“";
    right: 0;
    bottom: -20px;
}
.firstPage__quot:after, .firstPage__quot:before {
    position: absolute;
    font-style: normal;
    font-weight: 500;
    font-size: 40px;
    line-height: 40px;
}
.app, .container,.landing_page {
    height: 100%
}

.container {
    display: flex;
    flex-direction: column;
    max-width: 550px;
    width: 100%;
    min-height: 100%;
    padding: 25px 25px 0;
    margin: 0 auto;
}

.container::-webkit-scrollbar {
    width: 0
}

@media (max-width: 450px) {
    .container {
        max-width: 450px;
        padding: 0px;
    }
}

@media (max-width: 375px) {
    .container {
        max-width: 375px;
        padding: 0px;
    }
}

@media (max-width: 320px) {
    .container {
        max-width: 320px;
        padding: 0px;
    }
}

.price {
    margin-top: 10px;
    font-weight: 700;
    font-size: 9px;
    line-height: 19px;
    color: grey;
}

.footer p a{
    color: white;
}

.policy{
    display: block;
    margin: 0 auto;
    text-align: center;
    font-size: 11px;
}

.cons{
    text-align: center;
    color: #808080;
    font-size: 11px;
    padding: 5px 20px 0;
    line-height: 10px;
}

.cons a{
    color: white;
}