/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:opsz,wght@8..60,400;8..60,500;8..60,600&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

/* ── Tokens ── */
:root{
  --gp:#329AE0;--gd:#0065B8;--gl:#9ECDEE;--gw:#E7F2FB;--gi:#06365C;
  --cream:#FAF7F0;--cream2:#F3EFE4;--ink:#1A1F1A;--ink2:#2E332D;
  --stone:#6B7269;--stone2:#9AA09A;--line:#E6E4DC;--line2:#D5D2C7;--white:#fff;
  --warn:#C97A1A;--danger:#B3261E;--star:#E0A33B;
  --serif:'Source Serif 4',Georgia,serif;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
  --sh1:0 1px 2px rgba(0,101,184,.04),0 8px 24px rgba(0,101,184,.07);
  --sh2:0 2px 4px rgba(0,101,184,.06),0 16px 32px rgba(0,101,184,.09);
  --ease:cubic-bezier(.2,.8,.2,1);
  --fast:160ms;--med:240ms;
  --pill:999px;--lg:20px;--md:12px;--sm:6px;
}

/* ── Page wrapper ── width/centering/padding come from the shared
   .blm-container (common.css); .blc-page only carries the page base styles. */
.blc-page{font-family:var(--sans);color:var(--ink)}

/* Breadcrumb (.bl-crumbs) now lives in assets/common/css/common.css */


/* ── Category feature image + description ── */
.cat-feature{display:flex;flex-direction:column;gap:0;padding:20px 0 0}
.cat-feature__img{display:block;width:100%;max-height:360px;object-fit:cover;
  border-radius:var(--lg);box-shadow:var(--sh1);border:1px solid var(--line)}
.cat-feature__desc{width:100%;padding:18px 4px 6px;font-size:.9375rem;
  color:var(--ink2);line-height:1.75}
.cat-feature__desc p{margin:0 0 10px}
.cat-feature__desc p:last-child{margin:0}
/* Title fallback when a category has no ACF image */
.cat-feature--title{padding:24px 0 0}
.cat-feature__title{margin:0;font-size:clamp(1.7rem,3.2vw,2.4rem);line-height:1.15;
  font-weight:700;letter-spacing:-.01em;color:var(--ink)}
/* Category name + image together: name above the image */
.cat-feature--both{padding:24px 0 0}
.cat-feature--both .cat-feature__title{margin:0 0 16px;font-size:clamp(1.5rem,2.8vw,2.1rem)}

/* ── Toolbar ── */
.blc-toolbar{display:flex;align-items:center;gap:16px;padding:18px 0;margin-top:12px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.blc-count{font-size:.875rem;color:var(--stone)}.blc-count strong{color:var(--ink);font-weight:600}
.blc-right{margin-left:auto;display:flex;align-items:center;gap:16px}
.blc-sort{display:flex;align-items:center;gap:8px}
.blc-sort label{font-size:.875rem;color:var(--stone);white-space:nowrap}
.blc-select{height:42px;padding:0 38px 0 14px;border:1px solid var(--line2);border-radius:var(--pill);
  background:var(--white) 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='%236B7269' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 12px center;
  font:inherit;font-size:14px;color:var(--ink);cursor:pointer;appearance:none;-webkit-appearance:none}
.blc-select:focus{outline:none;border-color:var(--gp);box-shadow:0 0 0 3px rgba(50,154,224,.18)}

/* Mobile filter drawer controls — hidden on desktop, shown ≤880px */
.blc-filter-toggle{display:none;align-items:center;gap:8px;height:42px;padding:0 18px;
  border:1px solid var(--line2);border-radius:var(--pill);background:var(--white);
  font:inherit;font-size:14px;font-weight:600;color:var(--gd);cursor:pointer;white-space:nowrap}
.blc-filter-toggle:hover{border-color:var(--gp)}
.blc-sidebar-head{display:none}
.blc-side-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99998}

/* ── Layout ── */
.blc-shop{display:grid;grid-template-columns:304px 1fr;gap:48px;padding:32px 0 96px}

/* ── Sidebar ── */
.blc-sidebar{position:sticky;top:var(--blm-sticky-top,88px);align-self:start;display:flex;flex-direction:column;gap:24px}
.blc-filter{border:1px solid var(--line);border-radius:var(--lg);background:var(--white);padding:24px}
.blc-fhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.blc-ftitle{font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--gd)}

/* Price slider */
.blc-price-readout{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;
  font-size:14px;font-weight:600;color:var(--ink)}
.blc-price-readout span{background:var(--gw);color:var(--gd);padding:4px 10px;border-radius:var(--sm)}
.blc-range{position:relative;height:28px}
.blc-range-track{position:absolute;left:0;right:0;top:12px;height:4px;border-radius:2px;background:var(--line2)}
.blc-range-fill{position:absolute;top:12px;height:4px;border-radius:2px;background:var(--gp)}
.blc-range input[type=range]{position:absolute;left:0;right:0;top:0;width:100%;margin:0;
  height:28px;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none}
.blc-range input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;
  width:20px;height:20px;border-radius:50%;background:var(--white);border:2px solid var(--gp);
  box-shadow:var(--sh1);cursor:pointer}
.blc-range input[type=range]::-moz-range-thumb{pointer-events:auto;width:20px;height:20px;
  border-radius:50%;background:var(--white);border:2px solid var(--gp);cursor:pointer;border:none}

/* CTA card */
.blc-cta{background:var(--gw);border-color:transparent}
.blc-cta h4{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--gi);margin:0 0 6px}
.blc-cta p{font-size:13px;color:var(--gi);opacity:.85;margin:0 0 14px;line-height:1.5}

/* Clear button */
.blc-clear{display:block;width:100%;text-align:center;min-height:36px;padding:0 16px;
  font-family:var(--sans);font-size:.875rem;font-weight:600;line-height:1;
  border-radius:var(--pill);border:1px solid var(--gd);background:var(--white);
  color:var(--gd);cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background var(--fast) var(--ease)}
.blc-clear:hover{background:var(--gw);text-decoration:none}

/* Btn */
.blc-btn{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 16px;
  font-family:var(--sans);font-size:.875rem;font-weight:600;line-height:1;border-radius:var(--pill);
  border:1px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:background var(--fast) var(--ease),border-color var(--fast) var(--ease)}
.blc-btn-primary{background:var(--gp);color:var(--cream);border-color:var(--gp)}
.blc-btn-primary:hover{background:var(--gd);border-color:var(--gd);color:var(--cream);text-decoration:none}

/* ── Category tree ── */
.blc-tree-card{padding:24px 14px}
.tlist{list-style:none;margin:0;padding:0}
.tlist--root{max-height:calc(100vh - 150px);overflow-y:auto;margin-right:-4px;padding-right:4px}
.tlist--root::-webkit-scrollbar{width:8px}
.tlist--root::-webkit-scrollbar-thumb{background:var(--line2);border-radius:8px}
.tnode{position:relative}
.trow{display:flex;align-items:center;gap:4px}
.trow--top{margin-top:2px}

/* toggle arrow — CSS-only, no SVG */
.ttog{width:22px;height:22px;flex:none;cursor:pointer;background:none !important;border:none;padding:0;
  border-radius:4px;display:inline-flex;align-items:center;justify-content:center;
  transition:background var(--fast) var(--ease)}
.ttog .arr{display:inline-block;width:0;height:0;
  border-top:5px solid transparent;border-bottom:5px solid transparent;
  border-left:6px solid var(--stone2);
  transition:transform var(--fast) var(--ease),border-left-color var(--fast) var(--ease)}
/* hover, focus AND open state → blue bg + white arrow */
.ttog:hover,
.ttog:focus,
.ttog.is-open{background:var(--gp) !important;outline:none}
.ttog:hover .arr,
.ttog:focus .arr,
.ttog.is-open .arr{border-left-color:#fff}
.ttog.is-open .arr{transform:rotate(90deg)}
/* leaf dot — no hover bg */
.ttog--leaf,
.ttog--leaf:hover,
.ttog--leaf:focus{cursor:default;background:none !important}
.ttog--leaf .arr{display:none}
.ttog--leaf .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--line2)}

/* labels — zero hover/active/focus background */
.tlabel{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:none !important;border:0;cursor:pointer;font:inherit;font-size:14px;color:var(--ink2);
  text-align:left;padding:7px 6px 7px 0;line-height:1.3}
.tlabel:hover,.tlabel:focus,.tlabel:active{background:none !important;outline:none}
.tlabel>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink2)}
.tlabel:hover>span:first-child{font-weight:600;color:var(--ink2)}
.trow--top .tlabel{font-size:14.5px;font-weight:600;color:var(--ink);padding-top:9px;padding-bottom:9px}
.trow--top .tlabel>span:first-child{color:var(--ink)}
.trow--top .tlabel:hover>span:first-child{color:var(--ink)}
/* row itself — never a background */
.trow,.trow:hover,.trow.is-active{background:none !important}
.trow.is-active .tlabel>span:first-child{color:var(--gd);font-weight:600}
.tcount{font-size:11px;font-weight:600;color:var(--stone);background:var(--cream2);
  border-radius:var(--pill);padding:1px 8px;flex:none}

/* ── Product grid / list ── */
.blc-results{display:flex;flex-direction:column;gap:32px}
.blc-grid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px}
/* Product card (.product …) now lives in assets/common/css/common.css,
   scoped under .bl-pcard-grid (added to .blc-grid below). */


/* Empty */
.blc-empty{padding:80px 20px;text-align:center;color:var(--stone)}
.blc-empty h3{color:var(--ink);margin-bottom:8px;font-family:var(--serif)}

/* Pagination */
.blc-pager{display:flex;align-items:center;justify-content:center;gap:8px;padding-top:16px;flex-wrap:wrap}
.blc-pager .pg{width:36px;min-width:36px;height:36px;padding:0;border-radius:50%;border:1px solid var(--line2);
  background:var(--white);color:var(--ink2);font-weight:600;font-size:14px;
  display:inline-flex;align-items:center;justify-content:center;text-decoration:none;
  transition:all var(--fast) var(--ease)}
.blc-pager .pg:hover:not(.off):not(.on){border-color:var(--gd);color:var(--gd);text-decoration:none}
.blc-pager .pg.on{background:var(--gd);border-color:var(--gd);color:var(--cream)}
.blc-pager .pg.off{opacity:.4;pointer-events:none}
.blc-pager .dots{color:var(--stone2);padding:0 4px}

/* Responsive */
@media(max-width:1080px){.blc-shop{grid-template-columns:260px 1fr;gap:24px}.blc-grid{--cols:2 !important}}
@media(max-width:880px){
  .blc-shop{grid-template-columns:1fr}
  .blc-filter-toggle{display:inline-flex}
  .blc-sidebar{position:fixed;top:0;left:-100%;width:88%;max-width:340px;height:100%;
    z-index:99999;background:var(--white);padding:0 18px 24px;overflow-y:auto;
    gap:20px;transition:left .3s ease;box-shadow:0 0 40px rgba(0,0,0,.25);border-radius:0}
  .blc-sidebar.open{left:0}
  .blc-sidebar-head{display:flex;align-items:center;justify-content:space-between;
    position:sticky;top:0;background:var(--white);padding:18px 0 14px;margin-bottom:4px;
    border-bottom:1px solid var(--line);z-index:1}
  .blc-sidebar-close{background:none;border:none;font-size:22px;line-height:1;color:var(--ink);cursor:pointer;padding:0}
  .blc-side-overlay.open{display:block}
  .tlist--root{max-height:none;overflow:visible}
}
@media(max-width:560px){.blc-grid{--cols:1 !important}.blc-page{padding-left:18px;padding-right:18px}.blc-hero h1{font-size:2rem}
  .blc-pager{gap:6px}
  .blc-pager .pg{width:32px;min-width:32px;height:32px;padding:0;font-size:13px}
  .blc-pager .pg svg{width:15px;height:15px}
}