/**
 * OC — PLP facet rail enhancements v3 — OptionCutter branded.
 * Paired with oc-plp-facetwp-rail-enhancements.js
 *
 * Brand vars (inherited from oc-plp-facetwp-bestbuy-look.css):
 *   --bb-filter-accent:   #6d28d9  (OC purple)
 *   --bb-filter-accent-2: #be185d  (OC hot-pink)
 *   --bb-filter-border:   #ddd6fe
 *   --bb-filter-hover-bg: #f3eeff
 *   --bb-filter-sel-bg:   #ede9fe
 */

/* Only hide empty facets after JS — preview export parity */
.oc-plp-filters.oc-plp-facets-hydrated .facetwp-facet.oc-plp-facet-empty {
  display: none !important;
}

/* Raw fselect flash — hide until rail JS builds checkbox overflow */
.oc-plp-filters:not(.oc-plp-facets-hydrated) .facetwp-type-fselect .fs-wrap,
.oc-plp-filters:not(.oc-plp-facets-hydrated) .facetwp-type-fselect select.facetwp-dropdown {
  visibility: hidden;
  height: 0;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── "Show all (N)" + slideout tray (preview export parity) ──────── */
.oc-plp-filters .oc-preview-show-all-link {
  display: inline-block;
  margin-top: 8px;
  padding: 2px 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--bb-filter-accent, #6d28d9);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
}
.oc-plp-filters .oc-preview-show-all-link:hover {
  text-decoration: underline;
  color: var(--bb-filter-accent-2, #be185d);
}

.oc-plp-filters .oc-preview-brand-search {
  display: block;
  width: 100%;
  margin: 6px 0 10px;
  padding: 7px 10px;
  border: 1px solid var(--bb-filter-border, #ddd6fe);
  border-radius: var(--bb-filter-radius, 6px);
  font: inherit;
  font-size: 13px;
  color: var(--bb-filter-ink, #0f0a1e);
  background: #fff;
  box-sizing: border-box;
  outline: none;
}
.oc-plp-filters .oc-preview-brand-search:focus {
  border-color: var(--bb-filter-accent, #6d28d9);
  box-shadow: 0 0 0 2px rgba(109, 40, 217, 0.15);
}

.oc-preview-facet-tray-root {
  position: fixed;
  inset: 0;
  z-index: 10050;
  pointer-events: none;
}
.oc-preview-facet-tray-root.is-open {
  pointer-events: auto;
}
.oc-preview-facet-tray-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 10, 30, 0.55);
  backdrop-filter: blur(2px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease;
}
.oc-preview-facet-tray-root.is-open .oc-preview-facet-tray-backdrop {
  opacity: 1;
  visibility: visible;
}
.oc-preview-facet-tray {
  position: absolute;
  top: 0;
  right: 0;
  width: min(400px, 100vw);
  height: 100%;
  max-height: 100dvh;
  background: #fff;
  box-shadow: -6px 0 40px rgba(74, 29, 140, 0.22);
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.32, 0.72, 0, 1);
  display: flex;
  flex-direction: column;
  border-left: 1px solid #ede9fe;
}
.oc-preview-facet-tray-root.is-open .oc-preview-facet-tray {
  transform: translateX(0);
}
.oc-preview-facet-tray-head {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  border-bottom: 1px solid #ede9fe;
  border-top: 3px solid transparent;
  border-image: linear-gradient(90deg, #4a1d8c, #be185d) 1;
}
.oc-preview-facet-tray-title {
  font-size: 16px;
  font-weight: 700;
  background: linear-gradient(90deg, #4a1d8c, #be185d);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.oc-preview-facet-tray-close {
  border: none;
  background: transparent;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: var(--bb-filter-muted, #64748b);
  padding: 4px 8px;
  border-radius: 4px;
}
.oc-preview-facet-tray-close:hover {
  background: #f1f5f9;
  color: var(--bb-filter-ink, #0f0a1e);
}
.oc-preview-facet-tray-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 8px 14px 24px;
}

/* Legacy oc-plp-* tray aliases (deprecated) */
.oc-plp-filters .oc-plp-facet-seeall,
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  padding: 0;
  background: none;
  border: none;
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  color: var(--bb-filter-accent, #6d28d9);
  cursor: pointer;
  text-decoration: none;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
.oc-plp-filters .oc-plp-facet-seeall:hover {
  color: var(--bb-filter-accent-2, #be185d);
  text-decoration: underline;
}
.oc-plp-filters .oc-plp-facet-seeall-count {
  font-weight: 700;
  opacity: 0.8;
}

/* ── Search input ────────────────────────────────────────────────── */
.oc-plp-filters .oc-plp-search-input {
  display: block;
  width: 100%;
  margin: 6px 0 10px;
  padding: 7px 10px 7px 30px;
  border: 1px solid var(--bb-filter-border, #ddd6fe);
  border-radius: 20px;
  font: inherit;
  font-size: 12px;
  color: var(--bb-filter-ink, #0f0a1e);
  background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236d28d9' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 9px center;
  box-sizing: border-box;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.oc-plp-filters .oc-plp-search-input:focus {
  border-color: var(--bb-filter-accent, #6d28d9);
  box-shadow: 0 0 0 2px rgba(109, 40, 217, 0.18);
  background-color: transparent;
}

/* ── ────────────────────────────────────────────────────────────── */
/* ── SLIDEOUT TRAY                                                  */
/* ── ────────────────────────────────────────────────────────────── */

/* Search bar inside the tray */
.oc-plp-facet-tray .oc-plp-tray-search {
  flex-shrink: 0;
  margin: 10px 16px 0;
  width: calc(100% - 32px);
  border-radius: 20px;
}

.oc-plp-facet-tray-root {
  position: fixed;
  inset: 0;
  z-index: 10050;
  pointer-events: none;
}
.oc-plp-facet-tray-root.is-open {
  pointer-events: auto;
}

/* Backdrop — subtle purple-tinted dark */
.oc-plp-facet-tray-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 10, 30, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease;
}
.oc-plp-facet-tray-root.is-open .oc-plp-facet-tray-backdrop {
  opacity: 1;
  visibility: visible;
}

/* Tray panel */
.oc-plp-facet-tray {
  position: absolute;
  top: 0;
  right: 0;
  width: min(400px, 100vw);
  height: 100%;
  max-height: 100dvh;
  background: #fff;
  box-shadow: -6px 0 40px rgba(74, 29, 140, 0.22), -2px 0 8px rgba(0,0,0,0.08);
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.32, 0.72, 0, 1);
  display: flex;
  flex-direction: column;
  border-left: 1px solid #ede9fe;
}
.oc-plp-facet-tray-root.is-open .oc-plp-facet-tray {
  transform: translateX(0);
}

/* Tray header — gradient accent top border */
.oc-plp-facet-tray-head {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 16px 14px;
  background: #fff;
  border-bottom: 1px solid #ede9fe;
  border-top: 3px solid transparent;
  border-image: linear-gradient(90deg, #4a1d8c, #be185d) 1;
}
.oc-plp-facet-tray-title {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.01em;
  background: linear-gradient(90deg, #4a1d8c, #be185d);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Close button */
.oc-plp-facet-tray-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid #ede9fe;
  background: #faf8ff;
  border-radius: 50%;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  color: #6d28d9;
  padding: 0;
  transition: background .15s, border-color .15s, color .15s;
}
.oc-plp-facet-tray-close:hover {
  background: #6d28d9;
  border-color: #6d28d9;
  color: #fff;
}

/* Tray body — custom scrollbar */
.oc-plp-facet-tray-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 10px 14px 24px;
  scrollbar-width: thin;
  scrollbar-color: #c4b5fd #f5f3ff;
}
.oc-plp-facet-tray-body::-webkit-scrollbar {
  width: 6px;
}
.oc-plp-facet-tray-body::-webkit-scrollbar-track {
  background: #f5f3ff;
  border-radius: 3px;
}
.oc-plp-facet-tray-body::-webkit-scrollbar-thumb {
  background: #c4b5fd;
  border-radius: 3px;
}
.oc-plp-facet-tray-body::-webkit-scrollbar-thumb:hover {
  background: #7c3aed;
}

/* Items inside tray */
.oc-plp-facet-tray-body .facetwp-checkbox,
.oc-plp-facet-tray-body .facetwp-radio {
  border-radius: 6px;
  min-height: 38px;
  padding: 6px 6px 6px 26px;
}
.oc-plp-facet-tray-body .facetwp-checkbox:hover,
.oc-plp-facet-tray-body .facetwp-radio:hover {
  background: #f3eeff;
}
.oc-plp-facet-tray-body .facetwp-checkbox.checked,
.oc-plp-facet-tray-body .facetwp-radio.checked {
  background: #ede9fe;
}

/* ── Subcategory link list ────────────────────────────────────────── */
/* Legacy alias — live delivery now uses oc-preview-subcat-* (preview export) */
.oc-plp-filters .oc-plp-subcat-links .oc-plp-subcat-row,
.oc-plp-filters .oc-preview-subcat-links .oc-preview-subcat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: var(--bb-filter-row-h, 40px);
  padding: 4px 6px;
  border-radius: 6px;
}
.oc-plp-filters .oc-plp-subcat-links .oc-plp-subcat-row:hover {
  background: #f3eeff;
}
.oc-plp-filters .oc-plp-subcat-links .facetwp-link {
  flex: 1 1 auto;
  text-decoration: none;
  color: var(--bb-filter-accent, #6d28d9);
  font-weight: 500;
}
.oc-plp-filters .oc-plp-subcat-links .facetwp-link:hover {
  text-decoration: underline;
  color: var(--bb-filter-accent-2, #be185d);
}

/* Visually hide native select */
.oc-plp-filters .facetwp-facet-product_cat .oc-plp-sr-only-wrap {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* ── TV Screen Size accordion (preview export: oc-size-*) ───────── */
.oc-plp-filters .oc-size-range-row,
.oc-plp-filters .oc-plp-size-range-row {
  display: flex !important;
  align-items: center !important;
  border-radius: var(--bb-filter-radius, 6px);
}
.oc-plp-filters .oc-size-range-row:hover {
  background: rgba(109, 40, 217, 0.07);
}
.oc-plp-filters .oc-size-range-checkbox,
.oc-plp-filters .oc-size-range-row .oc-size-range-checkbox {
  flex: 1 1 auto !important;
  min-height: var(--bb-filter-row-h, 40px) !important;
  border-radius: 0 !important;
  margin-bottom: 0 !important;
}
.oc-plp-filters .oc-size-chevron,
.oc-plp-filters .oc-plp-size-chevron {
  background: none !important;
  border: none !important;
  padding: 2px 4px !important;
  color: var(--bb-filter-accent, #6d28d9) !important;
  width: 28px !important;
  height: 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  font-size: 0 !important;
  cursor: pointer !important;
  border-radius: 50% !important;
  transition: background 0.12s, color 0.12s !important;
}
.oc-plp-size-chevron:hover {
  background: #ede9fe !important;
  color: var(--bb-filter-accent-2, #be185d) !important;
}
.oc-plp-size-chevron[aria-expanded="true"] {
  background: #ede9fe !important;
}
.oc-plp-filters .oc-size-chevron[aria-expanded="true"] svg,
.oc-plp-size-chevron[aria-expanded="true"] svg {
  transform: rotate(180deg);
}
.oc-plp-filters .oc-size-children,
.oc-plp-size-children {
  display: none;
  padding: 0 0 4px 14px;
  background: #faf8ff;
  border-left: 2px solid var(--bb-filter-border, #ddd6fe);
  margin: 0 6px 4px 8px;
  border-radius: 0 0 4px 4px;
}
.oc-plp-filters .oc-size-children.is-open,
.oc-plp-size-children.is-open {
  display: block;
}
.oc-plp-filters .oc-size-child-row,
.oc-plp-size-child-row {
  min-height: 34px !important;
  font-size: 13px !important;
  padding-top: 4px !important;
  padding-bottom: 4px !important;
}
.oc-plp-filters .oc-tv-size-accordion {
  max-height: none !important;
}

/* ── BB-style price UI (preview export parity) ─────────────────── */
.oc-plp-filters .oc-preview-price-bb-wrap {
  margin-top: 2px;
}
.oc-plp-filters .oc-preview-price-inputs {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
}
.oc-plp-filters .oc-preview-price-input {
  flex: 1;
  min-width: 0;
  padding: 6px 8px;
  font-size: 12px;
  font-family: inherit;
  border: 1px solid var(--bb-filter-border, #ddd6fe);
  border-radius: var(--bb-filter-radius, 6px);
  background: #fff;
  box-sizing: border-box;
  outline: none;
  color: var(--bb-filter-ink, #0f0a1e);
}
.oc-plp-filters .oc-preview-price-input:focus {
  border-color: var(--bb-filter-accent, #6d28d9);
  box-shadow: 0 0 0 2px rgba(109, 40, 217, 0.15);
}
.oc-plp-filters .oc-preview-price-to {
  font-size: 12px;
  color: var(--bb-filter-muted, #64748b);
  flex-shrink: 0;
}
.oc-plp-filters .oc-preview-price-set-btn {
  flex-shrink: 0;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  background: linear-gradient(135deg, #4a1d8c, #6d28d9);
  color: #fff;
  border: none;
  border-radius: var(--bb-filter-radius, 6px);
  cursor: pointer;
}
.oc-plp-filters .oc-preview-price-set-btn:hover {
  opacity: 0.88;
}
.oc-plp-filters .oc-preview-price-ranges {
  margin-top: 2px;
  padding: 0;
}
.oc-plp-filters .oc-preview-price-ranges .facetwp-checkbox {
  cursor: pointer;
  min-height: var(--bb-filter-row-h, 40px);
  padding: 6px 6px 6px 8px;
}
.oc-plp-filters .oc-preview-price-ranges .facetwp-checkbox.checked,
.oc-plp-filters .oc-preview-price-ranges .facetwp-checkbox.facetwp-selected {
  background: var(--bb-filter-sel-bg, #ede9fe);
  border-radius: 6px;
}

/* ── Subcategory link list (preview export parity) ───────────────── */
.oc-plp-filters .oc-preview-subcat-links {
  padding: 0;
}
.oc-plp-filters .oc-preview-subcat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: var(--bb-filter-row-h, 40px);
  padding: 4px 6px;
  border-radius: var(--bb-filter-radius, 6px);
}
.oc-plp-filters .oc-preview-subcat-row:hover {
  background: rgba(109, 40, 217, 0.07);
}
.oc-plp-filters .oc-preview-subcat-row .facetwp-link {
  flex: 1 1 auto;
  color: var(--bb-filter-accent, #6d28d9);
  text-decoration: none;
  font-weight: 500;
}
.oc-plp-filters .oc-preview-subcat-row .facetwp-link:hover {
  text-decoration: underline;
  color: var(--bb-filter-accent-2, #be185d);
}
.oc-plp-filters .oc-preview-subcat-row .facetwp-counter {
  font-size: 12px;
  color: var(--bb-filter-muted, #64748b);
  flex-shrink: 0;
}

/* ── Condition cards ─────────────────────────────────────────────── */
.oc-plp-filters .facetwp-facet[data-name="condition"] .facetwp-overflow,
.oc-plp-filters .facetwp-facet[data-name="_oc_preview_condition"] .facetwp-overflow {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
  padding: 4px 0 8px !important;
}
.oc-plp-filters .oc-cond-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  padding: 12px 8px 10px !important;
  border: 1.5px solid rgba(221, 214, 254, 0.45) !important;
  border-radius: 10px !important;
  background: transparent !important;
  cursor: pointer !important;
  text-align: center !important;
  font: inherit !important;
  transition: border-color .15s, background .15s, box-shadow .15s !important;
  min-height: 80px !important;
  color: var(--bb-filter-ink, #0f0a1e) !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.oc-plp-filters .oc-cond-card:hover {
  border-color: var(--bb-filter-accent, #6d28d9) !important;
  background: #f3eeff !important;
}
.oc-plp-filters .oc-cond-card.checked,
.oc-plp-filters .oc-cond-card.facetwp-selected {
  border-color: var(--bb-filter-accent, #6d28d9) !important;
  background: #ede9fe !important;
  box-shadow: 0 0 0 2px rgba(109, 40, 217, 0.22) !important;
}
.oc-plp-filters .oc-cond-icon {
  color: var(--bb-filter-accent, #6d28d9) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.oc-plp-filters .oc-cond-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: var(--bb-filter-ink, #0f0a1e) !important;
}
.oc-plp-filters .oc-cond-card-sub {
  font-size: 10px !important;
  font-weight: 400 !important;
  color: var(--bb-filter-muted, #64748b) !important;
  line-height: 1.3 !important;
  text-align: center !important;
  display: block !important;
  width: 100% !important;
}

/* Shop by Brand — oc-nav logo chips (sidebar, after Subcategory) */
.oc-plp-filters .oc-plp-shop-by-brand-facet .facetwp-header {
  margin-bottom: 8px !important;
}
.oc-plp-filters .oc-plp-shop-brand__list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
.oc-plp-filters .oc-plp-shop-brand__chip {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  min-height: 56px !important;
  padding: 8px 6px !important;
  border: 1px solid var(--bb-filter-border, #e8e6f0) !important;
  border-radius: 8px !important;
  background: #fff !important;
  text-decoration: none !important;
  color: var(--bb-filter-ink, #0f0a1e) !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
}
.oc-plp-filters .oc-plp-shop-brand__chip:hover {
  border-color: var(--bb-filter-accent, #6d28d9) !important;
  box-shadow: 0 0 0 1px rgba(109, 40, 217, 0.15) !important;
}
.oc-plp-filters .oc-plp-shop-brand__logo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 28px !important;
}
.oc-plp-filters .oc-plp-shop-brand__logo img {
  max-width: 100% !important;
  max-height: 28px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}
.oc-plp-filters .oc-plp-shop-brand__label {
  font-size: 10px !important;
  line-height: 1.2 !important;
  text-align: center !important;
  color: var(--bb-filter-muted, #64748b) !important;
}
