#subcategories {
  position: relative;
  padding: 12px 0;
  margin-bottom: 24px;
}
#subcategories .subcategory-heading {
  display: none;
}
.subcat-track-outer {
  overflow: hidden;
  margin: 0 52px;
}
#subcategories .flex-container {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 12px;
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
  cursor: grab;
  user-select: none;
  margin: 0;
  padding: 4px 2px;
}
#subcategories .flex-container.grabbing { cursor: grabbing; }
#subcategories .flex-container li {
  flex: 0 0 148px;
  list-style: none;
}

/* Móvil: muestra 2.5 items */
@media (max-width: 600px) {
  .carousel-btn subcat-prev{display:none;}
  .subcat-track-outer {
    margin: 0 0px;
  }
  #subcategories .flex-container li {
    flex: 0 0 calc((100vw - 36px * 2 - 12px * 2) / 2.5);
  }
  .carousel-btn {
    width: 32px;
    height: 32px;
  }
  .carousel-btn.subcat-prev { display:none !important;}
  .carousel-btn.subcat-next { right: 0; }
}

#subcategories figure {
  margin: 0;
  border: 1.5px solid transparent;
  border-radius: 6px;
  padding: 14px 10px 12px;
  transition: border-color 0.18s, background 0.18s;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
#subcategories figure:hover { border-color: #ccc;  }
#subcategories figure.active { border: 2px solid #111; background: #f5f5f5; }
#subcategories figure a.img {
  display: block;
  width: 142px;
  height: auto;
  overflow: hidden;
}
#subcategories figure a.img picture,
#subcategories figure a.img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
#subcategories .subcategory-name {
  font-size: 13px;
  color: #111;
  text-align: center;
  line-height: 1.3;
  display: block;
  text-decoration: none;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
}
.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition: background 0.15s, border-color 0.15s;
}
.carousel-btn:hover { background: #f5f5f5; border-color: #999; }
.carousel-btn svg { width: 16px; height: 16px; stroke: #111; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.carousel-btn.subcat-prev { left: 4px; }
.carousel-btn.subcat-next { right: 4px; }