/* ── Features section ─────────────────────────────────── */

.section--features {
  background: var(--warm-cream);
}

/* ── Header ──────────────────────────────────────────── */

.features__header {
  margin-bottom: 64px;
}

.features__headline {
  font-family: var(--font-headline);
  font-size: 2.75rem;
  line-height: 1.1;
  color: var(--dark);
  margin-bottom: 16px;
}

.features__subhead {
  font-family: var(--font-body);
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.6;
  color: var(--dark);
  opacity: 0.6;
  max-width: 600px;
}

/* ── Card grid ───────────────────────────────────────── */

.features__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* ── Individual card ─────────────────────────────────── */

.feature-card {
  border: 1px solid rgba(17, 26, 14, 0.1);
  border-radius: 16px;
  padding: 36px 28px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.feature-card:hover {
  transform: scale(1.02);
  box-shadow: 0 4px 24px rgba(17, 26, 14, 0.06);
}

.feature-card__icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--shield-green);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  color: var(--warm-cream);
}

.feature-card__title {
  font-family: var(--font-headline);
  font-size: 1.25rem;
  line-height: 1.2;
  color: var(--dark);
  margin-bottom: 12px;
}

.feature-card__body {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--dark);
  opacity: 0.65;
}

/* ── Mobile ──────────────────────────────────────────── */

@media (max-width: 768px) {
  .features__headline {
    font-size: 2rem;
  }

  .features__header {
    margin-bottom: 40px;
  }

  .features__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .feature-card {
    padding: 28px 24px;
  }
}

/* ── Tablet (2-column) ───────────────────────────────── */

@media (min-width: 769px) and (max-width: 1024px) {
  .features__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
