/* =========================================================
   Furniture Reserve — Phase 3 (Collection / Shop pages)
   ========================================================= */

/* Hide Odoo's default breadcrumb + title on shop pages (we render our own banner) */
body.fr-body .o_wsale_products_page .o_header_standard > .container > .py-2 { display: none; }
body.fr-body #o_wsale_container .oe_structure.oe_structure_not_nearest[id^="oe_structure_website_sale_products"] { min-height: 0; }

/* ----- Collection Banner ----- */
.fr-col-banner {
  position: relative;
  overflow: hidden;
  background: var(--color-bg-warm);
  font-family: var(--font-sans);
}
.fr-col-banner__gradient {
  position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(135deg, var(--color-accent) 0%, #5a4a37 50%, #3d3226 100%);
}
.fr-col-banner__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(26,26,26,0.15) 0%, rgba(26,26,26,0.35) 100%);
}
.fr-col-banner__content {
  position: relative; z-index: 1;
  max-width: var(--max-width); margin: 0 auto;
  padding: 5rem 2rem; text-align: center;
  color: #fff;
}
.fr-col-banner__breadcrumbs {
  font-family: var(--font-sans);
  font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.75);
  margin-bottom: 1.5rem;
}
.fr-col-banner__breadcrumbs a {
  color: rgba(255,255,255,0.75);
  text-decoration: none;
}
.fr-col-banner__breadcrumbs a:hover { color: #fff; }
.fr-col-banner__breadcrumbs .sep { margin: 0 0.5rem; color: var(--color-accent-light); }
.fr-col-banner__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4.5vw, 3.25rem); font-weight: 300;
  line-height: 1.1; letter-spacing: -0.01em;
  margin: 0 0 0.75rem; color: #fff;
}
.fr-col-banner__description {
  font-size: 1rem; line-height: 1.7;
  color: rgba(255,255,255,0.85);
  max-width: 640px; margin: 0 auto 1rem;
}
.fr-col-banner__count {
  font-size: 0.75rem; letter-spacing: 0.15em; text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin: 0;
}
@media (max-width: 767px) {
  .fr-col-banner__content { padding: 3rem 1.25rem; }
}

/* ----- Shop / Product Grid ----- */
body.fr-body #o_wsale_container {
  max-width: var(--max-width) !important;
  padding: 2rem clamp(1.5rem, 4vw, 4rem) 4rem !important;
  font-family: var(--font-sans);
}

/* Toolbar */
body.fr-body .o_wsale_products_main_row > aside#products_grid_before {
  padding-top: 1rem;
}
body.fr-body #products_grid .js_attributes .o_header_standard h6,
body.fr-body #products_grid_before h6 {
  font-family: var(--font-sans);
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--color-text) !important;
}

/* Product card styling */
body.fr-body .o_wsale_products_item,
body.fr-body .oe_product {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin-bottom: 1.5rem;
}
body.fr-body .oe_product_cart {
  background: transparent;
  border: none;
}
body.fr-body .oe_product_cart .product_price .oe_price {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  color: var(--color-text);
}
body.fr-body .oe_product_cart h6 a.product_name,
body.fr-body .oe_product_cart h5 a.product_name,
body.fr-body .oe_product_cart h4 a.product_name {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-text);
  letter-spacing: 0;
  line-height: 1.4;
  text-transform: none;
}

/* Image frame */
body.fr-body .oe_product_image,
body.fr-body .oe_product_image_link {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--color-bg-cream);
  border-radius: 2px;
  margin-bottom: 1rem;
  display: block;
  transition: transform 0.6s ease;
}
body.fr-body .oe_product_image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.6s ease;
}
body.fr-body .oe_product:hover .oe_product_image img {
  transform: scale(1.05);
}

/* Empty-state message */
.fr-shop-empty {
  padding: 5rem 2rem;
  text-align: center;
  background: var(--color-bg);
}
.fr-shop-empty__eyebrow {
  font-family: var(--font-sans);
  font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 1rem;
}
.fr-shop-empty__title {
  font-family: var(--font-serif);
  font-size: 2rem; font-weight: 300;
  color: var(--color-text);
  margin: 0 0 1rem;
}
.fr-shop-empty__text {
  font-family: var(--font-sans);
  font-size: 1rem; line-height: 1.7;
  color: var(--color-text-light);
  max-width: 500px; margin: 0 auto 2rem;
}
.fr-shop-empty__cta {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 1rem 2.5rem;
  background: var(--color-accent); color: #fff;
  font-family: var(--font-sans); font-size: 0.75rem; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase;
  text-decoration: none; border: none; cursor: pointer;
  transition: background 0.3s ease, transform 0.3s ease;
}
.fr-shop-empty__cta:hover {
  background: var(--color-gold); color: #fff; transform: translateY(-2px);
}

/* Sort / View controls */
body.fr-body .o_wsale_apply_layout .btn,
body.fr-body #o_wsale_container .form-select {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  border-radius: 0;
  border-color: var(--color-border);
}
body.fr-body #o_wsale_container .form-select:focus,
body.fr-body .o_wsale_apply_layout .btn:focus {
  border-color: var(--color-accent);
  box-shadow: none;
}

/* Pagination */
body.fr-body .o_wsale_products_page nav[aria-label="Pagination"] .page-link {
  color: var(--color-text);
  border-radius: 0 !important;
  border-color: var(--color-border);
  font-family: var(--font-sans);
  font-size: 0.85rem;
}
body.fr-body .o_wsale_products_page nav[aria-label="Pagination"] .page-item.active .page-link {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}

/* ---- Quick-category row (under shop banner) ---- */
.fr-qcat {
  max-width: var(--max-width); margin: 0 auto;
  padding: 1.75rem clamp(1.5rem, 4vw, 4rem) 0;
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  justify-content: center;
  font-family: var(--font-sans);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 1.75rem;
}
.fr-qcat__item {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.55rem 1.25rem;
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-family: var(--font-sans); font-size: 0.8rem;
  letter-spacing: 0.05em;
  text-decoration: none;
  background: #fff;
  transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}
.fr-qcat__item:hover { border-color: var(--color-accent); color: var(--color-accent); text-decoration: none; }
.fr-qcat__item.is-active { background: var(--color-text); border-color: var(--color-text); color: #fff; }
.fr-qcat__item--feature { border-color: var(--color-accent); color: var(--color-accent); }
.fr-qcat__item--feature:hover { background: var(--color-accent); color: #fff; }
@media (max-width: 749px) {
  .fr-qcat { padding: 1rem 1rem 0; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; scroll-snap-type: x mandatory; }
  .fr-qcat__item { flex-shrink: 0; scroll-snap-align: start; padding: 0.45rem 1rem; font-size: 0.75rem; }
  .fr-qcat { padding-bottom: 1rem; }
}
