/**
 * Buddha Mind — каталог, карточки товаров, категория, страница товара.
 * Только CSS: без изменения логики корзины, фильтров, кнопок и данных.
 */

:root {
  --bm-cpu-radius-card: 16px;
  --bm-cpu-radius-img: 14px;
  --bm-cpu-gap: 24px;
  --bm-cpu-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --bm-cpu-dur: 0.22s;
}

/* ══════════════════════════════════════════
   1. Карточки товаров — общие (каталог + модули)
   ══════════════════════════════════════════ */
.product-grid .product-thumb.uni-item,
.uni-module .product-grid .product-thumb.uni-item,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb.uni-item {
  border-radius: var(--bm-cpu-radius-card) !important;
  border: 1px solid rgba(230, 223, 208, 0.85) !important;
  background: var(--color-bg, #fff) !important;
  box-shadow: 0 2px 12px rgba(20, 24, 42, 0.04) !important;
  overflow: hidden !important;
  transition:
    transform var(--bm-cpu-dur) var(--bm-cpu-ease),
    box-shadow var(--bm-cpu-dur) var(--bm-cpu-ease),
    border-color var(--bm-cpu-dur) var(--bm-cpu-ease) !important;
}

@media (hover: hover) and (pointer: fine) {
  .product-grid .product-thumb.uni-item:hover,
  .uni-module .product-grid .product-thumb.uni-item:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 12px 28px rgba(20, 24, 42, 0.1) !important;
    border-color: rgba(193, 154, 75, 0.35) !important;
  }
}

/* Image area */
.product-grid .product-thumb__image,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb__image {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  aspect-ratio: 1 / 1 !important;
  min-height: 0 !important;
  padding: 0 !important;
  background: var(--color-bg-card-tint, #f8f5ef) !important;
  border-bottom: 0 !important;
  box-sizing: border-box !important;
}

.product-grid .product-thumb__image img {
  width: 100% !important;
  height: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  border-radius: var(--bm-cpu-radius-img) !important;
}

.product-grid .product-thumb__caption {
  padding: 14px 14px 16px !important;
  gap: 8px !important;
  flex: 1 1 auto !important;
}

/* Название */
.product-grid .product-thumb__name,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb__name {
  font-family: var(--bm-sans, "Manrope", ui-sans-serif, system-ui, sans-serif) !important;
  font-style: normal !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  color: var(--color-primary, #14182a) !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  min-height: calc(1.4em * 2) !important;
  max-height: calc(1.4em * 2) !important;
  margin: 0 !important;
}

/* Цена */
.product-grid .product-thumb__price,
.product-grid .product-thumb__price.price,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb__price,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb__price.price {
  font-size: 19px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  color: var(--color-primary, #14182a) !important;
  margin: 4px 0 0 !important;
}

.product-grid .product-thumb__price .price-old {
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--color-text-muted, #6b6e80) !important;
}

.product-grid .product-thumb__price .price-new {
  font-weight: 700 !important;
  color: var(--color-sale, #a44a2a) !important;
}

/* Кнопки */
.product-grid .product-thumb__cart {
  display: flex !important;
  align-items: stretch !important;
  gap: 8px !important;
  margin-top: auto !important;
  padding-top: 10px !important;
}

.product-grid .product-thumb .product-thumb__add-to-cart,
.product-grid .product-thumb .product-thumb__add-to-cart.btn,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb__add-to-cart {
  flex: 1 1 auto !important;
  height: 42px !important;
  min-height: 42px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

.product-grid .product-thumb .product-thumb__quick-order,
#product-category .products-block:not(.is-list-table) .product-grid .product-thumb__quick-order {
  flex: 0 0 40px !important;
  width: 40px !important;
  min-width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  border: 1px solid var(--color-border, #e6dfd0) !important;
  background: var(--color-bg-warm, #f5f1e8) !important;
  color: var(--color-gold-deep, #8c6a3b) !important;
  opacity: 0.92;
}

.product-grid .product-thumb .product-thumb__quick-order:hover {
  border-color: var(--color-gold, #c19a4b) !important;
  background: rgba(193, 154, 75, 0.1) !important;
  opacity: 1;
}

.product-grid .product-thumb .product-thumb__quick-order i {
  font-size: 14px !important;
}

/* Бейдж «Новинка» / стикеры */
.product-grid .product-thumb .sticker__item,
.product-grid .product-thumb .uni-sticker {
  border-radius: 999px !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  padding: 4px 10px !important;
}

/* ══════════════════════════════════════════
   2. Сетка категории — gaps и колонки
   ══════════════════════════════════════════ */
#product-category .products-block:not(.is-list-table) .product-grid {
  row-gap: var(--bm-cpu-gap) !important;
}

@media (min-width: 992px) {
  #product-category .products-block:not(.is-list-table) .product-grid {
    row-gap: 28px !important;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  #product-category .products-block:not(.is-list-table) .product-grid {
    row-gap: 20px !important;
  }
}

/* 1 колонка на очень узких экранах */
@media (max-width: 360px) {
  #product-category .products-block:not(.is-list-table) .product-grid > [class*="col-"] {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
    float: none !important;
  }

  #product-category .products-block:not(.is-list-table) .product-grid .product-thumb__name {
    -webkit-line-clamp: 3 !important;
    min-height: calc(1.38em * 2) !important;
    max-height: calc(1.38em * 3) !important;
  }
}

@media (min-width: 361px) and (max-width: 767px) {
  #product-category .products-block:not(.is-list-table) .product-grid .product-thumb__name {
    -webkit-line-clamp: 2 !important;
    font-size: 13px !important;
  }

  .product-grid .product-thumb__price,
  #product-category .products-block:not(.is-list-table) .product-grid .product-thumb__price {
    font-size: 18px !important;
  }

  .product-grid .product-thumb .product-thumb__add-to-cart,
  .product-grid .product-thumb .product-thumb__quick-order {
    height: 40px !important;
    min-height: 40px !important;
  }

  .product-grid .product-thumb .product-thumb__quick-order {
    flex: 0 0 38px !important;
    width: 38px !important;
    min-width: 38px !important;
  }
}

/* ══════════════════════════════════════════
   3. Страница категории — breadcrumbs, toolbar, подкатегории
   ══════════════════════════════════════════ */
#product-category .breadcrumb-h1 .breadcrumb,
#product-category .bm-category-head .breadcrumb {
  font-size: 12px !important;
  line-height: 1.45 !important;
  color: var(--color-text-muted, #6b6e80) !important;
  margin-bottom: 10px !important;
}

#product-category .breadcrumb-h1 .breadcrumb li,
#product-category .bm-category-head .breadcrumb li {
  color: inherit;
}

#product-category .breadcrumb-h1 .breadcrumb a {
  color: var(--color-text-muted, #6b6e80) !important;
}

#product-category .breadcrumb-h1 .breadcrumb a:hover {
  color: var(--color-gold, #c19a4b) !important;
}

#product-category .bm-category-head__row h1 {
  font-size: clamp(26px, 3vw, 40px) !important;
  line-height: 1.15 !important;
}

#product-category .bm-category-head__row h1::after {
  width: 56px !important;
  height: 2px !important;
}

#product-category .bm-category-toolbar .sorts-block__limit,
.bm-cat-mobile-bar__select {
  min-height: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  padding: 0 16px !important;
  font-size: 13px !important;
  border-color: var(--color-border, #e6dfd0) !important;
  background: #fff !important;
  color: var(--color-primary, #14182a) !important;
}

.bm-cat-mobile-bar__btn {
  min-height: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  background: var(--color-primary, #14182a) !important;
  border-color: var(--color-primary, #14182a) !important;
  color: var(--color-on-primary, #f5f1e8) !important;
}

.bm-cat-mobile-bar__btn i {
  color: inherit !important;
}

.bm-subcat-carousel__name {
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: var(--color-primary, #14182a) !important;
  font-family: var(--bm-sans, "Manrope", sans-serif) !important;
}

.bm-subcat-carousel__img-wrap {
  width: 72px !important;
  height: 72px !important;
}

.bm-subcat-carousel__img-wrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

@media (max-width: 767px) {
  .bm-subcat-carousel {
    padding-left: 12px !important;
    padding-right: 12px !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .bm-subcat-carousel::-webkit-scrollbar {
    display: none;
  }

  .bm-subcat-carousel__name {
    font-size: 11px !important;
    min-height: 2.7em;
  }
}

/* ══════════════════════════════════════════
   4. Страница товара — layout, gallery, buy block
   ══════════════════════════════════════════ */
.product-layout__card {
  border-radius: var(--bm-cpu-radius-card) !important;
  border-color: rgba(230, 223, 208, 0.9) !important;
  box-shadow: 0 2px 14px rgba(20, 24, 42, 0.05) !important;
}

.product-layout__title {
  line-height: 1.3 !important;
  color: var(--color-primary, #14182a) !important;
}

@media (max-width: 767px) {
  .product-layout__title {
    font-size: clamp(22px, 5.5vw, 26px) !important;
    line-height: 1.28 !important;
    margin-bottom: 14px !important;
  }

  .product-layout__card--gallery .product-page__image-main-img {
    max-height: min(48vh, 360px) !important;
    width: auto !important;
    margin: 0 auto !important;
    display: block !important;
    border-radius: var(--bm-cpu-radius-img) !important;
  }

  .product-layout__card--gallery {
    padding: 14px !important;
  }

  .product-layout__card--gallery .product-page__image-main {
    margin-bottom: 10px !important;
  }
}

@media (min-width: 992px) {
  .product-layout__title {
    font-size: clamp(24px, 2.4vw, 32px) !important;
  }
}

/* Характеристики */
.product-layout__card--summary .product-data__item,
.product-data--summary .product-data__item {
  padding: 11px 0 !important;
  border-bottom-color: rgba(230, 223, 208, 0.65) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.product-layout__card--summary .product-data__item-div:first-child,
.product-data--summary .product-data__item .product-data__item-div:first-child {
  color: var(--color-text-muted, #6b6e80) !important;
  font-weight: 400 !important;
}

.product-layout__card--summary .product-data__value,
.product-data--summary .product-data__value {
  color: var(--color-primary, #14182a) !important;
  font-weight: 500 !important;
}

.product-layout__card--summary .product-data__item.stock .product-data__value,
.product-data--summary .product-data__item.stock .product-data__value {
  color: var(--color-success, #2d9a56) !important;
  font-weight: 600 !important;
}

/* Цена и CTA */
.product-block--buy .product-page__price {
  font-weight: 600 !important;
  color: var(--color-primary, #14182a) !important;
}

@media (max-width: 767px) {
  .product-block--buy .product-page__price {
    font-size: clamp(24px, 6.5vw, 28px) !important;
    font-weight: 700 !important;
  }
}

@media (min-width: 992px) {
  .product-block--buy .product-page__price {
    font-size: clamp(26px, 2.2vw, 32px) !important;
    font-weight: 700 !important;
  }
}

.product-block--buy .product-page__cart .qty-switch {
  border-radius: 14px !important;
  height: 48px !important;
  min-height: 48px !important;
  border-color: var(--color-border, #e6dfd0) !important;
}

.product-block--buy .product-page__add-to-cart {
  height: 50px !important;
  min-height: 50px !important;
  border-radius: 999px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  background: var(--color-primary, #14182a) !important;
  color: var(--color-on-primary, #f5f1e8) !important;
}

.product-block--buy .product-page__quick-order {
  height: 46px !important;
  min-height: 46px !important;
  border-radius: 14px !important;
  border: 1.5px solid var(--color-gold, #c19a4b) !important;
  color: var(--color-gold-deep, #8c6a3b) !important;
  background: transparent !important;
  font-weight: 500 !important;
}

.product-block--buy .product-page__quick-order:hover {
  background: rgba(193, 154, 75, 0.08) !important;
}

/* Tabs */
.product-layout__card--tabs .product-page-tabs {
  border-bottom: 1px solid rgba(230, 223, 208, 0.8) !important;
  gap: 4px;
}

.product-layout__card--tabs .product-page-tabs > li > a {
  font-family: var(--bm-sans, "Manrope", sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--color-text-muted, #6b6e80) !important;
  border-bottom: 2px solid transparent !important;
  padding: 14px 16px !important;
  transition: color var(--bm-cpu-dur) var(--bm-cpu-ease), border-color var(--bm-cpu-dur) var(--bm-cpu-ease) !important;
}

.product-layout__card--tabs .product-page-tabs > li.active > a,
.product-layout__card--tabs .product-page-tabs > li > a:hover {
  color: var(--color-primary, #14182a) !important;
  border-bottom-color: var(--color-gold, #c19a4b) !important;
  background: transparent !important;
}

.product-layout__card--tabs .tab-content {
  padding: 24px 24px 28px !important;
}

.product-layout__card--tabs #tab-description {
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: var(--color-text, #14182a) !important;
}

/* SEO-теги */
.product-tag {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 20px 0 8px !important;
  padding: 16px 0 0 !important;
  border-top: 1px solid rgba(230, 223, 208, 0.7) !important;
  max-height: none;
}

.product-tag__item {
  display: inline-flex !important;
  align-items: center !important;
  padding: 6px 12px !important;
  font-family: var(--bm-sans, "Manrope", sans-serif) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  color: var(--color-primary, #14182a) !important;
  background: var(--color-bg-warm, #f5f1e8) !important;
  border: 1px solid rgba(230, 223, 208, 0.9) !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  transition:
    background var(--bm-cpu-dur) var(--bm-cpu-ease),
    border-color var(--bm-cpu-dur) var(--bm-cpu-ease),
    color var(--bm-cpu-dur) var(--bm-cpu-ease) !important;
}

.product-tag__item:hover {
  color: var(--color-gold-deep, #8c6a3b) !important;
  border-color: rgba(193, 154, 75, 0.45) !important;
  background: rgba(193, 154, 75, 0.1) !important;
  text-decoration: none !important;
}

/* Похожие товары — наследуют стили product-grid выше */
#product .uni-module .product-grid .product-thumb.uni-item,
.uni-module__wrapper .product-grid .product-thumb.uni-item {
  border-radius: var(--bm-cpu-radius-card) !important;
}

@media (prefers-reduced-motion: reduce) {
  .product-grid .product-thumb.uni-item,
  .product-tag__item,
  .product-layout__card--tabs .product-page-tabs > li > a {
    transition: none !important;
  }
}
