@charset "UTF-8";
/*-----------------------------------

	headline

-----------------------------------*/
#headline h1::after {
	content: "Contact";
}
/*-----------------------------------

	reset(form用)

-----------------------------------*/
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}
textarea {
  resize: vertical;
}
input[type='checkbox'],
input[type='radio'] {
  display: none;
}
input[type='submit'],
input[type='button'],
label,
button,
select {
  cursor: pointer;
}
select::-ms-expand {
  display: none;
}
/*-----------------------------------

	contact

-----------------------------------*/
#contact .contents_inner {
	background: #FFF;
	padding: 50px;
	border-radius: 10px;
}
#contact span.required {
	color: #FF0000;
	margin-left: 10px;
}
#contact .contents_inner > p {
	text-align: center;
	line-height: 1.8;
	margin-bottom: 40px;
}
#contact table {
	width: min(780px, 100%);
	margin: 0 auto 40px;
}
#contact table th {
	width: 200px;
	text-align: left;
	vertical-align: middle;
	padding: 20px 0;
	color: #40A8A5;
}
#contact table th span.required {
	color: #FF0000;
	margin-left: 10px;
}
#contact table th span.optional {
	color: #999;
	margin-left: 10px;
}
#contact table td {
	padding: 20px 0;
}
#contact table td input[type="text"],
#contact table td input[type="email"],
#contact table td input[type="tel"],
#contact table td textarea {
	width: 100%;
	padding: 10px 15px;
	background: #eeeeee;
	border-radius: 6px;
	font-size: 16px;
}
#contact table td input.p-postal-code {
	width: min(200px, 100%);
	margin-left: 10px;
}
#contact table td textarea {
	min-height: 200px;
}
#contact table td p br {
	display: none;
}
#contact .checkbox {
	display: flex;
	justify-content: center;
	margin-bottom: 70px;
}
#contact .download_box {
	margin-bottom: 35px;
}
#contact .checkbox label{
	display: block;
	position: relative;
	padding-left: 46px;
	cursor: pointer;
}
#contact .checkbox label::before,
#contact .checkbox label::after{
	content: "";
	position: absolute;
	left: 0;
	top: -5px;
	margin: auto;
}
#contact .checkbox label::before{
	width: 30px;
	height: 30px;
	background: #eeeeee;
	border-radius: 5px;
}
#contact .checkbox label::after{
    top: 3px;
    border-bottom: 3px solid #40A8A5;
    border-left: 3px solid #40A8A5;
    height: 10px;
    width: 18px;
    transform: rotate(-45deg);
    left: 6px;
    margin: auto;
    opacity: 0;
	pointer-events: none; 
}
#contact .checkbox label:has(input:checked)::after{
    opacity: 1;
}
#contact .checkbox label a {
	color: #40A8A5;
	text-decoration: underline;
	display: inline-block;
}
#contact .checkbox label a:hover {
	text-decoration: none;
}

#contact .btn_box {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 30px;
}
#contact .btn_box > p {
	position: relative;
	cursor: pointer;
}
#contact .btn_box > p::after {
	content: '';
    display: block;
    background: url(../img/common/icon_btn_wh.svg) no-repeat center center / contain;
    width: 7px;
    height: 12px;
    margin: auto;
    position: absolute;
    top: 0;
    right: 23px;
    bottom: 0;
    z-index: 1;
    transition: 0.3s;
}
#contact .reset {
	text-shadow: 1px 2px 0 #666666;
	background: linear-gradient(180deg,rgb(174, 174, 174, 1) 0%, rgba(174, 174, 174, 1) 68%, rgb(130, 130, 130) 100%);
	width: 400px;
	box-shadow: 0 0 0 10px #f3f3f3;
}
#contact .btn_box > p:has(.btn.reset)::after {
	transform: scale(-1,1);
	right: auto;
	left: 23px;
}
#contact .btn_box > p:hover::after {
	right: 13px;
}
#contact .btn_box > p:has(.btn.reset):hover::after {
	left: 13px;
}
#contact a.btn.detail {
	margin: 0 auto;
}
#contact .btn_box br {
	display: none;
}
#contact .btn_box .wpcf7-spinner {
	display: none;
}
#contact .wpcf7-list-item {
	margin: 0;
}
#contact .wpcf7-not-valid-tip {
	font-weight: 500;
	color: #FF0000;
	margin-top: 1em;
}
#contact .wpcf7 form .wpcf7-response-output {
	text-align: center;
	padding: 2em 1em;
	margin-top: 3em;
}
@media screen and (max-width: 640px) {
	#contact .contents_inner {
		padding: 30px;
	}
	#contact .contents_inner > p {
		margin-bottom: 20px;
	}
	#contact table {
		margin: 0 auto 20px;
	}
	#contact table th {
		width: 100%;
		display: block;
		padding: 10px 0 0 0;
	}
	#contact table td {
		width: 100%;
		display: block;
		padding: 10px 0;
	}
	#contact table td input[type="text"],
	#contact table td input[type="email"],
	#contact table td input[type="tel"],
	#contact table td textarea {
		padding: 5px 10px;
	}
	#contact .checkbox {
		margin-bottom: 40px;
	}
	#contact .checkbox > p {
		width: 100%;
	}
	#contact .download_box {
		margin-bottom: 20px;
	}
	#contact .btn_box {
		gap: 20px;
	}
	#contact .btn_box > p {
		width: 100%;
	}
	#contact .btn_box > p::after {
		width: 6px;
        height: 10px;
        right: 18px;
	}
	#contact .btn_box > p:has(.btn.reset)::after {
		left: 18px;
	}
	#contact .reset {
		width: min(300px, 100%);
		box-shadow: 0 0 0 6px #f3f3f3;
	}
	#contact .detail {
		width: min(300px, 100%);
	}
	#contact .wpcf7-not-valid-tip {
		margin-top: 0.5em;
	}
}