/* ====================================================================
   page-contact.css  (tokens from variables.css)
   - Centered, compact form with consistent spacing & typography
   ==================================================================== */

/* ====== Layout: container centered ====== */
.contact-page .l-container{
  width: 100%;
  max-width: 880px; /* 画面幅が広い時だけ上限をかける（モバイルで縮小しない） */
  margin: 0 auto;
  padding: var(--space-16) var(--container-gutter) var(--space-24);
  box-sizing: border-box;
}

/* ====== Header ====== */
.contact-page .page-header{
  margin-bottom: var(--space-10);
}
.contact-page .page-title{
  font-family: var(--font-latin), var(--font-sans-jp);
  font-weight: var(--fw-bold);
  font-size: var(--fs-2xl);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-2);
  letter-spacing: 0.02em;
}
.contact-page .page-lead{
  color: var(--c-fg-muted);
  font-size: var(--fs-14);
  line-height: var(--lh-base);
  margin: 0;
}

/* PDPからの商品コード表示（任意要素） */
.contact-page__product{
  margin-top: var(--space-4);
  color: var(--c-fg-muted);
  font-size: var(--fs-14);
}
.contact-page__productCode{
  font-weight: var(--fw-semibold);
  color: var(--c-brand-blue);
}

/* ====== Form base ====== */
.contact-page__form{
  margin-top: var(--space-8);
}
.contact-page__field{
  margin-bottom: var(--space-8); /* 各フィールドの縦間隔を広めに */
}
.contact-page__field label{
  display: block;
  font-weight: var(--fw-regular);
  color: var(--c-fg);
}

/* ラベルと入力欄の間の余白＋タップ領域の確保 */
.contact-page__field input[type="text"],
.contact-page__field input[type="email"],
.contact-page__field input[type="tel"],
.contact-page__field textarea{
  display: block;
  width: 100%;
  margin-top: var(--space-3);
  padding: 14px 16px;
  min-height: 44px; /* モバイルでのタップしやすさ */
  background: var(--c-bg);
  color: var(--c-fg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  line-height: 1.6;
  box-sizing: border-box;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

/* フォーカス時のアクセシブルな強調 */
.contact-page__field input:focus,
.contact-page__field textarea:focus{
  outline: none;
  border-color: var(--c-brand-blue);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-brand-blue) 24%, transparent);
}

/* テキストエリア */
.contact-page__field textarea{
  min-height: 220px;
  resize: vertical;
}

/* 必須バッジ */
.contact-page__req{
  display: inline-block;
  margin-left: .5em;
  padding: 2px 8px;
  font-size: var(--fs-xs);
  border-radius: var(--radius-full);
  background: var(--c-brand-blue);
  color: var(--c-fg-inverse);
  vertical-align: middle;
}

/* エラーブロック（PHP側の .contact-page__errors を想定） */
.contact-page__errors{
  margin: var(--space-4) 0 var(--space-6);
  padding: var(--space-4);
  border: 1px solid color-mix(in srgb, var(--c-danger) 50%, var(--c-border));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--c-danger) 6%, #fff);
  color: #7f1d1d;
}
.contact-page__errors ul{
  margin: 0;
  padding-left: var(--space-6);
}

/* 送信ボタン */
.contact-page__actions{
  margin-top: var(--space-8);
}
.contact-page .button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: 12px 20px;
  font-weight: var(--fw-semibold);
  border-radius: var(--radius-full);
  color: var(--c-fg-inverse);
  background: var(--c-brand-blue);
  border: 1px solid var(--c-brand-blue);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-fast) var(--ease), background var(--dur) var(--ease);
}
.contact-page .button:hover{
  background: var(--c-brand-blue-light);
}
.contact-page .button:active{
  transform: translateY(1px);
}

/* Thanks メッセージ */
.contact-page__thanks{
  margin: var(--space-8) 0;
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: var(--c-bg-muted);
  color: var(--c-fg);
  box-shadow: var(--shadow-sm);
}

/* ====== Responsive fine tuning ====== */
@media (min-width: 1024px){
  .contact-page .l-container{
    max-width: 840px; /* PCはややコンパクトに中央寄せ */
    padding: var(--space-20) var(--container-gutter) var(--space-28);
  }
  .contact-page .page-title{
    font-size: calc(var(--fs-2xl) + 2px);
  }
}
