/* ============================================================
   page-contact.css — ご予約・お問合せページ
   ============================================================ */


/* ----------------------------------------------------------
   1. ボディエリア（2カラムグリッド）
   ---------------------------------------------------------- */

.ct-body {
  padding: clamp(80px, 10vw, 140px) 0;
  background-color: var(--btp-bg-primary);
}

.ct-grid {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: clamp(3rem, 6vw, 7rem);
  align-items: start;
}


/* ----------------------------------------------------------
   2. 左インフォパネル
   ---------------------------------------------------------- */

.ct-info__en {
  display: block;
  font-family: var(--btp-font-serif-en);
  font-size: 0.68rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--btp-gold);
  margin-bottom: 1.25rem;
}

.ct-info__gold-rule {
  display: block;
  width: 40px;
  height: 1px;
  background: var(--btp-gold);
  margin-bottom: 2rem;
}

.ct-info__heading {
  font-family: var(--btp-font-serif-ja);
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 300;
  color: var(--btp-text-primary);
  letter-spacing: 0.06em;
  line-height: 1.6;
  margin: 0 0 1.5rem;
}

.ct-info__lead {
  font-family: var(--btp-font-sans);
  font-size: clamp(0.83rem, 1.3vw, 0.92rem);
  font-weight: 300;
  color: var(--btp-text-secondary);
  line-height: 1.95;
  margin: 0 0 2.5rem;
}

.ct-info__dl {
  margin: 0 0 2rem;
  padding: 0;
}

.ct-info__row {
  display: grid;
  grid-template-columns: 5.5em 1fr;
  gap: 0.5rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--btp-border);
}

.ct-info__row:first-child {
  border-top: 1px solid var(--btp-border);
}

.ct-info__row dt {
  font-family: var(--btp-font-sans);
  font-size: 0.72rem;
  font-weight: 400;
  color: var(--btp-gold-dark);
  letter-spacing: 0.08em;
  padding-top: 0.15em;
}

.ct-info__row dd {
  font-family: var(--btp-font-sans);
  font-size: clamp(0.82rem, 1.3vw, 0.9rem);
  font-weight: 300;
  color: var(--btp-text-primary);
  line-height: 1.75;
  margin: 0;
}

.ct-info__note {
  display: block;
  font-size: 0.78em;
  color: var(--btp-text-secondary);
  margin-top: 0.15em;
}

.ct-info__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.ct-info__links a {
  font-size: 0.85rem;
  color: var(--btp-rose, #9B4D63);
  text-decoration: underline;
  text-decoration-color: rgba(155,77,99,0.35);
  transition: color 0.2s;
}

.ct-info__links a:hover {
  color: var(--btp-gold-dark, #c07a40);
}


/* ----------------------------------------------------------
   3. 右フォームパネル
   ---------------------------------------------------------- */

.ct-form__note {
  font-family: var(--btp-font-sans);
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--btp-text-secondary);
  margin: 0 0 1.5rem;
}

.ct-form__required-mark {
  color: var(--btp-gold-dark);
  margin-right: 0.25em;
}


/* ----------------------------------------------------------
   4. Contact Form 7 スタイルリセット＆サイトデザイン適用
   ---------------------------------------------------------- */

/* CF7 ラッパー */
.ct-form__cf7 .wpcf7 {
  margin: 0;
  padding: 0;
}

/* フォーム全体 */
.ct-form__cf7 .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* p タグのマージンをリセット（CF7 はフィールドを <p> で囲む） */
.ct-form__cf7 .wpcf7-form p {
  margin: 0 0 1.6rem;
  padding: 0;
}

.ct-form__cf7 .wpcf7-form p:last-of-type {
  margin-bottom: 0;
}

/* ラベル */
.ct-form__cf7 .wpcf7-form label {
  display: block;
  font-family: var(--btp-font-sans);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  color: var(--btp-text-secondary);
  margin-bottom: 0.55rem;
}

/* 必須マーク（CF7 の [your-name* ...] 等） */
.ct-form__cf7 .wpcf7-form abbr[title] {
  text-decoration: none;
  color: var(--btp-gold-dark);
  margin-left: 0.2em;
}

/* テキスト・メール・電話・URL の共通スタイル */
.ct-form__cf7 .wpcf7-form input[type="text"],
.ct-form__cf7 .wpcf7-form input[type="email"],
.ct-form__cf7 .wpcf7-form input[type="tel"],
.ct-form__cf7 .wpcf7-form input[type="url"],
.ct-form__cf7 .wpcf7-form input[type="number"],
.ct-form__cf7 .wpcf7-form input[type="date"],
.ct-form__cf7 .wpcf7-form select,
.ct-form__cf7 .wpcf7-form textarea {
  width: 100%;
  box-sizing: border-box;
  background-color: var(--btp-bg-secondary);
  border: 1px solid var(--btp-border);
  border-radius: 0;
  padding: 0.85em 1em;
  font-family: var(--btp-font-sans);
  font-size: 0.9rem;
  font-weight: 300;
  color: var(--btp-text-primary);
  line-height: 1.6;
  outline: none;
  transition: border-color 0.3s ease, background-color 0.3s ease;
  -webkit-appearance: none;
  appearance: none;
}

/* フォーカス */
.ct-form__cf7 .wpcf7-form input[type="text"]:focus,
.ct-form__cf7 .wpcf7-form input[type="email"]:focus,
.ct-form__cf7 .wpcf7-form input[type="tel"]:focus,
.ct-form__cf7 .wpcf7-form input[type="url"]:focus,
.ct-form__cf7 .wpcf7-form input[type="number"]:focus,
.ct-form__cf7 .wpcf7-form input[type="date"]:focus,
.ct-form__cf7 .wpcf7-form select:focus,
.ct-form__cf7 .wpcf7-form textarea:focus {
  border-color: var(--btp-gold);
  background-color: var(--btp-bg-primary);
}

/* テキストエリア */
.ct-form__cf7 .wpcf7-form textarea {
  min-height: 160px;
  resize: vertical;
}

/* セレクトボックスの矢印・外観 */
.ct-form__cf7 .wpcf7-form select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23b89968' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1em center;
  padding-right: 2.5em;
  cursor: pointer;
}

/* include_blank の空オプション（JS でテキストを注入）をプレースホルダー色に */
.ct-form__cf7 .wpcf7-form select.is-placeholder {
  color: var(--btp-text-secondary);
}
.ct-form__cf7 .wpcf7-form select option {
  color: var(--btp-text-primary);
}

/* チェックボックス・ラジオボタン */
.ct-form__cf7 .wpcf7-form input[type="checkbox"],
.ct-form__cf7 .wpcf7-form input[type="radio"] {
  width: 16px;
  height: 16px;
  margin-right: 0.5em;
  accent-color: var(--btp-gold);
  cursor: pointer;
  flex-shrink: 0;
}

.ct-form__cf7 .wpcf7-checkbox .wpcf7-list-item,
.ct-form__cf7 .wpcf7-radio .wpcf7-list-item {
  display: flex;
  align-items: center;
  margin-bottom: 0.5rem;
}

.ct-form__cf7 .wpcf7-checkbox .wpcf7-list-item-label,
.ct-form__cf7 .wpcf7-radio .wpcf7-list-item-label {
  font-family: var(--btp-font-sans);
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--btp-text-primary);
  cursor: pointer;
}

/* 同意チェックボックス行 —
   CF7 が <p> 内に <br> を挟んで出力するため、
   <p> を flex 化して <br> を非表示にして横並びにする */
.ct-form__cf7 .cf7-row--agreement p {
  display: flex !important;
  align-items: center !important;
  gap: 0.65rem !important;
  flex-wrap: nowrap;
  margin: 0 !important;
}

.ct-form__cf7 .cf7-row--agreement p br {
  display: none !important;
}

.ct-form__cf7 .cf7-row--agreement .wpcf7-form-control-wrap {
  display: inline-flex !important;
  flex-shrink: 0;
}

/* プライバシーポリシーリンク */
.ct-form__cf7 .cf7-row--agreement p a {
  color: var(--btp-gold-dark) !important;
  text-decoration: underline !important;
  text-underline-offset: 3px;
  font-weight: 400 !important;
  transition: color 0.3s ease;
}

.ct-form__cf7 .cf7-row--agreement p a:hover {
  color: var(--btp-gold) !important;
}

/* 送信ボタン */
.ct-form__cf7 .wpcf7-form input[type="submit"],
.ct-form__cf7 .wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 1em 2em;
  font-family: var(--btp-font-serif-en);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--btp-text-inverse);
  background: var(--btp-text-primary);
  border: 1px solid var(--btp-text-primary);
  border-radius: 0;
  cursor: pointer;
  transition: background 0.4s ease, border-color 0.4s ease, color 0.4s ease;
  -webkit-appearance: none;
  appearance: none;
  margin-top: 0.5rem;
}

.ct-form__cf7 .wpcf7-form input[type="submit"]:hover,
.ct-form__cf7 .wpcf7-submit:hover {
  background: var(--btp-gold);
  border-color: var(--btp-gold);
  color: var(--btp-text-inverse);
}

/* 送信中スピナー */
.ct-form__cf7 .wpcf7-spinner {
  display: none;
}

/* バリデーションエラー（フィールド下の赤テキスト） */
.ct-form__cf7 .wpcf7-not-valid-tip {
  display: block !important;
  visibility: visible !important;
  margin-top: 0.45rem;
  font-family: var(--btp-font-sans);
  font-size: 0.76rem;
  font-weight: 300;
  color: #9a4a20;
  letter-spacing: 0.03em;
  line-height: 1.5;
}

/* バリデーションエラー時のフィールド枠線 */
.ct-form__cf7 .wpcf7-not-valid {
  border-color: #c8855a !important;
  background-color: #fef9f6 !important;
}

/* 送信完了・エラーのレスポンスメッセージ共通 */
.ct-form__cf7 .wpcf7-response-output {
  display: block !important;
  visibility: visible !important;
  margin: 2rem 0 0 !important;
  padding: 1.1rem 1.4rem !important;
  border-width: 1px !important;
  border-style: solid !important;
  font-family: var(--btp-font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 300 !important;
  line-height: 1.75 !important;
  border-radius: 0 !important;
}

/* 送信成功（サンキューページへリダイレクトするため通常は見えないが念のため） */
.ct-form__cf7 .wpcf7-mail-sent-ok {
  border-color: var(--btp-gold) !important;
  background-color: #fdfaf5 !important;
  color: var(--btp-gold-dark) !important;
}

/* バリデーションエラー */
.ct-form__cf7 .wpcf7-validation-errors {
  border-color: #c8a882 !important;
  background-color: #fdf8f3 !important;
  color: #7a4a20 !important;
}

/* 同意チェック未チェック */
.ct-form__cf7 .wpcf7-acceptance-missing {
  border-color: #c8a882 !important;
  background-color: #fdf8f3 !important;
  color: #7a4a20 !important;
}

/* 送信失敗（サーバーエラー等） */
.ct-form__cf7 .wpcf7-mail-sent-ng,
.ct-form__cf7 .wpcf7-aborted {
  border-color: #b8a090 !important;
  background-color: #faf5f0 !important;
  color: #7a5a4a !important;
}

/* スパムブロック */
.ct-form__cf7 .wpcf7-spam-blocked {
  border-color: #b8a090;
  background-color: #faf5f0;
  color: var(--btp-text-secondary);
}


/* ----------------------------------------------------------
   5. レスポンシブ
   ---------------------------------------------------------- */

@media (max-width: 900px) {

  .ct-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .ct-info__heading {
    font-size: 1.3rem;
  }

}

@media (max-width: 480px) {

  .ct-form__cf7 .wpcf7-form input[type="text"],
  .ct-form__cf7 .wpcf7-form input[type="email"],
  .ct-form__cf7 .wpcf7-form input[type="tel"],
  .ct-form__cf7 .wpcf7-form textarea {
    font-size: 1rem; /* iOS の自動ズーム防止 */
  }

}
