/* Root */

:root {
    --accent: #80101B;

    --text: #111111;
    --text-2: #FFFFFF;

    --background: #FFFFFF;

    --width: 90%;
    --max-width: 1440px;

    --transition: 0.3s;

    --opacity: 0.8;
    --opacity-2: 0.5;

    --font-family: "Manrope", sans-serif;
    --font-family-2: "LT Remark", sans-serif;
    --font-family-3: "Santa Catarina", sans-serif;
}

::-moz-selection {
    background: var(--accent);
    color: #FFFFFF;
}

::selection {
    background: var(--accent);
    color: #FFFFFF;
}

html,
body {
    transition: var(--transition);
    color-scheme: light;
    scroll-behavior: smooth;
    text-rendering: optimizelegibility;
    -webkit-tap-highlight-color: transparent;
    -webkit-font-smoothing: antialiased;
    background-color: var(--background);
    font-family: var(--font-family);
    color: var(--text);
    padding: 0;
    margin: 0;
    overflow-x: hidden;
}

body {
    opacity: 0;
    -webkit-animation: load 1s 0.5s forwards ease-in-out;
    animation: load 1s 0.5s forwards ease-in-out;
}

* {
    padding: 0;
    margin: 0;
    text-wrap: balance;
}

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

a {
    transition: var(--transition);
    cursor: pointer;
    text-decoration: none;
    color: var(--text);
}

a:hover,
button:hover {
    opacity: var(--opacity);
}

a:active,
button:active {
    opacity: var(--opacity-2);
}

button,
.button {
    transition: var(--transition);
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 16px;
    font-weight: 600;
    line-height: 1;
    padding: 20px 45px;
    color: #FFFFFF;
    background-color: var(--accent);
    border-radius: 4px;
    border: none;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    cursor: pointer;
    font-family: var(--font-family);
    text-align: center;
    justify-content: center;
}

.checkbox {
    background-color: var(--background);
    position: relative;
    width: 24px;
    height: 24px;
    transition: var(--transition);
    border: 0.75px solid var(--accent);
}

.checkbox:has(input:checked) {
    background-color: var(--accent);
}

.checkbox:hover {
    opacity: var(--opacity);
}

.checkbox:active {
    opacity: var(--opacity-2);
}

.checkbox svg {
    pointer-events: none;
    position: absolute;
    left: 0;
    right: 0;
    top: -2px;
    bottom: 0;
    margin: auto;
}

.checkbox input {
    position: relative;
    width: 24px;
    height: 24px;
    opacity: 0;
    cursor: pointer;
}

/* Effects */

.opacity-true {
    transition: var(--transition);
    opacity: 1 !important;
    pointer-events: all !important;
}

.opacity-false {
    transition: var(--transition);
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Header */

header {
    position: relative;
    transition: var(--transition), -webkit-backdrop-filter 0s;
    transition: var(--transition), backdrop-filter 0s;
    transition: var(--transition), backdrop-filter 0s, -webkit-backdrop-filter 0s;
    width: 100vw;
    z-index: 123456;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-color: var(--background);
}

header .content {
    position: relative;
    width: var(--width);
    max-width: var(--max-width);
    display: grid;
}

header .content .up {
    padding-top: 20px;
    padding-bottom: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 0.75px solid #D7D7D7;
}

header .content .up a {
    padding: 20px 12.5px;
    font-size: 14px;
    font-weight: 500;
    color: #11111199;
}

header .content .up .links a:first-child {
    padding-left: 0;
}

header .content .up .contacts a:last-child {
    padding-right: 0;
}

header .content nav {
    margin-top: 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 122px;
}

header .content nav .navigation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

header .content nav .navigation .media-container {
    display: flex;
    gap: 15px;
    align-items: center;
}

header .content nav .navigation .media-container .media-trigger {
    display: none;
    cursor: pointer;
    transition: var(--transition);
}

header .content nav .navigation .media-container .media-trigger:hover {
    opacity: var(--opacity);
}

header .content nav .navigation .media-container .media-trigger:active {
    opacity: var(--opacity-2);
}

header .content nav .navigation .button {
    padding: 12px;
}

header .content nav .navigation .button:hover {
    opacity: 1;
    background-color: var(--text);
    color: var(--text-2);
}

header .content nav .navigation .button:active {
    opacity: var(--opacity);
}

header .content nav .navigation a:not(.button) {
    font-size: 16px;
    font-weight: 600;
}

header .content nav .navigation a:not(.button):hover {
    color: var(--accent);
}

header .content nav .manage {
    display: flex;
    gap: 36px;
}

header .content nav .manage a {
    position: relative;
}

header .content nav .manage a span {
    position: absolute;
    display: block;
    background-color: var(--accent);
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
    color: var(--text-2);
    border-radius: 32px;
    width: 16px;
    height: 16px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    bottom: 4px;
    right: 0;
}

/* Media Menu */

.media-menu {
    background-color: var(--text);
    transition: var(--transition);
    position: fixed;
    left: 0;
    z-index: 2;
    bottom: 0;
    width: 100vw;
    height: calc(100dvh - 55px - 15px - 35px * 2);
    overflow-y: scroll;
    color: var(--text-2);
    padding: 35px 20px;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.media-menu::-webkit-scrollbar {
    display: none;
}

.media-menu {
    display: grid;
}

.media-menu h3 {
    font-size: 12px;
    font-weight: 500;
    color: #FFFFFF99;
}

.media-menu h3:last-of-type {
    margin-top: 30px;
}

.media-menu .links {
    margin-top: 25px;
    display: grid;
    gap: 20px;
}

.media-menu .links a {
    display: flex;
    color: var(--text-2);
    gap: 10px;
    align-items: center;
    font-size: 16px;
    font-weight: 600;
}

.media-menu .info {
    margin-top: 35px;
    display: grid;
    align-content: end;
    gap: 20px;
}

.media-menu .info a {
    color: var(--text-2);
    font-size: 16px;
    line-height: 1;
    font-weight: 400;
}

.media-menu .info h4 {
    font-size: 12px;
    color: #FFFFFF99;
    font-weight: 400;
}

/* App */

.app {
    margin-top: 25px;
    min-height: 70dvh;
}

.app .big-title {
    font-size: 64px;
    text-align: center;
    font-weight: 400;
    font-family: var(--font-family-2);
    color: var(--accent);
    margin-top: 10px;
}

.app .item .up .wish {
    color: var(--text) !important;
}

.app .item .up .wish.activated {
    color: var(--accent) !important;
}

/* Footer */

.pre-footer {
    margin-top: 218px;
    background-image: url(/components/images/footer.png);
    background-size: cover;
    text-align: center;
    padding: 40px 0 82px 0;
}

.pre-footer h1 {
    font-size: 42px;
    font-weight: 400;
    font-family: var(--font-family-2);
    color: var(--text-2);
    width: var(--width);
    max-width: var(--max-width);
    margin: auto;
    margin-top: 90px;
}

.pre-footer .button {
    margin: auto;
    margin-top: 60px;
}

.pre-footer .button:hover {
    opacity: 1;
    background-color: #BA2A38;
}

.pre-footer .button:active {
    opacity: var(--opacity);
}

footer {
    background-color: var(--text);
    padding: 40px 0 25px 0;
}

footer .content {
    width: var(--width);
    max-width: var(--max-width);
    margin: auto;
    display: flex;
    justify-content: space-between;
    color: var(--text-2);
}

footer .content .company {
    max-width: 218px;
}

footer .content .company img {
    width: 60px;
    height: 60px;
    -o-object-fit: contain;
    object-fit: contain;
}

footer .content .company h3 {
    font-size: 10px;
    font-weight: 400;
    color: #FFFFFF99;
    margin-top: 25px;
}

footer .content .company .media-container div {
    display: none;
}

footer .content .company .media-container div a {
    color: var(--text-2);
    font-size: 12px;
    line-height: 1;
    font-weight: 400;
}

footer .content .company .media-container div h4 {
    font-size: 11px;
    color: #FFFFFF99;
    font-weight: 400;
}

footer .content .links {
    display: flex;
    gap: 65px;
}

footer .content .links .block {
    display: grid;
    align-content: baseline;
    gap: 12px;
}

footer .content .links .block h2 {
    margin-bottom: 10px;
    font-size: 12px;
    line-height: 1;
    font-weight: 600;
    color: #FFFFFF66;
}

footer .content .links .block a {
    color: var(--text-2);
    font-size: 12px;
    line-height: 1;
    font-weight: 400;
}

footer .content .links .block h4 {
    font-size: 11px;
    color: #FFFFFF99;
    font-weight: 400;
    margin-top: -4px;
}

footer .content .links .block h3 {
    font-size: 14px;
    font-weight: 400;
}

footer .content .links .block form {
    display: flex;
    gap: 5px;
}

footer .content .links .block form input {
    background-color: var(--text);
    width: calc(100% - 16px * 2 - 0.75px * 2);
    outline: none;
    padding: 12px 16px;
    font-family: var(--font-family);
    border-radius: 0;
    border: 0.75px solid #FFFFFF80;
    caret-color: var(--text-2);
    color: var(--text-2);
    font-weight: 400;
    font-size: 12px;
    resize: none;
}

footer .content .links .block form input::-webkit-input-placeholder {
    color: #FFFFFF80;
}

footer .content .links .block form input::-moz-placeholder {
    color: #FFFFFF80;
}

footer .content .links .block form input:-ms-input-placeholder {
    color: #FFFFFF80;
}

footer .content .links .block form input::-ms-input-placeholder {
    color: #FFFFFF80;
}

footer .content .links .block form input::placeholder {
    color: #FFFFFF80;
}

footer .content .links .block form button {
    border-radius: 0;
    padding: 14px 20px;
}

footer p {
    margin-top: 50px;
    text-align: center;
    color: #FFFFFF80;
    font-size: 12px;
    line-height: 1;
    font-weight: 400;
}

/* Animations */

@-webkit-keyframes load {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes load {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}