/* ==========================================================================
   Page: contact （lk-theme-light / 紙色背景）
   ========================================================================== */

/* swell-reset の 100vw + calc(50% - 50vw) トリックはスクロールバー幅ぶん
   左にズレるので、contact では section/footer を通常の 100% に戻す */
#body_wrap.lk-theme-light .post_content > section,
#body_wrap.lk-theme-light .post_content > footer {
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.lk-contact-page {
	padding: clamp(96px, 11vw, 160px) 5% clamp(72px, 9vw, 120px);
	background: var(--paper);
	box-sizing: border-box;
}
.lk-contact-page__inner {
	width: min(100%, 620px);
	margin-inline: auto;
	box-sizing: border-box;
}
.lk-contact-page__eyebrow {
	font-family: var(--f-en);
	font-size: 11px;
	letter-spacing: 0.32em;
	color: var(--mute);
	text-transform: uppercase;
	margin-bottom: 28px;
	text-align: center;
}
/* swell-reset.css の `.post_content h1 { margin: 0 !important }` が
   詳細度で勝ってしまうため、同じ詳細度（#body_wrap + .post_content）で上書き */
#body_wrap.lk-art .post_content .lk-contact-page__title {
	font-family: var(--f-en) !important;
	font-weight: 300 !important;
	font-size: clamp(56px, 10vw, 132px) !important;
	line-height: 1 !important;
	letter-spacing: 0;
	color: var(--ink) !important;
	text-align: center;
	margin: 0 0 80px 0 !important;
}
@media (max-width: 720px) {
	#body_wrap.lk-art .post_content .lk-contact-page__title {
		margin-bottom: 56px !important;
	}
}
#body_wrap.lk-art .post_content .lk-contact-page__lead {
	font-family: var(--f-jp);
	font-size: 15px;
	line-height: 2;
	color: rgba(7,7,7,0.72);
	width: min(100%, 520px);
	text-align: center;
	margin: 0 auto 72px !important;
}

/* ---------- CF7 form ---------- */
.lk-contact-page__form {
	margin-bottom: 72px;
	max-width: 100%;
}
.lk-contact-page__form .wpcf7,
.lk-contact-page__form .wpcf7-form {
	max-width: 100%;
	width: 100%;
}
.lk-contact-page__form .wpcf7-form {
	display: grid;
	gap: 28px;
}
.lk-contact-page__form .wpcf7-form p { margin: 0 !important; }
.lk-contact-page__form .hidden-fields-container { display: none; }

.lk-form__row {
	display: block;
	position: relative;
}
.lk-form__label {
	display: flex;
	align-items: baseline;
	gap: 12px;
	margin-bottom: 8px;
	font-family: var(--f-jp);
	font-size: 13px;
	letter-spacing: 0.08em;
	color: var(--ink);
}
.lk-form__label em {
	font-family: var(--f-en);
	font-style: normal;
	font-size: 10px;
	letter-spacing: 0.24em;
	color: var(--mute);
	text-transform: uppercase;
}
.lk-form__req {
	font-family: var(--f-en);
	font-size: 10px;
	color: var(--navy-soft);
	margin-left: 4px;
}

.lk-contact-page__form .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
}
.lk-contact-page__form input[type="text"],
.lk-contact-page__form input[type="email"],
.lk-contact-page__form input[type="tel"],
.lk-contact-page__form textarea,
.lk-contact-page__form select {
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	background: transparent;
	border: none;
	border-bottom: 1px solid rgba(7,7,7,0.18);
	border-radius: 0;
	color: var(--ink);
	font-family: var(--f-jp);
	font-size: 15px;
	padding: 10px 0;
	transition: border-color 0.3s;
	appearance: none;
	-webkit-appearance: none;
}
.lk-contact-page__form select {
	background-image: linear-gradient(45deg, transparent 50%, var(--mute) 50%),
	                  linear-gradient(-45deg, transparent 50%, var(--mute) 50%);
	background-position: calc(100% - 14px) 20px, calc(100% - 8px) 20px;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 28px;
	cursor: pointer;
}
.lk-contact-page__form select option {
	background: var(--paper);
	color: var(--ink);
}
.lk-contact-page__form textarea {
	resize: vertical;
	min-height: 120px;
	line-height: 1.8;
}
.lk-contact-page__form input:focus,
.lk-contact-page__form textarea:focus,
.lk-contact-page__form select:focus {
	outline: none;
	border-bottom-color: var(--ink);
}
.lk-contact-page__form input::placeholder,
.lk-contact-page__form textarea::placeholder {
	color: rgba(7,7,7,0.35);
}

.lk-form__submit {
	text-align: center;
	width: 100%;
	margin-top: 16px !important;
}
/* CF7 が <p class="lk-form__submit"> を生成するため、input 自体に
   margin: 0 auto を当ててブロック中央寄せにする（flex 中央寄せより確実） */
.lk-contact-page__form input[type="submit"] {
	display: block;
	margin: 0 auto !important;
	padding: 18px 56px;
	background: transparent;
	border: 1px solid var(--ink);
	color: var(--ink);
	font-family: var(--f-en);
	font-size: 12px;
	letter-spacing: 0.24em;
	/* letter-spacing の末尾余白ぶん右に寄せて、文字を視覚的に中央に置く */
	text-indent: 0.24em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.3s, color 0.3s;
	width: auto;
}
.lk-contact-page__form input[type="submit"]:hover {
	background: var(--ink);
	color: var(--paper);
}

/* CF7 validation & response messages */
.lk-contact-page__form .wpcf7-not-valid-tip {
	display: block;
	margin-top: 6px;
	font-family: var(--f-jp);
	font-size: 12px;
	color: #b44b4b;
	letter-spacing: 0.04em;
}
/* 空のときは非表示（送信結果がないのに border/padding で薄い枠が出る問題の封じ） */
.lk-contact-page__form .wpcf7-response-output[aria-hidden="true"],
.lk-contact-page__form .wpcf7-response-output:empty {
	display: none !important;
}
.lk-contact-page__form .wpcf7 form .wpcf7-response-output {
	margin: 24px 0 0 !important;
	padding: 14px !important;
	border: 1px solid rgba(7,7,7,0.12) !important;
	font-family: var(--f-jp);
	font-size: 13px;
	color: var(--ink);
	text-align: center;
}
.lk-contact-page__form .wpcf7 form.sent .wpcf7-response-output {
	border-color: var(--navy-soft) !important;
}
.lk-contact-page__form .wpcf7-spinner {
	background-color: var(--mute);
}

/* ---------- Invoice note ---------- */
.lk-contact-page__note {
	width: min(100%, 560px);
	margin: 0 auto !important;
	padding: 24px 28px;
	border: 1px solid rgba(7,7,7,0.1);
	text-align: center;
	font-family: var(--f-jp);
	font-size: 12px;
	line-height: 2;
	color: var(--mute);
	letter-spacing: 0.04em;
	box-sizing: border-box;
}
.lk-contact-page__note em {
	font-family: var(--f-en);
	font-style: normal;
	font-size: 10px;
	letter-spacing: 0.24em;
	color: var(--ink);
	text-transform: uppercase;
	display: block;
	margin-bottom: 6px;
}
