@charset "utf-8";

/*-------------------------------
	共通
-------------------------------*/

.Contact-step{
	width: 100%;
	margin-bottom: 4.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	z-index: 5000;
	counter-reset: number 0;
}
.Contact-step::before{
	background: var(--graycolor);
	content: "";
	display: block;
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	z-index: -1;
}
.Contact-step__item{
	border: 2px solid var(--graycolor);
	width: calc((100% - (6rem * 2)) / 3);
	height: 6rem;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}
.Contact-step__item::before{
	counter-increment: number 1;
	content: counter(number,decimal-leading-zero);
	font-family: var(--en);
	font-size: 1.2rem;
	margin-bottom: .4rem;
	font-weight: 700;
	line-height: 1;
	display: block;
	color: #999;
}
.Contact-step__itemText{
	font-weight: 700;
	line-height: 1;
	display: block;
	color: #999;
}
.Contact-step__item.-current{
	border-color: #d13354;
}
.Contact-step__item.-current::before,
.Contact-step__item.-current .Contact-step__itemText{
	color: #d13354;
}

.Contact__top{
	padding-bottom: 9rem;
}
.Contact__text{
	font-size: 2.2rem;
	line-height: calc(4.2 / 2.2);
	font-weight: 700;
	text-align: center;
}

.Form{
	background: var(--graybg);
	margin-bottom: 10.5rem;
	padding-top: 10.5rem;
	padding-bottom: 10.5rem;
}
.Form-block:not(:last-child){
	margin-bottom: 10rem;
}
.Form-block__title{
	width: 100%;
	margin-bottom: 3.4rem;
	font-size: 2.6rem;
	padding-left: 2.2rem;
	letter-spacing: .025em;
	font-weight: 700;
	line-height: 1;
	position: relative;
}
.Form-block__title::before{
	background: var(--maincolor);
	content: "";
	display: block;
	width: .8rem;
	height: .8rem;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.Form-block__item{
	border-bottom: 1px solid var(--graycolor);
	width: 100%;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
}
.Form-block__item:first-child{
	border-top: 1px solid var(--graycolor);
}
.Form-block__itemTitle{
	width: 30rem;
	padding: 2.6rem 5rem 2.6rem 3rem;
	font-weight: 700;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.Form-block__itemTitle span{
	width: calc(100% - 3.6rem);
	height: 5.2rem;
	padding-right: 3.6rem;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	position: relative;
}
.Form-block__itemTitle.-req::after{
	content: "必須";
	background: var(--maincolor);
	width: 3.6rem;
	height: 2rem;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.Form-block__itemBody{
	width: calc(100% - 30rem);
	min-height: 10.4rem;
	padding-top: 2.6rem;
	padding-right: 3rem;
	padding-bottom: 2.6rem;
	display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
}

/* ご希望対応 */
.Form-block__item.-connect .Form-block__itemTitle{
	align-items: flex-start;
}
.Form-block__item.-connect .Form-block__itemTitle span{
	align-items: flex-start;
}

/* ご相談詳細 */
.Form-block__item.-type .Form-block__itemTitle{
	align-items: flex-start;
}
.Form-block__item.-type .Form-block__itemTitle span{
	align-items: flex-start;
}


.Form__button-wrap{
	width: 100%;
	column-gap: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
.Form__button input[type="submit"],
.Form__button input[type="button"]{
	width: 100%;
	height: 100%;
}
.C-Button.-back .a input{
	transform: scale(-1,1);
}

.Form__button .a:has(input[type="submit"]:disabled){
	color: var(--graycolor);
}
.Form__button input[type="submit"]:disabled{
	background: #eee;
}
.Form__button .a:has(input[type="submit"]:disabled) .C-Arrow{
	background: var(--graycolor);
	border-color: var(--graycolor);
}
.Form__button .a:has(input[type="submit"]:disabled) .C-Arrow::after{
	animation: none;
}

.wpcf7-spinner{
	display: none;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

	.Form-block__itemTitle{
		width: 24rem;
		padding-left: 2rem;
		padding-right: 3.5rem;
	}
	.Form-block__itemTitle span{
		padding-right: 2.5rem;
	}
	.Form-block__itemBody{
		width: calc(100% - 24rem);
		padding-right: 2rem;
	}

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

	.Contact-step{
		margin-bottom: 6.5rem;
	}
	.Contact-step__item{
		border: 2px solid var(--graycolor);
		width: calc((100% - (5.4rem * 2)) / 3);
		height: 11rem;
	}
	.Contact-step__item::before{
		font-size: 2rem;
		margin-bottom: 1rem;
	}
	.Contact-step__itemText{
		font-size: 2.6rem;
	}

	.Contact__top{
		padding-bottom: 10rem;
	}
	.Contact__text{
		font-size: 3.2rem;
		line-height: calc(4.8 / 3.2);
		text-align: left;
	}

	.Form{
		margin-bottom: 10rem;
		padding-top: 10rem;
		padding-bottom: 10rem;
	}
	.Form-block__title{
		margin-bottom: 4.5rem;
		font-size: 3.6rem;
		padding-left: 3.2rem;
	}
	.Form-block__title::before{
		width: 1.2rem;
		height: 1.2rem;
	}
	.Form-block__item{
		padding-top: 4.8rem;
		padding-bottom: 5.5rem;
		flex-direction: column;
	}
	.Form-block__itemTitle{
		width: 100%;
		padding: 0 0 3.8rem;
		justify-content: flex-start;
	}
	.Form-block__itemTitle span{
		width: auto;
		height: auto;
		padding-right: 2.8rem;
	}
	.Form-block__itemTitle.-req::after{
		width: 7rem;
		height: 4rem;
		font-size: 2.4rem;
	}
	.Form-block__itemBody{
		width: 100%;
		padding-top: 0;
		padding-right: 0;
		padding-bottom: 0;
		min-height: auto;
	}

	/* ご希望対応 */
	.Form-block__item.-connect .Form-block__itemTitle{
		align-items: center;
	}

	/* ご相談詳細 */
	.Form-block__item.-type .Form-block__itemTitle{
		align-items: center;
	}

	.Form__button-wrap{
		gap: 7.5rem 0;
		flex-direction: column-reverse;
	}
	.Form__button.-large input[type="submit"]{
		padding-left: 5rem;
	}

}



/*-------------------------------
	入力
-------------------------------*/

.Contact-tel{
	margin-bottom: 9rem;
}
.Contact-tel__text{
	font-size: 2.2rem;
	margin-bottom: 2.2rem;
	line-height: calc(4.2 / 2.2);
	font-weight: 700;
	text-align: center;
}
.Contact-tel__number{
	font-family: var(--en);
	color: var(--maincolor);
	font-size: 6rem;
	margin-bottom: 2.2rem;
	font-weight: 700;
	line-height: .7;
    padding-bottom: .2rem;
	display: block;
	text-align: center;
}
.Contact-tel__time{
	line-height: 1;
	display: block;
	text-align: center;
}

::placeholder{
	color: #b2b2b2;
}
.Form-block__field{
	width: 100%;
}
.Form-block__field .wpcf7-form-control-wrap{
	height: 100%;
	display: block;
}
.Form-block__field input{
	border: 1px solid var(--graycolor);
	width: 100%;
	height: 5.2rem;
	padding: .9rem 2.2rem;
	background: #fff;
}
.Form__textarea{
	width: 100%;
}
.Form__textarea .wpcf7-form-control-wrap{
	display: block;
}
.Form__textarea textarea{
	border: 1px solid var(--graycolor);
	width: 100%;
	height: 20rem;
	padding: 1.2rem 2.2rem;
	background: #fff;
}
.Form__checkbox{
	width: 100%;
	max-width: 45rem;
}
.Form__checkbox .wpcf7-checkbox{
	width: 100%;
	gap: 2.8rem 3.5rem;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	flex-wrap: wrap;
}
.Form__checkbox input[type="checkbox"]{
	display: none;
}
.Form__checkbox .wpcf7-list-item-label{
	padding-left: 2.5rem;
	line-height: 1;
	display: block;
	position: relative;
	cursor: pointer;
}
.Form__checkbox .wpcf7-list-item-label::before{
	border: 1px solid var(--blackcolor);
	content: "";
	display: block;
	width: 1.6rem;
	height: 1.6rem;
	background: #fff;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.Form__checkbox .wpcf7-list-item-label::after{
	display: none;
}
.Form__checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label::after{
	content: "";
	border-bottom: 2px solid var(--maincolor);
	border-left: 2px solid var(--maincolor);
	width: 1rem;
	height: .6rem;
	display: block;
	transform: rotate(-45deg);
	position: absolute;
	left: .3rem;
	top: .4rem;
}

.Form__select{
	width: 100%;
	max-width: 24rem;
}
.Form__select .wpcf7-form-control-wrap{
	width: 100%;
	height: 100%;
	display: block;
	position: relative;
}
.Form__select .wpcf7-form-control-wrap::before{
	content: "";
	display: block;
	width: 1.1rem;
	height: 1rem;
	background-image: url(../images/common/icon_arrow2-black.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	position: absolute;
	right: 2.2rem;
	top: calc(5.2rem / 2);
	transform: translateY(-50%) rotate(90deg);
	z-index: 6000;
}
.Form__select select{
	border: 1px solid var(--graycolor);
	width: 100%;
	height: 5.2rem;
	padding: .9rem 2.2rem;
	position: relative;
	z-index: 4000;
	background: #fff;
}

.Contact-button{
	margin-left: auto;
	margin-right: auto;
}

.wpcf7-not-valid-tip{
	color: var(--maincolor);
	font-size: 1.2rem;
	line-height: 1;
	margin-top: 1rem;
	white-space: nowrap;
}

/* 住所 */
.Form-block__Child{
	width: 100%;
}
.Form-block__ChildItem{
	width: 100%;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
}
.Form-block__ChildItem:not(:last-child){
	margin-bottom: 2.5rem;
}
.Form-block__ChildItemTitle{
	width: 9rem;
	height: 5.2rem;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.Form-block__ChildItemBody{
	width: calc(100% - 9rem);
}
/* 郵便番号 */
.Form-block__zip{
	width: 100%;
	max-width: 39.5rem;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.Form-block__zipInner{
	width: calc(100% - (14rem + 2.1rem));
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
}
.Form-block__zipInner::before{
	content: "ー";
	display: block;
	position: absolute;
	left: 50%;
	top: calc(5.2rem / 2);
	transform: translate(-50%,-50%);
	line-height: 1;
}
.Form-block__zipInner .Form-block__field{
	width: calc((100% - 3.4rem) / 2);
}
.Form-block__zipButton{
	transition: var(--transition1);
	width: 14rem;
	height: 5.2rem;
	background: #808080;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}
.Form-block__zipButton:hover{
	background: var(--blackcolor);
}
/* 個人情報保護方針 */
.Form-block__privacy{
	width: 1.6rem;
	height: 1.6rem;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.Form-block__privacy .wpcf7-form-control-wrap{
	width: 100%;
	height: 100%;
}
.Form-block__privacy .wpcf7-form-control{
	width: 100%;
	height: 100%;
}
.Form-block__privacy .wpcf7-list-item{
	display: block;
	height: 100%;
	margin: 0;
}
.Form-block__privacy .wpcf7-list-item-label{
	width: 100%;
	height: 100%;
	font-size: 0;
	padding-left: 0;
}
.Form-block__privacyText{
	width: calc(100% - 1.6rem);
	padding-left: .8rem;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.Form-block__privacyText a{
	line-height: 1;
	position: relative;
}
.Form-block__privacyText a::after{
	background: var(--blackcolor);
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: -.5rem;
	right: 0;
}

.Form__recaptcha{
	margin-bottom: 7.5rem;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	.Contact-tel{
		margin-bottom: 10rem;
	}
	.Contact-tel__text{
		font-size: 3.2rem;
		margin-bottom: 3rem;
		line-height: calc(4.8 / 3.2);
	}
	.Contact-tel__number{
		font-size: 6.8rem;
		margin-bottom: 3.2rem;
		padding-bottom: .3rem;
	}

	.Form-block__field input{
		height: 10rem;
		padding: .9rem 3.5rem;
	}
	.Form__textarea textarea{
		height: 30rem;
		padding: 2rem 3.5rem;
	}
	.Form__checkbox{
		max-width: 100%;
	}
	.Form__checkbox .wpcf7-checkbox{
		gap: 4rem 4.5rem;
	}
	.Form__checkbox .wpcf7-list-item-label{
		padding-left: 4rem;
	}
	.Form__checkbox .wpcf7-list-item-label::before{
		width: 2.6rem;
		height: 2.6rem;
	}
	.Form__checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label::after{
		width: 2rem;
		height: 1.2rem;
	}

	.Form__select{
		max-width: 100%;
	}
	.Form__select .wpcf7-form-control-wrap::before{
		width: 2.2rem;
		height: 2rem;
		right: 3.5rem;
		top: calc(10rem / 2);
	}
	.Form__select select{
		width: 100%;
		height: 10rem;
		padding: .9rem 3.5rem;
	}

	.wpcf7-not-valid-tip{
		font-size: 2.2rem;
		margin-top: 2rem;
	}

	/* ご希望内容 */
	.Form-block__item.-type .wpcf7-checkbox{
		flex-direction: column;
	}

	/* 住所 */
	.Form-block__ChildItem{
		flex-direction: column;
	}
	.Form-block__ChildItem:not(:last-child){
		margin-bottom: 5rem;
	}
	.Form-block__ChildItemTitle{
		width: 100%;
		margin-bottom: 3.5rem;
		line-height: 1;
	}
	.Form-block__ChildItemBody{
		width: 100%;
	}
	/* 郵便番号 */
	.Form-block__zip{
		max-width: 100%;
	}
	.Form-block__zipInner{
		width: calc(100% - (22.5rem + 2.5rem));
	}
	.Form-block__zipInner::before{
		top: calc(10rem / 2);
	}
	.Form-block__zipInner .Form-block__field{
		width: calc((100% - 5rem) / 2);
	}
	.Form-block__zipButton{
		width: 22.5rem;
		height: 10rem;
	}
	/* 個人情報保護方針 */
	.Form-block__privacy{
		width: 2.6rem;
		height: 2.6rem;
	}
	.Form-block__privacy > label{
		height: auto;
	}
	.Form-block__privacyText{
		width: calc(100% - 2.6rem);
		padding-left: 1.4rem;
	}
	.Form-block__privacy .wpcf7-form-control-wrap{
		width: 2.6rem;
		height: 2.6rem;
	}

	.Form__recaptcha{
		margin-bottom: 10rem;
	}

}



/*-------------------------------
	確認
-------------------------------*/

#Confirm .Form-block__itemTitle::after{
	display: none;
}
#Confirm .Form-block__itemTitle span{
	line-height: var(--line-height);
	width: 100%;
	padding-right: 0;
	height: auto;
}
#Confirm .Form-block__itemBody{
	min-height: auto;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
#Confirm .Form-block__item.-connect .Form-block__itemTitle{
	align-items: center;
}
#Confirm .Form-block__item.-connect .Form-block__itemTitle span{
	align-items: center;
}
#Confirm .Form-block__item.-type .Form-block__itemTitle{
	align-items: center;
}
#Confirm .Form-block__item.-type .Form-block__itemTitle span{
	align-items: center;
}
#Confirm .Form-block__item.-address .Form-block__itemBody > span:first-child{
	margin-right: 1em;
}
#Confirm .Form-block__item.-address .Form-block__itemBody > span:empty{
	display: none;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	#Confirm .Form-block__itemTitle{
		padding-bottom: 2rem;
	}
	#Confirm .Form-block__itemTitle::after{
		display: none;
	}
	#Confirm .Form-block__itemBody{
		min-height: unset;
	}
	#Confirm .Form__button.-back{
		width: 40rem;
		height: 10rem;
	}
	#Confirm .Form__button.-back input[type="button"]{
		font-size: 2.6rem;
		padding-right: 4rem;
	}
	#Confirm .Form__button.-back .C-Arrow{
		width: 6rem;
		height: 6rem;
	}
	#Confirm .Form__button.-back .C-Arrow::after{
		width: 2.6rem;
	}

}



/*-------------------------------
	完了
-------------------------------*/

.Send__title{
	font-size: 3.2rem;
	margin-bottom: 2.5rem;
	font-weight: 700;
	line-height: calc(4.8 / 3.2);
	text-align: center;
}
.Send__text{
	margin-bottom: 8.5rem;
	font-size: 1.8rem;
	text-align: center;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	.Send__title{
		font-size: 4.4rem;
		margin-bottom: 4rem;
		line-height: calc(6.6 / 4.4);
	}
	.Send__text{
		font-size: 3rem;
	}

}