@charset "UTF-8";

body {
	overflow-x: hidden;
}

/* 全体的な横スクロール防止 */
*, *::before, *::after {
	max-width: 100%;
	box-sizing: border-box;
}

/* wrapper要素の制御 */
.wrapper {
	width: 100%;
	max-width: 100%;
	overflow-x: hidden;
}

#contact-block.wrapper {
	overflow: hidden;
}

#contact-block > .container,
#contact-form-block > .container {
	width: 100%;
	max-width: 100%;
	padding-inline: var(--space1);
	padding-inline: 0;
	overflow-x: hidden;
}

#contact-block > .container {
	padding-inline: var(--space1);
}

#contact-form-block .container {
	padding-inline: 0;
}

#form-block > .container {
	padding-inline: 0;
}

#page-title-block + .wrapper {
	padding-bottom: var(--space8);
}

:not(#Top) .wrapper {
	/* padding-bottom: 0; */
	margin-bottom: 0;
}

:not(#Top) .wrapper.pb08 {
	padding-bottom: var(--space8);
}


/* 4つのアイコン 電話番号、FAX、メールアドレス、FAQ */
.contact-list {
	width: 100%;
	max-width: 930px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space5) var(--space2);
	line-height: 1.5;
	margin-inline: auto;
}

.contact-list__item {
	width: 180px;
	max-width: 100%;
	display: grid;
	grid-template-rows: auto 1fr;
	gap: var(--space1);
}

.contact-list__item a {
	display: grid;
	grid-template-rows: auto 1fr;
	gap: var(--space1);
}

.contact-list__item-icon {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1/1;
	object-fit: contain;
	object-position: center;
	border-radius: var(--radius1);
	overflow: hidden;
	padding: 28%;
	background-color: var(--color_grey01);
}

.contact-list__item a:hover .contact-list__item-icon {
	color: var(--color01);
	background-color: var(--color02);
    transform: scale(1.02) translateY(-2px);
    transition: var(--transition_primary);
    -webkit-transition: var(--transition_primary);
    -moz-transition: var(--transition_primary);
    -ms-transition: var(--transition_primary);
    -o-transition: var(--transition_primary);
    box-shadow: 3px 3px 20px rgba(107, 125, 128, 0.2);
}

.contact-list__item-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.contact-list__item a:hover .contact-list__item-text p {
	transform: scale(1.05) translateY(-2px);
	transition: var(--transition_primary);
    -webkit-transition: var(--transition_primary);
    -moz-transition: var(--transition_primary);
    -ms-transition: var(--transition_primary);
    -o-transition: var(--transition_primary);
}

@keyframes zoomIn {
	from {
	  opacity: 0;
	  transform: scale(0.9);
	}
	50% {
		opacity: 0;
		transform: scale(0.9);
	}
	90% {
		transform: scale(1.05);
	}
	100% {
	  opacity: 1;
	  transform: scale(1);
	}
}

.contact-block.js-inview.is-show .contact-list__item:nth-of-type(1) figure img {
	animation: zoomIn 1s 0.2s ease forwards;
}
.contact-block.js-inview.is-show .contact-list__item:nth-of-type(2) figure img {
	animation: zoomIn 1s 0.3s ease forwards;
}
.contact-block.js-inview.is-show .contact-list__item:nth-of-type(3) figure img {
	animation: zoomIn 1s 0.4s ease forwards;
}
.contact-block.js-inview.is-show .contact-list__item:nth-of-type(4) figure img {
	animation: zoomIn 1s 0.5s ease forwards;
}


/* メールフォーム フォーム */
#form-block {
	margin-top: 0;
}

#form-block .content {
	max-width: 700px;
	margin: 0 auto;
}

#form-block .form-lead {
	background-color: var(--color06);
	margin-bottom: 60px;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}

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

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

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

#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: #DE3030;
	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: #999;
	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 input[type="text"],
#form-block .form-unit input[type="email"],
#form-block .form-unit input[type="tel"],
#form-block .form-unit input[type="number"],
#form-block .form-unit textarea {
	width: 100%;
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}

#form-block .form-unit select {
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}

#form-block .form-unit input[type="text"],
#form-block .form-unit input[type="email"],
#form-block .form-unit input[type="tel"],
#form-block .form-unit input[type="number"],
#form-block .form-unit select {
	height: 36px;
	padding: 10px;
}

#form-block .form-unit input[type="radio"]{
	width: 1.5em;
	height: 1.5em;
	margin: 0;
}

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

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

#form-block .submit-btn__unit .conf-btn {
	font-size: 15px;
	line-height: 1.2;
	font-weight: var(--fw_bold);
	text-align: center;
	text-decoration: none;
	padding: 15px;
	display: block;
	margin: 0 auto;
	transition: 0.3s;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-ms-transition: 0.3s;
	-o-transition: 0.3s;
	background-color: #333;
	color: #fff;
	width: min(240px, 100%);
}

#form-block .submit-btn__unit .conf-btn:hover {
	background-color: #999;
}


/* メールフォーム エラー、成功時のメッセージ */
.contact-form-basecore-error {
	color: #DE3030;
}

.contact-form-basecore-success {
	color: #000;
}

/* contactform7プラグイン フォーム */
.wpcf7-form-control.wpcf7-radio.radio-content {
	display: flex;
	flex-wrap: wrap;
	gap: 0 1em;
	margin-left: 0 !important;
}

.wpcf7-list-item{
	margin-left: 0 !important;
	margin-bottom: 0 !important;
}

.wpcf7-list-item label {
	display: inline-flex;
	align-items: center;
	gap: 0.2em;
}

.wpcf7-list-item input[type="checkbox"] {
	width: 1.2em;
	height: 1.2em;
	margin: 0;
	margin-right: 0.2em;
	transform: scale(1.2);
}

.submit__unit p {
	text-align: center;
	margin-top: 1em;
}

.wpcf7-spinner {
	display: none !important;
}

/* 送信ボタン */
.wpcf7-form-control.wpcf7-submit {
	min-width: 200px;
	max-width: 100%;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	gap: var(--space2);
	font-size: clamp(15px, 16 / 768 * 100vw, 16px);
	font-weight: var(--fw_medium);
	line-height: 1.5;
	letter-spacing: 0.05em;
	text-decoration: none;
	color: var(--color_white);
	background-color: var(--color01);
	border: 2px solid var(--color01);
	margin: 0;
	padding: var(--space1) var(--space3);
	border-radius: 9999px;
	transition: var(--transition_primary);
	-webkit-transition: var(--transition_primary);
	-moz-transition: var(--transition_primary);
	-ms-transition: var(--transition_primary);
	-o-transition: var(--transition_primary);
}

.wpcf7-form-control.wpcf7-submit:hover {
	background-color: var(--color_white);
	color: var(--color01);
	transform: scale(1.02) translateY(-2px);
	transition: var(--transition_primary);
	-webkit-transition: var(--transition_primary);
	-moz-transition: var(--transition_primary);
	-ms-transition: var(--transition_primary);
	-o-transition: var(--transition_primary);
	box-shadow: 3px 3px 10px rgba(74, 166, 194, 0.3);
}

.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
    border-color: var(--color03);
	text-align: center;
	padding: 1em;
	border-radius: 5px;
	background-color: var(--color04);
	color: var(--color_black);
}



/* reCAPTCHAバッジの制御 */

/* 基本設定 - reCAPTCHAバッジの表示設定 */
.grecaptcha-badge {
	/* visibility: visible !important; */
	/* opacity: 1 !important; */
	/* pointer-events: auto !important; */
	/* position: fixed !important; */
	/* bottom: 14px !important; */
	/* right: 14px !important; */
	bottom: 72px !important;
	z-index: 1000 !important;
	/* display: block !important; */
}



/* reCAPTCHAプライバシー文言の基本スタイル */
.recaptcha-privacy-notice {
    font-size: 12px;
    color: #666;
    margin-top: 1.5em;
    text-align: center;
    line-height: 1.4;
}

.recaptcha-privacy-notice a {
    color: #1976d2;
    text-decoration: none;
}

.recaptcha-privacy-notice a:hover {
    text-decoration: underline;
}

/* お問い合わせページでのreCAPTCHAプライバシー文言のスタイル */
.page-contact .recaptcha-privacy-notice,
.page-id-contact .recaptcha-privacy-notice {
    font-size: 12px;
    color: #666;
    margin-top: 10px;
    text-align: center;
    line-height: 1.4;
}

.page-contact .recaptcha-privacy-notice a,
.page-id-contact .recaptcha-privacy-notice a {
    color: #1976d2;
    text-decoration: none;
}

.page-contact .recaptcha-privacy-notice a:hover,
.page-id-contact .recaptcha-privacy-notice a:hover {
    text-decoration: underline;
}



/* スマートフォン用 - ブレイクポイント768 */
@media screen and (max-width: 768px) {
	/* より厳格な横スクロール防止 */
	/* より厳格な横スクロール防止 */
	* {
		max-width: 100% !important;
	}

	body, html {
		overflow-x: hidden !important;
	}

	/* コンテナの横スクロール防止 */
	.container {
		/* width: 100% !important;
		max-width: 100% !important; */
		/* padding-inline: var(--space1); */
		/* box-sizing: border-box; */
	}

	/* タイトル部分の横スクロール防止 */
	.cont-ttl {
		width: 100%;
		max-width: 100%;
		overflow: hidden;
	}

	.point-label {
		width: 100%;
		max-width: 100%;
		overflow: hidden;
	}

	.point-text {
		font-size: clamp(20px, 5vw, 32px) !important;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.contact-block .big-text {
		font-size: clamp(18px, 4.5vw, 28px);
	}

	/* 4つのアイコン 電話番号、FAX、メールアドレス、FAQ */
	.contact-list {
		width: 100%;
		gap: var(--space2);
	}

	.contact-list__item {
		width: calc(50% - var(--space2) / 2);
		max-width: 160px;
		gap: var(--space2);
		justify-content: center;
		justify-items: center;
	}

	.contact-list__item a {
		place-items: center;
		margin-inline: auto;
		gap: var(--space2);
	}

	.contact-list__item-icon {
		width: 80px;
		height: 80px;
		padding: 20px;
		aspect-ratio: 1/1;
		border-radius: 8px;
	}

	.contact-list__item-text {
		line-height: 1.5;
	}

	.contact-list__item-text p:first-of-type {
		font-size: 14px;
	}

	/* メールフォーム */
	#form-block .content {
		max-width: 480px;
	}

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

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

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

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

	#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: 30px;
	}
	
	#form-block .submit-btn__unit .conf-btn {
		font-size: 14px;
		width: min(220px, 90%);
	}
	#form-block .form-unit input[type="text"],
	#form-block .form-unit input[type="email"],
	#form-block .form-unit input[type="tel"],
	#form-block .form-unit input[type="number"],
	#form-block .form-unit select,
	#form-block .form-unit textarea {
		font-size: 16px;
	}



}

@media screen and (max-width: 480px) {
	#form-block > .content {
		max-width: 100%;
		padding: 0 var(--space1);
	}
	
	/* タイトル部分をより小さく */
	.point-text {
		font-size: clamp(16px, 4vw, 24px) !important;
	}

	.contact-block .big-text {
		font-size: clamp(16px, 4vw, 22px) !important;
	}
	
	/* 4つのアイコンの横スクロール防止 */
	.contact-list {
		width: 100%;
		gap: var(--space1);
		margin: 0;
	}

	.contact-list__item {
		width: calc(50% - var(--space1) / 2);
		max-width: 140px;
		min-width: 120px;
	}

	.contact-list__item-icon {
		width: 60px;
		height: 60px;
		padding: 15px;
	}
	
	/* 送信ボタンの横スクロール防止 */
	.wpcf7-form-control.wpcf7-submit {
		min-width: 160px;
		width: auto;
		max-width: 90%;
	}
	
	#form-block .submit-btn__unit .conf-btn {
		width: min(200px, 90%);
	}

}


/* 送信完了用 */
#finish-block.wrapper {
	overflow: hidden;
}

#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 .finish-comment {
		font-size: 15px;
	}

}

