@charset "UTF-8";

/* ========================================
お問い合わせ
======================================== */
.wrap_contact_form {
	border: calc(8 / 375 * 100vw) solid rgba(0, 133, 62, 0.4);
	border-radius: calc(16 / 375 * 100vw);
	padding: calc(24 / 375 * 100vw) calc(24 / 375 * 100vw) calc(32 / 375 * 100vw);
	margin-top: calc(48 / 375 * 100vw)
}

.wpforms-container {
	margin: 0!important;
}

/* ラベル */
.wrap_contact_form .wpforms-container .wpforms-field-label {
	display: flex;
	flex-direction: row-reverse;
	justify-content: flex-end;
	align-items: center;
	gap: calc(16 / 375 * 100vw);
	font-weight: normal;
	font-size: 18px;font-size: 1.8rem;
	color: #333333;
}

/* 必須マーク */
.wrap_contact_form .wpforms-required-label {
	display: flex;
	justify-content: center;
	align-items: center;
	width: calc(40 / 375 * 100vw);
	height: calc(26 / 375 * 100vw);
	background: #01843E;
	color: #fff!important;
	font-weight: bold!important;
	font-size: 14px;font-size: 1.4rem;
	border-radius: calc(4 / 375 * 100vw);
}

/* 任意マーク */
.wrap_contact_form .any .wpforms-required-label {
	color: #333!important;
	background: none;
	border: 1px solid #01843E;
	border-radius: calc(4 / 375 * 100vw);
}

.wrap_contact_form .any {
	display: flex;
	flex-wrap: wrap;
	gap: calc(8 / 375 * 100vw) calc(16 / 375 * 100vw);
}

.wrap_contact_form .any input {
	width: 100%;
}

.wrap_contact_form .any .wpforms-field-label {
	margin-bottom: 0;
}

/* メールアドレス */
.wrap_contact_form .contact_mail .wpforms-field-row {
	display: block!important;
	max-width: none!important;
}

.wrap_contact_form .contact_mail .wpforms-field-row .wpforms-field-row-block {
	padding: 0!important;
	width: 100%!important;
}

.wrap_contact_form .contact_mail .wpforms-field-row .wpforms-field-row-block.wpforms-first {
	margin-bottom: 30px;
}

/* 住所 */
.wpforms-field-label-any {
	margin-bottom: 0!important;
}

.wpforms-field-label-any .wpforms-required-label {
	color: #333!important;
	background: none;
	border: 1px solid #01843E;
	border-radius: calc(4 / 375 * 100vw);
}

.contact_address {
	padding-bottom: 0!important;
}

.contact_address input[type=text] {
	width: 64px!important;
}

.contact_address1 {
	padding-top: 8px!important;
}

.contact_address .wpforms-required-label,
.contact_address3 .wpforms-required-label {
	display: none;
}

div.wpforms-field-container legend.wpforms-address-label {
	padding-top: 15px;
}

.wpforms-container .contact_address1 em.wpforms-error,
.wpforms-container .contact_address2 em.wpforms-error {
	display: none!important;
}

.contact_address3 .wpforms-error {
	margin: 0!important;
	white-space: nowrap;
}

/* ボタン */
.contact .wrap_contact_form .wpforms-submit,
.contact .wrap_contact_form .wpforms-page-button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 64px;
	padding: 0 48px 0 24px;
	margin: 0 auto;
	border: 2px solid #00853E;
	background: #00853E!important;
	color: #fff;
	border-radius: 2.1333333333vw;
	font-size: 18px;
	font-size: 1.8rem;
	position: relative;
}

.wpforms-submit::before,
.wpforms-page-button::before {
	content: "";
	display: block;
	width: 24px;
	height: 24px;
	background: url(../images/arrow_white.svg) no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 16px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.wpforms-page-button.wpforms-page-prev::before {
	right: auto;
	left: 16px;
	transform: translateY(-50%) scale(-1,1);
}

/* input */
input[type=text] {
	width: 100%!important;
	max-width: none!important;
}

/* 同意 */
.agree a {
	text-decoration: underline;
	font-weight: bold;
}

/* レイアウト調整 */
.wpforms-page {
	display: flex;
	flex-wrap: wrap;
}

.wpforms-field,
.wpforms-container .wpforms-form .wpforms-field-label {
	width: 100%!important;
}

.contact_address1 {
	width: 75px!important;
}

.contact_address2 {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100px!important;
	align-self: flex-end;
}

.contact_address2::before {
	content: "";
	display: block;
	width: 16px;
	height: 1px;
	background: #707070;
}

.wpforms-field-limit-text {
	display: none;
}

.wpforms-container .wpforms-field.p_none {
	padding: 0;
}

@media (min-width: 769px) {
	/* ========================================
	お問い合わせ
	======================================== */
	.wrap_contact_form {
		border-width: 8px;
		border-radius: 16px;
		padding: 64px 96px;
		margin-top: 48px;
	}

	/* ラベル */
	.wrap_contact_form .wpforms-container .wpforms-field-label {
		gap: 16px;
		margin-bottom: 8px;
	}

	/* 必須マーク */
	.wrap_contact_form .wpforms-required-label {
		width: 40px;
		height: 26px;
		border-radius: 4px;
	}

	/* 任意マーク */
	.wrap_contact_form .any .wpforms-required-label {
		border-radius: 4px;
	}

	.wrap_contact_form .any .wpforms-field-label {
		width: auto!important;
		margin-bottom: 0px;
	}

	.wrap_contact_form .any {
		gap: 8px 16px;
	}

	.wrap_contact_form .any input {
		max-width: none!important;
	}

	/* メールアドレス */
	.wrap_contact_form .contact_mail .wpforms-field-row {
		display: block;
	}

	/* ボタン */
	.contact .wrap_contact_form .wpforms-submit,
	.contact .wrap_contact_form .wpforms-page-button {
		width: 352px;
		padding: 0;
		border-radius: 8px;
		height: 51px!important;
		font-size: 24px!important;
		margin: 0 auto!important;
	}

	.wpforms-submit::before,
	.wpforms-page-button::before {
		border-radius: 40px;
	}

	/* レイアウト調整 */
	.wpforms-container .wpforms-field.contact_address {
		padding-top: 0!important;
	}

	.contact_address1 {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
		width: 163px!important;
		margin-right: 8px!important;
	}

	.contact_address1 label {
		margin-bottom: 0!important;
		align-self: center;
	}

	.contact_address1,
	.contact_address2 {
		margin-top: 8px!important;
	}

	.contact_address3 {
		display: flex;
		align-items: center;
		gap: 63px;
	}

	.wpforms-container .contact_address3 .wpforms-field-label {
		min-width: 36px!important;
		width: auto!important;
	}

	.contact_address3 label {
		margin-bottom: 0!important;
	}
}