@charset "UTF-8";

body {
	background: none !important;
	overflow: visible;
}

.bottom-svg {
	display: none;
}

.wrap .bottom-svg {
	display: block;
	margin-top: 117px;
}

.page-title {
	height: 554px;
	position: relative;
	z-index: -1;
}

.wrap {
	background: url(../img/body.webp);
	background-repeat: repeat;
	border-radius: 50px 50px 0 0;
	margin: -40px auto 0;
	padding-top: 104px;
	color: #1F1F1F;
	width: 100%;
}

.wrap p {
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 1.875;
}

h2.situation {
	font-size: 30px;
	letter-spacing: .08em;
	line-height: 2;
	text-align: center;
}

/* プライバシーポリシー */

.page-title .privacypolicy {
	background: url(../img/page/contact/privacy-title.webp) no-repeat;
	background-size: cover;
	background-position: center;
	width: 100%;
	height: 554px;
}

.privacypolicy h1 {
	color: #fff;
	font-size: 50px;
	letter-spacing: .08em;
	line-height: 1.2;
	padding-top: 238px;
	padding-left: 143px;
}

.wrap .privacypolicy {
	margin: 0 auto;
	width: 90%;
	max-width: 1008px;
}

.privacypolicy section {
	margin-top: 67px;
}

.privacypolicy h2 {
	font-size: 25px;
	letter-spacing: .05em;
	line-height: 1.6;
	padding-left: 21px;
	position: relative;
	margin-bottom: 22px;
}

.privacypolicy h2::before {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	background: #005531;
	width: 6px;
	height: 53px;
}

.privacypolicy ol {
	counter-reset: counter;
}

.privacypolicy ol>li {
	counter-increment: counter;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 1.875;
	padding-left: 1em;
	position: relative;
	margin-top: 16px;
}

.privacypolicy ol>li::before {
	content: counter(counter)".";
	position: absolute;
	left: 0;
}

.privacypolicy ol.big>li {
	padding-left: 40px;
}

.privacypolicy ol.big>li::before {
	font-size: 25px;
	font-weight: bold;
	top: -10px;
}

/* お問い合わせ */

.page-title .contact-title {
	background: url(../img/page/contact/contact-title.webp) no-repeat;
	background-size: cover;
	background-position: center;
	width: 100%;
	height: 554px;
}

.contact-title h1 {
	color: #fff;
	font-size: 50px;
	letter-spacing: .08em;
	line-height: 1.2;
	padding-top: 238px;
	padding-left: 143px;
}

.photographer {
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 2.3;
	position: absolute;
	right: 56px;
	bottom: 50px;
}

.ly_form {
	margin: 0 auto;
	width: 90%;
	max-width: 1008px;
}

.please {
	color: #747474;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 2.5;
	text-align: center;
}

.bl_form_group {
	margin-top: 23px;
}

.bl_form_label {
	color: #1F1F1F;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 2.5;
}

.bl_form_required {
	background: #D40000;
	border-radius: 4px;
	color: #fff;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 2.5;
	padding: 0 7px;
	margin-left: 11px;
}

input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
	background: #fff;
	border: none;
	border-radius: 5px;
	box-sizing: border-box;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 2.5;
	padding: 10px 25px 12px;
	resize: vertical;
	width: 100%;
}

textarea {
	height: 241px;
}

/* ラジオ */
fieldset {
	border: none;
	margin: 0;
	padding: 0;
	min-width: 0;
}

fieldset .bl_form_control {
	background: #fff;
	border-radius: 5px;
	box-sizing: border-box;
	padding: 26px 34px;
	width: 100%;
}

.bl_form_group .wpcf7-form-control {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 38px;
}

.bl_form_group .wpcf7-list-item {
	color: #1F1F1F;
	display: block;
	margin: 0;
}

fieldset input[type="radio"] {
	opacity: 0;
	position: absolute;
}

fieldset .wpcf7-list-item-label {
	display: flex;
	align-items: center;
	gap: 9px;
	position: relative;
}

fieldset .wpcf7-list-item-label::before {
	content: "";
	background: #fff;
	border: 1px solid #333;
	border-radius: 50%;
	display: block;
	transition: background-color .5s;
	width: 21px;
	height: 21px;
}

.wpcf7-list-item-label::after {
	content: "";
	position: absolute;
	left: 7px;
	top: 8px;
}

input[type="radio"]:checked + .wpcf7-list-item-label::after {
	content: "";
	background: #14794E;
	border: 1px solid #000;
	border-radius: 50%;
	box-sizing: border-box;
	width: 9px;
	height: 9px;
}

/* ボタン */
.bl_form_btn input,
.send-btn input,
.back-btn input {
	background: #006E3F;
	border: none;
	border-radius: 30px;
	box-sizing: border-box;
	color: #fff;
	display: block;
	font-size: 15px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: .05em;
	padding: 12px 117px 12px 65px;
	max-width: max-content;
	transition: transform .2s cubic-bezier(0.33, 1, 0.68, 1);
}

.bl_form_btn {
	margin: 113px auto 0;
	position: relative;
	width: max-content;
}

.bl_form_btn::before,
.send-btn::before,
.back-btn::before {
	content: "";
	background: url(../img/btn-g.svg) no-repeat;
	background-size: contain;
	position: absolute;
	right: 41px;
	top: 50%;
	transform: translate(0, -50%);
	transition: .2s;
	width: 13px;
	height: 13px;
	z-index: 1;
}

.bl_form_btn::after,
.send-btn::after,
.back-btn::after {
	content: "";
	position: absolute;
	right: 19px;
	top: 11px;
	background: #fff;
	border-radius: 50%;
	width: 60px;
	height: 34px;
	transition: .2s all;
}

.bl_form_btn:hover::before,
.send-btn:hover::before,
.back-btn:hover::before {
	content: "";
	right: 3px;
	transition: .2s all;
}

.bl_form_btn:hover::after,
.send-btn:hover::after,
.back-btn:hover::after {
	right: -17px;
}

.btns {
	margin: 82px auto 0;
	width: 278px;
}

.send-btn,
.back-btn {
	position: relative;
}

.send-btn input {
	font-size: 20px;
	line-height: 1.2;
	padding: 15px 0 17px;
	width: 100%;
	max-width: none;
}

.back-btn {
	margin-top: 18px;
}

.back-btn input {
	background: #fff;
	border: 1px solid #006E3F;
	box-sizing: border-box;
	color: #1F1F1F;
	padding: 13px 110px 13px 57px;
	width: 100%;
}

.back-btn::before {
	content: "";
	background: url(../img/btn-w.svg) no-repeat;
	background-size: contain;
}

.back-btn::after {
	background: #006E3F;
}

/* 2カラム用 */
.bl_form_group .col {
	display: flex;
	gap: 32px;
}

.bl_form_group .col input {
	max-width: 288px;
}

.bl_form_group .col .bl_form_control:has(#addr) {
	width: 100%;
}

.bl_form_group .col #zip {
	max-width: 160px;
}

.bl_form_group .col #addr {
	max-width: none;
	width: 100%;
}

#autozip {
	display: none !important;
}

/* 同意 */

.bl_form_consent {
	margin-top: 35px;
}

.bl_form_consent .bl_form_required {
	margin-left: 0;
	margin-right: 19px;
}

.bl_form_consent input[type="checkbox"] {
	display: none;
}

.bl_form_consent .wpcf7-list-item {
	position: relative;
	margin: 0;
}

.bl_form_consent .wpcf7-list-item a {
	border-bottom: 1px solid #000;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 2.5;
	margin-left: 47px;
}

.bl_form_consent .wpcf7-list-item-label:before {
	position: absolute;
	top: 6px;
	left: 0;
	display: block;
	background: #fff;
	border: 1px solid #C1C1C1;
	width: 31px;
	height: 31px;
}

.bl_form_consent .wpcf7-list-item-label::before,
.bl_form_consent .wpcf7-list-item-label::after {
	content: "";
}

.bl_form_consent input[type="checkbox"]:checked+.wpcf7-list-item-label:after {
	width: 10px;
	height: 15px;
	transform: translateY(-50%) rotate(45deg);
	top: 20px;
	left: 10px;
	border: none;
	border-right: 2px solid #C30D23;
	border-bottom: 2px solid #C30D23;
	content: '';
	display: block;
	position: absolute;
	transition: .1s;
}

.bl_formConfirm .approval {
	display: none;
}

/* 確認画面とメッセージ、スピナーを非表示 */
.bl_formConfirm,
.wpcf7-response-output,
.bl_formConfirm .wpcf7-spinner {
	display: none;
}

.bl_formConfirm .input-wrap {
	background: #fff;
	border-radius: 5px;
	box-sizing: border-box;
	padding: 52px 80px 55px 48px;
	margin: 92px auto 0;
}

.bl_formConfirm .bl_form_group {
	border-bottom: 1px solid #000;
	padding: 16px 0;
	margin: 0;
}

.bl_formConfirm .bl_form_group .col {
	gap: 1em;
}

.bl_formConfirm .bl_form_label {
	color: #747474;
}

/* サンクスページ */

.thanks {
	margin: 0 auto;
	width: 90%;
	max-width: 1008px;
}

.thanks-content {
	background: #fff;
	border-radius: 5px;
	box-sizing: border-box;
	text-align: center;
	padding: 69px 64px 72px;
	margin: 96px auto 40px;
	width: 100%;
}

.thanks-content>div {
	background: #E0E0E0;
	border-radius: 5px;
	box-sizing: border-box;
	padding: 24px;
	margin: 60px auto 0;
	max-width: 464px;
	width: 90%;
}

.thanks-content b {
	font-size: 30px;
	letter-spacing: .08em;
	line-height: 1.2;
}

.thanks ul {
	margin-top: 24px;
}

.thanks ul li {
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .05em;
	line-height: 1.875;
}

.thanks .btn {
	margin: 172px auto 0;
}

.thanks .bottom-svg {
	margin-top: 70px;
}

@media screen and (max-width:768px) {

	.wrap {
		padding-top: 54px;
	}

	.page-title,
	.page-title .contact-title {
		height: 265px;
	}

	.contact-title h1 {
		font-size: 30px;
		padding: 116px 0 0;
		text-align: center;
	}

	.photographer {
		right: 8px;
		bottom: 48px;
	}

	/* プライバシーポリシー sp */
	.wrap p,
	.thanks ul li {
		font-size: 14px;
		line-height: 2.14;
	}

	.privacypolicy ol>li,
	.privacypolicy ul>li {
		font-size: 14px;
		line-height: 2.14;
	}

	/* お問い合わせ sp */

	.please {
		font-size: 15px;
		line-height: 2;
	}

	textarea {
		height: 400px;
	}

	fieldset .bl_form_control {
		padding: 26px 15px;
	}

	.bl_form_group .col {
		flex-flow: column;
		gap: 23px;
	}

	.bl_form_group .col input {
		max-width: none;
	}

	.bl_form_group .wpcf7-form-control {
		flex-flow: column;
	}

	/* 確認画面 sp */

	.bl_formConfirm .input-wrap {
		margin: 60px auto 0;
	}

	.bl_formConfirm .bl_form_group .col {
		flex-flow: row;
	}

	/* サンクスページ sp */
	.thanks-content {
		margin-top: 33px;
		padding: 32px 24px 24px;
	}

	.thanks-content>div {
		padding: 9px 5px 15px;
		margin-top: 32px;
	}

	.thanks-content>div p {
		margin-top: 7px;
	}

	.thanks-content b span {
		display: block;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: .05em;
	}

	.thanks .btn {
		margin-top: 56px;
	}
}