:root {
    --bg: #0f1115;
    --panel: #f3f0f0;
    --surface: #0c1017;
    --text: #e6e9ef;
    --muted: #9aa3b6;
    --brand: #4f8cff;
    --border: #212733;
    --radius: 14px;
    --shadow: 0 10px 30px rgba(233, 233, 233, 0.35);
    --speed: 320ms;
    --fade: 160ms;
    --easing: cubic-bezier(.2, .75, .25, 1);
    --content-max: 1340px;
    --gutter: 16px;
    --site-header-h: 60px;
    --panelPx: 360px;
    --d2-col-max: 320px;
    --liner-skel-color: #dbdde3;
    --skel-color: #e6e9ef;

    /* Right offset so fixed filters align to the container’s right edge */
    --wrap-right: 10px;
    --siteHeaderH: 60px;
}

#plp_container{
    --panelPx: 360px;
    position: relative;
}


#plp_container .plp-searchbar{
    position: sticky;
    top: var(--siteHeaderH);
    z-index: 600;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.06);
    border-bottom: 1px solid #eee;
}


#plp_container .plp-searchbar,
#plp_container .search-header-spacer{
    transition: height .18s ease, top .18s ease;
}


#plp_container .search-header-spacer{
    height: 0;
}


#plp_container .wrap{
    max-width: 1400px;
    margin: 0 auto;
    padding: 0;
}



@font-face {
    font-family: jpa;
    src: url('../../public/fonts/ttf/IRANSansWebFaNum.ttf');
}

@media (prefers-reduced-motion:reduce) {
    :root {
        --speed: 0ms;
        --fade: 0ms;
    }
}
#searchHeader{ position:static !important; }
body{ overflow-y:auto; }
#plp_container{ overflow:visible; }


body {
    margin: 0;
    background: #fff;
    color: #000;
    font: 500 15px/1.55 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
    font-family: jpa !important;
    overflow-x: hidden;
}

a {
    color: inherit;
    text-decoration: none
}

.wrap {
    direction: ltr;
    margin-inline: auto;
    padding: 0 var(--gutter)
}

#plp_container {
    width: 100%;
    height: 100%;
    margin: 0;
    background: #fff;
    font: 500 15px/1.55 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
    font-family: jpa !important;
    overflow-x: hidden;
    /* keep content below fixed site header */
}

/* === Fixed Site Header (60px) === */
.site-header {
    position: fixed;
    inset: 0 0 auto 0;
    height: var(--site-header-h);
    z-index: 130;
    background: #0e121a;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
}

.site-header .bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 0px;
    background: #f6f6f6;
    color: #000000;
    font-family: "jpa";
    padding: 9px 14px;
    border-radius: 12px;
    cursor: pointer;
    transition: background var(--speed) var(--easing), transform 120ms ease
}

.btn:hover {
    background: #dddde4;
}

.btn:active {
    transform: translateY(1px)
}

/* === Search Header (FIXED under site header, with spacer) === */
.search-header {
    direction: ltr;
    position: fixed;
    left: 0;
    right: 0;
    top: var(--site-header-h);
    z-index: 120;
    background: rgb(255, 255, 255);
    backdrop-filter: blur(10px);
    /* border-bottom:1px solid var(--border); */
    box-shadow: 0px 4px 10px rgba(124, 124, 124, 0.5);
    transform: translateY(0);
    transition: transform var(--speed) var(--easing);
    will-change: transform;
}

.search-header.is-hidden {
    transform: translateY(calc(-100% - 1px));
}

/* slide out of view */
.search-header .row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0
}

/* Spacer reserves layout under fixed search header when visible */
.search-header-spacer {
    direction: ltr;
    height: 0;
    transition: height var(--speed) var(--easing)
}

/* Category bar (Swiper) */
.catbar {
    padding: 10px 0 12px;
    border-top: 1px solid rgba(255, 255, 255, .04)
}

.catbar-inner {
    display: flex;
    align-items: center;
    gap: 8px
}
/* test */
.catbtn {
    flex: 0 0 auto;
    border: 0px;
    background: #f6f6f6;
    color: crimson;
    border-radius: 999px;
    padding: 7px 9px;
    font-weight: 700;
    cursor: pointer
}

.catbtn[disabled] {
    color: #000000;
    opacity: .5;
    cursor: not-allowed
}

.swiper {
    flex: 1 1 auto
}

.swiper-free-mode>.swiper-wrapper{
    width: 100%;
    display: flex;
    justify-content: center;
}
.swiper-wrapper {
    align-items: center
}

.swiper-slide {
    width: auto
}

.pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: #f6f6f6;
    border-radius: 12px;
    color: #000000;
    white-space: nowrap;
    cursor: pointer;
    transition: background var(--speed) var(--easing), transform 120ms ease, color var(--speed);
    font-family: 'jpa' !important;
    border: 2px solid transparent;
}

.pill:hover {
    background: #dddde4
}

.pill.active {
    color: #0b0e14;
    border-color: #c5c5cb;
    background: #eaeaf1;
    font-weight: 600;
}

.pill .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: currentColor;
    opacity: .85
}

.pill-skel {
    height: 30px;
    width: 84px;
    border-radius: 999px;
    background: var(--skel-color);
    position: relative;
    overflow: hidden;
    margin-right: 8px;
    display: inline-block
}

.pill-skel::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, var(--liner-skel-color), transparent);
    animation: shimmer 1.1s infinite
}

/* === Filter facet skeletons === */
.facet-skel {
    display: grid;
    gap: 10px;
    margin: 6px 0;
}

.facet-skel .row {
    height: 14px;
    border-radius: 8px;
    background: var(--skel-color);
    position: relative;
    overflow: hidden;
}

.facet-skel .row::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, var(--liner-skel-color), transparent);
    animation: shimmer 1.1s infinite;
}

.facet-group-title {
    height: 12px;
    width: 38%;
    border-radius: 6px;
    background: var(--skel-color);
    margin: 10px 0 6px;
    position: relative;
    overflow: hidden;
}

.facet-group-title::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, var(--liner-skel-color), transparent);
    animation: shimmer 1.1s infinite;
}

@keyframes shimmer {
    100% {
        transform: translateX(100%)
    }
}

/* Shell / Products */
.shell {
    position: relative;
    display: block;
    min-height: calc(100vh - var(--site-header-h));
    padding: 16px 0;
    overflow: hidden
}

.products {
    width: 100%;
    transition: width var(--speed) var(--easing)
}

.results-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 8px 0 12px
}

.muted {
    color: var(--muted)
}

.cards {
    display: grid;
    gap: 12px;
    transition: gap var(--speed) var(--easing), opacity var(--fade) ease;
    justify-content: center;
}

.cards.is-crossfading {
    opacity: 0.01
}

/* GRID PRESETS */
@media (min-width:901px) {
    #plp_container.grid-2 .cards {
        grid-template-columns: repeat(2, minmax(220px, min(100%, var(--d2-col-max))))
    }

    #plp_container.grid-4 .cards {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }

    #plp_container.grid-8 .cards {
        grid-template-columns: repeat(8, minmax(140px, 1fr))
    }

    #plp_container.filters-open.grid-8 .cards {
        grid-template-columns: repeat(8, minmax(120px, 1fr));
        /* optional: tighten gaps a bit if you still see a squeeze */
        /* gap: 10px; */
    }
}

@media (max-width:900px) {
    #plp_container.grid-2 .cards {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    #plp_container.grid-4 .cards {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }

    #plp_container.grid-4 .card .body {
        display: none
    }

    /* image-only on mobile at 4 cols */
}

.card {
    background-color: rgb(56, 56, 56);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: transform var(--speed) var(--easing), opacity var(--speed) var(--easing)
}

.products.animating .card {
    transform: scale(.985);
    opacity: .98
}

.thumb {
    aspect-ratio: 173/258;
    background: #0c111a;
    display: flex;
    align-items: center;
    justify-content: center
}

.thumb img {
    max-width: 100%;
    max-height: 100%;
    display: block
}

.body {
    padding: 10px;
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: end;
}

.title {
    font-size: 10px !important;
    font-weight: 700;
    line-height: 1.35;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}

.meta {
    margin-top: 6px;
    color: #9aa3b6;
    font-size: 13px
}

/* Card skeletons */
.card.skel .thumb {
    position: relative;
    background: var(--skel-color);
    overflow: hidden
}

.card.skel .thumb::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, var(--liner-skel-color), transparent);
    animation: shimmer 1.1s infinite
}

.card.skel .body>div {
    height: 12px;
    border-radius: 6px;
    background-color: var(--liner-skel-color);
    margin-top: 8px
}

.card.skel .body>div:first-child {
    height: 18px;
    margin-top: 0;
    width: 75%
}

/* Tiny spinner */
.spinner {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, .2);
    border-top-color: rgba(255, 255, 255, .85);
    animation: spin .7s linear infinite;
    display: inline-block;
    vertical-align: middle
}

@keyframes spin {
    to {
        transform: rotate(360deg)
    }
}

/* Backdrop — above everything except panel */
.backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .45);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--speed);
    z-index: 900;
}

#plp_container.filters-open .backdrop {
    opacity: 1;
    pointer-events: auto
}

/* ===== FILTERS ===== */
.filters {
    background: var(--panel);
    border-left: 1px solid var(--border);
    box-shadow: var(--shadow);
    overflow-y: scroll;
    scrollbar-gutter: stable;
}

.filters-inner {
    padding: 14px;
    direction: rtl;
}

.filters h3 {
    margin: 0 0 10px;
    font-size: 14px;
    color: #cbd3e2;
    text-transform: uppercase;
    letter-spacing: .14em
}

.filter_group_container {
    border-bottom: 1px solid gainsboro;
}

.filter_group_item {
    color: black;
}


/* Desktop: FIXED, full height, aligned to container’s right, internal scroll */
@media (min-width:901px) {
    .filters {
        position: fixed;
        top: 0;
        /* start below site header */
        right: var(--wrap-right);
        /* align with container right edge */
        height: 100vh;
        /* full viewport height under site header */
        width: var(--panelPx);
        max-width: 420px;
        min-width: 280px;
        border-radius: 12px;
        overflow: auto;
        /* internal scroll */
        transform: translateX(100%);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: transform var(--speed) var(--easing), opacity var(--speed), visibility 0s linear var(--speed);
        z-index: 1000;
        /* above headers */

    }

    #plp_container.filters-open .filters {
        transform: translateX(0);
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transition-delay: 0s;
        z-index: 99999;

    }

    /* Keep products from running under the fixed panel */
    #plp_container.filters-open .products {
        width: calc(100% - var(--panelPx))
    }
}

/* Mobile: overlay full screen */
@media (max-width:900px) {
    .filters {
        position: fixed;
        inset: 0;
        width: 100%;
        height: 100%;
        border-radius: 0;
        border-left: 0;
        transform: translateX(100%);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: transform var(--speed) var(--easing), opacity var(--speed);
        z-index: 1000;
        max-width: 100vw !important;
    }

    .filter-controls {
        align-items: start !important;
    }
    .toggle-btn{
        width: 48% !important;
    }


    #plp_container.filters-open {
        overflow: hidden
    }

    #plp_container.filters-open .filters {
        transform: translateX(0);
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        z-index: 99999;
    }
    #plp_container .filters{width: 100% !important;}
}

.filters .close {
    display: flex !important;
    justify-content: start !important;
    align-items: center !important;
    position: sticky;
    top: 0;
    z-index: 1;
    display: flex;
    justify-content: flex-end;
    background: linear-gradient(180deg, rgb(227, 227, 227), rgba(244, 244, 244, 0.7) 60%, transparent);
    padding: 10px
}

.filters .close .btn {
    background-color: crimson !important;
    color: white;
}

:where(button, a, input):focus-visible {
    outline: 2px solid var(--brand);
    outline-offset: 2px;
    border-radius: 10px
}



/* main filters item style */

/* -------- FILTER ITEM (Square Pill Style) -------- */
/* -------- FILTER GROUP -------- */
.filter-group {
    border-bottom: 2px solid gainsboro;
    margin-bottom: 10px;
    background: transparent !important;
    overflow: hidden;
    transition: box-shadow .25s ease;
}

.filter-group.open {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    background: rgba(255, 255, 255, 0.8) !important;
}

/* -------- HEADER -------- */
.group-header {
    width: 100%;
    border: none;
    padding: 10px 14px;
    font-weight: 600;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 15px;
    cursor: pointer;
    transition: background .25s, color .25s;
}

.group-header:hover {
    background: #f0f0f0;
    color: #111;
}

.group-header i {
    transition: transform .25s ease;
    opacity: 0.6;
}

.filter-group.open .group-header i {
    transform: rotate(180deg);
    opacity: 1;
}

/* -------- BODY -------- */
.group-body {
    display: none;
    padding: 10px 12px 14px;
    overflow: hidden;
}

/* -------- FILTER CONTROLS -------- */
.filter-controls {
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: start;
    gap: 8px;
    margin-bottom: 8px;
    padding: 10px;
}

.filter-controls button {
    width: 100%;
    background: transparent;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 0px;
    padding: 5px 10px;
    font-size: 13px;
    cursor: pointer;
    transition: background .2s, color .2s, transform .1s;
}

.filter-controls button:hover {
    background: #fd0d0d10;
    color: crimson;
    transform: scale(1.05);
}

/* -------- GRID LAYOUT -------- */
.filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 2fr));
    gap: 6px;
    justify-items: stretch;
}

/* -------- FILTER ITEM (Pill Style) -------- */
.filter-item {
    padding: 8px 10px;
    border: 1px solid #ddd;
    border-radius: 20px;
    text-align: center;
    cursor: pointer;
    color: #333;
    font-size: 14px;
    transition: background .2s, color .2s, transform .1s, border-color .2s;
    user-select: none;
}

.filter-item:hover {
    background: #f9f9f9;
}

.filter-item.selected {
    background: #fd0d0d10;
    color: crimson;
    border-color: crimson;
    font-weight: 600;
    transform: scale(1.05);
}

.filter-item .count {
    display: block;
    font-size: 11px;
    color: #999;
    margin-top: 2px;
}

/* ==========================================================
 🎚️ Toggle Switch Controls (Select All / Clear All)
 — Smooth, clean, mobile-friendly
========================================================== */

.filter-controls {
    display: flex;
    justify-content: flex-end;
    gap: 16px;
    margin-bottom: 10px;
    align-items: center;
}

.toggle-btn {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 8px;
    cursor: pointer;
    font-size: 10px;
    color: #333;
    user-select: none;
}

/* Hide native checkbox */
.toggle-btn input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 0;
    height: 0;
    position: absolute;
}

/* Switch track */
.toggle-btn .switch {
    position: relative;
    width: 38px;
    height: 20px;
    background: #ccc;
    border-radius: 20px;
    transition: background 0.3s ease;
    flex-shrink: 0;
}

/* Switch handle */
.toggle-btn .switch::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.3s ease;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

/* Checked (ON) state */
.toggle-btn input[type="checkbox"]:checked+.switch {
    background: crimson;
}

.toggle-btn input[type="checkbox"]:checked+.switch::before {
    transform: translateX(18px);
}

/* Label text */
.toggle-btn .label-text {
    pointer-events: none;
    transition: color 0.2s ease;
}

.toggle-btn:hover .label-text {
    color: crimson;
}
label{margin: 0 !important;}
/* Optional pressed feedback */
.toggle-btn:active .switch::before {
    transform: scale(0.9) translateX(2px);
}

.plp-card .price{font: 700 14px / 1.8 jpa !important;}

.plp-card .btn-add-mobile{border-radius: 100%}

.products_slider_section .owl-stage{
    padding-right: 20px !important;
    align-items: baseline;
}

.carousel_title_img_font{
    font-size: 18px !important;
}

@media screen and (max-width: 768px){
    .modern_see_all_carousel{
        bottom: 30px;
    }
    .modern_see_all_carousel {
        width: 40%;
        margin: auto;
        border-radius: 10px;
        left: 50% !important;
        transform: translate(-50%) !important;
        right: unset !important;
        font-family: 'jpack' !important;
        background-color: #626262 !important;
    }
}

.card-aekm {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.3);
    width: 90%;
    max-width: 420px;
    padding: 20px;
    z-index: 9999;
    display: none;
    flex-direction: column;
    gap: 15px;
    animation: fadeInScale .25s ease;
}

.card-aekm .image svg {
    width: 50px;
    height: 50px;
    stroke: #e74c3c;
    margin: 0 auto;
    display: block;
}

.card-aekm .title {
    font-weight: bold;
    font-size: 18px;
    color: #333;
    display: block;
    margin-bottom: 5px;
    text-align: center;
}

.card-aekm .message {
    color: #666;
    font-size: 14px;
    line-height: 1.6;
    text-align: center;
}

.card-aekm .actions {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.card-aekm .desactivate, .card-aekm .cancel {
    flex: 1;
    padding: 10px 0;
    border-radius: 6px;
    text-align: center;
    cursor: pointer;
    font-weight: bold;
    transition: 0.2s;
    min-width: 79px;
    line-height: 30px;
    height: 30px;
    justify-content: center;
    align-items: center;
    font-size: 13px;
    margin: 0;
}

.card-aekm .desactivate {
    background: #e74c3c;
    color: #fff;
}

.card-aekm .desactivate:hover {
    background: #c0392b;
}

.card-aekm .cancel {
    background: #eee;
    color: #444;
}

.card-aekm .cancel:hover {
    background: #ddd;
}

@keyframes fadeInScale {
    from { opacity: 0; transform: translate(-50%, -40%) scale(0.95); }
    to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}


.basket-info .meta {
    font-size: 13px;
    color: #555;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.basket-info .meta-item i {
    margin-left: 4px;
    color: #999;
    font-size: 12px;
}

.basket-info .separator {
    color: #bbb;
}


.basket-item {
    display: flex;
    gap: 16px;
    background: #fff;
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    transition: box-shadow .2s;
}
.basket-item:hover {
    box-shadow: 0 4px 14px rgba(0,0,0,.12);
}

.thumb {
    position: relative;
    flex: 0 0 90px;
}
.thumb img {
    width: 90px;
    height: auto;
    border-radius: 10px;
    object-fit: cover;
}
.thumb .promotion_badge_basket {
    position: absolute;
    top: 6px;
    left: 6px;
    background: #ff4757;
    color: #fff;
    font-size: 11px;
    padding: 2px 6px;
    border-radius: 6px;
}

/* متن‌ها */
.basket-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.title {
    font-size: 15px;
    font-weight: 600;
    margin: 0;
}
.meta {
    font-size: 13px;
    color: #666;
    margin: 0;
}

.price-row {
    margin: 0;
}
.price-row .price {
    font-size: 16px;
    font-weight: 700;
    width: 100%;
    display: inline-flex;
    align-items: center;
    color: #000
}
.discount-info .old-price {
    text-decoration: line-through;
    color: #999;
    font-size: 13px;
}

.main-basket-panel {
    display: flex;
    flex-direction: column;
    padding: 20px 20px 10px;
    overflow-y: scroll;
}

.cashback-txt{
    text-align: right;
}
.controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
}
.quantity-control {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f1f1f1;
    border-radius: 8px;
    padding: 4px 10px;
}
.qty-btn {
    border: none;
    background: #ddd;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 16px;
    font-weight: bold;
    transition: background .2s;
    justify-content: center;
}
.qty-btn:hover { background: #bbb; }
.qty {
    font-size: 14px;
    font-weight: 600;
    min-width: 20px;
    text-align: center;
    justify-content: center;
}

.remove-btn {
    border: none;
    background: transparent;
    color: #ff4757;
    font-size: 10px;
    cursor: pointer;
    transition: opacity .2s;
}
.remove-btn:hover { opacity: .7; }

/* بج تخفیف */
.discount-badge {
    position: absolute;
    top: 6px;
    right: 6px;
    background: #ff4757;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 6px;
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
}


.thumb {
    position: relative;
}
.thumb .promotion_badge_basket {
    position: absolute;
    top: 6px;
    left: 6px;
    background: #1e90ff;
    color: #fff;
    font-size: 11px;
    padding: 2px 6px;
    border-radius: 6px;
}

.price-row .currency {
    font-size: 10px;
    margin-right: 3px;
    opacity: 0.8;
}

body, .filters {
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    line-height: 1.5;
    color: #111;
}

.filters {
    position: fixed;
    top: 0;
    right: -420px;
    width: 420px;
    height: 100vh;
    background: #fff;
    box-shadow: -8px 0 24px rgba(0,0,0,0.1);
    transition: right 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    overflow: hidden;
    direction: rtl;
}

.filters[aria-hidden="false"] {
    right: 0;
}

.filters-inner {
    height: calc(100vh - 150px);
    overflow-y: auto;
    padding: 0;
    scrollbar-width: none;
}

.filters-inner::-webkit-scrollbar {
    display: none;
}

.hstrip .swiper-wrapper{
    direction: rtl;
    justify-content: flex-start;
}

.flt-head {
    padding: 20px 24px;
    border-bottom: 1px solid #eee;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 10;
}

.flt-head .title {
    font-size: 20px;
    font-weight: 700;
}

.icon-btn {
    background: none;
    border: none;
    cursor: pointer;
    transition: transform 0.2s;
}

.icon-btn:hover {
    transform: scale(1.1);
}

.flt-tags {
    padding: 16px 24px;
    position: sticky;
    top: 61px;
    background: #fff;
    z-index: 9;
    border-bottom: 1px solid #eee;
}

#fltActiveTags.chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

#fltActiveTags .chip {
    background: #f8f8f8;
    border-radius: 20px;
    padding: 6px 14px;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
    color: #333;
}

#fltActiveTags .chip::after {
    content: '×';
    font-weight: bold;
    color: #aaa;
    cursor: pointer;
}

.flt-tags .muted.small {
    font-size: 12px;
    color: #888;
    text-align: center;
}

.fsec {
    border-bottom: 1px solid #f2f2f2;
}

.fsec-h {
    padding: 10px 24px 10px 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    cursor: pointer;
    transition: background 0.2s;
    width: 100%;
}

.fsec-h:hover {
    background: #f9f9f9;
}

.fsec-h span:first-child {
    font-size: 16px;
    font-weight: 600;
    font-family: 'jpack';
    color: #000000;
}

.rhs {
    display: flex;
    align-items: center;
    gap: 16px;
}

.exp-toggle {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #f0f0f0;
    border: none;
    font-size: 16px;
    color: #666;
    cursor: pointer;
    transition: all 0.2s;
}

.exp-toggle[aria-pressed="true"] {
    background: #111;
    color: #fff;
}

.exp-toggle:hover {
    background: #ddd;
}

.chev {
    transition: transform 0.3s ease;
    color: #aaa;
}



.fsec .chev {
    transform: rotate(90deg);
}

.fsec.is-open .chev {
    transform: rotate(180deg);
}

.fsec-b {
    padding: 0 24px 50px 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.4s ease;
}

.fsec.is-open .fsec-b {
    max-height: none;
    padding: 0 24px 20px 0;
}

.hstrip {
    position: relative;
    overflow: hidden;
    padding: 0 0 0 0;}

.hstrip .swiper-wrapper {
    transition-timing-function: linear;
}

.fsec.is-expanded .hstrip {
    padding: 0;
}

.hstrip-inner {
    display: flex;
    gap: 8px;
}

.fsec.is-expanded .hstrip-inner {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 8px 8px;
}

.swiper-slide {
    flex-shrink: 0;
    width: auto;
}

.f-chips .chip,
.f-colors .dot {
    border-radius: 999px;
    padding: 8px 20px;
    font-size: 14px;
    color: #333;
    background: #f8f8f8;
    border: 1px solid #ddd;
    transition: all 0.2s;
    cursor: pointer;
    white-space: nowrap;
}

.f-chips .chip:hover,
.f-colors .dot:hover {
    background: #eee;
    border-color: #ccc;
}

.f-chips .chip.is-active,
.f-colors .dot.is-active {
    background: #d3060c;
    color: #fff;
    border-color: #d3060c;
}

.f-colors .dot {
    width: 36px;
    height: 36px;
    padding: 0;
    border-radius: 50%;
    background: var(--dot);
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px #ddd;
}

.f-colors .dot.is-active {
    box-shadow: 0 0 0 3px #111;
}

.f-groups {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.cat-group {
    border-bottom: none;
}

.cg-h {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
}

.cg-h .lbl {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
}

.cg-h input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #111;
    border-radius: 4px;
}

.cg-toggle {
    background: #f8f8f8;
    border: none;
    color: #666;
    font-size: 13px;
    padding: 4px 8px;
    cursor: pointer;
    transition: color 0.2s;
}

.cg-toggle:hover {
    color: #111;
}

.cg-b {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s;
}

.cg-b:not([style*="display: none"]) {
    max-height: none;
    padding: 8px 16px;
}

.f-item {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    color: #444;
    cursor: pointer;
    transition: color 0.2s;
}

.f-item:hover {
    color: #111;
}

.f-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #111;
    border-radius: 4px;
}

.price-row {
    display: flex;
    align-items: center;
    gap: 12px;
    direction: ltr;
    padding: 12px 0;
}

.price-row input {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 14px;
    text-align: center;
    transition: border-color 0.2s;
}

.price-row input:focus {
    border-color: #111;
    outline: none;
}

.price-row .dash {
    color: #888;
    font-size: 20px;
}

#priceApply {
    padding: 12px 20px;
    background: #111;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    cursor: pointer;
    transition: background 0.2s;
}

#priceApply:hover {
    background: #333;
}

.flt-foot {
    display: flex;
    gap: 12px;
    padding: 20px 24px;
    background: #fff;
    border-top: 1px solid #eee;
    position: sticky;
    bottom: 0;
    z-index: 10;
}

.btn.primary,
.btn.ghost {
    flex: 1;
    padding: 14px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.btn.primary {
    background: #111;
    color: #fff;
    border: none;
}

.btn.primary:hover {
    background: #333;
}

.btn.ghost {
    background: transparent;
    color: #111;
    border: 1px solid #ddd;
}

.btn.ghost:hover {
    border-color: #111;
}

.sizes-row--mobile{display: none}

@media (max-width: 768px) {
    .filters {
        width: 100vw;
        right: -100vw;
    }

    .sizes-row--mobile{
        display: flex;
    }

    .filters[aria-hidden="false"] {
        right: 0;
    }

    .filters-inner {
        height: calc(100dvh - 150px);
    }
}

.f-item input[type="checkbox"] {
    appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid #ccc;
    border-radius: 4px;
    position: relative;
    transition: all 0.2s;
}

.f-item input[type="checkbox"]:checked {
    border-color: #111;
    background: #111;
}

.f-item input[type="checkbox"]:checked::after {
    content: '✔';
    position: absolute;
    top: -2px;
    left: 2px;
    color: #fff;
    font-size: 14px;
}

.cg-h input[type="checkbox"] {
    appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid #ccc;
    border-radius: 4px;
    position: relative;
    transition: all 0.2s;
}

.cg-h input[type="checkbox"]:checked {
    border-color: #111;
    background: #111;
}

.cg-h input[type="checkbox"]:checked::after {
    content: '✔';
    position: absolute;
    top: -2px;
    left: 2px;
    color: #fff;
    font-size: 14px;
}
/* چیپ رنگ مینیمال */
.f-colors .chip-color {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: #f7f7f7;
    border: 1px solid #e6e6e6;
    border-radius: 999px;
    cursor: pointer;
    white-space: nowrap;
    transition: background .2s, border-color .2s, color .2s, transform .12s;
    width: auto;
}

.f-colors .chip-color .swatch {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--dot);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, .08) inset;
    position: relative;
    flex: 0 0 9px;
    transition: transform .12s, box-shadow .2s;
    border: 1px solid #fff;
}

.f-colors .chip-color .lbl {
    font-size: 13px;
    color: #fff;
    line-height: 1;
    opacity: .9;
    transition: color .2s, opacity .2s;
}

.f-colors .chip-color .tick {
    width: 14px;
    height: 14px;
    position: relative;
    background: #fff;
    -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23000' d='M9.0 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23000' d='M9.0 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
    opacity: 0; /* فقط در اکتیو نمایش */
    pointer-events: none;
    transition: opacity .15s ease;
}

/* Hover حالت لطیف */
.f-colors .chip-color:hover {
    background: #f1f1f1;
    border-color: #d9d9d9;
    transform: translateZ(0) scale(1.01);
}


.f-colors .chip-color.is-active {
    background: #111;
    color: #fff;
    border-color: #111;
    box-shadow: 0 6px 16px rgba(17,17,17,.12);
    align-items: center;
}

.f-colors .chip-color.is-active .lbl {
    color: #fff;
    opacity: 1;
}

/* رینگ دوتایی روی سواچ */
.f-colors .chip-color.is-active .swatch {
    transform: scale(1.06);
    box-shadow:
            0 0 0 2px #fff,   /* رینگ داخلی */
            0 0 0 4px #111,   /* رینگ بیرونی */
            0 2px 8px rgba(0,0,0,.18);
}

/* تیک روشن می‌شود */
.f-colors .chip-color.is-active .tick {
    opacity: .95;
}

.plp-card .row-top-mobile{min-height: 35px}

/* حالت فشرده‌تر روی موبایل */
@media (max-width: 480px) {
    .f-colors .chip-color { padding: 8px 10px; gap: 8px; }
    .f-colors .chip-color .swatch {        width: 9px;
        height: 9px; }
    .f-colors .chip-color .lbl { font-size: 12px; }
}

.plp_container.jpa-plp.grid-4{

}

@media screen and (max-width: 768px){
    .plp_container.jpa-plp.grid-4 .cards{
        gap: 0 !important;
    }
    .plp_container.jpa-plp.grid-4 .swiper-pagination,
    .plp_container.jpa-plp.grid-4 .plp-card .top-actions,
    .plp_container.jpa-plp.grid-4 .plp-card .sizes-row,
    .plp_container.jpa-plp.grid-4 .plp-card .color-badges{
        display: none;
    }

    .plp_container.jpa-plp.grid-4 .price-row .price{
        font: 700 11px / 1.8 jpa !important;
        direction: rtl;
        justify-content: center;
        text-align: center;
    }
    .plp_container.jpa-plp.grid-4 .price-row .prices{
        width: 100%;
    }

    .plp_container.jpa-plp.grid-4 .plp-card .price-row{
        margin: 0;
        padding: 0;
    }
    .plp_container.jpa-plp.grid-4 .plp-card{
        border-radius: 0;
    }

    .plp_container.jpa-plp.grid-4 .plp-card .row-top-mobile{
        align-items: baseline;
        min-height: 35px;
    }

    .plp_container.jpa-plp.grid-4 .price-off{
        position: absolute;
        top: 0;
        z-index: 1;
        left: 0;
    }
    .plp_container.jpa-plp.grid-4 .price-off{
        border-radius: 2px;
        font-size: 8px;
        padding: 3px 5px;
    }
    .plp_container.jpa-plp.grid-4 .price-row.has-off .prices{
        flex-direction: column;
        align-items: center;
        direction: rtl;
        gap: 0;
    }
}


.f-chips .chip, .f-colors .dot{
    width: 90px;
    top: 0;
    right: 0;
}

.plp-card .btn-add-mobile{border-radius: 100% !important;}

/* ===== JPA PLP — Pager UI (RTL-first, Mobile/Desktop) ===== */
#plpPager{
    --pg-bg:#fff; --pg-br:#e5e7eb; --pg-shadow:0 8px 24px rgba(16,24,40,.06);
    --pg-size:40px; --pg-gap:8px; --pg-radius:12px;
    --pg-fg:#111827; --pg-fg-muted:#667085; --pg-active:#111827; --pg-active-fg:#fff;
    --pg-hover:#f2f4f7; --pg-disabled:.45;

    background:var(--pg-bg); border:1px solid var(--pg-br); border-radius:16px;
    box-shadow:var(--pg-shadow); padding:10px 12px; margin:16px 0;
}

/* Wrapper: در دسکتاپ بالا، در موبایل استیکی پایین */
@media (min-width: 641px){
    #plpPager{ position:sticky; top:0; z-index:7; }
}
@media (max-width: 640px){
    #plpPager{ position:sticky; bottom:0; top:auto; border-radius:18px 18px 0 0; }
}

/* Grid layout: دکمه‌های قبلی/بعدی دو طرف، اعداد وسط */
#plpPager{ display:grid; grid-template-columns: auto 1fr auto; align-items:center; gap:12px; }
#plpPager .meta{ grid-column: 1 / -1; display:flex; align-items:center; gap:8px;
    color:var(--pg-fg-muted); font-size:12px; line-height:1; }
#plpPager .meta .sep{ opacity:.6; }
#plpPager .meta b{ color:var(--pg-fg); }

#plpPager .controls{ grid-column: 1 / -1; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:8px; }
#plpPager .controls .nums{ grid-column:2; justify-self:center; display:flex; align-items:center; gap:var(--pg-gap); }

/* RTL: شماره‌ها از راست به چپ دیده شوند */
html[dir="rtl"] #plpPager .controls .nums{ flex-direction: row-reverse; }

/* دکمه‌های اول/قبلی در راست، بعدی/آخر در چپ (با RTL سازگار) */
#plpPager .controls .first, #plpPager .controls .prev{ grid-column:1; }
#plpPager .controls .next,  #plpPager .controls .last{ grid-column:3; }

/* دکمه‌ها */
#plpPager .pg, #plpPager .num, #plpPager .gap{
    min-width:var(--pg-size); height:var(--pg-size);
    padding:0 10px; border:1px solid var(--pg-br); background:#fff;
    color:var(--pg-fg); border-radius:var(--pg-radius);
    display:inline-flex; align-items:center; justify-content:center;
    font:600 13px/1 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    cursor:pointer; transition:transform .08s ease, background-color .12s ease, border-color .12s ease;
}
#plpPager .pg:hover, #plpPager .num:hover, #plpPager .gap:hover{ background:var(--pg-hover); }
#plpPager .pg:active, #plpPager .num:active, #plpPager .gap:active{ transform: translateY(1px); }

/* شماره فعال */
#plpPager .num.active{
    background:var(--pg-active); color:var(--pg-active-fg); border-color:var(--pg-active);
}

/* غیر فعال */
#plpPager .pg:disabled{ opacity:var(--pg-disabled); cursor:not-allowed; }

/* کلیدهای پرش (… ±5) */
#plpPager .gap{
    font-weight:700; border-style:dashed; letter-spacing:1px;
}

/* اعداد قابل اسکرول در موبایل، اما تمیز و بدون اسکرول‌بار */
@media (max-width: 640px){
    #plpPager{ --pg-size:36px; --pg-gap:6px; padding:10px; }
    #plpPager .meta{ font-size:11px; }
    #plpPager .controls .nums{ overflow-x:auto; -ms-overflow-style:none; scrollbar-width:none; }
    #plpPager .controls .nums::-webkit-scrollbar{ display:none; }
}

/* اندازه‌های لمسی مناسب */
@media (pointer:coarse){
    #plpPager .pg, #plpPager .num, #plpPager .gap{ min-width:44px; height:44px; }
}

/* JPA Pager — Minimal Clean UI (RTL, Mobile/Desktop) */
#plpPager{
    --bg:#fff; --br:#eceff3; --fg:#1f2937; --muted:#6b7280;
    --primary:#0f172a; --primary-fg:#fff; --hover:#f3f4f6;
    --radius:12px; --size:38px; --gap:8px;
    background:var(--bg); border:1px solid var(--br); border-radius:16px;
    padding:10px 12px; margin:16px 0; box-shadow:0 8px 24px rgba(16,24,40,.06);
    display:grid; grid-template-columns:1fr; gap:10px;
}

/* Meta line */
#plpPager .meta{ display:flex; align-items:center; gap:8px; color:var(--muted); font-size:12px; }
#plpPager .meta .dot{ width:4px; height:4px; border-radius:50%; background:#d1d5db; display:inline-block; }
#plpPager .meta b{ color:var(--fg); }

/* Controls */
#plpPager .controls{ display:flex;  align-items:center; gap:10px; }
#plpPager .nums{ display:flex; align-items:center; gap:var(--gap); justify-content:center; }

/* RTL: اعداد از راست به چپ */
html[dir="rtl"] #plpPager .nums{ flex-direction:row-reverse; }

/* Buttons */
#plpPager .num, #plpPager .gap, #plpPager .nav{
    min-width:var(--size); height:var(--size);
    background:#fff; border:1px solid var(--br); color:var(--fg);
    border-radius:12px; display:inline-flex; align-items:center; justify-content:center;
    font:600 13px/1 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    cursor:pointer; transition:background-color .12s ease, border-color .12s ease, transform .08s ease;
}
#plpPager .num:hover, #plpPager .gap:hover, #plpPager .nav:hover{ background:var(--hover); }
#plpPager .num:active, #plpPager .gap:active, #plpPager .nav:active{ transform:translateY(1px); }
#plpPager .num.active{ background:var(--primary); color:var(--primary-fg); border-color:var(--primary); }
#plpPager .nav:disabled{ opacity:.5; cursor:not-allowed; }

/* Gap (… ±5) */


#plpPager .gap{ border-style:dashed; font-weight:700; letter-spacing:1px; }


#gridToggle{background: transparent;border: unset}
/* Mobile tweaks */
@media (max-width:640px){
    #plpPager{ --size:36px; padding:10px; border-radius:18px 18px 12px 12px; position:sticky; bottom:0; z-index:7; }
    #plpPager .meta{ font-size:11px; }
    #plpPager .nums{ overflow-x:auto; -ms-overflow-style:none; scrollbar-width:none; }
    #plpPager .nums::-webkit-scrollbar{ display:none; }

    .plp-searchbar #filterToggle{
        width: 70%;
    }

    .plp-searchbar #gridToggle{
        width: 30%;
    }

    #resultCount{
        width: 50%;
        text-align: right;
        direction: rtl;
    }
    .plp-searchbar .sort-select{
        width: 50%;
    }
    #sortSelect{
        width: 100%;
    }
    .plp-searchbar .wrap .right{padding: 0 20px !important;}
    .plp-searchbar .wrap .right,.plp-searchbar .wrap .left{gap: 0 !important;width: 100% !important;margin: 0 0 0 23px;}
}

@media (min-width:641px){
    #plpPager{ position:sticky; top:0; }
}

.switcher { display:flex; align-items:center; gap:.6rem; }
.switcher .sui { position:relative; width:40px; height:22px; border-radius:999px; background:#e5e7eb; transition:.2s; }
.switcher input { display:none; }
.switcher .sui::after{ content:''; position:absolute; top:3px; left:3px; width:16px; height:16px; background:#fff; border-radius:50%; box-shadow:0 1px 3px rgba(0,0,0,.2); transition:.2s; }
.switcher input:checked + .sui{ background:#10b981; }
.switcher input:checked + .sui::after{ transform:translateX(18px); }
.active-tags { display:flex; flex-wrap:wrap; gap:8px; margin:8px 0 0 }
.chip { display:inline-flex; align-items:center; gap:.35rem; padding:.35rem .6rem; border:1px solid #e5e7eb; border-radius:999px; background:#fff; font-size:.9rem }
.chip--rem span { opacity:.6; font-weight:700 }
.active-tags-sw { margin: 6px 0 10px;}
#activeTagsSwiper { padding: 2px 0; }
#activeTagsSwiper .swiper-slide { width: auto; }

.chip-min {
    display:inline-flex; align-items:center; gap:.4rem;
    padding:.28rem .6rem; border:1px solid #e5e7eb;
    border-radius:999px; background:#fff; font-size:11px; line-height:1.2;
    box-shadow:0 1px 2px rgba(16,24,40,.04);
    white-space:nowrap; user-select:none; cursor:pointer;
}
.chip-min .x { font-weight:700; opacity:.45; }
.chip-min:hover { background:#f9fafb; border-color:#e5e7eb; }
.chip-min[data-k="discount_only"],
.chip-min[data-k="bigSize"] { border-style:dashed; }

@media (prefers-color-scheme: dark) {
    .chip-min { background:#0b0f13; border-color:#1e293b; color: #fff}
    .chip-min:hover { background:#0e1218;}
}
/* جا بده در CSS صفحه‌ات */
.chip-min--color .chip-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-inline-end:6px;vertical-align:-1px;background:var(--dot,#ccc);box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);}

/* ===== Offers (chips slider) ===== */
.plp-offers-bar { min-width: 0; }
#offersSwiper { width: min(64vw, 700px); }
#offersSwiper .swiper-wrapper { align-items: stretch; }
.offer-chip {
    --bg: #f7f7f8;
    --ring: rgba(0,0,0,.06);
    --txt: #111;
    --shadow: 0 6px 18px rgba(16,24,40,.06);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 999px;
    background: var(--bg);
    color: var(--txt);
    border: 1px solid var(--ring);
    box-shadow: var(--shadow);
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    font: 600 12px/1 system-ui;
    max-width: 150px;
    transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.offer-chip .ico {
    width: 18px; height: 18px; display: inline-grid; place-items:center;
}
.offer-chip .lbl { letter-spacing: -.2px }
.offer-chip:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(16,24,40,.10); }
.offer-chip.is-active {
    border-color: transparent;
    box-shadow: 0 10px 26px rgba(16,24,40,.12);
}


.offer-chip[data-theme="stock"]   { --bg: #f7f7f8; --txt:#222; }
.offer-chip .badge {
    font: 700 10px/1 system-ui; padding: 4px 6px; border-radius: 999px;
    background: rgba(255,255,255,.7); color: inherit; border:1px solid rgba(0,0,0,.06);
}

@media (max-width: 768px){
    #offersSwiper { width: 58vw; }
}
.plp-searchbar .row-top{ gap:12px; }
.plp-searchbar .row-offers{ display:flex; align-items:center; }

.muted-small{
    font-size:12px;
    opacity:.8;
}


#offersSwiper{ width:100%; }
#offersSwiper .swiper-wrapper{ align-items:stretch;    justify-content: right; }
#offersSwiper, #activeTagsSwiper{ direction: rtl;    display: inline-flex;
    padding: 0 19px 0 0; }
/* ============ Grid switch ============ */
.grid-toggle { padding: 6px; border-radius: 12px; }
.grid-toggle .grid-switch { display:block; }

.grid-switch .sw-body {
    fill: none;
    stroke: currentColor;
    opacity: .28;
    stroke-width: 2;
}

.grid-switch .sw-grid rect {
    fill: currentColor;
    opacity: .38;
    transform-origin: center;
    transition: transform .25s ease, opacity .2s ease, filter .2s ease;
}

/* پیکان */
.grid-switch .sw-arrow path {
    stroke: currentColor;
    stroke-width: 2;
    opacity: .7;
    transition: transform .25s ease, opacity .2s ease;
}

/* نُب */
.grid-switch .sw-knob {
    fill: currentColor;
    opacity: .12;
    transition: transform .28s ease, opacity .2s ease, fill .2s ease;
}




/* ===== Unique Grid Switch ===== */
.grid-toggle-uni { padding: 4px; border-radius: 12px; line-height: 0; }
.grid-toggle-uni .uni { display:block; color: currentColor; }

.grid-toggle-uni .uni-bg {
    fill: none;
    stroke: currentColor;
    stroke-opacity: .18;
    stroke-width: 2;
}

/* کپسول‌ها */
.grid-toggle-uni .cap {
    fill: currentColor;
    opacity: .06;
    transition: opacity .25s ease, transform .25s ease, filter .25s ease;
}

/* نقاط (گرید) */
.grid-toggle-uni .dots rect {
    fill: currentColor;
    opacity: .42;
    transition: transform .25s ease, opacity .25s ease, filter .25s ease;
    transform-origin: center;
}

/* فلش مرکزی */
.grid-toggle-uni .arrow .shaft,
.grid-toggle-uni .arrow .head {
    stroke: currentColor;
    stroke-width: 2.2;
    stroke-linecap: square;
    fill: none;
    opacity: .7;
    transition: transform .25s ease, opacity .25s ease;
}

/* حلقه‌ی های‌لایت */
.grid-toggle-uni .glow {
    fill: none;
    stroke: currentColor;
    stroke-opacity: .16;
    stroke-width: 6;
    filter: drop-shadow(0 0 6px rgba(0,0,0,.06));
    transition: transform .28s ease, opacity .28s ease, cx .28s ease;
}

/* حالت فعال: ۴ستون (RTL: سمت چپ) */
:root[dir="rtl"] .grid-toggle-uni[data-view="4"] .side-left .cap { opacity: .12; filter: drop-shadow(0 6px 16px rgba(0,0,0,.08)); }
:root[dir="rtl"] .grid-toggle-uni[data-view="4"] .side-left .dots rect { opacity: 1; transform: scale(1.08); }
:root[dir="rtl"] .grid-toggle-uni[data-view="4"] .glow { cx: 32px; opacity: .9; }

/* حالت غیرفعال: ۲ستون (RTL: سمت راست) */
:root[dir="rtl"] .grid-toggle-uni[data-view="4"] .side-right .cap { opacity: .04; }
:root[dir="rtl"] .grid-toggle-uni[data-view="4"] .side-right .dots rect { opacity: .28; transform: scale(.9); }

/* حالت فعال: ۲ستون (RTL: سمت راست) */
:root[dir="rtl"] .grid-toggle-uni[data-view="2"] .side-right .cap { opacity: .12; filter: drop-shadow(0 6px 16px rgba(0,0,0,.08)); }
:root[dir="rtl"] .grid-toggle-uni[data-view="2"] .side-right .dots rect { opacity: 1; transform: scale(1.1); }
:root[dir="rtl"] .grid-toggle-uni[data-view="2"] .glow { cx: 108px; opacity: .9; }

/* حالت غیرفعال: ۴ستون (RTL) */
:root[dir="rtl"] .grid-toggle-uni[data-view="2"] .side-left .cap { opacity: .04; }
:root[dir="rtl"] .grid-toggle-uni[data-view="2"] .side-left .dots rect { opacity: .28; transform: scale(.9); }

/* اگر LTR بودی، فقط جای cx و کلاس‌ها برعکس می‌شود: */
:root[dir="ltr"] .grid-toggle-uni[data-view="4"] .glow { cx: 108px; }
:root[dir="ltr"] .grid-toggle-uni[data-view="2"] .glow { cx: 32px; }
:root[dir="ltr"] .grid-toggle-uni[data-view="4"] .side-right .cap,
:root[dir="ltr"] .grid-toggle-uni[data-view="2"] .side-left  .cap { opacity: .12; filter: drop-shadow(0 6px 16px rgba(0,0,0,.08)); }
:root[dir="ltr"] .grid-toggle-uni[data-view="4"] .side-right .dots rect,
:root[dir="ltr"] .grid-toggle-uni[data-view="2"] .side-left  .dots rect { opacity:1; transform:scale(1.1); }
:root[dir="ltr"] .grid-toggle-uni[data-view="4"] .side-left  .cap,
:root[dir="ltr"] .grid-toggle-uni[data-view="2"] .side-right .cap { opacity:.04; }
:root[dir="ltr"] .grid-toggle-uni[data-view="4"] .side-left  .dots rect,
:root[dir="ltr"] .grid-toggle-uni[data-view="2"] .side-right .dots rect { opacity:.28; transform:scale(.9); }

/* انیمیشن فلش هنگام سوئیچ */
@keyframes uni-wiggle-rtl { 0%{transform:translateX(0)} 50%{transform:translateX(-2.2px)} 100%{transform:translateX(0)} }
@keyframes uni-wiggle-ltr { 0%{transform:translateX(0)} 50%{transform:translateX( 2.2px)} 100%{transform:translateX(0)} }
:root[dir="rtl"] .grid-toggle-uni.wiggle .arrow { animation: uni-wiggle-rtl .28s ease; }
:root[dir="ltr"] .grid-toggle-uni.wiggle .arrow { animation: uni-wiggle-ltr .28s ease; }

/* کاهش حرکت */
@media (prefers-reduced-motion: reduce){
    .grid-toggle-uni .cap,
    .grid-toggle-uni .dots rect,
    .grid-toggle-uni .arrow .shaft,
    .grid-toggle-uni .arrow .head,
    .grid-toggle-uni .glow { transition:none; animation:none !important; }
}

.offer-chip{
    min-width: 60px !important;
    max-width: 150px !important;
    width: 80px !important;
}
/* هدر گروه */
.cat-group { border:1px solid #eee; border-radius:12px; background:#fff; margin-bottom:12px; }
.cat-group .cg-h{
    display:flex; align-items:center; justify-content:space-between;
    padding:10px 12px; gap:12px;
}
.cat-group .lbl{ display:flex; align-items:center; gap:8px; font:700 14px/1.6 system-ui; }

/* تاگل آیکونی (بدون متن) */
.cg-toggle{
    display:inline-grid; place-items:center;
    width:auto; height:32px; border:1px solid #e5e7eb; border-radius:8px;
    background:#f8f8f8; color:#111; cursor:pointer;
    transition: border-color .2s ease, background .2s ease, color .2s ease;
}
.cg-toggle:hover{ background:#f9fafb; border-color:#d1d5db; }
.cg-toggle .chev{ transition: transform .22s ease; }

/* حالت باز: چرخش آیکون */
.cat-group.is-open .cg-toggle .chev{ transform: rotate(180deg); }

/* بدنهٔ آیتم‌ها: سه‌ستونه روی دسکتاپ، RTL-فیکس */
.cg-b{
    list-style:none; margin:0; padding:8px 12px 12px;
    display:grid; gap:10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* آیتم چک‌باکس */
.cg-b li{ min-width:0; }
.f-item{ display:flex; align-items:center; gap:4px; }
.f-item input[type="checkbox"]{
    width:18px; height:18px; accent-color:#111; /* اگر نخواستی، استایل سفارشی بذار */
}
.f-item .t{ font:500 13px/1.8 system-ui; color:#111; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* رسپانسیو */
@media (max-width: 900px){
    .cg-b{ grid-template-columns: repeat(2, minmax(0, 1fr)); }

    .f-item .t{
        font: 500 11px / 1.8 system-ui;
    }

}
@media (max-width: 520px){
    .cg-b{ grid-template-columns: 1fr 1fr 1fr; }
}

/* انیمیشن باز/بسته با hidden */
.cg-b[hidden]{ display:none !important; }



/* Theme tokens */
.flt-head{
    --flt-bg: color-mix(in oklab, #0b1220 10%, #ffffff 90%);
    --flt-bg-2: color-mix(in oklab, #0b1220 2%, #ffffff 98%);
    --flt-border: color-mix(in oklab, #000 12%, transparent);
    --flt-shadow: 0 8px 24px rgba(16,24,40,.06), 0 2px 6px rgba(16,24,40,.04);
    --flt-accent: #d01d33;            /* می‌تونی با رنگ برندت عوض کنی */
    --txt: #0e1525;
}


@media (prefers-color-scheme: dark){
    .flt-head{
        --flt-bg: rgba(17, 22, 34, .72);
        --flt-bg-2: rgba(17, 22, 34, .55);
        --flt-border: rgba(255,255,255,.08);
        --flt-shadow: 0 10px 30px rgba(0,0,0,.35);
        --txt: #e8ebf3;
    }
}

/* Container */
.flt-head{
    position: sticky;
    top: 0;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    isolation: isolate;
}

/* Title */
.flt-head .title{
    font-weight: 800;
    font-size: 16px;
    letter-spacing: .2px;
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    position: relative;
    font-family: jpack;
}

/* Accent bar (animated) */
.flt-head .title::after{
    content: "";
    height: 3px;
    width: 56px;
    border-radius: 999px;
    background:
            linear-gradient(90deg, var(--flt-accent), color-mix(in oklab, var(--flt-accent), #ffcf33 35%), var(--flt-accent));
    position: absolute;
    inset-inline-start: 0;
    bottom: -8px;

    animation: titleSweep 2.4s cubic-bezier(.22,1,.36,1) infinite;
    opacity: .9;
}

@keyframes titleSweep{
    0%   { transform: scaleX(.25); filter: brightness(1); }
    40%  { transform: scaleX(1);   filter: brightness(1.2); }
    60%  { transform: scaleX(.6);  filter: brightness(1); }
    100% { transform: scaleX(.25); filter: brightness(1); }
}

/* Close button */
.flt-head .icon-btn{
    --size: 40px;
    inline-size: var(--size);
    block-size: var(--size);
    border-radius: 12px;
    border: 1px solid var(--flt-border);
    background: linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.4));
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .25s ease, background .25s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,.06) inset;
    position: relative;
    outline: none;
}


@media (prefers-color-scheme: dark){
    .flt-head .icon-btn{
        background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
        box-shadow: 0 0 0 0 rgba(208,29,51,0); /* صاف در دارک */
    }
}

/* Icon sizing & animation */
.flt-head .icon-btn svg{
    width: 18px;
    height: 18px;
    transition: transform .45s cubic-bezier(.22,1,.36,1), opacity .2s ease;
    opacity: .92;
    /* اگر سمبل #ico-close استروک دارد، این رنگ‌ها اعمال می‌شوند: */
    stroke: currentColor;
}

/* Hover/active states */
.flt-head .icon-btn:hover{
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(16,24,40,.12);
    background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.6));
}
.flt-head .icon-btn:active{
    transform: translateY(0);
}

/* Rotate the close icon on hover */
.flt-head .icon-btn:hover svg{
    transform: rotate(90deg) scale(1.02);
}

/* Ripple feedback (pure CSS) */
.flt-head .icon-btn::after{
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(100% 100% at 50% 50%, color-mix(in oklab, var(--flt-accent) 35%, transparent), transparent 60%);
    opacity: 0;
    transform: scale(.6);
    transition: opacity .25s ease, transform .25s ease;
    pointer-events: none;
}
.flt-head .icon-btn:hover::after{
    opacity: .22;
    transform: scale(1);
}

/* Keyboard focus (accessibility) */
.flt-head .icon-btn:focus-visible{
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--flt-accent) 40%, transparent);
}

/* Compact on small screens */
@media (max-width: 480px){
    .flt-head{
        border-radius: 12px;
        padding: 12px 12px;
    }
    .flt-head .title{ font-size: 15px !important; }
    .flt-head .title::after{ bottom: -6px; width: 48px; }
    .flt-head .icon-btn{ --size: 36px; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
    .flt-head .title::after,
    .flt-head .icon-btn svg{
        animation: none !important;
        transition: none !important;
    }
}
.size-chip-side{
    width: 31px !important;
    border-radius: 4px !important;
    padding: 5px 0 !important;
    text-align: center;
    justify-content: center;
}