/* =====================================================================
   SERVICIOS (solo home)
   Fondo: var(--color-fondo-secundario) gris
   ===================================================================== */

.bloque-servicios {
  background: var(--color-fondo-secundario);
}

/* Grids de cards */

.servicios-grid-top,
.servicios-grid-bottom {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.servicios-grid-bottom {
  margin-top: 20px;
}

/* ----- Card de servicio ----- */

.servicio-card {
  position: relative;
  background: var(--color-fondo);
  border: 1px solid var(--color-borde);
  border-radius: var(--radio);
  overflow: hidden;
  transition: box-shadow 0.25s ease, transform 0.2s ease;
}

.servicio-card:hover {
  box-shadow: 0 8px 32px rgba(27, 58, 75, 0.12);
  transform: translateY(-2px);
}

/* Imagen de la card */

.servicio-card-img {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.servicio-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.servicio-card:hover .servicio-card-img img {
  transform: scale(1.05);
}

/* Cuerpo de la card */

.servicio-card-body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.servicio-card-h3 {
  font-size: 16px;
  font-weight: var(--peso-bold);
  color: var(--color-primario);
  margin: 0;
  line-height: 1.3;
}

/* Enlace que cubre toda la card con ::after */

.servicio-card-h3 a {
  position: static;
  color: inherit;
  text-decoration: none;
}

.servicio-card-h3 a::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
}

.servicio-card-p {
  font-size: 13px;
  color: var(--color-texto-secundario);
  line-height: 1.65;
  margin: 0;
}

.servicio-card-arrow {
  font-size: 13px;
  font-weight: var(--peso-semibold);
  color: var(--color-acento);
  margin-top: 4px;
  display: inline-block;
  transition: transform 0.2s ease;
}

.servicio-card:hover .servicio-card-arrow {
  transform: translateX(4px);
}

/* ----- Desktop (≥ 768px) ----- */

@media (min-width: 768px) {

  .servicios-grid-top {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }

  .servicios-grid-bottom {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    max-width: 66.666%;
    margin-inline: auto;
    margin-top: 20px;
  }
}
