/* ==========================================================================
   05-components.css — Module grid and cards matching website.pen
   ========================================================================== */

/* Section header (.pen: gap 16 between h2 and lead) */
.section-header {
  margin-bottom: var(--space-10);
}

.section-header .lead {
  margin-top: var(--space-5);
}

/* Module grid — .pen: 4 columns, gap 16 */
.module-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}

/* Module card — .pen: cornerRadius 12, padding 24, fill $gray-50, gap 8 */
.module-card {
  background-color: var(--color-gray-50);
  border-radius: var(--radius-xl);
  padding: var(--space-7);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.module-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* Module card icon — .pen: fill #EF6181, 24x24 */
.module-card__icon {
  color: var(--color-terracotta);
}

.module-card__icon svg {
  width: 24px;
  height: 24px;
}

/* Module card name — .pen: Plus Jakarta Sans 15px, weight 600 */
.module-card__name {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: var(--font-weight-semibold);
}

/* Module card desc — .pen: Plus Jakarta Sans 13px, normal, line-height 1.5 */
.module-card__desc {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  line-height: 1.5;
}

/* Responsive: stack on smaller screens */
@media (max-width: 1023px) {
  .module-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .module-grid {
    grid-template-columns: 1fr;
  }
}
