/*
 * bestof-lux.css
 * Premium design-polish layer for The Glow makeup best-of roundup pages.
 * Scoped entirely to .bestof-lux — zero bleed to other pages.
 *
 * Targets two templates that these 4 pages use:
 *   Template A (concealer, brow):  body.reviews-skin  — classes: .review-hero, .breadcrumb,
 *                                   .ai-answer, .comparison-table-wrap, .test-conditions,
 *                                   .top-pick-callout, .ed-section / .pick-grid / .pick-card,
 *                                   .faq-section, .related-section, .author-byline
 *   Template B (primer, blush):    body.glow-guide-v3 — classes: .gv3-hero, .gv3-eyebrow,
 *                                   .gv3-cards / .gv3-card, .gv3-ranked-sec, .gv3-section-h2,
 *                                   .gv3-faq-sec, .gv3-seo-block
 *
 * Applied via wrapper: <main id="top" class="bestof-lux"> on all 4 pages.
 *
 * Created: 2026-06-08
 */

/* ─── DESIGN TOKENS ──────────────────────────────────────────────── */
.bestof-lux {
  --bl-ink:          #171514;
  --bl-ink-2:        #2c2438;
  --bl-body:         #5C554B;
  --bl-body-2:       #7A7068;
  --bl-muted:        #9b8f82;
  --bl-rose:         #9A6A4B;
  --bl-rose-deep:    #7B5236;
  --bl-rose-soft:    #f0eff1;
  --bl-canvas:       #ffffff;
  --bl-parch:        #ffffff;
  --bl-parch-2:      #f4f4f5;
  --bl-parch-3:      #EDE9DE;
  --bl-line:         rgba(0,0,0,0.07);
  --bl-line-2:       rgba(0,0,0,0.13);
  --bl-serif:        'Canela', Georgia, 'Times New Roman', serif;
  --bl-sans:         'Instrument Sans', 'Inter', system-ui, sans-serif;
  --bl-shadow-card:  0 2px 12px rgba(0,0,0,0.06), 0 8px 32px rgba(0,0,0,0.05);
  --bl-shadow-lift:  0 8px 28px rgba(0,0,0,0.10), 0 20px 60px rgba(0,0,0,0.08);
}

/* ─── PAGE BACKGROUND ────────────────────────────────────────────── */
.bestof-lux {
  background: var(--bl-parch);
}


/* =====================================================================
   BREADCRUMB — uppercase, tracked, inset, coral hover
   (used by both templates — .breadcrumb class)
   ===================================================================== */

.bestof-lux .breadcrumb,
.bestof-lux nav.breadcrumb {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 0.35rem !important;
  padding: 1.75rem 0 1.5rem !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  color: var(--bl-muted) !important;
  background: transparent !important;
  border: 0 !important;
  margin: 0 !important;
}

.bestof-lux .breadcrumb a,
.bestof-lux nav.breadcrumb a {
  color: var(--bl-muted) !important;
  text-decoration: none !important;
  transition: color 180ms ease !important;
}

.bestof-lux .breadcrumb a:hover,
.bestof-lux nav.breadcrumb a:hover {
  color: var(--bl-rose) !important;
}

.bestof-lux .breadcrumb .sep {
  color: rgba(26,23,20,0.28) !important;
  font-weight: 400 !important;
}

/* gv3 breadcrumb uses "·" as separator inline text */
.bestof-lux nav.breadcrumb span {
  color: var(--bl-ink) !important;
}


/* =====================================================================
   TEMPLATE A — REVIEW HERO
   Classes: .review-hero, .review-hero h1, .lede, .meta
   ===================================================================== */

.bestof-lux .review-hero {
  background: var(--bl-canvas) !important;
  padding-block: clamp(3.5rem, 7vw, 6.5rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

/* Hero H1 — dramatic Canela serif */
.bestof-lux .review-hero h1 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(3rem, 6.5vw, 5.5rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.025em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 1.5rem !important;
  max-width: 20ch !important;
}

.bestof-lux .review-hero h1 em {
  font-style: italic !important;
  color: var(--bl-rose-deep) !important;
}

/* Lede text */
.bestof-lux .review-hero .lede {
  font-family: var(--bl-sans) !important;
  font-size: clamp(1.08rem, 1.5vw, 1.22rem) !important;
  line-height: 1.62 !important;
  color: var(--bl-body) !important;
  max-width: 48ch !important;
  margin: 0 0 2rem !important;
}

/* Meta row */
.bestof-lux .review-hero .meta {
  display: flex !important;
  gap: 1.5rem !important;
  flex-wrap: wrap !important;
  font-family: var(--bl-sans) !important;
  font-size: 11px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
}

.bestof-lux .review-hero .meta strong {
  color: var(--bl-ink) !important;
  font-weight: 600 !important;
}


/* =====================================================================
   TEMPLATE A — AUTHOR BYLINE
   ===================================================================== */

.bestof-lux .author-byline {
  background: var(--bl-parch) !important;
  padding-block: 2rem !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .ab-card {
  display: flex !important;
  align-items: center !important;
  gap: 1.25rem !important;
  background: var(--bl-canvas) !important;
  border: 1px solid var(--bl-line-2) !important;
  padding: 1.5rem 2rem !important;
  box-shadow: var(--bl-shadow-card) !important;
}

.bestof-lux .ab-avatar {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  background: var(--bl-rose-soft) !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.bestof-lux .ab-avatar::after {
  content: attr(data-initials);
  font-family: var(--bl-serif) !important;
  font-size: 1.1rem !important;
  color: var(--bl-rose-deep) !important;
  font-style: italic !important;
}

.bestof-lux .ab-label {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.26em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
  margin-bottom: 0.3rem !important;
}

.bestof-lux .ab-name {
  font-family: var(--bl-serif) !important;
  font-size: 1.1rem !important;
  color: var(--bl-ink) !important;
  font-style: italic !important;
}

.bestof-lux .ab-role {
  font-style: normal !important;
  font-size: 0.85rem !important;
  color: var(--bl-muted) !important;
}

.bestof-lux .ab-credential {
  font-family: var(--bl-sans) !important;
  font-size: 0.82rem !important;
  color: var(--bl-body-2) !important;
  margin-top: 0.2rem !important;
}

.bestof-lux .ab-date {
  margin-left: auto !important;
  text-align: right !important;
}

.bestof-lux .ab-when {
  font-family: var(--bl-serif) !important;
  font-size: 1rem !important;
  color: var(--bl-ink) !important;
}


/* =====================================================================
   TEMPLATE A — AI ANSWER / VERDICT ASIDE
   Classes: .ai-answer, .ai-q-label, .ai-q, .ai-a, .ai-for
   ===================================================================== */

.bestof-lux .ai-answer {
  background: var(--bl-parch-2) !important;
  border-top: none !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
  padding-block: clamp(3rem, 5vw, 4.5rem) !important;
  position: relative !important;
}

.bestof-lux .ai-answer::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: var(--bl-rose);
}

.bestof-lux .ai-q-label {
  display: block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  margin-bottom: 1rem !important;
}

.bestof-lux .ai-q {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(1.8rem, 3.2vw, 2.6rem) !important;
  line-height: 1.12 !important;
  letter-spacing: -0.02em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 1.25rem !important;
  max-width: 30ch !important;
}

.bestof-lux .ai-a {
  font-family: var(--bl-sans) !important;
  font-size: clamp(1rem, 1.25vw, 1.1rem) !important;
  line-height: 1.72 !important;
  color: var(--bl-body) !important;
  max-width: 58ch !important;
  margin: 0 0 1.5rem !important;
}

.bestof-lux .ai-for {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.6rem !important;
}

.bestof-lux .ai-for li {
  font-family: var(--bl-sans) !important;
  font-size: 0.92rem !important;
  color: var(--bl-body) !important;
  padding: 0.75rem 1rem !important;
  background: var(--bl-canvas) !important;
  border: 1px solid var(--bl-line-2) !important;
  display: flex !important;
  gap: 0.75rem !important;
  align-items: baseline !important;
}

.bestof-lux .ai-for li strong {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  font-weight: 600 !important;
  flex-shrink: 0 !important;
}


/* =====================================================================
   TEMPLATE A — COMPARISON TABLE
   Classes: .comparison-table-wrap, .comparison-table, .ct-rank, .ct-score, .ct-price, .ct-cta
   ===================================================================== */

.bestof-lux .comparison-table-wrap {
  background: var(--bl-canvas) !important;
  padding-block: clamp(3rem, 5vw, 4.5rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .comparison-table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-family: var(--bl-sans) !important;
  box-shadow: var(--bl-shadow-card) !important;
}

.bestof-lux .comparison-table caption {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(1.6rem, 2.8vw, 2.2rem) !important;
  letter-spacing: -0.015em !important;
  color: var(--bl-ink) !important;
  text-align: left !important;
  padding-bottom: 1.5rem !important;
  caption-side: top !important;
}

.bestof-lux .comparison-table caption em {
  font-style: italic !important;
  color: var(--bl-rose-deep) !important;
}

.bestof-lux .comparison-table thead th {
  background: var(--bl-ink) !important;
  color: #fff !important;
  font-size: 10px !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  padding: 1rem 1.25rem !important;
  font-weight: 600 !important;
  border: 0 !important;
}

.bestof-lux .comparison-table tbody tr {
  border-bottom: 1px solid var(--bl-line) !important;
  transition: background 180ms ease !important;
}

.bestof-lux .comparison-table tbody tr:hover {
  background: var(--bl-parch) !important;
}

.bestof-lux .comparison-table tbody tr:first-child {
  background: rgba(200, 79, 79, 0.05) !important;
}

.bestof-lux .comparison-table td {
  padding: 1rem 1.25rem !important;
  font-size: 0.93rem !important;
  color: var(--bl-body) !important;
  vertical-align: middle !important;
}

/* Rank cell — large serif numeral */
.bestof-lux .ct-rank {
  font-family: var(--bl-serif) !important;
  font-size: 1.6rem !important;
  font-weight: 300 !important;
  color: var(--bl-rose) !important;
  letter-spacing: -0.03em !important;
  font-style: italic !important;
  white-space: nowrap !important;
  padding-left: 1.5rem !important;
}

/* Product cell */
.bestof-lux .ct-product {
  font-family: var(--bl-serif) !important;
  font-size: 1.05rem !important;
  color: var(--bl-ink) !important;
  font-style: italic !important;
  line-height: 1.2 !important;
}

.bestof-lux .ct-product small {
  display: block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
  font-style: normal !important;
  margin-top: 0.2rem !important;
}

/* Score cell */
.bestof-lux .ct-score {
  font-family: var(--bl-serif) !important;
  font-size: 1.1rem !important;
  font-weight: 300 !important;
  color: var(--bl-ink) !important;
  white-space: nowrap !important;
}

/* Price cell */
.bestof-lux .ct-price {
  font-family: var(--bl-serif) !important;
  font-size: 1rem !important;
  font-style: italic !important;
  color: var(--bl-body) !important;
  white-space: nowrap !important;
}

/* CTA cell */
.bestof-lux .ct-cta a {
  display: inline-block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: var(--bl-ink) !important;
  padding: 0.6rem 1.1rem !important;
  border: 1px solid var(--bl-ink) !important;
  text-decoration: none !important;
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease !important;
  white-space: nowrap !important;
}

.bestof-lux .ct-cta a:hover {
  background: var(--bl-rose) !important;
  color: #fff !important;
  border-color: var(--bl-rose) !important;
}


/* =====================================================================
   TEMPLATE A — TEST CONDITIONS STRIP
   Classes: .test-conditions, .tc-grid, .tc-stat
   ===================================================================== */

.bestof-lux .test-conditions {
  background: var(--bl-parch-3) !important;
  padding-block: 2.5rem !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .tc-grid {
  display: flex !important;
  gap: 2rem !important;
  flex-wrap: wrap !important;
}

.bestof-lux .tc-stat {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.25rem !important;
}

.bestof-lux .tc-stat strong {
  font-family: var(--bl-serif) !important;
  font-size: clamp(2rem, 3.5vw, 2.8rem) !important;
  font-weight: 300 !important;
  letter-spacing: -0.03em !important;
  color: var(--bl-ink) !important;
  line-height: 1 !important;
}

.bestof-lux .tc-stat span {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
}


/* =====================================================================
   TEMPLATE A — TOP PICK CALLOUT
   Classes: .top-pick-callout, .pick-tag, .verdict, .price, .btn-rose-fill
   ===================================================================== */

.bestof-lux .top-pick-callout {
  background: #1a0a0d !important;
  padding-block: clamp(4rem, 7vw, 7rem) !important;
  border-bottom: none !important;
  text-align: center !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Large decorative quote behind */
.bestof-lux .top-pick-callout::before {
  content: '★';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--bl-serif);
  font-size: 22rem;
  color: rgba(255,255,255,0.025);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.bestof-lux .top-pick-callout .wrap { position: relative; z-index: 1; }

.bestof-lux .top-pick-callout .pick-tag {
  display: inline-block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose-soft) !important;
  margin-bottom: 1.5rem !important;
  opacity: 0.85 !important;
}

.bestof-lux .top-pick-callout h2 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(2.4rem, 5vw, 4rem) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.025em !important;
  color: #fff !important;
  margin: 0 0 1.25rem !important;
}

.bestof-lux .top-pick-callout h2 em {
  font-style: italic !important;
  color: var(--bl-rose-soft) !important;
}

.bestof-lux .top-pick-callout .verdict {
  font-family: var(--bl-sans) !important;
  font-size: clamp(1rem, 1.3vw, 1.1rem) !important;
  line-height: 1.65 !important;
  color: rgba(233,223,210,0.82) !important;
  max-width: 50ch !important;
  margin: 0 auto 2.5rem !important;
}

.bestof-lux .top-pick-callout .price {
  font-family: var(--bl-serif) !important;
  font-style: italic !important;
  font-size: 1.3rem !important;
  color: var(--bl-rose-soft) !important;
  margin-right: 1rem !important;
}

.bestof-lux .btn-rose-fill {
  display: inline-block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.26em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: #fff !important;
  background: var(--bl-rose) !important;
  padding: 14px 28px !important;
  border: 1px solid var(--bl-rose) !important;
  text-decoration: none !important;
  transition: background 200ms ease, border-color 200ms ease, transform 200ms ease !important;
}

.bestof-lux .btn-rose-fill:hover {
  background: var(--bl-rose-deep) !important;
  border-color: var(--bl-rose-deep) !important;
  transform: translateY(-2px) !important;
}


/* =====================================================================
   TEMPLATE A — ED SECTION + PICK GRID + PICK CARDS
   Classes: .ed-section, .sec-head, .pick-grid, .pick-card,
            .pick-image, .pick-tag, .pick-sub, .pick-meta, .star
   ===================================================================== */

.bestof-lux .ed-section {
  background: var(--bl-parch) !important;
  padding-block: clamp(3.5rem, 6vw, 6rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .sec-head {
  display: flex !important;
  align-items: baseline !important;
  gap: 1.5rem !important;
  margin-bottom: 2.5rem !important;
  padding-bottom: 1.5rem !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .sec-head h2 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(2.2rem, 4vw, 3.2rem) !important;
  letter-spacing: -0.02em !important;
  color: var(--bl-ink) !important;
  margin: 0 !important;
  line-height: 1 !important;
}

/* Pick grid */
.bestof-lux .pick-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(1.25rem, 2.5vw, 2rem) !important;
}

@media (min-width: 640px) {
  .bestof-lux .pick-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (min-width: 1080px) {
  .bestof-lux .pick-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* Pick card — the core product card for Template A */
.bestof-lux .pick-card {
  display: flex !important;
  flex-direction: column !important;
  background: var(--bl-canvas) !important;
  text-decoration: none !important;
  color: inherit !important;
  box-shadow: var(--bl-shadow-card) !important;
  transition: transform 320ms cubic-bezier(0.22,0.61,0.36,1),
              box-shadow 320ms cubic-bezier(0.22,0.61,0.36,1) !important;
  position: relative !important;
  overflow: hidden !important;
  border: 0 !important;
}

/* Rose hairline reveal on top edge */
.bestof-lux .pick-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--bl-rose);
  opacity: 0;
  transition: opacity 260ms ease;
  z-index: 2;
}

.bestof-lux .pick-card:hover::before {
  opacity: 1;
}

.bestof-lux .pick-card:hover {
  transform: translateY(-7px) !important;
  box-shadow: var(--bl-shadow-lift) !important;
}

/* Product image area */
.bestof-lux .pick-image {
  aspect-ratio: 4/5 !important;
  background-size: cover !important;
  background-position: center !important;
  overflow: hidden !important;
  transition: transform 600ms cubic-bezier(0.22,0.61,0.36,1) !important;
}

.bestof-lux .pick-card:hover .pick-image {
  transform: scale(1.04) !important;
}

/* Rank badge / pick-tag inside card — becomes small uppercase eyebrow */
.bestof-lux .pick-card .pick-tag {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.26em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  padding: 1.5rem 1.5rem 0.5rem !important;
  display: block !important;
  background: transparent !important;
  margin: 0 !important;
}

/* Card heading */
.bestof-lux .pick-card h3 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(1.35rem, 1.8vw, 1.65rem) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.015em !important;
  color: var(--bl-ink) !important;
  margin: 0 !important;
  padding: 0 1.5rem 0.75rem !important;
}

/* Card body copy */
.bestof-lux .pick-card .pick-sub {
  font-family: var(--bl-sans) !important;
  font-size: 0.9rem !important;
  line-height: 1.62 !important;
  color: var(--bl-body) !important;
  padding: 0 1.5rem !important;
  margin: 0 0 auto !important;
  flex-grow: 1 !important;
}

/* Meta row — score/price/retailer */
.bestof-lux .pick-card .pick-meta {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
  padding: 1.25rem 1.5rem !important;
  margin-top: 1rem !important;
  border-top: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .pick-card .star {
  color: var(--bl-rose) !important;
  font-size: 0.9rem !important;
}

/* First pick card — #1 hero treatment */
.bestof-lux .pick-grid > a:first-child {
  grid-column: 1 / -1 !important;
  flex-direction: row !important;
  max-height: 340px !important;
}

@media (max-width: 639px) {
  .bestof-lux .pick-grid > a:first-child {
    flex-direction: column !important;
    max-height: none !important;
  }
}

.bestof-lux .pick-grid > a:first-child .pick-image {
  width: 40% !important;
  aspect-ratio: auto !important;
  flex-shrink: 0 !important;
}

@media (max-width: 639px) {
  .bestof-lux .pick-grid > a:first-child .pick-image {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
  }
}

/* Oversized rank numeral on first card */
.bestof-lux .pick-grid > a:first-child .pick-tag::before {
  content: '01';
  font-family: var(--bl-serif) !important;
  font-size: 3.5rem !important;
  font-weight: 300 !important;
  font-style: italic !important;
  color: var(--bl-rose) !important;
  line-height: 0.9 !important;
  letter-spacing: -0.04em !important;
  display: block !important;
  margin-bottom: 0.4rem !important;
}


/* =====================================================================
   TEMPLATE A — TESTIMONIAL PULL
   ===================================================================== */

.bestof-lux .testimonial-pull {
  background: var(--bl-parch-2) !important;
  padding-block: clamp(2.5rem, 4vw, 4rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .tp-quote {
  margin: 0 !important;
  border-left: 3px solid var(--bl-rose) !important;
  padding-left: 2rem !important;
}

.bestof-lux .tp-quote p {
  font-family: var(--bl-serif) !important;
  font-style: italic !important;
  font-size: clamp(1.2rem, 1.8vw, 1.55rem) !important;
  line-height: 1.5 !important;
  color: var(--bl-ink) !important;
  margin: 0 0 0.75rem !important;
}

.bestof-lux .tp-quote footer {
  font-family: var(--bl-sans) !important;
  font-size: 11px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
}


/* =====================================================================
   TEMPLATE A — FAQ SECTION
   Classes: .faq-section, .faq-section details, .faq-section summary
   ===================================================================== */

.bestof-lux .faq-section {
  background: var(--bl-canvas) !important;
  padding-block: clamp(3.5rem, 6vw, 6rem) !important;
  border-top: 1px solid var(--bl-line-2) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .faq-section h2 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(2rem, 3.5vw, 2.8rem) !important;
  letter-spacing: -0.02em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 2.5rem !important;
}

.bestof-lux .faq-section h2 em {
  font-style: italic !important;
  color: var(--bl-rose-deep) !important;
}

.bestof-lux .faq-section details {
  border-top: 1px solid var(--bl-line-2) !important;
  padding: 1.5rem 0 !important;
}

.bestof-lux .faq-section details:last-child {
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .faq-section summary {
  font-family: var(--bl-sans) !important;
  font-weight: 500 !important;
  font-size: 1.04rem !important;
  color: var(--bl-ink) !important;
  cursor: pointer !important;
  list-style: none !important;
  position: relative !important;
  padding-right: 2.5rem !important;
  line-height: 1.4 !important;
}

.bestof-lux .faq-section summary::-webkit-details-marker { display: none; }

.bestof-lux .faq-section summary::after {
  content: '+';
  position: absolute !important;
  right: 0 !important;
  top: 0 !important;
  font-family: var(--bl-serif) !important;
  font-size: 1.5rem !important;
  line-height: 1 !important;
  color: var(--bl-rose) !important;
  font-style: normal !important;
  transition: transform 200ms ease !important;
}

.bestof-lux .faq-section details[open] summary::after {
  content: '−' !important;
}

.bestof-lux .faq-section details p {
  font-family: var(--bl-sans) !important;
  font-size: 0.97rem !important;
  line-height: 1.68 !important;
  color: var(--bl-body) !important;
  margin: 0.9rem 0 0 !important;
  max-width: 62ch !important;
}


/* =====================================================================
   TEMPLATE A — RECIPROCITY / QUIZ CARD
   ===================================================================== */

.bestof-lux .reciprocity {
  background: var(--bl-parch) !important;
  padding-block: clamp(3rem, 5vw, 5rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .rc-card {
  background: var(--bl-canvas) !important;
  border: 1px solid var(--bl-line-2) !important;
  padding: clamp(2rem, 4vw, 3.5rem) !important;
  box-shadow: var(--bl-shadow-card) !important;
  position: relative !important;
  overflow: hidden !important;
}

.bestof-lux .rc-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--bl-rose);
}

.bestof-lux .rc-label {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  font-weight: 600 !important;
  margin-bottom: 1rem !important;
  display: block !important;
}

.bestof-lux .rc-head {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
  letter-spacing: -0.02em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 0.75rem !important;
  line-height: 1.1 !important;
}

.bestof-lux .rc-head em {
  font-style: italic !important;
  color: var(--bl-rose-deep) !important;
}

.bestof-lux .rc-sub {
  font-family: var(--bl-sans) !important;
  font-size: 0.96rem !important;
  line-height: 1.65 !important;
  color: var(--bl-body) !important;
  max-width: 52ch !important;
  margin: 0 0 1.75rem !important;
}

.bestof-lux .rc-cta {
  display: inline-block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.26em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: var(--bl-ink) !important;
  padding: 13px 24px !important;
  border: 1px solid var(--bl-ink) !important;
  text-decoration: none !important;
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease !important;
}

.bestof-lux .rc-cta:hover {
  background: var(--bl-rose) !important;
  color: #fff !important;
  border-color: var(--bl-rose) !important;
}


/* =====================================================================
   TEMPLATE A — RELATED SECTION
   Classes: .related-section, .related-grid, .related-card
   ===================================================================== */

.bestof-lux .related-section {
  background: var(--bl-canvas) !important;
  padding-block: clamp(3rem, 5vw, 5rem) !important;
}

.bestof-lux .related-section h3 {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  font-weight: 600 !important;
  margin: 0 0 2rem !important;
}

.bestof-lux .related-card {
  display: block !important;
  padding: 1.4rem 1.75rem !important;
  border: 1px solid var(--bl-line-2) !important;
  font-family: var(--bl-serif) !important;
  font-style: italic !important;
  font-size: 1.2rem !important;
  font-weight: 300 !important;
  letter-spacing: -0.01em !important;
  color: var(--bl-ink) !important;
  text-decoration: none !important;
  transition: border-color 180ms ease, color 180ms ease, transform 220ms ease !important;
  position: relative !important;
}

.bestof-lux .related-card::after {
  content: '→';
  position: absolute;
  right: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--bl-sans);
  font-style: normal;
  font-size: 0.9rem;
  color: var(--bl-muted);
  transition: color 180ms ease, right 180ms ease;
}

.bestof-lux .related-card:hover {
  border-color: var(--bl-rose) !important;
  color: var(--bl-rose-deep) !important;
  transform: translateX(4px) !important;
}

.bestof-lux .related-card:hover::after {
  color: var(--bl-rose);
  right: 1.2rem;
}

/* Strip trailing arrow from link text since we provide our own */
.bestof-lux .related-card[href]::before {
  display: none;
}


/* =====================================================================
   TEMPLATE A — AFFILIATE NOTE
   ===================================================================== */

.bestof-lux .aff-note {
  font-family: var(--bl-sans) !important;
  font-size: 0.82rem !important;
  color: var(--bl-muted) !important;
  line-height: 1.5 !important;
}

.bestof-lux .aff-note a {
  color: var(--bl-muted) !important;
  border-bottom: 1px solid currentColor !important;
  text-decoration: none !important;
}

.bestof-lux .aff-note a:hover {
  color: var(--bl-rose) !important;
}


/* =====================================================================
   TEMPLATE B (gv3) — HERO
   Classes: .gv3-hero, .gv3-eyebrow, .gv3-lede, .gv3-hero-stats, .stat
   ===================================================================== */

.bestof-lux .gv3-hero {
  background: var(--bl-canvas) !important;
  padding-block: clamp(3.5rem, 7vw, 6.5rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

/* Eyebrow — wide-tracked uppercase */
.bestof-lux .gv3-eyebrow {
  display: block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.38em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  margin-bottom: 1.25rem !important;
}

/* H1 — dramatic Canela display */
.bestof-lux .gv3-hero h1 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(3rem, 6.5vw, 5.5rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.025em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 1.5rem !important;
  max-width: 22ch !important;
}

.bestof-lux .gv3-hero h1 em {
  font-style: italic !important;
  color: var(--bl-rose-deep) !important;
}

/* Lede */
.bestof-lux .gv3-lede {
  font-family: var(--bl-sans) !important;
  font-size: clamp(1.08rem, 1.5vw, 1.22rem) !important;
  line-height: 1.62 !important;
  color: var(--bl-body) !important;
  max-width: 48ch !important;
  margin: 0 0 2rem !important;
}

/* Stats row */
.bestof-lux .gv3-hero-stats {
  display: flex !important;
  gap: 1.5rem !important;
  flex-wrap: wrap !important;
  border-top: 1px solid var(--bl-line-2) !important;
  padding-top: 1.5rem !important;
  margin-top: 0.5rem !important;
}

.bestof-lux .gv3-hero-stats .stat {
  font-family: var(--bl-sans) !important;
  font-size: 11px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
}

.bestof-lux .gv3-hero-stats .stat strong {
  color: var(--bl-ink) !important;
  font-weight: 600 !important;
}


/* =====================================================================
   TEMPLATE B (gv3) — RANKED SECTION
   Classes: .gv3-ranked-sec, .gv3-section-eyebrow, .gv3-section-h2, .gv3-section-intro
   ===================================================================== */

.bestof-lux .gv3-ranked-sec {
  background: var(--bl-parch-2) !important;
  padding-block: clamp(3.5rem, 6vw, 6rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .gv3-section-eyebrow {
  display: block !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.38em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  margin-bottom: 1rem !important;
}

.bestof-lux .gv3-section-h2 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(2.2rem, 4vw, 3.4rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.022em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 1rem !important;
}

.bestof-lux .gv3-section-h2 em {
  font-style: italic !important;
  color: var(--bl-rose-deep) !important;
}

.bestof-lux .gv3-section-intro {
  font-family: var(--bl-sans) !important;
  font-size: clamp(1rem, 1.2vw, 1.08rem) !important;
  line-height: 1.68 !important;
  color: var(--bl-body) !important;
  max-width: 54ch !important;
  margin: 0 0 3rem !important;
}


/* =====================================================================
   TEMPLATE B (gv3) — CARDS GRID
   Classes: .gv3-cards, .gv3-card, .gv3-card-img, .gv3-rank, .gv3-score,
            .gv3-card-body, .gv3-card-meta, .gv3-cat, .gv3-price-pill,
            .gv3-card-h3, .gv3-card-loc, .gv3-tags, .gv3-tag, .gv3-card-why
   ===================================================================== */

.bestof-lux .gv3-cards {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(1.5rem, 2.5vw, 2rem) !important;
}

@media (min-width: 640px) {
  .bestof-lux .gv3-cards {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (min-width: 1024px) {
  .bestof-lux .gv3-cards {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* Card base */
.bestof-lux .gv3-card {
  background: var(--bl-canvas) !important;
  border: 0 !important;
  box-shadow: var(--bl-shadow-card) !important;
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform 320ms cubic-bezier(0.22,0.61,0.36,1),
              box-shadow 320ms cubic-bezier(0.22,0.61,0.36,1) !important;
}

/* Rose hairline top-edge reveal */
.bestof-lux .gv3-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--bl-rose);
  opacity: 0;
  transition: opacity 260ms ease;
  z-index: 3;
}

.bestof-lux .gv3-card:hover::before { opacity: 1; }

.bestof-lux .gv3-card:hover {
  transform: translateY(-7px) !important;
  box-shadow: var(--bl-shadow-lift) !important;
}

/* Card #1 (top pick) — spans full width + side-by-side layout */
.bestof-lux .gv3-cards > .gv3-card-1 {
  grid-column: 1 / -1 !important;
}

@media (min-width: 640px) {
  .bestof-lux .gv3-cards > .gv3-card-1 {
    flex-direction: row !important;
  }

  .bestof-lux .gv3-cards > .gv3-card-1 .gv3-card-img {
    width: 38% !important;
    aspect-ratio: auto !important;
    flex-shrink: 0 !important;
    min-height: 280px !important;
  }
}

/* Card image area */
.bestof-lux .gv3-card-img {
  aspect-ratio: 4/5 !important;
  background-size: cover !important;
  background-position: center !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform 600ms cubic-bezier(0.22,0.61,0.36,1) !important;
}

.bestof-lux .gv3-card:hover .gv3-card-img {
  transform: scale(1.04) !important;
}

/* Rank badge — oversized serif numeral */
.bestof-lux .gv3-rank {
  position: absolute !important;
  top: 1.25rem !important;
  left: 1.25rem !important;
  font-family: var(--bl-serif) !important;
  font-size: clamp(1.8rem, 3vw, 2.6rem) !important;
  font-weight: 300 !important;
  font-style: italic !important;
  color: #fff !important;
  line-height: 1 !important;
  letter-spacing: -0.04em !important;
  text-shadow: 0 1px 8px rgba(0,0,0,0.35) !important;
  z-index: 2 !important;
}

/* Score badge */
.bestof-lux .gv3-score {
  position: absolute !important;
  bottom: 1.1rem !important;
  right: 1.1rem !important;
  background: rgba(255,255,255,0.92) !important;
  color: var(--bl-ink) !important;
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  padding: 5px 10px !important;
  backdrop-filter: blur(4px) !important;
  z-index: 2 !important;
  box-shadow: 0 1px 6px rgba(0,0,0,0.15) !important;
}

/* Card body */
.bestof-lux .gv3-card-body {
  padding: clamp(1.5rem, 2.5vw, 2rem) !important;
  display: flex !important;
  flex-direction: column !important;
  flex-grow: 1 !important;
}

/* Meta row: category + price pill */
.bestof-lux .gv3-card-meta {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 0.75rem !important;
}

.bestof-lux .gv3-cat {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--bl-muted) !important;
  font-weight: 500 !important;
}

.bestof-lux .gv3-price-pill {
  font-family: var(--bl-serif) !important;
  font-style: italic !important;
  font-size: 0.95rem !important;
  color: var(--bl-ink) !important;
  background: var(--bl-parch-2) !important;
  padding: 3px 10px !important;
  border: 1px solid var(--bl-line-2) !important;
}

/* Card H3 */
.bestof-lux .gv3-card-h3 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(1.3rem, 1.7vw, 1.6rem) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.015em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 0.5rem !important;
}

/* Best-for label */
.bestof-lux .gv3-card-loc {
  font-family: var(--bl-sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--bl-rose) !important;
  font-weight: 600 !important;
  margin-bottom: 0.75rem !important;
}

/* Tags */
.bestof-lux .gv3-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.4rem !important;
  margin-bottom: 0.85rem !important;
}

.bestof-lux .gv3-tag {
  font-family: var(--bl-sans) !important;
  font-size: 9px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  padding: 3px 9px !important;
  border: 1px solid !important;
}

.bestof-lux .gv3-tag.tag-top {
  color: var(--bl-rose) !important;
  border-color: var(--bl-rose) !important;
  background: var(--bl-rose-soft) !important;
}

.bestof-lux .gv3-tag.tag-verified {
  color: var(--bl-ink) !important;
  border-color: var(--bl-line-2) !important;
  background: var(--bl-parch) !important;
}

.bestof-lux .gv3-tag.tag-value {
  color: #4a7c59 !important;
  border-color: rgba(74,124,89,0.4) !important;
  background: rgba(74,124,89,0.07) !important;
}

.bestof-lux .gv3-tag.tag-beginners {
  color: #4a6b8a !important;
  border-color: rgba(74,107,138,0.4) !important;
  background: rgba(74,107,138,0.07) !important;
}

.bestof-lux .gv3-tag.tag-luxury {
  color: var(--bl-rose-deep) !important;
  border-color: rgba(162,55,69,0.35) !important;
  background: var(--bl-rose-soft) !important;
}

/* Card copy */
.bestof-lux .gv3-card-why {
  font-family: var(--bl-sans) !important;
  font-size: 0.9rem !important;
  line-height: 1.65 !important;
  color: var(--bl-body) !important;
  margin: auto 0 0 !important;
  padding-top: 0.75rem !important;
  border-top: 1px solid var(--bl-line) !important;
  flex-grow: 1 !important;
}


/* =====================================================================
   TEMPLATE B (gv3) — FAQ SECTION
   Classes: .gv3-faq-sec, .gv3-faq, details, summary
   ===================================================================== */

.bestof-lux .gv3-faq-sec {
  background: var(--bl-parch) !important;
  padding-block: clamp(3.5rem, 6vw, 6rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .gv3-faq-sec .gv3-section-h2 {
  margin-bottom: 2rem !important;
}

.bestof-lux .gv3-faq details {
  border-top: 1px solid var(--bl-line-2) !important;
  padding: 1.5rem 0 !important;
}

.bestof-lux .gv3-faq details:last-child {
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .gv3-faq summary {
  font-family: var(--bl-sans) !important;
  font-weight: 500 !important;
  font-size: 1.04rem !important;
  color: var(--bl-ink) !important;
  cursor: pointer !important;
  list-style: none !important;
  position: relative !important;
  padding-right: 2.5rem !important;
  line-height: 1.4 !important;
}

.bestof-lux .gv3-faq summary::-webkit-details-marker { display: none; }

.bestof-lux .gv3-faq summary::after {
  content: '+' !important;
  position: absolute !important;
  right: 0 !important;
  top: 0 !important;
  font-family: var(--bl-serif) !important;
  font-size: 1.5rem !important;
  line-height: 1 !important;
  color: var(--bl-rose) !important;
  transition: transform 200ms ease !important;
}

.bestof-lux .gv3-faq details[open] summary::after {
  content: '−' !important;
}

.bestof-lux .gv3-faq details p {
  font-family: var(--bl-sans) !important;
  font-size: 0.97rem !important;
  line-height: 1.68 !important;
  color: var(--bl-body) !important;
  margin: 0.9rem 0 0 !important;
  max-width: 62ch !important;
}


/* =====================================================================
   TEMPLATE B (gv3) — SEO BLOCK
   Classes: .gv3-seo-block, .gv3-seo-h2
   ===================================================================== */

.bestof-lux .gv3-seo-block {
  background: var(--bl-canvas) !important;
  padding-block: clamp(3rem, 5vw, 5rem) !important;
  border-bottom: 1px solid var(--bl-line-2) !important;
}

.bestof-lux .gv3-seo-h2 {
  font-family: var(--bl-serif) !important;
  font-weight: 300 !important;
  font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
  letter-spacing: -0.018em !important;
  color: var(--bl-ink) !important;
  margin: 0 0 1.25rem !important;
}

.bestof-lux .gv3-seo-block p {
  font-family: var(--bl-sans) !important;
  font-size: 0.97rem !important;
  line-height: 1.68 !important;
  color: var(--bl-body) !important;
  max-width: 58ch !important;
}

.bestof-lux .gv3-seo-block a {
  color: var(--bl-rose-deep) !important;
  text-decoration: none !important;
  border-bottom: 1px solid currentColor !important;
  transition: color 180ms ease !important;
}

.bestof-lux .gv3-seo-block a:hover {
  color: var(--bl-rose) !important;
}


/* =====================================================================
   SCROLL REVEAL
   Only animates on devices with no reduced-motion preference.
   Applied to cards and key sections.
   ===================================================================== */

@media (prefers-reduced-motion: no-preference) {
  .bestof-lux .pick-card,
  .bestof-lux .gv3-card,
  .bestof-lux .related-card,
  .bestof-lux .ai-for li,
  .bestof-lux .tc-stat,
  .bestof-lux .rc-card {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 480ms ease, transform 480ms cubic-bezier(0.22,0.61,0.36,1),
                box-shadow 320ms cubic-bezier(0.22,0.61,0.36,1) !important;
  }

  .bestof-lux .pick-card.bl-revealed,
  .bestof-lux .gv3-card.bl-revealed,
  .bestof-lux .related-card.bl-revealed,
  .bestof-lux .ai-for li.bl-revealed,
  .bestof-lux .tc-stat.bl-revealed,
  .bestof-lux .rc-card.bl-revealed {
    opacity: 1;
    transform: translateY(0);
  }

  /* Stagger siblings */
  .bestof-lux .pick-card:nth-child(2),
  .bestof-lux .gv3-card:nth-child(2) { transition-delay: 80ms !important; }
  .bestof-lux .pick-card:nth-child(3),
  .bestof-lux .gv3-card:nth-child(3) { transition-delay: 160ms !important; }
  .bestof-lux .pick-card:nth-child(4),
  .bestof-lux .gv3-card:nth-child(4) { transition-delay: 240ms !important; }
  .bestof-lux .pick-card:nth-child(5),
  .bestof-lux .gv3-card:nth-child(5) { transition-delay: 320ms !important; }
  .bestof-lux .pick-card:nth-child(6),
  .bestof-lux .gv3-card:nth-child(6) { transition-delay: 400ms !important; }
}


/* =====================================================================
   MOBILE OVERRIDES
   ===================================================================== */

@media (max-width: 639px) {
  /* Breadcrumb wraps cleanly */
  .bestof-lux .breadcrumb,
  .bestof-lux nav.breadcrumb {
    font-size: 9px !important;
    letter-spacing: 0.2em !important;
  }

  /* Author byline stacks */
  .bestof-lux .ab-card {
    flex-wrap: wrap !important;
    gap: 0.75rem !important;
  }

  .bestof-lux .ab-date {
    margin-left: 0 !important;
    text-align: left !important;
    width: 100% !important;
  }

  /* Table scrolls horizontally */
  .bestof-lux .comparison-table-wrap .wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Hero H1 tighter on mobile */
  .bestof-lux .review-hero h1,
  .bestof-lux .gv3-hero h1 {
    font-size: clamp(2.4rem, 10vw, 3.2rem) !important;
  }

  /* Stats wrap more tightly */
  .bestof-lux .gv3-hero-stats {
    gap: 1rem !important;
  }

  /* Pick-grid first card: stack on mobile */
  .bestof-lux .pick-grid > a:first-child {
    max-height: none !important;
  }
}
