.contact-guides {
	width: min(1100px, 95%);
	margin: 1rem auto 1rem;
	padding: clamp(14px, 2vw, 18px) clamp(14px, 2vw, 18px);
	background: #fff;
	border: 2px solid var(--grey);
	border-radius: 12px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}
.contact-guides__title {
	margin: 0 0 0.3em 0;
	font-size: clamp(1.7rem, 2.3vw, 2.1rem);
	font-weight: 800;
	color: var(--brown2);
	letter-spacing: 0.01em;
}
.contact-guides__lead {
	margin: 0 0 10px 0;
	color: #6f6a73;
	line-height: 1.8;
	font-weight: 600;
}
.contact-guides__list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(12px, 1.8vw, 18px);
	list-style: none;
	padding: 0;
	margin: 8px 0 0 0;
}
.contact-guides__list li {
	padding: clamp(12px, 1.8vw, 16px);
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 10px;
	background: #fcfcfd;
}
.contact-guides__list i {
	display: inline-block;
	margin-right: 0.5em;
	font-size: 2rem;
	line-height: 1;
	color: #8aa67c;
	vertical-align: -2px;
}
.contact-guides__list h4 {
	margin: 0 0 0.35em 0;
	font-size: clamp(1.35rem, 2vw, 1.6rem);
	font-weight: 700;
	color: #333;
}
.contact-guides__list p {
	margin: 0;
	color: #555;
	font-size: 1.3rem;
	line-height: 1.7;
}
.CMS-FORM {
	padding: 2.4rem;
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.25);
	border-radius: 0.8rem;
}
.CMS-FORM-INPUT,
.CMS-FORM-EMAIL,
.CMS-FORM-GROUP textarea {
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.3);
	border-radius: 0.4rem;
}
.CMS-FORM-INPUT:focus,
.CMS-FORM-EMAIL:focus,
.CMS-FORM-GROUP textarea:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(162, 150, 199, 0.25);
}
.optional {
	padding: 0.4rem 0.7rem;
	margin-left: 1rem;
	background: #9aa4b2;
	color: #fff;
	font-size: 1rem;
	line-height: 1;
	border-radius: 10rem;
}
.privacy {
	border: 1px solid rgba(0, 0, 0, 0.3);
	border-radius: 0.6rem;
}
@media (max-width: 640px) {
	:root {
		--gutter: 0px;
		--card-max: 640px;
	}
	.page-ttl {
		position: relative; 
		height: 8rem;
		background-image: url("../img/plan-header-bg_sp.webp"); 
		background-size: cover;
		background-position: center;
		display: flex; 
		justify-content: center;
		align-items: center;
		text-align: center;
		margin-bottom: 2rem;
	}
	.page-ttl::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-color: rgba(0, 0, 0, 0.4); 
		z-index: 1; 
	}
	.page-ttl h2 {
		position: relative; 
		z-index: 2;
		font-size: 2.6rem;
		font-weight: 800;
		color: #fff; 
		margin: 0;
	}
	.ttl {
		color: #6d558d;
		font-weight: 800;
		font-size: 2.6rem;
		margin: 1rem 16px 0.6rem;
	}
	.container {
		padding-left: max(var(--gutter), env(safe-area-inset-left, 0px));
		padding-right: max(var(--gutter), env(safe-area-inset-right, 0px));
		overflow: visible;
	}
	.contact-guides,
	section.contact-guides {
		width: 100%;
		padding: 0 16px;
		margin: 0 auto !important;
		box-sizing: border-box;
		overflow: visible;
	}
	section.contact-guides.fade,
	section.contact-guides.fade.is-animation {
		margin: 0 auto !important;
	}
	.contact-guides__title {
		color: #6d558d;
		font-weight: 800;
		margin: 0 0 0.4rem;
		text-align: center;
	}
	.contact-guides__lead {
		margin: 0.1rem 0 0.8rem;
		color: #6b7280;
		font-size: 1.3rem;
		line-height: 1.9;
		text-align: center;
	}
	.contact-guides__list {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0.8rem;
		padding: 0;
		margin: 0;
		width: 100%;
		justify-items: center;
	}
	.contact-guides__list li {
		width: calc(100% - var(--gutter) * 2);
		max-width: var(--card-max);
		margin: 0.8rem auto;
		padding: 1rem;
		background: #fff;
		border: 1px solid #eee;
		border-radius: 12px;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
		box-sizing: border-box;
	}
	.contact-guides__list i {
		color: #6b67a0;
		font-size: 1.8rem;
		margin-right: 0.5em;
	}
	.contact-guides__list h4 {
		margin: 0.2rem 0;
		font-size: 1.6rem;
		color: #333;
	}
	.contact-guides__list p {
		margin: 0;
		font-size: 1.35rem;
		line-height: 1.8;
		color: #555;
	}
	.CMS-FORM {
		width: calc(100% - var(--gutter) * 2);
		max-width: var(--card-max);
		margin-inline: auto;
		padding: 1.2rem;
		background: #fff;
		border: 1px solid #eee;
		border-radius: 12px;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
		box-sizing: border-box;
		overflow: hidden;
	}
	section.contact-form.fade,
	section.contact-form.fade.is-animation {
		margin: 0 auto !important;
	}
	.CMS-FORM-GROUP {
		margin: 0 0 1rem;
	}
	.CMS-FORM-INPUT,
	.CMS-FORM-EMAIL,
	.CMS-FORM-TEXTAREA {
		display: block;
		width: 100%;
		font-size: 1.6rem;
		line-height: 1.6;
		padding: 0.8rem 1rem;
		border: 1px solid rgba(0, 0, 0, 0.22);
		border-radius: 10px;
		background: #fff;
		box-sizing: border-box;
	}
	.CMS-FORM-TEXTAREA {
		min-height: 9.5rem;
	}
	.CMS-FORM-INPUT:focus,
	.CMS-FORM-EMAIL:focus,
	.CMS-FORM-TEXTAREA:focus {
		outline: none;
		border-color: #6d558d;
		box-shadow: 0 0 0 3px rgba(109, 85, 141, 0.25);
	}
	.CMS-FORM-INPUT-LABEL,
	.CMS-FORM-TEXTAREA-LABEL {
		display: block;
		font-weight: 800;
		color: #333;
		margin: 0 0 0.35rem;
	}
	.required,
	.optional {
		display: inline-block;
		margin-left: 0.6rem;
		padding: 0.35rem 0.65rem;
		border-radius: 9999px;
		font-size: 1.1rem;
		line-height: 1;
		color: #fff;
	}
	.required {
		background: #a91b50;
	}
	.optional {
		background: #9aa4b2;
	}
	.CMS-FORM-GROUP input[type="submit"] {
		appearance: none;
		-webkit-appearance: none;
		border: 0;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		border-radius: 9999px;
		padding: 1rem 1.2rem;
		background: #6b67a0;
		color: #fff;
		font-weight: 800;
		font-size: 1.5rem;
		box-shadow: 0 6px 16px rgba(107, 103, 160, 0.25);
	}
	.CMS-FORM-GROUP input[type="submit"]:active {
		transform: translateY(1px);
	}
	#sec-privacy {
		--gutter: 12px;
		--pad-x: 1.2rem;
		--body-fz: 1.3rem;
		--scroll-h: 33vh;
	}
	.privacy-note {
		padding: 0 16px;
		color: #6b7280;
		font-size: 1.3rem;
		line-height: 1.9;
	}
	.privacy {
		width: calc(100% - var(--gutter) * 2);
		max-width: var(--card-max);
		margin-inline: auto;
		padding: 0.9rem var(--pad-x) 1.1rem;
		border: 1px solid #eee;
		border-radius: 12px;
		background: #fff;
		font-size: var(--body-fz);
		line-height: 1.9;
		box-sizing: border-box;
	}
	.privacy .policy-title {
		text-align: center;
		font-weight: 800;
		font-size: 1.7rem;
		margin: 0.2rem 0 0.4rem;
	}
	.privacy .policy-caption {
		text-align: center;
		color: #6b7280;
		font-size: 1.25rem;
		margin: 0 0 2rem;
	}
	.privacy .policy-scroll {
		max-height: var(--scroll-h);
		overflow: auto;
		-webkit-overflow-scrolling: touch;
		padding-right: 0.3rem;
	}
	.privacy .policy-scroll::-webkit-scrollbar {
		width: 8px;
	}
	.privacy .policy-scroll::-webkit-scrollbar-thumb {
		background: rgba(0, 0, 0, 0.15);
		border-radius: 8px;
	}
	img,
	svg,
	video,
	iframe {
		max-width: 100%;
		height: auto;
		display: block;
	}
	html,
	body,
	.site-frame {
		overflow-x: hidden;
	}
} 
@media (min-width: 641px) {
	.page-ttl {
		position: relative;
		height: clamp(100px, 16vh, 200px);
		display: grid;
		place-items: center;
		margin: 0 0 24px;
		background: center / cover no-repeat
			url("../img/plan-header-bg_pc.webp");
	}
	.page-ttl::before {
		content: "";
		position: absolute;
		inset: 0;
		background: rgba(0, 0, 0, 0.35);
	}
	.page-ttl h2 {
		position: relative;
		z-index: 1;
		margin: 0;
		color: #fff;
		font-weight: 800;
		font-size: clamp(3.2rem, 4.8vw, 5.6rem);
		letter-spacing: 0.06em;
		text-shadow: 0 2px 14px rgba(0, 0, 0, 0.45);
	}
	.contact-guides,
	.container > .mb-40,
	#sec-privacy {
		border-top: 1px solid #e8e6f2;
		padding-top: 18px;
		margin-top: 24px;
	}
	.contact-guides {
		width: min(1100px, 95%);
		margin: 18px auto;
	}
	.contact-guides__list {
		grid-template-columns: repeat(4, 1fr);
		gap: clamp(12px, 1.6vw, 18px);
	}
	@media (min-width: 641px) and (max-width: 1024px) {
		.contact-guides__list {
			grid-template-columns: repeat(3, 1fr);
		}
	}
	.CMS-FORM {
		width: min(980px, 95%);
		margin: 8px auto 0;
		padding: 2rem 2.2rem;
		background: #fff;
		border: 1px solid #eee;
		border-radius: 12px;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
	}
	.CMS-FORM-GROUP {
		display: grid;
		grid-template-columns: 16em 1fr;
		align-items: start;
		gap: 0.6rem 1.2rem;
		margin: 0 0 1.1rem;
	}
	.CMS-FORM-INPUT-LABEL,
	.CMS-FORM-TEXTAREA-LABEL {
		grid-column: 1;
		margin: 0.4rem 0 0;
		font-weight: 800;
		color: #333;
		text-align: left;
	}
	.CMS-FORM-INPUT,
	.CMS-FORM-EMAIL,
	.CMS-FORM-TEXTAREA {
		grid-column: 2;
		display: block;
		width: 100%;
		font-size: 1.6rem;
		line-height: 1.6;
		padding: 0.8rem 1rem;
		border: 1px solid rgba(0, 0, 0, 0.22);
		border-radius: 10px;
		background: #fff;
	}
	.CMS-FORM-TEXTAREA {
		min-height: 12rem;
	}
	.CMS-FORM-INPUT:focus,
	.CMS-FORM-EMAIL:focus,
	.CMS-FORM-TEXTAREA:focus {
		outline: none;
		border-color: #6d558d;
		box-shadow: 0 0 0 3px rgba(109, 85, 141, 0.25);
	}
	.required,
	.optional {
		display: inline-block;
		margin-left: 0.6rem;
		padding: 0.35rem 0.65rem;
		border-radius: 9999px;
		font-size: 1.1rem;
		line-height: 1;
		color: #fff;
	}
	.required {
		background: #a91b50;
	}
	.optional {
		background: #9aa4b2;
	}
	.CMS-FORM-GROUP input[type="submit"] {
		grid-column: 1 / -1; 
		justify-self: center; 
		appearance: none;
		-webkit-appearance: none;
		border: 0;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		border-radius: 9999px;
		padding: 0.9rem 1.4rem;
		background: #6b67a0;
		color: #fff;
		font-weight: 800;
		font-size: 1.5rem;
		box-shadow: 0 6px 16px rgba(107, 103, 160, 0.25);
		cursor: pointer;
		margin-top: clamp(16px, 2.2vw, 28px); 
	}
	.CMS-FORM-GROUP input[type="submit"]:active {
		transform: translateY(1px);
	}
	#sec-privacy {
		--scroll-h: 40vh; 
	}
	.privacy-note {
		width: min(980px, 95%);
		margin: 8px auto 10px;
		color: #6b7280;
		font-size: 1.4rem;
		line-height: 1.9;
	}
	.privacy {
		width: min(980px, 95%);
		margin-inline: auto;
		padding: 0.9rem 1.2rem 1.1rem;
		border: 1px solid #eee;
		border-radius: 12px;
		background: #fff;
		font-size: 1.4rem;
		line-height: 1.9;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
	}
	.privacy .policy-title {
		text-align: center;
		font-weight: 800;
		font-size: 1.8rem;
		margin: 0.2rem 0 0.4rem;
	}
	.privacy .policy-caption {
		text-align: center;
		color: #6b7280;
		font-size: 1.3rem;
		margin: 0 0 1.4rem;
	}
	.privacy .policy-scroll {
		max-height: var(--scroll-h);
		overflow: auto;
		padding-right: 0.3rem;
	}
	.privacy .policy-scroll::-webkit-scrollbar {
		width: 8px;
	}
	.privacy .policy-scroll::-webkit-scrollbar-thumb {
		background: rgba(0, 0, 0, 0.15);
		border-radius: 8px;
	}
} 
