@charset "UTF-8";

/* ページトップ */
#topImage-block figure {
	height: 640px;
}

#topImage-block figure img {
	object-position: 50% 50%;
}


/* メールフォーム */
#form-block .content {
	max-width: 960px;
	margin: 0 auto;
	padding: 80px;
	background-color: var(--color_white);
	border-radius: 80px;
	-webkit-border-radius: 80px;
	-moz-border-radius: 80px;
	-ms-border-radius: 80px;
	-o-border-radius: 80px;
}

#form-block .form-lead {
	margin-bottom: 64px;
}

#form-block .form-lead p {
	text-align: center;
	font-size: clamp(14px, 18 / 768 * 100vw, 18px);
	font-weight: var(--fw_jp_bold);
}

#form-block .form-unit dl {
	display: flex;
	justify-content: space-between;
	gap: 5px 20px;
	padding: 12px 0;
}

#form-block .form-unit dl dt {
	width: calc(30% - 20px);
	padding: 0.5em 0;
}

#form-block .form-unit dl dd {
	width: 70%;
}

#form-block .form-unit .req {
	font-size: 13px;
	line-height: 1.0;
	padding: 2px 10px 3px;
	margin-right: 10px;
	background: var(--color01);
	color: var(--color_white);
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}

#form-block .form-unit .any {
	font-size: 13px;
	line-height: 1.0;
	padding: 2px 10px 3px;
	margin-right: 10px;
	background: var(--color_gray02);
	color: var(--color_white);
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}

::placeholder {
	color: var(--color_gray02);
}

#form-block .form-unit input[type="text"],
#form-block .form-unit textarea {
	width: 100%;
	border: 1px solid var(--color03);
	background: var(--color03);
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}

#form-block .form-unit select,
#form-block .form-unit input[type="date"] {
	border: 1px solid var(--color_gray03);
	background: var(--color_white);
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
	color: var(--color_gray02);
}

#form-block .form-unit input[type="text"],
#form-block .form-unit input[type="date"],
#form-block .form-unit select {
	height: 48px;
}

#form-block .form-unit textarea {
	height: 300px;
}

#form-block .submit-btn__unit {
	margin-top: 64px;
}

#form-block .submit-btn__unit .conf-btn {
	font-size: 15px;
	line-height: 1.6;
	font-weight: var(--fw_jp_bold);
	letter-spacing: 0.05em;
	text-decoration: none;
	display: block;
	margin: 0 auto;
	padding: 8px 40px 8px 16px;
	position: relative;
	transition: ease 0.3s;
	-webkit-transition: ease 0.3s;
	-moz-transition: ease 0.3s;
	-ms-transition: ease 0.3s;
	-o-transition: ease 0.3s;
	border-radius: 48px;
	-webkit-border-radius: 48px;
	-moz-border-radius: 48px;
	-ms-border-radius: 48px;
	-o-border-radius: 48px;
	width: 100%;
	overflow: hidden;
	max-width: 240px;
	color: var(--color_white);
	background-color: var(--color01);
	text-align: left;
}
#form-block .submit-btn__unit .conf-btn::after {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	z-index: 3;
	width: 24px;
	aspect-ratio: 1/1;
	background-repeat: no-repeat;
	background-size: 50%;
	background-position: center;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-ms-border-radius: 50%;
	-o-border-radius: 50%;
	transition: .4s;
	-webkit-transition: .4s;
	-moz-transition: .4s;
	-ms-transition: .4s;
	-o-transition: .4s;
	background-image: url(../img/common/icon_arrow-right_white.svg);
	border: 1px solid var(--color_white);
}
#form-block .submit-btn__unit .conf-btn:hover::after {
	right: 6px;
}
#form-block .submit-btn__unit .conf-btn::before {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-webkit-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-moz-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-ms-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-o-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	-webkit-transform: scale(0, 1);
	-moz-transform: scale(0, 1);
	-ms-transform: scale(0, 1);
	-o-transform: scale(0, 1);
	transform-origin: right top;
	background-color: var(--color05);
}
#form-block .submit-btn__unit .conf-btn:hover::before {
	transform-origin:left top;
	transform:scale(1, 1);
}

#form-block .submit-btn__unit .conf-btn span {
	position: relative;
	z-index: 3;
}



/* スマートフォン用 - ブレイクポイント768 */
@media screen and (max-width: 768px) {

	/* ページトップ */
	#topImage-block figure {
		height: 240px;
	}


	/* メールフォーム */
	#form-block .content {
		max-width: 480px;
		padding: 40px 24px;
		border-radius: 40px;
		-webkit-border-radius: 40px;
		-moz-border-radius: 40px;
		-ms-border-radius: 40px;
		-o-border-radius: 40px;
	}

	#form-block .form-lead {
		margin-bottom: 24px;
	}

	#form-block .form-lead p {
		text-align: justify;
	}

	#form-block .form-unit dl {
		flex-direction: column;
	}

	#form-block .form-unit dl dt {
		width: 100%;
		padding: 0;
	}

	#form-block .form-unit dl dd {
		width: 100%;
	}

	#form-block .form-unit .req {
		font-size: 12px;
	}

	#form-block .form-unit .any {
		font-size: 12px;
	}

	#form-block .submit-btn__unit {
		margin-top: 24px;
	}

	#form-block .submit-btn__unit .conf-btn {
		font-size: 14px;
		width: 220px;
	}

}



/* 確認画面用 */
#confirm-block {
	margin-top: 80px;
}

#confirm-block .content {
	max-width: 960px;
	margin: 0 auto;
	padding: 80px;
	background-color: var(--color_white);
	border-radius: 80px;
	-webkit-border-radius: 80px;
	-moz-border-radius: 80px;
	-ms-border-radius: 80px;
	-o-border-radius: 80px;
}

#confirm-block .confirm-ttl {
	font-size: 24px;
	line-height: 1.5;
	font-weight: var(--fw_jp_bold);
	letter-spacing: 0.1em;
	font-weight: 500;
	text-align: center;
	color: var(--color_gray02);
	margin-bottom: 30px;
}

#confirm-block .confirm-lead {
	margin-bottom: 30px;
	text-align: center;
}

#confirm-block .confirm-unit dl {
	display: flex;
	justify-content: space-between;
	gap: 5px 20px;
	padding: 30px 0;
	border-bottom: 1px solid var(--color_gray03);
}

#confirm-block .confirm-unit dl:first-of-type {
	border-top: 1px solid var(--color_gray03);
}

#confirm-block .confirm-unit dl dt {
	width: calc(30% - 20px);
	font-weight: var(--fw_jp_bold);
}

#confirm-block .confirm-unit dl dd {
	width: 70%;
}

#confirm-block .confirm-unit .err {
	color: #d12926;
}

#confirm-block .submit-btn__unit {
	display: flex;
	justify-content: center;
	width: 100%;
	margin: 64px auto 0;
	gap: 10px 20px;
	max-width: 560px;
}

#confirm-block .submit-btn__unit .submit-btn {
	font-size: 15px;
	line-height: 1.6;
	font-weight: var(--fw_jp_bold);
	letter-spacing: 0.05em;
	text-decoration: none;
	display: block;
	margin: 0 auto;
	padding: 8px 40px 8px 16px;
	position: relative;
	transition: ease 0.3s;
	-webkit-transition: ease 0.3s;
	-moz-transition: ease 0.3s;
	-ms-transition: ease 0.3s;
	-o-transition: ease 0.3s;
	border-radius: 48px;
	-webkit-border-radius: 48px;
	-moz-border-radius: 48px;
	-ms-border-radius: 48px;
	-o-border-radius: 48px;
	width: 100%;
	overflow: hidden;
	max-width: 240px;
	color: var(--color_white);
	background-color: var(--color01);
	text-align: left;
}
#confirm-block .submit-btn__unit .submit-btn::after {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	z-index: 3;
	width: 24px;
	aspect-ratio: 1/1;
	background-repeat: no-repeat;
	background-size: 50%;
	background-position: center;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-ms-border-radius: 50%;
	-o-border-radius: 50%;
	transition: .4s;
	-webkit-transition: .4s;
	-moz-transition: .4s;
	-ms-transition: .4s;
	-o-transition: .4s;
	background-image: url(../img/common/icon_arrow-right_white.svg);
	border: 1px solid var(--color_white);
}
#confirm-block .submit-btn__unit .submit-btn:hover::after {
	right: 6px;
}
#confirm-block .submit-btn__unit .submit-btn::before {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-webkit-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-moz-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-ms-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-o-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	-webkit-transform: scale(0, 1);
	-moz-transform: scale(0, 1);
	-ms-transform: scale(0, 1);
	-o-transform: scale(0, 1);
	transform-origin: right top;
	background-color: var(--color05);
}
#confirm-block .submit-btn__unit .submit-btn:hover::before {
	transform-origin:left top;
	transform:scale(1, 1);
}

#confirm-block .submit-btn__unit .submit-btn span {
	position: relative;
	z-index: 3;
}

#confirm-block .submit-btn__unit .back-btn {
	font-size: 15px;
	line-height: 1.6;
	font-weight: var(--fw_jp_bold);
	letter-spacing: 0.05em;
	text-decoration: none;
	display: block;
	margin: 0 auto;
	padding: 8px 40px 8px 16px;
	position: relative;
	transition: ease 0.3s;
	-webkit-transition: ease 0.3s;
	-moz-transition: ease 0.3s;
	-ms-transition: ease 0.3s;
	-o-transition: ease 0.3s;
	border-radius: 48px;
	-webkit-border-radius: 48px;
	-moz-border-radius: 48px;
	-ms-border-radius: 48px;
	-o-border-radius: 48px;
	width: 100%;
	overflow: hidden;
	max-width: 240px;
	color: var(--color_white);
	background-color: var(--color_gray02);
	text-align: left;
}
#confirm-block .submit-btn__unit .back-btn::after {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	z-index: 3;
	width: 24px;
	aspect-ratio: 1/1;
	background-repeat: no-repeat;
	background-size: 50%;
	background-position: center;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-ms-border-radius: 50%;
	-o-border-radius: 50%;
	transition: .4s;
	-webkit-transition: .4s;
	-moz-transition: .4s;
	-ms-transition: .4s;
	-o-transition: .4s;
	background-image: url(../img/common/icon_arrow-right_white.svg);
	border: 1px solid var(--color_white);
}
#confirm-block .submit-btn__unit .back-btn:hover::after {
	right: 6px;
}
#confirm-block .submit-btn__unit .back-btn::before {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-webkit-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-moz-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-ms-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	-o-transition: transform .4s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	-webkit-transform: scale(0, 1);
	-moz-transform: scale(0, 1);
	-ms-transform: scale(0, 1);
	-o-transform: scale(0, 1);
	transform-origin: right top;
	background-color: var(--color_gray01);
}
#confirm-block .submit-btn__unit .back-btn:hover::before {
	transform-origin:left top;
	transform:scale(1, 1);
}

#confirm-block .submit-btn__unit .back-btn span {
	position: relative;
	z-index: 3;
}



/* スマートフォン用 */
@media screen and (max-width: 768px) {

	/* 確認画面用 */
	#confirm-block {
		margin-top: 40px;
	}

	#confirm-block .content {
		max-width: 480px;
		padding: 40px 24px;
		border-radius: 40px;
		-webkit-border-radius: 40px;
		-moz-border-radius: 40px;
		-ms-border-radius: 40px;
		-o-border-radius: 40px;
	}

	#confirm-block .confirm-ttl {
		font-size: 18px;
		letter-spacing: 0;
		margin-bottom: 20px;
	}

	#confirm-block .confirm-lead {
		margin-bottom: 20px;
	}

	#confirm-block .confirm-unit dl {
		flex-direction: column;
	}

	#confirm-block .confirm-unit dl dt {
		width: 100%;
		color: var(--color_gray02);
	}

	#confirm-block .confirm-unit dl dd {
		width: 100%;
	}

	#confirm-block .submit-btn__unit {
		flex-direction: column;
		margin: 30px auto 0;
	}

	#confirm-block .submit-btn__unit .submit-btn {
		font-size: 14px;
		max-width: 220px;
	}

	#confirm-block .submit-btn__unit .back-btn {
		font-size: 14px;
		max-width: 220px;
	}

}



/* 送信完了用 */
#finish-block {
	margin-top: 80px;
}

#finish-block .cont-ttl .cont-ttl--jp {
	text-align: center;
}

#finish-block .cont-ttl .cont-ttl--sub {
	text-align: center;
}

#finish-block .finish-comment {
	font-size: 18px;
	line-height: 2.0;
	text-align: center;
	margin: 50px auto;
}

#finish-block .link-btn__unit .link-btn {
	margin: 0 auto;
}



/* スマートフォン用 */
@media screen and (max-width: 768px) {

	/* 送信完了用 */
	#finish-block {
		margin-top: 40px;
	}

	#finish-block .finish-comment {
		font-size: 14px;
	}

}

