html .page-products .columns {
    padding: 20px 0 50px;
}

.category-boxed-banner .banner-text {
    position: absolute;
    top: 40%;
    left: 4%;
    color: #fff;
    width: 100%;
}

/*
.product-info-main .product-add-form .swatch-opt {
    display: none;
}
*/

.product.media .swatch-attribute-label {
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px;
    min-width: 72px;
    font-size: .8571em;
    text-transform: uppercase;
    font-weight: 400;
    line-height: 32px;
    white-space: nowrap;
    padding: 2px 0 8px;
    margin: 0;
}

.product.media .swatch-attribute-options {
    display: inline-block;
    vertical-align: middle;
    padding: 2px 8px 8px;
}

#main-media-container #fancybox-button {
    display: none;
}

.swatch-opt .label.has-selected {
    float: left;
}

/* =========================================================
   SIDEBAR INFO BLOCK (pfx-side-info)
   Sticky + разделитель под изображением + карточки
   ========================================================= */

.pfx-side-info .pfx-info-card {
    border: 1px solid #e7e7e7;
    border-radius: 2px;
    padding: 14px 12px;
    margin-bottom: 14px;
    background: #fff;
}

.pfx-side-info .pfx-info-card:last-child {
    margin-bottom: 0;
}

.pfx-side-info .porto-just-icon-wrapper {
    text-align: center;
}

.pfx-side-info .porto-sicon-img {
    display: inline-block;
    padding-bottom: 12px;
    margin-bottom: 12px;
    border-bottom: 1px solid #e7e7e7;
}

.pfx-side-info .porto-sicon-img img {
    display: block;
    width: 200px;
    height: auto;
    max-width: 100%;
}

.pfx-side-info .mb-2 {
    margin-bottom: 0;
}

/* Sticky (desktop) */
@media (min-width: 992px) {
    html,
    body {
        overflow: visible !important;
    }

    .sidebar.sidebar-main .sidebar-content {
        overflow: visible !important;
    }

    .columns {
        align-items: flex-start;
    }

    .page-layout-2columns-left .sidebar.sidebar-main {
        position: sticky !important;
        top: 110px !important;
        z-index: 3;
        align-self: flex-start;
    }
}

/* =========================================================
   Header / product list CLS fix
   ========================================================= */

#layer-product-list {
    min-height: 800px;
}

/* =========================================================
   FTA Kontinent slider — CLS / LCP fix
   Фиксируем геометрию слайдера и миниатюр до инициализации Owl
   ========================================================= */

.fta-kontinent-slider {
    max-width: 851px;
    width: 100%;
    margin: 0 auto;
}

.fta-main-slider {
    width: 100%;
    aspect-ratio: 851 / 420;
    position: relative;
    overflow: hidden;
}

.fta-main-slider .item,
.fta-main-slider .fta-slide {
    position: relative;
    width: 100%;
    height: 100%;
}

.fta-main-slider .fta-slide img,
.fta-main-slider .owl-item img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fta-main-slider .owl-stage-outer,
.fta-main-slider .owl-stage,
.fta-main-slider .owl-item {
    height: 100%;
}

.fta-main-slider .owl-stage-outer {
    overflow: hidden;
}

.fta-main-slider .fta-slide-caption {
    position: absolute;
    left: 3.5%;
    top: 10%;
    z-index: 2;
    text-align: left;
}

.page-main .fta-main-slider .fta-slide-caption h2 {
    margin: 0;
    font-weight: 400;
    line-height: 1.1 !important;
    display: inline-block;
    padding: 3px 10px;
    background: rgba(255, 255, 255, .7);
    border-radius: 2px;
}

/* =========================================================
   FTA Thumb Slider — CLS fix
   ========================================================= */

.fta-thumb-slider-wrap {
    width: 100%;
    margin-top: 18px;
}

.fta-thumb-slider {
    display: flex;
    align-items: flex-start;
    min-height: 190px;
}

.fta-thumb-slider .owl-stage-outer {
    min-height: 190px;
}

.fta-thumb-slider .owl-stage {
    display: flex;
}

.fta-thumb-slider .owl-item {
    flex: 0 0 auto;
}

.fta-thumb-card {
    position: relative;
    width: 150px;
    height: 150px;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: #ededed;
    margin: 0 auto;
    display: block;
}

.fta-thumb-card img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fta-thumb-card h4 {
    margin-top: 6px;
    font-size: 13px;
    line-height: 1.2;
    text-align: center;
    min-height: 32px;
}

@media (min-width: 768px) {
    .fta-thumb-slider.owl-carousel .owl-item .item {
        width: 100% !important;
    }

    .fta-thumb-slider.owl-carousel .fta-thumb-card {
        width: 100% !important;
        height: auto;
        aspect-ratio: 1 / 1;
        margin: 0;
    }

    .fta-thumb-slider.owl-carousel .fta-thumb-card img {
        width: 100% !important;
        height: 100% !important;
    }
}

@media (max-width: 767px) {
    .fta-main-slider {
        aspect-ratio: 851 / 420;
    }

    .fta-main-slider .fta-slide-caption {
        left: 4%;
        top: 8%;
    }

    .page-main .fta-main-slider .fta-slide-caption h2 {
        font-size: 24px;
        line-height: 1.1 !important;
    }

    .fta-thumb-card {
        width: 100%;
        height: auto;
        aspect-ratio: 1 / 1;
        margin: 0;
    }

    .fta-thumb-card img {
        width: 100%;
        height: 100%;
        aspect-ratio: 1 / 1;
    }

    .fta-thumb-slider .owl-nav {
        display: block !important;
        pointer-events: none;
    }

    .fta-thumb-slider .owl-nav button {
        display: block !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto;
    }

    .fta-thumb-slider .owl-prev {
        left: 0;
    }

    .fta-thumb-slider .owl-next {
        right: 0;
    }
}

/* =========================================================
   STICKY HEADER / HEADER RELATED
   ========================================================= */

.page-header.sticky-header,
.page-header.sticky {
    background: #fff !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .10) !important;
    border-bottom: 1px solid rgba(0, 0, 0, .10) !important;
}

.page-header.sticky-header .navigation,
.page-header.sticky .navigation {
    width: 100% !important;
    padding-right: 90px !important;
    box-sizing: border-box !important;
}

.page-header.sticky-header .navigation > ul,
.page-header.sticky .navigation > ul {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    align-content: flex-start !important;
    gap: 10px 28px !important;
    padding: 10px 20px !important;
    margin: 0 !important;
}

.page-header.sticky-header .navigation > ul > li,
.page-header.sticky .navigation > ul > li {
    margin: 0 !important;
}

.page-header.sticky-header .navigation > ul > li:first-child,
.page-header.sticky .navigation > ul > li:first-child {
    display: none !important;
}

.page-header.sticky-header .navigation > ul > li > a,
.page-header.sticky .navigation > ul > li > a {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    display: inline-block !important;
    padding: 10px 0 !important;
    color: #111 !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: -0.3px !important;
    white-space: nowrap !important;
}

.page-header.sticky-header .navigation > ul > li > a:hover,
.page-header.sticky .navigation > ul > li > a:hover {
    color: #08c !important;
}

.page-header.sticky-header .navigation > ul > li.active > a,
.page-header.sticky .navigation > ul > li.active > a {
    color: #08c !important;
    border-bottom: 2px solid #08c !important;
    padding-bottom: 8px !important;
}

.page-header.sticky-header .navigation > ul > li.parent > a::after,
.page-header.sticky .navigation > ul > li.parent > a::after {
    content: none !important;
}

@media (min-width: 992px) {
    .page-header.type1 > .main-panel-top {
        display: none !important;
    }

    .page-header.type1 {
        min-height: 126px !important;
    }

    .page-header.type1 .header-main,
    .page-header.type1 .header.content.header-row,
    .page-header.type1 .header-left,
    .page-header.type1 .header-center,
    .page-header.type1 .header-right {
        min-height: 126px !important;
        height: 126px !important;
        display: flex !important;
        align-items: center !important;
    }

    .page-header.sticky-header .navigation > ul,
    .page-header.sticky .navigation > ul {
        gap: 4px 18px !important;
        padding: 6px 14px !important;
    }

    .page-header.sticky-header .navigation > ul > li > a,
    .page-header.sticky .navigation > ul > li > a {
        font-size: 12px !important;
        font-weight: 600 !important;
        letter-spacing: -0.2px !important;
        line-height: 1.2 !important;
        white-space: nowrap !important;
    }
}

@media (min-width: 992px) and (max-width: 1400px) {
    .page-header.sticky-header .navigation > ul > li > a,
    .page-header.sticky .navigation > ul > li > a {
        font-size: 11.5px !important;
    }
}

@media (min-width: 992px) and (max-width: 1280px) {
    .page-header.sticky-header .navigation > ul > li > a,
    .page-header.sticky .navigation > ul > li > a {
        font-size: 11px !important;
    }
}