/* 
 * お問い合わせページ専用CSS
 */

/* ===========================================
   お問い合わせページ基本スタイル
   =========================================== */

.contact-page {
  min-height: 100vh;
  padding-top: var(--spacing-xl);
}

.contact-page .container {
  max-width: var(--container-lg);
  margin: 0 auto;
  padding: 0 var(--spacing-base);
}

.contact-page .page-article {
  background: var(--color-bg-primary);
  padding: var(--spacing-xl);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-md);
  margin-bottom: var(--spacing-lg);
}

/* ===========================================
   ページヘッダー
   =========================================== */

.contact-page .page-header {
  text-align: center;
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-2xl);
  border-bottom: 2px solid var(--color-primary);
}

.contact-page .page-title {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-lg);
}

.contact-page .page-excerpt {
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

/* ===========================================
   お問い合わせ情報セクション
   =========================================== */

.contact-page .contact-info-section {
  margin: var(--spacing-lg) 0;
}

.contact-page .contact-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-2xl);
}

.contact-page .contact-info-card {
  background: var(--color-bg-primary);
  padding: var(--spacing-2xl);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-base);
  text-align: center;
  transition: all var(--transition-base);
  border: 1px solid rgba(37, 99, 235, 0.1);
}

.contact-page .contact-info-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(37, 99, 235, 0.2);
}

.contact-page .contact-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(
    135deg,
    var(--color-primary) 0%,
    var(--color-secondary) 100%
  );
  border-radius: var(--border-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--spacing-base);
  color: var(--color-bg-primary);
  font-size: var(--font-size-xl);
}

.contact-page .contact-info-card h3 {
  color: var(--color-text-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-sm);
}

.contact-page .contact-detail {
  color: var(--color-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--spacing-xs);
}

.contact-page .contact-hours {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

/* ===========================================
   お問い合わせフォームセクション
   =========================================== */

.contact-page .contact-form-section {
  background: var(--color-bg-secondary);
  padding: var(--spacing-xl);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-base);
  margin-top: var(--spacing-2xl);
}

.contact-page .contact-form-section h2 {
  text-align: center;
  margin-bottom: var(--spacing-lg);
  color: var(--color-text-primary);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-semibold);
}

.contact-page .contact-form-wrapper p {
  text-align: center;
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-xl);
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
}

.contact-page .form-placeholder {
  background: var(--color-bg-primary);
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-base);
  border: 2px dashed var(--color-border);
  text-align: center;
}

.contact-page .form-placeholder p {
  margin-bottom: var(--spacing-base);
}

.contact-page .form-placeholder code {
  background: var(--color-bg-secondary);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-sm);
  font-family: "Courier New", monospace;
  color: var(--color-primary);
  font-size: var(--font-size-sm);
}

/* ===========================================
   ページ本文
   =========================================== */

.contact-page .page-body {
  margin-bottom: var(--spacing-lg);
}

.contact-page .page-content-wrapper h2 {
  color: var(--color-text-primary);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  margin-top: var(--spacing-2xl);
  margin-bottom: var(--spacing-lg);
}

.contact-page .page-content-wrapper p {
  color: var(--color-text-secondary);
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-lg);
}

/* ===========================================
   レスポンシブ対応
   =========================================== */

@media (max-width: 768px) {
  .contact-page .page-article {
    padding: var(--spacing-2xl);
  }

  .contact-page .page-title {
    font-size: var(--font-size-3xl);
  }

  .contact-page .contact-info-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-base);
  }

  .contact-page .contact-info-card {
    padding: var(--spacing-lg);
  }

  .contact-page .contact-form-section {
    padding: var(--spacing-xl);
  }

  .contact-page .contact-form-section h2 {
    font-size: var(--font-size-2xl);
  }
}
