/* ============================================================
   CONTACT
   - Snow Monkey Forms 周りのスタイルは旧子テーマからの実績を流用
   ============================================================ */

/* Snow Monkey Forms — 縦並び・必須バッジ */
.smf-form.smf-form--input { max-width: 720px; margin: 0 auto; }
.smf-form.smf-form--input .smf-item {
	display: block;
	padding: 1.25em 0;
	border-bottom: 1px solid var(--c-line-soft);
}
.smf-form.smf-form--input .smf-item:last-of-type { border-bottom: 0; }
.smf-form.smf-form--input .smf-item__label {
	display: block;
	width: 100%;
	margin-bottom: 0.5em;
	font-weight: 600;
	font-size: clamp(0.85rem, 0.3vw + 0.78rem, 0.92rem);
	color: var(--c-ink);
}
.smf-form.smf-form--input .smf-item__label__text {
	display: inline-flex; align-items: center; gap: 0.5em;
}
.smf-required-badge {
	display: inline-block;
	padding: 0.15em 0.55em;
	font-size: 0.72em; font-weight: 700;
	color: #fff;
	background: var(--c-cta-warning);
	border-radius: 2px;
	letter-spacing: 0.05em;
}
.smf-form.smf-form--input .smf-item__description {
	margin-top: 0.5em; font-size: 0.85em; color: var(--c-mute);
}
.smf-form.smf-form--input .smf-text-control__control,
.smf-form.smf-form--input .smf-email-control__control,
.smf-form.smf-form--input .smf-tel-control__control,
.smf-form.smf-form--input .smf-url-control__control,
.smf-form.smf-form--input .smf-textarea-control__control,
.smf-form.smf-form--input .smf-select-control__control {
	width: 100%; max-width: 100%;
	padding: 0.7em 0.9em;
	font-size: clamp(0.92rem, 0.3vw + 0.85rem, 0.96rem); line-height: 1.6;
	color: var(--c-ink);
	background: var(--c-bg-soft);
	border: 1px solid #d9d9d9; border-radius: 3px;
	box-sizing: border-box;
	transition: border-color var(--dur-1) var(--ease), background var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.smf-form.smf-form--input .smf-textarea-control__control { min-height: 160px; resize: vertical; }
.smf-form.smf-form--input .smf-text-control__control:focus,
.smf-form.smf-form--input .smf-email-control__control:focus,
.smf-form.smf-form--input .smf-tel-control__control:focus,
.smf-form.smf-form--input .smf-url-control__control:focus,
.smf-form.smf-form--input .smf-textarea-control__control:focus,
.smf-form.smf-form--input .smf-select-control__control:focus {
	outline: none; background: #fff; border-color: #888;
	box-shadow: 0 0 0 3px rgba(0,0,0,0.06);
}
.smf-form.smf-form--input .smf-radio-buttons-control,
.smf-form.smf-form--input .smf-checkboxes-control { display: block; }
.smf-form.smf-form--input .smf-radio-buttons-control__control,
.smf-form.smf-form--input .smf-checkboxes-control__control {
	display: flex; flex-direction: column; gap: 0.55em;
}
.smf-form.smf-form--input .smf-label {
	display: inline-flex; align-items: flex-start; gap: 0.5em;
	line-height: 1.5; cursor: pointer;
}
.smf-form.smf-form--input .smf-item--required:has(.smf-checkboxes-control) {
	padding: 1.25em; background: var(--c-bg-warm);
	border: 1px solid #e5e2d9; border-radius: 4px;
	margin-top: 0.5em;
}
.smf-form .smf-error-messages { margin-top: 0.4em; color: var(--c-cta-warning); font-size: 0.85em; }

.smf-form + .smf-action,
.smf-action {
	display: block; text-align: center;
	margin: 2.5em auto 0;
}
.smf-action .smf-button-control { display: inline-block; margin: 0 0.4em; }
.smf-action .smf-button-control__control {
	min-width: 200px;
	padding: 0.85em 1.5em;
	font-family: var(--ff-display);
	font-size: clamp(0.78rem, 0.3vw + 0.7rem, 0.85rem); font-weight: 600;
	letter-spacing: 0.18em;
	color: #fff; background: var(--c-ink); background-image: none;
	border: 1px solid var(--c-ink); border-radius: 0;
	transition: background var(--dur-1) var(--ease);
}
.smf-action .smf-button-control__control:hover { background: #000; }
.smf-action .smf-button-control--back .smf-button-control__control {
	color: var(--c-ink); background: #e5e5e5; border-color: #d0d0d0;
}
.smf-form.smf-form--confirm .smf-item {
	padding: 1em 0; border-bottom: 1px solid var(--c-line-soft);
}
.smf-form.smf-form--confirm .smf-item__label {
	font-weight: 600; color: var(--c-mute); font-size: 0.9em; margin-bottom: 0.35em;
}

/* ============================================================
   送信完了画面 (smf-form--complete) と確認画面 (smf-form--confirm) の
   共通 / SP 対応（2026-05-18 SP 表示崩れ修正）
   ============================================================ */
.smf-form.smf-form--complete,
.smf-form.smf-form--confirm {
	max-width: 720px;
	margin: 0 auto;
	padding: 1.5rem 1.25rem;
	box-sizing: border-box;
}
.smf-form.smf-form--complete p,
.smf-form.smf-form--confirm p {
	line-height: 1.85;
	word-break: keep-all;
	overflow-wrap: anywhere;
	max-width: 100%;
}
/* confirm 画面の dl/dt/dd（入力内容確認）も枠内に収める */
.smf-form.smf-form--confirm .smf-item,
.smf-form.smf-form--confirm .smf-item__controls {
	max-width: 100%;
	box-sizing: border-box;
	word-break: break-word;
	overflow-wrap: anywhere;
}

@media (max-width: 767px) {
	.smf-form.smf-form--complete,
	.smf-form.smf-form--confirm {
		padding: 1.2rem 1rem;
	}
	.smf-form.smf-form--complete p,
	.smf-form.smf-form--confirm p {
		font-size: clamp(0.88rem, 0.4vw + 0.8rem, 0.95rem);
	}
	/* 戻る/送信ボタンは縦並びで横幅 100% に */
	.smf-action { margin-top: 1.8em; }
	.smf-action .smf-button-control { display: block; margin: 0.5em auto; }
	.smf-action .smf-button-control__control { width: 100%; min-width: 0; }
}
