/* Integratori – subcategorie (solo /categorie/cosmetici/)
   Scope: body.vi-page-cosmetici */

body.vi-page-cosmetici .vi-subcats-wrap{
  margin-top: 18px;
}

body.vi-page-cosmetici .vi-subcats-title{
  margin: 22px 0 10px;
  font-size: 1.35rem;
  line-height: 1.2;
}

body.vi-page-cosmetici .vi-subcats-note{
  margin: 0 0 12px;
  color: var(--cat-muted, rgba(2,6,23,.66));
}

body.vi-page-cosmetici .vi-subcats-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

body.vi-page-cosmetici .vi-subcat-card{
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--cat-border, rgba(15,23,42,.10));
  background: var(--cat-surface, rgba(255,255,255,.92));
  box-shadow: var(--cat-shadow-soft, 0 10px 26px rgba(2,6,23,.08));
  transition: transform .12s ease, box-shadow .12s ease;
}

body.vi-page-cosmetici .vi-subcat-card:hover{
  transform: translateY(-1px);
  box-shadow: var(--cat-shadow, 0 12px 30px rgba(2,6,23,.10));
}

body.vi-page-cosmetici .vi-subcat-media{
  aspect-ratio: 16 / 9;   /* QUI risolviamo immagini non uniformi */
  background: rgba(2,6,23,.03);
}

body.vi-page-cosmetici .vi-subcat-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;      /* crop “pulito” per tile larghe/squadrate */
  display: block;
}

body.vi-page-cosmetici .vi-subcat-body{
  padding: 12px 14px 14px;
}

body.vi-page-cosmetici .vi-subcat-title{
  display: block;
  font-weight: 800;
  color: var(--cat-fg, #0b1220);
  line-height: 1.15;
}

body.vi-page-cosmetici .vi-subcat-desc{
  display: block;
  margin-top: 6px;
  color: var(--cat-muted, rgba(2,6,23,.66));
  line-height: 1.25;
  font-size: .95rem;
}
