/* === 【お問い合わせフォーム /contact】 ===
 * 意図: Contact Form 7 を使ったお問い合わせフォームのスタイル。
 *       .c-form__badge / .c-form__row など contact 固有のコンポーネントを定義する。
 */

/* --- フォームラッパー --- */
.c-contact-form {
  max-width: 760px;
}

/* --- 必須/任意バッジ --- */
.c-form__badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: var(--radius-xs);
  margin-right: var(--sp-8);
  line-height: 1.4;
  vertical-align: middle;
}

.c-form__badge--req {
  background: var(--color_main);
  color: var(--color_white);
}

.c-form__badge--opt {
  background: #e8edf2;
  color: #666;
}

/* --- フォーム行: ラベル + コントロールの 2 カラムグリッド --- */
.c-contact-form .c-form__row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--sp-12) var(--sp-24);
  align-items: center;
  /* 理由: wpautop <p> が介在するため start より center が揃いやすい */
  padding: var(--sp-16) 0;
  border-bottom: 1px solid #f0f4f8;
}

.c-contact-form .c-form__row:first-of-type {
  padding-top: 0;
}

@media (max-width: 960px) {
  .c-contact-form .c-form__row {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
    padding: var(--sp-12) 0;
  }
}

/* --- ラベル --- */
.c-contact-form .c-form__label {
  font-size: 14px;
  font-weight: 600;
  color: #333;
  line-height: 1.5;
}

/* --- コントロール領域 --- */
.c-contact-form .c-form__control {
  min-width: 0;
}

.c-contact-form .c-form__control--sm {
  max-width: 280px;
}

@media (max-width: 960px) {
  .c-contact-form .c-form__control--sm {
    max-width: 100%;
  }
}

/* --- 2 カラムコントロール（姓/名、セイ/メイ） --- */
.c-contact-form .c-form__control--cols2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-16);
}

@media (max-width: 580px) {
  .c-contact-form .c-form__control--cols2 {
    grid-template-columns: 1fr;
  }
}

/* サブラベル（姓 / 名） */
.c-form__sublabel {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #666;
  margin-bottom: var(--sp-4);
}

/* CF7 の wrap span をブロック化 */
.c-contact-form .wpcf7-form-control-wrap {
  display: block;
}

/* 理由: WordPress の wpautop が CF7 タグ周辺に <p> を挿入するため
 *       SWELL デフォルトの p margin を打ち消す */
.c-contact-form .c-form__label p,
.c-contact-form .c-form__control p,
.c-contact-form .c-form__sub p {
  margin: 0;
}

/* 理由: CF7 が label と input の間に改行を挿入するため <br> を非表示にする */
.c-contact-form .c-form__sub p br {
  display: none;
}

/* 理由: wpautop が郵便番号 input と「自動入力」ボタンを同じ <p> に入れ、
 *       その間に <br> を挿入して flex レイアウトを崩す */
.c-form__control--postal p {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-8);
  margin: 0;
}

.c-form__control--postal p br {
  display: none;
}

/* 理由: wpautop がプライバシーテキスト先頭に空の <br> を挿入する */
.c-form__privacy-text br:first-child {
  display: none;
}

/* --- 入力フィールド共通 --- */
.c-form__input,
.c-form__select,
.c-form__textarea {
  display: block;
  width: 100%;
  padding: var(--sp-12) var(--sp-16);
  border: 1.5px solid #ccd3dc;
  border-radius: var(--radius-xs);
  font-size: 15px;
  line-height: 1.5;
  color: #333;
  background: #f8fafc;
  transition: border-color 0.2s, box-shadow 0.2s;
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
}

.c-form__input:focus,
.c-form__select:focus,
.c-form__textarea:focus {
  border-color: var(--color_main);
  box-shadow: 0 0 0 3px rgba(15, 63, 110, 0.1);
  outline: none;
  background: var(--color_white);
}

/* セレクト: カスタム矢印アイコン */
.c-form__select {
  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='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-16) center;
  padding-right: var(--sp-40);
  cursor: pointer;
}

.c-form__textarea {
  min-height: 160px;
  resize: vertical;
}

/* --- バリデーションエラー表示 --- */
.c-contact-form .wpcf7-not-valid-tip {
  display: block;
  font-size: 12px;
  color: #c0392b;
  margin-top: var(--sp-4);
}

.c-form__input.wpcf7-not-valid,
.c-form__select.wpcf7-not-valid,
.c-form__textarea.wpcf7-not-valid {
  border-color: #c0392b !important;
  background: #fff8f8;
}

/* --- 住所グループ (fieldset) --- */
/* 理由: 住所 5 項目をひとかたまりとして「任意」を legend でまとめることで
 *       フォームの項目数が多く見える問題を緩和する */
.c-form__address-group {
  border: 1px solid #e0e8f0;
  border-radius: var(--radius-sm);
  padding: 0 var(--sp-20) var(--sp-8);
  margin: var(--sp-4) 0 0;
}

/* SWELL が fieldset に適用するスタイルを打ち消す */
.post_content .c-form__address-group {
  margin-top: var(--sp-4);
}

.c-form__address-legend {
  font-size: 14px;
  font-weight: 600;
  color: #333;
  padding: 0 var(--sp-8);
  float: none;
  width: auto;
}

/* 住所グループ内の行: セパレーターを薄くする */
.c-contact-form .c-form__row--sub {
  align-items: center;
  padding: var(--sp-8) 0;
  border-bottom: 1px solid #f4f7fb;
}

.c-contact-form .c-form__row--sub:last-child {
  border-bottom: none;
}

/* --- 郵便番号 + 自動入力ボタン --- */
.c-form__control--postal {
  display: flex;
  gap: var(--sp-8);
  align-items: flex-start;
}

.c-form__control--postal .wpcf7-form-control-wrap {
  max-width: 160px;
  flex-shrink: 0;
}

.c-form__inline-btn {
  padding: var(--sp-12) var(--sp-16);
  /* 理由: input と高さを揃える */
  background: #f0f4f8;
  color: var(--color_main);
  border: 1.5px solid #ccd3dc;
  border-radius: var(--radius-xs);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s;
  white-space: nowrap;
  flex-shrink: 0;
  line-height: 1.5;
}

.c-form__inline-btn:hover {
  background: #dde7f0;
}

.c-form__inline-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* --- プライバシーポリシー同意エリア --- */
.c-form__privacy {
  padding: var(--sp-24) 0 var(--sp-16);
  border-top: 1px solid #f0f4f8;
  margin-top: var(--sp-8);
}

.c-form__privacy-text {
  font-size: 13px;
  color: #666;
  margin: 0 0 var(--sp-12);
  line-height: 1.7;
}

.c-form__privacy-text a {
  color: var(--color_main);
  text-decoration: underline;
}

/* 理由: CF7 は class: オプションを span.wpcf7-acceptance ではなく
 *       input[type="checkbox"] に付与するため、親スパンから辿ってスタイルする */
.wpcf7-acceptance .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-8);
  font-size: 14px;
  font-weight: 600;
  color: #333;
  cursor: pointer;
  margin: 0;
}

.wpcf7-acceptance .wpcf7-list-item input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color_main);
  cursor: pointer;
  flex-shrink: 0;
  margin: 0;
}

/* --- 送信ボタン --- */
.c-form__submit-row {
  padding-top: var(--sp-24);
  text-align: center;
}

/* CF7 が input[type=submit] または button[type=submit] を出力するため両方指定 */
.c-form__submit-btn,
input.c-form__submit-btn {
  display: inline-block;
  padding: var(--sp-16) var(--sp-60);
  background: var(--color_main);
  color: var(--color_white);
  border: none;
  border-radius: var(--radius-xs);
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.2s;
  line-height: 1.5;
  min-width: 240px;
  appearance: none;
}

.c-form__submit-btn:hover,
input.c-form__submit-btn:hover {
  background: var(--color_main_deep);
}

/* CF7 スピナー */
.wpcf7 .ajax-loader {
  display: inline-block;
  margin-left: var(--sp-8);
  vertical-align: middle;
}

/* --- CF7 フォームレベルのメッセージ --- */
.wpcf7-response-output {
  margin-top: var(--sp-16) !important;
  padding: var(--sp-12) var(--sp-16) !important;
  border-radius: var(--radius-xs) !important;
  font-size: 14px !important;
  border-width: 0 0 0 4px !important;
  border-style: solid !important;
}

.wpcf7-mail-sent-ok {
  background: #d1e7dd !important;
  border-color: #198754 !important;
  color: #0a3622 !important;
}

.wpcf7-mail-sent-ng,
.wpcf7-spam-blocked,
.wpcf7-validation-errors,
.wpcf7-acceptance-missing {
  background: #f8d7da !important;
  border-color: #dc3545 !important;
  color: #58151c !important;
}

/* === 【サンクスページ /contact/thanks】 === */
.c-thanks {
  position: relative;
  margin: var(--sp-48) auto;
  padding: var(--sp-60) var(--sp-48) var(--sp-48);
  background: var(--color_white);
  border-radius: var(--radius-lg);
  box-shadow: 0 10px 40px rgba(15, 63, 110, 0.1);
  overflow: hidden;
}

.c-thanks::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 6px;
  background: linear-gradient(90deg, var(--color_cta) 0%, var(--color_sub) 100%);
}

.c-thanks__header {
  text-align: center;
  margin-bottom: var(--sp-32);
}

.c-thanks__icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 96px;
  height: 96px;
  margin: 0 auto var(--sp-24);
  background: var(--color_cta);
  border-radius: var(--radius-full);
  color: var(--color_white);
  box-shadow: 0 8px 24px rgba(255, 100, 0, 0.3);
}

.c-thanks__icon::before {
  content: "";
  position: absolute;
  inset: -12px;
  border: 2px solid rgba(255, 100, 0, 0.15);
  border-radius: var(--radius-full);
}

.c-thanks__icon::after {
  content: "";
  position: absolute;
  inset: -24px;
  border: 2px solid rgba(255, 100, 0, 0.08);
  border-radius: var(--radius-full);
}

.c-thanks__icon svg {
  position: relative;
  width: 48px;
  height: 48px;
  stroke: currentColor;
  stroke-width: 3;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.c-thanks__heading {
  font-size: 22px;
  font-weight: 700;
  color: var(--color_main);
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin: 0;
}

.c-thanks__lead {
  max-width: 580px;
  margin: 0 auto var(--sp-32);
  font-size: 16px;
  line-height: 1.9;
  color: #333;
  text-align: center;
}

.c-thanks__note {
  display: flex;
  gap: var(--sp-12);
  max-width: 580px;
  margin: 0 auto var(--sp-40);
  padding: var(--sp-20) var(--sp-24);
  background: #fff8dd;
  border-radius: var(--radius-sm);
  font-size: 14px;
  line-height: 1.8;
  color: #555;
  text-align: left;
}

.c-thanks__note::before {
  content: "!";
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: var(--color_sub);
  color: var(--color_main);
  border-radius: var(--radius-full);
  font-weight: 700;
  font-size: 13px;
  margin-top: 2px;
}

.c-thanks__actions {
  display: flex;
  gap: var(--sp-16);
  justify-content: center;
  flex-wrap: wrap;
}

.c-thanks__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-8);
  min-width: 240px;
  height: 56px;
  padding: 0 var(--sp-32);
  border-radius: var(--radius-xl);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.c-thanks__btn--primary {
  background: var(--color_main);
  color: var(--color_white);
  box-shadow: 0 4px 14px rgba(15, 63, 110, 0.25);
}

.c-thanks__btn--primary:hover {
  background: #0b3057;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15, 63, 110, 0.35);
  color: var(--color_white);
}

.c-thanks__btn--secondary {
  background: var(--color_white);
  color: var(--color_main);
  border: 2px solid var(--color_main);
}

.c-thanks__btn--secondary:hover {
  background: var(--color_main);
  color: var(--color_white);
  transform: translateY(-2px);
}

.c-thanks__btn-arrow {
  display: inline-block;
  transition: transform 0.2s ease;
}

.c-thanks__btn:hover .c-thanks__btn-arrow {
  transform: translateX(-3px);
}

@media (max-width: 600px) {
  .c-thanks__icon {
    width: 80px;
    height: 80px;
  }

  .c-thanks__icon svg {
    width: 40px;
    height: 40px;
  }

  .c-thanks__heading {
    font-size: 18px;
  }

  .c-thanks__lead {
    font-size: 15px;
    text-align: left;
  }

  .c-thanks__btn {
    min-width: 100%;
    height: 52px;
  }
}