/* =========================================================
   ARISTAS — Categoría (Sofás) · usa tokens de aristas.css
   ========================================================= */
body.cat{zoom:1.15}                  /* +15% legibilidad global (fixes) */
.cat .site-header{position:static}   /* header estático → la barra de filtros es sticky */

/* HERO */
.cathero{position:relative;background-size:cover;background-position:center;padding:66px 40px;color:#fff}
.cathero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(26,22,19,.55),rgba(26,22,19,.15))}
.cathero__inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto}
.cathero__title{font-family:var(--display);text-transform:uppercase;letter-spacing:.02em;font-weight:500;font-size:56px;line-height:1;margin:0;color:#fff}
.cathero__sub{margin:12px 0 0;color:#eee5d8;font-size:15px;letter-spacing:.02em}

/* ============ BARRA DE FILTROS (toolbar de una fila) ============ */
.filters-bar{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 6px 20px -20px rgba(0,0,0,.35)}
.filters-bar__inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding-top:12px;padding-bottom:12px}

/* Botón que abre el offcanvas — gris claro neutro, con acentos clay cálidos */
.filters-toggle{display:inline-flex;align-items:center;gap:9px;border:1px solid #dcdbd7;border-radius:99px;padding:9px 18px;font-size:12px;letter-spacing:.09em;text-transform:uppercase;font-weight:600;background:#f0efec;color:var(--ink);cursor:pointer;transition:.22s var(--ease);white-space:nowrap}
.filters-toggle:hover{background:#e7e6e2;border-color:#c9c8c3}
.filters-toggle__ic{width:18px;height:18px;color:var(--clay)}
.filters-toggle__badge{display:inline-flex;align-items:center;justify-content:center;min-width:19px;height:19px;padding:0 5px;border-radius:99px;background:var(--clay);color:#fff;font-size:11px;font-weight:700;letter-spacing:0}

/* fila utilitaria (chips · conteo · ordenar) */
.fa-count{font-size:13px;color:var(--text-2);letter-spacing:.02em;white-space:nowrap}
.fa-count strong{color:var(--ink);font-weight:600;font-size:15px}
.fa-chips{display:flex;gap:7px;flex-wrap:wrap}
.fa-chip{display:inline-flex;align-items:center;gap:7px;background:var(--cream);border:1px solid var(--border);border-radius:99px;padding:5px 12px;font-size:11px;color:var(--accent-ink);cursor:pointer;transition:.2s var(--ease)}
.fa-chip:hover{border-color:var(--accent)}
.fa-chip .x{font-size:12px;line-height:1;opacity:.7}
.fa-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.freset{background:none;border:none;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600;cursor:pointer;white-space:nowrap}
.fsort-lbl{font-size:12px;letter-spacing:.02em;color:var(--text-3);white-space:nowrap}
.fsort{padding:8px 14px;font-size:13px;min-width:136px}
.ffilter-select{padding:8px 14px;font-size:13px;min-width:128px}

/* ============ OFFCANVAS ============ */
.offcanvas{position:fixed;inset:0;z-index:120}
.offcanvas[hidden]{display:none}
.offcanvas__backdrop{position:absolute;inset:0;background:rgba(26,22,19,.42);opacity:0;transition:opacity .32s var(--ease)}
.offcanvas__panel{position:absolute;top:0;right:0;height:100%;width:min(400px,92vw);background:#fff;box-shadow:-24px 0 60px -30px rgba(26,22,19,.5);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .36s var(--ease)}
.offcanvas.is-open .offcanvas__backdrop{opacity:1}
.offcanvas.is-open .offcanvas__panel{transform:translateX(0)}

.offcanvas__head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0}
.offcanvas__title{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-weight:500;font-size:22px;color:var(--ink)}
.offcanvas__close{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;background:#fff;color:var(--ink);cursor:pointer;transition:.2s var(--ease)}
.offcanvas__close:hover{background:var(--cream);border-color:var(--taupe)}
.offcanvas__close svg{width:16px;height:16px}

.offcanvas__body{flex:1;overflow-y:auto;padding:6px 24px 20px}
.offcanvas__foot{display:flex;align-items:center;gap:12px;padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0}
.offcanvas__clear{background:none;border:none;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);font-weight:600;cursor:pointer;white-space:nowrap;padding:8px 4px}
.offcanvas__clear:hover{color:var(--accent)}
.offcanvas__apply{margin-left:auto;flex:1;text-align:center}

/* Grupos de filtro (verticales dentro del offcanvas) */
.fgroup{display:flex;flex-direction:column;align-items:stretch;gap:12px;padding:20px 0;border-top:1px solid var(--border)}
.fgroup:first-child{border-top:none}
.fgroup__lbl{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);font-weight:600}

/* Pills */
.fpills{display:flex;gap:8px;flex-wrap:wrap}
.fpill{border:1px solid var(--border);background:#fff;border-radius:99px;padding:9px 16px;font-size:13.5px;color:var(--text-2);cursor:pointer;transition:.22s var(--ease);white-space:nowrap}
.fpill:hover{border-color:var(--taupe)}
.fpill.is-sel{background:var(--ink);border-color:var(--ink);color:#fff}

/* Swatches de Tela / Madera (mismo lenguaje que el PDP: textura real + aro al elegir) */
.fpills--sw{gap:14px 12px}
.fsw{display:flex;flex-direction:column;align-items:center;gap:7px;width:58px;background:none;border:none;padding:0;cursor:pointer}
.fsw__chip{width:44px;height:44px;border-radius:50%;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.14);position:relative;transition:transform .18s var(--ease)}
.fsw__chip::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.6px solid transparent;transition:.18s var(--ease)}
.fsw:hover .fsw__chip{transform:scale(1.08)}
.fsw.is-sel .fsw__chip::after{border-color:var(--ink)}
.fsw__lbl{font-size:11.5px;line-height:1.15;text-align:center;color:var(--text-2);letter-spacing:.01em}
.fsw.is-sel .fsw__lbl{color:var(--ink);font-weight:600}

/* Slider de rango de precio (doble control, escritorio + mobile) */
.prange{position:relative;height:52px;padding:0 2px}
.prange__rail{position:absolute;top:16px;left:2px;right:2px;height:4px;border-radius:2px;background:var(--border)}
.prange__fill{position:absolute;top:0;height:100%;border-radius:2px;background:var(--ink)}
.prange__in{position:absolute;top:6px;left:0;width:100%;height:24px;margin:0;background:none;pointer-events:none;-webkit-appearance:none;appearance:none}
.prange__in::-webkit-slider-runnable-track{height:4px;background:none;border:none}
.prange__in::-moz-range-track{height:4px;background:none;border:none}
.prange__in::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;width:20px;height:20px;margin-top:-8px;border-radius:50%;background:#fff;border:1.5px solid var(--ink);box-shadow:0 1px 5px rgba(26,22,19,.28);cursor:pointer;transition:transform .15s var(--ease)}
.prange__in::-moz-range-thumb{pointer-events:auto;width:20px;height:20px;border-radius:50%;background:#fff;border:1.5px solid var(--ink);box-shadow:0 1px 5px rgba(26,22,19,.28);cursor:pointer}
.prange__in::-webkit-slider-thumb:hover{transform:scale(1.12)}
.prange__in:focus-visible{outline:none}
.prange__in:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 3px var(--accent)}
.prange__in:focus-visible::-moz-range-thumb{box-shadow:0 0 0 3px var(--accent)}
.prange__vals{position:absolute;top:30px;left:0;right:0;display:flex;justify-content:space-between;font-size:13px;font-weight:600;color:var(--ink)}

/* Foco visible (a11y) */
.fpill:focus-visible,.fsort:focus-visible,.ffilter-select:focus-visible,.pcard__namelink:focus-visible,.pcard__cta:focus-visible,.pcard__media:focus-visible,.fa-chip:focus-visible,.freset:focus-visible,.filters-toggle:focus-visible,.offcanvas__close:focus-visible,.offcanvas__clear:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.fsw:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:10px}

/* ============ RESULTADOS ============ */
.results{padding:22px 40px 20px}
.results__empty{padding:60px 0;text-align:center;color:var(--text-2)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@keyframes pcardIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* CARD */
.pcard{border:1px solid transparent;border-radius:8px;overflow:hidden;transition:border-color .3s var(--ease),box-shadow .3s var(--ease);background:#fff;animation:pcardIn .45s var(--ease) both;display:flex;flex-direction:column}
.pcard:hover{box-shadow:0 16px 38px -26px rgba(42,36,32,.20)}
.pcard__media{position:relative;display:block;aspect-ratio:768/461;background:var(--bg-light);overflow:hidden}
.pcard__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.pcard:hover .pcard__media img{transform:scale(1.04)}
.pcard__badge{position:absolute;top:12px;left:12px;background:rgba(111,125,74,.94);color:#fff;font-size:10px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;padding:5px 11px;border-radius:99px;display:none}
.pcard.fits .pcard__badge{display:inline-block}
.pcard__body{padding:16px 18px 20px;display:flex;flex-direction:column;flex:1}
.pcard__namelink{display:block;color:inherit;text-decoration:none}
.pcard__name{font-family:var(--sans);text-transform:uppercase;letter-spacing:.04em;font-weight:500;font-size:18px;line-height:1.14;margin:0 0 6px;color:var(--ink);min-height:2.24em}
.pcard__namelink:hover .pcard__name{color:var(--accent-ink)}
.pcard__price{font-size:13.5px;color:var(--text-2)}
.pcard__price strong{color:var(--ink);font-weight:600}
.pcard__pricemax{color:var(--text-3)}
.pcard__colors{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap;align-items:center}
.pcolor{width:15px;height:15px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.16)}
.pcolor--more{font-size:10.5px;color:var(--text-3);margin-left:2px}
.pcard__cta{display:inline-block;margin-top:16px;align-self:flex-start;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600;border-bottom:1px solid currentColor;padding-bottom:2px;opacity:0;transform:translateY(4px);transition:.28s var(--ease)}
.pcard:hover .pcard__cta,.pcard:focus-within .pcard__cta{opacity:1;transform:none}

/* BANDA ASESOR */
.guideband{background:var(--cream);padding:56px 40px}
.guideband__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.guideband p{color:var(--text-2);margin:8px 0 0}

/* ============ RESPONSIVE ============ */
@media(max-width:1024px){ .pgrid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:900px){
  .mainbar__nav{display:none}
  .fpill{padding:11px 17px;font-size:14px}                 /* targets táctiles más cómodos */
  .ffilter-select{font-size:14px;padding:11px 14px}
}
@media(max-width:560px){
  .wrap,.results,.cathero,.guideband{padding-left:20px;padding-right:20px}
  .cathero__title{font-size:40px}
  .pgrid{grid-template-columns:1fr}
  .pcard__cta{opacity:1;transform:none}
  /* barra: botón arriba, orden abajo a lo ancho */
  .fa-right{margin-left:0;width:100%;justify-content:space-between}
  .offcanvas__panel{width:100vw}
}
