/* ==========================================================================
   About — 소개 페이지
   ========================================================================== */

/* ── About Hero ── */
.about-hero {
  text-align: center;
  padding: var(--space-3xl) 0 var(--space-2xl);
}

.about-hero__emoji {
  margin-bottom: var(--space-md);
  line-height: 1;
}

.about-hero__emoji img {
  width: 64px;
  height: 64px;
}

.about-hero__title {
  font-size: var(--font-2xl);
  font-weight: 800;
  margin-bottom: var(--space-md);
}

.about-hero__desc {
  font-size: var(--font-md);
  color: var(--color-text-sub);
  max-width: 40rem;
  margin-inline: auto;
  line-height: 1.7;
}

/* ── Feature Cards ── */
.features {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-3xl);
}

.feature-card {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  text-align: center;
  transition: transform var(--transition-fast),
              box-shadow var(--transition-fast);
}

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

.feature-card__icon {
  font-size: 2.5rem;
  margin-bottom: var(--space-md);
}

.feature-card__title {
  font-size: var(--font-base);
  font-weight: 700;
  margin-bottom: var(--space-sm);
}

.feature-card__desc {
  font-size: var(--font-sm);
  color: var(--color-text-sub);
  line-height: 1.6;
}

/* ── Tech Stack ── */
.tech-stack {
  margin-bottom: var(--space-3xl);
}

.tech-stack__grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: center;
}

.tech-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg);
  font-size: var(--font-sm);
  font-weight: 600;
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  transition: border-color var(--transition-fast);
}

.tech-badge:hover {
  border-color: var(--color-accent);
}

.tech-badge__icon {
  font-size: var(--font-md);
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .about-hero {
    padding: var(--space-2xl) 0 var(--space-lg);
  }

  .about-hero__title {
    font-size: var(--font-xl);
  }

  .features {
    grid-template-columns: 1fr;
  }
}
