@charset 'UTF-8';

/**
 * お問い合わせページ専用スタイル
 */

/* ========================================
 * ヒーローセクション
 * ======================================== */
.contact_hero .section_inner {
  text-align: center;
}

.contact_intro {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  margin-top: var(--spacing-lg);
  max-width: var(--form-width);
  margin-left: auto;
  margin-right: auto;
}

/* ========================================
 * Contact Form 7 フォームスタイル
 * ======================================== */
.contact_form {
  max-width: var(--form-width);
  margin: var(--spacing-xl) auto 0;
}

.contact_form .wpcf7-form {
  text-align: left;
}

/* フォームグループ */
.contact_form .wpcf7-form p {
  margin-top: var(--spacing-lg);
}

.contact_form .wpcf7-form p:first-child {
  margin-top: 0;
}

/* ラベル */
.contact_form .wpcf7-form label {
  display: block;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
}

/* ラベルとフィールド間の余白 */
.contact_form .wpcf7-form-control-wrap {
  display: block;
  margin-top: var(--spacing-sm);
}

/* 必須・任意バッジ */
.contact_form .required {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  margin-left: 0.6em;
}

.contact_form .optional {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  color: var(--color-disabled);
  margin-left: 0.6em;
}

/* 入力フィールド */
.contact_form .wpcf7-form input[type="text"],
.contact_form .wpcf7-form input[type="email"],
.contact_form .wpcf7-form input[type="tel"],
.contact_form .wpcf7-form textarea {
  width: 100%;
  padding: 1rem 1.2rem;
  font-family: var(--font-base);
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-main);
  background-color: var(--color-bg-main);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--border-radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  appearance: none;
}

.contact_form .wpcf7-form input[type="text"]::placeholder,
.contact_form .wpcf7-form input[type="email"]::placeholder,
.contact_form .wpcf7-form input[type="tel"]::placeholder,
.contact_form .wpcf7-form textarea::placeholder {
  color: var(--color-border);
}

.contact_form .wpcf7-form input[type="text"]:focus,
.contact_form .wpcf7-form input[type="email"]:focus,
.contact_form .wpcf7-form input[type="tel"]:focus,
.contact_form .wpcf7-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.06);
}

.contact_form .wpcf7-form textarea {
  min-height: 14rem;
  resize: vertical;
}

/* 送信ボタン */
.contact_form .wpcf7-form input[type="submit"] {
  display: block;
  width: 100%;
  max-width: var(--btn-width);
  min-height: var(--btn-height);
  margin: var(--spacing-xl) auto 0;
  padding: 0 2rem;
  font-family: var(--font-ja);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-inverse);
  background-color: var(--color-primary);
  border: none;
  border-radius: var(--border-radius-md);
  cursor: pointer;
  transition: background-color var(--transition-base);
  appearance: none;
}

.contact_form .wpcf7-form input[type="submit"]:hover {
  background-color: var(--color-accent);
}

/* バリデーションエラー */
.contact_form .wpcf7-not-valid {
  border-color: var(--color-accent);
}

.contact_form .wpcf7-not-valid-tip {
  font-size: var(--font-size-xs);
  color: var(--color-accent);
  margin-top: var(--spacing-xs);
}

/* レスポンスメッセージ共通 */
.contact_form .wpcf7-response-output {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  padding: 1.5rem 2rem;
  margin: var(--spacing-xl) 0 0;
  text-align: center;
  border: none;
  border-radius: var(--border-radius-md);
}

/* 送信成功 */
.contact_form .wpcf7 form.sent .wpcf7-response-output,
.contact_form form.sent .wpcf7-response-output {
  color: #1b5e20;
  background-color: #e8f5e9;
}

/* バリデーションエラー・送信失敗 */
.contact_form .wpcf7 form.invalid .wpcf7-response-output,
.contact_form .wpcf7 form.unaccepted .wpcf7-response-output,
.contact_form .wpcf7 form.failed .wpcf7-response-output,
.contact_form form.invalid .wpcf7-response-output,
.contact_form form.unaccepted .wpcf7-response-output,
.contact_form form.failed .wpcf7-response-output {
  color: #b71c1c;
  background-color: #fce4ec;
}

/* CF7 スピナー */
.contact_form .wpcf7-spinner {
  display: block;
  margin: var(--spacing-sm) auto 0;
}

/* ========================================
 * プライバシーポリシー同意テキスト
 * ======================================== */
.contact_privacy {
  margin-top: var(--spacing-md);
  text-align: center;
  font-size: var(--font-size-xs);
}

.contact_privacy a {
  text-decoration: underline;
  color: var(--color-accent);
}

.contact_privacy a:hover {
  opacity: 0.7;
}

/* ========================================
 * Responsive
 * ======================================== */
@media screen and (max-width: 900px) {
  .contact_intro {
    font-size: var(--font-size-sm);
  }

  .contact_form .wpcf7-form input[type="text"],
  .contact_form .wpcf7-form input[type="email"],
  .contact_form .wpcf7-form input[type="tel"],
  .contact_form .wpcf7-form textarea {
    padding: 0.8rem 1rem;
  }

  .contact_form .wpcf7-form textarea {
    min-height: 10rem;
  }

  .contact_form .wpcf7-form p {
    margin-top: var(--spacing-md);
  }

  .contact_form .wpcf7-form input[type="submit"] {
    margin-top: var(--spacing-lg);
  }

  .contact_form .wpcf7-response-output {
    padding: 1rem 1.5rem;
  }
}
