/* =========================================================
   Furniture Reserve — Phase 13
   Showroom detail, swatch request steps, mattress grid, article page
   ========================================================= */

/* ---- Showroom rich layout ---- */
.fr-showroom-hero {
  position: relative; padding: 6rem 2rem 5rem;
  text-align: center; overflow: hidden;
  background: linear-gradient(135deg, #C4AD8F 0%, #8B7355 50%, #5E5040 100%);
  color: #fff;
}
.fr-showroom-hero__eyebrow { font-family: var(--font-sans); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.25em; text-transform: uppercase; color: rgba(255,255,255,0.8); margin: 0 0 1rem; }
.fr-showroom-hero__heading { font-family: var(--font-serif); font-size: clamp(2.25rem, 5vw, 3.5rem); font-weight: 300; color: #fff; margin: 0 0 1rem; line-height: 1.1; }
.fr-showroom-hero__intro { font-family: var(--font-sans); font-size: 1.1rem; line-height: 1.7; color: rgba(255,255,255,0.88); max-width: 600px; margin: 0 auto; }

.fr-showroom-detail {
  max-width: 1280px; margin: 0 auto;
  padding: 5rem clamp(1.5rem, 4vw, 4rem);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 4rem; align-items: start;
}
.fr-showroom-detail__info h2 { font-family: var(--font-serif); font-size: 1.5rem; font-weight: 300; margin: 2.5rem 0 1rem; color: var(--color-text); }
.fr-showroom-detail__info h2:first-child { margin-top: 0; }
.fr-showroom-detail__info p,
.fr-showroom-detail__info address {
  font-family: var(--font-sans); font-size: 1rem; line-height: 1.75;
  color: var(--color-text-light); font-style: normal;
  margin: 0 0 1rem;
}
.fr-showroom-detail__info a { color: var(--color-accent); text-decoration: none; }
.fr-showroom-detail__info a:hover { color: var(--color-accent-hover); }

.fr-hours-table { width: 100%; border-collapse: collapse; font-family: var(--font-sans); font-size: 0.95rem; }
.fr-hours-table tr { border-bottom: 1px solid var(--color-border); }
.fr-hours-table tr:last-child { border-bottom: none; }
.fr-hours-table th, .fr-hours-table td { padding: 0.75rem 0; text-align: left; color: var(--color-text); font-weight: 400; }
.fr-hours-table td:last-child { text-align: right; color: var(--color-text-light); }

.fr-showroom-detail__map {
  aspect-ratio: 4/5;
  border: 1px solid var(--color-border);
  overflow: hidden; background: var(--color-bg-cream);
}
.fr-showroom-detail__map iframe { width: 100%; height: 100%; border: 0; }
@media (max-width: 989px) { .fr-showroom-detail { grid-template-columns: 1fr; gap: 3rem; padding: 3.5rem 1.5rem; } .fr-showroom-detail__map { aspect-ratio: 4/3; } }

/* ---- What to expect row ---- */
.fr-expect { padding: 5rem 0; background: var(--color-bg-cream); font-family: var(--font-sans); }
.fr-expect__container { max-width: 1280px; margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem); }
.fr-expect__header { text-align: center; margin-bottom: 3rem; }
.fr-expect__eyebrow { font-family: var(--font-sans); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-accent); margin: 0 0 1rem; }
.fr-expect__heading { font-family: var(--font-serif); font-size: clamp(1.75rem, 3vw, 2.25rem); font-weight: 300; color: var(--color-text); margin: 0; }
.fr-expect__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.fr-expect__item {
  text-align: center; padding: 2rem 1.5rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}
.fr-expect__item-icon { width: 32px; height: 32px; color: var(--color-accent); margin: 0 auto 1rem; display: block; }
.fr-expect__item-title { font-family: var(--font-serif); font-size: 1.1rem; font-weight: 400; color: var(--color-text); margin: 0 0 0.5rem; }
.fr-expect__item-desc { font-family: var(--font-sans); font-size: 0.88rem; line-height: 1.6; color: var(--color-text-light); margin: 0; }
@media (max-width: 989px) { .fr-expect__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fr-expect__grid { grid-template-columns: 1fr; } }

/* ---- Swatch request steps (big numbers) ---- */
.fr-steps-row { padding: 5rem 0; background: var(--color-bg); font-family: var(--font-sans); }
.fr-steps-row__container { max-width: 1280px; margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem); }
.fr-steps-row__header { text-align: center; margin-bottom: 3.5rem; }
.fr-steps-row__eyebrow { font-family: var(--font-sans); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-accent); margin: 0 0 1rem; }
.fr-steps-row__heading { font-family: var(--font-serif); font-size: clamp(1.75rem, 3vw, 2.25rem); font-weight: 300; color: var(--color-text); margin: 0; }
.fr-steps-row__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; position: relative; }
.fr-steps-row__item { text-align: center; position: relative; padding: 0 1rem; }
.fr-steps-row__item::before {
  content: ''; position: absolute; top: 28px; right: -1rem;
  width: 2rem; height: 1px; background: var(--color-accent-light);
}
.fr-steps-row__item:last-child::before { display: none; }
.fr-steps-row__number {
  font-family: var(--font-serif); font-size: 2.5rem; font-weight: 300;
  width: 56px; height: 56px; border-radius: 50%;
  border: 1px solid var(--color-accent);
  color: var(--color-accent);
  background: var(--color-bg);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem; line-height: 1;
}
.fr-steps-row__item-title { font-family: var(--font-serif); font-size: 1.15rem; font-weight: 400; color: var(--color-text); margin: 0 0 0.5rem; }
.fr-steps-row__item-desc { font-family: var(--font-sans); font-size: 0.88rem; line-height: 1.65; color: var(--color-text-light); margin: 0; }
@media (max-width: 989px) { .fr-steps-row__grid { grid-template-columns: 1fr 1fr; } .fr-steps-row__item::before { display: none; } }
@media (max-width: 540px) { .fr-steps-row__grid { grid-template-columns: 1fr; } }

/* ---- Swatch color tiles preview ---- */
.fr-swatch-preview {
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 0.5rem;
  max-width: 900px; margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem) 4rem;
}
.fr-swatch-preview__tile {
  aspect-ratio: 1; background-size: cover; background-position: center;
  border-radius: 2px;
}
@media (max-width: 749px) { .fr-swatch-preview { grid-template-columns: repeat(4, 1fr); } }

/* ---- Mattress collection grid (Tempur-Pedic) ---- */
.fr-mattress-grid { padding: 5rem 0; background: var(--color-bg); }
.fr-mattress-grid__container { max-width: 1280px; margin: 0 auto; padding: 0 clamp(1.5rem, 4vw, 4rem); }
.fr-mattress-grid__header { text-align: center; margin-bottom: 3rem; }
.fr-mattress-grid__eyebrow { font-family: var(--font-sans); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-gold); margin: 0 0 1rem; }
.fr-mattress-grid__heading { font-family: var(--font-serif); font-size: clamp(1.75rem, 3vw, 2.25rem); font-weight: 300; color: var(--color-text); margin: 0; }
.fr-mattress-grid__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.fr-mattress-card {
  padding: 2rem; background: #fff; border: 1px solid var(--color-border);
  font-family: var(--font-sans);
}
.fr-mattress-card__tier { font-family: var(--font-sans); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-accent); margin: 0 0 0.5rem; }
.fr-mattress-card__name { font-family: var(--font-serif); font-size: 1.5rem; font-weight: 300; color: var(--color-text); margin: 0 0 0.75rem; }
.fr-mattress-card__desc { font-family: var(--font-sans); font-size: 0.9rem; line-height: 1.65; color: var(--color-text-light); margin: 0 0 1.5rem; }
.fr-mattress-card__feature-list { list-style: none; padding: 0; margin: 0 0 1.5rem; }
.fr-mattress-card__feature-list li { font-family: var(--font-sans); font-size: 0.85rem; padding: 0.4rem 0; border-bottom: 1px solid var(--color-border); color: var(--color-text); }
.fr-mattress-card__feature-list li:last-child { border-bottom: none; }
.fr-mattress-card__starting { font-family: var(--font-serif); font-size: 1.1rem; color: var(--color-accent); font-weight: 400; }
@media (max-width: 989px) { .fr-mattress-grid__grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; } }

/* ---- Blog article detail ---- */
.fr-article { background: var(--color-bg); font-family: var(--font-sans); }
.fr-article__hero {
  max-width: 1200px; margin: 0 auto;
  padding: 4rem clamp(1.5rem, 4vw, 4rem) 3rem;
  text-align: center;
}
.fr-article__category {
  font-family: var(--font-sans); font-size: 0.7rem; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--color-accent); margin: 0 0 1rem;
}
.fr-article__heading {
  font-family: var(--font-serif); font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 300; color: var(--color-text);
  line-height: 1.1; margin: 0 auto 1.5rem; max-width: 820px;
}
.fr-article__meta {
  font-family: var(--font-sans); font-size: 0.8rem;
  color: var(--color-text-muted); letter-spacing: 0.05em;
}
.fr-article__cover {
  max-width: 1200px; margin: 0 auto 3rem;
  padding: 0 clamp(1.5rem, 4vw, 4rem);
}
.fr-article__cover-inner {
  aspect-ratio: 16/8; overflow: hidden;
  background: linear-gradient(135deg, var(--color-bg-cream), rgba(139,115,85,0.25));
  display: flex; align-items: center; justify-content: center;
}
.fr-article__cover-inner svg { width: 56px; height: 56px; color: rgba(139,115,85,0.4); }
.fr-article__body {
  max-width: 720px; margin: 0 auto;
  padding: 0 clamp(1.5rem, 4vw, 4rem) 5rem;
  font-family: var(--font-sans);
}
.fr-article__body p { font-size: 1.0625rem; line-height: 1.85; color: var(--color-text); margin: 0 0 1.25rem; }
.fr-article__body h2 { font-family: var(--font-serif); font-size: 1.6rem; font-weight: 400; color: var(--color-text); margin: 2.5rem 0 1rem; }
.fr-article__body blockquote {
  margin: 2.5rem 0;
  padding: 1rem 0 1rem 1.5rem;
  border-left: 2px solid var(--color-accent);
  font-family: var(--font-serif);
  font-size: 1.25rem; font-style: italic;
  color: var(--color-text-light);
}
.fr-article__back {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-sans); font-size: 0.75rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--color-accent); text-decoration: none;
  margin-bottom: 2rem;
}
.fr-article__back svg { width: 14px; height: 14px; }
.fr-article__back:hover { color: var(--color-accent-hover); }
