/* ===========================================================
   Category Banner module — frontend styles
   Стратегія: банер на повну ширину content-area,
   без trick з 100vw, без overflow-x: hidden на body.
   =========================================================== */

.category-banner-item {
  width: 100%;
  overflow: hidden;
  line-height: 0;
}

.category-banner-item picture,
.category-banner-item img {
  display: block;
  width: 100%;
  height: auto; /* природні пропорції картинки */
  max-width: 100%;
}

.category-banner-item a {
  display: block;
  text-decoration: none;
}

.category-banner-item a:hover img {
  opacity: 0.92;
  transition: opacity 0.2s ease;
}

/* === Top banner === */
/* Знаходиться всередині .container з padding 15px.
   Negative margin компенсує цей padding щоб банер був на ширину контейнера. */
.category-top-banners-wrapper {
  margin: 0 -15px 20px -15px;
}

.category-banner-top {
  margin-bottom: 10px;
}

/* === Middle banner === */
/* Знаходиться всередині .category-box (CSS Grid).
   grid-column: 1 / -1 — span на всі колонки рядка. */
.category-banner-middle {
  grid-column: 1 / -1;
  margin: 15px 0;
}

/* Fallback для flex layouts */
.category-box .category-banner-middle {
  flex-basis: 100%;
}

@media (max-width: 768px) {
  .category-top-banners-wrapper {
    margin: 0 -15px 15px -15px;
  }
  .category-banner-middle {
    margin: 10px 0;
  }
  .category-banner-top {
    margin-bottom: 8px;
  }
}
