/* ═══════════════════════════════════════
   BREADCRUMB & LAYOUT (come layout-proposta.html)
   ═══════════════════════════════════════ */
/* Breadcrumb stesso respiro e allineamento del carrello/pagine */
.shop-breadcrumb,
.breadcrumb { max-width:1280px; margin:0 auto; padding:20px 24px 8px; font-size:13px; color:#4b5563; }
.shop-breadcrumb a,
.breadcrumb a { color:#475569; text-decoration:none; }
.shop-breadcrumb a:hover,
.breadcrumb a:hover { color:#1e293b; }
.shop-archive.container { max-width:1280px; margin:0 auto; padding:0 24px 60px; }

/* ═══════════════════════════════════════
   PROPOSTA A — Blocco unico shop-head (titolo + pill + toolbar)
   Titolo allineato a sinistra come breadcrumb, stesse distanze
   ═══════════════════════════════════════ */
.shop-head {
  background:#fff;
  border-radius:20px;
  padding:20px 24px 0;
  margin-bottom:24px;
}

.shop-head__top {
  text-align: center;
  padding-bottom: 24px;
}

.shop-head__title {
  font-size:26px;
  font-weight:700;
  color:#1e293b;
  margin:0;
}

.shop-head__count {
  font-size:14px;
  color:#475569;
  margin-top:6px;
}

/* Pills dentro lo stesso blocco bianco */
.shop-head__cats {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  padding:16px 0;
  border-top:1px solid #f1f5f9;
}

.pill,
.shop-head__cats .shop-cat-pill {
  display:inline-flex;
  align-items:center;
  padding:8px 18px;
  border-radius:9999px;
  font-size:13px;
  font-weight:600;
  text-decoration:none;
  color:#64748b;
  background:#f8fafc;
  border:1.5px solid #e2e8f0;
  transition:all 0.15s;
}
.pill:hover,
.shop-head__cats .shop-cat-pill:hover { border-color:#cbd5e1; color:#1e293b; background:#f1f5f9; }
.pill--active,
.shop-head__cats .pill--active,
.shop-head__cats .shop-cat-pill.pill--active { background:#1e293b; border-color:#1e293b; color:#fff; }
.pill--active:hover,
.shop-head__cats .pill--active:hover { background:#334155; border-color:#334155; }

/* Toolbar dentro lo stesso blocco */
.shop-head__toolbar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  border-top:1px solid #f1f5f9;
}

.toolbar-right { display:flex; align-items:center; gap:12px; }

.filter-btn {
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 20px;
  border-radius:10px;
  background:#f8fafc;
  border:2px solid #e2e8f0;
  font-family:inherit;
  font-size:14px;
  font-weight:600;
  color:#475569;
  cursor:pointer;
  transition:all 0.15s;
}
.filter-btn:hover { border-color:#cbd5e1; background:#f1f5f9; }
.filter-btn:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }
.filter-btn svg { width:18px; height:18px; }
.filter-btn__badge,
.filter-btn__count {
  min-width:22px;
  height:22px;
  padding:0 6px;
  background:#dc2626;
  color:#fff;
  border-radius:9999px;
  font-size:12px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.sort-select,
.shop-head__toolbar .orderby {
  padding:10px 40px 10px 16px;
  border-radius:10px;
  border:2px solid #e2e8f0;
  background:#fff;
  font-family:inherit;
  font-size:14px;
  font-weight:500;
  appearance:none;
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
}
.shop-head__toolbar .orderby:focus-visible,
.sort-select:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }

.woocommerce .woocommerce-ordering {
  margin: 0 0 0;
}

.view-toggle { display:flex; gap:4px; background:#f1f5f9; padding:4px; border-radius:10px; }
.view-btn {
  width:40px;
  height:40px;
  border:none;
  background:transparent;
  border-radius:8px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#94a3b8;
  transition:all 0.15s;
}
.view-btn:hover { color:#475569; }
.view-btn--active,
.view-btn.active { background:#fff; color:#dc2626; box-shadow:0 2px 4px rgba(0,0,0,0.05); }
.view-btn:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }
.view-btn svg { width:20px; height:20px; }

/* ═══════════════════════════════════════
   DRAWER FILTRI
   ═══════════════════════════════════════ */
.filter-drawer-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.55); backdrop-filter:blur(3px);
    z-index:999; opacity:0; visibility:hidden; transition:opacity 0.3s, visibility 0.3s;
}
.filter-drawer-overlay.is-active { opacity:1; visibility:visible; }

.filter-drawer {
    position:fixed; top:0; left:0; bottom:0;
    width:380px; max-width:90vw;
    background:var(--color-white,#fff); z-index:1000;
    display:flex; flex-direction:column;
    transform:translateX(-100%); transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);
    box-shadow:8px 0 40px rgba(15,23,42,0.15);
}
.filter-drawer.is-open { transform:translateX(0); }
body.drawer-open { overflow:hidden; }

.filter-drawer__header {
    display:flex; align-items:center; justify-content:space-between;
    padding:20px 24px; border-bottom:1px solid var(--color-gray-200,#e5e7eb); flex-shrink:0;
}
.filter-drawer__title { display:flex; align-items:center; gap:10px; font-size:18px; font-weight:700; color:var(--color-gray-800,#1e293b); margin:0; }
.filter-drawer__close {
    min-width:44px; min-height:44px;
    display:flex; align-items:center; justify-content:center;
    border:2px solid var(--color-gray-300); background:var(--color-gray-100,#f1f5f9);
    border-radius:10px; cursor:pointer; color:#475569; transition:background 0.15s;
}
.filter-drawer__close:hover { background:var(--color-gray-200); }
.filter-drawer__close:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }

.filter-drawer__body { flex:1; overflow-y:auto; padding:0; }
.filter-drawer__footer {
    padding:20px 24px; border-top:1px solid var(--color-gray-200,#e5e7eb); flex-shrink:0; text-align:center;
}
.filter-drawer__apply {
    display:block; width:100%; min-height:48px; padding:14px 24px;
    background:var(--color-primary,#dc2626); color:#fff; border:none; border-radius:10px;
    font-family:inherit; font-size:16px; font-weight:700; cursor:pointer;
    transition:background 0.15s;
}
.filter-drawer__apply:hover { background:var(--color-primary-dark,#b91c1c); }
.filter-drawer__apply:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }
.filter-drawer__reset {
    display:block; margin-top:12px; font-size:13px; font-weight:600;
    color:#475569; text-decoration:none; min-height:44px; line-height:44px;
}
.filter-drawer__reset:hover { color:var(--color-gray-800,#1e293b); }
.filter-drawer__reset:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }

/* ═══════════════════════════════════════
   FILTER SECTIONS
   ═══════════════════════════════════════ */
.filter-section { padding:16px 20px 0; }
.filter-section + .filter-section { border-top:1px solid var(--color-gray-100,#f1f5f9); margin-top:4px; padding-top:16px; }
.filter-section__title {
    font-size:11px; font-weight:700; color:#475569; margin:0 0 10px;
    text-transform:none; letter-spacing:0.5px;
}
.filter-section__content { margin:0; }

/* ═══════════════════════════════════════
   CATEGORIA (filter-cat-select: select ad albero come colore)
   ═══════════════════════════════════════ */
.filter-cat-select { position:relative; }
.filter-cat-select__toggle {
    display:flex; align-items:center; justify-content:space-between; gap:8px;
    width:100%; min-height:40px; padding:8px 12px;
    border:2px solid var(--color-gray-200); border-radius:8px;
    background:var(--color-white); font-family:inherit; font-size:14px; font-weight:500; color:#475569;
    cursor:pointer; text-align:left; box-sizing:border-box;
}
.filter-cat-select__toggle:hover { border-color:var(--color-gray-300); }
.filter-cat-select__toggle:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }
.filter-cat-select__chevron { flex-shrink:0; transition:transform 0.2s; }
.filter-cat-select__toggle[aria-expanded="true"] .filter-cat-select__chevron { transform:rotate(180deg); }

.filter-cat-select__dropdown {
    position:absolute; top:100%; left:0; right:0; margin-top:4px;
    background:var(--color-white); border:2px solid var(--color-gray-200); border-radius:10px;
    box-shadow:0 10px 40px rgba(15,23,42,0.12);
    z-index:10; max-height:260px; overflow-y:auto; overflow-x:hidden;
    display:flex; flex-direction:column;
}
.filter-cat-select__dropdown[hidden] { display:none !important; }
.filter-cat-select__search {
    flex-shrink:0; width:100%; padding:8px 12px; border:none; border-bottom:1px solid var(--color-gray-100);
    font-family:inherit; font-size:14px; box-sizing:border-box;
}
.filter-cat-select__search:focus { outline:none; border-bottom-color:var(--color-primary); }

.filter-cat-select__option {
    display:flex; align-items:center; gap:6px;
    padding:8px 12px; min-height:40px; box-sizing:border-box;
    border:none; background:transparent; width:100%; max-width:100%;
    font-family:inherit; font-size:14px; color:#475569;
    text-align:left; cursor:pointer;
    transition:background 0.1s;
}
.filter-cat-select__option:hover { background:var(--color-gray-50); }
.filter-cat-select__option:focus-visible { outline:2px solid var(--color-primary); outline-offset:-2px; }
.filter-cat-select__option.is-active { background:var(--color-gray-100,#f1f5f9); color:var(--color-gray-800,#1e293b); font-weight:600; }
.filter-cat-select__name { flex:1; min-width:0; }
.filter-cat-select__count { font-size:12px; color:var(--color-gray-500); flex-shrink:0; }
.filter-cat-select__option.is-active .filter-cat-select__count { color:var(--color-gray-600); }
/* Indent sottocategorie: solo padding, niente bordi/margini per evitare scroll orizzontale */
.filter-cat-select__option[data-level="1"] { padding-left:24px; }
.filter-cat-select__option[data-level="2"] { padding-left:36px; }
.filter-cat-select__option[data-level="3"] { padding-left:48px; }
.filter-cat-select--child { margin-top:14px; position:relative; z-index:1; }
.filter-cat-select--child .filter-section__title { margin-bottom:10px; }
.filter-cat-select--child.is-dropdown-open { z-index:20; }
.filter-cat-select--child.is-dropdown-open .filter-cat-select { position:relative; z-index:21; }
.filter-cat-select--child .filter-cat-select__dropdown { z-index:25; }
.filter-cat-select--child .filter-cat-select__dropdown:not([hidden]) { display:flex !important; flex-direction:column; }

/* ═══════════════════════════════════════
   COLORE (filter-color-select: dropdown sotto bottone)
   ═══════════════════════════════════════ */
.filter-color-select { position:relative; }
.filter-color-select__toggle {
    display:flex; align-items:center; justify-content:space-between; gap:8px;
    width:100%; min-height:40px; padding:8px 12px;
    border:2px solid var(--color-gray-200); border-radius:8px;
    background:var(--color-white); font-family:inherit; font-size:14px; font-weight:500; color:#475569;
    cursor:pointer; text-align:left; box-sizing:border-box;
}
.filter-color-select__toggle:hover { border-color:var(--color-gray-300); }
.filter-color-select__toggle:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }
.filter-color-select__chevron { flex-shrink:0; transition:transform 0.2s; }
.filter-color-select__toggle[aria-expanded="true"] .filter-color-select__chevron { transform:rotate(180deg); }

/* Select chiuso: lista visibile solo quando aperto */
.filter-color-select__dropdown {
    position:absolute; top:100%; left:0; right:0; margin-top:4px;
    background:var(--color-white); border:2px solid var(--color-gray-200); border-radius:8px;
    box-shadow:0 10px 40px rgba(15,23,42,0.12);
    z-index:10; max-height:260px; overflow-y:auto; overflow-x:hidden;
    display:flex; flex-direction:column;
}
.filter-color-select__dropdown[hidden] { display:none !important; }
.filter-color-select__search {
    flex-shrink:0; width:100%; padding:8px 12px; border:none; border-bottom:1px solid var(--color-gray-100);
    font-family:inherit; font-size:14px; box-sizing:border-box;
}
.filter-color-select__search:focus { outline:none; border-bottom-color:var(--color-primary); }

.filter-color-select__option {
    display:flex; align-items:center; gap:6px;
    padding:8px 12px; min-height:40px; box-sizing:border-box;
    border:none; background:transparent; width:100%; max-width:100%;
    font-family:inherit; font-size:14px; color:#475569;
    text-align:left; cursor:pointer;
    transition:background 0.1s;
}
.filter-color-select__option:hover { background:var(--color-gray-50); }
.filter-color-select__option:focus-visible { outline:3px solid var(--color-primary); outline-offset:-2px; }
.filter-color-select__option.is-active { background:var(--color-gray-100,#f1f5f9); color:var(--color-gray-800,#1e293b); font-weight:600; }
.filter-color-select__dot {
    width:22px; height:22px; border-radius:9999px; flex-shrink:0;
    border:2px solid #fff; box-shadow:0 0 0 1px rgba(15,23,42,0.2);
}
.filter-color-select__name { flex:1; }
.filter-color-select__count { font-size:12px; color:var(--color-gray-500); }
.filter-color-select__option.is-active .filter-color-select__count { color:var(--color-gray-600); opacity:0.9; }

/* ═══════════════════════════════════════
   PREZZO: una riga (Da €X / a €Y), track con due range sovrapposti
   ═══════════════════════════════════════ */
.price-range--row { margin-bottom:20px; }
.price-range__values {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:16px; font-size:14px; color:#475569;
}
.price-range__values strong { color:var(--color-gray-800,#1e293b); font-weight:700; }

.price-range__track {
    position:relative; height:40px; display:flex; align-items:center;
}
.price-range__track::before {
    content:''; position:absolute; left:0; right:0; top:50%; height:4px;
    transform:translateY(-50%); background:var(--color-gray-200,#e5e7eb); border-radius:9999px; pointer-events:none;
}
.price-range__track input[type="range"] {
    position:absolute; left:0; top:0; width:100%; height:100%; margin:0; padding:0;
    appearance:none; -webkit-appearance:none; background:transparent; pointer-events:none; z-index:2;
}
.price-range__track input[type="range"]::-webkit-slider-runnable-track { height:4px; background:transparent; border:none; }
.price-range__track input[type="range"]::-moz-range-track { height:4px; background:transparent; border:none; }
.price-range__track input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance:none; width:22px; height:22px; border-radius:9999px;
    background:var(--color-primary,#dc2626); border:3px solid #fff;
    box-shadow:0 0 0 1px rgba(15,23,42,0.25),0 2px 6px rgba(0,0,0,0.15);
    pointer-events:auto; cursor:grab; margin-top:-9px;
}
.price-range__track input[type="range"]::-moz-range-thumb {
    width:22px; height:22px; border-radius:9999px;
    background:var(--color-primary,#dc2626); border:3px solid #fff;
    box-shadow:0 0 0 1px rgba(15,23,42,0.25),0 2px 6px rgba(0,0,0,0.15);
    pointer-events:auto; cursor:grab;
}
.price-range__track input[type="range"]:focus-visible::-webkit-slider-thumb {
    box-shadow:0 0 0 3px var(--color-primary), 0 0 0 5px rgba(220,38,38,0.3);
}
.price-range__track input[type="range"]:focus-visible::-moz-range-thumb {
    box-shadow:0 0 0 3px var(--color-primary), 0 0 0 5px rgba(220,38,38,0.3);
}

.price-apply-btn {
    width:100%; min-height:44px; padding:14px 24px; margin-top:20px; margin-bottom:0;
    background:var(--color-primary); color:#fff; border:none; border-radius:10px;
    font-family:inherit; font-size:14px; font-weight:600; cursor:pointer; transition:background 0.15s;
}
.price-apply-btn:hover { background:var(--color-primary-dark,#b91c1c); }
.price-apply-btn:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }

/* ═══════════════════════════════════════
   ACTIVE FILTERS (come layout-proposta.html)
   ═══════════════════════════════════════ */
.active-filters {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-bottom:24px;
}
.active-filters .badge,
.filter-badge {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:9999px;
  background:#fff;
  color:#475569;
  font-size:13px;
  text-decoration:none;
  border:1.5px solid #e2e8f0;
  transition:all 0.15s;
}
.active-filters .badge:hover,
.filter-badge:hover { border-color:#fecaca; background:#fef2f2; }
.active-filters .badge:focus-visible,
.filter-badge:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }
.active-filters .badge__label,
.filter-badge__label { font-weight:700; text-transform:none; font-size:11px; letter-spacing:0.03em; color:var(--color-gray-500); }
.badge__x {
  width:16px;
  height:16px;
  border-radius:9999px;
  background:#e5e7eb; /* leggermente più scuro */
  color:#111827;      /* testo quasi nero per contrasto massimo */
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:12px;     /* evita testo “too small” */
  font-weight:700;
}
.badge:hover .badge__x { background:#fecaca; color:#dc2626; }
.clear-all,
.active-filters__clear {
    margin-left:auto;
    font-size:13px;
    font-weight:600;
    color:#b91c1c; /* rosso più scuro per contrasto su bg grigio */
    text-decoration:none;
}
.clear-all:hover,
.active-filters__clear:hover { text-decoration:underline; }
.clear-all:focus-visible,
.active-filters__clear:focus-visible { outline:3px solid var(--color-primary); outline-offset:2px; }

/* Wrapper prodotti (sostituito via AJAX al click categoria nel drawer) */
#shop-products-wrap.is-loading { opacity:0.7; pointer-events:none; transition:opacity 0.2s; }

/* ═══════════════════════════════════════
   PRODUCTS GRID (archivio, home, blocchi vari)
   ═══════════════════════════════════════ */
.products-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.product-card { position:relative; }
.product-card__badges { position:absolute; top:12px; left:12px; z-index:2; display:flex; flex-direction:column; gap:6px; }
.product-card__link {
    display:flex;
    flex-direction:column;
    height:100%;
    text-decoration:none;
    color:inherit;
    border-radius:16px;
    outline:none;
}
.product-card__link:focus,
.product-card__link:focus-visible {
    background-color:#fef2f2;
}
.product-card.product-card--focused {
    outline:3px solid #dc2626;
    outline-offset:4px;
    box-shadow:0 0 0 3px #ffffff, 0 0 0 6px rgba(220,38,38,0.6);
    border-radius:16px;
}
.product-card__image {
    aspect-ratio:1;
    padding:12px;
    display:flex;
    align-items:center;
    justify-content:center;
}
.product-card__name,
.product-card__name a { text-transform:none; }
.product-card__badge {
    display:inline-block;
    padding:6px 10px;
    font-size:11px;
    font-weight:700;
    border-radius:6px;
    text-transform:uppercase;
}
.product-card__badge--sale {
    background:var(--color-error,#dc2626) !important;
    color:#fff !important;
}

@media (min-width:640px) { .products-grid { grid-template-columns:repeat(3,1fr); gap:20px; } }
@media (min-width:1024px) { .products-grid { grid-template-columns:repeat(4,1fr); gap:24px; } }

.shop-archive .products-grid.view-list { grid-template-columns:1fr; }
.shop-archive .products-grid.view-list .product-card__link {
    display:grid;
    grid-template-columns:190px 1fr;
    gap:20px;
    align-items:center;
}
.shop-archive .products-grid.view-list .product-card__image { aspect-ratio:1; padding:12px; }
.shop-archive .products-grid.view-list .product-card__info { display:flex; flex-direction:column; justify-content:center; }

.product-card__availability {
    display:inline-flex; align-items:center; gap:6px;
    font-size:11px; font-weight:600; margin-top:6px; padding:4px 10px; border-radius:9999px;
}
.shop-archive .products-grid.view-list .product-card__availability { align-self:flex-start; }
.product-card__availability__dot { width:6px; height:6px; border-radius:9999px; background:currentColor; }
.product-card__availability--in-stock {
    background:#ecfdf3;
    color:#065f46; /* verde più scuro per contrasto AA */
}
.product-card__availability--out-of-stock {
    background:#fee2e2;
    color:#7f1d1d; /* rosso molto più scuro per contrasto AA */
}

.product-card__colors { margin-top:8px; display:flex; align-items:center; gap:6px; }
.product-card__color-dot { width:16px; height:16px; border-radius:9999px; border:2px solid #fff; box-shadow:0 0 0 1px rgba(15,23,42,0.25); display:inline-block; }
.product-card__color-more { font-size:12px; font-weight:600; color:#475569; }

/* ═══════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════ */
.woocommerce-pagination {
    display:flex;
    justify-content:center;
    align-items:center;
    gap:8px;
    margin-top:48px;
    flex-wrap:wrap;
}
.woocommerce-pagination .page-numbers {
    display:flex;
    gap:8px;
    list-style:none;
    margin:0;
    padding:0;
}
.woocommerce-pagination .page-numbers li { margin:0; }
.woocommerce-pagination a,
.woocommerce-pagination span {
    width:44px;
    height:44px;
    padding:0;
    background:var(--color-white);
    border:2px solid var(--color-gray-200);
    border-radius:9999px; /* cerchio perfetto */
    font-family:inherit;
    font-size:14px;
    font-weight:600;
    color:#4b5563;
    display:flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    transition:all 0.15s;
}
.woocommerce-pagination a:hover {
    border-color:var(--color-gray-300);
    background:var(--color-gray-50);
}
.woocommerce-pagination a:focus,
.woocommerce-pagination a:focus-visible {
    outline:3px solid var(--color-primary);
    outline-offset:2px;
}
.woocommerce-pagination .current {
    /* pagina attiva: bordo rosso brand, numero quasi nero per massimo contrasto */
    background:#ffffff;
    border-color:var(--color-primary);      /* rosso brand per il bordo */
    color:#111827;                          /* testo nero/blu molto scuro */
}

/* ═══════════════════════════════════════
   CATEGORY DESCRIPTION & MISC
   ═══════════════════════════════════════ */
.category-description { margin-top:40px; padding:0 2px 32px; font-size:15px; color:#475569; line-height:1.8; }
.category-description h2 { font-size:1.35em; font-weight:700; color:var(--color-gray-800,#1e293b); margin:0 0 0.75em; line-height:1.3; }
.category-description b, .category-description strong { font-weight:700; }
.shop-no-products { text-align:center; padding:48px 24px; font-size:16px; color:#475569; }

/* ═══════════════════════════════════════
   WCAG: focus ovunque (fallback anche per browser senza :focus-visible)
   ═══════════════════════════════════════ */
a:focus,
a:focus-visible,
button:focus,
button:focus-visible,
input:focus,
input:focus-visible,
select:focus,
select:focus-visible,
textarea:focus,
textarea:focus-visible {
    outline:3px solid var(--color-primary);
    outline-offset:2px;
}

/* ═══════════════════════════════════════
   OVERRIDE PAGINATION FLATSOME (contrasto pagina corrente)
   ═══════════════════════════════════════ */
nav.woocommerce-pagination ul li span.current,
.shop-archive nav.woocommerce-pagination ul li span.current {
    background:#ffffff !important;
    color:#000000 !important;              /* nero pieno */
    border-color:var(--color-primary) !important; /* bordo rosso brand */
}

/* ═══════════════════════════════════════
   RESPONSIVE & REDUCED MOTION
   ═══════════════════════════════════════ */
@media (max-width:768px) {
    .shop-head { padding:24px 20px 0; }
    .shop-head__title { font-size:26px; }
    .shop-head__cats { display:none; }
    .shop-head__toolbar { flex-wrap:wrap; gap:12px; }
    .toolbar-right { width:100%; justify-content:space-between; }
}

@media (prefers-reduced-motion: reduce) {
    .filter-drawer, .filter-drawer-overlay { transition:none; }
    .color-dropdown__chevron { transition:none; }
    .shop-cat-pill, .filter-btn, .view-btn, .filter-badge, .filter-drawer__reset { transition:none; }
}
