@charset "utf-8";

/*
	contact.css
---------------------------------------------------------------------------------------------------------------------------------------------*/
/* main-visual
--------------------------------------------------------------------------------------------------------*/
#contact-page #main-visual {
	background-image: url(../images/contact/bg_main-visual.jpg);
}

/* contents
--------------------------------------------------------------------------------------------------------*/
#contact-page #contents {
/*	padding: 5.0rem 0 0;*/
	padding: 8.0rem 0 0;
}
#contact-page #contents .inner {
/*	padding: 0 0 5.0rem;*/
	padding: 0 0 8.0rem;
}
#contact-page #contents .inner .tel-area,
#contact-page #contents .inner .mail-area {
	width: 510px;
/*	margin: 0 auto 4.5rem;*/
	margin: 0 auto 6.0rem;
}
#contact-page #contents .inner .mail-area {
	margin-bottom: 0;
}
#contact-page #contents .inner .tel-area dl,
#contact-page #contents .inner .mail-area dl {
	border-top: 1px solid rgba(22, 22, 22, 0.6);
	border-bottom: 1px solid rgba(22, 22, 22, 0.6);
	text-align: center;
	padding: 1.5rem 0 1.2rem;
}
#contact-page #contents .inner .tel-area dl dt,
#contact-page #contents .inner .mail-area dl dt {
	font-size: 1.9rem;
	margin-bottom: 1.0rem;
}
#contact-page #contents .inner .mail-area dl dt {
	margin-bottom: 0.5rem;
}
#contact-page #contents .inner .tel-area dl dd,
#contact-page #contents .inner .tel-area dl dd a,
#contact-page #contents .inner .mail-area dl dd {
	display: flex;
	display: -webkit-flex;
	justify-content: center;
	-webkit-justify-content: center;
	align-items: center;
	-webkit-align-items: center;
}
#contact-page #contents .inner .tel-area dl dd,
#contact-page #contents .inner .mail-area dl dd {
	font-size: 3.7rem;
}
#contact-page #contents .inner .tel-area dl dd span {
	background: url(../images/contact/ic-phone.png) no-repeat left center;
	background-size: 31px auto;
	padding: 0 0 0.5rem 3.7rem;
}
#contact-page #contents .inner .mail-area dl dd span {
	position: relative;
	font-size: 3.4rem;
}
#contact-page #contents .inner .mail-area dl dd span::before {
	color: #444;
	content: '\f0e0';
	font-family: FontAwesome;
	padding-right: 1.2rem;
}
#contact-page #contents .inner .tel-area dl dd small,
#contact-page #contents .inner .mail-area dl dd small {
	font-size: 1.6rem;
	padding-left: 0.5rem;
}
#contact-page #contents .inner .field {
	background-color: #fff;
	padding: 4.0rem 0 2.0rem;
	box-shadow: 4px 4px 10px 5px rgba(27, 29, 36, 0.08);
}
#contact-page #contents .inner .field h3 {
	text-align: center;
	font-size: 2.0rem;
}
#contact-page #contents .inner .field span.required {
	color: #cc1616;
}

#contact-page #contents .inner .field .steps,
#contact-page #contents .inner .field .steps dl {
	display: flex;
	display: -webkit-flex;
	justify-content: center;
	-webkit-justify-content: center;
}
#contact-page #contents .inner .field .steps {
	margin: 2.0rem 0;
}
#contact-page #contents .inner .field .steps dl {
	align-items: center;
	-webkit-align-items: center;
	flex-direction: column;
	-webkit-flex-direction: column;
	flex: 0 0 210px;
	width: 210px;
	padding: 1.5rem 0;
	position: relative;
}
#contact-page #contents .inner .field .steps dl::after {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: #f6f6f6;
	z-index: 1;
	transform: skewX(-27deg);
	-webkit-transform: skewX(-27deg);
}
#contact-page #contents .inner .field .steps dl:nth-of-type(2) {
	margin: 0 1.5rem;
}
#contact-page #contents .inner .field .steps dl.current::after {
	background-color: #fff001;
}
#contact-page #contents .inner .field .steps dl dt,
#contact-page #contents .inner .field .steps dl dd {
	position: relative;
	z-index: 2;
	letter-spacing: 0.03em;
}
#contact-page #contents .inner .field .steps dl dt {
	font-size: 1.1rem;
	margin-bottom: 0.8rem;
}
#contact-page #contents .inner .field .steps dl dd {
	font-size: 1.6rem;
}
#contact-page #contents .inner .field .steps + p {
	font-size: 1.5rem;
	text-align: center;
}
#contact-page #contents .inner .field p.txt-complete {
	text-align: center;
	line-height: 1.66;
	padding: 0.25em 0 0;
}
#contact-page #contents .inner .field .form-area {
	margin-top: 2.5rem;
	padding: 0 5.0rem;
}
#contact-page #contents .inner .field .form-area dl {
	display: flex;
	display: -webkit-flex;
	align-items: center;
	-webkit-align-items: center;
	padding: 3.5rem 0;
	border-top: 1px solid rgba(45, 49, 66, 0.15);
}
#contact-page #contents .inner .field .form-area dl dt,
#contact-page #contents .inner .field .form-area dl dd input,
#contact-page #contents .inner .field .form-area dl dd textarea {
	font-size: 1.6rem;
}
#contact-page #contents .inner .field .form-area dl dt {
	flex: 0 0 280px;
	-webkit-flex: 0 0 280px;
	width: 280px;
	padding-left: 1.8rem;
}
#contact-page #contents .inner .field .form-area dl dd {
	width: calc(100% - 280px);
	line-height: 1.66;
}
#contact-page #contents .inner .field .form-area dl dd input,
#contact-page #contents .inner .field .form-area dl dd textarea {
	width: 100%;
	border: 1px solid #d1d1d1;
	border-radius: 3px;
	background-color: #f9f9f9;
	padding: 1.5rem;
	height: 4.0em;
}
#contact-page #contents .inner .field .form-area dl dd input::placeholder {
	color: rgba(51, 51, 51, 0.4);
	font-weight: 500;
}
#contact-page #contents .inner .field .form-area dl dd input:-ms-input-placeholder {
	color: rgba(51, 51, 51, 0.4);
	font-weight: 500;
}
#contact-page #contents .inner .field .form-area dl dd input::-ms-input-placeholder {
	color: rgba(51, 51, 51, 0.4);
	font-weight: 500;
}
#contact-page #contents .inner .field .form-area dl dd textarea {
	min-height: 24.0rem;
}
#contact-page #contents .inner .field .form-area dl dd .required {
	background-color: #fff1f1;
}
#contact-page #contents .inner .field .form-area dl dd span.error {
	padding: 0.5em;
}
#contact-page #contents .inner .btn-wrap {
	display: flex;
	display: -webkit-flex;
	justify-content: center;
	-webkit-justify-content: center;
	padding: 5.0rem 0 0;
}
#contact-page #contents .inner .btn-wrap button {
	padding: 0;
	background-color: transparent;
	border: none;
	cursor: pointer;
	margin: 0 1.5rem;
}
#contact-page #contents .inner .btn-wrap button.btn-confirm .btn-link,
#contact-page #contents .inner .btn-wrap button.btn-submit .btn-link {
	width: 34.0rem;
}
#contact-page #contents .inner .btn-wrap button span {
	font-size: 1.9rem;
}




/*
	less than 767px;
---------------------------------------------------------------------------------------------------------------------------------------------*/
@media (max-width: 767px) {

/* contents
--------------------------------------------------------------------------------------------------------*/
	#contact-page #contents {
		padding: calc(80 / 750 * 100vw) 0 0;
	}
	#contact-page #contents .inner {
		padding: 0 calc(25 / 750 * 100vw) calc(80 / 750 * 100vw);
	}
	#contact-page #contents .inner .tel-area {
		width: 100%;
		margin-bottom: calc(50 / 750 * 100vw);
	}
	#contact-page #contents .inner .tel-area dl {
		padding: calc(25 / 750 * 100vw) 0;
	}
	#contact-page #contents .inner .tel-area dl dt {
		font-size: calc(24 / 750 * 100vw);
		margin-bottom: 0.5em;
	}
	#contact-page #contents .inner .tel-area dl dd {
		font-size: calc(48 / 750 * 100vw);
	}
	#contact-page #contents .inner .tel-area dl dd span {
		background-size: calc(40 / 750 * 100vw) auto;
		padding: 0.1em 0 0.25em calc(45 / 750 * 100vw);
	}
	#contact-page #contents .inner .tel-area dl dd small {
		font-size: calc(22 / 750 * 100vw);
		padding-left: 0.5em;
	}

	#contact-page #contents .inner .field {
		padding: calc(50 / 750 * 100vw) calc(25 / 750 * 100vw) calc(25 / 750 * 100vw);
	}
	#contact-page #contents .inner .field h3 {
		font-size: calc(28 / 750 * 100vw);
	}
	#contact-page #contents .inner .field .steps {
		margin: calc(40 / 750 * 100vw) 0 calc(25 / 750 * 100vw);
		padding: 0 calc(18 / 750 * 100vw);
	}
	#contact-page #contents .inner .field .steps dl {
		flex: 1;
		-webkit-flex: 1;
		width: auto;
		padding: calc(18 / 750 * 100vw) 0;
	}
	#contact-page #contents .inner .field .steps dl::after {
		transform: skewX(-20deg);
		-webkit-transform: skewX(-20deg);
	}
	#contact-page #contents .inner .field .steps dl:nth-of-type(2) {
		margin: 0 calc(12 / 750 * 100vw);
	}
	#contact-page #contents .inner .field .steps dl dt {
		font-size: calc(18 / 750 * 100vw);
		margin-bottom: 0.25em;
	}
	#contact-page #contents .inner .field .steps dl dd {
		font-size: calc(21 / 750 * 100vw);
	}
	#contact-page #contents .inner .field .steps + p,
	#contact-page #contents .inner .field p.txt-complete {
		font-size: calc(22 / 750 * 100vw);
		text-align: left;
		line-height: 1.45;
	}
	#contact-page #contents .inner .field .form-area {
		margin-top: calc(40 / 750 * 100vw);
		padding: 0;
	}
	#contact-page #contents .inner .field .form-area dl {
		flex-direction: column;
		-webkit-flex-direction: column;
		padding: calc(25 / 750 * 100vw) 0;
	}
	#contact-page #contents .inner .field .form-area dl dt {
		flex: 0 0 100%;
		-webkit-flex: 0 0 100%;
		width: 100%;
		padding-left: 0;
		font-size: calc(26 / 750 * 100vw);
		margin-bottom: 0.75em;
	}

	#contact-page #contents .inner .field .form-area dl dd {
		width: 100%;
		font-size: calc(26 / 750 * 100vw);
	}
	#contact-page #contents .inner .field .form-area dl dd input,
	#contact-page #contents .inner .field .form-area dl dd textarea {
		height: 3.5em;
		padding: 1.0rem;
		font-size: 1.5rem;
	}

	#contact-page #contents .inner .btn-wrap {
		padding: calc(50 / 750 * 100vw) 0 0;
	}
	#contact-page #contents .inner .btn-wrap button {
		margin: 0 calc(15 / 750 * 100vw);
	}
	#contact-page #contents .inner .btn-wrap button.btn-confirm .btn-link,
	#contact-page #contents .inner .btn-wrap button.btn-submit .btn-link {
		width: calc(260 / 750 * 100vw);
	}
	#contact-page #contents .inner .btn-wrap button span {
		font-size: calc(24 / 750 * 100vw);
	}



/*
	contact.css End
---------------------------------------------------------------------------------------------------------------------------------------------*/
}