/* ========== Features セクション ========== */

.features-section {
  padding: 4rem 1.5rem;
  background-color: var(--color-bg, #fff);
  color: var(--color-text);
}

.features-section h2 {
  font-size: 2rem;
  text-align: center;
  margin-bottom: 3rem;
  letter-spacing: var(--letter-spacing-tight, -0.02em);
}

/* ブロック全体（flex or grid対応） */
.feature-blocks {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
  justify-content: center;
}

/* 各項目 */
.feature-block {
  background-color: var(--color-bg-section, #f9fafb);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 8px;
  padding: 2rem;
  flex: 1 1 280px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: box-shadow 0.3s ease;
}

.feature-block:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

/* アイコン画像 */
.feature-icon {
  width: 48px;
  height: 48px;
  margin-bottom: 1rem;
}

/* タイトル */
.feature-title {
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

/* 説明文 */
.feature-description {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--color-text-muted, #666);
}

/* モバイル対応 */
@media (max-width: 768px) {
  .feature-blocks {
    flex-direction: column;
    gap: 1.5rem;
  }

  .feature-block {
    width: 100%;
  }
}
