@charset "UTF-8";
@font-face {
    font-family: Gilroy;
    src: url(../Gilroy-Regular.ttf);
    font-weight: 400
}

@font-face {
    font-family: Gilroy;
    src: url(../Gilroy-Bold.ttf);
    font-weight: 700
}

:root {
    --primary: #E9473F;
    --text: #606060
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

body {
    font-family: Gilroy, sans-serif;
    background-color: #fffdf9;
    color: var(--text)
}

a, input {
    font-family: Gilroy, sans-serif
}

a:hover {
    color: var(--primary);
    transition: color .3s ease
}

br {
    display: none
}

.pre-line {
    white-space: pre-line
}

.uppercase {
    text-transform: uppercase
}

.red {
    color: var(--primary) !important
}

.btn {
    border-radius: 30px;
    border: none;
    outline: none;
    background-color: #fff;
    font-weight: 600;
    font-size: 18px;
    line-height: 100%;
    text-align: center;
    transition: all .3s ease
}

.btn-red {
    background-color: var(--primary);
    color: #fff
}

.btn-white {
    border: 1px solid var(--primary);
    color: var(--primary)
}

.btn-to-red:hover {
    background-color: var(--primary);
    color: #fff;
    border: none
}

.btn-to-white:hover {
    border: 1px solid var(--primary);
    color: var(--primary);
    background-color: #fff
}

.btn-scale:hover {
    transform: scale(1.05)
}

.universal-title {
    font-weight: 700;
    font-size: 55px;
    line-height: 100%;
    text-align: center;
    color: #606060;
    margin-bottom: 50px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.universal-title-one {
    margin: 0 auto 40px;
    display: block
}

.line-box {
    display: flex;
    align-items: center
}

.line-box--right {
    left: auto;
    right: 0;
    top: 50%;
    transform: translateY(-50%)
}

.the-line {
    height: 2px;
    width: 600px;
    background-color: var(--primary)
}

.the-square {
    width: 10px;
    height: 10px;
    background-color: var(--primary);
    transform: rotate(45deg)
}

.custom-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    position: relative
}

.custom-checkbox input[type=checkbox] {
    position: absolute;
    opacity: 0;
    top: 0;
    left: 0;
    height: 20px;
    width: 180px;
    outline: none
}

.checkbox-custom {
    position: relative;
    width: 20px;
    height: 20px;
    background: transparent;
    border: 1px solid var(--primary);
    border-radius: 3px;
    flex-shrink: 0;
    transition: all .2s ease
}

.checkbox-custom:after {
    content: "";
    position: absolute;
    display: none;
    left: 8px;
    top: -8px;
    width: 10px;
    height: 24px;
    border: solid var(--primary);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg)
}

.custom-checkbox input[type=checkbox]:checked + .checkbox-custom:after {
    display: block
}

.checkbox-label {
    color: var(--primary);
    font-size: 12px;
    line-height: 16px;
    width: max-content
}

.checkbox-label a {
    color: var(--primary);
    text-decoration: underline
}

@media (max-width: 768px) {
    .checkbox-label {
        font-size: 14px
    }

    .universal-title {
        font-size: 25px;
        margin-bottom: 30px
    }

    .the-line {
        width: 60px
    }

    br {
        display: block
    }
}

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

html {
    min-height: 100dvh;
    color-scheme: light dark;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    -moz-tab-size: 2;
    tab-size: 2
}

body {
    margin: 0;
    min-height: 100dvh;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility
}

body:has(dialog[open]) {
    overflow: hidden;
    height: 100dvh
}

.visually-hidden {
    position: absolute !important;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    overflow: hidden;
    white-space: nowrap
}

:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 2px
}

a {
    text-decoration: none
}

b, strong {
    font-weight: bolder
}

code, kbd, samp, pre {
    font-family: ui-monospace, SFMono-Regular, Consolas, Liberation Mono, Menlo, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

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

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    border-collapse: collapse;
    border-color: currentColor
}

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

button {
    cursor: pointer
}

textarea {
    resize: vertical
}

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

:-moz-focusring {
    outline: auto
}

:disabled {
    cursor: not-allowed
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0
}

legend {
    padding: 0
}

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto
}

::file-selector-button {
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button;
    font: inherit
}

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

::-webkit-search-decoration {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

img, picture, video, canvas, svg {
    max-width: 100%;
    height: auto;
    object-fit: cover
}

details, summary {
    display: block
}

summary {
    cursor: pointer;
    list-style: none
}

dialog {
    border: 0;
    padding: 0;
    margin: auto
}

header {
    background-color: #fff;
    box-shadow: 0 2px 10px #00000026;
    z-index: 1000
}

.header-top__container {
    padding: 20px 0 10px;
    border-bottom: 1px solid #D9D9D9;
    background-color: #fff;
    z-index: 1000
}

.header-top {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.header-top__city-container {
    border: none;
    background-color: transparent;
    text-decoration: underline;
    color: #000
}

.header-top__links-container {
    display: flex;
    align-items: center;
    gap: 25px
}

.header-top__link {
    font-weight: 600;
    font-size: 16px;
    line-height: 100%;
    color: #8d8d8d
}

.header-bottom__container {
    padding: 20px 0 25px;
    position: sticky;
    top: 0
}

.header-bottom {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.header-bottom__nav {
    display: flex;
    align-items: center;
    gap: 25px
}

.header-bottom__nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 18px;
    line-height: 100%;
    color: #606060
}

.header-bottom__nav-link img {
    margin-top: 3px
}

.header-bottom__social-container {
    display: flex;
    align-items: center;
    gap: 30px
}

.header-bottom__social-link {
    width: 40px;
    height: 40px
}

.header-bottom__social-link img {
    object-fit: cover;
    width: 100%;
    height: 100%
}

.header-bottom__tel-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px
}

.header-bottom__tel-link {
    font-family: Montserrat, sans-serif;
    font-weight: 500;
    font-size: 18px;
    line-height: 100%;
    color: #606060
}

.header-bottom__tel-btn {
    border: none;
    background-color: transparent;
    color: var(--primary);
    text-decoration: underline;
    font-weight: 600;
    font-size: 16px;
    line-height: 100%;
    text-align: center
}

footer {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 100px;
    padding: 70px 0 25px;
    background-color: #fff;
    border-top-left-radius: 90px;
    border-top-right-radius: 90px;
    box-shadow: 0 -2px 10px #00000026
}

.footer__form-title {
    font-family: Bounded, sans-serif;
    font-weight: 400;
    font-size: 45px;
    line-height: 100%;
    text-align: center;
    color: var(--primary);
    margin-bottom: 15px
}

.footer__form-text {
    font-weight: 500;
    font-size: 24px;
    line-height: 100%;
    text-align: center;
    color: var(--primary);
    margin-bottom: 40px
}

.footer__form {
    display: flex;
    gap: 30px
}

.footer__form-input, .footer__form-btn {
    width: 320px;
    height: 65px;
    border-radius: 30px;
    background-color: #fff;
    border: 1px solid #D8D8D8;
    text-align: center;
    font-weight: 600;
    font-size: 18px;
    line-height: 100%;
    color: #606060;
    outline: none
}

.footer__form-btn-container {
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center
}

.footer__form-btn {
    background-color: var(--primary);
    border: none;
    color: #fff
}

.footer__content {
    width: 1440px;
    margin: 0 auto 40px;
    display: flex;
    justify-content: space-between
}

.footer__logo {
    width: 230px;
    height: fit-content;
    flex-shrink: 0
}

.footer__content-container {
    display: flex;
    gap: 70px
}

.footer__contacts-title {
    font-weight: 600;
    font-size: 24px;
    line-height: 100%;
    color: #606060;
    margin-bottom: 25px
}

.footer__contacts {
    display: flex;
    flex-direction: column;
    gap: 15px
}

.footer__contacts-item {
    font-weight: 600;
    font-size: 16px;
    line-height: 100%;
    color: #606060
}

.footer__contacts-item a, .footer__contacts-item span {
    font-weight: 400;
    font-size: 16px;
    line-height: 100%;
    color: #606060
}

.footer__social {
    display: flex;
    gap: 30px
}

.footer__social-link {
    width: 50px;
    height: 50px
}

.footer__social-link img {
    width: 100%;
    height: 100%
}

.footer__privacy-container {
    width: 1440px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between
}

.footer__privacy-link {
    font-weight: 500;
    font-size: 16px;
    line-height: 100%;
    text-decoration: underline;
    color: var(--primary)
}

.footer__logo--mob {
    display: none
}

@media (max-width: 768px) {
    footer {
        border-top-left-radius: 60px;
        border-top-right-radius: 60px;
        padding: 25px 0 35px;
        gap: 50px
    }

    .footer__logo--mob {
        display: block;
        margin-bottom: 35px
    }

    .footer__form-container {
        display: flex;
        flex-direction: column;
        align-items: center
    }

    .footer__form-title {
        font-size: 28px;
        font-weight: 700;
        margin-bottom: 5px
    }

    .footer__form-text {
        font-size: 18px
    }

    .footer__form {
        flex-direction: column;
        align-items: center;
        gap: 20px
    }

    .footer__form-input, .footer__form-btn {
        width: 300px;
        height: 50px
    }

    .footer__content {
        flex-direction: column-reverse;
        align-items: center;
        gap: 50px;
        width: 100%;
        margin-bottom: 0
    }

    .footer__logo {
        display: none
    }

    .footer__content-container {
        flex-direction: column;
        gap: 40px
    }

    .footer__contacts-container h3, .footer__contacts-container p {
        text-align: center
    }

    .footer__contacts-title {
        margin-bottom: 10px
    }

    .footer__contacts {
        gap: 10px
    }

    .footer__privacy-container {
        width: 100%;
        flex-direction: column
    }

    .footer__privacy-container {
        gap: 15px
    }

    .footer__privacy-container a {
        text-align: center
    }
}

@media (min-width: 1200px) and (max-width: 1450px) {
    .footer__content, .footer__privacy-container {
        width: 95%;
    }
    .footer__content-container {
        gap: 25px;
    }
    .footer__social {
        gap: 15px;
    }
}

.hero {
    width: 1440px;
    margin: 50px auto 170px;
    padding: 15px 15px 15px 80px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: 40px;
    box-shadow: 0 2px 10px #00000026;
    background-color: #fff
}

.hero__title {
    font-weight: 700;
    font-size: 42px;
    line-height: 100%;
    margin-bottom: 45px
}

.hero__subtitle {
    font-weight: 400;
    font-size: 25px;
    line-height: 100%;
    margin-bottom: 110px
}

.hero__btn-container {
    display: flex;
    gap: 25px
}

.hero__btn {
    height: 65px;
    width: 220px
}

.hero__btn.btn-red {
    width: 320px
}

.about-nums {
    margin-bottom: 130px
}

.about-nums__item-container {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between
}

.about-nums__item {
    width: 350px;
    height: 290px;
    padding: 30px;
    background-color: #fff;
    box-shadow: 0 4px 10px #00000026;
    border-radius: 40px;
    display: flex;
    flex-direction: column;
    gap: 15px;
    justify-content: flex-end;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    transition: background .3s ease;
}
.about-nums__item:nth-child(1) {
    background-image: url("../images/nums1.png");
}
.about-nums__item:nth-child(2) {
    background-image: url("../images/nums2.png");
}
.about-nums__item:nth-child(3) {
    background-image: url("../images/nums3.png");
}
.about-nums__item:nth-child(4) {
    background-image: url("../images/nums4.png");
}
.about-nums__item:nth-child(1):hover {
    background-image: url("../images/nums1-red.png");
}
.about-nums__item:nth-child(2):hover {
    background-image: url("../images/nums2-red.png");
}
.about-nums__item:nth-child(3):hover {
    background-image: url("../images/nums3-red.png");
}
.about-nums__item:nth-child(4):hover {
    background-image: url("../images/nums4-red.png");
}
.about-nums__item:hover .about-nums__item-num, .about-nums__item:hover .about-nums__item-text {
    color: #fff !important;
}
.about-nums__item:first-child {
    align-items: flex-end
}

.about-nums__item:nth-child(odd) {
    margin-top: 40px
}

.about-nums__item:first-child .about-nums__item-num {
    width: 153px
}

.about-nums__item-num {
    font-weight: 700;
    font-size: 50px;
    line-height: 100%
}

.about-nums__item-num span {
    font-weight: 500;
    font-size: 25px
}

.about-nums__item-text {
    font-weight: 400;
    font-size: 25px;
    line-height: 100%
}

.why-us {
    padding: 70px 0;
    background-image: url(../bg-why-us.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    margin-bottom: 170px
}

.why-us__title {
    font-weight: 700;
    font-size: 50px;
    line-height: 100%;
    text-align: center;
    margin-bottom: 60px
}

.why-us__item-container {
    max-width: 1440px;
    margin: 0 auto;
    display: grid;
    grid-template-columns:repeat(3, 1fr);
    row-gap: 30px;
    column-gap: 45px
}

.why-us--hidden {
    display: contents
}

.why-us__item {
    width: 450px;
    height: 260px;
    background-color: #fff;
    border: 1px solid var(--primary);
    box-shadow: 0 1px 10px #00000026;
    border-radius: 25px;
    padding: 25px 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between
}

.why-us__item-arrow {
    display: none
}

.why-us__item-title {
    font-weight: 700;
    font-size: 20px;
    line-height: 100%;
    text-align: center;
    margin-bottom: 5px;
    height: 25px
}

.why-us__item-subtitle {
    font-weight: 500;
    font-size: 18px;
    line-height: 100%;
    text-align: center
}

.why-us__show-btn, .hits__show-btn {
    display: none
}

.partners {
    margin-bottom: 80px;
    overflow: hidden
}

.partners__wrapper {
    background-color: var(--primary);
    height: 150px;
    overflow: hidden;
    display: flex;
    align-items: center
}

.partners__container {
    display: flex;
    align-items: center;
    gap: 35px;
    animation: scroll 60s linear infinite
}

.partners__container span {
    width: 10px;
    height: 10px;
    background-color: #fff;
    border-radius: 50%;
    flex-shrink: 0
}

.partners__text {
    font-weight: 400;
    font-size: 30px;
    line-height: 100%;
    color: #fff;
    flex-shrink: 0
}

@keyframes scroll {
    0% {
        transform: translate(0)
    }
    to {
        transform: translate(-100%)
    }
}

.catalog {
    max-width: 1440px;
    margin: 0 auto 180px
}

.catalog__title {
    width: fit-content
}

.catalog__swiper-container, .services__swiper-container, .awards__swiper-container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 35px;
    margin-bottom: 45px
}

.catalog__swiper-btn, .services__swiper-btn, .awards__swiper-btn, .reviews__swiper-btn, .news__swiper-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 20px;
    outline: none;
    background-color: var(--primary);
    width: 50px;
    height: 50px;
    flex-shrink: 0
}

.swiper {
    padding: 10px !important
}

.catalog__slide {
    height: 400px !important;
    max-width: 300px !important;
    padding: 15px 20px 20px;
    background-color: #fff;
    border-radius: 20px;
    box-shadow: 0 2px 10px #00000026;
    display: flex !important;
    flex-direction: column;
    justify-content: space-between
}

.catalog__slide-title {
    font-weight: 600;
    font-size: 20px;
    line-height: 100%;
    color: #381f1f;
    margin-bottom: 10px
}

.catalog__slide-text {
    font-weight: 400;
    font-size: 18px;
    line-height: 100%;
    color: #606060;
    margin-bottom: 15px
}

.catalog__slide-link {
    width: 100%;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 400;
    box-shadow: 0 2px 5px #0000001a
}

.catalog__slide-img {
    width: 100%;
    height: 190px;
    display: flex;
    justify-content: center;
    align-items: center
}

.catalog__slide-img img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.catalog__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    width: 620px;
    height: 50px;
    font-weight: 600;
    color: #fff !important
}

.hits {
    margin: 0 auto 170px
}

.hits__item-container, .hits__item--hidden {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    row-gap: 25px;
    column-gap: 20px;
    max-width: 1440px;
    margin: 0 auto
}

.hits__item--hidden {
    display: contents;
}

.hits__item {
    width: 465px;
    height: 200px;
    box-shadow: 0 2px 10px #00000026;
    display: flex;
    justify-content: space-between;
    padding: 30px 20px;
    border-radius: 20px
}

.hits__item-img {
    width: 190px;
    height: 140px;
    border: 1px solid var(--primary);
    border-radius: 20px;
    flex-shrink: 0
}

.hits__item-img img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.hits__item-info {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 215px
}

.hits__item-title {
    font-weight: 600;
    font-size: 20px;
    line-height: 100%;
    margin-bottom: 5px
}

.hits__item-desc {
    font-weight: 400;
    font-size: 14px;
    line-height: 100%
}

.hits__item-btn {
    width: 100%;
    height: 35px;
    font-size: 16px;
    line-height: 100%;
    box-shadow: 0 2px 5px #0000001a
}

.brands, .trust-us {
    max-width: 1440px;
    margin: 0 auto 170px
}

.brands__title, .trust-us__title {
    margin-bottom: 60px
}

.brands__container, .trust-us__container {
    display: flex;
    flex-direction: column;
    gap: 60px
}

.brands__row, .trust-us__row {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 45px
}

.brands__row img, .trust-us__row img {
    height: 100%;
    filter: grayscale(100%) drop-shadow(0 0 0 transparent);
    transition: filter .3s ease;
    cursor: pointer
}

.brands__row img:hover, .trust-us__row img:hover {
    filter: none
}

.services {
    max-width: 1440px;
    margin: 0 auto 170px
}

.services__swiper-container {
    gap: 45px
}

.services__slide {
    height: 400px !important;
    padding: 20px;
    background-color: #fff;
    box-shadow: 0 4px 10px #00000026;
    border-radius: 20px;
    display: flex !important;
    flex-direction: column;
    justify-content: space-between
}

.services__slide-img {
    width: 100%;
    height: 230px;
    border-radius: 20px
}

.services__slide-img img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.services__slide-title {
    font-weight: 700;
    font-size: 25px;
    line-height: 100%;
    color: var(--primary);
    margin-bottom: 20px
}

.services__slide-link {
    width: 235px;
    height: 35px;
    border-radius: 20px;
    box-shadow: 0 2px 5px #0000001a;
    font-weight: 500;
    font-size: 16px;
    line-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.portfolio {
    max-width: 1440px;
    margin: 0 auto 170px;
    display: flex;
    gap: 25px
}

.portfolio__left {
    display: flex;
    flex-direction: column;
    gap: 25px;
    width: 585px
}

.portfolio__left-main {
    padding: 30px;
    background-color: var(--primary);
    background-image: url(../bg-service.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 20px;
    height: 395px
}

.portfolio__title {
    font-weight: 700;
    font-size: 50px;
    line-height: 100%;
    color: #fff;
    margin-bottom: 25px
}

.portfolio__btn {
    width: 235px;
    height: 55px;
    border-radius: 55px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fff;
    color: var(--primary);
    font-weight: 700;
    font-size: 16px;
    line-height: 100%
}

.portfolio__left-item {
    width: 100%;
    height: 235px
}

.portfolio__item {
    border-radius: 20px;
    overflow: hidden
}

.portfolio__item-img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.portfolio__right {
    width: 830px;
    display: flex;
    flex-direction: column;
    gap: 25px
}

.portfolio__right-top {
    display: flex;
    gap: 25px
}

.portfolio__right-top .portfolio__item {
    height: 245px
}

.portfolio__right-item {
    height: 385px
}

.feedback {
    max-width: 1440px;
    margin: 0 auto 170px;
    padding: 25px 115px 25px 25px;
    box-shadow: 0 4px 10px #00000026;
    border-radius: 40px;
    background-color: #fff;
    display: flex;
    justify-content: space-between
}

.feedback__form-container {
    margin: 20px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between
}

.feedback__title {
    font-weight: 700;
    font-size: 50px;
    line-height: 100%;
    margin-bottom: 5px;
    text-align: center
}

.feedback__subtitle {
    font-weight: 500;
    font-size: 24px;
    line-height: 100%;
    text-align: center
}

.feedback__form {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    width: 400px
}

.feedback__form-input {
    width: 100%;
    height: 65px;
    border: 1px solid #D8D8D8;
    border-radius: 30px;
    background-color: #fff;
    font-weight: 400;
    font-size: 18px;
    line-height: 100%;
    text-align: center
}

.feedback__form-btn {
    height: 65px;
    width: 100%;
    margin-bottom: -10px
}

.awards {
    max-width: 1440px;
    margin: 0 auto 170px
}

.awards__item-container {
    display: flex;
    gap: 35px;
    margin-bottom: 60px
}

.awards__item {
    box-shadow: 0 5px 10px #00000040;
    border-radius: 5px
}

.awards__item img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.awards__item--main {
    height: 975px;
    width: 670px
}

.awards__item-container--right {
    display: flex;
    flex-direction: column;
    gap: 35px
}

.awards__item-container--right-top {
    display: flex;
    gap: 35px
}

.awards__item--small {
    height: 490px;
    width: 350px
}

.awards__item--horiz {
    height: 450px;
    width: 735px
}

.awards__swiper-container {
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease
}

.awards__swiper-container.active {
    max-height: 500px
}

.awards__btn {
    width: 620px;
    height: 50px;
    display: block;
    margin: 0 auto
}

.awards__slide {
    height: 310px !important;
    background-color: #fff;
    box-shadow: 0 2px 10px #00000026;
    border-radius: 20px;
    padding: 20px;
    display: flex !important;
    gap: 10px
}

.awards__slide-img {
    width: 190px;
    height: 270px
}

.awards__slide-img img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.awards__text {
    font-weight: 700
}

.reviews {
    max-width: 1440px;
    margin: 0 auto 170px
}

.reviews__top {
    display: flex;
    justify-content: space-between;
    margin-bottom: 65px
}

.reviews__title {
    text-align: left;
    margin-bottom: 0
}

.reviews__tab-container {
    display: flex;
    gap: 20px
}

.reviews__tab {
    height: 45px;
    background-color: transparent;
    border: none;
    outline: none;
    cursor: pointer;
    font-weight: 400;
    font-size: 20px;
    line-height: 100%;
    color: #929292;
    transition: all .3s ease
}

.reviews__tab.active {
    box-shadow: 0 2px 5px #0000001a;
    background-color: #fff;
    border-radius: 15px;
    color: var(--primary);
    font-weight: 700;
    padding: 0 15px
}

.reviews__slider-btn-container, .news__slider-btn-container {
    display: flex;
    justify-content: flex-end;
    gap: 15px;
    margin-bottom: 20px
}

.reviews__slide {
    height: 315px !important;
    display: flex !important;
    flex-direction: column;
    justify-content: space-between;
    gap: 25px;
    padding: 20px 80px 20px 20px;
    border-radius: 20px;
    background-color: #fff;
    box-shadow: 0 2px 10px #00000026;
    max-width: 700px !important;
    position: relative;
}

.reviews__slide-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 500px;
    height: 50px;
    margin: 50px auto 0;
}

.reviews__slide-img-container {
    display: flex;
    gap: 15px;
    flex-wrap: wrap
}

.reviews__slide-img {
    width: 140px;
    height: 90px;
    border-radius: 10px;
    overflow: hidden
}

.reviews__slide-img img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.reviews__slide-content {
    width: 610px
}

.reviews__slide-top {
    display: flex;
    align-items: center;
    gap: 25px;
    margin-bottom: 15px
}

.reviews__slide-content p {
    color: #000;
    line-height: 100%;
    font-size: 14px
}

.reviews__slide-name {
    font-size: 20px !important
}

.reviews__slide-stars {
    display: flex;
    gap: 5px
}

.reviews__slide-text {
    margin-bottom: 15px
}

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

.news {
    max-width: 1440px;
    margin: 0 auto 170px;
    background-color: #fff;
    border-radius: 30px;
    box-shadow: 0 2px 10px #00000026;
    padding: 45px 40px
}

.news__top {
    margin-left: 15px;
    display: flex;
    justify-content: space-between;
    margin-bottom: 60px
}

.news__title {
    font-weight: 700;
    font-size: 55px;
    line-height: 100%
}

.news__btn-container {
    display: flex;
    gap: 25px
}

.news__btn {
    width: 220px;
    height: 50px;
    box-shadow: 0 2px 5px #00000026;
    border-radius: 20px;
    border: none;
    background-color: #fff;
    font-weight: 400;
    font-size: 18px;
    line-height: 100%;
    color: var(--text);
    transition: all .3s ease
}

.news__btn.active {
    background-color: var(--primary);
    color: #fff
}

.news__slide-img {
    width: 320px;
    height: 275px;
    border-radius: 20px;
    overflow: hidden;
    margin-bottom: 10px
}

.news__slide-img img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.news__slide-info {
    display: flex;
    justify-content: space-between
}

.news__slide-info p {
    color: #000;
    line-height: 100%
}

.news__slide-text {
    max-width: 190px
}

.news__slide-date {
    font-size: 14px
}

.news__slide {
    max-width: 320px !important;
}

.news__swiper-btn.swiper-button-disabled {
    background-color: #fac1be !important
}

.news__pagination {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 30px;
    position: static !important
}

.news__pagination .swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    background-color: #eee;
    opacity: 1;
    border-radius: 50%;
    cursor: pointer;
    transition: all .3s ease
}

.news__pagination .swiper-pagination-bullet-active {
    background-color: var(--primary)
}

@media (max-width: 768px) {
    section {
        margin-bottom: 80px !important
    }

    .hero {
        width: 95%;
        flex-direction: column-reverse;
        padding: 10px 10px 20px;
        margin-bottom: 80px
    }

    .hero img {
        width: 100%;
        border-radius: 30px;
        object-fit: cover;
        margin-bottom: 25px
    }

    .hero__title {
        font-size: 24px;
        text-align: center;
        margin-bottom: 15px
    }

    .hero__subtitle {
        display: none
    }

    .hero__btn-container {
        flex-direction: column;
        align-items: center;
        gap: 15px
    }

    .hero__btn {
        height: 45px;
        width: 250px
    }

    .hero__btn.btn-red {
        width: 280px;
        height: 50px
    }

    .about-nums__item-container {
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 10px
    }

    .about-nums__item {
        background: #fff !important;
    }

    .about-nums__item:nth-child(odd) {
        margin-top: 0
    }

    .about-nums__item {
        width: 170px;
        height: 115px;
        border-radius: 20px;
        padding: 15px;
        gap: 0;
        justify-content: center;
        align-items: center !important
    }

    .about-nums__item-num {
        font-size: 30px;
        width: fit-content !important;
        text-align: center
    }

    .about-nums__item-text {
        text-align: center;
        font-size: 16px
    }

    .about-nums__item-num span {
        font-size: 12px
    }

    .why-us {
        padding: 30px 25px;
        margin-bottom: 0
    }

    .why-us__title {
        font-size: 25px;
        margin-bottom: 30px
    }

    .why-us__item-container, .why-us--hidden.active {
        display: flex;
        flex-direction: column;
        gap: 10px
    }

    .why-us--hidden {
        display: none
    }

    .why-us__item {
        width: 100%;
        height: fit-content;
        padding: 20px 30px 20px 20px;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: flex-start;
        position: relative;
        overflow: hidden
    }

    .why-us__item-arrow {
        display: block;
        position: absolute;
        top: 38px;
        right: 30px;
        transition: transform .3s ease
    }

    .why-us__item-title {
        font-size: 18px;
        max-width: 190px;
        text-align: left;
        height: fit-content;
        margin-bottom: 0;
        margin-left: 15px
    }

    .why-us__item-text {
        display: contents
    }

    .why-us__item-icon {
        width: 60px
    }

    .why-us__item-subtitle {
        font-size: 16px;
        text-align: left;
        white-space: normal;
        max-height: 0;
        transition: max-height .3s ease, margin-top .3s ease;
        overflow: hidden;
        margin-top: 0
    }

    .why-us__item.active .why-us__item-subtitle {
        max-height: 400px;
        margin-top: 15px
    }

    .why-us__item.active .why-us__item-arrow {
        transform: rotate(180deg)
    }

    .why-us__show-btn, .hits__show-btn {
        margin: 15px auto 0;
        border: none;
        background-color: transparent;
        display: flex;
        gap: 10px;
        align-items: center;
        font-weight: 700;
        font-size: 25px;
        line-height: 100%;
        text-align: center
    }

    .why-us__show-btn img, .hits__show-btn img {
        width: 12px;
        margin-top: 5px;
        transition: transform .3s ease
    }

    .partners__wrapper {
        height: 90px
    }

    .partners__container {
        gap: 25px
    }

    .partners__container span {
        width: 12px;
        height: 12px
    }

    .partners__title {
        font-size: 23px;
    }

    .partners__text {
        font-size: 20px
    }

    .catalog {
        padding: 0 20px
    }

    .catalog__btn {
        width: 100%;
        font-size: 16px
    }

    .catalog__swiper-container, .services__swiper-container, .awards__swiper-container {
        flex-wrap: wrap;
        column-gap: 20px;
        row-gap: 30px;
        margin-bottom: 30px
    }

    .catalog__swiper-btn--prev, .services__swiper-btn--prev, .awards__swiper-btn--prev {
        order: 2
    }

    .catalog__swiper-btn--next, .services__swiper-btn--next, .awards__swiper-btn--next {
        order: 3
    }

    .catalog__slide {
        max-width: none !important
    }

    .hits__item--hidden {
        display: none;
    }

    .hits__item-container, .hits__item--hidden.active {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 0 25px
    }

    .hits__item--hidden {
        padding: 0 !important;
    }

    .hits__item {
        width: 48%;
        height: 270px;
        flex-direction: column;
        align-items: center;
        padding: 10px
    }

    .hits__item-img {
        width: 100%;
        height: 110px
    }

    .hits__item-info {
        width: 100%
    }

    .hits__item-title {
        font-size: 16px;
        text-align: center
    }

    .hits__item-desc {
        text-align: center;
        margin-bottom: 10px
    }

    .hits__item-btn {
        height: 40px;
        border-radius: 15px;
        font-size: 14px
    }

    .hits__show-btn {
        margin-top: 30px;
    }

    .brands__row, .trust-us__row {
        display: contents
    }

    .brands__title, .trust-us__title {
        margin-bottom: 30px
    }

    .brands__container, .trust-us__container {
        flex-direction: row;
        gap: 30px;
        height: 45px;
        align-items: center;
        animation: scroll 60s linear infinite
    }

    .brands__wrapper, .trust-us__wrapper {
        overflow: hidden;
        display: flex;
        align-items: center
    }

    .partners__container {
        display: flex;
        align-items: center;
        gap: 35px;
        animation: scroll 60s linear infinite
    }

    .services__swiper-container {
        padding: 0 20px
    }

    .portfolio {
        flex-direction: column;
        gap: 10px;
        padding: 0 10px
    }

    .portfolio__left {
        width: 100%
    }

    .portfolio__left-item {
        display: none
    }

    .portfolio__left-main {
        height: fit-content;
        padding: 20px 25px
    }

    .portfolio__title {
        font-size: 28px;
        text-align: center;
        white-space: normal
    }

    .portfolio__btn {
        margin: 0 auto
    }

    .portfolio__right {
        width: 100%;
        gap: 10px
    }

    .portfolio__right-top {
        gap: 10px
    }

    .portfolio__right-top .portfolio__item {
        height: 120px
    }

    .portfolio__right-item {
        height: 155px
    }

    .feedback {
        flex-direction: column-reverse;
        width: 100%;
        padding: 40px 20px
    }

    .feedback__form-container {
        margin: 0 0 35px
    }

    .feedback__title {
        font-size: 28px
    }

    .feedback__subtitle {
        font-size: 18px
    }

    .feedback__form-text {
        margin-bottom: 30px
    }

    .feedback__form {
        width: 300px
    }

    .feedback__form-input {
        height: 50px
    }

    .awards__item-container {
        display: none
    }

    .awards__swiper-container {
        max-height: fit-content
    }

    .awards__btn {
        display: none
    }

    .awards__slide {
        height: 220px !important
    }

    .awards__slide-img {
        width: 130px;
        height: 180px
    }

    .reviews {
        padding: 0 10px
    }

    .reviews__top {
        flex-direction: column;
        align-items: center;
        gap: 25px;
        margin-bottom: 30px
    }

    .reviews__tab-container {
        justify-content: flex-start;
        align-items: flex-start;
        overflow-x: auto;
        flex-wrap: nowrap;
        max-width: 100%;
        scrollbar-width: none;
        -ms-overflow-style: none;
        padding: 5px
    }

    .reviews__tab {
        width: fit-content;
        flex-shrink: 0
    }

    .reviews__slider-container {
        display: flex;
        flex-direction: column-reverse
    }

    .reviews__slider-btn-container, .news__slider-btn-container {
        justify-content: center;
        margin-top: 15px
    }

    .reviews__swiper {
        width: 100% !important
    }

    .reviews__slide {
        height: fit-content !important;
        padding: 20px 10px 20px 20px
    }

    .reviews__slide-btn {
        width: 100%;
        margin-top: 30px;
    }

    .reviews__slide-top {
        gap: 15px;
    }

    .reviews__slide-top p {
        max-width: 240px;
    }

    .reviews__slide-content {
        width: 100%
    }

    .news {
        padding: 30px 20px
    }

    .news__top {
        flex-direction: column;
        align-items: center;
        gap: 30px;
        margin-left: 0;
        margin-bottom: 40px
    }

    .news__title {
        font-size: 25px
    }

    .news__btn-container {
        gap: 20px
    }

    .news__btn {
        width: 170px
    }

    .news__slider-container {
        display: flex;
        flex-direction: column-reverse
    }

    .news__swiper {
        width: 100% !important
    }

    .news__slide-img {
        width: 100%;
        height: auto;
        max-height: 300px;
    }
}

@media (min-width: 1200px) and (max-width: 1450px) {
    .hero {
        width: 95%;
        padding-left: 25px;

    }
    .hero img {
        width: 48%;
        height: auto;
    }
    .hero__title {
        font-size: 38px;
    }
    .hero__btn.btn-red {
        width: 300px;
    }
    .the-line {
        width: 325px;
    }
    .about-nums__item-container {
        justify-content: center;
        gap: 15px;
    }
    .about-nums__item {
        width: 280px;
    }
    .about-nums__item-num {
        font-size: 47px;
    }
    .why-us__item-container {
        column-gap: 20px;
        justify-items: center;
    }
    .why-us__item {
        width: 365px;
        height: 225px;
    }
    .why-us__item-icon {
        width: 70px;
        height: 70px;
    }
    .why-us__item-subtitle {
        font-size: 16px;
    }
    .partners__title {
        font-size: 46px;
    }
    .catalog__slide {
        max-width: none !important;
    }
    .catalog__swiper-container, .services__swiper-container, .awards__swiper-container {
        max-width: 95%;
        margin: 0 auto 45px;
    }
    .hits__item-container, .hits__item--hidden {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }
    .brands__wrapper, .trust-us__wrapper {
        max-width: 95%;
        margin: 0 auto;
    }
    .portfolio__left {
        width: 500px;
        gap: 15px;
    }
    .portfolio__right {
        width: 675px;
        gap: 15px;
    }
    .portfolio {
        justify-content: center;
        gap: 15px;
    }
    .portfolio__right-top {
        gap: 15px;
    }
    .feedback {
        width: 95%;
        padding: 25px;
    }
    .feedback img {
        width: 60%;
        border-radius: 15px;
    }
    .feedback__title {
        font-size: 40px;
    }
    .awards__item-container, .awards__item-container--right, .awards__item-container--right-top {
        gap: 15px;
    }
    .awards__item--small {
        height: 445px;
        width: 300px;
    }
    .awards__item--horiz {
        width: 615px;
        height: 410px;
    }
    .awards__item--main {
        height: 870px;
        width: 560px;
    }
    .awards__item-container {
        justify-content: center;
    }
    .awards__swiper-container {
        margin: 0;
    }
    .awards__swiper-container.active {
        margin: 30px auto;
    }
    .reviews {
        width: 95%;
    }
    .reviews__slide {
        padding: 20px;
    }
    .reviews__slide-content {
        width: 100%;
    }
    .reviews__slide-content p {
        white-space: normal;
    }
    .reviews__slide {
        height: 345px !important;
    }
    .news {
        width: 95%;
    }
    .news__title {
        font-size: 48px;
    }
}

@media (min-width: 1451px) and (max-width: 1600px) {
    .the-line {
        width: 400px;
    }
}

@font-face {
    font-family: swiper-icons;
    src: url(data:application/font-woff;charset=utf-8;base64,\ d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA);
    font-weight: 400;
    font-style: normal
}

:root {
    --swiper-theme-color: #007aff
}

:host {
    position: relative;
    display: block;
    margin-left: auto;
    margin-right: auto;
    z-index: 1
}

.swiper {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
    display: block
}

.swiper-vertical > .swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    box-sizing: content-box
}

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
    transform: translateZ(0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
    display: block
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}

.swiper-backface-hidden .swiper-slide {
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide {
    transform-style: preserve-3d
}

.swiper-css-mode > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
    display: none
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: start start
}

.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
    scroll-snap-type: none
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: none
}

.swiper-css-mode.swiper-centered > .swiper-wrapper:before {
    content: "";
    flex-shrink: 0;
    order: 9999
}

.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: center center;
    scroll-snap-stop: always
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
    margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper:before {
    height: 100%;
    min-height: 1px;
    width: var(--swiper-centered-offset-after)
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
    margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper:before {
    width: 100%;
    min-width: 1px;
    height: var(--swiper-centered-offset-after)
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: #00000026
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, #00000080, #0000)
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, #00000080, #0000)
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, #00000080, #0000)
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, #00000080, #0000)
}

.swiper-lazy-preloader {
    width: 42px;
    height: 42px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -21px;
    margin-top: -21px;
    z-index: 10;
    transform-origin: 50%;
    box-sizing: border-box;
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top-color: transparent
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(360deg)
    }
}

.swiper-virtual .swiper-slide {
    -webkit-backface-visibility: hidden;
    transform: translateZ(0)
}

.swiper-virtual.swiper-css-mode .swiper-wrapper:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper:after {
    height: 1px;
    width: var(--swiper-virtual-size)
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper:after {
    width: 1px;
    height: var(--swiper-virtual-size)
}

:root {
    --swiper-navigation-size: 44px
}

.swiper-button-next, .swiper-button-prev {
    position: absolute;
    top: var(--swiper-navigation-top-offset, 50%);
    width: calc(var(--swiper-navigation-size) / 44 * 27);
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--swiper-navigation-color, var(--swiper-theme-color))
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}

.swiper-button-next.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
    opacity: 0;
    cursor: auto;
    pointer-events: none
}

.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
    display: none !important
}

.swiper-button-next svg, .swiper-button-prev svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transform-origin: center
}

.swiper-rtl .swiper-button-next svg, .swiper-rtl .swiper-button-prev svg {
    transform: rotate(180deg)
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset, 10px);
    right: auto
}

.swiper-button-lock {
    display: none
}

.swiper-button-next:after, .swiper-button-prev:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none !important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
    content: "prev"
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 10px);
    left: auto
}

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    content: "next"
}

.swiper-pagination {
    position: absolute;
    text-align: center;
    transition: .3s opacity;
    transform: translateZ(0);
    z-index: 10
}

.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}

.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
    display: none !important
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: var(--swiper-pagination-bottom, 8px);
    top: var(--swiper-pagination-top, auto);
    left: 0;
    width: 100%
}

.swiper-pagination-bullets-dynamic {
    overflow: hidden;
    font-size: 0
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transform: scale(.33);
    position: relative
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active, .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
    transform: scale(.33)
}

.swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    display: inline-block;
    border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
    background: var(--swiper-pagination-bullet-inactive-color, #000);
    opacity: var(--swiper-pagination-bullet-inactive-opacity, .2)
}

button.swiper-pagination-bullet {
    border: none;
    margin: 0;
    padding: 0;
    box-shadow: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}

.swiper-pagination-bullet:only-child {
    display: none !important
}

.swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: var(--swiper-pagination-color, var(--swiper-theme-color))
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
    right: var(--swiper-pagination-right, 8px);
    left: var(--swiper-pagination-left, auto);
    top: 50%;
    transform: translate3d(0, -50%, 0)
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
    display: block
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: .2s transform, .2s top
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px)
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translate(-50%);
    white-space: nowrap
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform, .2s left
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform, .2s right
}

.swiper-pagination-fraction {
    color: var(--swiper-pagination-fraction-color, inherit)
}

.swiper-pagination-progressbar {
    background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));
    position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transform-origin: left top
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    width: 100%;
    height: var(--swiper-pagination-progressbar-size, 4px);
    left: 0;
    top: 0
}

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
    width: var(--swiper-pagination-progressbar-size, 4px);
    height: 100%;
    left: 0;
    top: 0
}

.swiper-pagination-lock {
    display: none
}

.swiper-scrollbar {
    border-radius: var(--swiper-scrollbar-border-radius, 10px);
    position: relative;
    touch-action: none;
    background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, .1))
}

.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
    display: none !important
}

.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
    position: absolute;
    left: var(--swiper-scrollbar-sides-offset, 1%);
    bottom: var(--swiper-scrollbar-bottom, 4px);
    top: var(--swiper-scrollbar-top, auto);
    z-index: 50;
    height: var(--swiper-scrollbar-size, 4px);
    width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%))
}

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
    position: absolute;
    left: var(--swiper-scrollbar-left, auto);
    right: var(--swiper-scrollbar-right, 4px);
    top: var(--swiper-scrollbar-sides-offset, 1%);
    z-index: 50;
    width: var(--swiper-scrollbar-size, 4px);
    height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%))
}

.swiper-scrollbar-drag {
    height: 100%;
    width: 100%;
    position: relative;
    background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, .5));
    border-radius: var(--swiper-scrollbar-border-radius, 10px);
    left: 0;
    top: 0
}

.swiper-scrollbar-cursor-drag {
    cursor: move
}

.swiper-scrollbar-lock {
    display: none
}

.swiper-zoom-container {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center
}

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain
}

.swiper-slide-zoomed {
    cursor: move;
    touch-action: none
}

.swiper .swiper-notification {
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none;
    opacity: 0;
    z-index: -1000
}

.swiper-free-mode > .swiper-wrapper {
    transition-timing-function: ease-out;
    margin: 0 auto
}

.swiper-grid > .swiper-wrapper {
    flex-wrap: wrap
}

.swiper-grid-column > .swiper-wrapper {
    flex-wrap: wrap;
    flex-direction: column
}

.swiper-fade.swiper-free-mode .swiper-slide {
    transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}

.swiper-fade .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper.swiper-cube {
    overflow: visible
}

.swiper-cube .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1;
    visibility: hidden;
    transform-origin: 0 0;
    width: 100%;
    height: 100%
}

.swiper-cube .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-cube.swiper-rtl .swiper-slide {
    transform-origin: 100% 0
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-prev {
    pointer-events: auto;
    visibility: visible
}

.swiper-cube .swiper-cube-shadow {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: .6;
    z-index: 0
}

.swiper-cube .swiper-cube-shadow:before {
    content: "";
    background: #000;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    filter: blur(50px)
}

.swiper-cube .swiper-slide-next + .swiper-slide {
    pointer-events: auto;
    visibility: visible
}

.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper.swiper-flip {
    overflow: visible
}

.swiper-flip .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1
}

.swiper-flip .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-creative .swiper-slide {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden;
    transition-property: transform, opacity, height
}

.swiper.swiper-cards {
    overflow: visible
}

.swiper-cards .swiper-slide {
    transform-origin: center bottom;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden
}

:root {
    --f-button-width: 40px;
    --f-button-height: 40px;
    --f-button-border: 0;
    --f-button-border-radius: 0;
    --f-button-color: #374151;
    --f-button-bg: #f8f8f8;
    --f-button-shadow: none;
    --f-button-transition: all .15s ease;
    --f-button-transform: none;
    --f-button-outline-width: 1px;
    --f-button-outline-color: rgba(0, 0, 0, .7);
    --f-button-svg-width: 20px;
    --f-button-svg-height: 20px;
    --f-button-svg-stroke-width: 1.5;
    --f-button-svg-fill: none;
    --f-button-svg-filter: none;
    --f-button-svg-opacity: 1;
    --f-button-svg-disabled-opacity: .5;
    --f-button-svg-transition: opacity .15s ease;
    --f-button-svg-transform: none
}

.f-button {
    width: var(--f-button-width);
    height: var(--f-button-height);
    border: var(--f-button-border);
    border-radius: var(--f-button-border-radius);
    color: var(--f-button-color);
    background: var(--f-button-bg);
    box-shadow: var(--f-button-shadow);
    transform: var(--f-button-transform);
    transition: var(--f-button-transition);
    -webkit-backdrop-filter: var(--f-button-backdrop-filter);
    backdrop-filter: var(--f-button-backdrop-filter);
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: content-box;
    position: relative;
    margin: 0;
    padding: 0;
    pointer-events: all;
    cursor: pointer;
    overflow: hidden
}

@media (hover: hover) {
    .f-button:hover:not([aria-disabled]) {
        color: var(--f-button-hover-color, var(--f-button-color));
        background-color: var(--f-button-hover-bg, var(--f-button-bg))
    }
}

.f-button:active:not([aria-disabled]) {
    color: var(--f-button-active-color, var(--f-button-hover-color, var(--f-button-color)));
    background-color: var(--f-button-active-bg, var(--f-button-hover-bg, var(--f-button-bg)))
}

.f-button:focus {
    outline: none
}

.f-button:focus-visible {
    outline: var(--f-button-outline-width) solid var(--f-button-outline-color);
    outline-offset: var(--f-button-outline-offset)
}

.f-button svg {
    width: var(--f-button-svg-width);
    height: var(--f-button-svg-height);
    transform: var(--f-button-svg-transform);
    fill: var(--f-button-svg-fill);
    filter: var(--f-button-svg-filter);
    opacity: var(--f-button-svg-opacity, 1);
    transition: var(--f-button-svg-transition);
    stroke: currentColor;
    stroke-width: var(--f-button-svg-stroke-width);
    stroke-linecap: round;
    stroke-linejoin: round;
    pointer-events: none
}

.f-button[aria-disabled] {
    cursor: default
}

.f-button[aria-disabled] svg {
    opacity: var(--f-button-svg-disabled-opacity)
}

[data-panzoom-action=toggleFS] g:first-child {
    display: flex
}

[data-panzoom-action=toggleFS] g:last-child {
    display: none
}

.in-fullscreen [data-panzoom-action=toggleFS] g:first-child {
    display: none
}

.in-fullscreen [data-panzoom-action=toggleFS] g:last-child {
    display: flex
}

[data-autoplay-action=toggle] svg g:first-child {
    display: flex
}

[data-autoplay-action=toggle] svg g:last-child {
    display: none
}

.has-autoplay [data-autoplay-action=toggle] svg g:first-child {
    display: none
}

.has-autoplay [data-autoplay-action=toggle] svg g:last-child {
    display: flex
}

:fullscreen [data-fullscreen-action=toggle] svg [data-fullscreen-action=toggle] svg g:first-child {
    display: none
}

:fullscreen [data-fullscreen-action=toggle] svg [data-fullscreen-action=toggle] svg g:last-child {
    display: flex
}

:root {
    --f-spinner-color-1: rgba(0, 0, 0, .1);
    --f-spinner-color-2: rgba(17, 24, 28, .8);
    --f-spinner-width: 50px;
    --f-spinner-height: 50px;
    --f-spinner-border-radius: 50%;
    --f-spinner-border-width: 4px
}

.f-spinner {
    position: absolute;
    top: 50%;
    left: 50%;
    margin: 0;
    padding: 0;
    width: var(--f-spinner-width);
    height: var(--f-spinner-height);
    translate: -50% -50%;
    border: var(--f-spinner-border-width) solid var(--f-spinner-color-1);
    border-top-color: var(--f-spinner-color-2);
    border-radius: var(--f-spinner-border-radius);
    animation: f-spinner .75s linear infinite, f-fadeIn .2s ease .2s both
}

@keyframes f-spinner {
    to {
        rotate: 360deg
    }
}

.f-panzoom, .f-zoomable {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    flex-direction: column
}

.f-panzoom:before, .f-panzoom:after, .f-zoomable:before, .f-zoomable:after {
    display: block;
    content: ""
}

.f-panzoom:not(.has-controls):before, .f-zoomable:not(.has-controls):before {
    margin-bottom: auto
}

.f-panzoom:after, .f-zoomable:after {
    margin-top: auto
}

.f-panzoom.in-fullscreen, .f-zoomable.in-fullscreen {
    position: fixed;
    top: 0;
    left: 0;
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    aspect-ratio: unset !important;
    z-index: 9999
}

.f-panzoom__wrapper {
    position: relative;
    min-width: 0;
    min-height: 0;
    max-width: 100%;
    max-height: 100%
}

.f-panzoom__wrapper.will-zoom-out {
    cursor: zoom-out
}

.f-panzoom__wrapper.can-drag {
    cursor: move;
    cursor: grab
}

.f-panzoom__wrapper.will-zoom-in {
    cursor: zoom-in
}

.f-panzoom__wrapper.is-dragging {
    cursor: move;
    cursor: grabbing
}

.f-panzoom__wrapper.has-error {
    display: none
}

.f-panzoom__content {
    display: block;
    min-width: 0;
    min-height: 0;
    max-width: 100%;
    max-height: 100%
}

.f-panzoom__content.is-lazyloading, .f-panzoom__content.has-lazyerror {
    visibility: hidden
}

img.f-panzoom__content {
    width: auto;
    height: auto;
    vertical-align: top;
    object-fit: contain;
    transition: none;
    -webkit-user-select: none;
    user-select: none
}

.f-panzoom__wrapper > .f-panzoom__content {
    visibility: hidden
}

.f-panzoom__viewport {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10
}

.f-panzoom__viewport > .f-panzoom__content {
    width: 100%;
    height: 100%;
    object-fit: fill
}

picture.f-panzoom__content img {
    vertical-align: top;
    width: 100%;
    height: auto;
    max-height: 100%;
    object-fit: contain;
    transition: none;
    -webkit-user-select: none;
    user-select: none
}

.f-panzoom__protected {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    -webkit-user-select: none;
    user-select: none
}

html.with-panzoom-in-fullscreen {
    overflow: hidden
}

.f-fadeIn {
    animation: var(--f-transition-duration, .2s) var(--f-transition-easing, ease) var(--f-transition-delay, 0s) both f-fadeIn;
    z-index: 2
}

.f-fadeOut {
    animation: var(--f-transition-duration, .2s) var(--f-transition-easing, ease) var(--f-transition-delay, 0s) both f-fadeOut;
    z-index: 1
}

@keyframes f-fadeIn {
    0% {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

@keyframes f-fadeOut {
    to {
        opacity: 0
    }
}

.f-crossfadeIn {
    animation: var(--f-transition-duration, .2s) ease both f-crossfadeIn;
    z-index: 2
}

.f-crossfadeOut {
    animation: calc(var(--f-transition-duration, .2s) * .2) ease calc(var(--f-transition-duration, .2s) * .8) both f-crossfadeOut;
    z-index: 1
}

@keyframes f-crossfadeIn {
    0% {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

@keyframes f-crossfadeOut {
    to {
        opacity: 0
    }
}

.is-horizontal .f-slideIn.from-next {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideInNextX
}

.is-horizontal .f-slideIn.from-prev {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideInPrevX
}

.is-horizontal .f-slideOut.to-next {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideOutNextX
}

.is-horizontal .f-slideOut.to-prev {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideOutPrevX
}

@keyframes f-slideInPrevX {
    0% {
        transform: translate(calc(100% + var(--f-carousel-gap, 0)))
    }
    to {
        transform: translateZ(0)
    }
}

@keyframes f-slideInNextX {
    0% {
        transform: translate(calc(-100% - var(--f-carousel-gap, 0)))
    }
    to {
        transform: translateZ(0)
    }
}

@keyframes f-slideOutNextX {
    to {
        transform: translate(calc(-100% - var(--f-carousel-gap, 0)))
    }
}

@keyframes f-slideOutPrevX {
    to {
        transform: translate(calc(100% + var(--f-carousel-gap, 0)))
    }
}

.is-vertical .f-slideIn.from-next {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideInNextY
}

.is-vertical .f-slideIn.from-prev {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideInPrevY
}

.is-vertical .f-slideOut.to-next {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideOutNextY
}

.is-vertical .f-slideOut.to-prev {
    animation: var(--f-transition-duration, .85s) cubic-bezier(.16, 1, .3, 1) f-slideOutPrevY
}

@keyframes f-slideInPrevY {
    0% {
        transform: translateY(calc(100% + var(--f-carousel-gap, 0)))
    }
    to {
        transform: translateZ(0)
    }
}

@keyframes f-slideInNextY {
    0% {
        transform: translateY(calc(-100% - var(--f-carousel-gap, 0)))
    }
    to {
        transform: translateZ(0)
    }
}

@keyframes f-slideOutNextY {
    to {
        transform: translateY(calc(-100% - var(--f-carousel-gap, 0)))
    }
}

@keyframes f-slideOutPrevY {
    to {
        transform: translateY(calc(100% + var(--f-carousel-gap, 0)))
    }
}

.f-zoomInUp {
    animation: var(--f-transition-duration, .3s) ease both f-zoomInUp
}

.f-zoomOutDown {
    animation: var(--f-transition-duration, .3s) ease both f-zoomOutDown
}

@keyframes f-zoomInUp {
    0% {
        transform: scale(var(--f-zoomInUp-scale, .975)) translate3d(var(--f-zoomInUp-x, 0), var(--f-zoomInUp-y, 16px), 0);
        opacity: var(--f-zoomInUp-opacity, 0)
    }
    to {
        transform: scale(1) translateZ(0);
        opacity: 1
    }
}

@keyframes f-zoomOutDown {
    to {
        transform: scale(var(--f-zoomOutDown-scale, .975)) translate3d(var(--f-zoomOutDown-x, 0), var(--f-zoomOutDown-y, 16px), 0);
        opacity: 0
    }
}

.f-throwOutUp {
    animation: var(--f-throwOutUp-duration, .2s) ease-out both f-throwOutUp
}

.f-throwOutDown {
    animation: var(--f-throwOutDown-duration, .2s) ease-out both f-throwOutDown
}

@keyframes f-throwOutUp {
    to {
        transform: translate3d(0, calc(var(--f-throwOutUp-y, 150px) * -1), 0);
        opacity: 0
    }
}

@keyframes f-throwOutDown {
    to {
        transform: translate3d(0, var(--f-throwOutDown-y, 150px), 0);
        opacity: 0
    }
}

.has-iframe .f-html, .has-pdf .f-html, .has-gmap .f-html {
    width: 100%;
    height: 100%;
    min-height: 1px;
    overflow: visible
}

.has-pdf .f-html, .has-gmap .f-html {
    padding: 0
}

.f-html {
    position: relative;
    box-sizing: border-box;
    margin: var(--f-html-margin, 0);
    padding: var(--f-html-padding, 2rem);
    color: var(--f-html-color, currentColor);
    background: var(--f-html-bg)
}

.f-html.is-error {
    text-align: center
}

.f-iframe {
    display: block;
    margin: 0;
    border: 0;
    height: 100%;
    width: 100%
}

.f-caption {
    align-self: center;
    flex-shrink: 0;
    margin: var(--f-caption-margin);
    padding: var(--f-caption-padding, 16px 8px);
    max-width: 100%;
    max-height: calc(80vh - 100px);
    overflow: auto;
    overflow-wrap: anywhere;
    line-height: var(--f-caption-line-height);
    color: var(--f-caption-color);
    background: var(--f-caption-bg);
    font: var(--f-caption-font)
}

.has-html5video .f-html, .has-youtube .f-html, .has-vimeo .f-html {
    padding: 0;
    width: 100%;
    height: 100%;
    min-height: 1px;
    overflow: visible;
    max-width: var(--f-video-width, 960px);
    max-height: var(--f-video-height, 540px);
    aspect-ratio: var(--f-video-aspect-ratio);
    background: var(--f-video-bg, rgba(0, 0, 0, .9))
}

.f-html5video {
    border: 0;
    display: block;
    height: 100%;
    width: 100%;
    background: transparent
}

.f-button.is-arrow {
    --f-button-width: var(--f-arrow-width, 46px);
    --f-button-height: var(--f-arrow-height, 46px);
    --f-button-svg-width: var(--f-arrow-svg-width, 24px);
    --f-button-svg-height: var(--f-arrow-svg-height, 24px);
    --f-button-svg-stroke-width: var(--f-arrow-svg-stroke-width, 1.75);
    --f-button-border-radius: var(--f-arrow-border-radius, unset);
    --f-button-bg: var(--f-arrow-bg, transparent);
    --f-button-hover-bg: var(--f-arrow-hover-bg, var(--f-arrow-bg));
    --f-button-active-bg: var(--f-arrow-active-bg, var(--f-arrow-hover-bg));
    --f-button-shadow: var(--f-arrow-shadow);
    --f-button-color: var(--f-arrow-color);
    --f-button-hover-color: var(--f-arrow-hover-color, var(--f-arrow-color));
    --f-button-active-color: var(--f-arrow-active-color, var(--f-arrow-hover-color));
    overflow: visible
}

.f-button.is-arrow.is-prev, .f-button.is-arrow.is-next {
    position: absolute;
    transform: translate(0);
    z-index: 20
}

.is-horizontal .f-button.is-arrow.is-prev, .is-horizontal .f-button.is-arrow.is-next {
    inset: 50% auto auto;
    transform: translateY(-50%)
}

.is-horizontal.is-ltr .f-button.is-arrow.is-prev {
    left: var(--f-arrow-pos, 0)
}

.is-horizontal.is-ltr .f-button.is-arrow.is-next {
    right: var(--f-arrow-pos, 0)
}

.is-horizontal.is-rtl .f-button.is-arrow.is-prev {
    right: var(--f-arrow-pos, 0);
    transform: translateY(-50%) rotateY(180deg)
}

.is-horizontal.is-rtl .f-button.is-arrow.is-next {
    left: var(--f-arrow-pos, 0);
    transform: translateY(-50%) rotateY(180deg)
}

.is-vertical.is-ltr .f-button.is-arrow.is-prev, .is-vertical.is-rtl .f-button.is-arrow.is-prev {
    top: var(--f-arrow-pos, 0);
    right: auto;
    bottom: auto;
    left: 50%;
    transform: translate(-50%)
}

.is-vertical.is-ltr .f-button.is-arrow.is-next, .is-vertical.is-rtl .f-button.is-arrow.is-next {
    top: auto;
    right: auto;
    bottom: var(--f-arrow-pos, 0);
    left: 50%;
    transform: translate(-50%)
}

.is-vertical .f-button.is-arrow.is-prev svg, .is-vertical .f-button.is-arrow.is-next svg {
    transform: rotate(90deg)
}

.f-carousel__toolbar {
    display: grid;
    grid-template-columns:1fr auto 1fr;
    margin: var(--f-toolbar-margin, 0);
    padding: var(--f-toolbar-padding, 8px);
    line-height: var(--f-toolbar-line-height);
    background: var(--f-toolbar-bg, none);
    box-shadow: var(--f-toolbar-shadow, none);
    -webkit-backdrop-filter: var(--f-toolbar-backdrop-filter);
    backdrop-filter: var(--f-toolbar-backdrop-filter);
    position: relative;
    z-index: 20;
    color: var(--f-toolbar-color, currentColor);
    font-size: var(--f-toolbar-font-size, 17px);
    font-weight: var(--f-toolbar-font-weight, inherit);
    font-family: var(--f-toolbar-font, -apple-system, BlinkMacSystemFont, "Segoe UI Adjusted", "Segoe UI", "Liberation Sans", sans-serif);
    text-shadow: var(--f-toolbar-text-shadow);
    text-align: center;
    font-variant-numeric: tabular-nums;
    -webkit-font-smoothing: subpixel-antialiased;
    white-space: nowrap;
    pointer-events: none
}

.f-carousel__toolbar.is-absolute {
    position: absolute;
    top: 0;
    left: 0;
    right: 0
}

.f-carousel__toolbar .f-button:focus-visible {
    position: relative;
    z-index: 1
}

.f-carousel__toolbar__column {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: flex-start;
    gap: var(--f-toolbar-gap, 0)
}

.f-carousel__toolbar__column.is-left {
    display: flex;
    justify-self: flex-start;
    justify-content: flex-start
}

.f-carousel__toolbar__column.is-middle {
    display: flex;
    justify-content: center
}

.f-carousel__toolbar__column.is-right {
    display: flex;
    justify-self: flex-end;
    justify-content: flex-end;
    flex-flow: nowrap
}

.f-carousel__toolbar__column {
    pointer-events: none
}

.f-carousel__toolbar__column > * {
    pointer-events: all
}

.f-counter {
    position: relative;
    display: flex;
    flex-direction: row;
    cursor: default;
    -webkit-user-select: none;
    user-select: none;
    margin: var(--f-counter-margin, 0);
    padding: var(--f-counter-padding, 4px);
    line-height: var(--f-counter-line-height);
    background: var(--f-counter-bg);
    border-radius: var(--f-counter-border-radius)
}

.f-counter span {
    padding: 0 var(--f-counter-gap, 4px)
}

:root {
    --f-thumbs-gap: 8px;
    --f-thumbs-margin: 0;
    --f-thumbs-padding-x: 8px;
    --f-thumbs-padding-y: 8px;
    --f-thumbs-bg: transparent;
    --f-thumbs-transition: max-height .3s ease, max-width .3s ease, padding .3s ease;
    --f-thumbs-z-index: 1;
    --f-thumbs-viewport-padding-x: 0px;
    --f-thumbs-viewport-padding-y: 0px;
    --f-thumb-width: 94px;
    --f-thumb-height: 76px;
    --f-thumb-clip-width: 46px;
    --f-thumb-extra-gap: 16px;
    --f-thumb-opacity: 1;
    --f-thumb-transition: opacity .3s ease, transform .15s ease;
    --f-thumb-border: none;
    --f-thumb-border-radius: 4px;
    --f-thumb-shadow: none;
    --f-thumb-bg: linear-gradient(rgba(0, 0, 0, .1), rgba(0, 0, 0, .05));
    --f-thumb-focus-shadow: inset 0 0 0 .8px #222, inset 0 0 0 2.25px #fff;
    --f-thumb-selected-shadow: inset 0 0 0 .8px #222, inset 0 0 0 2.25px #fff;
    --f-thumb-border-transition: all .1s ease;
    --f-thumb-img-width: 100%;
    --f-thumb-img-height: 100%;
    --f-thumb-img-fit: cover;
    --f-thumb-img-position: 50% 20%
}

.f-thumbs {
    --f-carousel-slide-width: var(--f-thumb-width);
    --f-carousel-slide-height: var(--f-thumb-height);
    --f-carousel-gap: var(--f-thumbs-gap);
    position: relative;
    box-sizing: border-box;
    flex-shrink: 0;
    margin: var(--f-thumbs-margin);
    padding: var(--f-thumbs-padding-y) var(--f-thumbs-padding-x);
    overflow: hidden;
    background: var(--f-thumbs-bg);
    -webkit-tap-highlight-color: transparent;
    -webkit-user-select: none;
    user-select: none;
    transition: var(--f-thumbs-transition);
    z-index: var(--f-thumbs-z-index)
}

.f-thumbs.is-horizontal {
    max-height: calc(var(--f-carousel-slide-height) + var(--f-thumbs-padding-y) * 2)
}

.f-thumbs.is-horizontal.is-hidden {
    max-height: 0;
    --f-thumbs-padding-y: 0
}

.f-thumbs.is-vertical {
    max-width: calc(var(--f-carousel-slide-width) + var(--f-thumbs-padding-x) * 2)
}

.f-thumbs.is-vertical.is-hidden {
    max-width: 0;
    --f-thumbs-padding-x: 0
}

.f-thumbs.is-scrollable.is-hidden {
    max-height: 0;
    --f-thumbs-padding-y: 0
}

.f-thumbs.is-ltr {
    direction: ltr
}

.f-thumbs.is-rtl {
    direction: rtl
}

.f-thumbs img {
    display: block;
    width: var(--f-thumb-img-width);
    height: var(--f-thumb-img-height);
    object-fit: var(--f-thumb-img-fit);
    object-position: var(--f-thumb-img-position);
    pointer-events: none;
    border-radius: inherit;
    color: transparent
}

.f-thumbs img[data-lazy-src] {
    visibility: hidden
}

.f-thumbs img.has-lazyerror {
    display: none
}

.f-thumbs__viewport {
    box-sizing: border-box;
    height: 100%;
    padding: var(--f-thumbs-viewport-padding-y) var(--f-thumbs-viewport-padding-x);
    overflow: visible;
    display: grid
}

.f-thumbs__slide {
    position: relative;
    box-sizing: border-box;
    grid-area: 1/1;
    width: var(--f-carousel-slide-width);
    height: var(--f-carousel-slide-height);
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    flex-direction: column;
    cursor: pointer;
    overflow: visible
}

.f-thumbs__slide:hover button {
    opacity: var(--f-thumb-hover-opacity, 1);
    transform: var(--f-thumb-hover-transform, none)
}

.f-thumbs__slide:hover button:after {
    border: var(--f-thumb-hover-border, none);
    box-shadow: var(--f-thumb-hover-shadow, var(--f-thumb-shadow))
}

.f-thumbs__slide button {
    all: unset;
    display: block;
    margin: auto;
    padding: 0;
    position: relative;
    overflow: visible;
    width: 100%;
    height: 100%;
    outline: none;
    transition: var(--f-thumb-transition);
    border-radius: var(--f-thumb-border-radius);
    opacity: var(--f-thumb-opacity);
    transform: var(--f-thumb-transform);
    background: var(--f-thumb-bg)
}

.f-thumbs__slide button:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    transition: var(--f-thumb-border-transition);
    border-radius: inherit;
    border: var(--f-thumb-border);
    box-shadow: var(--f-thumb-shadow)
}

.f-thumbs__slide button:focus-within {
    opacity: var(--f-thumb-focus-opacity, 1);
    transform: var(--f-thumb-focus-transform, none)
}

.f-thumbs__slide button:focus-within:after {
    border: var(--f-thumb-focus-border, none);
    box-shadow: var(--f-thumb-focus-shadow, var(--f-thumb-shadow))
}

.f-thumbs__slide:active {
    opacity: var(--f-thumb-active-opacity, 1);
    transform: var(--f-thumb-active-transform, none)
}

.f-thumbs__slide:active:after {
    border: var(--f-thumb-active-border, none);
    box-shadow: var(--f-thumb-active-shadow, var(--f-thumb-shadow))
}

.f-thumbs__slide.is-selected {
    z-index: 2
}

.f-thumbs__slide.is-selected button {
    opacity: var(--f-thumb-selected-opacity, 1);
    transform: var(--f-thumb-selected-transform, none)
}

.f-thumbs__slide.is-selected button:after {
    border: var(--f-thumb-selected-border, none);
    box-shadow: var(--f-thumb-selected-shadow, var(--f-thumb-shadow))
}

.f-thumbs.is-modern {
    --f-carousel-slide-width: calc(var(--f-thumb-clip-width) + var(--f-thumbs-gap));
    --f-carousel-slide-height: var(--f-thumb-height);
    --f-carousel-gap: 0;
    --width-diff: calc((var(--f-thumb-width) - var(--f-thumb-clip-width)))
}

.f-thumbs.is-modern .f-thumbs__viewport {
    width: calc(100% + var(--f-carousel-slide-width) * 2 + var(--f-thumbs-padding-x));
    margin-inline: calc((var(--f-carousel-slide-width) + var(--f-thumbs-padding-x)) * -1)
}

.f-thumbs.is-modern .f-thumbs__slide {
    --clip-shift: calc((var(--width-diff) * .5) * var(--progress));
    --clip-path: inset(0 var(--clip-shift) round var(--f-thumb-border-radius, 0));
    padding: 0;
    overflow: visible;
    left: var(--shift, 0);
    will-change: left;
    transition: left var(--f-transition-duration) var(--f-transition-easing)
}

.f-thumbs.is-modern .f-thumbs__slide button {
    display: block;
    margin-inline: 50%;
    width: var(--f-thumb-width);
    clip-path: var(--clip-path);
    border: none;
    box-shadow: none;
    transition: clip-path var(--f-transition-duration) var(--f-transition-easing), opacity var(--f-thumb-transition-duration, .2s) var(--f-thumb-transition-easing, ease)
}

.f-thumbs.is-modern .f-thumbs__slide button:after {
    display: none
}

.f-thumbs.is-modern .f-thumbs__slide:focus:not(:focus-visible) {
    outline: none
}

.f-thumbs.is-modern .f-thumbs__slide:focus-within:not(.is-selected) button:before {
    content: "";
    position: absolute;
    z-index: 1;
    top: 0;
    left: var(--clip-shift);
    bottom: 0;
    right: var(--clip-shift);
    transition: border var(--f-transition-duration) var(--f-transition-easing), box-shadow var(--f-transition-duration) var(--f-transition-easing);
    border-radius: inherit;
    border: var(--f-thumb-focus-border, none);
    box-shadow: var(--f-thumb-focus-shadow, none)
}

.f-thumbs.is-modern {
    --f-transition-duration: .25s;
    --f-transition-easing: ease-out
}

.f-thumbs.is-modern.is-syncing {
    --f-transition-duration: 0s
}

.f-thumbs.is-scrollable .f-thumbs__viewport {
    display: grid;
    grid-template-columns:repeat(auto-fill, minmax(var(--f-thumb-width), 1fr));
    grid-auto-rows: var(--f-thumb-height);
    gap: var(--f-thumbs-gap);
    overflow: auto;
    overscroll-behavior: contain;
    -webkit-user-select: none;
    user-select: none
}

.f-thumbs.is-scrollable .f-thumbs__viewport .f-thumbs__slide {
    grid-area: auto;
    display: block;
    position: relative;
    max-width: 100%;
    width: var(--f-thumb-width);
    height: var(--f-thumb-height);
    cursor: pointer;
    outline: none
}

:root {
    --f-progressbar-height: 3px;
    --f-progressbar-color: var(--f-carousel-theme-color, #575ad6);
    --f-progressbar-opacity: 1;
    --f-progressbar-z-index: 30
}

.f-progressbar {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: var(--f-progressbar-z-index);
    height: var(--f-progressbar-height);
    transform: scaleX(0);
    transform-origin: 0;
    opacity: var(--f-progressbar-opacity);
    background: var(--f-progressbar-color);
    -webkit-user-select: none;
    user-select: none;
    pointer-events: none;
    animation-name: f-progressbar;
    animation-play-state: running;
    animation-timing-function: linear
}

.f-progressbar:empty {
    display: block
}

button > .f-progressbar {
    --f-progressbar-height: 100%;
    --f-progressbar-opacity: .2
}

@keyframes f-progressbar {
    0% {
        transform: scaleX(0)
    }
    to {
        transform: scaleX(1)
    }
}

[data-fullscreen-action=toggle] svg g:first-child {
    display: flex
}

[data-fullscreen-action=toggle] svg g:last-child {
    display: none
}

:fullscreen [data-fullscreen-action=toggle] svg g:first-child {
    display: none
}

:fullscreen [data-fullscreen-action=toggle] svg g:last-child {
    display: flex
}

.in-fullscreen-mode > .f-carousel {
    flex: 1;
    min-width: 0 !important;
    min-height: 0 !important
}

html.with-fancybox {
    width: auto;
    overflow: visible;
    scroll-behavior: auto
}

html.with-fancybox body.hide-scrollbar {
    width: auto;
    margin-right: calc(var(--f-body-margin, 0px) + var(--f-scrollbar-compensate, 0px));
    overflow: hidden !important;
    overscroll-behavior-y: none
}

.fancybox__dialog {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1050;
    width: 100%;
    height: 100vh;
    max-height: unset;
    max-width: unset;
    padding: 0;
    margin: 0;
    border: 0;
    overflow: hidden;
    background: transparent;
    touch-action: none;
    overscroll-behavior: contain
}

.fancybox__dialog:focus {
    outline: none
}

.fancybox__dialog::backdrop {
    opacity: 0
}

@supports (height: 100dvh) {
    .fancybox__dialog {
        height: 100dvh
    }
}

.fancybox__dialog *:empty {
    display: block
}

.fancybox__container {
    --fancybox-color: #dbdbdb;
    --fancybox-backdrop-bg: rgba(24, 24, 27, .95);
    --f-toolbar-margin: 0;
    --f-toolbar-padding: 8px;
    --f-toolbar-gap: 0;
    --f-toolbar-color: #ddd;
    --f-toolbar-font-size: 16px;
    --f-toolbar-font-weight: 500;
    --f-toolbar-font: -apple-system, BlinkMacSystemFont, "Segoe UI Adjusted", "Segoe UI", "Liberation Sans", sans-serif;
    --f-toolbar-line-height: var(--f-button-height);
    --f-toolbar-text-shadow: 1px 1px 1px rgba(0, 0, 0, .75);
    --f-toolbar-shadow: none;
    --f-toolbar-bg: none;
    --f-counter-margin: 0;
    --f-counter-padding: 0px 10px;
    --f-counter-gap: 4px;
    --f-counter-line-height: var(--f-button-height);
    --f-carousel-gap: 17px;
    --f-carousel-slide-width: 100%;
    --f-carousel-slide-height: 100%;
    --f-carousel-slide-padding: 0;
    --f-carousel-slide-bg: unset;
    --f-html-color: #222;
    --f-html-bg: #fff;
    --f-error-color: #fff;
    --f-error-bg: #333;
    --f-caption-margin: 0;
    --f-caption-padding: 16px 8px;
    --f-caption-color: var(--fancybox-color, #dbdbdb);
    --f-caption-bg: transparent;
    --f-caption-font: inherit;
    --f-caption-line-height: 1.375;
    --f-spinner-color-1: rgba(255, 255, 255, .2);
    --f-spinner-color-2: rgba(255, 255, 255, .8);
    --f-spinner-width: 50px;
    --f-spinner-height: 50px;
    --f-spinner-border-radius: 50%;
    --f-spinner-border-width: 4px;
    --f-progressbar-color: rgba(255, 255, 255);
    --f-button-width: 46px;
    --f-button-height: 46px;
    --f-button-color: #ddd;
    --f-button-hover-color: #fff;
    --f-button-outline-width: 1px;
    --f-button-outline-color: rgba(255, 255, 255, .75);
    --f-button-outline-offset: 0px;
    --f-button-bg: rgba(54, 54, 54, .75);
    --f-button-border: 0;
    --f-button-border-radius: 0;
    --f-button-shadow: none;
    --f-button-transition: all .2s ease;
    --f-button-transform: none;
    --f-button-svg-width: 24px;
    --f-button-svg-height: 24px;
    --f-button-svg-stroke-width: 1.75;
    --f-button-svg-filter: drop-shadow(1px 1px 1px rgba(24, 24, 27, .01)), drop-shadow(1px 2px 1px rgba(24, 24, 27, .05));
    --f-button-svg-fill: none;
    --f-button-svg-disabled-opacity: .5;
    --f-arrow-pos: 32px;
    --f-arrow-width: 50px;
    --f-arrow-height: 50px;
    --f-arrow-svg-width: 24px;
    --f-arrow-svg-height: 24px;
    --f-arrow-svg-stroke-width: 2.5;
    --f-arrow-border-radius: 50%;
    --f-arrow-bg: rgba(54, 54, 54, .65);
    --f-arrow-color: #ddd;
    --f-arrow-hover-color: #fff;
    --f-close-button-width: 30px;
    --f-close-button-height: 30px;
    --f-close-button-svg-width: 24px;
    --f-close-button-svg-height: 24px;
    --f-close-button-svg-stroke-width: 1.75;
    --f-close-border-radius: 4px;
    --f-close-button-color: #fff;
    --f-close-button-hover-color: #fff;
    --f-close-button-bg: transparent;
    --f-close-button-hover-bg: transparent;
    --f-close-button-active-bg: transparent;
    --f-thumbs-margin: 0px;
    --f-thumbs-padding-x: 8px;
    --f-thumbs-padding-y: 8px;
    --f-thumbs-bg: none;
    --f-thumb-transition: all .2s ease;
    --f-thumb-width: 94px;
    --f-thumb-height: 76px;
    --f-thumb-opacity: 1;
    --f-thumb-border: none;
    --f-thumb-shadow: none;
    --f-thumb-transform: none;
    --f-thumb-focus-opacity: 1;
    --f-thumb-focus-border: none;
    --f-thumb-focus-shadow: inset 0 0 0 2px rgba(255, 255, 255, .65);
    --f-thumb-focus-transform: none;
    --f-thumb-hover-opacity: 1;
    --f-thumb-hover-border: none;
    --f-thumb-hover-transform: none;
    --f-thumb-active-opacity: var(--f-thumb-hover-opacity);
    --f-thumb-active-border: var(--f-thumb-hover-border);
    --f-thumb-active-transform: var(--f-thumb-hover-transform);
    --f-thumb-selected-opacity: 1;
    --f-thumb-selected-border: none;
    --f-thumb-selected-shadow: inset 0 0 0 2px #fff;
    --f-thumb-selected-transform: none;
    --f-scrollbar-width: 7px;
    --f-scrollbar-track-bg: #444;
    --f-scrollbar-track-border-radius: 10px;
    --f-scrollbar-track-shadow: inset 0 0 6px rgba(0, 0, 0, .2);
    --f-scrollbar-thumb-bg: #ddd;
    --f-scrollbar-thumb-border-radius: 10px
}

.fancybox__container[theme=light] {
    --fancybox-color: #222;
    --fancybox-backdrop-bg: rgba(255, 255, 255, .97);
    --f-toolbar-color: var(--fancybox-color, #222);
    --f-toolbar-text-shadow: none;
    --f-toolbar-font-weight: 400;
    --f-html-color: var(--fancybox-color, #222);
    --f-html-bg: #fff;
    --f-error-color: #555;
    --f-error-bg: #fff;
    --f-video-bg: #fff;
    --f-caption-color: #333;
    --f-spinner-color-1: rgba(0, 0, 0, .2);
    --f-spinner-color-2: rgba(0, 0, 0, .8);
    --f-spinner-border-width: 3.5px;
    --f-progressbar-color: rgba(111, 111, 116);
    --f-button-color: #333;
    --f-button-hover-color: #000;
    --f-button-outline-color: rgba(0, 0, 0, .85);
    --f-button-bg: rgba(255, 255, 255, .85);
    --f-button-svg-stroke-width: 1.3;
    --f-button-svg-filter: none;
    --f-arrow-bg: rgba(255, 255, 255, .85);
    --f-arrow-color: #333;
    --f-arrow-hover-color: #000;
    --f-arrow-svg-stroke-width: 1.3;
    --f-close-button-color: #555;
    --f-close-button-hover-color: #000;
    --f-thumb-bg: linear-gradient(#ebeff2, #e2e8f0);
    --f-thumb-focus-shadow: 0 0 0 1.8px #fff, 0px 0px 0px 2.25px #888;
    --f-thumb-selected-shadow: 0 0 0 1.8px #fff, 0px 0px 0px 2.25px #000;
    --f-scrollbar-track-bg: #ddd;
    --f-scrollbar-thumb-bg: #444
}

.fancybox__container {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column
}

.fancybox__container:focus {
    outline: none
}

.fancybox__container.has-vertical-thumbs {
    flex-direction: row-reverse
}

.fancybox__container.has-vertical-thumbs:not(.is-closing) .fancybox__viewport {
    overflow-x: clip;
    overflow-y: visible
}

.fancybox__container > *:not(.fancybox__carousel), .fancybox__container .fancybox__carousel > *:not(.fancybox__viewport), .fancybox__container .fancybox__carousel > .fancybox__viewport > .fancybox__slide:not(.is-selected), .fancybox__container .fancybox__carousel > .fancybox__viewport > .fancybox__slide.is-selected > *:not(.f-html,.f-panzoom__wrapper,.f-spinner) {
    opacity: var(--f-drag-opacity, 1)
}

.fancybox__container:not(.is-ready,.is-hiding) {
    visibility: hidden
}

.fancybox__container.is-revealing > *:not(.fancybox__carousel), .fancybox__container.is-revealing .fancybox__carousel > *:not(.fancybox__viewport), .fancybox__container.is-revealing .fancybox__carousel > .fancybox__viewport > .fancybox__slide:not(.is-selected), .fancybox__container.is-revealing .fancybox__carousel > .fancybox__viewport > .fancybox__slide.is-selected > *:not(.f-html,.f-panzoom__wrapper,.f-spinner) {
    animation: var(--f-interface-enter-duration, .35s) ease none f-fadeIn
}

.fancybox__container.is-hiding > *:not(.fancybox__carousel), .fancybox__container.is-hiding .fancybox__carousel > *:not(.fancybox__viewport), .fancybox__container.is-hiding .fancybox__carousel > .fancybox__viewport > .fancybox__slide.is-selected > *:not(.f-html,.f-panzoom__wrapper) {
    animation: var(--f-interface-exit-duration, .35s) ease forwards f-fadeOut
}

.fancybox__container.is-hiding .fancybox__carousel .fancybox__slide:not(.is-selected) {
    opacity: 0
}

.fancybox__container.is-hiding {
    pointer-events: none
}

.fancybox__container.is-idle .f-carousel__toolbar {
    pointer-events: none;
    opacity: 0
}

.fancybox__container.is-idle .f-button.is-arrow {
    opacity: 0
}

.fancybox__container.is-idle.is-ready .f-carousel__toolbar {
    pointer-events: none;
    animation: .15s ease-out both f-fadeOut
}

.fancybox__container.is-idle.is-ready .f-button.is-arrow {
    animation: .15s ease-out both f-fadeOut
}

.fancybox__backdrop {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: var(--fancybox-backdrop-bg)
}

.fancybox__carousel {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    min-width: 0;
    position: relative;
    z-index: 10;
    overflow-y: visible;
    overflow-x: clip
}

.fancybox__carousel.is-vertical {
    --f-carousel-slide-height: 100%
}

.fancybox__carousel.is-ltr {
    direction: ltr
}

.fancybox__carousel.is-rtl {
    direction: rtl
}

.fancybox__carousel > .f-button.is-arrow:before {
    position: absolute;
    content: "";
    top: -30px;
    right: -30px;
    bottom: -30px;
    left: -30px;
    z-index: 1
}

.fancybox__viewport {
    display: grid;
    flex: 1;
    min-height: 0;
    min-width: 0;
    position: relative;
    overflow: visible;
    transform: translate3d(0, var(--f-drag-offset, 0), 0)
}

.fancybox__viewport.is-draggable {
    cursor: move;
    cursor: grab
}

.fancybox__viewport.is-dragging {
    cursor: move;
    cursor: grabbing
}

.fancybox__viewport [data-selectable], .fancybox__viewport [contenteditable] {
    cursor: auto
}

.fancybox__slide {
    box-sizing: border-box;
    position: relative;
    grid-area: 1/1;
    display: flex;
    align-items: center;
    flex-direction: column;
    width: var(--f-carousel-slide-width);
    height: var(--f-carousel-slide-height);
    min-width: 0;
    min-height: 0;
    max-width: 100%;
    margin: 0;
    padding: var(--f-carousel-slide-padding);
    background: var(--f-carousel-slide-bg);
    backface-visibility: hidden;
    transform: translateZ(0);
    will-change: transform
}

.fancybox__slide:before, .fancybox__slide:after {
    display: block;
    content: ""
}

.fancybox__slide:before {
    margin-bottom: auto
}

.fancybox__slide:after {
    margin-top: auto
}

.fancybox__slide.is-selected {
    z-index: 1
}

.fancybox__slide.f-zoomable {
    overflow: visible
}

.fancybox__slide.has-error {
    --f-html-color: var(--f-error-color, --f-html-color);
    --f-html-bg: var(--f-error-bg, --f-html-bg)
}

.fancybox__slide.has-html {
    overflow: auto;
    padding: 8px
}

.fancybox__slide.has-close-btn {
    padding-top: 34px
}

.fancybox__slide.has-controls:before {
    margin: 0
}

.fancybox__slide .f-spinner {
    cursor: pointer
}

.fancybox__container.is-closing .f-caption, .fancybox__slide.is-loading .f-caption {
    visibility: hidden
}

.fancybox__container.is-closing .fancybox__carousel {
    overflow: visible
}

.f-button.is-close-button {
    --f-button-width: var(--f-close-button-width);
    --f-button-height: var(--f-close-button-height);
    --f-button-border-radius: var(--f-close-border-radius);
    --f-button-color: var(--f-close-button-color);
    --f-button-hover-color: var(--f-close-button-hover-color);
    --f-button-bg: var(--f-close-button-bg);
    --f-button-hover-bg: var(--f-close-button-hover-bg);
    --f-button-active-bg: var(--f-close-button-active-bg);
    --f-button-svg-width: var(--f-close-button-svg-width);
    --f-button-svg-height: var(--f-close-button-svg-height);
    --f-button-svg-stroke-width: var(--f-close-button-svg-stroke-width);
    position: absolute;
    top: calc((var(--f-button-height) + 2px) * -1);
    right: 0;
    z-index: 10
}

.fancybox__thumbs {
    flex: 0 1 100%
}

.fancybox__thumbs.is-scrollable {
    --f-thumbs-cols: 1;
    --f-thumbs-gap: 8px;
    --f-thumbs-transition: none;
    --f-thumbs-padding-x: 4px;
    --f-thumbs-padding-y: 8px;
    --f-thumbs-viewport-padding-x: 4px;
    --f-thumbs-viewport-padding-y: 0px;
    max-width: calc(var(--f-thumb-width) * var(--f-thumbs-cols) + var(--f-thumbs-gap) * (var(--f-thumbs-cols) - 1) + var(--f-thumbs-padding-x) * 2 + var(--f-thumbs-viewport-padding-x) * 2)
}

.fancybox__thumbs.is-scrollable ::-webkit-scrollbar {
    width: var(--f-scrollbar-width)
}

.fancybox__thumbs.is-scrollable ::-webkit-scrollbar-track {
    background: var(--f-scrollbar-track-bg);
    border-radius: var(--f-scrollbar-track-border-radius);
    box-shadow: var(--f-scrollbar-track-shadow)
}

.fancybox__thumbs.is-scrollable ::-webkit-scrollbar-thumb {
    background: var(--f-scrollbar-thumb-bg);
    border-radius: var(--f-scrollbar-thumb-border-radius)
}

.fancybox__thumbs.is-scrollable.is-hidden {
    max-width: 0;
    --f-thumbs-padding-x: 0;
    max-height: unset;
    --f-thumbs-padding-y: unset
}

.fancybox__thumbs.is-scrollable .f-thumbs__viewport {
    overflow-x: hidden !important;
    grid-template-columns:repeat(auto-fill, calc((100% - var(--f-thumbs-gap) * (var(--f-thumbs-cols) - 1)) / var(--f-thumbs-cols))) !important
}
