/* =========================================================
   SEEBY SOUND — shop.css  (category / product listing)
   ========================================================= */

/* ---------- Category banner ---------- */
.cat-banner{ position:relative; background:var(--black); color:#fff; overflow:hidden; }
.cat-banner__media{ position:absolute; inset:0; }
.cat-banner__media .ph{ width:100%; height:100%; }
.cat-banner__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(10,10,10,.92),rgba(10,10,10,.55) 70%,rgba(10,10,10,.3)); }
.cat-banner__inner{ position:relative; z-index:2; padding-block:44px; }
@media (min-width:768px){ .cat-banner__inner{ padding-block:64px; max-width:640px; } }
.cat-banner h1{ font-size:clamp(2.2rem,7vw,3.6rem); line-height:.96; margin-top:8px; }
.cat-banner p{ color:#d8d8d2; margin-top:14px; font-size:1.08rem; max-width:48ch; }
.cat-banner__count{ margin-top:16px; font-family:var(--ff-head); font-weight:600; letter-spacing:.04em; color:var(--yellow); text-transform:uppercase; font-size:.9rem; }

/* ---------- Sub-category tabs ---------- */
.subcats{ background:#fff; border-bottom:1px solid var(--line); position:sticky; top:var(--header-h); z-index:40; }
.subcats__scroll{ display:flex; gap:8px; overflow-x:auto; padding-block:14px; scrollbar-width:none; }
.subcats__scroll::-webkit-scrollbar{ display:none; }
.subcat{
  flex:0 0 auto; font-family:var(--ff-head); font-weight:600; text-transform:uppercase; letter-spacing:.04em;
  font-size:.92rem; padding:9px 16px; border-radius:30px; border:1.5px solid var(--line-2);
  color:var(--ink); background:#fff; transition:.15s; white-space:nowrap;
}
.subcat:hover{ border-color:var(--ink); }
.subcat.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* ---------- Toolbar ---------- */
.shop-toolbar{
  display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding-block:20px;
}
.shop-toolbar__count{ font-size:.92rem; color:var(--muted); }
.shop-toolbar__count strong{ color:var(--ink); }
.shop-toolbar__right{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.filter-btn{
  display:inline-flex; align-items:center; gap:8px; border:1.5px solid var(--line-2); border-radius:7px;
  padding:9px 14px; font-family:var(--ff-head); font-weight:600; text-transform:uppercase; letter-spacing:.04em; font-size:.85rem;
}
.filter-btn svg{ width:16px; height:16px; }
.filter-btn .fcount{ background:var(--yellow); color:#0a0a0a; border-radius:20px; min-width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; font-size:.72rem; padding:0 5px; }
@media (min-width:1024px){ .filter-btn{ display:none; } }
.sort-wrap{ position:relative; display:flex; align-items:center; gap:7px; }
.sort-wrap label{ font-size:.85rem; color:var(--muted); display:none; }
@media (min-width:560px){ .sort-wrap label{ display:inline; } }
.sort-select{
  appearance:none; border:1.5px solid var(--line-2); border-radius:7px; background:#fff;
  padding:9px 34px 9px 12px; font-size:.9rem; font-weight:500; cursor:pointer;
}
.sort-wrap::after{ content:""; position:absolute; right:12px; top:50%; width:8px; height:8px; border-right:2px solid var(--muted); border-bottom:2px solid var(--muted); transform:translateY(-70%) rotate(45deg); pointer-events:none; }

/* layout toggle (desktop only) */
.layout-toggle{ display:none; }
@media (min-width:1024px){
  .layout-toggle{ display:inline-flex; border:1.5px solid var(--line-2); border-radius:8px; overflow:hidden; }
  .layout-toggle button{ display:inline-flex; align-items:center; gap:6px; padding:8px 12px; font-family:var(--ff-head); font-weight:600; text-transform:uppercase; letter-spacing:.03em; font-size:.78rem; color:var(--muted); }
  .layout-toggle button svg{ width:15px; height:15px; }
  .layout-toggle button + button{ border-left:1.5px solid var(--line-2); }
  .layout-toggle button.is-active{ background:var(--ink); color:#fff; }
}

/* ---------- Layout grid ---------- */
.shop-layout{ display:grid; grid-template-columns:1fr; gap:24px; padding-bottom:60px; }
@media (min-width:1024px){
  .shop-layout.layout--sidebar{ grid-template-columns:266px 1fr; align-items:start; }
  .shop-layout.layout--topbar{ grid-template-columns:1fr; }
}

/* ---------- Filters ---------- */
.filters{ }
.filters__head{ display:none; align-items:center; justify-content:space-between; margin-bottom:14px; }
.filters__title{ font-size:1.25rem; }
.clear-filters{ font-size:.82rem; color:var(--muted); text-decoration:underline; }
.clear-filters:hover{ color:var(--sale); }

.fgroup{ border:1px solid var(--line); border-radius:10px; background:#fff; margin-bottom:12px; }
.fgroup > summary{
  list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; font-family:var(--ff-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:.95rem;
}
.fgroup > summary::-webkit-details-marker{ display:none; }
.fgroup > summary .chev{ width:14px; height:14px; transition:transform .2s; color:var(--muted); }
.fgroup[open] > summary .chev{ transform:rotate(180deg); }
.fgroup__body{ padding:0 16px 16px; }

.f-check{ display:flex; align-items:center; gap:10px; padding:7px 0; cursor:pointer; font-size:.95rem; }
.f-check input{ width:18px; height:18px; accent-color:var(--yellow); cursor:pointer; flex-shrink:0; }
.f-check .cnt{ margin-left:auto; color:var(--muted-2); font-size:.82rem; }
.f-check:hover{ color:var(--yellow-dark); }

/* price */
.price-inputs{ display:flex; align-items:center; gap:8px; margin-bottom:14px; }
.price-inputs input{ width:100%; padding:9px 10px; border:1.5px solid var(--line-2); border-radius:7px; font-size:.9rem; }
.price-inputs span{ color:var(--muted); }
.range-wrap{ position:relative; height:30px; }
.range-wrap input[type=range]{ position:absolute; width:100%; pointer-events:none; appearance:none; background:none; top:11px; margin:0; }
.range-wrap input[type=range]::-webkit-slider-thumb{ appearance:none; pointer-events:auto; width:18px; height:18px; border-radius:50%; background:var(--yellow); border:2px solid #fff; box-shadow:0 1px 4px rgba(0,0,0,.3); cursor:pointer; }
.range-wrap input[type=range]::-moz-range-thumb{ pointer-events:auto; width:18px; height:18px; border-radius:50%; background:var(--yellow); border:2px solid #fff; box-shadow:0 1px 4px rgba(0,0,0,.3); cursor:pointer; }
.range-track{ position:absolute; top:11px; left:0; right:0; height:6px; border-radius:3px; background:var(--bg-2); }
.range-fill{ position:absolute; top:11px; height:6px; border-radius:3px; background:var(--yellow); }

/* rating radios */
.f-rating{ display:flex; align-items:center; gap:10px; padding:7px 0; cursor:pointer; font-size:.92rem; }
.f-rating input{ accent-color:var(--yellow); }
.f-rating .stars svg{ width:15px; height:15px; }

/* availability toggle */
.f-toggle{ display:flex; align-items:center; justify-content:space-between; gap:10px; cursor:pointer; font-size:.95rem; }
.switch{ position:relative; width:42px; height:24px; flex-shrink:0; }
.switch input{ position:absolute; opacity:0; }
.switch .track{ position:absolute; inset:0; background:var(--line-2); border-radius:20px; transition:.2s; }
.switch .track::before{ content:""; position:absolute; top:3px; left:3px; width:18px; height:18px; background:#fff; border-radius:50%; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.25); }
.switch input:checked + .track{ background:var(--ok); }
.switch input:checked + .track::before{ transform:translateX(18px); }

/* applied chips */
.applied-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.applied-chips:empty{ display:none; }
.chip{
  display:inline-flex; align-items:center; gap:7px; background:var(--bg-2); border:1px solid var(--line-2);
  border-radius:20px; padding:6px 8px 6px 13px; font-size:.82rem; font-weight:500;
}
.chip button{ width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; background:rgba(0,0,0,.08); }
.chip button:hover{ background:var(--sale); color:#fff; }
.chip button svg{ width:11px; height:11px; }

/* ---------- Products grid ---------- */
.shop-products{ min-width:0; }
.product-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (min-width:640px){ .product-grid{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1024px){
  .layout--sidebar .product-grid{ grid-template-columns:repeat(3,1fr); gap:20px; }
  .layout--topbar .product-grid{ grid-template-columns:repeat(4,1fr); gap:20px; }
}
.no-results{ text-align:center; padding:60px 20px; color:var(--muted); display:none; }
.no-results svg{ width:48px; height:48px; color:var(--line-2); margin:0 auto 14px; }
.no-results h3{ text-transform:none; letter-spacing:0; font-size:1.4rem; margin-bottom:6px; }

/* pagination */
.pagination{ display:flex; justify-content:center; gap:8px; margin-top:40px; }
.pagination a,.pagination span{
  min-width:42px; height:42px; display:inline-flex; align-items:center; justify-content:center;
  border:1.5px solid var(--line-2); border-radius:8px; font-family:var(--ff-head); font-weight:600; font-size:1rem;
}
.pagination a:hover{ border-color:var(--ink); }
.pagination .is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.pagination .disabled{ opacity:.4; pointer-events:none; }

/* ---------- TOPBAR layout: filters become a horizontal bar ---------- */
@media (min-width:1024px){
  .layout--topbar .filters{
    display:flex; flex-wrap:wrap; align-items:center; gap:10px;
    border:1px solid var(--line); background:#fff; border-radius:12px; padding:12px 14px; margin-bottom:4px;
  }
  .layout--topbar .filters__head{ display:none; }
  .layout--topbar .fgroup{ margin:0; border:1.5px solid var(--line-2); border-radius:8px; position:relative; }
  .layout--topbar .fgroup > summary{ padding:9px 13px; font-size:.82rem; }
  .layout--topbar .fgroup__body{
    position:absolute; top:calc(100% + 6px); left:0; z-index:30; min-width:230px;
    background:#fff; border:1px solid var(--line); border-radius:10px; box-shadow:var(--shadow-lg);
    padding:14px 16px;
  }
  .layout--topbar .fgroup--price .fgroup__body{ min-width:260px; }
  .layout--topbar .filters .clear-filters{ margin-left:auto; }
  .layout--topbar .filters__label{ display:inline-flex; align-items:center; gap:7px; font-family:var(--ff-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:.85rem; color:var(--muted); margin-right:4px; }
  .layout--topbar .filters__label svg{ width:16px; height:16px; }
}
.layout--topbar .filters__label{ display:none; }
@media (min-width:1024px){ .layout--topbar .filters__label{ display:inline-flex; } }
.filters__label{ display:none; }

/* ---------- MOBILE: filters as drawer ---------- */
@media (max-width:1023px){
  .filters{
    position:fixed; top:0; right:0; bottom:0; width:min(88vw,380px); z-index:95;
    background:var(--bg); padding:18px; overflow-y:auto;
    transform:translateX(100%); transition:transform .26s cubic-bezier(.4,0,.2,1);
    box-shadow:-10px 0 40px rgba(0,0,0,.2);
  }
  .filters.open{ transform:translateX(0); }
  .filters__head{ display:flex; }
  .filters__label{ display:none; }
  .filters__apply{ position:sticky; bottom:-18px; margin:14px -18px -18px; padding:14px 18px; background:#fff; border-top:1px solid var(--line); }
}
@media (min-width:1024px){ .filters__apply{ display:none; } }
.filters-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:94; opacity:0; visibility:hidden; transition:.2s; }
.filters-overlay.open{ opacity:1; visibility:visible; }
@media (min-width:1024px){ .filters-overlay{ display:none; } }
