/* ==========================================================================
   Homestay Korea — About Homestay Page
   홈스테이 소개 히어로, 콘텐츠 타이포그래피, 유형 카드, 예약 단계
   ========================================================================== */

/* ---- 히어로 ---- */
.about-hero {
  position: relative;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-color: var(--color-bg-dark);
  background-image: url('../../assets/images/homestay/hero-about-homestay.jpg');
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.about-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.5));
}

.about-hero__content {
  position: relative;
  z-index: 1;
  color: var(--color-text-white);
  padding: var(--spacing-6);
  max-width: 700px;
}

.about-hero__title {
  font-size: var(--text-5xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--spacing-4);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.about-hero__description {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  opacity: 0.9;
}

/* ---- 콘텐츠 타이포그래피 ---- */
.about-content h2 {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--spacing-4);
  color: var(--color-text-primary);
}

.about-content h3 {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-3);
  color: var(--color-text-primary);
}

.about-content p {
  font-size: var(--text-base);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--spacing-4);
}

.about-content ul {
  padding-left: var(--spacing-6);
  margin-bottom: var(--spacing-4);
}

.about-content li {
  font-size: var(--text-base);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--spacing-2);
  list-style: disc;
}

/* ---- 섹션 제목 중앙 정렬 ---- */
.about-content__heading--center {
  text-align: center;
  margin-bottom: var(--spacing-8);
}

.about-content__subheading--center {
  text-align: center;
  font-size: var(--text-lg);
  color: var(--color-text-light);
  max-width: 600px;
  margin: 0 auto;
}

/* ---- 유형 카드 ---- */
.type-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-6);
  margin-bottom: var(--spacing-8);
}

.type-card {
  background: var(--color-bg-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
  padding: var(--spacing-6);
  text-align: center;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

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

.type-card__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--spacing-4);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary-light);
  border-radius: var(--radius-circle);
  color: var(--color-primary);
}

.type-card__icon svg {
  width: 28px;
  height: 28px;
  fill: currentColor;
}

.type-card__title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--spacing-2);
  color: var(--color-text-primary);
}

.type-card__text {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
}

/* ---- 예약 단계 ---- */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-8);
  margin-top: var(--spacing-8);
}

.step {
  text-align: center;
}

.step__number {
  width: 56px;
  height: 56px;
  margin: 0 auto var(--spacing-4);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary);
  color: var(--color-text-white);
  border-radius: var(--radius-circle);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
}

.step__title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--spacing-2);
  color: var(--color-text-primary);
}

.step__text {
  font-size: var(--text-base);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
}

/* ---- Navy 배경 섹션 ---- */
.section--navy {
  background: var(--color-bg-navy);
  color: var(--color-text-white);
}
.section--navy .step__title {
  color: var(--color-text-white);
}
.section--navy .step__text {
  color: rgba(255, 255, 255, 0.7);
}
.section--navy h2 {
  color: var(--color-text-white);
}
.section--navy .about-content__subheading--center {
  color: rgba(255, 255, 255, 0.7);
}

/* ---- 리스트 카드 ---- */
.about-list-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--spacing-6);
}
.about-list-card--dark {
  background: var(--color-bg-navy);
  color: var(--color-text-white);
  border-color: transparent;
}
.about-list-card--dark li {
  color: rgba(255, 255, 255, 0.8);
}
.about-list-card--dark .about-list-card__title {
  color: var(--color-text-white);
}
.about-list-card__title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--spacing-4);
}

/* ---- CTA 버튼 그룹 ---- */
.pro-cta__actions {
  display: flex;
  justify-content: center;
  gap: var(--spacing-3);
  flex-wrap: wrap;
}

/* ---- CTA 중앙 정렬 ---- */
.about-content__cta {
  text-align: center;
  margin-top: var(--spacing-12);
}

.about-content__subheading--center {
  margin-bottom: var(--spacing-8);
}

/* ---- 반응형 ---- */
@media (max-width: 1024px) {
  .about-hero {
    height: 320px;
  }

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

  .type-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .steps {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-6);
  }
}

@media (max-width: 767px) {
  .about-hero {
    height: 280px;
  }

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

  .about-hero__description {
    font-size: var(--text-md);
  }

  .type-cards {
    grid-template-columns: 1fr;
  }

  .steps {
    grid-template-columns: 1fr;
    gap: var(--spacing-6);
  }
}
