/*
 Theme Name: Shoptimizer Child
 Template: shoptimizer
 Text Domain: shoptimizer-child
*/

:root { --product-thumb-ratio: 1 / 1; }
.woocommerce :where(ul.products, .related, .upsells, .cross-sells) li.product a img,
.wc-block-grid__products .wc-block-grid__product img {
  width: 100%;
  aspect-ratio: var(--product-thumb-ratio);
  object-fit: contain;
  display: block;
  height: auto;
}
/* ==========================================================================
   BE Filters — WOOF sidebar (mobile-first)
   Wrapper: .be-filters
   ========================================================================== */

/* 0) WOOF layout fixes: make it a single column, remove forced heights */
.be-filters .woof_sid_auto_shortcode .woof_redraw_zone { display: block; }
.be-filters .woof_sid_auto_shortcode .woof_container,
.be-filters .woof_sid_auto_shortcode .woof_container_mselect {
  width: 100%;
  min-width: 0;
  max-height: none;
  overflow: visible;
}

/* 1) Wrapper should NOT look like a card; each section is a card */
.be-filters .woof_sid_auto_shortcode,
.be-filters .woof { background: transparent; border: 0; box-shadow: none; padding: 0; }

/* 2) Section cards */
.be-filters .woof_container {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden; /* keeps rounded corners during animation */
  font-size: 14px;
}
@media (min-width: 768px) {
  .be-filters .woof_container { font-size: 15px; }
}

/* 3) Headers */
.be-filters .woof_container .woof_container_title,
.be-filters .woof_container .woof_front_toggle,
.be-filters .woof_container > h4,
.be-filters .woof_container > h5 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  margin: 0;
  cursor: pointer;
  background: #fafafa;
  border-bottom: 1px solid #eaeaea;
  font-weight: 600;
  font-size: 15px;
  line-height: 1.2;
  color: #111827;
}

/* Chevron */
.be-filters .woof_container .woof_container_title::after,
.be-filters .woof_container .woof_front_toggle::after,
.be-filters .woof_container > h4::after,
.be-filters .woof_container > h5::after {
  content: "";
  width: 10px; height: 10px; margin-left: auto;
  border-right: 2px solid #6b7280; border-bottom: 2px solid #6b7280;
  transform: rotate(45deg); transition: transform .2s ease;
}
.be-filters .woof_container.is-open .woof_container_title::after,
.be-filters .woof_container.is-open .woof_front_toggle::after,
.be-filters .woof_container.is-open > h4::after,
.be-filters .woof_container.is-open > h5::after { transform: rotate(225deg); }

/* 4) Body: open by default, then JS enables accordion clamping */
.be-filters .woof_container_inner,
.be-filters .woof_closed_block { display: block !important; }  /* defeat plugin inline display:none */

/* Default: fully visible (no clamp) until JS marks ready */
.be-filters .woof_container .woof_container_inner { padding: 10px 14px; overflow: hidden; max-height: none; }

/* When JS adds .be-accordion-ready to the wrapper, enable accordion */
.be-accordion-ready .woof_container .woof_container_inner { max-height: 0; transition: max-height .25s ease; }
.be-accordion-ready .woof_container.is-open .woof_container_inner { max-height: 1200px; }

/* 5) Lists */
.be-filters .woof_list,
.be-filters .woof_block_html_items ul { width: 100%; margin: 4px 0 0 0 !important; padding: 0; }
.be-filters .woof_list li { margin: 0 0 6px 0; color: #374151; font-size: 14px; }

/* 6) “Show more / less” */
.be-filters .woof_open_hidden_li { display: block !important; text-align: left; margin-top: 6px; }
.be-filters .woof_open_hidden_li a {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; color: #111827;
  padding: 6px 8px; border-radius: 6px;
  background: #e5e7eb; text-decoration: none;
  transition: background-color .15s ease, color .15s ease;
}
.be-filters .woof_open_hidden_li a:hover { background: #d1d5db; }

/* 7) Counts */
.be-filters .woof-sd-ie-count,
.be-filters .woof_checkbox_count,
.be-filters .woof_radio_count {
  background: #fff;
  border: 1px solid #d1d5db;
  border-radius: 999px;
  padding: 0 6px;
  font-size: 12px;
  line-height: 18px;
  color: #374151;
}

/* 8) Apply/Reset row */
.be-filters .woof_submit_search_form_container { margin-top: 10px; padding-top: 10px; border-top: 1px solid #e5e7eb; }
.be-filters .woof_submit_search_form_container .button,
.be-filters a.woof_start_filtering_btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 12px; border-radius: 6px; font-weight: 600; font-size: 14px;
  border: 1px solid #d1d5db; background: #fff; color: #111827;
  text-decoration: none; transition: background-color .15s ease, border-color .15s ease;
}
.be-filters .woof_submit_search_form_container .button:hover,
.be-filters a.woof_start_filtering_btn:hover { background: #f3f4f6; border-color: #cfd3d8; }

/* 9) Remove conflicting plugin icons */
.be-filters .woof_show_auto_form,
.be-filters .woof_hide_auto_form,
.be-filters .woof_childs_list_opener span { background: none !important; }

/* 10) Bigger checkbox/radio (WOOF skin vars + native fallback) */
.be-filters {
  --woof-sd-ie-ch_width: 36px;
  --woof-sd-ie-ch_height: 36px;
  --woof-sd-ie-ch_font_size: 15px;
  --woof-sd-ie-rad_width: 36px;
  --woof-sd-ie-rad_height: 36px;
  --woof-sd-ie-rad_font_size: 15px;
}
.be-filters input[type="checkbox"],
.be-filters input[type="radio"] {
  transform: scale(1.25);
  transform-origin: center;
  accent-color: #111827;
}
