@charset "UTF-8";

/* !contact
---------------------------------------------------------- */
.contactForm {
	font-size: 110%;
}
.contactForm dt {
	display: block;
	width: 24%;
	float: left;
	padding: 1em 0;
}
.contactForm dd {
	width: 100%;
	padding: 1em 0 1em 24%;
	display: block;
}
.contactForm dd:last-child {
}
.wpcf7 input:not([type=submit],[type=checkbox],[type=radio],.wpcf7-previous),
.wpcf7 textarea,
.wpcf7 select {
	padding: 0.7em 1em;
	width: 100%;
	border: 1px solid #aaa;
	border-radius: .3em;
}
.wpcf7 .w20 input {
	width: 13em;
}
.wpcf7 input[type=checkbox] {
	width: 1.1em;
	height: 1.1em;
	vertical-align: -3px;
	margin-right: .4em;
}
.wpcf7 input[type=radio] {
	width: 17px;
	height: 17px;
	vertical-align: -1px;
}
span.wpcf7-spinner {
  display: none;
}
.contactForm dd span.wpcf7-list-item { /*ラジオボタンを横並びにする*/
  display: block;
}
span.cf7msm-ro {
  display: block;
}
.wpcf7-response-output { display: none; }
.wpcf7-list-item {
    margin: 0 !important;
}
@media screen and (max-width: 1280px) {
}
@media screen and (max-width: 1024px) {
	.contactForm dt {
		width: 100%;
		float: none;
		font-size: 2vw;
		padding: 2vw 0 1vw;
	}
	.contactForm dd {
		width: 100%;
		float: none;
		padding: 0.5vw 0 2.5vw;
	}
}
@media screen and (max-width: 820px) {
}
@media screen and (max-width: 540px) {
	.contactForm {
		margin: 0 auto;
	}
	.contactForm dt {
		font-size: 3.8vw;
		padding: 2.5vw 0 1vw;
	}
	.contactForm dd {
		padding: 0 0 4vw;
	}
	.wpcf7 input:not([type=submit],[type=checkbox],[type=radio]),
	.wpcf7 textarea,
	.wpcf7 select {
		padding: 0.5em 0.7em;
	}
	.contactForm dd input:not([type=submit]),
	.contactForm dd textarea,
	.contactForm dd select {
		font-size: 16px;
		margin: 1vw 0;
	}
}
@keyframes onAutoFillStart { from {} to {}}

.wpcf7 input:-webkit-autofill,
.wpcf7 textarea:-webkit-autofill {
	animation-name: onAutoFillStart;
	transition: background-color 50000s ease-in-out 0s;
}


/* エラー文字 */
.wpcf7-not-valid-tip {
	font-weight: 700;
}

/* エラーの項目を強調 */
.wpcf7 dd:has(.wpcf7-not-valid-tip) input[type=text],
.wpcf7 dd:has(.wpcf7-not-valid-tip) input[type=email],
.wpcf7 dd:has(.wpcf7-not-valid-tip) textarea {
	border: 2px solid #f70734;
}

/* プライバシーポリシーカスタマイズ */
.pcheck .wpcf7-list-item-label {
	display: none;
}
.pcheck .wpcf7-not-valid-tip {
	display: none;
}
.pcheck:has(.wpcf7-not-valid-tip) span.ptxtwrap::after {
	content: "同意は必須です";
	color: #de4242;
	font-weight: normal;
	display: block;
}

/* !ラジオボタン色変え
---------------------------------------------------------- */
input[type=radio] {
  appearance: none;
  display: none;
}
input[type=radio] + span {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
  margin-left: 1.5em;
  margin-right: 1.8em;
}
input[type=radio] + span::before {
	background: #fff;
	border: 1px solid #b9b9b9;
	border-radius: 50%;
	content: '';
	display: block;
	left: -1.3em;
	margin-top: -.45em;
	position: absolute;
	top: 50%;
	width: 1em;
	height: 1em;
}
input[type=radio] + span::after {
	background: #0B8247;
	border-radius: 50%;
	content: '';
	display: block;
	left: -1.15em;
	margin-top: -.27em;
	opacity: 0;
	position: absolute;
	top: 50%;
	width: .7em;
	height: .7em;
}
input[type=radio]:checked + span::after {
    opacity: 1;
}
@media screen and (max-width: 540px) {
	input[type=radio] + span {
	  margin-left: 2em;
	}
	input[type=radio] + span::before {
		width: 1.2em;
		height: 1.2em;
		margin-top: -.6em;
		left: -1.5em;
	}
	input[type=radio] + span::after {
		margin-top: -.4em;
		width: .8em;
		height: .8em;
		left: -1.3em;
	}
}

::placeholder {
	color: #939393;
}



.select-box {
	position: relative;
	display: inline-block;
	width: 10em;
}
.select-box::before {
	content: "";
	position: absolute;
	right: 0;
	top: 40%;
	width: .5em;
	height: .5em;
	margin-right: .6em;
	border-top: 2px solid #000;
	border-right: 2px solid #000;
	transform: rotate(135deg);
	display: inline-block;
}
@media screen and (max-width: 540px) {
	.select-box {
		display: block;
	}
	.select-box.select-box-dib {
		display: inline-block;
	}
	
}

input[type="checkbox"] {
  accent-color: #352D20;
}


.submitbtnWrap {
	margin-left: auto;
	margin-right: auto;
	width: 90%;
	max-width: 16.75em;
	height: 3.25em;
	font-weight: 600;
	position: relative;
	border-radius: 1.7em;
}
.submitbtnWrap input {
	width: 100%;
	height: 100%;
	background: #ccc;
	color: #fff;
	text-align: center;
	font-size: 1.25em;
	border-radius: 1.7em;
}
.pcheck:has(input:checked) .submitbtnWrap input,
.submitbtnWrap.submitbtnWrap_confirm input {
	background: #0B8247;
}
.pcheck:has(input:checked) .submitbtnWrap input:hover,
.submitbtnWrap.submitbtnWrap_confirm input:hover {
	background: #333;
}

.submitbtnWrap::after {
	position: absolute;
	right: 1em;
	content: "";
	clip-path: polygon(10% 0, 100% 50%, 10% 100%, 0 90%, 70% 50%, 0 10%);
	width: 0.375em;
	height: 0.5625em;
	background: #fff;
	top: 50%;
	transform: translateY(-50%);
}

.addtxt {
	color: #777;
	border-left: 3px solid var(--green);
	padding: .3em 0 .3em .6em;
	margin-bottom: .5em;
}


select.is-empty,
select.is-empty2,
select.is-empty3 {
	/*color: #939393;*/
}