:root {
    --color-dark:      #0B1220;
    --color-black:     #000000;
    --color-white:     #FFFFFF;
    --color-red:       #a82c46;
    --color-orange:    #fb8734;
    --color-gray:      #62666F;
    --color-border:    #E5E5E5;
    --color-bg-menu:   #f7f7f7;
    --color-gray-900:  #101828;

    --color-text:      var(--color-black);
    --color-bg:        var(--color-white);
    --color-muted:     var(--color-gray);
    --color-accent:    var(--color-orange);

    --font-body:    'Euclid Circular A', sans-serif;
    --font-heading: 'Euclid Circular A', sans-serif;
    --fw-light:     300;
    --fw-regular:   400;
    --fw-medium:    500;
    --fw-semibold:  600;
    --fw-bold:      700;
    --line-height:  1.6;

    --container-width:   1820px;
    --container-padding: 20px;

    --radius:     4px;
    --transition: 0.2s ease;
    --shadow:     0 4px 12px rgba(0, 0, 0, .12);

    --header-top-height:  40px;
    --header-main-height: 70px;
    --header-height: calc(var(--header-top-height) + var(--header-main-height));

    --footer-bg:    #111111;
    --footer-color: #cccccc;

    --z-dropdown: 100;
    --z-sticky:   200;
    --z-modal:    400;
}

html {
    font-size: 16px;
    scroll-padding-top: var(--header-height);
    overflow-x: hidden;
}

body {
    font-family:      var(--font-body);
    line-height:      var(--line-height);
    color:            var(--color-text);
    background-color: var(--color-bg);
    display:          flex;
    flex-direction:   column;
    min-height:       100vh;
}

.site      { display: flex; flex-direction: column; min-height: 100vh; }
.site-main { flex: 1; }

.container {
    width:          100%;
    max-width:      var(--container-width);
    margin-inline:  auto;
    padding-inline: var(--container-padding);
}

@media (max-width: 767px) {
    .container { padding-inline: 24px; }
}

.header-top {
    position:         sticky;
    top:              0;
    z-index:          var(--z-sticky);
    background-color: var(--color-dark);
    min-height:       var(--header-top-height);
}

.header-top__container {
    width:          100%;
    max-width:      1900px;
    margin-inline:  auto;
    padding-inline: 30px;
    min-height:     var(--header-top-height);
}

.header-top__inner {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    min-height:      var(--header-top-height);
    gap:             16px;
    padding-block:   6px;
}

.header-top__email {
    display:     flex;
    align-items: center;
    gap:         8px;
    flex-shrink: 0;
    color:       #CCD5E2;
}

.header-top__email-link {
    font-size:   14px;
    font-weight: var(--fw-regular);
    color:       #CCD5E2;
    white-space: nowrap;
    transition:  opacity var(--transition);
}
.header-top__email-link:hover { opacity: 0.75; }

.header-top__text {
    flex:           1;
    text-align:     center;
    font-size:      16px;
    font-weight:    var(--fw-light);
    color:          var(--color-white);
    text-transform: uppercase;
    margin:         0;
    padding-inline: 12px;
}

.header-top__right {
    display:     flex;
    align-items: center;
    gap:         12px;
    flex-shrink: 0;
}

.lang-dropdown {
    position: relative;
}

.lang-dropdown__trigger {
    display:     flex;
    align-items: center;
    gap:         5px;
    background:  none;
    border:      none;
    padding:     0;
    cursor:      pointer;
    color:       var(--color-white);
    line-height: 1;
}

.lang-dropdown__globe  { flex-shrink: 0; }

.lang-dropdown__current {
    font-size:   13px;
    font-weight: var(--fw-light);
    color:       var(--color-white);
    white-space: nowrap;
}

.lang-dropdown__chevron {
    flex-shrink: 0;
    transition:  transform var(--transition);
}

.lang-dropdown__trigger[aria-expanded="true"] .lang-dropdown__chevron {
    transform: rotate(180deg);
}

.lang-dropdown__panel {
    position:       absolute;
    top:            calc(100% + 4px);
    right:          0;
    min-width:      180px;
    list-style:     none;
    margin:         0;
    padding:        6px;
    background:     var(--color-dark);
    opacity:        0;
    pointer-events: none;
    transition:     opacity var(--transition);
    z-index:        var(--z-dropdown);
}

.lang-dropdown.is-open .lang-dropdown__panel {
    opacity:        1;
    pointer-events: auto;
}

.lang-dropdown__panel li { display: block; }

.lang-dropdown__panel a {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    height:          40px;
    padding:         0 16px;
    font-size:       14px;
    font-weight:     var(--fw-light);
    color:           var(--color-white);
    text-decoration: none;
    white-space:     nowrap;
    opacity:         0.7;
    transition:      opacity var(--transition);
}

.lang-dropdown__panel a:hover { opacity: 1; }

.lang-dropdown__panel [aria-selected="true"] a {
    opacity:     1;
    font-weight: var(--fw-medium);
}

.header-top__close {
    display:     none;
    color:       var(--color-white);
    background:  none;
    border:      none;
    padding:     0;
    cursor:      pointer;
    flex-shrink: 0;
}

.site-header {
    position:         sticky;
    top:              var(--header-top-height);
    z-index:          calc(var(--z-sticky) - 1);
    background-color: rgba(255, 255, 255, 0.85);
    backdrop-filter:  blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom:    1px solid var(--color-border);
    height:           var(--header-main-height);
    transition:       box-shadow var(--transition);
}

.site-header.is-sticky { box-shadow: 0 2px 16px rgba(0, 0, 0, 0.08); }

.site-header__container {
    width:          100%;
    max-width:      1840px;
    margin-inline:  auto;
    padding-inline: 20px;
    height:         100%;
}

.site-header__inner {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    height:          100%;
}

.site-header__left {
    display:     flex;
    align-items: center;
    gap:         40px;
}

.site-header__logo a,
.site-header__logo img {
    display: block;
    height:  26px;
    width:   auto;
}

.site-header__logo .site-title-link {
    font-size:   18px;
    font-weight: var(--fw-semibold);
    color:       var(--color-dark);
    white-space: nowrap;
}

.site-header__nav {
    display:     flex;
    align-items: center;
    gap:         0;
}

.site-header__nav-link,
.site-header__nav-btn {
    display:         flex;
    align-items:     center;
    justify-content: center;
    height:          40px;
    padding:         10px;
    font-size:       16px;
    font-weight:     var(--fw-light);
    color:           var(--color-black);
    border-radius:   6px;
    white-space:     nowrap;
    text-decoration: none;
    background:      none;
    border:          none;
    cursor:          pointer;
    font-family:     inherit;
    transition:      background-color var(--transition);
}

.site-header__nav-link:hover,
.site-header__nav-btn:hover,
.site-header__nav-btn[aria-expanded="true"] {
    background-color: var(--color-bg-menu);
}

.site-header__actions {
    display:     flex;
    align-items: center;
    gap:         24px;
}

.site-header__btn {
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           24px;
    height:          24px;
    background:      none;
    border:          none;
    padding:         0;
    cursor:          pointer;
    color:           var(--color-dark);
    flex-shrink:     0;
    position:        relative;
    transition:      opacity var(--transition);
}

.site-header__btn:hover                       { opacity: 0.65; }
.site-header__btn[aria-disabled="true"]       { cursor: default; }
.site-header__btn[aria-disabled="true"]:hover { opacity: 1; }

/* Wishlist / cart count badge */
.site-header__wishlist-count,
.site-header__cart-count {
    position:        absolute;
    top:             -5px;
    right:           -5px;
    min-width:       16px;
    height:          16px;
    padding:         0 3px;
    border-radius:   8px;
    background:      var(--color-red);
    color:           var(--color-white);
    font-size:       10px;
    font-weight:     var(--fw-bold);
    line-height:     1;
    display:         flex;
    align-items:     center;
    justify-content: center;
}

/* Favourite button active state (any page) */
.js-fav-trigger.is-active {
    color: var(--color-red);
}

/* WooCommerce default sets height: auto, which breaks absolutely-positioned object-fit: cover images */
.woocommerce img,
.woocommerce-page img {
    height: 100%;
}

/* Hidden JetCW trigger wrapper */
.product-card__jet-trigger {
    display:    none;
    visibility: hidden;
    position:   absolute;
}

/* ── Product card — shared across all pages ─────────────────────────────── */
.product-card {
    display: flex;
    flex-direction: column;
    width: 100%;
    border: 1px solid var(--color-border);
    gap: 16px;
    background: var(--color-white);
}

.product-card__img-wrap {
    position: relative;
    display: block;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-white);
    flex-shrink: 0;
}

.product-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.product-card:hover .product-card__img { transform: scale(1.06); }

.product-card__overlay {
    position: absolute;
    bottom: -60px;
    left: 0;
    width: 100%;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10.5px);
    -webkit-backdrop-filter: blur(10.5px);
    transition: bottom 0.3s ease;
    z-index: 1;
}

.product-card:hover .product-card__overlay { bottom: 0; }

.product-card__mobile-bar { display: none; }

.product-card__mobile-bar .product-card__swatches { gap: 2px; }

.product-card__body {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding-bottom: 16px;
}

.product-card__title {
    font-size: 16px;
    font-weight: var(--fw-medium);
    line-height: 1.4;
    color: var(--color-text);
    margin: 0;
    padding: 0 12px;
    min-height: calc(1.4em * 3);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.product-card__title a { color: inherit; text-decoration: none; }
.product-card__title a:hover { text-decoration: underline; }

.product-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 12px;
}

.product-card__price {
    font-size: 16px;
    font-weight: var(--fw-bold);
    color: var(--color-text);
    line-height: 1.4;
}

.product-card__price .woocommerce-Price-amount { font-weight: inherit; }

.product-card__actions { display: flex; align-items: center; gap: 16px; }

.product-card__fav {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text);
    transition: opacity var(--transition);
    line-height: 0;
}

.product-card__fav:hover  { opacity: 0.5; }
.product-card__fav.is-active { color: var(--color-red); }

.product-card__cart {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--color-dark);
    border: 1px solid var(--color-border);
    color: var(--color-white);
    text-decoration: none;
    cursor: pointer;
    flex-shrink: 0;
    transition: opacity var(--transition);
    line-height: 0;
}

.product-card__cart:hover { opacity: 0.85; }

@media (max-width: 767px) {
    .product-card { gap: 0; }
    .product-card__overlay { display: none; }
    .product-card__mobile-bar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: 30px;
        padding: 0 6px;
        background: rgba(255, 255, 255, 0.2);
        backdrop-filter: blur(11px);
        -webkit-backdrop-filter: blur(11px);
    }
    .product-card__fav--desktop { display: none; }
    .product-card__body { gap: 16px; padding-bottom: 8px; }
    .product-card__title {
        font-size: 14px;
        font-weight: var(--fw-regular);
        line-height: 1.2;
        -webkit-line-clamp: 3;
        min-height: calc(1.2em * 3);
        padding: 0 6px;
    }
    .product-card__footer { padding: 0 6px; }
    .product-card__price { font-size: 14px; }
    .product-card:hover .product-card__img { transform: none; }
}

/* ── Product card swatches — shared across all pages ────────────────────── */
.product-card__swatches {
    display: flex;
    align-items: center;
    gap: 4px;
}

.product-card__swatch {
    position: relative;
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.product-card__swatch::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.12);
    transition: border-color var(--transition), border-width var(--transition);
}

.product-card__swatch::after {
    content: '';
    position: absolute;
    inset: 3px;
    border-radius: 50%;
    background: var(--swatch-color, #ccc);
}

.product-card__swatch:hover::before,
.product-card__swatch.is-active::before {
    border-color: var(--color-text);
    border-width: 2px;
}

.product-card__swatch:hover { transform: scale(1.1); }

.product-card__swatch--sm {
    width: 15px;
    height: 15px;
}

.product-card__swatch--sm::after { inset: 2px; }

/* ── Product card badge ──────────────────────────────────────────────────── */
.product-card__badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--color-dark);
    color: var(--color-white);
    font-size: 12px;
    font-weight: var(--fw-medium);
    padding: 2px 8px;
    z-index: 1;
}

/* ── Product card prices ─────────────────────────────────────────────────── */
.product-card__prices {
    display: flex;
    align-items: center;
    gap: 6px;
}

.product-card__price--sale { color: var(--color-red, #e00); }
.product-card__price--old  {
    font-weight: var(--fw-regular);
    font-size: 13px;
    color: #999;
    text-decoration: line-through;
}

.site-header__cart-total {
    font-size:      18px;
    font-weight:    var(--fw-light);
    color:          var(--color-dark);
    letter-spacing: 0.02em;
    white-space:    nowrap;
}

.site-header__cart-total .woocommerce-Price-amount { font-weight: var(--fw-light); }

.site-header__burger {
    display:     none;
    background:  none;
    border:      none;
    padding:     0;
    cursor:      pointer;
    color:       var(--color-dark);
    flex-shrink: 0;
}

.mobile-menu {
    position:       fixed;
    inset:          0;
    z-index:        var(--z-modal);
    background:     var(--color-white);
    display:        flex;
    flex-direction: column;
    transform:      translateX(-100%);
    transition:     transform 0.3s ease;
    overflow:       hidden;
}

.mobile-menu.is-open { transform: translateX(0); }

.site-header__burger-icon      { display: flex; align-items: center; }
.site-header__burger-close     { display: none; align-items: center; }
.site-header__burger-back-icon { display: none; align-items: center; }

body.menu-open .site-header {
    z-index: calc(var(--z-modal) + 1);
}

body.menu-open .site-header__burger-icon       { display: none; }
body.menu-open .site-header__burger-close      { display: flex; }
body.menu-subpanel .site-header__burger-close-icon { display: none; }
body.menu-subpanel .site-header__burger-back-icon  { display: flex; }

.mobile-menu__panels {
    flex:     1;
    position: relative;
    overflow: hidden;
}

.mobile-menu__panel {
    position:       absolute;
    inset:          0;
    transform:      translateX(100%);
    transition:     transform 0.3s ease;
    overflow-y:     auto;
    background:     #f8f8f8;
    padding:        16px 24px 20px;
    display:        flex;
    flex-direction: column;
    gap:            8px;
}

.mobile-menu__panel.is-active { transform: translateX(0); }
.mobile-menu__panel.is-prev   { transform: translateX(-30%); }

.mobile-menu__panel-title {
    font-size:      16px;
    font-weight:    var(--fw-medium);
    color:          var(--color-dark);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin:         0;
    flex-shrink:    0;
}

.mobile-menu__panel-divider {
    height:       1px;
    background:   var(--color-border);
    flex-shrink:  0;
}

.mobile-menu__nav {
    display:        flex;
    flex-direction: column;
    gap:            8px;
}

.mobile-menu__separator {
    height:      1px;
    background:  var(--color-border);
    flex-shrink: 0;
}

.mobile-menu__lang-row {
    display:          flex;
    align-items:      center;
    height:           40px;
    padding:          0 12px;
    gap:              8px;
    background-color: var(--color-bg-menu);
    border-radius:    6px;
    border:           none;
    width:            100%;
    cursor:           pointer;
    color:            var(--color-dark);
    transition:       background-color var(--transition);
    flex-shrink:      0;
}

.mobile-menu__lang-row:hover { background-color: var(--color-border); }

.mobile-menu__lang-row-label {
    flex:        1;
    font-size:   17px;
    font-weight: var(--fw-light);
    text-align:  left;
}

.mobile-menu__lang-row-globe,
.mobile-menu__lang-row-arrow { flex-shrink: 0; }

.mobile-menu__panel--eshop {
    gap:            16px;
    padding-inline: 0;
}

.mobile-menu__panel--eshop .mobile-menu__panel-title,
.mobile-menu__panel--eshop .mobile-menu__panel-divider,
.mobile-menu__panel--eshop .mobile-menu__all-btn {
    margin-inline: 24px;
}

.mobile-menu__categories {
    display:                    flex;
    gap:                        5px;
    overflow-x:                 auto;
    scroll-snap-type:           x mandatory;
    scroll-padding-left:        24px;
    -webkit-overflow-scrolling: touch;
    flex-shrink:                0;
    padding-left:               24px;
}

.mobile-menu__categories::-webkit-scrollbar { display: none; }

.mobile-menu__cat-card {
    position:              relative;
    display:               block;
    flex-shrink:           0;
    width:                 140px;
    height:                237px;
    overflow:              hidden;
    text-decoration:       none;
    scroll-snap-align:     start;
    background-color:      var(--color-dark);
    background-size:       cover;
    background-position:   center;
    background-repeat:     no-repeat;
}

.mobile-menu__cat-card::after {
    content:        '';
    position:       absolute;
    inset:          0;
    background:     linear-gradient(to bottom, transparent 30%, rgba(0,0,0,0.35));
    pointer-events: none;
    z-index:        1;
}


.mobile-menu__cat-name {
    position:    absolute;
    bottom:      14px;
    left:        50%;
    transform:   translateX(-50%);
    border:      1px solid rgba(255, 255, 255, 0.75);
    padding:     4px 8px;
    font-size:   11px;
    font-weight: var(--fw-regular);
    color:       var(--color-white);
    white-space: nowrap;
    z-index:     2;
}

.mobile-menu__all-btn {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             10px;
    height:          50px;
    padding:         0 16px;
    border:          1px solid var(--color-border);
    font-size:       14px;
    font-weight:     var(--fw-light);
    color:           var(--color-dark);
    text-decoration: none;
    text-transform:  uppercase;
    letter-spacing:  0.08em;
    flex-shrink:     0;
    transition:      background-color var(--transition);
}

.mobile-menu__all-btn svg  { flex-shrink: 0; }
.mobile-menu__all-btn:hover { background-color: var(--color-bg-menu); opacity: 1; }

/* ── Mega menu (desktop E-shop dropdown) ─────────────────────────────────── */

.mega-menu {
    position:   absolute;
    top:        100%;
    left:       0;
    right:      0;
    background: var(--color-bg-menu);
    z-index:    var(--z-dropdown);
    opacity:         0;
    pointer-events:  none;
    transform:       translateY(-6px);
    transition:      opacity var(--transition), transform var(--transition);
}

.mega-menu.is-open {
    opacity:        1;
    pointer-events: auto;
    transform:      translateY(0);
}

.mega-menu__inner {
    display:        flex;
    flex-direction: column;
    gap:            16px;
    max-width:      1840px;
    margin-inline:  auto;
    padding:        40px 20px;
}

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

.mega-menu__title {
    font-size:      16px;
    font-weight:    var(--fw-medium);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color:          var(--color-dark);
}

.mega-menu__divider {
    height:     1px;
    background: var(--color-border);
    flex-shrink: 0;
}

.mega-menu__grid {
    display:            flex;
    gap:                10px;
    overflow-x:         auto;
    scroll-snap-type:   x mandatory;
    -webkit-overflow-scrolling: touch;
}

.mega-menu__card {
    flex-shrink:        0;
    width:              250px;
    height:             420px;
    position:           relative;
    overflow:           hidden;
    background-color:   var(--color-dark);
    background-size:    cover;
    background-position: center;
    background-repeat:  no-repeat;
    text-decoration:    none;
    transition:         transform 0.4s ease;
    scroll-snap-align:  start;
}

.mega-menu__card:hover { transform: scale(1.02); }

.mega-menu__card::after {
    content:        '';
    position:       absolute;
    inset:          0;
    background:     linear-gradient(to bottom, transparent 30%, rgba(0,0,0,0.3));
    pointer-events: none;
}

.mega-menu__card-name {
    position:   absolute;
    top:        337px;
    left:       50%;
    transform:  translateX(-50%);
    border:     1px solid #fff;
    padding:    10px;
    font-size:  18px;
    font-weight: var(--fw-regular);
    color:      #fff;
    white-space: nowrap;
    z-index:    1;
}

.mega-menu-info {
    position:       absolute;
    top:            100%;
    left:           0;
    width:          283px;
    background:     var(--color-bg-menu);
    padding:        6px;
    z-index:        var(--z-dropdown);
    opacity:        0;
    pointer-events: none;
    transition:     opacity var(--transition);
}

.mega-menu-info.is-open {
    opacity:        1;
    pointer-events: auto;
}

.mega-menu-info__link {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    height:          52px;
    padding:         14px 16px;
    font-size:       16px;
    font-weight:     var(--fw-regular);
    color:           var(--color-black);
    text-decoration: none;
    letter-spacing:  0.02em;
    white-space:     nowrap;
    transition:      background-color var(--transition);
}

.mega-menu-info__link:hover {
    background-color: rgba(0, 0, 0, 0.04);
}

.mega-menu-info__arrow {
    flex-shrink: 0;
    opacity:     0.5;
}

.mega-menu-kontakt {
    position:       absolute;
    top:            100%;
    left:           0;
    width:          320px;
    background:     var(--color-bg-menu);
    padding:        16px;
    display:        flex;
    flex-direction: column;
    gap:            10px;
    z-index:        var(--z-dropdown);
    opacity:        0;
    pointer-events: none;
    transition:     opacity var(--transition);
}

.mega-menu-kontakt.is-open {
    opacity:        1;
    pointer-events: auto;
}

.kontakt-card {
    display:        flex;
    flex-direction: column;
    gap:            12px;
    padding:        14px;
    background:     var(--color-white);
    border:         1px solid var(--color-border);
    width:          100%;
}

.kontakt-card__title {
    font-size:      14px;
    font-weight:    var(--fw-medium);
    color:          var(--color-black);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.kontakt-card__text {
    font-size:      14px;
    font-weight:    var(--fw-light);
    color:          var(--color-black);
    letter-spacing: 0.05em;
}

.kontakt-card__row {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             12px;
}

.kontakt-card__email {
    display:         flex;
    align-items:     center;
    gap:             10px;
    font-size:       14px;
    font-weight:     var(--fw-light);
    color:           var(--color-black);
    text-decoration: none;
    letter-spacing:  0.05em;
}

.kontakt-card__socials {
    display:     flex;
    align-items: center;
    gap:         12px;
    flex-shrink: 0;
}

.kontakt-card__social {
    display:     flex;
    align-items: center;
    color:       var(--color-black);
    transition:  opacity var(--transition);
}

.kontakt-card__social:hover { opacity: 0.7; }

/* ─────────────────────────────────────────────────────────────────────────── */

.mobile-menu__contact-card {
    display:        flex;
    flex-direction: column;
    gap:            12px;
    padding:        14px;
    border:         1px solid var(--color-border);
    border-radius:  6px;
    background:     var(--color-white);
    flex-shrink:    0;
}

.mobile-menu__contact-row {
    display:         flex;
    align-items:     center;
    gap:             10px;
    font-size:       15px;
    font-weight:     var(--fw-light);
    color:           var(--color-dark);
    text-decoration: none;
    transition:      opacity var(--transition);
}

.mobile-menu__contact-row svg { flex-shrink: 0; color: var(--color-muted); }
.mobile-menu__contact-row:hover { opacity: 0.7; }

.mobile-lang-list {
    display:        flex;
    flex-direction: column;
    gap:            8px;
    list-style:     none;
    margin:         0;
    padding:        0;
}

.mobile-lang-list li { display: block; }

.mobile-lang-list a {
    display:          flex;
    align-items:      center;
    justify-content:  center;
    height:           40px;
    background-color: var(--color-bg-menu);
    border-radius:    6px;
    font-size:        17px;
    font-weight:      var(--fw-light);
    color:            var(--color-dark);
    text-decoration:  none;
    transition:       background-color var(--transition);
}

.mobile-lang-list .is-active a {
    background-color: var(--color-dark);
    color:            var(--color-white);
}

.mobile-lang-list a:hover { background-color: var(--color-border); opacity: 1; }

/* ── Header search ─────────────────────────────────────────────────────── */

.site-header__container {
    position: relative;
    z-index: 2;
}

.header-search {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    z-index: 1;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.3s ease, opacity 0.3s ease, visibility 0.3s;
    pointer-events: none;
}

.header-search.is-open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.header-search__inner {
    padding-top: 24px;
    padding-bottom: 24px;
    max-height: calc(100vh - var(--header-main-height, 70px) - var(--header-top-height, 0px) - 48px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.header-search__form {
    display: flex;
    align-items: center;
    border: 1px solid var(--color-border);
    transition: border-color var(--transition);
}

.header-search__form:focus-within {
    border-color: var(--color-dark);
}

.header-search__input {
    flex: 1;
    height: 50px;
    padding: 10px 24px;
    font-size: 16px;
    font-family: inherit;
    color: var(--color-black);
    background: none;
    border: none;
    outline: none;
}

.header-search__input::placeholder {
    color: rgba(0, 0, 0, 0.4);
}

.header-search__submit {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: none;
    border: none;
    color: var(--color-black);
    cursor: pointer;
    transition: opacity var(--transition);
}

.header-search__submit:hover {
    opacity: 0.6;
}

.header-search__results {
    margin-top: 16px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 24px;
}

.header-search__results[hidden] { display: none; }

.search-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border);
    text-decoration: none;
    transition: opacity var(--transition);
}

.search-item:last-of-type {
    border-bottom: none;
}

.search-item:hover {
    opacity: 0.7;
}

.search-item__img {
    flex-shrink: 0;
    width: 80px;
    height: 80px;
    object-fit: cover;
    border: 1px solid var(--color-border);
}

.search-item__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.search-item__name {
    font-size: 14px;
    font-weight: var(--fw-medium);
    color: var(--color-black);
    line-height: 1.4;
}

.search-item__price {
    font-size: 14px;
    color: rgba(0, 0, 0, 0.6);
}

.header-search__view-all {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 16px;
    height: 44px;
    padding: 10px 24px;
    font-size: 14px;
    font-family: inherit;
    font-weight: var(--fw-regular);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--color-black);
    background: transparent;
    border: 1px solid var(--color-black);
    text-decoration: none;
    transition: all var(--transition);
}

.header-search__view-all:hover {
    background: var(--color-black);
    color: var(--color-white);
}

.header-search__empty {
    grid-column: 1 / -1;
    margin: 0;
    padding: 24px 0;
    text-align: center;
    font-size: 14px;
    color: rgba(0, 0, 0, 0.5);
}


/* ── Search results page ───────────────────────────────────────────────── */

.search-page {
    padding: 40px 0 80px;
}

.search-page__title {
    margin: 0 0 8px;
    font-size: 24px;
    font-weight: var(--fw-semibold);
    line-height: 1.4;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    text-align: center;
    color: var(--color-black);
}

.search-page__query {
    font-weight: var(--fw-regular);
    text-transform: none;
    letter-spacing: 0;
}

.search-page__count {
    margin: 0 0 40px;
    text-align: center;
    font-size: 14px;
    color: rgba(0, 0, 0, 0.5);
}

.search-page__empty {
    text-align: center;
    padding: 60px 0;
}

.search-page__empty p {
    margin: 0 0 24px;
    font-size: 16px;
    color: rgba(0, 0, 0, 0.5);
}

.search-page__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 50px;
    padding: 10px 40px;
    font-size: 16px;
    font-family: inherit;
    font-weight: var(--fw-regular);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--color-white);
    background: var(--color-black);
    border: 1px solid var(--color-black);
    text-decoration: none;
    transition: opacity var(--transition);
}

.search-page__btn:hover {
    opacity: 0.85;
    color: var(--color-white);
}

/* ── 404 page ──────────────────────────────────────────────────────────── */

.page-404 {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 80px 0 120px;
}

.page-404__code {
    font-size: 160px;
    font-weight: var(--fw-semibold);
    line-height: 1;
    letter-spacing: 8px;
    color: var(--color-border);
    margin-bottom: 24px;
}

.page-404__title {
    margin: 0 0 16px;
    font-size: 32px;
    font-weight: var(--fw-semibold);
    line-height: 1.3;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    color: var(--color-black);
}

.page-404__text {
    margin: 0 0 40px;
    font-size: 16px;
    line-height: 1.6;
    color: rgba(0, 0, 0, 0.5);
    max-width: 480px;
}

.page-404__actions {
    display: flex;
    gap: 16px;
}

.page-404__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 50px;
    padding: 10px 40px;
    font-size: 16px;
    font-family: inherit;
    font-weight: var(--fw-regular);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--color-white);
    background: var(--color-black);
    border: 1px solid var(--color-black);
    text-decoration: none;
    cursor: pointer;
    transition: opacity var(--transition);
}

.page-404__btn:hover {
    opacity: 0.85;
    color: var(--color-white);
}

.page-404__btn--outline {
    color: var(--color-black);
    background: transparent;
}

.page-404__btn--outline:hover {
    color: var(--color-black);
}

@media (max-width: 767px) {
    .header-search__results { grid-template-columns: 1fr; }
    .search-page { padding: 24px 0 48px; }
    .search-page__title { font-size: 20px; }
    .search-page__count { margin-bottom: 24px; }
    .page-404 { padding: 48px 0 64px; }
    .page-404__code { font-size: 100px; letter-spacing: 4px; }
    .page-404__title { font-size: 24px; }
    .page-404__actions { flex-direction: column; width: 100%; }
    .page-404__btn { width: 100%; }
}

body.menu-open,
body.search-open { overflow: hidden; }

@media (max-width: 1399px) {
    .site-header__left    { gap: 24px; }
    .site-header__nav-link,
    .site-header__nav-btn { font-size: 15px; padding: 8px; }
    .header-top__text     { font-size: 14px; }
}

@media (max-width: 1023px) {
    .header-top__text { font-size: 13px; }
}

@media (max-width: 1023px) {
    .site-header__nav        { display: none; }
    .site-header__burger     { display: flex; }
    .site-header__container  { padding-inline: 24px; }
    .site-header__left       { gap: 0; }
    .site-header__logo       { margin-inline: auto 0; padding-left: 16px; }
    .site-header__cart-total { display: none; }
}

@media (max-width: 767px) {
    .header-top            { height: auto; min-height: 0; }
    .header-top__container { padding: 10px 26px 10px 16px; min-height: 0; height: auto; }
    .header-top__inner     { height: auto; min-height: 0; padding-block: 0; align-items: flex-start; gap: 10px; }
    .header-top__text      { font-size: 12px; font-weight: var(--fw-light); text-align: left; text-transform: none; padding-inline: 0; white-space: normal; overflow: visible; text-overflow: clip; word-break: break-word; }
    .header-top__email     { display: none; }
    .lang-dropdown         { display: none; }
    .header-top__close     { display: flex; margin-top: 1px; }

    .site-header__actions { gap: 20px; }
    .site-header__btn     { width: 17px; height: 17px; }
    .site-header__btn svg { width: 17px; height: 17px; }
    .site-header          { height: 50px; }
}

/* ── Header cart popup ──────────────────────────────────────────────────── */

.cart-popup {
    position:       fixed;
    top:            var(--header-height);
    right:          0;
    width:          460px;
    max-width:      calc(100vw - 40px);
    max-height:     calc(100vh - var(--header-height) - 24px);
    overflow-y:     auto;
    background:     var(--color-white);
    border:         1px solid var(--color-border);
    z-index:        var(--z-dropdown);
    opacity:        0;
    pointer-events: none;
    transform:      translateX(100%);
    transition:     opacity var(--transition), transform var(--transition);
}

.cart-popup.is-open {
    opacity:        1;
    pointer-events: auto;
    transform:      translateX(0);
}

.cart-popup.is-busy .cart-popup__body { opacity: 0.5; pointer-events: none; }

.cart-popup__header {
    position:        sticky;
    top:             0;
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             16px;
    padding:         24px 30px;
    background:      var(--color-bg-menu);
    border-bottom:   1px solid var(--color-border);
}

.cart-popup__title {
    display:        flex;
    align-items:    center;
    gap:            12px;
    font-size:      24px;
    font-weight:    var(--fw-medium);
    text-transform: uppercase;
    color:          var(--color-black);
}

.cart-popup__close {
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           32px;
    height:          32px;
    background:      none;
    border:          none;
    padding:         0;
    cursor:          pointer;
    color:           var(--color-dark);
    flex-shrink:     0;
    transition:      opacity var(--transition);
}

.cart-popup__close:hover { opacity: 0.65; }

.cart-popup__items {
    display:        flex;
    flex-direction: column;
    padding:        24px 30px 0;
}

.cart-popup__item {
    display:        flex;
    gap:            16px;
    padding-bottom: 24px;
}

.cart-popup__item:not(:last-child) {
    margin-bottom: 24px;
    border-bottom: 1px solid var(--color-border);
}

.cart-popup__item-image {
    display:     block;
    flex-shrink: 0;
    width:       110px;
    height:      110px;
    border:      1px solid var(--color-border);
    background:  var(--color-white);
    overflow:    hidden;
}

.cart-popup__item-image img {
    display:    block;
    width:      100%;
    height:     100%;
    object-fit: cover;
}

.cart-popup__item-info {
    display:        flex;
    flex-direction: column;
    gap:            16px;
    flex:           1 1 0;
    min-width:      0;
}

.cart-popup__item-title {
    font-size:       16px;
    font-weight:     var(--fw-medium);
    line-height:     1.4;
    color:           var(--color-black);
    text-decoration: none;
    transition:      opacity var(--transition);
}

.cart-popup__item-title:hover { opacity: 0.65; }

.cart-popup__item-attrs {
    display:        flex;
    flex-direction: column;
    gap:            12px;
    font-size:      16px;
    line-height:    1.4;
    color:          var(--color-black);
}

.cart-popup__item-attr-label { color: var(--color-muted); }

.cart-popup__item-row {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             16px;
    margin-top:      auto;
}

.cart-popup__qty {
    display:     flex;
    align-items: center;
    gap:         10px;
    height:      36px;
    padding:     0 16px;
    border:      1px solid var(--color-border);
}

.cart-popup__qty-btn {
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           24px;
    height:          24px;
    background:      none;
    border:          none;
    padding:         0;
    cursor:          pointer;
    color:           var(--color-dark);
    transition:      opacity var(--transition);
}

.cart-popup__qty-btn:hover { opacity: 0.65; }

.cart-popup__qty-value {
    min-width:   16px;
    font-size:   16px;
    font-weight: var(--fw-semibold);
    text-align:  center;
    color:       var(--color-black);
}

.cart-popup__item-price {
    font-size:   16px;
    font-weight: var(--fw-medium);
    color:       var(--color-black);
    white-space: nowrap;
}

.cart-popup__footer {
    position:       sticky;
    bottom:         0;
    display:        flex;
    flex-direction: column;
    gap:            14px;
    padding:        24px 30px 30px;
    background:     var(--color-white);
    border-top:     1px solid var(--color-border);
}

.cart-popup__total {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    font-size:       16px;
    line-height:     1.4;
    color:           var(--color-black);
}

.cart-popup__total-label { font-weight: var(--fw-medium); }
.cart-popup__total-value { font-weight: var(--fw-bold); }

.cart-popup__checkout {
    display:         flex;
    align-items:     center;
    justify-content: center;
    height:          56px;
    background:      var(--color-black);
    border:          1px solid var(--color-black);
    color:           var(--color-white);
    font-size:       16px;
    text-transform:  uppercase;
    letter-spacing:  0.8px;
    text-decoration: none;
    transition:      opacity var(--transition);
}

.cart-popup__checkout:hover { opacity: 0.85; }

.cart-popup__empty {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            16px;
    padding:        40px 30px;
    text-align:     center;
}

.cart-popup__empty-text {
    font-size: 16px;
    color:     var(--color-dark);
}

.cart-popup__empty-cta {
    display:         inline-flex;
    align-items:     center;
    gap:             8px;
    font-size:       14px;
    font-weight:     var(--fw-medium);
    text-transform:  uppercase;
    letter-spacing:  0.05em;
    color:           var(--color-black);
    text-decoration: none;
    transition:      opacity var(--transition);
}

.cart-popup__empty-cta:hover { opacity: 0.65; }

@media (max-width: 1023px) {
    .cart-popup {
        width:     60vw;
        max-width: 60vw;
    }
}

@media (max-width: 767px) {
    .cart-popup {
        position:   fixed;
        inset:      0;
        width:      100%;
        max-width:  100%;
        max-height: 100vh;
        border:     none;
        z-index:    var(--z-modal);
        transform:  translateX(100%);
    }

    .cart-popup.is-open { transform: translateX(0); }

    body.cart-popup-open { overflow: hidden; }
}

/* ── Site Footer ─────────────────────────────────────────────────────────── */

.site-footer {
    background:  var(--color-white);
    border-top:  1px solid var(--color-border);
}

.container {
    max-width:      1840px;
    margin-inline:  auto;
    padding-inline: 20px;
}

.site-footer__main {
    display:     flex;
    align-items: stretch;
}

.site-footer__brand {
    display:         flex;
    flex-direction:  column;
    gap:             24px;
    padding:         40px 60px 40px 0;
    flex:            0 0 360px;
    border-right:    1px solid var(--color-border);
    overflow:        hidden;
}

.site-footer__logo-link { display: block; line-height: 0; }

.site-footer__logo {
    height:    30px;
    width:     auto;
    max-width: 200px;
}

.site-footer__desc {
    font-size:   14px;
    font-weight: var(--fw-light);
    color:       #62666f;
    line-height: 1.4;
    margin:      0;
}

.site-footer__cols {
    display: flex;
    flex:    1;
    min-width: 0;
}

.site-footer__col {
    display:        flex;
    flex-direction: column;
    gap:            24px;
    padding:        40px 40px 40px 60px;
    flex:           1;
    border-right:   1px solid var(--color-border);
    overflow:       hidden;
    min-width:      0;
}

.site-footer__col:last-child {
    border-right:  none;
    padding-right: 0;
}

.site-footer__col-title {
    font-size:      16px;
    font-weight:    var(--fw-bold);
    color:          var(--color-dark);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin:         0;
    flex-shrink:    0;
}

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

.site-footer__nav-list li { display: block; }

.site-footer__nav-list a {
    display:         block;
    padding:         10px 0;
    font-size:       14px;
    font-weight:     var(--fw-regular);
    color:           #62666f;
    text-decoration: none;
    letter-spacing:  0.04em;
    transition:      color var(--transition);
    line-height:     1.4;
}

.site-footer__nav-list a:hover { color: var(--color-dark); }

.site-footer__contact {
    display:        flex;
    flex-direction: column;
    gap:            0;
}

.site-footer__contact-email {
    display:         flex;
    align-items:     center;
    gap:             10px;
    font-size:       14px;
    font-weight:     var(--fw-light);
    color:           var(--color-dark);
    text-decoration: none;
    letter-spacing:  0.044em;
    transition:      opacity var(--transition);
}

.site-footer__contact-email:hover { opacity: 0.7; }

.site-footer__follow {
    display:        flex;
    flex-direction: column;
    gap:            16px;
}

.site-footer__follow-title {
    font-size:      14px;
    font-weight:    var(--fw-bold);
    color:          var(--color-dark);
    letter-spacing: 0.04em;
    line-height:    1.4;
    margin:         0;
}

.site-footer__socials {
    display:     flex;
    align-items: center;
    gap:         12px;
}

.site-footer__social {
    display:         flex;
    align-items:     center;
    color:           var(--color-dark);
    text-decoration: none;
    transition:      opacity var(--transition);
}

.site-footer__social:hover { opacity: 0.7; }

.site-footer__delivery,
.site-footer__payment {
    display:        flex;
    flex-direction: column;
    gap:            16px;
}

.site-footer__col-text {
    font-size:      14px;
    font-weight:    var(--fw-regular);
    color:          #62666f;
    letter-spacing: 0.04em;
    margin:         0;
}

.site-footer__logos {
    display:     flex;
    align-items: center;
    gap:         12px;
    flex-wrap:   wrap;
}

.site-footer__carrier-logo {
    width:      auto;
    object-fit: contain;
    display:    block;
}

.site-footer__payment-icons {
    display:     flex;
    align-items: center;
    gap:         8px;
    flex-wrap:   wrap;
}

.site-footer__payment-icon {
    height:     30px;
    width:      auto;
    display:    block;
    object-fit: contain;
}

.site-footer__terms {
    display:       flex;
    align-items:   center;
    justify-content: space-between;
    height:        50px;
    border-top:    1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.site-footer__copy {
    font-size:      14px;
    font-weight:    var(--fw-regular);
    color:          var(--color-dark);
    letter-spacing: 0.04em;
    margin:         0;
    white-space:    nowrap;
}

.site-footer__privacy-nav { line-height: 0; }

.site-footer__privacy-list {
    display:     flex;
    align-items: center;
    gap:         16px;
    list-style:  none;
    margin:      0;
    padding:     0;
}

.site-footer__privacy-list li { display: block; }

.site-footer__privacy-list a {
    font-size:       14px;
    font-weight:     var(--fw-regular);
    color:           var(--color-dark);
    text-decoration: none;
    letter-spacing:  0.04em;
    white-space:     nowrap;
    transition:      opacity var(--transition);
}

.site-footer__privacy-list a:hover { opacity: 0.7; }

.site-footer__bg-text {
    display:         flex;
    justify-content: center;
    line-height:     0;
    overflow:        hidden;
    margin-top:      30px;
    padding-inline:  20px;
}

.site-footer__bg-img {
    max-width: 1496px;
    width:     100%;
    height:    auto;
    display:   block;
}

@media (max-width: 1399px) {
    .site-footer__col   { padding-left: 40px; }
    .site-footer__brand { flex: 0 0 300px; padding-right: 40px; }
}

@media (min-width: 768px) and (max-width: 1023px) {
    .site-footer__brand {
        flex:    0 0 240px;
        padding: 24px 32px 24px 0;
        gap:     16px;
    }

    .site-footer__cols {
        display:               grid;
        grid-template-columns: 1fr 1fr;
    }

    .site-footer__col {
        padding:       24px;
        border-right:  none;
        border-bottom: 1px solid var(--color-border);
        gap:           16px;
    }

    .site-footer__col:nth-child(odd)  { border-right: 1px solid var(--color-border); }
    .site-footer__col:nth-last-child(-n+2) { border-bottom: none; }

    .site-footer__col:last-child { padding-right: 24px; }

    .site-footer__terms {
        height:        auto;
        min-height:    50px;
        flex-wrap:     wrap;
        gap:           8px;
        padding-block: 12px;
    }

    .site-footer__bg-img { max-width: 100%; }
}

@media (max-width: 767px) {
    .site-footer__main {
        flex-direction: column;
        height:         auto;
    }

    .site-footer__brand {
        flex:          1 1 auto;
        width:         100%;
        padding:       16px 0 24px;
        border-right:  none;
        border-bottom: 1px solid var(--color-border);
        gap:           16px;
    }

    .site-footer__logo { height: 20px; max-width: 133px; }

    .site-footer__cols {
        display:        flex;
        flex-direction: column;
    }

    .site-footer__col {
        flex:          1 1 auto;
        padding:       16px 0 24px;
        border-right:  none;
        border-bottom: 1px solid var(--color-border);
        gap:           16px;
    }

    .site-footer__col:last-child {
        border-bottom: none;
        padding-right: 0;
    }

    .site-footer__terms {
        height:        auto;
        min-height:    50px;
        flex-wrap:     wrap;
        gap:           8px;
        padding-block: 12px;
    }

    .site-footer__bg-img { max-width: 100%; }
}
