:root {
    --base-font:            'PT Sans Narrow', 'Trebuchet MS', Arial, Helvetica, sans-serif;
    --text-font:            Arial, Helvetica, sans-serif;
    --accent-color:         #B3FF00;
    --accent-hover-color:   #D83131;
    --grey-color:           #2A3137;
    --main-color:           #000000;
    --secondary-color:      #717171;
    --border-color:         #aaaaaa;
    --error-color:          #ff0000;
}

@font-face {
    font-family: 'PT Sans Narrow';
    src: url('../fonts/PTSans-Narrow.woff2') format('woff2'),
    url('../fonts/PTSans-Narrow.woff') format('woff');
    font-display: swap;
    font-weight: normal;
}

@font-face {
    font-family: 'PT Sans Narrow';
    src: url('../fonts/PTSans-NarrowBold.woff2') format('woff2'),
    url('../fonts/PTSans-NarrowBold.woff') format('woff');
    font-display: swap;
    font-weight: bold;
}

*,
*:before,
*:after {
    box-sizing: border-box;
}

.svg-sprite {
    position: absolute;
    left: -9999px;
    top: -9999px;
    height: 0;
    width: 0;
    visibility: hidden;
    opacity: 0;
}

.icon {
    display: inline-block;
    vertical-align: middle;
    position: relative;
    flex-shrink: 0;
}

html {
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

html:not(.behavior-auto) {
    scroll-behavior: smooth;
}

/*html,
body {
    display: flex;
    flex-direction: column;
}*/

body {
    font-family: var(--base-font);
    font-size: 17px;
    line-height: 22px;
    background: #fff;
    color: var(--main-color);
    min-width: 320px;
    /*min-height: 100vh;*/
    margin: 0;
}

.theme-dark body {
    background: #000 url('../images/bg.jpg') center top repeat;
    color: #fff;
}

button,
input,
optgroup,
select,
textarea {
    font: inherit;
    color: inherit;
    margin: 0;
}

button,
input {
    overflow: visible;
}

button,
select {
    text-transform: none;
}

button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
}

button::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

:hover,
:active,
:focus {
    outline: none;
}

img {
    vertical-align: middle;
    border: none;
    max-width: 100%;
    height: auto;
}

b,
strong {
    font-weight: bold;
}

hr {
    height: auto;
    border: 1px solid var(--border-color);
    border-width: 1px 0 0;
    margin: 27px 0;
    clear: both;
}

table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}

th {
    text-align: inherit;
    font-weight: bold;
}

textarea {
    max-width: 100%;
    min-width: 100%;
    overflow: auto;
    resize: vertical;
}

a,
button {
    transition: 0.15s ease-in-out;
    transition-property: color, border-color, background-color, opacity, box-shadow;
}

a {
    color: inherit;
    text-decoration: underline;
    text-decoration-thickness: 1px;
}

a:hover,
a:focus {
    text-decoration: none;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
.h1 a,
.h2 a,
.h3 a,
.h4 a,
.h5 a,
.h6 a {
    color: inherit;
    text-decoration: none;
}

h1 a:hover,
.h1 a:hover,
h1 a:focus,
.h1 a:focus,
h2 a:hover,
.h2 a:hover,
h2 a:focus,
.h2 a:focus,
h3 a:hover,
.h3 a:hover,
h3 a:focus,
.h3 a:focus,
h4 a:hover,
.h4 a:hover,
h4 a:focus,
.h4 a:focus,
h5 a:hover,
.h5 a:hover,
h5 a:focus,
.h5 a:focus,
h6 a:hover,
.h6 a:hover,
h6 a:focus,
.h6 a:focus {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-position: under;
}

p {
    margin: 0 0 5px 0;
}

ul,
ol,
dl,
pre,
table,
figure,
address,
fieldset,
blockquote {
    margin: 0 0 22px 0;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
    font-family: var(--base-font);
    font-weight: 700;
    line-height: 1.2;
    color: inherit;
    margin: 0 0 16px 0;
}

h1,
.h1 {
    font-size: 45px;
    line-height: 51px;
    margin-bottom: 28px;
}

h2,
.h2 {
    font-size: 22px;
    line-height: 28px;
}

h3,
.h3 {
    font-size: inherit;
    line-height: inherit;
}

.text {
    font-family: var(--text-font);
    font-size: 17px;
    line-height: 22px;
}

.text h3,
.text .h3 {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    font-weight: bold;
    margin: 0;
}

.text * + h1,
.text * + h2 {
    margin-top: 28px;
}

.text * + h3 {
    margin-top: 22px;
}

.text ul,
.text ol {
    list-style: none;
    padding: 0;
    margin-left: 30px;
}

.text li > ul,
.text li > ol {
    margin-bottom: 0;
}

.text li {
    position: relative;
    padding-left: 30px;
}

.text ul > li:before {
    content: '';
    width: 10px;
    height: 10px;
    background: var(--accent-color);
    position: absolute;
    left: 0;
    top: 6px;
}

.text ol {
    counter-reset: li;
}

.text ol > li {
    counter-increment: li;
}

.text ol > li:before {
    content: counter(li)'.';
    color: var(--accent-color);
    position: absolute;
    font-weight: bold;
    left: 0;
}

.text figure {
    margin: 0 0 34px;
}

.text * + figure {
    margin-top: 34px;
}

.text figure:last-child {
    margin-bottom: 0;
}

.text img {
    width: auto;
    height: auto;
    max-width: 100%;
}

.text iframe {
    max-width: 100%;
}

.text-btn-row {
    margin-bottom: 40px;
}

* + .text-btn-row {
    margin-top: 40px;
}

.text-btn-row:last-child {
    margin-bottom: 0;
}

.text-btn-row .btn {
    width: 100%;
    max-width: 280px;
}

.form-check {
    font-size: 18px;
    line-height: 20px;
    margin-bottom: 16px;
}

.form-check label {
    display: inline-block;
    position: relative;
    cursor: pointer;
}

.form-check input {
    opacity: 0;
}

.form-check input ~ span {
    display: block;
    position: relative;
    padding: 0 0 0 31px;
}

.form-check input,
.form-check input ~ span:before,
.form-check input ~ span:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    transition: 0.15s ease-in-out;
}

.form-check input,
.form-check input ~ span:before {
    width: 20px;
    height: 20px;
    border: 2px solid currentColor;
    background: none;
}

.form-check input[type=radio] ~ span:before {
    border-radius: 50%;
}

.form-check input[type=radio] ~ span:after {
    width: 10px;
    height: 10px;
    margin: 5px 0 0 5px;
    background: currentColor;
    border-radius: 50%;
    opacity: 0;
}

.form-check input[type=checkbox] ~ span:after {
    width: 10px;
    height: 6px;
    margin: 5px 0 0 5px;
    border-style: solid;
    border-color: currentColor;
    border-width: 0 0 2px 2px;
    opacity: 0;
    transform: rotate(-45deg);
}

.form-check input:checked ~ span:after {
    opacity: 1;
}

.form-check input.error ~ span:before {
    border-color: var(--error-color);
}

.form-check input:disabled ~ span {
    opacity: 0.5;
    cursor: default;
    cursor: not-allowed;
}

.form-check-list {
    margin-left: -12px;
    margin-right: -12px;
}

.form-check-list .form-check {
    display: inline-block;
    vertical-align: top;
    padding-left: 12px;
    padding-right: 12px;
}

.form-text-row {
    text-align: center;
    margin: 20px 0;
    font-size: 18px;
    line-height: 1.2;
}

.form-text-row:last-child {
    margin-bottom: 0;
}

.form-text-row button {
    padding: 0;
    background: none;
    border: none;
}

.form-text-row button:hover {
    color: var(--accent-color);
}

.form-group {
    margin-bottom: 19px;
}

.form-group._sm {
    margin-bottom: 12px;
}

.form-control,
.form-select {
    display: block;
    box-shadow: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    appearance: none;
    transition: 0.15s ease-in-out;
    width: 100%;
    height: 52px;
    color: #000;
    background: #DDDDDD;
    border-radius: 6px;
    font-family: var(--base-font);
    font-size: 17px;
    line-height: 22px;
    letter-spacing: 0.04em;
    border: 2px solid #DDDDDD;
    padding: 13px 16px;
}

.form-control._md,
.form-select._md {
    padding-top: 9px;
    padding-bottom: 9px;
    height: 44px;
}

.form-control._sm,
.form-select._sm {
    padding-top: 5px;
    padding-bottom: 5px;
    height: 36px; 
}

.form-control::placeholder {
    color: #000;
}

.form-control:not([readonly]):focus::placeholder {
    color: transparent;
}

.form-select {
    max-width: 100%; 
    margin: 0;
    padding-right: 25px;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%23383838' stroke-width='2'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 12px 8px;
}

.form-select::-ms-expand {
    display: none;
}

textarea.form-control {
    height: auto;
    resize: none;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--accent-color);
}

.form-control[disabled],
.form-select[disabled] {
    background-color: #f5f5f5;
    border-color: #ccc;
    color: #888;
    cursor: default;
    cursor: not-allowed;
}

.form-control.error,
.form-select.error,
.form-control.error:focus,
.form-select.error:focus {
    border-color: var(--error-color) !important;
}

label.error {
    display: block;
    color: var(--error-color);
    font-size: 12px;
    line-height: 12px;
    margin-bottom: -12px;
}

.btn {
    display: inline-block;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    text-decoration: none;
    cursor: pointer;
    border: none;
    color: #000;
    text-transform: uppercase;
    background: var(--accent-color);
    border-radius: 6px;
    font-family: var(--base-font);
    font-size: 17px;
    line-height: 22px;
    font-weight: bold;
    padding: 15px 16px;
    letter-spacing: 0.04em;
}

.btn._md {
    padding-top: 11px;
    padding-bottom: 11px;
}

.btn._sm {
    padding-top: 9px;
    padding-bottom: 9px;
}

.btn:hover,
.btn:focus {
    background-color: var(--accent-hover-color);
    color: #000;
}

.btn._secondary {
    background-color: var(--grey-color);
    color: #fff;
}

.btn._secondary:hover,
.btn._secondary:focus {
    background-color: var(--accent-color);
    color: #fff;
}

.btn._red {
    background-color: #E56A6A;
    color: #000;
}

.btn._red:hover,
.btn._red:focus {
    background-color: var(--accent-hover-color);
    color: #000;
}

.btn._full-width {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.btn[disabled],
.btn.is-disabled {
    opacity: .55;
    cursor: default;
    cursor: not-allowed;
}

.close-btn {
    vertical-align: middle;
    position: relative;
    border: none;
    background: none;
    padding: 0;
    width: 54px;
    height: 54px;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.close-btn .icon {
    width: 22px;
    height: 22px;
}

.fancybox-close-btn {
    position: absolute;
    right: 3px;
    top: 0;
}

.popup-window {
    padding: 44px 30px 30px;
    width: 422px;
    overflow: visible;
    background: #000 url('../images/bg.jpg') center top repeat;
    background-size: 450px;
    color: #fff;
    border: 10px solid #343434;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 12px;
    font-size: 19px;
    line-height: 1.2;
}

.popup-window:not(.fancybox-content) {
    display: none;
}

body:not(.compensate-for-scrollbar) .compensate-for-scrollbar {
    margin-right: 0 !important;
}

.popup-window__title {
    font-size: 38px;
    line-height: 108.9%;
    text-align: center;
    margin-top: 8px;
    margin-bottom: 17px;
    text-transform: uppercase;
}

.login-window .popup-window__title,
.pass-recovery-window .popup-window__title {
    margin-top: 31px;
}

.registration-window .popup-window__title {
    font-size: 42px;
}

.popup-window__title + form {
    margin-top: 35px;
}

.popup-window__lead {
    font-size: 18px;
    text-align: center;
    margin-bottom: 19px;
}

.popup-window .form-check-list {
    text-align: center;
    margin: 0 -20px 13px;
}

.slick-slider {
    display: block;
}

.slick-track {
    margin: 0;
}

.slick-slide > div > * {
    width: auto;
    vertical-align: top;
}

.slick-dots {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
}

.slick-dots li button {
    display: block;
    width: 20px;
    height: 30px;
    border: none;
    background: none;
    padding: 0;
    position: relative;
    cursor: pointer;
    text-indent: -9999px;
}

.slick-dots li button:before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    width: 10px;
    height: 10px;
    margin: -5px;
    border-radius: 50%;
    background: var(--secondary-color);
}

.slick-dots li.slick-active button:before {
    background: var(--accent-color);
}

.slick-arrow {
    border: none;
    padding: 0;
    background: none;
    position: absolute;
    text-indent: -9999px;
    z-index: 11;
    top: 50%;
    width: 30px;
    height: 40px;
    margin-top: -20px;
    opacity: .7;
}

.slick-arrow:hover {
    opacity: 1;
}

.slick-prev {
    left: 0;
}

.slick-next {
    right: 0;
}

.slick-arrow:before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -16px -11px;
    border-style: solid;
    border-width: 16px 22px 16px 0;
    border-color: transparent currentColor;
}

.slick-prev:before {
    transform: translateX(-4px);
}

.slick-next:before {
    border-width: 16px 0 16px 22px;
    transform: translateX(4px);
}

.slick-arrow.slick-disabled {
    opacity: 0.1;
    cursor: default;
    pointer-events: none;
}

.menu-popup__bg,
.menu-popup__close {
    display: none;
}

@media (min-width: 1210px) {
    .container {
        max-width: 1190px;
    }
}

.container {
    --bs-gutter-x: 10px;
}

.row {
    --bs-gutter-x: 20px;
}

.content {
    /*flex-grow: 1;
    min-height: 1px;*/
    padding: 24px 0;
}

.header__bg {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}

.header__bg-cell {
    position: relative;
}

.header__bg-image {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: #2C3339;
    background-size: cover;
    background-position: center center;
    background-blend-mode: luminosity;
}

.header__bg-image:after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: #252B30;
    opacity: .5;
}

.header__bg-cell._1 .header__bg-image {
    background-position: center right;
}

.header__bg-center {
    max-width: 1170px;
    margin: 0 auto;
    height: 100%;
}

.header__bg-content {
    width: 58.548%;
    margin-left: auto;
    height: 100%;
    display: grid;
    grid-template-rows: 1fr 1fr;
    grid-template-columns: 17.81% 17.81% 22.92% 20% 21.46%;
}

.header__bg-cell._2:after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    width: 20px;
    background: linear-gradient(to right, #252B30, rgba(37, 43, 48, 0));
}

.header__bg-cell._1 {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 50%;
    margin-right: 622px;
}

.header__bg-cell._2 {
    grid-area: 1 / 1 / 3 / 2;
}

.header__bg-cell._3 {
    grid-area: 1 / 2 / 3 / 3;
}

.header__bg-cell._4 {
    grid-area: 1 / 3 / 2 / 4;
}

.header__bg-cell._5 {
    grid-area: 1 / 4 / 2 / 5;
}

.header__bg-cell._6 {
    grid-area: 2 / 3 / 3 / 5;
}

.header__bg-cell._7 {
    grid-area: 1 / 5 / 3 / 6;
}

.header {
    background: #000 url('../images/bg.jpg') center top repeat;
    color: #fff;
    position: relative;
    height: 240px;
    overflow: hidden;
}

.header .container {
    height: 100%;
}

.header__inner {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    height: 100%;
}

.header__menu-btn {
    display: none;
}

.menu-btn {
    display: block;
    position: relative;
    width: 36px;
    height: 35px;
    border: none;
    background: none;
    padding: 0;
    cursor: pointer;
    border-radius: 4px;
    background: #fff;
    color: #252B30;
}

.menu-btn:before,
.menu-btn:after {
    content: '';
}

.menu-btn:before,
.menu-btn:after,
.menu-btn > span {
    position: absolute;
    height: 5px;
    top: 15px;
    left: 7px;
    right: 7px;
    background: currentColor;
    transition: 0.25s ease-in-out;
}

.menu-btn:before {
    transform: translateY(-9px);
}

.menu-btn:after {
    transform: translateY(9px);
}

.header__logo {
    margin: 12px 0 22px;
}

.header__logo img {
    width: 152px;
    height: auto;
}

.header__title {
    font-weight: 700;
    font-size: 25px;
    line-height: 28px;
    text-shadow: 0 3px 3px rgba(0, 0, 0, 0.25);
    width: 11em;
}

.header__title br {
    display: none;
}

.header__subscribe {
    display: none;
    margin-top: 64px;
}

.header__subscribe-link {
    display: flex;
    align-items: center;
    text-decoration: none;
    font-size: 22px;
    line-height: 112.9%;
}

.header__subscribe-link:hover {
    color: var(--accent-color);
}

.header__subscribe-icon {
    flex-shrink: 0;
    margin-right: 19px;
}

.header__subscribe-text {
    max-width: 9em;
}

.header__arrow-wrapper {
    margin: 55px 0 0 100px;
    position: relative;
}

.header__arrow-wrapper:before {
    content: '';
    position: absolute;
    left: -59px;
    top: 131px;
    width: 75px;
    height: 54px;
    background: url('../images/header-arrow-s.svg') 0 0 no-repeat;
    background-size: 100% 100%;
    z-index: 1;
}

.header__arrow {
    width: 392px;
    position: relative;
    background: url('../images/header-arrow.png') 0 0 no-repeat;
    background-size: 100% 100%;
}

.header__arrow:before {
    content: '';
    display: block;
    padding-top: calc(263 * 100% / 392);
}

.header__quote-wrapper {
    display: none;
    margin-left: 29px;
}

.header__quote {
    font-size: 20px;
    line-height: 112.9%;
    text-shadow: 0 4px 4px rgb(0 0 0 / 25%);
    padding: 20px 22px 27px 18px;
    background: #2C3339;
    border: 3px solid #BCBCBC;
    box-shadow: 0 4px 4px rgb(0 0 0 / 25%);
    border-radius: 0 26px;
    width: 270px;
    margin-top: 111px;
    position: relative;
}

.header__quote:before {
    content: '';
    width: 120px;
    height: 100px;
    position: absolute;
    left: 0;
    bottom: 100%;
    background: url('../images/header-quote.svg') 0 0 no-repeat;
    background-size: 100% 100%;
    margin: 0 0 3px -3px;
}

@media (min-width: 768px) {
    .home-page .header__bg-content {
        width: 54.701%;
        grid-template-columns: 53.439% 46.563%;
    }

    .home-page .header__bg-cell._4 {
        grid-area: 1 / 1 / 2 / 2;
    }

    .home-page .header__bg-cell._5 {
        grid-area: 1 / 2 / 2 / 3;
    }

    .home-page .header__bg-cell._6 {
        grid-area: 2 / 1 / 3 / 3;
    }

    .home-page .header__bg-cell._2,
    .home-page .header__bg-cell._3 {
        display: none;
    }

    .home-page .header__bg-cell._7 {
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        left: 50%;
        margin-left: 584px;
    }

    .home-page .header__bg-cell._7 .header__bg-image {
        background-position: center left;
    }

    .home-page .header {
        height: 536px;
    }

    .home-page .header__logo {
        margin: 30px 0;
    }

    .home-page .header__logo img {
        width: 218px;
    }

    .home-page .header__title {
        font-size: 41px;
        line-height: 46px;
        text-shadow: 0 4px 4px rgb(0 0 0 / 25%);
        width: 7.97em;
        margin-left: 27px;
    }

    .home-page .header__title br {
        display: unset;
    }

    .home-page .header__subscribe {
        display: block;
    }

    .home-page .header__arrow-wrapper {
        margin: 100px 0 0 0;
    }

    .home-page .header__arrow-wrapper:before {
        display: none;
    }

    .home-page .header__arrow {
        width: 442px;
        background-image: url(../images/header-arrow-home.png);
    }

    .home-page .header__arrow:before {
        padding-top: calc(311 * 100% / 442);
    }

    .home-page .header__quote-wrapper {
        display: block;
    }
}

.mob-header {
    display: none;
    background: #fff;
}

.mob-header__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 70px;
}

.mob-header__logo img {
    width: auto;
    height: auto;
    max-width: 87px;
    max-height: 34px;
}

.mob-header .menu-btn {
    background: #252B30;
    color: #fff;
}

.nav {
    background: var(--accent-color);
    color: #1E1E1E;
    text-transform: uppercase;
    font-size: 20px;
    line-height: 1;
    padding: 10px 0;
    white-space: nowrap;
    position: sticky;
    top: 0;
    z-index: 1001;
}

.nav ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
}

.nav li {
    margin-right: 30px;
}

.nav li:last-child {
    margin-right: 0;
}

.nav a {
    display: block;
    position: relative;
    text-decoration: none;
}

.nav a:hover,
.nav a.is-active {
    color: #fff;
}

.nav a.is-active:after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    border-bottom: 1px solid;
}

.footer {
    padding-bottom: 50px;
    line-height: 1.129;
}

.footer a {
    text-decoration: none;
}

.footer a:hover {
    color: var(--accent-color);
}

.footer__inner {
    display: flex;
    background: #000 url('../images/bg.jpg') left top repeat;
    background-size: 450px;
    color: #fff;
    border: 12px solid var(--grey-color);
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 0 0 15px 15px;
}

.footer__section {
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    flex: 0 0 auto;
    padding: 22px 46px 46px 44px;
}

.footer__section_left {
    border-right: 12px solid var(--grey-color);
    background-image: url('../images/footer-left-bg.jpg');
    width: 41.012%;
    padding-right: 37px;
}

.footer__section_right {
    background-image: url('../images/footer-right-bg.jpg');
    width: 58.988%;
}

.footer__row {
    display: flex;
    justify-content: space-between;
    margin: 0 -5px;
}

.footer__row_social {
    align-items: flex-end;
    margin-top: 31px;
}

.footer__col {
    padding: 0 5px;
}

.footer__title {
    font-weight: 700;
    font-size: 21px;
    width: 8em;
    margin-bottom: 31px;
}

.footer__contacts {
    font-size: 18px;
}

.footer__contacts a {
    text-decoration: none;
}

.footer__nav {
    font-size: 18px;
    text-align: right;
    white-space: nowrap;
    margin-top: 7px;
}

.footer__nav ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer__nav li {
    margin-bottom: 7px;
}

.footer__nav a {
    text-decoration: none;
}

.footer__nav a:hover {
    text-decoration: underline;
}

.social {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
}

.social li {
    margin-right: 7px;
}

.social li:last-child {
    margin-right: 0;
}

.social a:hover {
    color: var(--accent-color);
}

.social .icon {
    width: 30px;
    height: 30px;
}

.footer .social li {
    margin-right: 9px;
}

.footer .social .icon {
    width: 37px;
    height: 37px;
}

.footer__login-btn {
    border: none;
    padding: 0;
    background: none;
}

.footer__login-btn:hover {
    color: var(--accent-color);
}

.footer__projects-title {
    font-weight: 700;
    font-size: 26px;
    margin-bottom: 14px;
}

.footer__projects-list {
    margin: 0;
    padding: 0;
    list-style: none;
    font-weight: 700;
    font-size: 21px;
}

.footer__projects-arrow {
    margin-top: 29px;
}

.footer__subscribe {
    width: 271px;
    margin-left: auto;
}

.footer__subscribe-title {
    font-weight: 700;
    font-size: 26px;
    margin-bottom: 12px;
}

.footer__subscribe-text {
    display: none;
    font-size: 21px;
    margin-bottom: 20px;
}

.footer__subscribe .form-control {
    border-color: #ADB6C0;
    background: #ADB6C0;
}

.footer__subscribe-form .g-recaptcha > div {
    position: relative;
    left: 50%;
    transform: translateX(-50%) scale(0.9);
}

.date {
    display: inline-block;
    vertical-align: top;
    margin-top: 6px;
    position: relative;
    background: #2C3339;
    color: #fff;
    border-radius: 0 0 5px 5px;
    text-align: center;
    min-width: 73px;
    font-size: 15px;
    line-height: 1;
    text-transform: uppercase;
    padding: 2px 5px 12px;
}

.date:before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: -6px;
    height: 3px;
    background: var(--accent-color);
}

.date__days {
    display: block;
}

.date__day {
    display: block;
    font-family: var(--text-font);
    font-size: 39px;
}

.date__day + .date__day {
    margin-top: 4px;
    padding-top: 7px;
    position: relative;
}

.date__separator {
    text-indent: -9999px;
    font-size: 1px;
    line-height: 1;
    display: block;
    width: 40px;
    margin: 3px auto;
    height: 3px;
    background: currentColor;
}

.date__month {
    display: block;
    margin-top: 3px;
}

.speaker-s {
    display: flex;
    align-items: center;
    text-decoration: none;
    font-size: 16px;
    line-height: 18px;
}

.speaker-s__image {
    display: block;
    width: 62px;
    height: 62px;
    flex-shrink: 0;
    margin-right: 15px;
}

.speaker-s__image img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
    border-radius: 50%;
}

.speaker-s__content {
    flex-grow: 1;
    min-width: 1px;
}

.speaker-s__title {
    display: block;
    font-weight: bold;
}

.speaker-s__text {
    display: block;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 30px;
}

.section-title {
    font-size: 32px;
    line-height: 41px;
    color: #303030;
    margin: 0;
}

.theme-dark .section-title {
    color: #8E959E;
}

.home-page .section-title {
    font-size: 40px;
    line-height: 52px;
}

.section-more {
    display: inline-block;
    font-size: 16px;
    line-height: 20px;
    color: #888888;
    text-decoration: none;
}

.section-title a:hover,
.section-more:hover {
    text-decoration: none;
    color: var(--accent-color);
}

.section-more:after {
    content: '';
    display: inline-block;
    vertical-align: middle;
    position: relative;
    transform: rotate(-45deg);
    width: 8px;
    height: 8px;
    border-style: solid;
    border-width: 0 2px 2px 0;
    margin-left: 7px;
}

.main-events-section {
    margin-bottom: 6px;
}

.main-events-section .section-header {
    margin: 13px 0 38px;
}

.main-events-section .section-title {
    font-size: 35px;
}

.main-events-section .section-more {
    font-size: 18px;
}

.main-events-section .section-more:after {
    top: -1px;
}

.main-events__item {
    padding-top: 12px;
    margin-bottom: 26px;
}

.event-card {
    display: flex;
    flex-direction: column;
    width: 100%;
    border-radius: 4px;
    background: #EAEAEA;
    color: #000;
    position: relative;
    font-size: 16px;
    line-height: 18px;
}

.event-card__image-wrapper {
    position: relative;
}

.event-card__image {
    display: block;
}

.event-card__image img {
    display: block;
    width: 100%;
    height: auto;
}

.event-card__sticker {
    position: absolute;
    left: 0;
    top: 13px;
    background: var(--accent-color);
    color: #fff;
    border-radius: 0 5px 5px 0;
    font-size: 20px;
    line-height: 1;
    text-transform: uppercase;
    padding: 7px 19px;
}

.event-card .date {
    position: absolute;
    right: 8px;
    top: -12px;
}

.event-card__content {
    padding: 19px 23px 67px;
    flex-grow: 1;
    min-height: 1px;
    display: flex;
    flex-direction: column;
}

.event-card__title {
    font-size: 20px;
    line-height: 22px;
    font-weight: bold;
    margin: 0 0 16px;
}

.event-card__text {
    font-family: var(--text-font);
    margin-bottom: 40px;
}

.event-card__speakers {
    display: flex;
    overflow: hidden;
    margin-top: auto;
    padding-bottom: 38px;
}

.event-card__speakers.slick-slider {
    display: block;
    overflow: visible;
}

.event-card__speakers .slick-arrow,
.event-item__speakers .slick-arrow {
    width: 36px;
    height: 36px;
    top: auto;
    margin: 0;
    bottom: 0;
}

.event-card__speakers .slick-arrow:hover,
.event-item__speakers .slick-arrow:hover {
    color: var(--accent-color);
}

.event-card__speakers .slick-prev,
.event-item__speakers .slick-prev {
    left: auto;
    right: 50%;
}

.event-card__speakers .slick-next,
.event-item__speakers .slick-next {
    right: auto;
    left: 50%;
}

.event-card__speakers .slick-arrow:before,
.event-item__speakers .slick-arrow:before {
    width: 10px;
    height: 10px;
    margin: -5px;
    border-width: 0 2px 2px 0;
    border-color: currentColor;
}

.event-card__speakers .slick-prev:before,
.event-item__speakers .slick-prev:before {
    transform: translateX(2px) rotate(135deg);
}

.event-card__speakers .slick-next:before,
.event-item__speakers .slick-next:before {
    transform: translateX(-2px) rotate(-45deg);
}

.event-card__speakers-item {
    flex: 0 0 auto;
    width: 100%;
    padding-right: 15px;
}

.event-card__footer {
    position: absolute;
    left: 23px;
    right: 23px;
    bottom: 23px;
    text-align: right;
}

.event-card__registration-btn {
    border: none;
    padding: 0;
    background: none;
    font-size: 20px;
    line-height: 1;
    text-transform: uppercase;
    color: #DD370A;
    text-decoration: underline;
    text-decoration-thickness: 1px;
}

.event-card__registration-btn:hover {
    text-decoration: none;
}

.event-card__registration-btn .icon {
    top: -1px;
    margin-left: 9px;
    color: var(--accent-color);
}

@media (min-width: 1210px) {
    .main-events__item:not(.col-xl-3) .event-card__content {
        padding-bottom: 74px;
    }

    .main-events__item:not(.col-xl-3) .event-card__text {
        margin-bottom: 22px;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers {
        padding: 0;
        margin-right: 56px;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers.slick-slider {
        padding: 0;
        margin-right: 0;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers .slick-list {
        margin-right: 56px;
        transition: margin 0.3s ease-in-out;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers .slick-arrow:not(.slick-disabled) ~ .slick-list {
        margin: 0 28px;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers .slick-arrow {
        top: 50%;
        margin-top: -18px;
        bottom: auto;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers .slick-prev {
        left: -10px;
        right: auto;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers .slick-next {
        right: -10px;
        left: auto;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers .slick-arrow.slick-disabled {
        opacity: 0;
    }

    .main-events__item:not(.col-xl-3) .event-card__speakers-item {
        width: 50%;
    }
}

.speakers-section {
    background: #131618;
    padding: 25px 0 17px;
    margin-bottom: 40px;
}

.speakers-list {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -10px;
}

.speakers-list__item {
    flex: 0 0 auto;
    padding: 0 10px;
    width: 20%;
    margin-bottom: 23px;
}

.speaker {
    position: relative;
    text-align: center;
    font-size: 20px;
    line-height: 22px;
}

.speaker .date {
    position: absolute;
    right: -10px;
    top: 0;
    z-index: 1;
}

@media (min-width: 1240px) {
    .speaker .date {
        right: -23px;
    }
}

.speaker__image {
    margin-bottom: 20px;
}

.speaker__image img {
    display: block;
    margin: 0 auto;
    max-width: none;
    width: 190px;
    height: 190px;
    object-fit: cover;
    border-radius: 50%;
    filter: grayscale(1);
    transition: 0.15s ease-in-out;
}

.speaker:hover .speaker__image img {
    filter: grayscale(0);
}

.speaker__title {
    font-weight: bold;
}

.speaker__date {
    color: #E56A6A;
    margin: 6px 0 1px;
}

.speaker__about {
    font-size: 16px;
    color: #ABABAB;
}

.speaker__about a {
    text-decoration: none;
}

.speaker__about a:hover {
    text-decoration: underline;
}

.speaker-window .speaker {
    margin-bottom: 25px;
}

.speaker-window .speaker__image {
    margin-bottom: 15px;
}

.speaker-window .speaker__image img {
    border: 2px solid #47515E;
    width: 127px;
    height: 127px;
    filter: grayscale(0);
}

.simple-gallery {
    overflow: hidden;
    margin-bottom: 37px;
}

.simple-gallery__row {
    margin-right: -20%;
    position: relative;
    margin-bottom: 9px;
    display: flex;
}

.simple-gallery__row + .simple-gallery__row {
    left: -10%;
}

.simple-gallery__item {
    flex: 0 0 auto;
    width: 16.66667%;
}

.simple-gallery__item a {
    display: block;
}

.simple-gallery__item img {
    display: block;
    width: 100%;
    height: auto;
}

.about-section {
    border-top: 12px solid var(--grey-color);
    border-bottom: 12px solid var(--grey-color);
    overflow: hidden;
    margin-bottom: 22px;
}

.about-section__inner {
    display: flex;
    position: relative;
}

.about-section__inner:before {
    content: '';
    position: absolute;
    right: 100%;
    top: 50%;
    width: 350px;
    height: 245px;
    background: url('../images/about-section-arrow.svg') 0 0 no-repeat;
    background-size: 100% 100%;
    margin: -114px 72px 0 0;
}

.about-section__content {
    flex: 0 0 auto;
    width: 62.905%;
    align-self: center;
    padding: 10px 30px 28px 0;
    font-family: var(--text-font);
    font-size: 18px;
    line-height: 112.9%;
}

.about-section__content .section-header {
    margin-bottom: 16px;
}

.about-section__content p:last-child {
    margin-bottom: 0;
}

.about-section__gallery {
    flex: 0 0 auto;
    width: 37.095%;
    display: flex;
    position: relative;
}

.about-section__gallery-item {
    flex: 0 0 auto;
    width: 100%;
}

.about-section__gallery-item + .about-section__gallery-item {
    width: auto;
    position: absolute;
    left: 100%;
    top: 0;
    bottom: 0;
}

.about-section__gallery-item img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
}

.about-section__gallery-item + .about-section__gallery-item img {
    width: auto;
}

.news-section {
    margin-bottom: 10px;
}

.news-list__item {
    margin-bottom: 20px;
}

.news-item-s {
    width: 100%;
    background: linear-gradient(180deg, #121518 50%, #22292F 100%);
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 0 0 4px 4px;
    color: #fff;
}

.news-item-s__image {
    display: block;
    position: relative;
}

.news-item-s__image:before {
    content: '';
    display: block;
    padding-top: calc(178 * 100% / 278);
}

.news-item-s__image img {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
}

.news-item-s__content {
    padding: 19px 23px 40px;
}

.news-item-s__title {
    font-weight: 700;
    font-size: 20px;
    line-height: 1.1;
    margin-bottom: 7px;
}

.news-item-s__footer {
    font-size: 18px;
    line-height: 20px;
    color: #4E4E4E;
}

.news-item-s__footer a {
    text-decoration: none;
}

.news-item-s__footer a:hover {
    color: var(--accent-color);
}

.for-whom-section {
    margin-bottom: 55px;
}

.for-whom-list__item {
    margin-bottom: 20px;
}

.for-whom-list__link {
    display: flex;
    width: 100%;
    background: #fff;
    border: 12px solid var(--grey-color);
    border-radius: 15px;
    color: #13181E;
    font-weight: 700;
    font-size: 20px;
    line-height: 22px;
    padding: 0 14px 0 12px;
    align-items: center;
    min-height: 84px;
    text-decoration: none;
}

a.for-whom-list__link:hover {
    border-color: var(--accent-color);
}

.for-whom-list__title {
    padding-left: 32px;
    position: relative;
}

.for-whom-list__title .icon {
    position: absolute;
    left: 0;
    top: 0;
    color: #9F9D9D;
    transition: 0.15s ease-in-out;
}

a.for-whom-list__link:hover .for-whom-list__title .icon {
    color: var(--accent-color);
}

.main-info {
    background: url('../images/main-info.jpg') center center no-repeat;
    background-size: cover;
    text-align: center;
    padding: 44px 0 81px;
    margin-bottom: 48px;
    color: #fff;
}

.main-info__content {
    font-weight: 700;
    font-size: 29px;
    line-height: 38px;
    margin: 0 auto 47px;
    max-width: 38em;
}

.main-info__btn-row .btn {
    width: 100%;
    max-width: 342px;
}

.partners-list__item {
    margin-bottom: 20px;
}

.partners-list__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: #fff;
    border: 12px solid var(--grey-color);
    border-radius: 15px;
    color: #13181E;
    padding: 5px;
    height: 101px;
}

a.partners-list__link:hover {
    border-color: var(--accent-color);
}

.partners-list__link img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
}

.breadcrumbs {
    border-bottom: 1px solid #828282;
    font-family: var(--text-font);
    font-size: 12px;
    line-height: 16px;
    color: #828282;
    padding: 11px 0;
}

.breadcrumbs ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
    list-style: none;
}

.breadcrumbs li:not(:last-child):after {
    content: '';
    display: inline-block;
    vertical-align: middle;
    position: relative;
    transform: rotate(-45deg);
    width: 5px;
    height: 5px;
    border-style: solid;
    border-width: 0 1px 1px 0;
    margin: 0 15px;
    top: -1px;
}

.breadcrumbs a {
    text-decoration: none;
}

.breadcrumbs a:hover {
    text-decoration: underline;
}

.page-title {
    margin: 40px 0 85px;
    color: #202020;
}

.theme-dark .page-title {
    color: #8E959E;
}

.pagination {
    margin: 56px 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    font-family: var(--text-font);
    font-size: 24px;
    line-height: 1;
}

.pagination li {
    margin: 0 7px;
}

.pagination a {
    display: block;
    text-align: center;
    text-decoration: none;
}

.pagination a:hover,
.pagination a.is-active {
    color: #6C6C6C;
}

.theme-dark .pagination a:hover,
.theme-dark .pagination a.is-active {
    color: #758598;
}

.pagination a.is-active {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-position: under;
}

.news {
    --bs-gutter-x: 15px;
}

.news__item-inner {
    padding-bottom: 15px;
}

@supports(display: grid){
    .news._masonry.is-complete {
        display: grid;
        margin: 0;
        grid-gap: 0 15px;
        grid-template-columns: repeat(3, 1fr);
        grid-auto-rows: 1px;
    }

    .news._masonry.is-complete .news__item {
        width: auto;
        padding: 0;
        grid-row-end: span 1;
    }
}

.news-item {
    background: #EEEEEE;
    border-radius: 5px;
    color: #6D6D6D;
    font-size: 16px;
    line-height: 18px;
}

.news-item:hover {
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}

.news-item__image {
    display: block;
}

.news-item__image img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 5px 5px 0 0;
}

.news-item__content {
    padding: 27px 25px 24px;
}

.news-item__title {
    font-weight: 700;
    font-size: 24px;
    line-height: 1.089;
    margin-bottom: 20px;
    color: #000;
}

.news-item__text {
    font-family: var(--text-font);
}

.news-item__footer {
    font-size: 16px;
    line-height: 21px;
    margin-top: 17px;
}

.news-item__footer a {
    text-decoration: none;
}

.news-item__footer a:hover {
    color: var(--accent-color);
}

.event-item {
    background: #EDEDED;
    color: #000;
    position: relative;
    font-size: 16px;
    line-height: 18px;
    margin-bottom: 40px;
    border-radius: 4px;
}

.event-item__main {
    display: flex;
}

.event-item__image-wrapper {
    flex: 0 0 auto;
    width: 278px;
    position: relative;
    display: flex;
    flex-direction: column;
}

.event-item__sticker {
    position: absolute;
    left: 0;
    top: 13px;
    background: var(--accent-color);
    color: #fff;
    border-radius: 0 5px 5px 0;
    font-size: 20px;
    line-height: 1;
    text-transform: uppercase;
    padding: 7px 19px;
}

.event-item__image {
    display: block;
    flex-shrink: 0;
}

.event-item__image img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 4px 0 0 0;
}

.event-item__date {
    background: var(--accent-color);
    color: #fff;
    text-align: center;
    font-family: var(--text-font);
    font-size: 28px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-grow: 1;
    min-height: 1px;
    padding: 11px 5px 10px;
}

.event-item__content {
    padding: 25px;
    flex-grow: 1;
    min-width: 1px;
}

.event-item__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.event-item__type {
    order: 1;
    display: flex;
    align-items: center;
    color: #414B56;
    white-space: nowrap;
    font-size: 18px;
    line-height: 25px;
    margin-left: 10px;
}

.event-item__type .icon {
    width: 25px;
    height: 25px;
    flex-shrink: 0;
    margin-right: 8px;
}

.event-item__type .icon + .icon {
    margin-left: -4px;
}

.event-item__title {
    font-size: 24px;
    line-height: 26px;
    font-weight: bold;
    margin: 0 0 23px;
}

.event-item__text {
    font-family: var(--text-font);
    margin-bottom: 30px;
}

.event-item__speakers {
    display: flex;
    overflow: hidden;
    padding-bottom: 38px;
}

.event-item__speakers-item {
    flex: 0 0 auto;
    width: 100%;
    padding-right: 15px;
}

.event-item__speakers.slick-slider {
    display: block;
    overflow: visible;
}

@media (min-width: 992px) {
    .event-item__speakers {
        padding: 0;
        margin-right: 150px;
    }

    .event-item__speakers.slick-slider {
        padding: 0;
        margin-right: 0;
    }

    .event-item__speakers .slick-list {
        margin-right: 150px;
        transition: margin 0.3s ease-in-out;
    }

    .event-item__speakers .slick-arrow:not(.slick-disabled) ~ .slick-list {
        margin: 0 75px;
    }

    .event-item__speakers .slick-arrow {
        width: 50px;
        height: 50px;
        top: 50%;
        margin-top: -25px;
        background: #DBDBDB;
        border-radius: 50%;
        bottom: auto;
    }

    .event-item__speakers .slick-prev {
        left: 0;
        right: auto;
    }

    .event-item__speakers .slick-next {
        right: 0;
        left: auto;
    }

    .event-item__speakers .slick-arrow.slick-disabled {
        opacity: 0;
    }

    .event-item__speakers-item {
        width: 50%;
    }
}

@media (min-width: 1210px) {
    .event-item__speakers-item {
        width: 33.33%;
    }
}

.event-item__footer {
    background: #2C3339;
    color: #fff;
    display: flex;
    border-radius: 0 0 4px 4px;
}

.event-item__data {
    flex-grow: 1;
    min-width: 1px;
    display: flex;
    font-family: var(--text-font);
    font-size: 18px;
    line-height: 1;
    padding: 0 10px;
}

.event-item__data-item {
    display: flex;
    align-items: center;
    height: 50px;
    padding: 0 10px;
}

.event-item__data-icon {
    margin-right: 17px;
    color: #6B747C;
}

.event-item__registration-btn {
    width: 278px;
    flex-shrink: 0;
    display: block;
    text-align: center;
    white-space: nowrap;
    text-decoration: none;
    cursor: pointer;
    border: none;
    position: relative;
    background: var(--accent-color);
    color: #2C3339;
    border-radius: 0 0 4px 0;
    padding: 12px 16px;
    font-size: 24px;
    line-height: 26px;
    font-weight: bold;
}

.event-item__registration-btn:hover {
    background-color: var(--accent-hover-color);
    color: #000;
}

.event-item__registration-btn .icon {
    color: #fff;
    position: absolute;
    top: 50%;
    right: 26px;
    margin-top: -18px;
}

.filter {
    border-top: 2px solid #0F1113;
    border-bottom: 2px solid #0F1113;
    padding: 28px 0;
    margin-bottom: 42px;
}

.filter__row {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    margin: 0 -3px;
}

.filter__item {
    flex: 0 0 auto;
    width: 8.3333%;
    padding: 0 3px 6px;
}

.filter__item a {
text-decoration:none;
}

.filter__item._auto {
    width: auto;
    margin-right: 16px;
}

.filter__btn {
    width: 100%;
    height: 35px;
    border: none;
    padding: 0;
    background: #2C3339;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 18px;
    line-height: 1;
}

.filter__btn:hover {
    background: #495661;
}

.filter__btn.is-active {
    background: #495661;
    text-decoration: underline;
    text-decoration-skip-ink: none;
}

.filter__btn[disabled] {
    background: #0F1113;
    color: #494E53;
    cursor: default;
    cursor: not-allowed;
}

.filter__btn._type {
    background: none;
}

.filter__btn._type .icon {
    margin-right: 8px;
    color: #414B56;
    transition: 0.15s ease-in-out;
}

.filter__btn._type .icon + .icon {
    margin-left: -4px;
}

.filter__btn._type:hover,
.filter__btn._type.is-active {
    color: var(--accent-color);
}

.filter__btn._type:hover .icon,
.filter__btn._type.is-active .icon {
    color: #fff;
}

.filter__item._search {
    width: 25%;
}

.filter__search-form {
    display: flex;
}

.filter__search-input-wrapper {
    flex-grow: 1;
    min-width: 1px;
}

.filter__search-input-wrapper label.error {
    display: none !important;
}

.filter__search-input {
    background: #2C3339;
    border-color: #2C3339;
    color: #fff;
    border-radius: 4px 0 0 4px;
    font-size: 18px;
    line-height: 23px;
    height: 35px;
    padding: 4px 18px;
    font-family: var(--base-font);
    letter-spacing: 0;
}

.filter__search-input:focus {
    border-color: #2C3339;
}

.filter__search-input::placeholder {
    color: #5C656C;
}

.filter__search-input:not([readonly]):focus::placeholder {
    color: transparent;
}

.filter__search-btn-wrapper {
    flex-shrink: 0;
}

.filter__search-btn {
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 35px;
    width: 43px;
    background: #0F1113;
    color: #787878;
    border-radius: 0 4px 4px 0;
}

.filter__search-btn:hover {
    color: #fff;
}

.filter__list {
    font-family: var(--text-font);
    font-size: 16px;
    margin-top: 43px;
    margin-bottom: -14px;
}

.filter__list-target {
    display: none;
    cursor: pointer;
    color: #5C656C;
    transition: 0.15s ease-in-out;
}

.filter__list.is-open .filter__list-target,
.filter__list-target:hover {
    color: #fff;
}

.filter__list-target-text {
    flex-grow: 1;
    min-width: 1px;
    background: #2C3339;
    border-radius: 4px 0 0 4px;
    font-size: 18px;
    line-height: 23px;
    height: 35px;
    padding: 6px 20px;
    font-family: var(--base-font);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.filter__list-target-btn {
    flex-shrink: 0;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 35px;
    width: 43px;
    background: #0F1113;
    color: #787878;
    border-radius: 0 4px 4px 0;
}

.filter__list.is-open .filter__list-target-btn,
.filter__list-target:hover .filter__list-target-btn {
    color: #fff;
}

.filter__list.is-open .filter__list-target-btn .icon {
    transform: rotate(90deg);
}

.filter__list-content {
    column-count: 4;
    column-gap: 6px;
}

.filter__list-item {
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    padding-bottom: 14px;
}

.filter__list-btn {
    text-decoration: none;
    display: inline-block;
    position: relative;
    padding-left: 25px;
}

.filter__list-btn:before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 10px;
    height: 10px;
    margin-top: -5px;
    border-style: solid;
    border-width: 0 2px 2px 0;
    border-color: #414B56;
    transform: rotate(-45deg);
}

.filter__list-btn:hover,
.filter__list-btn.is-active {
    color: var(--accent-color);
}

.filter__list-btn.is-active {
    text-decoration: underline;
}

.about {
    display: grid;
    grid-gap: 15px;
    grid-template-columns: repeat(3, 1fr);
}

.about__cell:nth-child(1),
.about__cell:nth-child(3),
.about__cell:nth-child(8) {
    grid-column-end: span 2;
}

.about__cell:nth-child(4) {
    grid-row-end: span 2;
}

.about__img {
    display: block;
    border-radius: 7px;
    width: 100%;
    height: auto;
    min-height: 100%;
    object-fit: cover;
}

.about-text {
    display: flex;
    line-height: 1.129;
    padding: 29px 32px 11px 32px;
}

.about-text__header {
    flex: 0 0 auto;
    width: 46.6%;
    padding-right: 15px;
}

.about-text__title {
    font-size: 34px;
    line-height: 112.9%;
    font-weight: bold;
    margin: 0 0 20px;
    max-width: 8em;
}

.about-text__contacts {
    font-size: 20px;
    margin-bottom: 25px;
}

.about-text__contacts a {
    text-decoration: none;
}

.about-text__contacts a:hover {
    color: var(--accent-color);
}

.about-text__content {
    font-family: var(--text-font);
    font-size: 17px;
    padding-top: 10px;
    flex-grow: 1;
    min-width: 1px;
}

.about-text__content p:last-child {
    margin-bottom: 0;
}

.article:not(:last-child) {
    margin-bottom: 45px;
}

.timer {
    background: #272727;
    color: #fff;
    border-radius: 3px;
    text-align: center;
    padding: 5px;
    width: 125px;
}

.timer__title {
    font-size: 15px;
    line-height: 24px;
    margin-bottom: 2px;
}

.timer__timer {
    display: flex;
    margin: 0 -2px;
}

.timer__timer-col {
    flex-grow: 1;
    flex-basis: 0;
    padding: 0 2px;
}

.timer__timer-item {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 65px;
    background: linear-gradient(180deg, #000000 0%, #555454 48.96%, #000000 100%);
    font-family: var(--base-font);
    font-weight: 700;
    font-size: 29px;
}

.timer__labels {
    display: flex;
    margin: 0 -2px;
    font-size: 14px;
    line-height: 20px;
    white-space: nowrap;
}

.timer__label {
    flex-grow: 1;
    flex-basis: 0;
    padding: 0 2px;
}

.event-main {
    background: #000 url('../images/bg.jpg') 25% top repeat;
    background-size: 385px;
    color: #fff;
    border-radius: 15px;
    display: flex;
    margin-bottom: 12px;
}

.event-main__header {
    flex: 0 0 auto;
    width: 50%;
    position: relative;
}

.event-main__image {
    height: 100%;
}

.event-main__image img {
    display: block;
    width: 100%;
    height: auto;
    min-height: 100%;
    object-fit: cover;
    border-radius: 15px 0 0 15px;
}

.event-main__timer {
    position: absolute;
    left: 27px;
    bottom: 22px;
}

.event-main__content {
    flex: 0 0 auto;
    width: 50%;
    padding: 54px;
    display: flex;
    flex-direction: column;
}

.event-main__date {
    align-self: flex-start;
    display: inline-block;
    vertical-align: top;
    text-align: center;
    font-weight: 700;
    font-size: 30px;
    line-height: 40px;
    color: #252B30;
    padding: 15px 12px;
    border-radius: 0 0 10px 10px;
    background: var(--accent-color);
    margin: -54px 0 44px;
    min-width: 197px;
}

.event-main__content h1 {
    margin-bottom: 40px;
}

.event-main__content h2 {
    margin-bottom: 30px;
}

.event-main__footer {
    margin-top: auto;
}

.event-main__footer .btn {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.page-nav {
    margin: 0 -6px 35px;
    padding: 0;
    list-style: none;
    display: flex;
    font-size: 17px;
    line-height: 22px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.page-nav li {
    flex-grow: 1;
    flex-basis: 0;
    padding:  0 6px 12px;
}

.page-nav a {
    display: block;
    text-align: center;
    background: #DDE4EC;
    border-radius: 15px;
    text-decoration: none;
    padding: 8px;
}

.page-nav a:hover {
    text-decoration: underline;
}

.event-price {
    text-align: center;
    margin-bottom: 30px;
}

.block {
    position: relative;
    margin-bottom: 35px;
}

.block-target {
    position: absolute;
    left: 0;
    top: -40px;
}

.block > h2,
.block .text h2 {
    font-size: 24px;
    line-height: 112.9%;
}

.block > h2 {
    margin-bottom: 35px;
}

.video-block {
    border: 1px solid var(--border-color);
    border-width: 1px 0;
    padding: 27px 0;
}

.video-block figure {
    max-width: 560px;
    text-align: center;
    margin: 0 auto;
}

.video-block iframe {
    max-width: 100%;
}

.video-block figcaption {
    font-family: var(--text-font);
    margin-top: 15px;
}

.event-speaker {
    font-size: 20px;
    line-height: 1.15;
    margin-bottom: 20px;
}

.event-speaker__image img {
    display: block;
    width: 164px;
    height: 164px;
    border-radius: 50%;
    object-fit: cover;
}

.event-speaker__time {
    width: 164px;
    height: 164px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: var(--accent-color);
    color: #fff;
    font-size: 47px;
    line-height: 1;
}

.event-speaker__content {
    padding-left: 20px;
}

.event-speaker__title {
    margin-bottom: 8px;
}

.event-speaker__about {
    color: var(--secondary-color);
    margin-top: 8px;
}

.event-news + .event-news {
    margin-top: 30px;
}

.event-news__image {
    display: block;
}

.event-news__image img {
    width: 100%;
    height: auto;
    border-radius: 5px;
}

.event-news__content {
    padding-left: 20px;
}

.event-news__title {
    margin-bottom: 15px;
}

.event-news__text {
    font-family: var(--text-font);
    font-size: 16px;
    line-height: 18px;
}

.event-news__footer {
    color: var(--secondary-color);
    font-size: 14px;
    line-height: 16px;
    margin-top: 8px;
}

.event-cards {
    margin-bottom: -30px;
}

@media (min-width: 1249px) {
    .event-cards {
        --bs-gutter-x: 60px;
    }
}

.text-card {
    background: #E5ECF2;
    border-radius: 6px;
    margin-bottom: 30px;
}

.text-card__header {
    border-bottom: 1px solid #fff;
    padding: 16px 30px;
}

.text-card h2 {
    margin: 0;
    font-size: 24px;
}

.text-card__content {
    padding: 23px 30px;
}

.gallery {
    --bs-gutter-x: 10px;
    margin-top: 16px;
    margin-bottom: 16px;
}

.gallery__item  {
    padding: calc(var(--bs-gutter-x) * .5);
}

.gallery a {
    display: block;
}

.gallery img {
    display: block;
    width: 100%;
    height: auto;
}

.gallery.slick-slider {
    margin-left: 0;
    margin-right: 0;
}

.gallery.slick-slider .slick-list {
    margin-right: calc(-.5 * var(--bs-gutter-x));
    margin-left: calc(-.5 * var(--bs-gutter-x));
    width: auto;
    max-width: none;
}

.gallery .slick-arrow {
    color: #fff;
}

.partners-block {
    border: 1px solid #E5ECF2;
    border-width: 1px 0;
    padding: 10px 0;
    margin: 18px 0;
}

.partners-block__list {
    padding: 0 38px;
    display: flex;
    flex-wrap: wrap;
}

.partners-block__list.slick-slider {
    display: block;
}

.partners-block__list .slick-arrow {
    width: 30px;
    height: 40px;
    margin-top: -20px;
    color: #E5ECF2;
}

.partners-block__list .slick-arrow:hover {
    color: var(--accent-color);
}

.partners-block__list .slick-arrow:before {
    width: 30px;
    height: 30px;
    margin: -15px;
    border-width: 0 7px 7px 0;
    border-color: currentColor;
}

.partners-block__list .slick-prev:before {
    transform: translateX(7px) rotate(135deg);
}

.partners-block__list .slick-next:before {
    transform: translateX(-7px) rotate(-45deg);
}

.partners-block__item {
    flex: 0 0 auto;
    width: 16.66%;
    padding: 10px;
}

.partners-block__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: #fff;
    border: 12px solid #E5ECF2;
    border-radius: 15px;
    padding: 5px;
    height: 92px;
}

.partners-block__link img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
}

.text-col {
    column-count: 2;
    column-gap: 20px;
}

@media (min-width: 1249px) {
    .text-col {
        column-gap: 80px;
    }
}

.text-section {
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    padding-bottom: 10px;
}

.event-data {
    font-size: 24px;
    line-height: 27px;
}

@media (min-width: 1249px) {
    .event-data {
        --bs-gutter-x: 36px;
    }
}

.event-data__item {
    display: flex;
    align-items: center;
    border-top: 1px solid #B4B4B4;
    border-bottom: 1px solid #B4B4B4;
    padding: 9px 20px;
    margin-bottom: -1px;
}

.event-data__icon {
    flex-shrink: 0;
    margin-right: 24px;
    color: #575757;
}

.event-data__icon .icon {
    width: 30px;
    height: 30px;
}

.event-registration {
    position: relative;
    margin-bottom: 30px;
}

.event-registration__main {
    background: #000 url('../images/bg.jpg') center top repeat;
    background-size: 420px;
    color: #fff;
    padding: 43px 0 57px;
    overflow: hidden;
}

.event-registration__inner {
    padding: 0 114px;
    position: relative;
    max-width: 1014px;
    margin: 0 auto;
}

.event-registration__inner:before,
.event-registration__inner:after {
    content: '';
    position: absolute;
    top: 69%;
    width: 58px;
    height: 58px;
    margin: -29px;
    border-style: solid;
    border-width: 0 14px 14px 0;
    border-color: #ADB6C0;
}

.event-registration__inner:before {
    left: 0;
    transform: rotate(-45deg);
}

.event-registration__inner:after {
    right: 0;
    transform: rotate(135deg);
}

.event-registration__header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}

.event-registration__title {
    font-weight: 700;
    font-size: 28px;
    line-height: 112.9%;
}

.event-registration__title .icon {
    color: #8E9BA7;
    margin-right: 13px;
}

.event-registration__type {
    text-transform: uppercase;
    padding-top: 11px;
}

.event-registration__type .form-check-list {
    margin-left: -9px;
    margin-right: -9px;
}

.event-registration__type .form-check-list .form-check {
    padding-left: 9px;
    padding-right: 9px;
}

.event-registration .form-control {
    text-align: center;
    text-transform: uppercase;
}

.event-registration .btn {
    color: #fff;
}

.event-registration .btn .icon {
    margin: -5px -34px -5px 7px;
    top: -3px;
}

.event-registration__footer {
    text-align: center;
    font-size: 18px;
    margin-top: 12px;
}

.event-address__header {
    text-align: center;
    margin-bottom: 24px;
}

.event-address__title {
    font-size: 24px;
    margin-bottom: 11px;
}

.event-address__title .icon {
    top: -3px;
    margin-right: 5px;
}

.event-footer__logo {
    font-size: 10px;
    margin-bottom: 24px;
    padding-right: 10em;
}

.event-footer__logo-row {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    margin: 0 -.7em;
}

.event-footer__logo-col {
    padding: 0 .7em;
    flex-shrink: 0;
}

.event-footer__content {
    display: flex;
    justify-content: center;
    margin: 0 -12px;
    font-size: 18px;
    line-height: 20px;
    max-width: 500px;
    margin: 0 auto;
}

.event-footer__header {
    flex: 0 0 auto;
    width: 50%;
    padding: 0 12px;
    text-align: right;
}

.event-footer__contacts {
    flex: 0 0 auto;
    width: 50%;
    padding: 0 12px;
}

.up-btn {
    position: fixed;
    right: 10px;
    bottom: 10px;
    width: 44px;
    height: 44px;
    padding: 0;
    border: none;
    background: #1B2026;
    color: #fff;
    cursor: pointer;
    z-index: 101;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: 0.25s ease-in-out;
    transition: 0.25s ease-in-out;
}

.up-btn.is-visible {
    opacity: 1;
    visibility: visible;
}

.up-btn:hover {
    background: var(--accent-color);
}

.up-btn:before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -12px 0 0 -14px;
    border-style: solid;
    border-width: 0 14px 24px;
    border-color: currentColor transparent;
}

.video-wrapper {
    position: relative;
    max-width: 560px;
    margin: 0 auto;
}

.video-wrapper:before {
    content: '';
    display: block;
    padding-top: 56.25%;
}

.video-wrapper iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}