/* ============================================================
   Contact Page
   ============================================================ */
.contact-page {
	padding-block: clamp(80px, 14vh, 140px);
	padding-top: calc(var(--header-height) + clamp(60px, 10vh, 100px));
}

.contact-page__inner {
	width: min(720px, 100% - 3rem);
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: clamp(32px, 5vw, 56px);
}

.contact-page__header {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.contact-page__title img {
	display: block;
	height: clamp(48px, 8vw, 80px);
	width: auto;
}

.contact-page__subtitle {
	font-size: clamp(13px, 1.5vw, 15px);
	letter-spacing: 0.12em;
	color: #666;
}

.contact-page__lead p {
	font-size: clamp(14px, 1.6vw, 16px);
	line-height: 1.9;
	color: #444;
}

/* 確認画面テキストは初期非表示 */
.contact-page__lead--confirm {
	display: none;
}

/* Snow Monkey Forms が確認画面になったら切り替え */
.contact-page:has(.snow-monkey-form[data-screen="confirm"]) .contact-page__lead--input {
	display: none;
}
.contact-page:has(.snow-monkey-form[data-screen="confirm"]) .contact-page__lead--confirm {
	display: block;
}

/* 完了画面ではリードテキストをすべて非表示 */
.contact-page:has(.snow-monkey-form[data-screen="complete"]) .contact-page__lead {
	display: none;
}

/* トップへ戻るボタン — 完了画面のみ表示 */
.contact-page__back-to-top {
	display: none;
	margin-top: 40px;
	text-align: center;
}

.contact-page:has(.snow-monkey-form[data-screen="complete"]) .contact-page__back-to-top {
	display: block;
}

.contact-page__back-to-top a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 240px;
	padding: 18px 48px;
	font-size: 14px;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-weight: 700;
	letter-spacing: 0.19em;
	color: #fff;
	background: #e07a5f;
	border-radius: 80px;
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.contact-page__back-to-top a:hover {
	opacity: 0.85;
	transform: translateY(-2px);
}

@media (max-width: 767px) {
	.contact-page__back-to-top a {
		width: 100%;
		min-width: unset;
	}
}

.contact-page__form {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

/* ============================================================
   Snow Monkey Forms — カスタムスタイル
   ============================================================ */

/* フォーム全体 */
.contact-page .snow-monkey-form {
	--smf-accent: #1a1a1a;
}

/* 各フィールド行 */
.contact-page .smf-item {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding-block: 24px;
	border-bottom: 1px solid #e8e8e8;
	margin: 0 !important;
}

.contact-page .smf-item:first-child {
	border-top: 1px solid #e8e8e8;
}

.contact-page .smf-item:last-child {
	border-bottom: none;
}

/* ラベル列 */
.contact-page .smf-item__col--label {
	display: flex;
	align-items: center;
	gap: 8px;
	background: none !important;
	border: none !important;
	padding: 0 !important;
}

.contact-page .smf-item__col--label label {
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.08em;
	color: #1a1a1a;
}

/* 必須バッジ */
.contact-page .smf-item__col--label .smf-label__required,
.contact-page .smf-item__col--label [class*="required"] {
	display: inline-flex;
	align-items: center;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.06em;
	color: #fff;
	background: #1a1a1a;
	padding: 2px 7px;
	line-height: 1.6;
}

/* 任意バッジ */
.contact-page .smf-item__col--label .smf-label__任意,
.contact-page .smf-item__col--label [class*="optional"] {
	display: inline-flex;
	align-items: center;
	font-size: 10px;
	letter-spacing: 0.06em;
	color: #999;
	border: 1px solid #ccc;
	padding: 2px 7px;
	line-height: 1.6;
}

/* コントロール列 */
.contact-page .smf-item__col--controls {
	padding: 0 !important;
}

/* テキスト入力・セレクト共通 */
.contact-page .smf-text-control__control,
.contact-page .smf-select-control__control,
.contact-page .smf-textarea-control__control {
	width: 100%;
	max-width: 100%;
}

.contact-page .smf-text-control__control input,
.contact-page .smf-text-control__control textarea,
.contact-page .smf-select-control__control select,
.contact-page .smf-textarea-control__control textarea,
.contact-page input[type="text"],
.contact-page input[type="email"],
.contact-page select,
.contact-page textarea {
	width: 100%;
	padding: 12px 16px;
	font-size: 15px;
	font-family: var(--font-sans);
	color: #1a1a1a;
	background: #fafafa;
	border: 1px solid #ddd;
	border-radius: 6px;
	outline: none;
	appearance: none;
	-webkit-appearance: none;
	transition: border-color 0.2s ease, background 0.2s ease;
}

.contact-page input[type="text"]:focus,
.contact-page input[type="email"]:focus,
.contact-page select:focus,
.contact-page textarea:focus {
	border-color: #1a1a1a;
	background: #fff;
}

/* セレクトボックスの矢印 */
.contact-page .smf-select-control__control {
	position: relative;
}

.contact-page .smf-select-control__control::after {
	content: '';
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	width: 8px;
	height: 8px;
	border-right: 1.5px solid #1a1a1a;
	border-bottom: 1.5px solid #1a1a1a;
	rotate: 45deg;
	pointer-events: none;
}

.contact-page select {
	padding-right: 40px;
	cursor: pointer;
}

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

/* バリデーションエラー */
.contact-page .smf-error-messages {
	font-size: 12px;
	color: #c0392b;
	margin-top: 6px;
}

.contact-page .smf-form [data-invalid="1"] {
	border-color: #c0392b !important;
	background: #fff9f9;
}

/* 送信ボタンエリア */
.contact-page .smf-action {
	margin-top: 40px !important;
	text-align: center;
}

.contact-page .smf-action .smf-button-control__control,
.contact-page .smf-action input[type="submit"],
.contact-page .smf-action button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 240px;
	padding: 18px 48px;
	font-size: 14px;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-weight: 700;
	letter-spacing: 0.19em;
	color: #fff;
	background: #e07a5f;
	border: none;
	border-radius: 80px;
	cursor: pointer;
	transition: opacity 0.2s ease, transform 0.2s ease;
	background-image: none !important;
}

.contact-page .smf-action .smf-button-control__control:hover,
.contact-page .smf-action input[type="submit"]:hover,
.contact-page .smf-action button[type="submit"]:hover {
	opacity: 0.85;
	transform: translateY(-2px);
}

.contact-page .smf-action .smf-button-control__control[disabled] {
	opacity: 0.4;
	cursor: not-allowed;
}

/* 戻るボタン */
.contact-page .smf-action .smf-button-control__control[data-action="back"] {
	background: transparent;
	color: #999;
	border: 1px solid #ccc;
	min-width: 160px;
}

.contact-page .smf-action .smf-button-control__control[data-action="back"]:hover {
	background: transparent;
	color: #666;
	border-color: #999;
	opacity: 1;
	transform: translateY(-2px);
}

/* プログレストラッカー（確認・完了ステップ） */
.contact-page .smf-progress-tracker {
	margin-bottom: 48px;
	gap: 0;
}

.contact-page .smf-progress-tracker__item__number {
	background-color: #ddd;
	width: 28px;
	height: 28px;
	font-size: 12px;
}

.contact-page .smf-progress-tracker__item[aria-current=true] .smf-progress-tracker__item__number {
	background-color: #1a1a1a;
}

.contact-page .smf-progress-tracker__item__text {
	font-size: 11px;
	letter-spacing: 0.06em;
	margin-top: 6px;
}

.contact-page .smf-progress-tracker__item::before,
.contact-page .smf-progress-tracker__item::after {
	top: 14px;
	background-color: #ddd;
}

/* SP 対応 */
@media (max-width: 767px) {
	.contact-page .smf-action .smf-button-control__control,
	.contact-page .smf-action input[type="submit"],
	.contact-page .smf-action button[type="submit"] {
		width: 100%;
		min-width: unset;
	}
}
