/* =================== hc-bestsellers.css =================== */
/* hc-bestsellers — home "Популярное у мебельщиков" unified product showcase
 * (Хиты · Новинки · Со скидкой · Товар дня · Для вас). Left column is a
 * branded promo card (one of 4 palettes), right column is a 3-col rail of
 * .pcard mini cards. Strictly .hc-bestsellers / .hc-bestsellers__*.
 *
 * Previous file had every promo rule wrapped in @media(max-width:1024px),
 * leaving the promo card on desktop completely unstyled (no gradient bg,
 * no body layout, no bgfx). This rewrite places all base rules outside the
 * media-query and uses @media only for responsive breakpoints. */

.hc-bestsellers__tabs {
display: flex;
  flex-wrap: wrap;
  gap: var(--hc-sp-1, 6px);
  margin-bottom: var(--hc-sp-4, 20px);
}

/* base grid: promo (left) + product rail (right) */
.hc-bestsellers__grid {
display: grid;
  grid-template-columns: minmax(300px, 0.82fr) minmax(0, 2.18fr);
  gap: clamp(14px, 1.4vw, 20px);
  align-items: stretch;
  margin-top: var(--hc-sp-4, 20px);
}

/* promo card — editorial card on the left of each tab */
.hc-bestsellers__promo {
position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: clamp(300px, 24vw, 360px);
  padding: clamp(28px, 2.6vw, 36px) clamp(24px, 2.4vw, 32px);
  border-radius: clamp(18px, 1.6vw, 22px);
  overflow: hidden;
  text-decoration: none;
  border: 1px solid rgba(180, 151, 115, 0.22);
  box-shadow:
    0 1px 2px rgba(40, 30, 15, 0.04),
    0 24px 56px -28px rgba(40, 30, 15, 0.22);
  transition:
    transform 0.38s cubic-bezier(0.16, 0.84, 0.32, 1),
    box-shadow 0.38s ease;
  isolation: isolate;
}
.hc-bestsellers__promo::after {
  content: "BLUM";
  position: absolute;
  top: clamp(24px, 2.4vw, 34px);
  left: clamp(24px, 2.4vw, 32px);
  z-index: 1;
  font-family: var(--hc-mono, "JetBrains Mono", monospace);
  font-size: clamp(28px, 3.8vw, 54px);
  font-weight: 500;
  letter-spacing: 0.24em;
  color: currentColor;
  opacity: 0.2;
  pointer-events: none;
}
.hc-bestsellers__promo:hover {
transform: translateY(-4px);
  box-shadow:
    0 2px 4px rgba(40, 30, 15, 0.05),
    0 34px 70px -28px rgba(80, 60, 40, 0.32);
}

/* 4 palettes — keyed to each tab (featured/new/sale/day) */
.hc-bestsellers__promo--a {
background: linear-gradient(155deg, #f3ead7 0%, #e0d0a8 100%);
  color: #5a4520;
}
.hc-bestsellers__promo--b {
background: linear-gradient(155deg, #e8eef0 0%, #b8c8d0 100%);
  color: #2a3a48;
}
.hc-bestsellers__promo--c {
background: linear-gradient(155deg, #f0e3da 0%, #d4b8a0 100%);
  color: #5a3820;
}
.hc-bestsellers__promo--d {
background: linear-gradient(155deg, #e6e2da 0%, #c0b8a8 100%);
  color: #3a3528;
}

.hc-bestsellers__promo-bgfx {
position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  color: inherit;
  opacity: 0.6;
}
.hc-bestsellers__promo-bgfx svg {
width: 100%;
  height: 100%;
}

.hc-bestsellers__promo-body {
position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.hc-bestsellers__promo-eyebrow {
font-family: var(--hc-mono, "JetBrains Mono", monospace);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.78;
}
.hc-bestsellers__promo-title {
margin: 0;
  font-family: var(--hc-serif, "Playfair Display", Georgia, serif);
  font-size: clamp(26px, 2.6vw, 38px);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.012em;
}
.hc-bestsellers__promo-lede {
margin: 0;
  font-size: 15px;
  line-height: 1.55;
  opacity: 0.78;
  max-width: 36ch;
}
.hc-bestsellers__promo-cta {
display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  padding: 10px 18px;
  background: rgba(255, 255, 255, 0.62);
  border: 0.5px solid currentColor;
  border-radius: var(--hc-r-pill, 999px);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  align-self: flex-start;
  transition: background 0.22s ease, transform 0.22s ease;
}


/* product rail — 4-col grid of pcards */
.hc-bestsellers__rail {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  grid-template-rows: auto;
  grid-auto-rows: 0;
  gap: clamp(12px, 1.2vw, 16px);
  align-items: stretch;
  overflow: hidden;
}

.hc-bestsellers__recs {
margin-top: var(--hc-sp-4, 20px);
  min-height: 160px;
}

@media (max-width: 1440px) {
  .hc-bestsellers__grid { grid-template-columns: 1fr; }
  .hc-bestsellers__promo { min-height: 320px; }
}
/* rail columns are width-driven (single-row auto-flow, see base rule) */
/* v8.6 — на phone (<=560px) bestsellers — горизонтальный scroll-snap rail.
   Не вертикальный 1-col stack — компактнее и видны 1.2 карты сразу как
   подсказка свайпа. */
@media (max-width: 480px) {
  .hc-bestsellers__rail {
    grid-template-columns: none;
    display: flex;
    gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: 16px;
    padding: 4px 16px 16px;
    margin: 0 -16px;
    scrollbar-width: none;
  }
  .hc-bestsellers__rail::-webkit-scrollbar { display: none; }
  .hc-bestsellers__rail > * {
    flex: 0 0 82%;
    scroll-snap-align: start;
  }
}

.hc-bestsellers__promo:hover .hc-bestsellers__promo-cta {
background: rgba(255, 255, 255, 0.92);
  transform: translateX(2px);
}

.hc-bestsellers__recs .hc-text-center {
  text-align: center;
  padding: 40px 0;
}
