@charset "UTF-8";

/*------------------------
タイトル・リードなど
------------------------*/
.footer-contact{
	display: none;
}
.ttl-wrap .ja{
	color: var(--black);
}
#contact .other h2{
	letter-spacing: 0.2em;
}
#error{
	color: var(--red);
}
.other .textarea span{
border-bottom: 1px solid var(--red);
}
/* PC */
@media screen and (min-width:768px) {
	#contact{
		padding: 114px 0 160px;
	}
	.ttl-wrap .ja{
		font-size: 22px;
	}
	#contact .inner{
		max-width: 1100px;
		margin: 0 auto;
	}
	/*square*/
	#contact .other,
	#contact	.message{
		font-size: 18px;
		width: 810px;
	}
	#contact .other h2,
	.thanks h2{
		font-size: 22px;
		margin-bottom: 45px;
	}
	#contact .textarea{
		margin-bottom: 1.65em;
	}
	#contact .message{
		margin-bottom: 82px;
	}
	#error{
		font-size: 16px;
		margin-top: -30px;
		margin-bottom: 40px;
	}
}
/* SP */
@media screen and (max-width:767px) {
		#contact{
		padding: 8.72vw 7.69vw 25.6vw;
	}
	.ttl-wrap .ja{
		font-size:5.64vw;
	}
	#contact .inner{	}
	/*square*/
	#contact .other,
	#contact	.message{
		font-size:3.33vw;
		line-height: 2;
	}
	#contact .other h2,
	.thanks h2{
		font-size:5.13vw;
		margin-bottom:11.53vw;
		line-height: 1.5;
		text-align: center;
	}
	#contact .textarea{
		margin-bottom: 1em;
	}
	#contact .message{
		margin-bottom: 14vw;
	}
	#error{
		font-size:3.33vw;
		margin-top: -8.7vw;
		margin-bottom: 7.7vw;
	}

}
/*------------------------
form
------------------------*/
.require{
	color: var(--red);

}
#contact table{
	position: relative;
	z-index: 30;
}
#contact table th,
#contact table td{
		vertical-align: top;
}
#contact table th{
	letter-spacing: 0.2em;
	font-weight: bold;
	position: relative;
}
#contact table td{
}
/*住所セット*/
#form_zipcode td{
	display: flex;

}
#form_zipcode input[type="button"]{
	border: 1px solid #707070;
	background: var(--sage);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}
/* PC */
@media screen and (min-width:768px) {
	#contact table{
		font-size: 16px;
		margin-bottom: 100px;
	}
	#contact table:nth-of-type(2){
		margin-bottom: 50px;
}
	#contact table input,
	#contact table select,
	#contact table textarea{
		font-size: 16px!important;
	}
	#contact table textarea{
		height: 13em;
	}
	#contact table th,
		#contact table td{
		padding-bottom: 23px;
	}
	#contact table th {
		padding-right: 3em;
		padding-top: 8px;
	}
	#contact table td{
		width: 820px;
	}
	#contact th .require {
		position: absolute;
		right: 20px;
		top:8px;
	}
	/*住所セット*/
	#form_zipcode input[type="button"]{
		padding: 5px 10px;
		font-size: 14px!important;
	}
}
/* SP */
@media screen and (max-width:767px) {
		#contact table{
		margin-bottom:7.8vw;
		font-size: 3.6vw;
	}
	#contact table input,
	#contact table select,
	#contact table textarea{
		font-size:3.6vw!important;
	}
	#contact table textarea{
		height: 8em;
	}
	#contact table th,
	#contact table td{
		display: block;
	}
	#contact  #form_zipcode td {
    display: flex;
	}
	#contact table th {
		padding-bottom:2.2vw;
	}
	#contact table td{
		padding-bottom:3.7vw;
	}
	#contact th .require {
		padding-left: 1em;
	}
	.form-input .submit-wrap.btn.lb input {
		padding-bottom: 8vw;
		font-size: 3.59vw;
	}
.form-input .submit-wrap.btn.lb::after {
	transform: translateX(-50%);
	left: 50%;
	top: auto;
	bottom: 4vw;
	}
}
/*------------------------
下エリア・プライバシー
------------------------*/
#contact .privacy a{
	color: #43576e;
	font-weight: bold;
}
#contact .textarea ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
#contact .textarea li {
	position: relative;
	padding-left: 1.2em;
}
#contact .textarea li::before {
	content: "・";
	position: absolute;
	left: 0;
	top: 0;
}
/* PC */
@media screen and (min-width:768px) {
	#contact .privacy a:hover{
		text-decoration: underline;
}
	#contact .notice{
		font-size: 15px;
		margin-top: 100px;
	}
	#contact .notice .textarea{
		margin-bottom: 0!important;
		line-height: 2;
	}
	#contact .notice .ttl{
		margin-bottom:30px;
	}
}
/* SP */
@media screen and (max-width:767px) {
		#contact .privacy{
			font-size: 3.85vw;
}
	#contact .notice{
			font-size: 3.85vw;
		margin-top:38vw;
	}
	#contact .notice .textarea{
		margin-bottom: 0!important;
		line-height: 2;
	}
	#contact .notice .ttl{
		margin-bottom:7.7vw;
	}
}



/*------------------------
確認画面
------------------------*/
.confirm .btn-g{
	position: relative;
}

input.back{
	color: #fff;
	background-color: var(--sage);
	border: 1px solid #707070;
	display: flex;
	align-items: center;
	justify-content: center;
}
/* PC */
@media screen and (min-width:768px) {
	.confirm #contact .message{
		margin-bottom: 30px;
	}
	.confirm #contact table {
		margin-bottom: 20px;
	}
	.confirm #contact table th,
	.confirm #contact table td{
			padding-bottom:15px;
	}
	.confirm td{
		padding-top: 8px;
	}
	input.back{
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		padding: 0 15px;
		height: 45px;
		transition: opacity .3s ease;
	}
	input.back:hover{
		opacity: .7;
	}
}
/* SP */
@media screen and (max-width:767px) {
	.confirm #contact .message{
		margin-bottom:7.7vw;
	}
	.confirm #contact table:nth-of-type(2) {
		margin-bottom:15.38vw;
	}
	input.back{
		margin-top: 3.85vw;
		padding: 3.58vw 3.7vw;
		width: 100%;
	}
	.confirm #contact table th{
		padding-top: 4vw;
		padding-bottom: 1.67vw;
		font-size: 3.33vw;
	}
	.confirm #contact table td{
		border-bottom: 1px solid var(--sage);
		padding-bottom: 3.7vw;
	}
	#contact table:nth-of-type(2) td {
	margin-bottom:0;
	padding-bottom: 0;
	border: none;
  }
	 .confirm .btn-g {
    position: relative;
    display: flex;
    flex-direction: column-reverse;
	}
}

/*------------------------
サンクス
------------------------*/
/* PC */
@media screen and (min-width:768px) {
	.thanks #contact .inner{
		font-size: 16px;
	}
	.thanks #contact .inner .text{
		margin-bottom: 50px;
	}
	.thanks .back.lb{
			margin-left: 0;
	}			
}
/* SP */
@media screen and (max-width:767px) {
	.thanks #contact .inner .text{
		margin-bottom:13.8vw;
	}	
}
/*------------------------
header
------------------------*/
/* PC */
@media screen and (min-width:768px) {
}
/* SP */
@media screen and (max-width:767px) {
}
/*------------------------
header
------------------------*/
/* PC */
@media screen and (min-width:768px) {
}
/* SP */
@media screen and (max-width:767px) {
}




