/* ===== Sección Categorías (aislada del resto) ===== */
.section-categorias {
  background: #fff;
  padding: clamp(2.5rem, 6vw, 5rem) 0;
  color: #4b0082; /* proaseoPurple */
}

.section-categorias .cat-container {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.section-categorias .cat-header {
  text-align: center;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}
.section-categorias .cat-header h2 {
  font-weight: 800;
  font-size: clamp(1.8rem, 3.8vw, 3rem);
  letter-spacing: -0.02em;
}
.section-categorias .cat-header p {
  margin-top: .75rem;
  opacity: .85;
  font-size: clamp(.95rem, 1.2vw, 1.125rem);
}

/* Grid responsive */
.section-categorias .cat-grid{
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
@media (min-width: 640px){ .section-categorias .cat-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px){ .section-categorias .cat-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px){ .section-categorias .cat-grid{ grid-template-columns: repeat(5, 1fr); } }

/* Card */
.section-categorias .cat-card{
  display: flex;
  flex-direction: column;
  align-items: center;
  --card-gap: clamp(0.75rem, 1.2vw, 1.25rem);
  --title-bottom: clamp(1rem, 2vw, 1.6rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--card-gap);           /* <- separación fija entre imagen y título */
  min-height: 280px;              /* puedes subir/bajar este valor si quieres */
  padding: 1.25rem 1.5rem 1.25rem;
  border-radius: 1.25rem;
  background: #fff7ef;
  box-shadow: 0 6px 20px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.05);
  transition: transform .35s ease, box-shadow .35s ease, background .35s ease;
  outline: none; border: 0;
}
.section-categorias .cat-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(0,0,0,.10);
}
.section-categorias .cat-card:focus-visible{
  box-shadow: 0 0 0 3px rgba(255,140,0,.35), 0 6px 20px rgba(0,0,0,.06);
}

/* Imagen */
.section-categorias .cat-img{
  width: clamp(150px, 78%, 210px);
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

/* Título */
.section-categorias .cat-title{
  display: block;
  text-align: center;
  font-weight: 800;
  color: #ff8a00;
  font-size: clamp(1.05rem, 1.2vw, 1.35rem);
  margin-top: 0;                  /* el gap de la card ya da el espacio superior */
  margin-bottom: var(--title-bottom); /* <- margen inferior más amplio */
}

/* Mejora de rendimiento para morph de cards */
#categorias .cat-card{
  will-change: transform, border-radius, background-color, box-shadow, opacity;
  transform-origin:center center;
}
#categorias .cat-card .cat-media,
#categorias .cat-card img,
#categorias .cat-card .cat-title,
#categorias .cat-card .cat-text{
  will-change: opacity, filter, transform;
}
