﻿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
}

body {
    line-height: 1
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

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

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;
    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%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%
}

a:focus {
    outline: thin dotted
}

a:active,
a:hover {
    outline: 0
}

img {
    border: 0;
    -ms-interpolation-mode: bicubic
}

figure {
    margin: 0
}

form {
    margin: 0
}

fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    border: 0;
    padding: 0;
    white-space: normal;
    *margin-left: -7px
}

button,
input,
select,
textarea {
    font-size: 100%;
    margin: 0;
    vertical-align: baseline;
    *vertical-align: middle
}

button,
input {
    line-height: normal
}

button,
select {
    text-transform: none
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer;
    *overflow: visible
}

button[disabled],
html input[disabled] {
    cursor: default
}

input[type=checkbox],
input[type=radio] {
    box-sizing: border-box;
    padding: 0;
    *height: 13px;
    *width: 13px
}

input[type=search] {
    -webkit-appearance: textfield;
    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;
    vertical-align: top
}

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
}

.chromeframe {
    margin: .2em 0;
    background: #ccc;
    color: #000;
    padding: .2em 0
}

html {
    scrollbar-gutter: stable
}

*::-webkit-scrollbar {
    width: 5px;
    border-radius: 2px
}

body::-webkit-scrollbar {
    width: 5px;
    border-radius: 2px
}

body::-webkit-scrollbar-track {
    background: #717176
}

body::-webkit-scrollbar-thumb {
    background: #ed2f1f;
    min-height: 150px
}

body::-webkit-scrollbar-thumb:hover {
    background: #ce4133
}

.header {
    height: 112px;
    width: 100%;
    max-width: 1921px;
    margin: 0 auto;
    padding: 0 200px;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%);
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 100
}

.header_logo {
    cursor: pointer;
    width: 120px;
    flex: 0 0 120px
}

.header_logo img {
    width: 100%
}

.header .overflow {
    display: none;
    width: 100vw;
    height: 200vh;
    position: fixed;
    background-color: #0000005e;
    opacity: 0;
    transition: opacity .4s;
    z-index: 20;
    margin-left: -50px;
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px)
}

@media (max-width: 767px) {
    .header .overflow {
        margin-left: -24px
    }
}

.header .overflow.active {
    opacity: 1
}

.header .nav-bar {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding-left: 59px;
    height: 100%;
    line-height: 120%
}

@media (max-width: 1435px) {
    .header .nav-bar {
        padding-left: 40px
    }
}

.header .nav-bar_wrapper {
    gap: 30px;
    display: flex;
    align-items: center;
    padding-left: 10px
}

.header .nav-bar_buttons {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 46px;
    color: #ffffff61
}

@media (max-width: 1610px) {
    .header .nav-bar_buttons {
        gap: 35px
    }
}

@media (max-width: 1480px) {
    .header .nav-bar_buttons {
        gap: 25px
    }
}

.header .nav-bar_buttons a {
    white-space: nowrap;
    display: block;
    transition: color .25s;
    display: flex;
    align-items: center;
    gap: 12px
}

.header .nav-bar_buttons a path {
    transition: fill-opacity .25s
}

.header .nav-bar_buttons a.giveaway {
    position: relative;
    background: linear-gradient(90deg, #be3cf9 30.44%, #2a6ade 59.26%, #be3cf9 84.27%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    background-size: 200%;
    animation: textGradient 3s infinite;
    font-weight: 400;
    height: 100%;
    padding: 0 10px;
    margin: 0 0 0 -10px
}

@media (min-width: 1230px) {
    .header .nav-bar_buttons a.giveaway.with-row:before {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 0px;
        background: linear-gradient(0deg, #0078d640, #0078d600 30.83%);
        transition: .2s
    }

    .header .nav-bar_buttons a.giveaway.with-row:after {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 3px;
        background: linear-gradient(90deg, #be3cf9 30.44%, #2a6ade 59.26%, #be3cf9 84.27%);
        background-size: 200% 100%;
        animation: backgroundGradient 3s infinite
    }
}

.header .nav-bar_buttons a.active:not(.giveaway) {
    color: #ffffffb7
}

.header .nav-bar_buttons a.active:not(.giveaway) path {
    fill-opacity: .7
}

.header .nav-bar_buttons a.active.with-row.giveaway:before {
    height: 100%
}

.header .nav-bar_func-panel {
    display: flex;
    gap: 49px;
    align-items: center;
    height: 42px
}

.header .nav-bar_func-panel .language-select {
    width: 168px;
    height: 100%;
    position: relative
}

.header .nav-bar_func-panel .language-select_container {
    width: 168px;
    height: 50px;
    align-items: center
}

@media (min-width: 1230px) and (max-width: 1560px) {

    .header .nav-bar_func-panel .language-select,
    .header .nav-bar_func-panel .language-select_container {
        width: 24px
    }
}

.header .nav-bar_func-panel .language-select button {
    height: 40px;
    letter-spacing: 1px;
    position: absolute;
    top: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    opacity: 0;
    left: 50%;
    transform: translate(-50%, 170%);
    pointer-events: none;
    line-height: 40px;
    font-weight: 300;
    border: solid 1px rgba(255, 251, 239, 0);
    border-radius: 5px;
    transition: all .3s
}

@media (min-width: 1230px) and (max-width: 1560px) {
    .header .nav-bar_func-panel .language-select button {
        padding: 0 18px
    }
}

.header .nav-bar_func-panel .language-select button img {
    width: 24px;
    height: 24px
}

.header .nav-bar_func-panel .language-select button:hover {
    background-color: #fffbef0e;
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    border: solid 1px rgba(255, 251, 239, .253)
}

@media (min-width: 1230px) and (max-width: 1560px) {
    .header .nav-bar_func-panel .language-select button span {
        display: none
    }
}

.header .nav-bar_func-panel .language-select button.active {
    top: 0;
    opacity: 1;
    pointer-events: all;
    transform: translate(-50%)
}

.header .nav-bar_func-panel .language-select button.active:hover {
    border: solid 1px rgba(255, 251, 239, 0);
    background: none
}

.header .nav-bar_func-panel .language-select_container.active {
    height: 80px
}

.header .nav-bar_func-panel .language-select_container.active button {
    opacity: 1;
    pointer-events: all;
    transform: translate(-50%, 120%)
}

.header .nav-bar_func-panel .language-select_container.active button.active {
    transform: translate(-50%)
}

.header .nav-bar_func-panel .screen-mode-select {
    height: -moz-max-content;
    height: max-content;
    display: flex;
    display: none
}

.header .nav-bar_func-panel .screen-mode-select button {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background-color: #fffbef00;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color .2s
}

.header .nav-bar_func-panel .screen-mode-select button:first-child {
    margin-right: 8px
}

.header .nav-bar_func-panel .screen-mode-select button:hover {
    background-color: #fffbef0d
}

.header .nav-bar_func-panel .screen-mode-select button.active {
    background-color: #fffbef26
}

.header .nav-bar_func-panel .screen-mode-select button.active .first-path {
    opacity: .8
}

.header .nav-bar_func-panel .screen-mode-select button.active .second-path {
    opacity: 1;
    fill-opacity: 1
}

.header .nav-bar_cabinet-btn {
    height: 54px;
    width: 54px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    transition: box-shadow .2s ease;
    border-radius: 4px;
    background: linear-gradient(90deg, #1977fd, #00439e)
}

.header .nav-bar_cabinet-btn .cabinet-btn-text {
    white-space: nowrap;
    font-weight: 600
}

.header .nav-bar_cabinet-btn.active {
    box-shadow: 0 0 25px #1a2fa5
}

.header_vacantion {
    margin-left: 36px;
    width: 180px;
    height: 54px;
    background-image: linear-gradient(90deg, #ec2b1d, #f17d36, #ec2b1d);
    background-size: 200% 100%;
    background-position: 0%;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    font-size: 16px;
    font-family: Gotham Pro, sans-serif;
    font-weight: 400;
    transition: background-position .4s
}

.header_vacantion:hover {
    background-position: 100%
}

.header_vacantion img {
    width: 24px
}

.header_vacantion span {
    display: flex;
    height: 100%;
    align-items: center
}

.header .mobile-hamburger {
    display: none;
    width: 50px;
    height: 50px;
    padding: 14px 12px;
    flex-direction: column;
    justify-content: space-between;
    background-color: #ffffff1a;
    border-radius: 15px
}

.header .mobile-hamburger div {
    width: 100%;
    height: 2px;
    background-color: #89898f;
    border-radius: 2px
}

@media (max-width: 1840px) {
    .header {
        padding: 0 100px
    }
}

@media (max-width: 1435px) {
    .header {
        height: 112px;
        padding: 0 80px
    }

    .section-button {
        width: 300px;
        height: 70px;
        font-size: 22px
    }
}

@media (max-width: 1360px) {
    .header {
        height: 112px
    }
}

@media (max-width: 1230px) {
    .header {
        height: 112px;
        padding: 0 50px
    }

    .header_logo {
        z-index: 2
    }

    .header .nav-bar {
        position: fixed;
        flex-direction: column;
        height: 100vh;
        width: max(30%, 350px);
        left: 0;
        top: 0;
        transform: translate(-100%);
        transition: transform .4s .4s;
        background-color: #070714;
        z-index: 21
    }

    .header .nav-bar_buttons {
        margin-top: 130px;
        flex-direction: column;
        gap: 32px;
        align-items: start
    }

    .header .nav-bar_buttons a {
        transform: translate(-100vw);
        transition: transform .35s
    }

    .header .nav-bar_buttons a:nth-child(1) {
        transition-delay: .25s
    }

    .header .nav-bar_buttons a:nth-child(2) {
        transition-delay: .2s
    }

    .header .nav-bar_buttons a:nth-child(3) {
        transition-delay: .15s
    }

    .header .nav-bar_buttons a:nth-child(4) {
        transition-delay: .1s
    }

    .header .nav-bar_buttons a:nth-child(5) {
        transition-delay: .05s
    }

    .header .nav-bar .header_vacantion {
        top: 45px;
        transition: transform .2s .2s;
        transform: translate(-100vw)
    }

    .header .nav-bar .header_vacantion:hover {
        background-position: 0%
    }

    .header .nav-bar_func-panel {
        position: absolute;
        bottom: 185px;
        left: 50%;
        transform: translate(-150vw);
        transition: transform .5s;
        transition-delay: 0s
    }

    .header .nav-bar_func-panel .language-select_container {
        bottom: 0
    }

    .header .nav-bar_func-panel .language-select button {
        transform: translate(-50%, -170%)
    }

    .header .nav-bar_func-panel .language-select button:hover {
        background-color: none;
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
        border: none
    }

    .header .nav-bar_func-panel .language-select button.active {
        bottom: 0;
        top: unset
    }

    .header .nav-bar_func-panel .language-select button.active:hover {
        background-color: none;
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
        border: none
    }

    .header .nav-bar_func-panel .language-select_container.active button {
        bottom: 0;
        top: unset;
        transform: translate(-50%, -120%)
    }

    .header .nav-bar_func-panel .language-select_container.active button.active {
        transform: translate(-50%);
        background-color: #fffbef0e;
        -webkit-backdrop-filter: blur(5px);
        backdrop-filter: blur(5px);
        border: solid 1px rgba(255, 251, 239, .253)
    }

    .header .nav-bar .nav-bar_cabinet-btn {
        position: absolute;
        bottom: 100px;
        transition: .5s;
        transform: translate(-150vw);
        left: 50%
    }

    .header .mobile-hamburger {
        position: relative;
        display: flex;
        z-index: 21
    }

    .header .mobile-hamburger div {
        width: 26.5px;
        position: relative
    }

    .header .mobile-hamburger div:nth-child(1) {
        top: 0%;
        transform: translateY(0);
        transition: all .3s .3s, rotate .3s
    }

    .header .mobile-hamburger div:nth-child(2) {
        opacity: 1;
        transition: opacity .3s;
        transition-delay: 0s
    }

    .header .mobile-hamburger div:nth-child(3) {
        bottom: 0;
        transform: translateY(0);
        transition: all .3s .3s, rotate .3s
    }

    .header .mobile-hamburger.active div:nth-child(1) {
        top: 50%;
        transform: translateY(-50%);
        rotate: 45deg;
        transition: all .3s, rotate .3s .3s
    }

    .header .mobile-hamburger.active div:nth-child(2) {
        opacity: 0;
        transition-delay: .3s
    }

    .header .mobile-hamburger.active div:nth-child(3) {
        bottom: 50%;
        transform: translateY(50%);
        rotate: -45deg;
        transition: all .3s, rotate .3s .3s
    }

    .header .nav-bar.active {
        transform: translate(0)
    }

    .header .nav-bar.active .nav-bar_func-panel {
        transform: translate(-50%);
        transition-delay: .5s
    }

    .header .nav-bar.active .nav-bar_buttons a {
        transform: translate(0)
    }

    .header .nav-bar.active .nav-bar_buttons a:nth-child(1) {
        transition-delay: .3s
    }

    .header .nav-bar.active .nav-bar_buttons a:nth-child(2) {
        transition-delay: .35s
    }

    .header .nav-bar.active .nav-bar_buttons a:nth-child(3) {
        transition-delay: .4s
    }

    .header .nav-bar.active .nav-bar_buttons a:nth-child(4) {
        transition-delay: .45s
    }

    .header .nav-bar.active .nav-bar_buttons a:nth-child(5) {
        transition-delay: .5s
    }

    .header .nav-bar.active .nav-bar_buttons a:nth-child(6) {
        transition-delay: .55s
    }

    .header .nav-bar.active .header_vacantion {
        transform: translate(0);
        transition: transform .3s .25s
    }

    .header .nav-bar.active .nav-bar_cabinet-btn {
        transform: translate(-50%);
        transition-delay: .5s
    }

    .header_vacantion {
        position: absolute;
        top: 20px;
        left: 59px;
        margin: 0
    }
}

@media (max-width: 767px) {
    .header {
        height: 150px;
        padding: 0 24px
    }

    .header_vacantion span {
        padding-top: 2px
    }
}

@media (max-width: 500px) {
    .header .nav-bar {
        width: 100%
    }
}

.support.with-cookie {
    bottom: 123px
}

.cookie-container {
    position: fixed;
    bottom: 15px;
    right: 15px;
    transition: .3s;
    transition-delay: .3s;
    border: 1px solid rgba(65, 63, 65, .5607843137);
    background: #040f20;
    border-radius: 15px;
    display: flex;
    align-items: center;
    gap: 60px;
    padding: 22px 24px;
    z-index: 100;
    margin-left: 20px
}

.cookie-container .left {
    display: flex;
    align-items: center;
    gap: 15px
}

.cookie-container .left .image {
    width: 46px;
    height: 46px
}

.cookie-container .left .text {
    color: #fff9;
    font-size: 14px;
    line-height: 140%;
    max-width: 370px
}

.cookie-container .right {
    display: flex;
    align-items: center;
    gap: 12px;
    height: 38px
}

.cookie-btn {
    height: 100%;
    border-radius: 4px;
    text-align: center;
    font-size: 12px;
    line-height: 120%;
    transition: .2s;
    padding: 0 29px;
    cursor: pointer
}

.cookie-container .right .cancel-btn {
    background: #1977fd0d;
    color: #fffc
}

.cookie-container .right .accept-btn {
    background: #1977fd;
    transition: .2s
}

.cookie-container.hide {
    opacity: 0;
    pointer-events: none
}

@media (any-hover: hover) {
    .cookie-container .right .accept-btn:hover {
        box-shadow: 0 0 20px #1a2fa5
    }

    .cookie-container .right .cancel-btn:hover {
        box-shadow: 0 0 25px #05142b;
        color: #fff
    }
}

@media (max-width: 832.8px) {
    .support.with-cookie {
        bottom: 135px !important
    }
}

@media (max-width: 767.8px) {
    .cookie-container {
        flex-direction: column;
        gap: 24px;
        bottom: 0;
        left: 0;
        margin: 0;
        width: 100%;
        border-radius: 0;
        border-right: none;
        border-left: none;
        border-bottom: none;
        align-items: start
    }

    .cookie-container .left .text {
        font-size: 12px
    }

    .cookie-container .left .image {
        width: 38px;
        height: 38px
    }

    .cookie-container .right {
        height: 34px
    }

    .cookie-btn {
        flex: 1 1 100%
    }

    .cookie-container .right {
        width: 100%
    }

    .support.with-cookie {
        bottom: 156px !important
    }
}

@media (max-width: 417.8px) {
    .support.with-cookie {
        bottom: 168px !important
    }
}

@keyframes support {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.support {
    position: fixed;
    bottom: 15px;
    right: 15px;
    z-index: 100;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    transition: .3s
}

.support.hidden {
    pointer-events: none;
    opacity: 0
}

.support__text-container {
    margin-top: 3px;
    background-color: #070714;
    color: #fff;
    font-size: 12px;
    padding: 10px;
    z-index: 9998;
    border-radius: 5px
}

.support__img-container {
    width: 40px;
    height: 40px;
    background-color: #16abff;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.support__img-container img {
    width: 30px;
    height: 30px
}

.support.hide {
    opacity: 0;
    pointer-events: none
}

footer {
    padding-bottom: 31px;
    padding-top: 36px;
    background-color: #fffbef05
}

footer .container {
    width: 100%;
    max-width: 1921px;
    padding: 0 200px;
    margin: 0 auto
}

.footer {
    display: flex
}

.footer_body {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 75px
}

.footer_grid {
    display: flex;
    -moz-column-gap: 68px;
    column-gap: 68px;
    row-gap: 42px
}

.footer_grid_item {
    max-width: 192px
}

.footer_grid_item img {
    width: 178px
}

.footer_grid_item ul {
    margin-top: 16px
}

.footer_grid_item li {
    cursor: pointer
}

.footer_grid_item li>a {
    display: block;
    width: 100%;
    font-size: 14px;
    line-height: 28px;
    opacity: .4;
    transition: opacity .2s;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden
}

.footer_grid_item li:hover a {
    opacity: .8
}

.footer_grid_item:first-child {
    cursor: pointer
}

.footer_grid_item:first-child a {
    width: 100%;
    height: 100%;
    display: block;
    z-index: 2
}

.footer_grid_item img {
    height: 108px
}

.footer_grid_title {
    font-size: 16px;
    font-weight: 400
}

.footer_grid_title svg {
    display: none
}

.footer_flex_container {
    width: 347px;
    display: flex;
    flex-wrap: wrap;
    align-items: start;
    gap: 12px;
    justify-content: end
}

.footer_flex_container .social-item {
    padding: 10px 12px 10px 10px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: end;
    gap: 8px;
    background-color: #fffbef0a;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color .25s
}

.footer_flex_container .social-item img {
    width: 24px;
    height: 24px
}

.footer_flex_container .social-item span {
    font-weight: 400;
    font-size: 12px;
    opacity: .4;
    transition: opacity .3s
}

.footer_flex_container .social-item:hover {
    background-color: #fffbef11
}

.footer_flex_container .social-item:hover span {
    opacity: .8
}

.footer_flex {
    position: relative
}

.footer_flex .section-button {
    width: 302px;
    height: 64px;
    position: absolute;
    right: 0;
    bottom: 44px;
    font-size: 16px
}

.footer_bottom {
    margin-top: 18px
}

.footer_bottom_text {
    width: 100%;
    font-size: 12px;
    line-height: 150%;
    color: #fffbef33;
    display: flex;
    justify-content: space-between;
    align-items: end
}

.footer_bottom_text .section-button {
    margin-top: 0;
    width: 302px;
    height: 64px;
    right: 0;
    bottom: 44px;
    font-size: 16px
}

.footer_bottom_text span {
    width: 734px
}

.footer_bottom_pay {
    display: flex;
    gap: 20px
}

.footer_bottom_descr {
    margin-top: 42px;
    height: 38px;
    border-top: solid 1px rgba(255, 251, 239, .1);
    font-size: 14px;
    opacity: .4;
    display: flex;
    align-items: end;
    justify-content: center
}

.footer_bottom_descr div {
    width: -moz-max-content;
    width: max-content
}

@media (max-width: 1840px) {
    .footer .container {
        padding: 0 100px
    }
}

@media (max-width: 1513px) {
    .footer .container {
        padding: 0;
        width: calc(100% - 200px)
    }

    .footer_body {
        gap: unset
    }
}

@media (max-width: 1420px) {
    .footer .container {
        width: 704px;
        margin: 0 auto;
        padding: 0
    }

    .footer_grid {
        width: 100%;
        gap: unset;
        justify-content: space-between
    }

    .footer_body {
        flex-direction: column;
        gap: 40px;
        align-items: center
    }

    .footer_flex {
        width: 100%;
        height: -moz-max-content;
        height: max-content;
        display: flex;
        align-items: center;
        gap: 95px
    }

    .footer_flex_container {
        justify-content: space-between;
        width: 100%
    }

    .footer_flex .section-button {
        width: 260px;
        height: 54px;
        position: relative;
        bottom: unset;
        margin-top: unset
    }

    .footer_bottom {
        margin-top: 40px;
        display: flex;
        flex-direction: column;
        align-items: center
    }

    .footer_bottom_text {
        width: 100%;
        align-items: center;
        gap: 40px
    }

    .footer_bottom_text span {
        width: 370px
    }

    .footer_bottom_descr {
        width: 100%
    }
}

@media (max-width: 900px) {
    .footer_grid {
        gap: 30px
    }
}

@media (max-width: 1200px) {
    .footer_flex_container .social-item:hover {
        background-color: #fffbef0a
    }

    .footer_flex_container .social-item:hover span {
        opacity: .4
    }
}

@media (max-width: 794px) {
    .footer {
        padding-top: 27px
    }

    .footer .container {
        width: 100%;
        padding: 0 16px;
        position: relative
    }

    .footer .section-button {
        height: 49px
    }

    .footer_body {
        margin: 0;
        width: 100%;
        gap: 30px;
        align-items: center
    }

    .footer_grid {
        width: -moz-max-content;
        width: max-content;
        display: grid;
        grid-template-columns: 1fr 1fr;
        row-gap: 10px
    }

    .footer_grid .footer_grid_item.active:nth-child(2) ul {
        height: 56px
    }

    .footer_grid_item {
        width: 220px;
        height: -moz-max-content;
        height: max-content;
        max-width: unset
    }

    .footer_grid_item img {
        position: relative
    }

    .footer_grid_item ul {
        padding-right: 25px;
        margin-top: 5px;
        height: 0px;
        opacity: 0;
        overflow: hidden;
        transition: all .5s
    }

    .footer_grid_item:first-child {
        margin-bottom: 10px;
        height: -moz-max-content;
        height: max-content
    }

    .footer_grid_item li:hover a {
        opacity: .4
    }

    .footer_grid_item.active .footer_grid_title svg {
        transform: translateY(-50%) rotate(270deg)
    }

    .footer_grid_item.active ul {
        opacity: 1
    }

    .footer_grid_title {
        width: 100%;
        height: 32px;
        line-height: 32px;
        position: relative
    }

    .footer_grid_title svg {
        height: 13px;
        display: block;
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%) rotate(90deg);
        transition: transform .3s
    }

    .footer_flex {
        flex-direction: column;
        align-items: start;
        gap: 100px
    }

    .footer_flex .section-button {
        width: 280px;
        height: 49px;
        left: 50%;
        transform: translate(-50%)
    }

    .footer_flex_container {
        justify-content: center;
        flex-wrap: wrap
    }

    .footer_bottom {
        margin-top: 0
    }

    .footer_bottom_text {
        width: 80%;
        text-align: center;
        margin-top: 30px;
        flex-direction: column
    }

    .footer_bottom_text span {
        width: 100%
    }
}

@media (max-width: 500px) {
    .footer_body {
        justify-content: start;
        align-items: start
    }

    .footer_grid {
        display: flex;
        flex-direction: column;
        align-items: start
    }

    .footer_grid_item {
        width: 237px
    }

    .footer_flex_container {
        justify-content: start
    }

    .footer_bottom_text {
        width: 100%;
        text-align: left;
        align-items: start
    }

    .footer_bottom_pay {
        flex-wrap: wrap
    }
}

@font-face {
    font-family: Gotham Pro;
    src: url(../fonts/GothamPro-Light.ttf) format("truetype");
    font-weight: 300;
    font-style: normal
}

@font-face {
    font-family: Gotham Pro;
    src: url(../fonts/GothamPro-Medium.ttf) format("truetype");
    font-weight: 400;
    font-style: normal
}

@font-face {
    font-family: Gotham Pro;
    src: url(../fonts/GothamPro-Bold.ttf) format("truetype");
    font-weight: 500;
    font-style: normal
}

@font-face {
    font-family: Gotham Pro;
    src: url(../fonts/GothamPro-Black.ttf) format("truetype");
    font-weight: 700;
    font-style: normal
}

@font-face {
    font-family: Unbounded;
    src: url(../fonts/Unbounded-Bold.ttf) format("truetype");
    font-weight: 500;
    font-style: normal
}

:root{
  --bg-1:#0b0713;  /* very dark purple */
  --bg-2:#0e0a19;
  --bg-3:#140c24;

  --glow-violet: rgba(138, 92, 245, .22);  /* violet */
  --glow-magenta:rgba(255, 77, 210, .16);  /* magenta */
  --glow-indigo: rgba(96, 70, 200, .14);   /* indigo */
  --line:        rgba(180,140,255,.04);    /* subtle lavender grid */
}

body{
  font-family: Gotham Pro, sans-serif;
  font-weight: 300;
  color-scheme: dark;

  background:
    /* большие пятна свечения */
    radial-gradient(120% 120% at 12% 10%, var(--glow-violet) 0 24%, transparent 60%),
    radial-gradient(120% 140% at 88% 16%, var(--glow-magenta) 0 22%, transparent 62%),
    radial-gradient(140% 120% at 72% 84%, var(--glow-indigo) 0 20%, transparent 65%),
    /* лёгкие диагональные лучи/сеточка */
    conic-gradient(from 210deg at 50% 50%,
      rgba(255,255,255,.03) 0 25%, transparent 25% 50%,
      rgba(255,255,255,.02) 50% 75%, transparent 75% 100%),
    repeating-linear-gradient(135deg, var(--line) 0 1px, transparent 1px 56px),
    /* базовый вертикальный градиент */
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg-2) 55%, var(--bg-3) 100%);
  background-attachment: fixed;
}

/* виньетка по краям */
body::before{
  content:"";
  position: fixed; inset:-8vw;
  pointer-events:none;
  background: radial-gradient(120% 100% at 50% 50%, transparent 60%, rgba(0,0,0,.38) 100%);
  mix-blend-mode:multiply;
  z-index:-1;
}

/* едва заметные «искры» */
body::after{
  content:"";
  position: fixed; inset:0; pointer-events:none;
  background:
    radial-gradient(circle at 22% 32%, rgba(220,180,255,.06) 0 2px, transparent 3px),
    radial-gradient(circle at 78% 72%, rgba(200,160,255,.05) 0 2px, transparent 3px);
  background-size: 3px 3px, 4px 4px;
  mix-blend-mode:overlay;
  opacity:.22;
  z-index:-1;
}


* {
    outline: none;
    -webkit-tap-highlight-color: transparent
}

@media (max-width: 1230px) {
    * {
        -webkit-user-select: none;
        -webkit-touch-callout: none;
        outline: none
    }
}

* {
    box-sizing: border-box
}

button {
    outline: none;
    border: none;
    background: none;
    color: #fffbef;
    font-weight: 400;
    font-family: Gotham Pro
}

a {
    text-decoration: none;
    color: unset;
    outline: none !important
}

body {
    color: #fffbef;
    overflow-x: hidden
}

img {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    pointer-events: none
}

.container {
    margin: 0 auto;
    width: 1312px
}

.container_left {
    width: 1412px;
    margin-left: calc((100vw - 1412px)/2 - 100px)
}

.container_right {
    width: 1512px;
    margin-right: calc((100vw - 1512px)/2 - 100px)
}

.button {
    padding: 21px 32px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 18px;
    font-weight: 500;
    border-radius: 4px;
    background-image: linear-gradient(to right, #1977fd, #034fb6 33%, #00439e);
    background-size: 300% auto;
    background-position: 0%;
    transition: all .3s, color .4s
}

.button_black {
    font-size: 16px;
    font-weight: 400;
    color: #fffbef93;
    background-image: linear-gradient(to right, #fff0, #fff0, #ffffff2d)
}

.button.active {
    background-position: 76%;
    color: #fffbefc9;
    box-shadow: 0 0 20px #1a2fa5
}

.button_black.active {
    box-shadow: none
}

h2 {
    display: block;
    font-size: 36px;
    font-family: Unbounded, Gotham Pro, sans-serif;
    font-weight: 500
}

h2 .blue {
    padding-top: 4px;
    display: block;
    font-size: 46px;
    color: #1977fd
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0
}

.section_title {
    display: flex;
    justify-content: space-between;
    position: relative
}

.section_title_descr {
    padding-top: 10px;
    width: 523px;
    text-align: right;
    color: #fff9
}

.section_title_button {
    height: -moz-max-content;
    height: max-content;
    padding: 20px 32px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-radius: 20px;
    font-weight: 500;
    background-color: #34aadf26;
    font-size: 18px;
    transition: background-color .3s;
    cursor: pointer
}

.section_title_button div {
    width: 24px;
    height: 24px;
    border-radius: 60%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #34aadf
}

.section_title_button div img {
    width: 13.5px
}

.section_title_button.active {
    background-color: #34aadf66
}

.section_title .stroke-line {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.fake-border {
    width: 17px;
    height: calc(100% + 1px);
    position: absolute;
    right: 0;
    bottom: 0;
    border: 1px solid #02884f;
    border-left: none;
    border-radius: 0 20px 20px 0;
    pointer-events: none
}

.ellipse-container {
    position: absolute;
    width: 70vw;
    min-height: 70vw;
    z-index: -1;
    overflow: hidden;
    pointer-events: none
}

.ellipse {
    position: absolute;
    width: 40vw;
    height: 40vw;
    min-height: 700px;
    min-width: 700px;
    border-radius: 60%;
    z-index: -1
}

.lock-scroll {
    overflow: hidden
}

@media (max-width: 1700px) {
    .container_right {
        margin: 0 auto;
        width: 1312px
    }
}

@media (max-width: 1500px) {
    .container {
        width: 1100px
    }

    .section_title .stroke-line {
        display: none
    }
}

@media (max-width: 1200px) {
    .container {
        width: 800px
    }

    .container_left {
        margin: 0 auto;
        width: 800px
    }

    .section_title h2 {
        font-size: 32px
    }

    .section_title .blue {
        font-size: 36px
    }

    .section_title_descr {
        width: 345px
    }

    .ellipse-container {
        min-width: 100%;
        min-height: 100%
    }
}

@media (max-width: 900px) {
    .container {
        margin: 0 40px;
        width: calc(100% - 80px)
    }

    .section_title {
        flex-direction: column;
        align-items: center
    }

    .section_title h2,
    .section_title .blue {
        text-align: center
    }

    .section_title_descr {
        margin-top: 10px;
        width: 350px;
        max-width: 100%;
        text-align: center
    }

    .section_title_button {
        margin-top: 33px;
        width: 100%;
        max-width: 400px;
        justify-content: center
    }
}

@media (max-width: 719px) {
    .button {
        padding-top: 16px;
        padding-bottom: 16px;
        font-size: 16px
    }

    h2 {
        font-size: 18px
    }

    h2 .blue {
        font-size: 29px
    }

    .section_title h2 {
        font-size: 18px
    }

    .section_title h2 .blue {
        font-size: 29px
    }

    .section_title_descr {
        font-size: 14px;
        line-height: 18px
    }

    .section_title_button {
        font-size: 16px;
        padding-top: 16px;
        padding-bottom: 16px
    }

    .section_title_button div {
        width: 18px;
        height: 18px
    }

    .section_title_button div img {
        width: 10.17px
    }
}

@media (max-width: 530px) {
    .container {
        margin: 0 auto;
        width: calc(100% - 32px)
    }

    .section_title {
        align-items: start
    }

    .section_title h2,
    .section_title h2 .blue,
    .section_title_descr,
    h2,
    h2 .blue {
        text-align: start
    }
}

.localPreloader {
    transition: filter .4s;
    transition-delay: 0s
}

.localPreloader.localPreloaderOn {
    transition-delay: .1s;
    filter: blur(1.5px) !important;
    pointer-events: none
}

.loader-container {
    position: fixed;
    width: 100vw;
    height: 100vh;
    display: none;
    z-index: 10000;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    transition: .2s ease;
    opacity: 0
}

.loader-container .wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: -moz-max-content;
    width: max-content
}

.loader-container .wrap .logo-container {
    position: relative;
    width: 190px;
    height: 87px;
    animation-duration: .2s;
    animation-iteration-count: 1
}

.loader-container .wrap .logo-container img {
    width: 190px;
    height: 87px;
    -o-object-fit: contain;
    object-fit: contain
}

.loader-container .wrap .logo-container .first-logo,
.loader-container .wrap .logo-container .second-logo {
    position: absolute;
    left: 0;
    top: 0
}

.loader-container .wrap .logo-container .second-logo {
    clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0% 100%);
    overflow: hidden;
    animation-timing-function: cubic-bezier(0, .61, .68, .86);
    animation-duration: 8s;
    animation-iteration-count: 1
}

.loader-container.active {
    display: block;
    animation: showLoaderContainer .5s ease-out;
    animation-delay: 1s;
    animation-fill-mode: forwards
}

.loader-container.active .logo-container .second-logo {
    animation-fill-mode: forwards;
    animation-delay: 1.5s;
    animation-name: fillPreloaderLogo
}

@keyframes showLoaderContainer {
    0% {
        opacity: 0;
        -webkit-backdrop-filter: blur(0px);
        backdrop-filter: blur(0px)
    }

    to {
        opacity: 1;
        -webkit-backdrop-filter: blur(3px);
        backdrop-filter: blur(3px);
        background: #030b17de
    }
}

@keyframes flowerFlow {
    0% {
        opacity: 1;
        transform: rotate(0);
        box-shadow: 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor, 0 0 0 -.5em currentcolor
    }

    to {
        opacity: 0;
        transform: rotate(180deg);
        box-shadow: -1em -1em 0 -.35em currentcolor, 0 -1.5em 0 -.35em currentcolor, 1em -1em 0 -.35em currentcolor, -1.5em 0 0 -.35em currentcolor, 1.5em 0 0 -.35em currentcolor, -1em 1em 0 -.35em currentcolor, 0 1.5em 0 -.35em currentcolor, 1em 1em 0 -.35em currentcolor
    }
}

@keyframes dotFirst {
    0% {
        opacity: 0
    }

    10% {
        opacity: 1
    }

    to {
        opacity: 1
    }
}

@keyframes dotSecond {
    0% {
        opacity: 0
    }

    20% {
        opacity: 0
    }

    30% {
        opacity: 1
    }

    to {
        opacity: 1
    }
}

@keyframes dotThird {
    0% {
        opacity: 0
    }

    40% {
        opacity: 0
    }

    50% {
        opacity: 1
    }

    to {
        opacity: 1
    }
}

@keyframes fillPreloaderLogo {
    0% {
        clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0% 100%)
    }

    to {
        clip-path: polygon(0 0%, 100% 0%, 100% 100%, 0% 100%)
    }
}

@keyframes textGradient {
    0% {
        background-position: 0%
    }

    to {
        background-position: 200%
    }
}

@keyframes backgroundGradient {
    0% {
        background-position: 0% 50%
    }

    to {
        background-position: 200% 50%
    }
}

@keyframes online-icon-animation {
    0% {
        width: 100%;
        height: 100%
    }

    25% {
        width: 75%;
        height: 75%
    }

    50% {
        width: 100%;
        height: 100%
    }

    to {
        width: 100%;
        height: 100%
    }
}

.popup {
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    background-color: #003af700;
    -webkit-backdrop-filter: blur(0);
    backdrop-filter: blur(0);
    z-index: 100;
    transition: .5s all;
    display: none;
    z-index: 1000
}

@media (max-width: 840px) {
    .popup {
        overflow-y: scroll
    }
}

.popup_modal {
    padding: 20px;
    width: 521px;
    max-width: 100vw;
    height: -moz-max-content;
    height: max-content;
    min-height: 100px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -120vh);
    transition: transform .3s;
    transform: translate(-50%, -200vh)
}

.popup_modal:not(.check) {
    border-radius: 10px;
    background: linear-gradient(180deg, #fffbef0d, #fffbef00);
    padding-top: 30px
}

.popup_modal__fake-border {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 30px;
    border-radius: 0 0 12px 12px;
    border: 1px solid rgb(33, 34, 41);
    border-top: 0px
}

.popup_modal__fake-border:before {
    content: "";
    position: absolute;
    bottom: 29px;
    right: -1px;
    height: 155%;
    width: 1px;
    background-image: linear-gradient(to top, #212229, #21222900)
}

.popup_modal__fake-border:after {
    content: "";
    position: absolute;
    bottom: 29px;
    left: -1px;
    height: 170%;
    width: 1px;
    background-image: linear-gradient(to top, #212229, #21222900)
}

.popup_modal:not(.check) .title {
    padding: 0 30px;
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    line-height: 140%
}

.popup_modal .text {
    margin-top: 20px;
    text-align: center;
    font-weight: 400;
    line-height: 140%;
    color: #fff6;
    font-size: 16px;
    font-weight: 300
}

.popup_modal .close {
    width: 40px;
    height: 40px;
    position: absolute;
    border-radius: 4px;
    pointer-events: all;
    transition: background-color .2s;
    background: #fffbef08;
    cursor: pointer
}

.popup_modal .close:hover {
    background: #fffbef26
}

.popup_modal .close:before,
.popup_modal .close:after {
    content: "";
    height: 1px;
    width: 60%;
    position: absolute;
    top: 50%;
    left: 50%;
    background-color: #5e5e5e;
    transform: translate(-50%, -50%) rotate(-45deg)
}

.popup_modal .close:after {
    transform: translate(-50%, -50%) rotate(45deg)
}

.popup_modal .close:hover {
    background-color: #292929a1
}

.popup_modal:not(.check) .close {
    top: 15px;
    right: 10px
}

.popup_modal.check {
    width: -moz-max-content;
    width: max-content;
    padding: 20px 10px 120px
}

.popup_modal.check .popup_modal__fake-border,
.popup_modal.check .title {
    display: none
}

.popup_modal.check .close {
    top: 35px;
    left: 295px;
    z-index: 1000
}

@media (max-width: 840px) {
    .popup_modal {
        align-items: center;
        flex-direction: column;
        overflow-y: auto
    }
}

.popup_modal .payment {
    height: 473px;
    width: 698px;
    display: flex;
    gap: 18px
}

.popup_modal .payment__payment-systems,
.popup_modal .payment__info {
    flex: 0 0 calc(50% - 9px)
}

@media (max-width: 840px) {
    .popup_modal .payment {
        flex-direction: column;
        width: -moz-max-content;
        width: max-content;
        height: -moz-max-content;
        height: max-content
    }
}

.popup_modal .payment .check {
    height: 100%;
    position: relative;
    align-items: center;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between
}

@media (max-width: 840px) {
    .popup_modal .payment .check {
        flex: 0 0 473px;
        width: 340px
    }
}

.popup_modal .payment .check__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.popup_modal .payment .check__top-content {
    width: 100%;
    padding: 90px 32px 0;
    display: flex;
    align-items: center;
    flex-direction: column
}

.popup_modal .payment .check__logo {
    width: 104px;
    height: auto;
    -o-object-fit: contain;
    object-fit: contain;
    padding-bottom: 15px
}

.popup_modal .payment .check__title {
    color: #fff6;
    font-size: 16px;
    line-height: 140%;
    padding-bottom: 10px
}

.popup_modal .payment .check__nickname {
    color: #fff;
    font-size: 24px;
    font-weight: 700;
    line-height: 140%;
    max-width: 250px;
    text-align: center;
    padding-bottom: 20px
}

.popup_modal .payment .check__id-tag {
    display: flex;
    align-items: center;
    gap: 8px;
    border-radius: 10px;
    height: 42px;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, .05);
    background: linear-gradient(180deg, #ffffff0d, #fff0)
}

.popup_modal .payment .check__bottom-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 1;
    position: relative;
    padding: 0 32px 27px;
    width: 100%
}

.popup_modal .payment .check__info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 50px
}

.popup_modal .payment .check__info-row:first-child {
    border-bottom: 1px solid rgba(255, 255, 255, .05)
}

.popup_modal .payment .check__info-col:first-child {
    color: #fff9;
    font-size: 16px;
    line-height: 140%
}

.popup_modal .payment .check__info-col:last-child {
    color: #fff;
    font-size: 16px;
    font-weight: 400;
    line-height: 140%
}

.popup_modal .payment .payment-systems {
    height: 100%;
    padding: 34px 15px 30px 30px;
    position: relative
}

.popup_modal .payment .payment-systems__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media (max-width: 840px) {
    .popup_modal .payment .payment-systems {
        flex: 0 0 473px;
        width: 340px
    }
}

.popup_modal .payment .payment-systems__title {
    color: #fff9;
    font-size: 16px;
    line-height: 140%;
    padding-bottom: 24px
}

.popup_modal .payment .payment-systems__items-container {
    padding-right: 15px;
    height: calc(100% - 40px);
    max-height: calc(100% - 40px);
    overflow: auto;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.popup_modal .payment .payment-systems__items-container::-webkit-scrollbar-track {
    background: #3530326e
}

.popup_modal .payment .payment-systems__items-container::-webkit-scrollbar {
    width: 3px;
    border-radius: 3px
}

.popup_modal .payment .payment-systems__items-container::-webkit-scrollbar-thumb {
    background: #353032;
    min-height: 150px
}

.popup_modal .payment .payment-systems__items {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    height: 100%;
    flex-direction: column;
    justify-content: start;
    padding-top: 1px
}

.popup_modal .payment .payment-systems__item {
    display: flex;
    width: 100%;
    align-items: center;
    border-radius: 4px;
    border: 1px solid rgba(255, 251, 239, .1);
    background: #fffbef05;
    padding: 14px 12px;
    transition: all .2s ease;
    gap: 8px;
    cursor: pointer;
    position: relative
}

.popup_modal .payment .payment-systems__item.with-bonus {
    background-image: linear-gradient(120deg, #fffbef05 50%, #ffffff26 55%, #fffbef05 65%);
    animation: animateBg cubic-bezier(.66, .34, .77, .54) 2.5s infinite;
    animation-delay: 2s;
    background-size: 270%
}

.popup_modal .payment .payment-systems__item:hover {
    background: #fffbef0d
}

.popup_modal .payment .payment-systems__item-bonus {
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 0 3px 0 10px;
    color: #fff;
    text-shadow: 0px 0px 16.5px rgba(0, 0, 0, .65);
    font-size: 10px;
    font-weight: 700;
    height: 18px;
    display: flex;
    align-items: center;
    padding: 0 5px;
    line-height: 100%;
    background-size: 270%;
    background-color: #fb7a01;
    background-image: linear-gradient(120deg, #fb7a01 50%, #e9c099 55%, #fb7a01 65%);
    animation: animateBg cubic-bezier(.66, .34, .77, .54) 2.5s infinite;
    animation-delay: 2s
}

.popup_modal .payment .payment-systems__item-icon {
    width: 32px;
    height: 32px;
    flex-shrink: 0
}

.popup_modal .payment .payment-systems__item-name {
    font-size: 14px;
    font-weight: 700;
    line-height: 140%
}

.popup_modal .payment .payment-systems__item-description {
    font-size: 10px;
    font-weight: 300;
    line-height: 130%
}

.popup_custom.close {
    opacity: 1;
    animation: hide-custom-popup .3s ease 0s 1 forwards
}

.popup.active {
    background-color: #02040cd4;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px)
}

.popup.active .popup_modal {
    transform: translate(-50%, -50%)
}

.alert-payment {
    max-width: 402px;
    border-radius: 12px;
    border: 1px solid #101723 !important;
    background: #030b17 !important;
    overflow: hidden;
    position: relative
}

.alert-payment .close,
.alert-payment .title,
.alert-payment .text {
    display: none !important
}

.alert-payment:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(62.51% 32.69% at 50% 0%, #ff474714, #ff474700) !important;
    z-index: -1
}

.alert-payment .a-icon {
    margin: 0 auto;
    width: 68px;
    height: 68px;
    background-color: #ff474714;
    border: 1px solid rgba(255, 71, 71, .1);
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center
}

.alert-payment .a-icon svg {
    width: 24px;
    height: 24px
}

.alert-payment .a-title {
    color: #fff;
    text-align: center;
    font-family: Unbounded;
    font-size: 18px;
    font-weight: 500;
    padding-top: 24px
}

.alert-payment .a-description {
    color: #fff6;
    text-align: center;
    font-size: 14px;
    font-weight: 300;
    line-height: 140%;
    padding-top: 16px
}

.alert-payment .a-text {
    margin-top: 27px;
    padding: 16px 17px;
    border-radius: 6px;
    border: 1px solid rgba(255, 71, 71, .15);
    background: #ff474714;
    color: #fff9;
    font-size: 14px;
    font-weight: 300;
    line-height: 140%;
    text-align: center
}

.alert-payment .a-text .red {
    color: #ff4747
}

.alert-payment .a-button {
    margin: 30px auto 0;
    height: 56px;
    display: flex;
    align-items: center;
    padding: 0 43px;
    border-radius: 4px;
    background: #ffffff0d;
    color: #fff9;
    text-align: center;
    font-size: 14px;
    font-weight: 400;
    pointer-events: none
}

.alert-payment .a-button.active {
    background-image: linear-gradient(to right, #1977fd, #034fb6 33%, #00439e);
    background-size: 300% auto;
    background-position: 0%;
    transition: all .3s, color .4s;
    color: #fffbef;
    pointer-events: initial
}

@media (any-hover: hover) {
    .alert-payment .a-button.active:hover {
        background-position: 76%;
        color: #fffbefc9;
        box-shadow: 0 0 20px #1a2fa5
    }
}

@media (max-width: 840px) {
    .popup.active .popup_modal.check {
        height: 100vh
    }
}

@media (max-width: 550px) {

    .popup .popup_modal:not(.check),
    .popup.active .popup_modal:not(.check) {
        padding-top: 20px;
        padding-bottom: 20px;
        max-width: calc(100vw - 40px);
        width: -moz-max-content;
        width: max-content;
        min-width: 280px
    }

    .popup .popup_modal:not(.check)>.title,
    .popup.active .popup_modal:not(.check)>.title {
        width: 150px;
        margin: 0 auto;
        padding: 0
    }
}

@media (max-width: 550px) {
    .alert-payment .close {
        display: block !important
    }

    .alert-payment .a-icon {
        width: 56px;
        height: 56px
    }

    .alert-payment .a-icon svg {
        width: 24px;
        height: 24px
    }

    .alert-payment .a-title {
        font-size: 16px;
        padding-top: 22px
    }

    .alert-payment .a-description {
        font-size: 12px
    }

    .alert-payment .a-text {
        font-size: 12px;
        margin-top: 20px;
        padding: 16px
    }

    .alert-payment .a-button {
        margin-top: 18px;
        height: 48px;
        font-size: 12px;
        padding: 0 25px
    }
}

@keyframes show-custom-popup {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes hide-custom-popup {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

body {
    background-color: #050608
}

footer {
    background-color: #08080c
}

.fms {
    position: relative;
    height: 95vh;
    max-height: 1100px;
    min-height: 810px;
    background-image: url(../img/families/main-background.webp);
    background-size: auto 100%;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    margin-bottom: 50px
}

.fms__center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

.fms__title {
    font-family: Unbounded;
    font-weight: 900;
    line-height: 120%;
    font-size: 42px;
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-wrap: wrap;
    white-space: nowrap
}

.fms__title .blue {
    color: #1977fd;
    text-shadow: 0px 0px 44.2px rgba(0, 0, 0, .45)
}

.fms__title .white {
    color: #fff;
    display: flex;
    align-items: center;
    gap: 16px;
    font-weight: 900
}

.fms__title .white div {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center
}

.fms__title .white div img {
    width: 22px;
    height: 22px
}

.fms__sub-title {
    color: #fff9;
    text-align: center;
    font-size: 16px;
    font-weight: 300;
    line-height: 140%;
    max-width: 670px;
    padding: 22px 20px 0
}

.fms__buttons {
    padding-top: 34px;
    display: flex;
    align-items: center;
    gap: 18px
}

.fms__reg {
    text-align: center;
    padding: 28px 0 0;
    color: #fff6;
    font-size: 16px;
    font-weight: 300
}

.fms__reg button {
    color: #fffc;
    padding: 0
}

@media (any-hover: hover) {
    .fms__reg button:hover {
        text-decoration: underline
    }
}

.fms__bottom {
    max-width: 1352px;
    width: 100%;
    padding: 0 20px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%)
}

.fms__stats {
    display: flex;
    align-items: center;
    justify-content: space-between
}

.fms__metric div:first-child {
    display: flex;
    align-items: center;
    gap: 15px
}

.fms__metric div:first-child img {
    width: 32px;
    height: 32px
}

.fms__metric div:first-child span {
    color: #fff;
    font-size: 56px;
    font-weight: 700;
    line-height: 120%
}

.fms__metric div:last-child {
    text-align: center;
    color: #fff6;
    font-size: 16px;
    font-weight: 300;
    line-height: 120%
}

.fms__text {
    padding-top: 52px;
    margin: 0 auto;
    max-width: 570px;
    color: #fff3;
    text-align: center;
    font-size: 14px;
    font-weight: 300;
    line-height: 140%
}

.flb {
    margin: 0 auto;
    max-width: 1352px;
    padding: 50px 0 0
}

.flb .section-title {
    padding: 0 20px
}

.flb__places {
    padding: 64px 20px 0;
    display: flex;
    gap: 18px
}

.flb .place {
    position: relative;
    flex: 0 0 calc(33.33333% - 12px);
    border-radius: 6px;
    overflow: hidden;
    background-repeat: no-repeat;
    background-size: 100% auto;
    display: flex;
    flex-direction: column
}

.flb .place:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1
}

.flb .place__top {
    padding: 32px 32px 0;
    display: flex;
    justify-content: space-between
}

.flb .place__logo {
    width: 72px;
    height: 72px;
    border-radius: 100%;
    overflow: hidden;
    -o-object-fit: cover;
    object-fit: cover
}

.flb .place__icon {
    position: relative;
    width: 52px;
    height: 52px;
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center
}

.flb .place__icon img {
    width: 24px;
    height: 24px
}

.flb .place__body {
    padding: 36px 32px 0
}

.flb .place__name {
    color: #fff;
    font-size: 24px;
    font-weight: 400
}

.flb .place__stats {
    padding-top: 42px;
    display: flex;
    align-items: center;
    gap: 82px
}

.flb .place__stat:first-child div:first-child {
    color: #fff6;
    font-size: 16px;
    font-weight: 300
}

.flb .place__stat:first-child div:last-child {
    display: flex;
    align-items: center;
    padding-top: 6px;
    gap: 6px
}

.flb .place__stat:first-child div:last-child img {
    width: 20px;
    height: 20px
}

.flb .place__stat:first-child div:last-child span {
    color: #fff;
    font-size: 21px;
    font-weight: 400
}

.flb .place__stat:last-child div:first-child {
    color: #fff6;
    font-size: 16px;
    font-weight: 300
}

.flb .place__stat:last-child div:last-child {
    padding-top: 6px;
    color: #fff;
    font-size: 21px;
    font-weight: 400
}

.flb .place__leader {
    padding-top: 22px
}

.flb .place__leader div:first-child {
    color: #fff6;
    font-size: 16px;
    font-weight: 300
}

.flb .place__leader div:last-child {
    padding-top: 6px;
    color: #fff;
    font-size: 21px;
    font-weight: 400
}

.flb .place__bottom {
    margin-top: auto;
    padding: 20px
}

.flb .place__bottom .line {
    width: 100%
}

.flb .place.gold {
    height: 460px;
    background-image: url(../img/families/place-gold-bg.webp)
}

.flb .place.gold:after {
    background: radial-gradient(84.45% 84.45% at 100% 0%, #ffc42f0d, #ffc42f00), #08080c
}

.flb .place.gold .place__icon {
    background: radial-gradient(31.55% 123.65% at 56.82% 33.33%, #fff7e2, #ffc42f), #d9d9d9
}

.flb .place.silver {
    margin-top: 30px;
    background-image: url(../img/families/place-silver-bg.webp)
}

.flb .place.silver:after {
    background: radial-gradient(84.45% 84.45% at 100% 0%, #ffffff0d, #fff0), #08080c
}

.flb .place.silver .place__icon {
    background: radial-gradient(31.55% 123.65% at 56.82% 33.33%, #fff, #b6b6b6), #d9d9d9
}

.flb .place.bronze {
    background-image: url(../img/families/place-bronze-bg.webp);
    margin-top: 65px
}

.flb .place.bronze:after {
    background: radial-gradient(84.45% 84.45% at 100% 0%, #855c570d, #855c5700), #08080c
}

.flb .place.bronze .place__icon {
    background: radial-gradient(36.01% 123.65% at 56.82% 33.33%, #946661, #6a4945)
}

.flb__board {
    padding-top: 28px
}

.flb .board {
    margin: 0 20px;
    background: #0e0e13;
    border-radius: 6px;
    padding-bottom: 2px
}

.flb .board__row {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr 1fr 2fr;
    margin: 2px
}

.flb .board__row.b-header .board__column {
    color: #fff6;
    font-size: 16px;
    font-weight: 300;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center
}

.flb .board__row.b-body {
    background: #08080c
}

.flb .board__row.b-body .board__column {
    height: 72px;
    display: flex;
    align-items: center;
    font-size: 18px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.flb .board__row.b-body .board__column:nth-child(1) {
    padding-left: 42%;
    color: #fff6
}

.flb .board__row.b-body .board__column:nth-child(2) {
    padding-left: 32%;
    gap: 12px
}

.flb .board__row.b-body .board__column:nth-child(2) img {
    width: 42px;
    height: 42px;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 100%;
    overflow: hidden;
    flex: 0 0 42px
}

.flb .board__row.b-body .board__column:nth-child(2) span {
    color: #fff;
    font-weight: 300
}

.flb .board__row.b-body .board__column:nth-child(3) {
    color: #fff;
    line-height: 140%;
    gap: 8px;
    padding-left: 28%
}

.flb .board__row.b-body .board__column:nth-child(4) {
    padding-left: 37%
}

.flb .board__row.b-body .board__column:nth-child(5) {
    padding-left: 31%;
    padding-right: 10px
}

.flb .board__row.b-body .board__column span {
    display: inline-block;
    width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
}

.flb .board__row:nth-child(2) {
    border-radius: 4px 4px 0 0
}

.flb .board__row:last-child {
    border-radius: 0 0 4px 4px;
    margin-bottom: 0
}

.flb__boost {
    padding-top: 144px
}

.flb .boost {
    display: grid;
    grid-template-columns: repeat(3, 1fr)
}

.flb .boost__item {
    border-bottom: 1px solid rgba(255, 255, 255, .05)
}

.flb .boost__item:nth-child(2) {
    border-right: 1px solid rgba(255, 255, 255, .05);
    border-left: 1px solid rgba(255, 255, 255, .05)
}

.flb .boost__button {
    grid-column-start: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 45px;
    border-right: 1px solid rgba(255, 255, 255, .05);
    border-left: 1px solid rgba(255, 255, 255, .05)
}

.flb .boost__top {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 0 35px;
    border-bottom: 1px solid rgba(255, 255, 255, .05)
}

.flb .boost__icon {
    width: 52px;
    height: 52px;
    border-radius: 6px;
    background: #ffffff0d;
    display: flex;
    align-items: center;
    justify-content: center
}

.flb .boost__icon img {
    width: 24px;
    height: 24px
}

.flb .boost__bottom {
    padding: 35px 50px 45px
}

.flb .boost__title {
    color: #fff;
    text-align: center;
    font-family: Gotham Pro;
    font-size: 21px;
    font-weight: 700;
    line-height: 140%;
    text-transform: uppercase
}

.flb .boost__description {
    color: #ffffff7d;
    text-align: center;
    font-size: 16px;
    line-height: 140%;
    padding-top: 12px
}

.fs {
    max-width: 1352px;
    padding: 200px 20px 0;
    margin: 0 auto
}

.fs .items {
    padding-top: 70px
}

.fs .items__row {
    display: flex;
    gap: 16px
}

.fs .items__row:last-child {
    padding-top: 16px
}

.fs .items .item {
    padding: 10px;
    flex: 0 0 calc(50% - 8px);
    border-radius: 8px;
    background: #08080c
}

.fs .items .item__image {
    width: 100%;
    border-radius: 6px 6px 0 0;
    background: #d9d9d903;
    box-shadow: 0 4px 33.7px 20px #0e0e12 inset
}

.fs .items .item__body {
    padding: 30px 22px 28px
}

.fs .items .item__label {
    border-radius: 30px;
    background: #1977fd;
    height: 36px;
    padding: 0 18px;
    display: flex;
    align-items: center;
    width: -moz-max-content;
    width: max-content;
    color: #fff;
    font-size: 16px;
    font-weight: 400
}

.fs .items .item__title {
    padding-top: 24px;
    color: #fff;
    font-size: 28px;
    font-weight: 700;
    line-height: 140%
}

.fs .items .item__desctiption {
    padding-top: 12px;
    color: #fff6;
    font-size: 16px;
    line-height: 140%
}

.fs .items .item.full {
    flex: 1 0 100%;
    display: flex;
    gap: 90px
}

.fs .items .item__left {
    flex: 1 1 calc(53% - 45px)
}

.fs .items .item__right {
    flex: 0 0 calc(47% - 45px);
    width: calc(47% - 45px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative
}

.fg {
    padding-top: 120px;
    padding-bottom: 50px
}

.fg__gallery {
    padding-top: 30px;
    overflow: hidden;
    max-width: 3000px;
    margin: 0 auto
}

.fg__row {
    display: flex;
    height: 228px;
    margin-top: 16px;
    position: relative
}

.fg__item {
    width: 424px;
    overflow: hidden;
    padding: 0 9px;
    position: absolute;
    top: 0;
    transform: translate(0)
}

.fg__item img {
    height: 100%;
    border-radius: 7px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.btn {
    border-radius: 54px;
    height: 62px;
    padding: 0 62px;
    display: flex;
    align-items: center;
    font-size: 16px;
    font-weight: 400;
    white-space: nowrap
}

.btn.blue-btn {
    color: #fff;
    background-image: linear-gradient(to right, #1977fd, #034fb6 33%, #00439e);
    background-size: 300% auto;
    transition: all .3s, color .4s, transform 0s
}

@media (any-hover: hover) {
    .btn.blue-btn:hover {
        background-position: 76%;
        color: #fffbefc9;
        box-shadow: 0 0 20px #1a2fa5
    }
}

.btn.blue-btn:active {
    background-position: 76%;
    color: #fffbefc9;
    box-shadow: 0 0 20px #1a2fa5
}

.btn.gray-btn {
    background: #ffffff0a;
    color: #fffc;
    transition: all .3s
}

@media (any-hover: hover) {
    .btn.gray-btn:hover {
        background: #ffffff1a
    }
}

.section-title__icon {
    margin: 0 auto;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center
}

.section-title__icon img {
    width: 20px;
    height: 20px
}

.section-title__title {
    padding-top: 18px;
    font-family: Unbounded;
    font-weight: 700;
    text-align: center
}

.section-title__title .blue {
    font-size: 36px;
    line-height: 120%;
    color: #fff
}

.section-title__title .white {
    color: #1977fd;
    font-size: 46px;
    font-style: normal;
    line-height: 120%
}

.section-title__sub-title {
    margin: 0 auto;
    padding-top: 32px;
    color: #fff3;
    text-align: center;
    font-size: 14px;
    font-weight: 300;
    line-height: 140%;
    max-width: 620px
}

@media (max-width: 1065px) {
    .flb__places {
        gap: 9px
    }

    .flb .place.gold {
        height: 436px
    }
}

@media (max-width: 900px) {
    .fms {
        max-height: 870px
    }

    .fms__center {
        width: 100%;
        top: 43%
    }

    .fms__title {
        font-size: 21px;
        line-height: 140%
    }

    .fms__title .white {
        gap: 8px
    }

    .fms__title .white div {
        width: 24px;
        height: 24px;
        border-radius: 6px
    }

    .fms__title .white div img {
        width: 13px;
        height: 13px
    }

    .fms__sub-title {
        font-size: 12px;
        margin: 0 auto
    }

    .fms__buttons {
        padding-top: 28px;
        flex-direction: column;
        gap: 10px
    }

    .fms__reg {
        font-size: 12px
    }

    .fms__stats {
        flex-wrap: wrap;
        max-width: 280px;
        margin: 0 auto
    }

    .fms__metric {
        flex: 0 0 50%
    }

    .fms__metric div:first-child img {
        width: 16px;
        height: 16px
    }

    .fms__metric div:first-child span {
        font-size: 28px
    }

    .fms__metric div:last-child {
        font-size: 10px
    }

    .fms__metric:nth-child(1) div:last-child,
    .fms__metric:nth-child(3) div:last-child {
        text-align: start
    }

    .fms__metric:nth-child(2) div:first-child,
    .fms__metric:nth-child(4) div:first-child {
        justify-content: end
    }

    .fms__metric:nth-child(2) div:last-child,
    .fms__metric:nth-child(4) div:last-child {
        text-align: end
    }

    .fms__metric:nth-child(3),
    .fms__metric:nth-child(4) {
        padding-top: 56px
    }

    .flb {
        padding-top: 34px
    }

    .flb__places {
        padding-top: 28px;
        flex-direction: column;
        gap: 12px
    }

    .flb .place__top {
        padding: 24px 24px 0
    }

    .flb .place__logo {
        width: 48px;
        height: 48px
    }

    .flb .place__icon {
        width: 32px;
        height: 32px
    }

    .flb .place__icon img {
        width: 16px;
        height: 16px
    }

    .flb .place__body {
        padding: 40px 24px 0
    }

    .flb .place__name {
        font-size: 16px
    }

    .flb .place__stats {
        padding-top: 36px;
        gap: 55px
    }

    .flb .place__stat:first-child div:first-child {
        font-size: 12px
    }

    .flb .place__stat:first-child div:last-child img {
        width: 14px;
        height: 14px
    }

    .flb .place__stat:first-child div:last-child span {
        font-size: 14px
    }

    .flb .place__stat:last-child div:first-child {
        font-size: 12px
    }

    .flb .place__stat:last-child div:last-child {
        font-size: 14px
    }

    .flb .place__leader {
        padding-top: 16px
    }

    .flb .place__leader div:first-child {
        font-size: 12px
    }

    .flb .place__leader div:last-child {
        font-size: 14px
    }

    .flb .place__bottom {
        padding: 35px 12px 15px
    }

    .flb .board__row {
        grid-template-columns: 1fr 3fr
    }

    .flb .board__row.b-header .board__column {
        height: 38px;
        font-size: 12px
    }

    .flb .board__row.b-header .board__column:nth-child(5),
    .flb .board__row.b-header .board__column:nth-child(4),
    .flb .board__row.b-header .board__column:nth-child(3) {
        display: none
    }

    .flb .board__row.b-body .board__column {
        font-size: 14px;
        height: 53px
    }

    .flb .board__row.b-body .board__column:nth-child(1) {
        padding-left: 32%
    }

    .flb .board__row.b-body .board__column:nth-child(2) {
        padding-left: 32%;
        gap: 8px
    }

    .flb .board__row.b-body .board__column:nth-child(2) img {
        width: 32px;
        height: 32px;
        flex: 0 0 32px
    }

    .flb .board__row.b-body .board__column:nth-child(5),
    .flb .board__row.b-body .board__column:nth-child(4),
    .flb .board__row.b-body .board__column:nth-child(3) {
        display: none
    }

    .flb__boost {
        padding-top: 111px
    }

    .flb .boost {
        grid-template-columns: 1fr;
        grid-template-rows: auto
    }

    .flb .boost__item:nth-child(2) {
        border-left: none;
        border-right: none
    }

    .flb .boost__item:nth-child(3) {
        border-bottom: none
    }

    .flb .boost__button {
        grid-column-start: auto;
        border: none
    }

    .flb .boost__top {
        border-bottom: none;
        padding-bottom: 0;
        border-right: 1px solid rgba(255, 255, 255, .05);
        border-left: 1px solid rgba(255, 255, 255, .05);
        margin: 0 30px
    }

    .flb .boost__icon {
        width: 42px;
        height: 42px
    }

    .flb .boost__icon img {
        width: 16px;
        height: 16px
    }

    .flb .boost__bottom {
        margin: 0 30px;
        padding: 28px 35px 42px;
        border-right: 1px solid rgba(255, 255, 255, .05);
        border-left: 1px solid rgba(255, 255, 255, .05)
    }

    .flb .boost__title {
        font-size: 18px
    }

    .flb .boost__description {
        font-size: 12px
    }

    .fs {
        padding-top: 86px
    }

    .fs .items {
        padding-top: 50px
    }

    .fs .items__row {
        flex-direction: column;
        gap: 20px
    }

    .fs .items .item {
        padding: 8px
    }

    .fs .items .item__body {
        padding: 25px 18px
    }

    .fs .items .item__label {
        height: 27px;
        font-size: 12px;
        padding: 0 13px
    }

    .fs .items .item__title {
        padding-top: 18px;
        font-size: 16px
    }

    .fs .items .item__desctiption {
        padding-top: 8px;
        font-size: 12px
    }

    .fs .items .item.full {
        flex-direction: column-reverse;
        gap: 20px
    }

    .fs .items .item.full .item__body {
        padding-top: 0
    }

    .fs .items .item__right {
        width: 100%
    }

    .fs .items .item__image-dev {
        width: 100px
    }

    .fs .items .item__title-dev {
        font-size: 16px
    }

    .fs .items .item__description-dev {
        font-size: 12px
    }

    .fs .items .item__label-dev {
        font-size: 12px;
        height: 35px;
        padding: 0 20px
    }

    .fg {
        padding-top: 105px
    }

    .fg__row {
        height: 125px;
        padding: 0
    }

    .fg__row:last-child {
        margin-top: 12px
    }

    .fg__item {
        width: 234px;
        padding: 0 6px
    }

    .fg__item img {
        border-radius: 7px
    }

    .section-title__icon {
        width: 32px;
        height: 32px;
        border-radius: 8px
    }

    .section-title__icon img {
        width: 16px;
        height: 16px
    }

    .section-title__title .blue {
        font-size: 18px
    }

    .section-title__title .white {
        font-size: 28px
    }

    .section-title__sub-title {
        padding-top: 16px;
        font-size: 12px
    }

    .btn {
        width: 100%;
        justify-content: center;
        height: 46px;
        border-radius: 34px;
        font-size: 12px;
        max-width: 280px
    }
}

.register {
    transition: opacity .3s;
    opacity: 0;
    animation: show-custom-popup .3s ease 0s 1 forwards;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    z-index: 101
}

.reg {
    background: #020811f5;
    height: 100%;
    display: flex
}

.reg-form {
    transform: translate(-100%);
    flex: 0 0 618px;
    background: radial-gradient(89.65% 84.64% at 0% 0%, #1977fd17, #1977fd00), #030b17;
    padding: 41px 76px 35px 78px;
    display: flex;
    flex-direction: column;
    overflow: auto;
    animation: show-reg-form .3s ease .3s 1 forwards
}

.reg-form__caption {
    flex: 0 1 max-content;
    padding-bottom: 9px
}

.reg-form__fields-wrapper {
    flex: 0 1 auto;
    overflow: hidden;
    position: relative
}

.reg-form__fields-wrapper:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 20px;
    background: linear-gradient(180deg, #14142000, #030b17 85.71%)
}

.reg-form__fields {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: auto;
    padding-bottom: 20px;
    padding-right: 20px
}

.reg-form__btn-exit {
    border-radius: 4px;
    background: #ffffff08;
    height: 42px;
    padding: 0 20px 0 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: .3s;
    margin: 0 0 24px
}

.reg-form__btn-exit span {
    color: #fff9;
    font-size: 14px;
    font-weight: 400;
    transition: .3s
}

.reg-form__btn-exit img {
    opacity: .4;
    transition: .3s
}

@media (any-hover: hover) {
    .reg-form__btn-exit:hover {
        background: #ffffff1a
    }

    .reg-form__btn-exit:hover span {
        color: #fff
    }

    .reg-form__btn-exit:hover img {
        opacity: 1
    }
}

.reg-form__title {
    color: #fff;
    font-size: 28px;
    font-weight: 700;
    line-height: 140%
}

.reg-form__sub-title {
    color: #fff6;
    font-family: Gotham Pro;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    padding-top: 4px
}

.reg-form__buttons {
    display: flex;
    align-items: center;
    padding-top: 33px;
    gap: 8px
}

.reg-form__buttons button {
    height: 65px;
    display: flex;
    align-items: center;
    justify-content: center
}

.reg-form__buttons button.create {
    flex: 1 1 100%;
    font-size: 18px;
    font-weight: 500;
    border-radius: 4px;
    background-image: linear-gradient(to right, #1977fd, #034fb6 33%, #00439e);
    background-size: 300% auto;
    background-position: 0%;
    transition: all .3s, color .4s
}

@media (any-hover: hover) {
    .reg-form__buttons button.create:hover {
        background-position: 76%;
        color: #fffbefc9;
        box-shadow: 0 0 20px #1a2fa5
    }
}

.reg-form__buttons button.disabled {
    background: #ffffff0d;
    color: #fff9;
    pointer-events: none
}

.reg-form__buttons button.exit {
    flex: 1 1 40%
}

.reg-input {
    position: relative;
    padding-top: 22px;
    transition: .3s
}

.reg-input.first {
    padding-top: 13px
}

.reg-input.last {
    margin-bottom: 14px
}

.reg-input.password-power {
    margin-bottom: 24px
}

.reg-input label {
    color: #fff6;
    font-size: 14px;
    font-weight: 400
}

.reg-input__field {
    margin-top: 10px;
    height: 62px;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, .05);
    background: #ffffff05;
    transition: .3s;
    display: flex;
    align-items: center;
    position: relative
}

.reg-input__field svg,
.reg-input__field img {
    position: absolute;
    top: 50%;
    left: 26px;
    transform: translate(-50%, -50%);
    width: 20px;
    height: 20px;
    opacity: .4;
    transition: .3s
}

.reg-input__field input {
    padding: 0 24px 0 48px;
    color: #fff;
    font-size: 16px;
    background: transparent;
    outline: none;
    border: none;
    flex: 1 1 100%;
    text-overflow: ellipsis;
    height: 100%
}

.reg-input__field input::-moz-placeholder {
    color: #fff6
}

.reg-input__field input::placeholder {
    color: #fff6
}

.reg-input.focus .reg-input__field {
    border: 1px solid rgba(255, 255, 255, .15);
    background: #ffffff0a
}

.reg-input.focus svg,
.reg-input.focus img {
    opacity: 1
}

.reg-input.focus input {
    color: #fff
}

.reg-input .reg-input__error {
    position: absolute;
    bottom: -6px;
    transform: translateY(100%);
    left: 0;
    color: #c71d1d;
    font-size: 14px;
    opacity: 0;
    pointer-events: none;
    transition: .1s;
    transition-delay: .1s
}

.reg-input.error {
    margin-bottom: 27px !important
}

.reg-input.error .reg-input__field {
    border: 1px solid rgba(199, 29, 29, .25) !important;
    background: #c71d1d0d
}

.reg-input.error .reg-input__field input {
    color: #c71d1d
}

.reg-input.error .reg-input__field input::-moz-placeholder {
    color: #c71d1d99
}

.reg-input.error .reg-input__field input::placeholder {
    color: #c71d1d99
}

.reg-input.error .reg-input__field svg {
    opacity: 1
}

.reg-input.error .reg-input__field svg path {
    fill: #c71d1d
}

.reg-input.error .reg-input__error {
    opacity: 1;
    pointer-events: initial;
    transition-delay: 0s
}

@media (any-hover: hover) {
    .reg-input:hover .reg-input__field {
        border: 1px solid rgba(255, 255, 255, .15)
    }
}

.reg-input .reg-password-power {
    position: absolute;
    bottom: -6px;
    transform: translateY(100%);
    width: 100%;
    opacity: 0;
    pointer-events: none;
    transition: .1s;
    transition-delay: .1s
}

.reg-input .reg-password-power__lines {
    display: flex;
    align-items: center;
    gap: 4px;
    height: 2px
}

.reg-input .reg-password-power__lines div {
    flex: 1 1 100%;
    height: 100%;
    border-radius: 3px;
    background: #ffffff0d;
    transition: .1s
}

.reg-input .reg-password-power__label {
    padding-top: 8px;
    color: #c71d1d;
    font-size: 14px
}

.reg-input.password-power .reg-password-power {
    opacity: 1;
    pointer-events: initial;
    transition-delay: 0s
}

.reg-checkbox {
    display: flex;
    gap: 8px;
    padding-left: 1px;
    padding-top: 14px
}

.reg-checkbox input {
    background: unset;
    border-radius: 2px;
    position: relative;
    width: 18px;
    height: 18px;
    flex: 0 0 18px
}

.reg-checkbox input:before,
.reg-checkbox input:after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #0e192a;
    border-radius: 3px;
    border: 1px solid #26303f;
    cursor: pointer
}

.reg-checkbox input:after {
    background-color: #fff;
    background-image: url(../img/shop/done.svg);
    background-repeat: no-repeat;
    background-position: center center;
    opacity: 0;
    transition: opacity .25s
}

.reg-checkbox input:checked:after {
    opacity: 1
}

.reg-checkbox span {
    color: #fff6;
    font-size: 14px;
    line-height: 140%
}

.reg-checkbox span a {
    color: #fffc
}

.reg-checkbox span a:hover {
    text-decoration: underline
}

.reg-news {
    transform: translateY(100%);
    overflow: hidden;
    flex: 1 1 100%;
    padding: 35px 0 35px 50px;
    display: flex;
    flex-direction: column;
    animation: show-reg-news .3s ease .3s 1 forwards
}

.reg-news__header {
    display: flex;
    justify-content: space-between;
    flex: 0 1 auto;
    gap: 15px;
    padding-right: 50px;
    padding-bottom: 20px
}

.reg-news__header .left {
    display: flex;
    align-items: center
}

.reg-news__header .right {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    flex: 0 1 max-content
}

.reg-news__header .right a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 6px;
    background: #ffffff0d;
    transition: .3s
}

.reg-news__header .right a img {
    width: 24px;
    height: 24px;
    opacity: .6;
    transition: .3s
}

@media (any-hover: hover) {
    .reg-news__header .right a:hover {
        background: #ffffff14
    }

    .reg-news__header .right a:hover img {
        opacity: 1
    }
}

.reg-news__body-wrapper {
    flex: 0 1 auto;
    overflow: hidden;
    width: 100%;
    position: relative;
    padding-bottom: 20px
}

.reg-news__body-wrapper:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 20px;
    background: linear-gradient(180deg, #02081100, #020811f5 85.71%)
}

.reg-news__body {
    overflow-y: auto;
    overflow-x: hidden;
    height: 100%;
    width: 100%
}

.reg-online {
    display: flex;
    flex-direction: column;
    align-items: start;
    width: 156px;
    white-space: nowrap;
    border-right: 1px solid rgba(255, 255, 255, .05)
}

.reg-online__top {
    display: flex;
    align-items: center;
    gap: 8px
}

.reg-online__icon {
    position: relative;
    width: 22px;
    height: 22px
}

.reg-online__icon:before,
.reg-online__icon:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: #61ff00;
    border-radius: 60%
}

.reg-online__icon:after {
    width: 42.85%;
    height: 42.85%
}

.reg-online__icon:before {
    width: 100%;
    height: 100%;
    opacity: .4;
    animation: online-icon-animation ease 2s infinite
}

.reg-online__value {
    color: #fff;
    font-size: 36px;
    font-weight: 700;
    line-height: 140%
}

.reg-online__bottom {
    color: #fff6;
    font-size: 14px;
    line-height: 140%;
    text-align: center
}

.reg-active {
    padding-left: 42px;
    white-space: nowrap
}

.reg-active__top {
    color: #fff;
    font-size: 36px;
    font-weight: 700;
    line-height: 140%
}

.reg-active__bottom {
    color: #fff6;
    font-size: 14px;
    line-height: 140%;
    text-align: center
}

.reg-why__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 22px;
    padding-right: 50px;
    gap: 15px
}

.reg-why__header .content {
    max-width: 470px
}

.reg-why__header .content h4 {
    color: #fff;
    font-size: 24px;
    font-weight: 700;
    line-height: 140%
}

.reg-why__header .content.questions h4 {
    font-size: 18px
}

.reg-why__header .content p {
    padding-top: 10px;
    color: #fff6;
    font-size: 14px;
    line-height: 140%
}

.reg-why__header .buttons {
    display: flex;
    align-items: center;
    gap: 12px
}

.reg-why__header .buttons button {
    width: 42px;
    height: 42px;
    border-radius: 100px;
    background: #ffffff08;
    justify-content: center;
    align-items: center;
    transition: .3s
}

.reg-why__header .buttons button:first-child {
    transform: rotate(180deg)
}

.reg-why__header .buttons button img {
    width: 24px;
    height: 24px;
    opacity: .25;
    transition: .3s
}

@media (any-hover: hover) {
    .reg-why__header .buttons button:hover {
        background: #ffffff1a
    }

    .reg-why__header .buttons button:hover img {
        opacity: 1
    }
}

.reg-why__list {
    padding-top: 28px;
    display: flex;
    max-width: 100%
}

.reg-why__list-wrapper {
    padding-right: 50px
}

.reg-why .why-item {
    width: 326px;
    flex: 0 0 326px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, .03);
    background: #030b17
}

.reg-why .why-item__image {
    position: relative;
    height: 181px;
    overflow: hidden;
    border-radius: 8px
}

.reg-why .why-item__image img {
    transition: .2s;
    width: 100%
}

.reg-why .why-item__image:after {
    content: "";
    position: absolute;
    bottom: -15px;
    left: 0;
    width: 100%;
    height: 130px;
    background: linear-gradient(180deg, #04070b00, #04070b 85.71%)
}

.reg-why .why-item__content {
    padding: 33px 28px 27px;
    position: relative
}

.reg-why .why-item__content h5 {
    color: #fff;
    font-size: 18px;
    font-weight: 400;
    line-height: 140%;
    text-transform: uppercase
}

.reg-why .why-item__content p {
    padding-top: 12px;
    color: #fff6;
    font-size: 14px;
    line-height: 140%
}

.reg-why .why-item__label {
    position: absolute;
    top: -13px;
    left: 28px;
    color: #ffd542;
    font-size: 14px;
    font-weight: 400;
    border-radius: 4px;
    background: #ffd5420d;
    height: 36px;
    padding: 0 16px;
    display: flex;
    align-items: center
}

@media (any-hover: hover) {

    .reg-why .why-item:active .why-item__image img,
    .reg-why .why-item:hover .why-item__image img {
        transform: scale(1.04)
    }
}

.reg-faq__list {
    padding-top: 14px;
    display: flex
}

.reg-faq__list-wrapper {
    padding-right: 50px
}

.faq-item {
    width: 366px;
    flex: 0 0 366px;
    padding: 20px 24px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, .03);
    background: #030b17;
    transition: .3s
}

.faq-item__content h5 {
    color: #fff;
    font-size: 16px;
    font-weight: 400;
    line-height: 140%
}

.faq-item__content p {
    padding-top: 10px;
    color: #fff6;
    font-size: 14px;
    font-weight: 400;
    line-height: 140%
}

@media (any-hover: hover) {
    .faq-item:hover {
        border: 1px solid rgba(255, 255, 255, .1)
    }
}

@media (max-width: 1310px) {
    .reg-form {
        flex: 0 0 490px;
        padding: 35px 25px 35px 40px
    }

    .reg-news {
        padding: 35px 0 35px 40px
    }

    .reg-news__header {
        padding-right: 40px
    }

    .reg-news .reg-why__list-wrapper,
    .reg-news .reg-faq__list-wrapper {
        padding-right: 35px
    }

    .left .reg-online {
        width: 136px
    }

    .left .reg-active {
        padding-left: 35px
    }

    .reg-why__header {
        padding-right: 35px
    }
}

@media (max-width: 1310px) {
    .reg-form {
        flex: 0 0 450px
    }
}

@media (max-width: 1080px) {
    .reg-form {
        flex: 0 0 380px;
        padding: 30px 20px 30px 40px
    }

    .reg-form__btn-exit {
        height: 42px;
        padding: 0 20px 0 16px
    }

    .reg-form__btn-exit img {
        width: 16px;
        height: 16px
    }

    .reg-form__btn-exit span {
        font-size: 12px
    }

    .reg-form__title {
        font-size: 22px
    }

    .reg-form__sub-title {
        padding-top: 2px;
        font-size: 12px
    }

    .reg-form__btn-exit {
        margin: 0 0 20px
    }

    .reg-form__caption {
        padding-bottom: 6px
    }

    .reg-form__fields {
        padding-right: 10px
    }

    .reg-form__buttons {
        padding-top: 32px
    }

    .reg-form__buttons button.create {
        height: 52px;
        font-size: 12px
    }

    .reg-news {
        padding: 35px 0 30px 40px
    }

    .reg-news .left .reg-online {
        width: 106px
    }

    .reg-news .left .reg-online__value {
        font-size: 28px
    }

    .reg-news .left .reg-online__icon {
        width: 18px;
        height: 18px
    }

    .reg-news .left .reg-online__bottom {
        font-size: 12px
    }

    .reg-news .left .reg-active {
        padding-left: 19px
    }

    .reg-news .left .reg-active__top {
        font-size: 28px
    }

    .reg-news .left .reg-active__bottom {
        font-size: 12px
    }

    .reg-news .right {
        gap: 6px
    }

    .reg-news .right a {
        border-radius: 4px;
        width: 42px;
        height: 42px
    }

    .reg-news .right a img {
        width: 20px;
        height: 20px
    }

    .reg-news__header {
        padding-bottom: 10px
    }

    .reg-input {
        padding-top: 20px
    }

    .reg-input.first {
        padding-top: 13px
    }

    .reg-input.last {
        margin-bottom: 14px
    }

    .reg-input label {
        font-size: 12px
    }

    .reg-input__field {
        margin-top: 8px;
        height: 52px
    }

    .reg-input__field img {
        width: 18px;
        height: 18px;
        left: 23px
    }

    .reg-input__field input {
        font-size: 14px;
        padding: 0 20px 0 44px
    }

    .reg-input .reg-password-power {
        padding-top: 4px
    }

    .reg-input .reg-password-power__label {
        font-size: 12px;
        padding-top: 6px
    }

    .reg-checkbox {
        padding-top: 14px
    }

    .reg-checkbox input {
        margin-top: -2px !important
    }

    .reg-checkbox span {
        font-size: 11px
    }

    .reg-why__header .content h4 {
        font-size: 18px
    }

    .reg-why__header .content p {
        font-size: 12px
    }

    .reg-why__header .content.questions h4 {
        font-size: 14px
    }

    .reg-why__header .buttons {
        gap: 10px
    }

    .reg-why .why-item {
        width: 300px;
        flex: 0 0 300px
    }

    .reg-why .why-item__label {
        height: 28px;
        padding: 0 12px;
        font-size: 12px
    }

    .reg-why .why-item__content {
        padding: 26px 18px 24px
    }

    .reg-why .why-item__content p {
        font-size: 12px
    }

    .faq-item {
        width: 300px;
        flex: 0 0 300px;
        padding: 18px 18px 16px
    }

    .faq-item__content h5 {
        font-size: 14px
    }

    .faq-item__content p {
        font-size: 11px
    }
}

@media (min-width: 900px) {
    .reg .reg-monitor {
        display: none
    }
}

@media (max-width: 900px) {
    .reg {
        overflow: auto;
        overflow-x: hidden;
        flex-direction: column
    }

    .reg .reg-news,
    .reg .reg-form {
        transform: translate(0);
        animation: none
    }

    .reg .reg-form {
        padding: 32px 8px 45px 24px;
        flex: 1 0 auto
    }

    .reg .reg-form__caption,
    .reg .reg-form__fields-wrapper {
        max-width: 400px;
        width: 100%;
        margin: 0 auto
    }

    .reg .reg-form__fields-wrapper {
        flex: 1 1 auto
    }

    .reg .reg-form__fields-wrapper:after {
        display: none
    }

    .reg .reg-form__fields-wrapper,
    .reg .reg-form__fields {
        overflow: initial
    }

    .reg .reg-form__fields {
        padding-bottom: 0
    }

    .reg .reg-news {
        flex: 1 1 100%;
        overflow: initial;
        padding: 38px 0 130px 24px
    }

    .reg .reg-news__header {
        display: none
    }

    .reg .reg-news__body {
        overflow: initial
    }

    .reg .reg-news__body-wrapper {
        overflow: initial;
        padding-bottom: 0
    }

    .reg .reg-news__body-wrapper:after {
        display: none
    }

    .reg .reg-news .reg-why__header {
        padding-right: 24px;
        padding-top: 0
    }

    .reg .reg-news .reg-why__header .buttons {
        display: none
    }

    .reg .reg-news .reg-why__list-wrapper,
    .reg .reg-news .reg-faq__list-wrapper {
        padding-right: 17px
    }

    .reg .reg-monitor {
        padding: 34px 40px
    }

    .reg .reg-monitor__data {
        max-width: 350px;
        margin: 0 auto;
        padding: 0;
        display: flex;
        align-items: center
    }

    .reg .reg-monitor__data .reg-online {
        width: 121px
    }

    .reg .reg-monitor__data .reg-online__icon {
        width: 18px;
        height: 18px
    }

    .reg .reg-monitor__data .reg-online__value {
        font-size: 28px
    }

    .reg .reg-monitor__data .reg-online__bottom {
        font-size: 12px
    }

    .reg .reg-monitor__data .reg-active {
        padding-left: 28px
    }

    .reg .reg-monitor__data .reg-active__top {
        font-size: 28px
    }

    .reg .reg-monitor__data .reg-active__bottom {
        font-size: 12px
    }

    .reg .reg-faq {
        padding-top: 42px
    }

    .reg .reg-input .reg-input__error {
        font-size: 12px;
        bottom: -4px
    }

    .reg .reg-input.error {
        margin-bottom: 24px !important
    }
}

@keyframes show-reg-form {
    0% {
        transform: translate(-100%)
    }

    to {
        transform: translate(0)
    }
}

@keyframes show-reg-news {
    0% {
        transform: translateY(100%)
    }

    to {
        transform: translate(0)
    }
}