/* Универсальная сетка категорий с изображениями
   Цель:
   - аккуратно на мобиле
   - шрифт чуть крупнее и заметнее
   - "белая полоска снизу" не появляется, когда слева заголовок в 2 строки
   - однострочные НЕ становятся "как двухстрочные"
   - для главной страницы даём более выразительный контраст
*/

.cat-grid-visual{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin: 4px 0 8px;
  align-items: stretch;
}

@media (min-width: 768px){
  .cat-grid-visual{
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin: 12px 0 8px;
  }
}

/* Карточка */
.cat-card{
  display: flex;
  flex-direction: column;
  text-decoration: none;

  background: #fff;
  border-radius: 14px;
  overflow: hidden;

  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 6px 14px rgba(0,0,0,.05);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;

  height: 100%;
}

.cat-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
  border-color: rgba(79,106,95,.35);
}

/* Зона картинки */
.cat-card__img{
  background: #fff;
  padding: 12px 12px 8px;

  display: flex;
  align-items: center;
  justify-content: center;

  flex: 1 1 auto;
}

/* Внутренняя рамка картинки */
.cat-card__img-inner{
  display: flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  height: 128px;
}

/* Картинка */
.cat-card__img img{
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

/* Плашка заголовка */
.cat-card__title{
  margin: 0;
  padding: 12px 10px;

  display: flex;
  align-items: center;
  justify-content: center;

  background: #4f6a5f;
  color: #fff;

  font-weight: 800;
  font-size: 14px;
  line-height: 1.2;
  text-align: center;
  letter-spacing: -0.01em;

  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

/* Для длинных названий */
.cat-card.is-2l .cat-card__title{
  padding-top: 13px;
  padding-bottom: 13px;
}

/* Десктоп */
@media (min-width: 768px){
  .cat-card__img{
    padding: 14px 14px 10px;
  }

  .cat-card__img-inner{
    height: 136px;
  }

  .cat-card__title{
    padding: 13px 12px;
    font-size: 15px;
    line-height: 1.2;
  }

  .cat-card.is-2l .cat-card__title{
    padding-top: 14px;
    padding-bottom: 14px;
  }
}

/* Мелкие экраны */
@media (max-width: 380px){
  .cat-card__img{
    padding: 10px 10px 6px;
  }

  .cat-card__img-inner{
    height: 112px;
  }

  .cat-card__title{
    padding: 10px 8px;
    font-size: 13px;
    line-height: 1.18;
  }

  .cat-card.is-2l .cat-card__title{
    padding-top: 11px;
    padding-bottom: 11px;
  }
}

/* =========================================================
   HOME context
   На главной делаем карточки чуть выразительнее:
   - чуть теплее фон карточки
   - заметнее граница
   - глубже тень
   - заголовок контрастнее
   ========================================================= */

.cat-grid-visual--home{
  margin-top: 2px;
}

.cat-grid-visual--home .cat-card{
  background: linear-gradient(180deg, #ffffff 0%, #fcfcfb 100%);
  border-color: rgba(56, 73, 66, .11);
  box-shadow:
    0 10px 24px rgba(24, 30, 27, .06),
    0 1px 0 rgba(255,255,255,.9) inset;
}

.cat-grid-visual--home .cat-card:hover{
  border-color: rgba(79,106,95,.40);
  box-shadow:
    0 14px 28px rgba(24, 30, 27, .10),
    0 1px 0 rgba(255,255,255,.95) inset;
}

.cat-grid-visual--home .cat-card__img{
  background:
    radial-gradient(circle at top, rgba(86, 115, 100, .04), rgba(255,255,255,0) 55%),
    #ffffff;
}

.cat-grid-visual--home .cat-card__title{
  background: linear-gradient(180deg, #567364 0%, #486257 100%);
  color: #ffffff;
  font-weight: 800;
  text-shadow: 0 1px 0 rgba(0,0,0,.08);
}

@media (min-width: 768px){
  .cat-grid-visual--home{
    margin-top: 4px;
  }

  .cat-grid-visual--home .cat-card{
    border-radius: 16px;
  }
}

@media (max-width: 380px){
  .cat-grid-visual--home .cat-card{
    border-radius: 13px;
  }
}