/* ==========================================================================
   Homestay Korea -- Contact Page Styles
   문의 페이지 전용 스타일
   ========================================================================== */

/* ---- 페이지 컨테이너 ---- */
.contact-page {
  padding-top: var(--spacing-8);
  padding-bottom: var(--spacing-16);
}

.contact-page .section__title {
  margin-bottom: var(--spacing-4);
}

.contact-page .section__subtitle {
  margin-bottom: var(--spacing-8);
}

/* ==========================================================================
   소셜 아이콘 행
   ========================================================================== */

.contact-social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-10);
}

.contact-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: var(--color-bg-white);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-circle);
  color: var(--color-text-light);
  transition: background-color var(--transition-fast),
              border-color var(--transition-fast),
              color var(--transition-fast),
              transform var(--transition-base);
}

.contact-social__link:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-text-white);
  transform: scale(1.08);
}

.contact-social__link svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

/* ==========================================================================
   연락처 정보 (아이콘 + 텍스트)
   ========================================================================== */

.contact-info {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--spacing-8);
  margin-bottom: var(--spacing-10);
}

.contact-info__item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-3);
  max-width: 300px;
}

.contact-info__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  min-width: 40px;
  background: var(--color-primary-light);
  border-radius: var(--radius-circle);
  color: var(--color-primary);
}

.contact-info__icon svg {
  width: 20px;
  height: 20px;
}

.contact-info__text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

.contact-info__text strong {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.contact-info__text a {
  color: var(--color-primary);
}

.contact-info__text a:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

/* ==========================================================================
   Google Maps 컨테이너
   ========================================================================== */

.contact-map {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  margin-bottom: var(--spacing-12);
}

.contact-map iframe {
  display: block;
  width: 100%;
  height: 400px;
}

/* ==========================================================================
   문의 폼
   ========================================================================== */

.contact-form-wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: var(--spacing-10);
  background: var(--color-bg-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
}

.contact-form__title {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  text-align: center;
  margin-bottom: var(--spacing-8);
  color: var(--color-text-primary);
}

/* 폼 2열 행 (데스크톱) */
.contact-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-4);
}

/* 폼 그룹 */
.contact-form .form-group {
  margin-bottom: var(--spacing-5);
}

/* 제출 버튼 영역 */
.contact-form__actions {
  text-align: center;
  margin-top: var(--spacing-6);
}

.contact-form__actions .btn {
  min-width: 200px;
}

/* 파일 업로드 영역 */
.contact-form .form-file {
  padding: var(--spacing-4) var(--spacing-5);
}

.contact-form .form-file svg {
  flex-shrink: 0;
  color: var(--color-text-muted);
}

/* ==========================================================================
   반응형
   ========================================================================== */

@media (max-width: 1024px) {
  .contact-page {
    padding-top: var(--spacing-6);
    padding-bottom: var(--spacing-12);
  }

  .contact-info {
    gap: var(--spacing-6);
    margin-bottom: var(--spacing-8);
  }

  .contact-map iframe {
    height: 340px;
  }

  .contact-map {
    margin-bottom: var(--spacing-10);
  }

  .contact-form-wrapper {
    padding: var(--spacing-8);
  }

  .contact-form__title {
    font-size: var(--text-xl);
    margin-bottom: var(--spacing-6);
  }
}

@media (max-width: 767px) {
  .contact-page {
    padding-top: var(--spacing-4);
    padding-bottom: var(--spacing-10);
  }

  /* 소셜 아이콘 */
  .contact-social {
    gap: var(--spacing-3);
    margin-bottom: var(--spacing-8);
  }

  .contact-social__link {
    width: 42px;
    height: 42px;
  }

  /* 연락처 정보 - 단일 열 */
  .contact-info {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-5);
    margin-bottom: var(--spacing-8);
  }

  .contact-info__item {
    max-width: none;
  }

  /* 지도 높이 축소 */
  .contact-map iframe {
    height: 280px;
  }

  .contact-map {
    margin-bottom: var(--spacing-8);
  }

  /* 폼 래퍼 */
  .contact-form-wrapper {
    padding: var(--spacing-6) var(--spacing-4);
  }

  .contact-form__title {
    font-size: var(--text-xl);
    margin-bottom: var(--spacing-6);
  }

  /* 폼 단일 열 */
  .contact-form .form-row {
    grid-template-columns: 1fr;
  }

  .contact-form__actions .btn {
    width: 100%;
  }
}

/* ---- 지도 임베드 ---- */
.map-embed {
  border: 0;
}
