/* =========================================================
   Contact Form 7 — HGMT スタイル統合
   CF7 が生成する .wpcf7-form / .wpcf7-form-control を
   既存の .contact-form / input スタイルに合わせる
   ========================================================= */

/* ── CF7 ラッパー: 既存 .contact-form と同じ 2 カラムグリッド ── */
#contact .wpcf7 {
	margin-top: clamp(40px, 6vw, 72px);
}

#contact .wpcf7-form {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	grid-auto-rows: auto !important;
	align-items: start !important;
	gap: clamp(20px, 3vw, 40px) clamp(24px, 4vw, 64px) !important;
	max-width: 1080px;
	margin: 0 auto;
}

/* CF7 が <p> でラップしてもグリッドアイテムとして並ぶように */
#contact .wpcf7-form > p {
	margin: 0 !important;
	padding: 0 !important;
	display: contents !important;
}

/* ── .field レイアウト: label と入力の縦並び ── */
/* 元 style.css の .field は grid (140px 1fr) なので、それを打ち消す */
#contact .wpcf7-form .field {
	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	justify-content: flex-start !important;
	grid-template-columns: none !important;
	gap: 10px !important;
	min-width: 0 !important;
	align-self: start !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	text-align: left !important;
}

#contact .wpcf7-form .field.full {
	grid-column: 1 / -1 !important;
}

/* .field の中に追加ネストされた <div> が来ても、横幅 100% を保つ */
#contact .wpcf7-form .field > div {
	width: 100% !important;
	box-sizing: border-box !important;
}

/* label を左寄せに強制 */
#contact .wpcf7-form .field label,
#contact .wpcf7-form .field > label {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	justify-content: flex-start !important;
	text-align: left !important;
	width: auto !important;
	align-self: flex-start !important;
}

#contact .wpcf7-form .field.full {
	grid-column: 1 / -1;
}

#contact .wpcf7-form .field label {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	font-family: var(--font-jp-sans);
	font-size: 12px;
	letter-spacing: 0.2em;
	color: var(--ink);
	margin: 0;
}

/* 必須マーク */
#contact .wpcf7-form .field label .req {
	display: inline-block;
	padding: 2px 8px;
	font-family: var(--font-en);
	font-size: 9px;
	letter-spacing: 0.2em;
	color: var(--paper);
	background-color: var(--accent);
	border-radius: 1px;
	line-height: 1.4;
	white-space: nowrap;
}

/* ── CF7 内部ラッパー (input を包む span) を block 化 ── */
/* セレクタは `.wpcf7-form-control-wrap` の単独指定で確実にマッチさせる */
.wpcf7-form-control-wrap {
	display: block !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

/* ── 入力要素: 横幅いっぱい、適切な高さ ── */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="search"],
.wpcf7-form textarea,
.wpcf7-form select,
input.wpcf7-form-control,
textarea.wpcf7-form-control,
select.wpcf7-form-control {
	display: block !important;
	width: 100% !important;
	box-sizing: border-box !important;
	padding: 14px 16px !important;
	font-family: var(--font-jp-sans, "Noto Sans JP", sans-serif) !important;
	font-size: 15px !important;
	letter-spacing: 0.04em !important;
	line-height: 1.6 !important;
	color: var(--ink, #0f1115) !important;
	background: var(--white, #fff) !important;
	border: 1px solid var(--line-strong, #b8b1a0) !important;
	border-radius: 0 !important;
	transition: 0.25s ease !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	box-shadow: none !important;
	min-height: 0 !important;
	max-width: none !important;
}

/* プレースホルダー */
#contact .wpcf7-form input::placeholder,
#contact .wpcf7-form textarea::placeholder {
	color: rgba(15, 17, 21, 0.35);
}

/* フォーカス */
#contact .wpcf7-form input:focus,
#contact .wpcf7-form textarea:focus,
#contact .wpcf7-form select:focus {
	outline: none;
	border-color: var(--accent);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(168, 52, 31, 0.08);
}

/* テキストエリア */
#contact .wpcf7-form textarea {
	resize: vertical;
	min-height: 180px;
	line-height: 1.9;
}

/* ── セレクトボックス: 矢印カスタマイズ ── */
#contact .wpcf7-form .select-wrap {
	position: relative;
	width: 100%;
}

#contact .wpcf7-form .select-wrap::after {
	content: "";
	position: absolute;
	right: 18px;
	top: 50%;
	width: 8px;
	height: 8px;
	border-right: 1px solid var(--ink);
	border-bottom: 1px solid var(--ink);
	transform: translateY(-70%) rotate(45deg);
	pointer-events: none;
}

#contact .wpcf7-form select {
	padding-right: 44px;
	cursor: pointer;
}

/* ── ヘルプテキスト ── */
#contact .wpcf7-form .field-help {
	display: block;
	margin-top: 6px;
	font-family: var(--font-jp-sans);
	font-size: 11px;
	letter-spacing: 0.08em;
	line-height: 1.7;
	color: var(--sub);
}

/* ── 送信行 ── */
#contact .wpcf7-form .submit-row {
	grid-column: 1 / -1 !important;
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 24px !important;
	margin-top: 24px !important;
	padding-top: 32px !important;
	border-top: 1px solid var(--line) !important;
}

#contact .wpcf7-form .submit-note {
	font-family: var(--font-jp-sans);
	font-size: 12px;
	letter-spacing: 0.08em;
	line-height: 1.8;
	color: var(--sub);
}

/* ── 送信ボタン: 朱色フィルアニメ ── */
.wpcf7-form .submit-btn,
.wpcf7-form input[type="submit"],
.wpcf7-form input.wpcf7-submit,
input.wpcf7-submit {
	position: relative !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: auto !important;
	min-width: 220px !important;
	padding: 18px 36px !important;
	font-family: var(--font-jp-sans, "Noto Sans JP", sans-serif) !important;
	font-size: 13px !important;
	letter-spacing: 0.25em !important;
	color: var(--ink, #0f1115) !important;
	background: var(--white, #ffffff) !important;
	border: 1px solid var(--ink, #0f1115) !important;
	border-radius: 0 !important;
	cursor: pointer !important;
	transition: color 0.4s cubic-bezier(0.77, 0, 0.18, 1),
				background 0.4s cubic-bezier(0.77, 0, 0.18, 1),
				border-color 0.4s cubic-bezier(0.77, 0, 0.18, 1) !important;
	overflow: hidden !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	box-shadow: none !important;
	box-sizing: border-box !important;
}

.wpcf7-form .submit-btn:hover,
.wpcf7-form input[type="submit"]:hover,
.wpcf7-form input.wpcf7-submit:hover,
input.wpcf7-submit:hover {
	color: var(--paper, #f5f1e8) !important;
	background: var(--accent, #a8341f) !important;
	border-color: var(--accent, #a8341f) !important;
}

/* ── バリデーションエラー ── */
#contact .wpcf7-form .wpcf7-not-valid {
	border-color: var(--accent) !important;
	background: rgba(168, 52, 31, 0.04) !important;
}

#contact .wpcf7-form .wpcf7-not-valid-tip {
	display: block;
	margin-top: 6px;
	font-family: var(--font-jp-sans);
	font-size: 11px;
	letter-spacing: 0.08em;
	color: var(--accent);
}

/* ── メッセージ表示 (送信成功・失敗) ── */
#contact .wpcf7 form .wpcf7-response-output {
	grid-column: 1 / -1;
	margin: 24px 0 0;
	padding: 14px 18px;
	border: 1px solid var(--line-strong);
	font-family: var(--font-jp-sans);
	font-size: 13px;
	letter-spacing: 0.06em;
	color: var(--ink);
	background: #fff;
	border-radius: 0;
}

#contact .wpcf7 form.sent .wpcf7-response-output {
	border-color: #2a8a4a;
	color: #2a8a4a;
	background: rgba(42, 138, 74, 0.05);
}

#contact .wpcf7 form.invalid .wpcf7-response-output,
#contact .wpcf7 form.failed .wpcf7-response-output,
#contact .wpcf7 form.spam .wpcf7-response-output {
	border-color: var(--accent);
	color: var(--accent);
	background: rgba(168, 52, 31, 0.05);
}

/* ローダー (送信中) */
#contact .wpcf7 form .wpcf7-spinner {
	background-color: var(--accent);
}

/* ── レスポンシブ ── */
@media (max-width: 720px) {
	#contact .wpcf7-form {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	#contact .wpcf7-form .submit-row {
		flex-direction: column;
		align-items: stretch;
		gap: 16px;
	}
	#contact .wpcf7-form .submit-btn,
	#contact .wpcf7-form input[type="submit"] {
		min-width: 0;
		width: 100%;
	}
}
