/* секция категорий */
.catalog-cats{ padding: clamp(60px, 8vw, 100px) 24px; }
.catalog-cats__container{ max-width: 1200px; margin: 0 auto; }
.catalog-cats__title{ font-size: clamp(28px,4vw,64px); margin: 0 0 16px; }

.cats-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(14px, 2.4vw, 24px);
}
@media (max-width: 1100px){ .cats-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 780px){ .cats-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .cats-grid{ grid-template-columns: 1fr; } }

/* карточка категории (стеклянная, как на макете) */
.cat-card{
  position: relative;
  border-radius: 26px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 22px 60px rgba(0,0,0,.28);
  backdrop-filter: blur(16px) saturate(120%);
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  overflow: hidden;
  display: grid;
  grid-template-rows: 1fr auto;
  min-height: 460px;
}
.cat-card::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(rgba(0,0,0,.38), rgba(0,0,0,.28)),
    url("../../images/bg-dark.png") center/cover no-repeat;
  filter: blur(2px);
  z-index:0;
}
.cat-card__media{ position: relative; z-index:1; display:grid; place-items:center; padding: 22px; }
.cat-card__media img{ width: 88%; height: auto; display:block; object-fit: contain; }

.cat-card__body{
  position: relative; z-index:2;
  display:grid; gap:12px; padding: 16px;
  color:#fff;
  background: linear-gradient(transparent, rgba(0,0,0,.15));
}
.cat-card__title{ margin:0; font-weight:700; font-size: clamp(16px,1.6vw,20px); min-height: 3em; }
.cat-card__btn{
  height: 48px; border-radius: 16px; border: 0;
  font-weight: 700; background: #fff; color:#000;
  font-family: var(--font-ui);
  box-shadow: 0 10px 22px rgba(0,0,0,.25);
  cursor: pointer; transition: transform .2s, box-shadow .2s;
}
.cat-card__btn:hover{ transform: translateY(-1px); box-shadow: 0 14px 28px rgba(0,0,0,.3); }

/* секция результатов */
.catalog-results{ padding: clamp(28px, 4vw, 44px) 24px clamp(60px, 8vw, 100px); }
.catalog-results__container{ max-width: 1200px; margin: 0 auto; }

.catalog-results[hidden]{ display:none; }
.catalog-results.is-open{ animation: slideUp .45s ease both; }

.results-head{ display: grid; gap: 14px; margin-bottom: 16px; }
.results-title{ font-size: clamp(22px, 3vw, 36px); margin: 0; color:#000; }

/* фильтры */
.filters{
  display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center;
}
.filter__search input{
  width: 100%; height: 46px; border-radius: 12px; border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06); color:#000; padding: 0 14px;
}
.filter__chips{ display:flex; flex-wrap:wrap; gap:8px; grid-column: 1 / -1; }
.filter__right{ display:flex; gap:8px; justify-self: end; }
#filterSort{
  height: 46px; border-radius: 12px; border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06); color:#fff; padding: 0 12px;
}
.btn-reset{
  height: 46px; border-radius: 12px; border:1px solid rgba(255,255,255,.22);
  background: transparent; color:#000; padding: 0 12px; cursor: pointer;
}
.chip{
  display:inline-flex; align-items:center; gap:8px; padding:8px 12px;
  border-radius: 999px; background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.16); color:#000; cursor:pointer;
  transition: background .2s, border-color .2s;
}
.chip.is-active{ background:#000; color:#fff; border-color: #fff; }

/* сетка товаров */
.products-grid{
  display:grid; gap: clamp(12px, 2vw, 20px);
  grid-template-columns: repeat(3, 1fr);
  margin-top: 10px;
}
@media (max-width: 980px){ .products-grid{ grid-template-columns: repeat(2, 1fr);} }
@media (max-width: 560px){ .products-grid{ grid-template-columns: 1fr; } }

/* сетка оставь как есть; ниже только карточка */
.product{
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 8px;

  background: #fff;
  color: #111;
  border-radius: 26px;
  border: 1.5px solid rgba(0,0,0,.12);
  padding: 14px;

  box-shadow: 0 6px 20px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.product:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
  border-color: rgba(0,0,0,.18);
}

/* большое квадратное превью со скруглением как на макете */
.product__media{
  aspect-ratio: 1 / 1;
  border-radius: 22px;
  overflow: hidden;
  background: radial-gradient(120% 120% at 30% 20%, #3a3a3a, #191b1f);
  border: 1px solid rgba(0,0,0,.08);
}
.product__media img{
  width: 100%; height: 100%; object-fit: cover; display: block;
  transform: scale(1.02);
}

/* текст */
.product__body{ padding: 2px 2px 10px; }
.product__title{
  margin: 6px 46px 0 0;               /* справа место под кнопку */
  font-weight: 700;
  font-size: 16px;
  line-height: 1.15;
  color: #111;
}
.product__tags{
  display: none;                       /* в макете не видно тегов — убрал; вернёшь при необходимости */
}
.product__price{
  margin-top: 6px;
  font-weight: 800;
  font-size: 16px;
  color: #111;
}

/* круглая кнопка со стрелкой в углу */
.product__cta{
  position: absolute;
  right: 12px; bottom: 12px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid rgba(0,0,0,.24);
  display: grid; place-items: center;
  box-shadow: 0 6px 12px rgba(0,0,0,.10);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.product__cta:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(0,0,0,.14);
}
.product__cta svg{
  width: 18px; height: 18px;
  color: #111;
}

/* цвет текста в футере результатов под белые карточки */
.results-foot{ margin-top: 10px; color: rgba(0,0,0,.6); }

/* шапка результатов: заголовок + кнопка в одну линию */
.results-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  min-height: 46px;            /* под высоту кнопки */
}

/* заголовок ужимается и обрезается "..." */
.results-title{
  flex: 1 1 auto;
  min-width: 0;                /* важно для ellipsis во flex-контейнере */
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* сама кнопка — неизменной ширины, не сжимается */
.btn-filter-search{
  flex: 0 0 auto;
  height: 46px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.12);     /* под белые карточки можно затемнить бордер */
  background: #fff;
  color: #000;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(0,0,0,.12);
  transition: transform .2s, box-shadow .2s, background .2s, color .2s;
}
.btn-filter-search:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(0,0,0,.2);
}

/* экстрамалые — слегка ужимаем, но всё равно в одну строку */
@media (max-width: 400px){
  .results-title{ font-size: clamp(18px, 4.8vw, 20px); }
  .btn-filter-search{ height: 42px; padding: 0 10px; }
}

.btn-reset-search{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.18);
  background: #fff;
  color: #000;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
  transition: transform .2s, box-shadow .2s;
}
.btn-reset-search:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,.12);
}


/* ускорим рендер анимации карточек */
.catalog-results, .products-grid, .product { will-change: transform, opacity; }
/* защита от случайных глобальных правил */
/* безопасная страховка: только когда нет inline-стилей */
#productsGrid .product:not([style]) { opacity: 1; transform: none; }


@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
