@charset "utf-8";
/* CONTACT
======================================*/
.contactBg {
	background: #f9f9f9;
}

#contact {
	padding: 80px 0;
}

#contact .contactBody {
	background: #FFF;
	padding: 60px 0;
}

/*---- Intro ----*/
#formPageInLinkTop {
	padding-top: 100px;
	margin-top: -100px;
}

.intro {
	margin-bottom: 80px;
}

.introTxt {
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.1em;
	text-align: center;
	margin-bottom: 40px;
}

/*-- contents --*/
.commonCont {
	padding: 60px 50px 70px;
	margin-bottom: 200px;
}
.introCont {
	width: 680px;
	padding: 25px 0;
	margin: 0 auto 50px;
	position: relative;
	border: 1px solid #211488;
	text-align: center;
}

.telNumBlock {
	padding-bottom: 20px;
}

.telNum:before {
	width: 30px;
	height: 29px;
	content: '';
	padding-right: 10px;
	display: inline-block;
	vertical-align: middle;
	background: url(../../img/contact/icon_tel.svg) no-repeat 0 0 / contain;
}

.telNum span {
	display: inline-block;
	vertical-align: middle;
}


.telNumHead {

	font-size: 1.6rem;
	letter-spacing: .05em;
}

.telNum {
	margin-bottom: 6px;
	font-size: 4.4rem;
	line-height: 1;
	letter-spacing: 0.025em;
	color: #211488;
	font-weight: 700;
}

.telNumTxt {
	font-weight: bold;
	font-size: 1.3rem;
	letter-spacing: .05em;
	line-height: 1;
}

.toMail {
	text-align: center;
}

.toMail a {
	position: relative;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: .06em;
	line-height: 1;
	transition: all .3s ease-in-out;
}

.toMail a:hover {
	opacity: 0.7;
}

.toMail a:before {
	margin-right: 10px;
	display: inline-block;
	background: url(../../img/contact/icon_mail.png) no-repeat 0 0 / 100%;
	vertical-align: -2px;
	width: 22px;
	height: 15px;
	content: '';
	transition: all .3s ease-in-out;
}

/*-- guide --*/
.guideBlock {
	width: 568px;
	margin: auto;
	padding: 7px 0 8px;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: center;
	border: 3px solid #E5E5E5;
}

.guideItem {
	margin-right: 30px;
}

.guideItem:nth-last-of-type(1) {
	margin-right: 0;
}

.guideItem:after {
	width: 10px;
	height: 11px;
	margin-left: 20px;
	content: '';
	display: inline-block;
	background: url(../../img/contact/guide_arr.png) no-repeat 0 0 / 100%;
	vertical-align: -1px;
}

.guideItem.finished:after {
	background: url(../../img/contact/guide_arr_finished.png) no-repeat 0 0 / 100%;
}

.guideItem:nth-last-of-type(1):after {
	display: none;
}

.guideNum,
.guideTxt {
	display: inline-block;
}

.guideNum {
	width: 22px;
	height: 22px;
	padding: 4px 0 0;
	color: #FFF;
	font-size: 1.3rem;
	letter-spacing: 0;
	line-height: 1;
	text-align: center;
	background: #C3C3C3;
	border-radius: 100%;
}

.guideTxt {
	color: #C3C3C3;
	letter-spacing: .18em;
	line-height: 1;
	vertical-align: -1px;
}

.finished .guideNum {
	background: #0D859B;
}

.finished .guideTxt {
	color: #0D859B;
}


/*---- Form area ----*/
.contactTitNote {
	padding-left: 30px;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: .1em;
	line-height: 1;
	vertical-align: 1px;
	color: #C92222;
}

/*-- Form --*/
.formCol {
	width: 71%;
	padding: 25px 0;
	margin: 0 auto;
}

.confirm .formCol {
	border-bottom: 1px solid #dcdcdc;
}

.formColBody {
	border-bottom: none;
	margin: 0 auto 30px;
}

.formttl {
	color: #333;
	font-size: 1.6rem;
	letter-spacing: .08em;
	line-height: 1;
	margin-bottom: 10px;
	font-weight: 700;
}

.require {
	display: inline-block;
	background: #c71818;
	border-radius: 4px;
	color: #fff;
	font-size: 1.3rem;
	line-height: 1;
	padding: 4px 10px 5px;
	margin-left: 13px;
}

.formin {
	font-size: 1.6rem;
	line-height: 1.3;
}

.forminZip {
	margin-bottom: 10px;
	font-size: 2.3rem;
}

select,
input[type="text"],
input[type="tel"],
textarea {
	property: value;
	background: #FFF;
	width: 100%;
	border: 1px solid #AAA;
	border-radius: 8px;
	padding: 12px 25px;
	font-size: 2rem;
	letter-spacing: 0;
	box-sizing: border-box;
}

textarea {
	height: 400px;
}

.telInputBox {
	width: 155px !important;
}

/* Address */
#e_add01 {
	width: 155px;
}

#e_add02 {
	width: 176px;
}

.forminAdd01 {
	margin-bottom: 10px;
}

/* Button area */
.formAreaBot {
	text-align: center;
}

.formAreaBotTxt{
	font-size: 1.6rem;
}

.formAreaBotTxt {
	margin-bottom: 15px;
}

.policyLink {
	color: #b20218;
	text-decoration: underline;
	text-underline-offset: 4px;
	transition: 0.3s ease-in-out;
	font-weight: 700;
	font-size: 1.6rem;
}

.policyLink:hover {
	text-decoration: none;
}

.formBtn {
	margin: auto;
	width: 350px;
}

.formBtn a {
	color: #fff;
}

.formBtn {
	width: 370px;
	margin: 0 auto;
	padding: 17px 0;
	transition: 0.3s ease-in-out;
	border-radius: 40px;
}

.formBtn::after {
	width: 25px;
	height: 25px;
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
}

.formBtnIn {
	margin-bottom: 5px;
	display: block;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: .05em;
	line-height: 1;
}

/* btn */
a.submitBtn {
	padding: 14px 100px 10px;
	margin: 0 auto;
	display: inline-block;
	position: relative;
	border-radius: 100vw;
	background: #fed750 url(../../img/common/icon_chevron_submit.svg) no-repeat right 20px center / 22px;
	border: 2px solid #e4c148;
	transition: 0.3s ease-in-out;
	font-size: 1.8rem;
}

.sendBtnTxt {
	display: block;
	font-size: 1.8rem;
	letter-spacing: .05em;
	font-weight: bold;
}

a.submitBtn:hover {
	opacity: 0.7;
}

/* tit3 */
.contactTit {
	width: 90%;
	padding-bottom: 0.4em;
	margin: 0 auto 30px;
	letter-spacing: 0.1em;
	font-size: 2.6rem;
	color: #211488;
	border-bottom: 2px solid #211488;
}

.errTxt {
	padding-top: 5px;
	display: inline-block;
	color: #E60012;
	font-size: 1.4rem;
}

.errTxt::before {
	width: 18px;
	height: 18px;
	padding-right: 6px;
	content: '';
	display: inline-block;
	background: url(../../img/contact/err_icon.png) 0 0 no-repeat;
	vertical-align: middle;
	background-size: contain;
}

/*-- Placeholder --*/
input:placeholder,
textarea:placeholder {
	color: #999;
	letter-spacing: .1em;
	font-family: inherit;
}

/* Chrome */
:-webkit-input-placeholder,
:-webkit-textarea-placeholder {
	color: #999;
	letter-spacing: .1em;
	font-family: inherit;
}

/* Firefox */
:-moz-placeholder,
:-moz-textarea {
	color: #999;
	letter-spacing: .1em;
	font-family: inherit;
}

/* IE */
:-ms-input-placeholder,
:-ms-textarea-placeholder {
	color: #999;
	letter-spacing: .1em;
	font-family: inherit;
}


/*---- Confirm ----*/
.introTxt .introTit {
	color: #c20024;
	font-size: 2rem;
	padding-bottom: 10px;
	display: inline-block;
	font-weight: bold;
}

.introTxt.confirm {
	font-size: 2rem;
}

.introTxt.confirm .introTit  {
	font-size: 2.4rem;
	font-weight: bold;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.introTxt.confirm .introTit::before  {
	content: "";
	width: 50px;
	height: 45px;
	background: url(../../img/contact/icon_attention.svg) 0 0 no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
}

.introTxt .txtRed {
	color: #c20024;
}

.formin p {
	font-size: 2rem;
	letter-spacing: 0;
	line-height: 1.5;
}

.formAreaBot.confirm {
	margin-top: 45px;
}

.formBtnConfirm {
	margin-bottom: 20px;
}

.returnBtn {
	width: 280px;
	margin: 0 auto;
	line-height: 1;
	text-align: left;
}

.returnBtn a {
	padding-left: 20px;
	font-size: 1.6rem;
	line-height: 1;
	letter-spacing: 0.1em;
	color: #a0a0a0;
	background: url(../../img/contact/backbtn.svg) no-repeat left center;
	background-size: 16px;
}

/*---- Complete ----*/
.complete .intro {
	margin-bottom: 56px;
}

.complete .introTxt {
	margin-bottom: 1.5em;
}

.introBox {
	width: 885px;
	margin: 0 auto 40px;
	padding: 16px 28px;
	border: 4px solid #BA3A3A;
}

.introBoxTxt {
	margin-bottom: 12px;
	font-size: 1.5rem;
	letter-spacing: 0;
}

.introBoxTxt:nth-last-of-type(1) {
	margin-bottom: 0;
}

.introBoxTxt span {
	background: linear-gradient(transparent 0%, #FFEE67 0%);
}

.complete .btnDefLink {
	padding: 27px 0;
	font-size: 2rem;
	font-weight: 900;
}

.complete .btnDefLink:after {
	width: 9px;
	height: 9px;
	margin-top: -3px;
	position: absolute;
	top: 50%;
	right: 19px;
}

.completeBtn {
	width: 280px;
	font-size: 1.8rem;
	padding: 0.9em;
	letter-spacing: 0.1em;
	border-radius: 30px;
	background: #211488;
	color: #FFF;
	transition: all 0.3s ease-in-out 0s;
}

.completeBtn:hover {
	opacity: 0.7;
}

.completeBtn::after {
	content: "";
	width: 18px;
	height: 18px;
	background: url(../../img/common/icon_arrow4.svg) 0 0 no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
}

/* flow */
.flow {
	text-align: center;
}

