/* SENKYS — styles page catégorie (listing) */
.listing { display: grid; grid-template-columns: 268px 1fr; gap: var(--space-6); align-items: start; }

.filters { display: flex; flex-direction: column; gap: var(--space-3); position: sticky; top: var(--space-4); }
.fbox { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); }
.fbox-head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4); font-weight: 700; font-size: var(--text-sm); color: var(--ink); cursor: pointer; user-select: none; }
.fbox-body { padding: 0 var(--space-4) var(--space-4); }
.fbox.collapsed .fbox-body { display: none; }
.fbox-head .chev { transition: transform var(--t-fast); color: var(--ink-mute); }
.fbox.collapsed .chev { transform: rotate(-90deg); }

.fcheck { display: flex; align-items: center; gap: var(--space-3); padding: 6px 0; font-size: var(--text-sm); color: var(--ink-soft); cursor: pointer; }
.fcheck input { width: 16px; height: 16px; accent-color: var(--accent); }
.fcheck .ct { margin-left: auto; color: var(--ink-mute); font-size: var(--text-xs); }
.fsearch { display: flex; align-items: center; gap: var(--space-2); border: 1px solid var(--border-strong); border-radius: var(--radius-sm); padding: 6px var(--space-3); margin-bottom: var(--space-3); }
.fsearch input { border: none; outline: none; flex: 1; font-size: var(--text-sm); background: transparent; }
.fmore { color: var(--accent); font-size: var(--text-sm); font-weight: 600; margin-top: var(--space-2); display: inline-block; }

.range-inputs { display: flex; align-items: center; gap: var(--space-2); margin-top: var(--space-2); }
.range-inputs input { width: 100%; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); padding: 7px var(--space-2); font-size: var(--text-sm); text-align: center; }
.range-go { width: 32px; height: 32px; flex: 0 0 auto; background: var(--accent); color: #fff; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; border: none; cursor: pointer; }

.results-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-4); }
.results-bar h1 { font-size: var(--text-xl); font-weight: 800; letter-spacing: -0.01em; }
.results-bar h1 .count { color: var(--ink-mute); font-weight: 600; font-size: var(--text-base); }
.toolbar-right { display: flex; align-items: center; gap: var(--space-4); }
.sortsel { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); }
.sortsel select { border: 1px solid var(--border-strong); border-radius: var(--radius-sm); padding: 7px var(--space-3); font-size: var(--text-sm); background: var(--surface); color: var(--ink); }
.viewtoggle { display: flex; gap: 2px; background: var(--surface); border: 1px solid var(--border-strong); border-radius: var(--radius-sm); padding: 2px; }
.viewtoggle button { width: 34px; height: 30px; border-radius: 4px; color: var(--ink-mute); display: flex; align-items: center; justify-content: center; }
.viewtoggle button.active { background: var(--accent); color: #fff; }

.results { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.results.list-view { grid-template-columns: 1fr; gap: var(--space-3); }
.results.list-view .pcard { flex-direction: row; align-items: stretch; gap: var(--space-5); padding: var(--space-4); }
.results.list-view .pcard-media { width: 180px; flex: 0 0 auto; }
.results.list-view .pcard-media .ph, .results.list-view .pcard-media .ph-img { aspect-ratio: auto; height: 100%; min-height: 150px; }
.results.list-view .lc-main { flex: 1; display: flex; flex-direction: column; }
.results.list-view .lc-specs { display: block; font-size: var(--text-sm); color: var(--ink-soft); margin: 6px 0 var(--space-3); line-height: 1.5; }
.results.list-view .pcard-title { -webkit-line-clamp: 2; font-size: var(--text-md); }
.results.list-view .lc-foot { display: flex; align-items: flex-end; justify-content: space-between; margin-top: auto; }
.results.list-view .lc-price-block { width: 200px; flex: 0 0 auto; border-left: 1px solid var(--border); padding-left: var(--space-5); display: flex; flex-direction: column; justify-content: center; align-items: flex-start; gap: var(--space-2); }
.results.list-view .pcard-price { font-size: var(--text-xl); }

.lc-specs { display: none; }
.lc-price-block { display: none; }
.results.list-view .lc-price-block { display: flex; }
.results:not(.list-view) .pcard-price { font-size: var(--text-lg); }
.lc-detail-link { font-size: var(--text-xs); font-weight: 600; color: var(--accent); display: inline-flex; align-items: center; gap: 4px; margin-top: var(--space-2); }

.seo h2 { font-size: var(--text-xl); font-weight: 800; margin-bottom: var(--space-4); }
.seo h3 { font-size: var(--text-md); font-weight: 700; margin: var(--space-6) 0 var(--space-2); }
.seo p { color: var(--ink-soft); margin-bottom: var(--space-3); line-height: 1.7; max-width: 80ch; }
.seo p b { color: var(--ink); }

.pagination { display: flex; align-items: center; justify-content: flex-end; gap: var(--space-2); margin-top: var(--space-6); }
.pagination a, .pagination span { min-width: 38px; height: 38px; display: inline-flex; align-items: center; justify-content: center; border-radius: var(--radius-sm); font-size: var(--text-sm); font-weight: 600; color: var(--ink-soft); border: 1px solid transparent; }
.pagination a:hover { border-color: var(--border-strong); text-decoration: none; }
.pagination .cur { background: var(--accent); color: #fff; }
.pagination .next { background: var(--accent); color: #fff; }

/* Bouton "Filtres" (mobile uniquement) */
.filters-toggle { display: none; align-items: center; gap: var(--space-2); margin-bottom: var(--space-4); }
.filters-toggle svg { stroke: currentColor; }

@media (max-width: 980px) {
  .listing { grid-template-columns: 1fr; }
  /* Filtres masqués par défaut ; à l'ouverture ils passent AU-DESSUS des produits (sous le bouton) */
  .filters { position: static; order: 2; display: none; margin: 0 0 var(--space-5); padding: 0; border: none; }
  body.filters-open .filters { display: flex; order: -1; }
  .listing > section { order: 1; }
  .filters-toggle { display: inline-flex; }

  /* Barre d'outils empilée pour éviter le débordement (titre / tri / vues coupés) */
  .results-bar { flex-direction: column; align-items: stretch; gap: var(--space-3); }
  .toolbar-right { width: 100%; justify-content: space-between; }
  .sortsel { flex: 1; }
  .sortsel select { flex: 1; min-width: 0; }
}
@media (max-width: 720px) { .results { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 380px) { .results { grid-template-columns: 1fr; } }
