/* ==========================================================================
   PARACHRONO PREMIUM LISTING — v3.0
   Targets exact AN Theme HTML structure
   ========================================================================== */

/* --------------------------------------------------------------------------
   DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
    --pc-primary: #0891B2;
    --pc-primary-light: #06B6D4;
    --pc-primary-dark: #0E7490;
    --pc-primary-subtle: rgba(8, 145, 178, 0.08);
    --pc-heading: #1A202C;
    --pc-text: #4A5568;
    --pc-text-light: #718096;
    --pc-text-muted: #A0AEC0;
    --pc-bg-light: #F7FAFC;
    --pc-bg-white: #FFFFFF;
    --pc-bg-warm: #FAFBFC;
    --pc-border: #E2E8F0;
    --pc-border-light: #EDF2F7;
    --pc-danger: #E53E3E;
    --pc-success: #38A169;
    --pc-shadow-sm: 0 1px 3px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.03);
    --pc-shadow-md: 0 4px 12px rgba(0,0,0,0.06), 0 2px 4px rgba(0,0,0,0.04);
    --pc-shadow-hover: 0 12px 36px rgba(8, 145, 178, 0.10), 0 4px 12px rgba(0,0,0,0.06);
    --pc-radius: 12px;
    --pc-radius-sm: 8px;
    --pc-radius-xs: 6px;
    --pc-transition: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    --pc-transition-fast: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
    --pc-cols-desktop: 4;
    --pc-cols-tablet: 3;
    --pc-gap: 24px;
    --pc-gap-row: 32px;
}


/* ==========================================================================
   PAGE BACKGROUND & LAYOUT
   ========================================================================== */
#wrapper {
    background: var(--pc-bg-warm) !important;
}

/* Main row containing sidebar + products */
#wrapper .container {
    max-width: 1320px !important;
}

/* Force the left-column + content-wrapper into a proper flex row */
#left-column {
    flex: 0 0 260px !important;
    max-width: 260px !important;
    width: 260px !important;
    padding-right: 20px !important;
    padding-left: 0 !important;
    box-sizing: border-box !important;
}

#content-wrapper {
    flex: 1 1 0% !important;
    max-width: calc(100% - 260px) !important;
    width: auto !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Ensure parent row is flex */
#left-column + #content-wrapper,
#content-wrapper {
    /* handled by Bootstrap row, just ensure no extra margins */
}

/* When there's a left column, the row containing both should be flex */
.row:has(#left-column) {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: flex-start !important;
}

/* Fallback for browsers without :has — target common PS wrapper */
#columns .row,
#wrapper .row:not(.breadcrumb) {
    align-items: flex-start !important;
}


/* ==========================================================================
   BREADCRUMB
   ========================================================================== */
.breadcrumb {
    background: transparent !important;
    padding: 12px 0 !important;
    margin-bottom: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

.breadcrumb li {
    font-size: 13px !important;
    color: var(--pc-text-muted) !important;
}

.breadcrumb li a {
    color: var(--pc-text-light) !important;
    text-decoration: none !important;
    transition: color var(--pc-transition-fast) !important;
}

.breadcrumb li a:hover {
    color: var(--pc-primary) !important;
}

.breadcrumb li:last-child,
.breadcrumb li:last-child a {
    color: var(--pc-heading) !important;
    font-weight: 500 !important;
}

.breadcrumb li::after,
.breadcrumb li .material-icons {
    color: var(--pc-border) !important;
    font-size: 14px !important;
}


/* ==========================================================================
   CATEGORY HEADER
   ========================================================================== */
#js-product-list-header,
.block-category {
    background: var(--pc-bg-white) !important;
    border: none !important;
    border-radius: var(--pc-radius) !important;
    padding: 24px 28px !important;
    margin-bottom: 24px !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow: var(--pc-shadow-sm) !important;
}

/* Remove the left bar — cleaner look */
#js-product-list-header::before,
.block-category::before {
    display: none !important;
}

.block-category h1,
#js-product-list-header h1 {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: var(--pc-heading) !important;
    margin: 0 0 6px !important;
    letter-spacing: -0.02em !important;
    line-height: 1.3 !important;
}

/* "Catégorie :" prefix in lighter weight */
.block-category h1 .category-label,
.block-category h1 small {
    font-weight: 400 !important;
    color: var(--pc-text-light) !important;
}

.block-category #category-description,
.block-category .category-description,
#js-product-list-header p {
    font-size: 14px !important;
    line-height: 1.7 !important;
    color: var(--pc-text-light) !important;
    max-width: 720px !important;
    margin: 8px 0 0 !important;
    padding: 0 !important;
    border: none !important;
}

/* Kill any AN Theme borders/dividers inside category block */
.block-category hr,
.block-category .category-description *,
#js-product-list-header hr {
    border: none !important;
    border-top: none !important;
    border-bottom: none !important;
}

/* Description inner paragraphs */
.block-category .category-description p,
#category-description p {
    margin: 0 0 8px !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    color: var(--pc-text-light) !important;
}

.block-category .category-description p:last-child,
#category-description p:last-child {
    margin-bottom: 0 !important;
}



/* ==========================================================================
   LEFT SIDEBAR — FILTERS & CATEGORIES
   
   Exact AN Theme structure from #search_filters HTML
   ========================================================================== */

/* ── FILTER WRAPPER ─────────────────────────────────────────────── */
#search_filters {
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius) !important;
    box-shadow: var(--pc-shadow-sm) !important;
    overflow: visible !important;
    margin-bottom: 16px !important;
    padding: 5px !important;
}

.block-categories,
#left-column .block {
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius) !important;
    box-shadow: var(--pc-shadow-sm) !important;
    overflow: visible !important;
    margin-bottom: 16px !important;
}

/* Make sidebar sticky */
#left-column {
    position: sticky !important;
    top: 20px !important;
    align-self: flex-start !important;
}

/* ── "FILTRER PAR" — #search_filters > p.text-uppercase.h6 ────── */
#search_filters > p.text-uppercase,
#search_filters > p.h6 {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: var(--pc-heading) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    padding: 14px 16px !important;
    margin: 0 !important;
    background: var(--pc-bg-light) !important;
    border-bottom: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius) var(--pc-radius) 0 0 !important;
}

/* ── FACET SECTIONS — section.facet ─────────────────────────────── */
#search_filters section.facet {
    border-bottom: 1px solid var(--pc-border-light) !important;
    padding: 0 !important;
    margin: 0 !important;
}

#search_filters section.facet:last-child {
    border-bottom: none !important;
}

/* ── FACET TITLE — div.title > p.facet-title ────────────────────── */
#search_filters section.facet > div.title {
    cursor: pointer !important;
    transition: background var(--pc-transition-fast) !important;
}

#search_filters section.facet > div.title:hover {
    background: var(--pc-bg-light) !important;
}

#search_filters section.facet p.facet-title,
#search_filters section.facet div.title > .h6 {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--pc-heading) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    padding: 12px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
}

/* ── FACET LISTS — ul inside each section ───────────────────────── */
#search_filters section.facet > ul {
    list-style: none !important;
    padding: 0 12px 12px !important;
    margin: 0 !important;
    max-height: none !important;
    overflow: visible !important;
}

#search_filters section.facet > ul > li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── CHECKBOX ITEMS (Selections facet) ──────────────────────────── */
#search_filters label.facet-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 8px !important;
    margin: 0 !important;
    color: var(--pc-text) !important;
    font-size: 13px !important;
    cursor: pointer !important;
    transition: all var(--pc-transition-fast) !important;
    border-radius: var(--pc-radius-xs) !important;
    line-height: 1.4 !important;
}

#search_filters label.facet-label:hover {
    background: var(--pc-primary-subtle) !important;
    color: var(--pc-primary) !important;
}

/* Checkbox box — span.custom-checkbox > span.ps-shown-by-js */
#search_filters span.custom-checkbox {
    display: inline-flex !important;
    align-items: center !important;
    flex-shrink: 0 !important;
    position: relative !important;
}

#search_filters span.custom-checkbox input[type="checkbox"] {
    position: absolute !important;
    opacity: 0 !important;
    width: 18px !important;
    height: 18px !important;
    cursor: pointer !important;
    z-index: 1 !important;
}

#search_filters span.custom-checkbox span.ps-shown-by-js {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    border: 2px solid var(--pc-border) !important;
    border-radius: 4px !important;
    background: var(--pc-bg-white) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all var(--pc-transition-fast) !important;
}

#search_filters span.ps-shown-by-js i.material-icons {
    font-size: 14px !important;
    color: transparent !important;
}

#search_filters label.facet-label:hover span.ps-shown-by-js {
    border-color: var(--pc-primary) !important;
}

#search_filters input[type="checkbox"]:checked + span.ps-shown-by-js {
    background: var(--pc-primary) !important;
    border-color: var(--pc-primary) !important;
}

#search_filters input[type="checkbox"]:checked + span.ps-shown-by-js i.material-icons {
    color: #fff !important;
}

/* Filter link */
#search_filters label.facet-label a.search-link {
    color: inherit !important;
    text-decoration: none !important;
    font-size: 13px !important;
    flex: 1 !important;
}

/* Count badge */
#search_filters .magnitude {
    color: var(--pc-text-muted) !important;
    font-size: 11px !important;
    flex-shrink: 0 !important;
}

/* ── BRAND DROPDOWN — div.facet-dropdown.dropdown ───────────────── */

/* Reset Bootstrap col padding on dropdown wrapper */
#search_filters .facet-dropdown {
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: 100% !important;
    position: relative !important;
}

/* Hide "(aucun filtre)" trigger — list is always visible now */
#search_filters .facet-dropdown a.select-title {
    display: none !important;
}

/* Brand dropdown menu — always visible as a scrollable list */
#search_filters .facet-dropdown .dropdown-menu {
    position: relative !important;
    display: block !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    float: none !important;
    width: 100% !important;
    max-height: 350px !important;
    overflow-y: auto !important;
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius-xs) !important;
    box-shadow: none !important;
    padding: 4px 0 !important;
    margin: 8px 0 0 !important;
    z-index: 1 !important;
    scrollbar-width: thin !important;
    scrollbar-color: var(--pc-border) transparent !important;
}

#search_filters .facet-dropdown .dropdown-menu::-webkit-scrollbar {
    width: 4px !important;
}

#search_filters .facet-dropdown .dropdown-menu::-webkit-scrollbar-thumb {
    background: var(--pc-border) !important;
    border-radius: 4px !important;
}

/* Each brand in dropdown */
#search_filters .facet-dropdown a.select-list {
    display: block;
    padding: 7px 12px !important;
    font-size: 13px !important;
    color: var(--pc-text) !important;
    text-decoration: none !important;
    transition: all var(--pc-transition-fast) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#search_filters .facet-dropdown a.select-list:hover {
    background: var(--pc-primary-subtle) !important;
    color: var(--pc-primary) !important;
}

/* ── PRICE SLIDER — ul.faceted-slider ───────────────────────────── */
#search_filters ul.faceted-slider {
    padding: 8px 16px 16px !important;
    margin: 0 !important;
    list-style: none !important;
    max-height: none !important;
    overflow: visible !important;
}

#search_filters ul.faceted-slider > li {
    padding: 0 !important;
    list-style: none !important;
}

/* Price label */
#search_filters ul.faceted-slider p {
    font-size: 13px !important;
    color: var(--pc-text) !important;
    font-weight: 500 !important;
    margin: 0 0 12px !important;
    text-align: center !important;
}

/* Slider track */
#search_filters .ui-slider {
    height: 4px !important;
    background: var(--pc-border-light) !important;
    border: none !important;
    border-radius: 4px !important;
    position: relative !important;
    margin: 8px 0 !important;
}

#search_filters .ui-slider .ui-slider-range {
    background: var(--pc-primary) !important;
    border-radius: 4px !important;
    height: 100% !important;
}

#search_filters .ui-slider .ui-slider-handle {
    width: 20px !important;
    height: 20px !important;
    background: var(--pc-bg-white) !important;
    border: 3px solid var(--pc-primary) !important;
    border-radius: 50% !important;
    top: -8px !important;
    margin-left: -10px !important;
    box-shadow: 0 2px 6px rgba(8,145,178,0.2) !important;
    cursor: grab !important;
    outline: none !important;
}

#search_filters .ui-slider .ui-slider-handle:hover {
    box-shadow: 0 2px 10px rgba(8,145,178,0.35) !important;
}

/* ==========================================================================
   CATEGORY TREE — exact AN Theme structure
   
   div.block-categories
     ul.category-top-menu
       li > a.h6                         ← title
       li > ul.category-sub-menu
         li[data-depth="0"]
           a                             ← category link
           div.navbar-toggler.collapse-icons  ← toggle
           div.collapse > ul.category-sub-menu
             li[data-depth="1"] > a.category-sub-link
   ========================================================================== */

.block-categories {
    overflow: hidden !important;
}

.block-categories ul.category-top-menu {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.block-categories ul.category-top-menu > li {
    list-style: none !important;
}

/* ── TITLE — a.h6 inside first li ───────────────────────────────── */
.block-categories ul.category-top-menu > li:first-child > a.h6,
.block-categories ul.category-top-menu > li:first-child > a {
    display: block !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: var(--pc-heading) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    padding: 14px 16px !important;
    margin: 0 !important;
    background: var(--pc-bg-light) !important;
    border-bottom: 1px solid var(--pc-border-light) !important;
    line-height: 1.4 !important;
    white-space: normal !important;
    word-break: break-word !important;
    text-decoration: none !important;
}

/* ── CATEGORY LIST ───────────────────────────────────────────────── */
.block-categories ul.category-sub-menu {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.block-categories li[data-depth="0"] {
    position: relative !important;
    border-bottom: 1px solid var(--pc-border-light) !important;
}

.block-categories li[data-depth="0"]:last-child {
    border-bottom: none !important;
}

.block-categories li[data-depth="0"] > a {
    display: block !important;
    padding: 10px 40px 10px 16px !important;
    color: var(--pc-text) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: all var(--pc-transition-fast) !important;
    border-left: 3px solid transparent !important;
    line-height: 1.4 !important;
}

.block-categories li[data-depth="0"] > a:hover {
    color: var(--pc-primary) !important;
    background: var(--pc-primary-subtle) !important;
    border-left-color: var(--pc-primary) !important;
}

.block-categories li[data-depth="0"].current > a,
.block-categories li[data-depth="0"] > a.current {
    color: var(--pc-primary) !important;
    font-weight: 600 !important;
    background: var(--pc-primary-subtle) !important;
    border-left-color: var(--pc-primary) !important;
}

/* ── COLLAPSE TOGGLE — div.navbar-toggler.collapse-icons ─────────── */
.block-categories div.navbar-toggler.collapse-icons {
    position: absolute !important;
    right: 6px !important;
    top: 4px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    cursor: pointer !important;
    color: var(--pc-text-muted) !important;
    border-radius: var(--pc-radius-xs) !important;
    transition: all var(--pc-transition-fast) !important;
    z-index: 2 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    overflow: hidden !important;
}

.block-categories div.navbar-toggler.collapse-icons:hover {
    color: var(--pc-primary) !important;
    background: var(--pc-primary-subtle) !important;
}

.block-categories .collapse-icons i.material-icons {
    font-size: 22px !important;
    line-height: 1 !important;
    overflow: hidden !important;
    width: 22px !important;
    height: 22px !important;
}

.block-categories .collapse-icons i.material-icons.remove {
    display: none !important;
}

.block-categories .collapse-icons[aria-expanded="true"] i.material-icons.add {
    display: none !important;
}

.block-categories .collapse-icons[aria-expanded="true"] i.material-icons.remove {
    display: inline-block !important;
}

/* ── COLLAPSE CONTAINER ─────────────────────────────────────────── */
.block-categories li[data-depth="0"] > div.collapse,
.block-categories li[data-depth="0"] > div.collapse.in {
    border-top: 1px solid var(--pc-border-light) !important;
}

/* ── DEPTH-1 (subcategories) ────────────────────────────────────── */
.block-categories li[data-depth="1"] {
    border-bottom: none !important;
}

.block-categories li[data-depth="1"] > a,
.block-categories li[data-depth="1"] > a.category-sub-link {
    display: block !important;
    padding: 7px 16px 7px 28px !important;
    font-size: 12.5px !important;
    font-weight: 400 !important;
    color: var(--pc-text-light) !important;
    text-decoration: none !important;
    transition: all var(--pc-transition-fast) !important;
    line-height: 1.4 !important;
    border-left: none !important;
}

.block-categories li[data-depth="1"] > a:hover {
    color: var(--pc-primary) !important;
    background: var(--pc-primary-subtle) !important;
}

.block-categories li[data-depth="1"].current > a {
    color: var(--pc-primary) !important;
    font-weight: 500 !important;
    background: var(--pc-primary-subtle) !important;
}

.block-categories li[data-depth="2"] > a {
    padding-left: 44px !important;
    font-size: 12px !important;
}


/* ==========================================================================
   ACTIVE FILTERS
   ========================================================================== */
#js-active-search-filters .filter-block {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: var(--pc-primary-subtle) !important;
    border: 1px solid rgba(8,145,178,0.15) !important;
    border-radius: 50px !important;
    padding: 5px 12px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--pc-primary-dark) !important;
    margin: 0 6px 6px 0 !important;
}


/* ==========================================================================
   SORTING TOOLBAR
   ========================================================================== */

/* Hide grid/list view switcher */
.collection-view,
div.collection-view {
    display: none !important;
}

/* Fix Bootstrap grid: col-md-7 → 50% to avoid 13-column overflow */
#js-product-list-top .filters-toggler-block,
#js-product-list-top .col-md-7,
#js-product-list-top > .col-md-6:last-child {
    flex: 0 0 50% !important;
    max-width: 50% !important;
    width: 50% !important;
}

/* "Il y a X produits" count */
.total-products {
    font-size: 13px !important;
    color: var(--pc-text-light) !important;
}

.total-products p {
    margin: 0 !important;
}

#js-product-list-top {
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius) !important;
    padding: 14px 20px !important;
    margin-bottom: 20px !important;
    box-shadow: var(--pc-shadow-sm) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* "Trier par :" label */
#js-product-list-top .sort-by {
    font-size: 13px !important;
    color: var(--pc-text-light) !important;
    font-weight: 500 !important;
}

/* Sort dropdown — button.select-title */
#js-product-list-top .products-sort-order button.select-title {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    background: var(--pc-bg-light) !important;
    border: 1px solid var(--pc-border) !important;
    border-radius: var(--pc-radius-xs) !important;
    padding: 8px 12px !important;
    font-size: 13px !important;
    color: var(--pc-text) !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: border-color var(--pc-transition-fast) !important;
}

#js-product-list-top .products-sort-order button.select-title:hover {
    border-color: var(--pc-primary) !important;
}

#js-product-list-top .products-sort-order button.select-title > i.material-icons {
    font-size: 20px !important;
    color: var(--pc-text-muted) !important;
}

/* Sort dropdown menu */
#js-product-list-top .products-sort-order .dropdown-menu {
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border) !important;
    border-radius: var(--pc-radius-sm) !important;
    box-shadow: var(--pc-shadow-md) !important;
    padding: 6px !important;
    min-width: 220px !important;
    z-index: 50 !important;
}

#js-product-list-top .products-sort-order .dropdown-menu a.select-list {
    display: block !important;
    padding: 9px 16px !important;
    font-size: 13px !important;
    color: var(--pc-text) !important;
    border-radius: var(--pc-radius-xs) !important;
    transition: all var(--pc-transition-fast) !important;
    text-decoration: none !important;
}

#js-product-list-top .products-sort-order .dropdown-menu a.select-list:hover {
    background: var(--pc-primary-subtle) !important;
    color: var(--pc-primary) !important;
}

/* ==========================================================================
   PRODUCT GRID
   ========================================================================== */

/* Ensure product list takes full width */
#js-product-list {
    width: 100% !important;
}

#js-product-list .products,
.products {
    display: grid !important;
    grid-template-columns: repeat(var(--pc-cols-desktop), 1fr) !important;
    column-gap: var(--pc-gap) !important;
    row-gap: var(--pc-gap-row) !important;
    padding: 0 !important;
    margin: 0 !important;
    align-items: stretch !important;
}

/* Override Bootstrap columns from AN Theme */
#js-product-list .products .product-miniature,
.products .product-miniature,
.products article.product-miniature {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding: 0 !important;
    margin: 0 !important;
    float: none !important;
}


/* ==========================================================================
   PRODUCT CARD — article.product-miniature
   ========================================================================== */
article.product-miniature {
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius) !important;
    overflow: visible !important;
    transition: all var(--pc-transition) !important;
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}

article.product-miniature:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--pc-shadow-hover) !important;
    border-color: rgba(8,145,178,0.15) !important;
}

/* Inner .thumbnail-container */
article.product-miniature .thumbnail-container {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    flex: 1 !important;
}


/* ==========================================================================
   PRODUCT IMAGE — .thumbnail-container-image
   ========================================================================== */
article.product-miniature .thumbnail-container-image {
    position: relative !important;
    background: #FFFFFF !important;
    overflow: hidden !important;
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--pc-radius) var(--pc-radius) 0 0 !important;
    flex-shrink: 0 !important;
}

/* Subtle separator */
article.product-miniature .thumbnail-container-image::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 16px !important;
    right: 16px !important;
    height: 1px !important;
    background: var(--pc-border-light) !important;
    z-index: 2 !important;
}

/* Image link */
article.product-miniature a.thumbnail.product-thumbnail {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    padding: 20px !important;
}

/* The image itself */
article.product-miniature .thumbnail-container-image img {
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

article.product-miniature:hover .thumbnail-container-image img {
    transform: scale(1.05) !important;
}


/* ==========================================================================
   PRODUCT FLAGS — ul.product-flags
   ========================================================================== */
article.product-miniature .product-flags {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    z-index: 5 !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

article.product-miniature .product-flag {
    display: inline-flex !important;
    padding: 4px 10px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    border-radius: 5px !important;
    line-height: 1.3 !important;
    backdrop-filter: blur(8px) !important;
}

article.product-miniature .product-flag.new {
    background: rgba(8, 145, 178, 0.9) !important;
    color: #fff !important;
}

article.product-miniature .product-flag.discount {
    background: rgba(229, 62, 62, 0.9) !important;
    color: #fff !important;
}

article.product-miniature .product-flag.on-sale {
    background: rgba(229, 62, 62, 0.9) !important;
    color: #fff !important;
}

article.product-miniature .product-flag.pack {
    background: rgba(56, 161, 105, 0.9) !important;
    color: #fff !important;
}

/* Hide duplicate discount-percentage */
article.product-miniature .product-flag.discount-percentage {
    display: none !important;
}


/* ==========================================================================
   HIGHLIGHTED INFORMATIONS — wishlist + quick view
   ========================================================================== */
article.product-miniature .highlighted-informations {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    bottom: auto !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    align-items: flex-end !important;
    z-index: 6 !important;
    padding: 0 !important;
    opacity: 0 !important;
    transform: translateX(4px) !important;
    transition: all var(--pc-transition) !important;
}

article.product-miniature:hover .highlighted-informations {
    opacity: 1 !important;
    transform: translateX(0) !important;
}

/* Wishlist */
article.product-miniature .an_wishlist-mini {
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255,255,255,0.92) !important;
    border-radius: 50% !important;
    backdrop-filter: blur(8px) !important;
    border: 1px solid var(--pc-border-light) !important;
    cursor: pointer !important;
    transition: all var(--pc-transition-fast) !important;
}

article.product-miniature .an_wishlist-mini:hover {
    background: #fff !important;
    border-color: var(--pc-danger) !important;
}

article.product-miniature .an_wishlist-mini svg {
    width: 16px !important;
    height: 14px !important;
}

article.product-miniature .an_wishlist-mini:hover svg path {
    fill: var(--pc-danger) !important;
}

article.product-miniature .an_wishlist-mini-count {
    display: none !important;
}

/* Quick view */
article.product-miniature .quick-view {
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255,255,255,0.92) !important;
    border-radius: 50% !important;
    backdrop-filter: blur(8px) !important;
    border: 1px solid var(--pc-border-light) !important;
    cursor: pointer !important;
    transition: all var(--pc-transition-fast) !important;
    text-decoration: none !important;
}

article.product-miniature .quick-view:hover {
    background: var(--pc-primary) !important;
    border-color: var(--pc-primary) !important;
}

article.product-miniature .quick-view svg {
    width: 16px !important;
    height: 16px !important;
}

article.product-miniature .quick-view:hover svg path {
    fill: #fff !important;
}


/* ==========================================================================
   PRODUCT DESCRIPTION — .product-description
   ========================================================================== */
article.product-miniature .product-description {
    padding: 16px 16px 0 !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    background: transparent !important;
    border: none !important;
    text-align: left !important;
}

/* Title — h3.h3.product-title — 3 LINES */
article.product-miniature h3.product-title {
    font-size: 13.5px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
    color: var(--pc-heading) !important;
    margin: 0 0 6px !important;
    padding: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    min-height: calc(13.5px * 1.45 * 2) !important;
}

/* Brand name — injected by JS from meta[itemprop="brand"] */
article.product-miniature .pc-brand-name {
    display: block !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: var(--pc-primary) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    margin: 0 0 4px !important;
    padding: 0 !important;
    text-decoration: none !important;
    transition: color var(--pc-transition-fast) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    order: -1 !important;
    text-align: center !important;
}

article.product-miniature .pc-brand-name:hover {
    color: var(--pc-primary-dark) !important;
}

article.product-miniature h3.product-title a {
    color: inherit !important;
    text-decoration: none !important;
    transition: color var(--pc-transition-fast) !important;
}

article.product-miniature h3.product-title a:hover {
    color: var(--pc-primary) !important;
}

/* Short description — p.an_short_description */
article.product-miniature p.an_short_description {
    font-size: 12.5px !important;
    line-height: 1.55 !important;
    color: var(--pc-text-light) !important;
    margin: 0 0 auto !important;
    padding: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}


/* ==========================================================================
   PRICE — .product-price-and-shipping
   Contains both price display AND add-to-cart form in AN Theme
   ========================================================================== */
article.product-miniature .product-price-and-shipping {
    padding: 12px 16px 16px !important;
    margin-top: auto !important;
    border: none !important;
}

article.product-miniature .product-miniature-prices {
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

/* Current price */
article.product-miniature .product-miniature-prices .price {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--pc-heading) !important;
    line-height: 1.2 !important;
}

/* When there's a regular price = discount → current price becomes red */
article.product-miniature .product-miniature-prices .regular-price ~ .price,
article.product-miniature .product-miniature-prices .price:not(:only-child) {
    color: var(--pc-danger) !important;
}

/* Force: only price (no discount) stays dark */
article.product-miniature .product-miniature-prices .price:only-child {
    color: var(--pc-heading) !important;
}

/* Old price */
article.product-miniature .product-miniature-prices .regular-price {
    font-size: 13px !important;
    color: var(--pc-text-muted) !important;
    text-decoration: line-through !important;
    font-weight: 400 !important;
}

/* SR-only */
article.product-miniature .product-miniature-prices .sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
}


/* ==========================================================================
   ADD TO CART — .an_productattributes
   ========================================================================== */
article.product-miniature .an_productattributes {
    padding: 10px 0 0 !important;
    margin: 0 !important;
}

article.product-miniature .an_productattributesForm {
    margin: 0 !important;
    padding: 0 !important;
}

/* Qty + Add row */
article.product-miniature .an_productattributes-qty-add {
    display: flex !important;
    gap: 8px !important;
    align-items: stretch !important;
}

/* Qty input */
article.product-miniature .an_productattributes-qty-container {
    flex: 0 0 auto !important;
}

article.product-miniature input.an_productattributes-qty {
    width: 48px !important;
    height: 100% !important;
    min-height: 40px !important;
    text-align: center !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--pc-heading) !important;
    background: var(--pc-bg-light) !important;
    border: 1px solid var(--pc-border) !important;
    border-radius: var(--pc-radius-xs) !important;
    padding: 0 4px !important;
    transition: border-color var(--pc-transition-fast) !important;
    -moz-appearance: textfield !important;
}

article.product-miniature input.an_productattributes-qty::-webkit-inner-spin-button,
article.product-miniature input.an_productattributes-qty::-webkit-outer-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

article.product-miniature input.an_productattributes-qty:focus {
    border-color: var(--pc-primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(8,145,178,0.1) !important;
}

/* Add button container */
article.product-miniature .an_productattributes-add {
    flex: 1 !important;
}

/* THE BUTTON */
article.product-miniature .an_productattributes-add button.btn,
article.product-miniature .an_productattributes-add .js-an_productattributes-add-to-cart,
article.product-miniature button[data-button-action="add-to-cart"] {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 40px !important;
    padding: 10px 16px !important;
    background: var(--pc-primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--pc-radius-sm) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all var(--pc-transition-fast) !important;
    font-family: inherit !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

article.product-miniature .an_productattributes-add button.btn:hover,
article.product-miniature button[data-button-action="add-to-cart"]:hover {
    background: var(--pc-primary-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(8,145,178,0.25) !important;
}

/* Variant selectors (if product has attributes) */
article.product-miniature .an_pa_product-variants {
    margin: 0 !important;
    padding: 0 !important;
}

article.product-miniature .an_pa_product-variants:empty {
    display: none !important;
}


/* ==========================================================================
   PAGINATION
   ========================================================================== */
#js-product-list nav.pagination,
#js-product-list-bottom {
    margin-top: 48px !important;
    padding-top: 32px !important;
    border-top: 1px solid var(--pc-border-light) !important;
}

nav.pagination .page-list {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

nav.pagination .page-list li {
    list-style: none !important;
}

nav.pagination .page-list li a,
nav.pagination .page-list li span.spacer {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 40px !important;
    height: 40px !important;
    padding: 0 12px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--pc-text) !important;
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border) !important;
    border-radius: var(--pc-radius-sm) !important;
    text-decoration: none !important;
    transition: all var(--pc-transition-fast) !important;
    cursor: pointer !important;
}

nav.pagination .page-list li a:hover {
    border-color: var(--pc-primary) !important;
    color: var(--pc-primary) !important;
    background: var(--pc-primary-subtle) !important;
}

nav.pagination .page-list li.current a,
nav.pagination .page-list li.active a {
    background: var(--pc-primary) !important;
    color: #fff !important;
    border-color: var(--pc-primary) !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(8,145,178,0.25) !important;
}

nav.pagination .page-list li.disabled a,
nav.pagination .page-list li.disabled span {
    color: var(--pc-text-muted) !important;
    background: var(--pc-bg-light) !important;
    border-color: var(--pc-border-light) !important;
    cursor: default !important;
    pointer-events: none !important;
}

nav.pagination .showing {
    font-size: 13px !important;
    color: var(--pc-text-light) !important;
    text-align: center !important;
    margin-top: 12px !important;
}


/* ==========================================================================
   SEO TEXT (bottom of category page)
   ========================================================================== */
.block-category .category-description-bottom,
#category-description-bottom,
#js-product-list + .block-category {
    background: var(--pc-bg-white) !important;
    border: 1px solid var(--pc-border-light) !important;
    border-radius: var(--pc-radius) !important;
    padding: 28px 32px !important;
    margin-top: 32px !important;
    box-shadow: var(--pc-shadow-sm) !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    color: var(--pc-text) !important;
}


/* ==========================================================================
   RESPONSIVE — TABLET
   ========================================================================== */
@media (max-width: 1199px) {
    /* Narrower sidebar on tablet */
    #left-column {
        flex: 0 0 220px !important;
        max-width: 220px !important;
        width: 220px !important;
        padding-right: 16px !important;
    }

    #content-wrapper {
        max-width: calc(100% - 220px) !important;
    }

    #js-product-list .products,
    .products {
        grid-template-columns: repeat(var(--pc-cols-tablet), 1fr) !important;
        column-gap: 16px !important;
        row-gap: 24px !important;
    }

    article.product-miniature h3.product-title {
        font-size: 13px !important;
    }

    article.product-miniature .product-miniature-prices .price {
        font-size: 16px !important;
    }
}


/* ==========================================================================
   RESPONSIVE — MOBILE
   ========================================================================== */
@media (max-width: 767px) {
    /* Reset sidebar layout on mobile */
    #left-column {
        flex: none !important;
        max-width: 100% !important;
        width: 100% !important;
        padding-right: 0 !important;
        position: static !important;
    }

    #content-wrapper {
        max-width: 100% !important;
    }

    #js-product-list .products,
    .products {
        grid-template-columns: repeat(2, 1fr) !important;
        column-gap: 10px !important;
        row-gap: 18px !important;
    }

    #js-product-list-header,
    .block-category {
        padding: 20px !important;
    }

    .block-category h1,
    #js-product-list-header h1 {
        font-size: 20px !important;
    }

    article.product-miniature .product-description {
        padding: 10px 12px 0 !important;
    }

    article.product-miniature h3.product-title {
        font-size: 12px !important;
        -webkit-line-clamp: 3 !important;
    }

    article.product-miniature p.an_short_description {
        display: none !important;
    }

    article.product-miniature .product-price-and-shipping {
        padding: 8px 12px 12px !important;
    }

    article.product-miniature .product-miniature-prices .price {
        font-size: 15px !important;
    }

    article.product-miniature .an_productattributes-qty-container {
        display: none !important;
    }

    article.product-miniature .an_productattributes-add button.btn {
        padding: 8px 12px !important;
        font-size: 12px !important;
        min-height: 36px !important;
    }

    article.product-miniature .highlighted-informations {
        opacity: 1 !important;
        transform: none !important;
    }

    article.product-miniature .quick-view {
        display: none !important;
    }

    article.product-miniature .an_wishlist-mini {
        width: 30px !important;
        height: 30px !important;
    }

    #js-product-list-top {
        padding: 10px 12px !important;
    }

    #js-product-list nav.pagination,
    #js-product-list-bottom {
        margin-top: 32px !important;
        padding-top: 20px !important;
    }

    nav.pagination .page-list li a {
        min-width: 36px !important;
        height: 36px !important;
        font-size: 13px !important;
    }

    #search_filters_wrapper.show,
    #search_filters.show {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        max-width: 340px !important;
        height: 100vh !important;
        z-index: 9999 !important;
        overflow-y: auto !important;
        box-shadow: 4px 0 24px rgba(0,0,0,0.15) !important;
        border-radius: 0 !important;
    }
}

@media (max-width: 400px) {
    #js-product-list .products,
    .products {
        gap: 8px !important;
    }

    article.product-miniature .product-description {
        padding: 8px 10px 0 !important;
    }

    article.product-miniature .an_productattributes {
        padding: 6px 10px 10px !important;
    }

    article.product-miniature h3.product-title {
        font-size: 11.5px !important;
    }

    article.product-miniature .product-miniature-prices .price {
        font-size: 14px !important;
    }
}


/* ==========================================================================
   PRINT
   ========================================================================== */
@media print {
    #left-column,
    #search_filters,
    .products-sort-order,
    .an_productattributes,
    .highlighted-informations,
    nav.pagination,
    .product-flags {
        display: none !important;
    }

    #js-product-list .products {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    article.product-miniature {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
        break-inside: avoid !important;
    }

    article.product-miniature:hover {
        transform: none !important;
    }
}
