/* =========================================================
   Furniture Reserve — Phase 4 (Product pages)
   ========================================================= */

/* Style Odoo's product detail to match FR */
body.fr-body #product_detail .product_name,
body.fr-body #product_detail h1 {
  font-family: var(--font-serif);
  font-weight: 300;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  color: var(--color-text);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
}
body.fr-body #product_detail .product_price h4,
body.fr-body #product_detail h3.oe_price {
  font-family: var(--font-sans);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--color-text);
}
body.fr-body #product_detail .o_wsale_breadcrumb,
body.fr-body #product_detail .breadcrumb {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-text-light);
}
body.fr-body #product_detail .o_wsale_breadcrumb a,
body.fr-body #product_detail .breadcrumb a { color: var(--color-accent); text-decoration: none; }
body.fr-body #product_detail .o_wsale_breadcrumb a:hover { color: var(--color-accent-hover); }

/* Add-to-cart button restyling */
body.fr-body #product_detail #add_to_cart,
body.fr-body #product_detail .btn-primary {
  background: var(--color-accent) !important;
  border-color: var(--color-accent) !important;
  border-radius: 0 !important;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 1rem 2.5rem !important;
  transition: background 0.3s ease, transform 0.3s ease;
}
body.fr-body #product_detail #add_to_cart:hover,
body.fr-body #product_detail .btn-primary:hover {
  background: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  transform: translateY(-2px);
}

/* Outline buttons */
body.fr-body #product_detail .btn-secondary,
body.fr-body #product_detail .btn-outline-primary {
  background: transparent !important;
  border-radius: 0 !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 1rem 2.5rem !important;
}

/* ---- FR Quality Badges ---- */
.fr-prod-badges {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin: 2rem 0;
  padding: 1.5rem 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.fr-prod-badge { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; text-align: center; }
.fr-prod-badge__icon { width: 32px; height: 32px; color: var(--color-accent); }
.fr-prod-badge__label {
  font-family: var(--font-sans); font-size: 0.7rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--color-text-light);
  line-height: 1.3;
}
@media (max-width: 749px) { .fr-prod-badges { grid-template-columns: repeat(2, 1fr); } }

/* ---- Craftsmanship (below product) ---- */
.fr-prod-craft {
  padding: 5rem 0;
  background: var(--color-bg-warm);
  font-family: var(--font-sans);
}
.fr-prod-craft__container { max-width: var(--max-width); margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem); }
.fr-prod-craft__header { text-align: center; max-width: 700px; margin: 0 auto 3.5rem; }
.fr-prod-craft__eyebrow { font-family: var(--font-sans); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-accent); margin-bottom: 1rem; display: block; }
.fr-prod-craft__heading { font-family: var(--font-serif); font-size: clamp(2rem, 3.5vw, 2.6rem); font-weight: 300; color: var(--color-text); margin: 0 0 1.25rem; line-height: 1.15; }
.fr-prod-craft__body { font-size: 0.95rem; line-height: 1.8; color: var(--color-text-light); }
.fr-prod-craft__body p { margin: 0 0 1rem; }
.fr-prod-craft__features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.fr-prod-craft__feature { text-align: center; padding: 1.5rem; }
.fr-prod-craft__feature-icon { width: 44px; height: 44px; color: var(--color-accent); margin: 0 auto 1.25rem; display: block; }
.fr-prod-craft__feature-title { font-family: var(--font-serif); font-size: 1.15rem; font-weight: 400; color: var(--color-text); margin: 0 0 0.75rem; }
.fr-prod-craft__feature-desc { font-family: var(--font-sans); font-size: 0.85rem; line-height: 1.7; color: var(--color-text-light); margin: 0; }
@media (max-width: 749px) { .fr-prod-craft__features { grid-template-columns: 1fr; gap: 1.5rem; } }

/* ---- Dimensions ---- */
.fr-prod-dims { padding: 4rem 0; background: var(--color-bg); font-family: var(--font-sans); }
.fr-prod-dims__container { max-width: 900px; margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem); }
.fr-prod-dims__heading {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 300;
  text-align: center;
  color: var(--color-text);
  margin: 0 0 2.5rem;
}
.fr-prod-dims__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--color-border);
}
.fr-prod-dims__spec {
  padding: 1.5rem 1rem;
  text-align: center;
  border-bottom: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
}
.fr-prod-dims__spec:nth-child(3n) { border-right: none; }
.fr-prod-dims__label {
  font-family: var(--font-sans);
  font-size: 0.65rem; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0 0 0.5rem;
}
.fr-prod-dims__value {
  font-family: var(--font-serif);
  font-size: 1.5rem; font-weight: 300;
  color: var(--color-text);
}
@media (max-width: 749px) {
  .fr-prod-dims__grid { grid-template-columns: repeat(2, 1fr); }
  .fr-prod-dims__spec:nth-child(3n) { border-right: 1px solid var(--color-border); }
  .fr-prod-dims__spec:nth-child(2n) { border-right: none; }
}

/* ---- Consultation CTA ---- */
.fr-prod-cta { padding: 6rem 0; background: var(--color-bg-dark); color: #fff; text-align: center; font-family: var(--font-sans); }
.fr-prod-cta__container { max-width: 720px; margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem); }
.fr-prod-cta__eyebrow { font-family: var(--font-sans); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 1.25rem; display: block; }
.fr-prod-cta__heading { font-family: var(--font-serif); font-size: clamp(2rem, 3.5vw, 2.75rem); font-weight: 300; color: #fff; margin: 0 0 1.5rem; line-height: 1.15; }
.fr-prod-cta__body { font-size: 0.95rem; line-height: 1.8; color: rgba(255,255,255,0.7); margin: 0 0 2.5rem; }
.fr-prod-cta__buttons { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; margin-bottom: 2rem; }
.fr-prod-cta__btn-primary, .fr-prod-cta__btn-outline {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 1rem 2.5rem;
  font-family: var(--font-sans); font-size: 0.75rem; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase;
  text-decoration: none;
  transition: background 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
}
.fr-prod-cta__btn-primary { background: var(--color-accent); color: #fff; border: 1px solid var(--color-accent); }
.fr-prod-cta__btn-primary:hover { background: var(--color-gold); border-color: var(--color-gold); color: #fff; transform: translateY(-2px); }
.fr-prod-cta__btn-outline { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.3); }
.fr-prod-cta__btn-outline:hover { border-color: #fff; background: rgba(255,255,255,0.05); color: #fff; transform: translateY(-2px); }
.fr-prod-cta__trust { font-family: var(--font-sans); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin: 0; }
@media (max-width: 749px) { .fr-prod-cta__buttons { flex-direction: column; align-items: center; } .fr-prod-cta__btn-primary, .fr-prod-cta__btn-outline { width: 100%; max-width: 300px; justify-content: center; } }

/* ---- Trust bar (product page) ---- */
.fr-trust-bar {
  background: var(--color-bg-cream);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  font-family: var(--font-sans);
}
.fr-trust-bar__container {
  max-width: 1200px; margin: 0 auto;
  padding: 1.5rem clamp(1.5rem, 4vw, 4rem);
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.fr-trust-bar__item {
  display: flex; gap: 0.75rem; align-items: center;
}
.fr-trust-bar__item > svg {
  flex-shrink: 0;
  width: 28px; height: 28px;
  color: var(--color-accent);
}
.fr-trust-bar__title {
  font-family: var(--font-sans); font-size: 0.8rem; font-weight: 600;
  color: var(--color-text);
  margin: 0 0 0.125rem;
  letter-spacing: 0.02em;
}
.fr-trust-bar__sub {
  font-family: var(--font-sans); font-size: 0.75rem;
  color: var(--color-text-light);
  margin: 0;
}
@media (max-width: 989px) {
  .fr-trust-bar__container { grid-template-columns: repeat(2, 1fr); gap: 1rem 1.5rem; }
}
@media (max-width: 540px) {
  .fr-trust-bar__container { grid-template-columns: 1fr; padding: 1.25rem 1.5rem; }
}
