@charset "UTF-8";
/*--------------------------------------------------------------
.inner_form_bg
--------------------------------------------------------------*/

/* mobile */
@media (min-width: 300px) {
	
	.inner_form_bg {
		margin: 0;
		padding: 0 0 50px 0;
		background: #fff;
	}
	
	.inner_form_bg h2 {
		margin: 0 0 50px 0;
		padding: 30px 0;
		font-size: 20px;
		letter-spacing: 1px;
		font-weight: 600;
		text-align: center;
		color: #fff;
	}
	
	.form-area {
		margin: 0 auto;
		padding: 0 5%;
	}
	
	.subject {
		display: none;
	}
	
	.form-area h3 {
		margin: 0 0 20px 0;
		padding: 10px 20px;
		font-size: 18px;
		letter-spacing: 1px;
		font-weight: 600;
		background: #F5F5F5;
	}
	
	.form-area h3.estimate {
		border-top: #71B5B7 solid 3px;
	}
	
	.form-area h3.request {
		border-top: #007A9F solid 3px;
	}
	
	.green {
		background: #58B7B8;
	}
	
	.blue {
		background: #007A9F;
	}
	
	.inner_form_bg p,
	.inner_form_bg p.complete {
		margin: 0 0 50px 0;
		padding: 0 2%;
		font-size: 14px;
		line-height: 1.8;
	}
	
	.inner_form_bg p.complete span {
		margin: 0 0 10px 0;
		padding: 0;
		font-size: 16px;
		font-weight: 600;
		display: block;
		text-align: center;
	}
	
	.inner_form_bg p a {
		color: #58B7B8;
		text-decoration: none;
	}
	
	.inner_form_bg dl {
		margin: 0 0 50px 0;
		padding: 0;
		background: #F5F5F5;
		border-left: 1px solid #ccc;
		border-right: 1px solid #ccc;
		border-bottom: 1px solid #ccc;
		display: -webkit-flex;
		display: flex;
		flex-wrap: wrap;
		font-size: 14px;
		line-height: 1.8;
	}
	
	.inner_form_bg dt {
		margin: 0;
		padding: 20px;
		width: 100%;
		border-top: 1px solid #ccc;
	}
	
	.inner_form_bg dt span {
		margin: 0 0 0 5px;
		padding: 0;
		color: #AA2E2E;
	}
	
	.inner_form_bg dd {
		margin: 0;
		padding: 20px;
		width: 100%;
		background: #fff;
		border-top: 1px solid #ccc;
	}
	
	.inner_form_bg dd span.ub {
		margin: 0 5px;
		padding: 0;
	}
	
	.inner_form_bg dd span.info {
		margin: 10px 0 0 0;
		padding: 0;
		display: block;
		font-size: 14px;
	}
	
	.inner_form_bg dd span.info_top {
		margin: 0 0 10px 0;
		padding: 0;
		display: block;
		font-size: 14px;
	}
	
	.step,
	.step2 {
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
		justify-content: center;
		margin: 0 0 30px 0;
		padding: 0;
	}
	
	.step li,
	.step2 li{
		position: relative;
		padding: 15px 10px;
		margin: 0 25px 10px 0;
		background: #F5F5F5;
		width: 33.3%;
		text-align: center;
		font-size: 13px;
	}
	
	.step li span,
	.step2 li span {
		padding: 0;
		margin: 0;
		font-size: 10px;
		display: block;
	}

	.step li:nth-child(1)::after,
	.step li:nth-child(2)::after,
	.step2 li:nth-child(1)::after,
	.step2 li:nth-child(2)::after{
		content: "";
		position: absolute;
		top: 0;
		right: -30px;
		border-width: 32px 15px;
		border-color: transparent transparent transparent #F5F5F5 ;
		border-style: solid;
	}
	
	.step li:nth-child(1).is-current,
	.step li:nth-child(2).is-current,
	.step li:nth-child(3).is-current {
		background: #58B7B8;
		color: #fff;
	}
	
	.step2 li:nth-child(1).is-current,
	.step2 li:nth-child(2).is-current,
	.step2 li:nth-child(3).is-current {
		background: #007A9F;
		color: #fff;
	}
	
	
	.step li:nth-child(1).is-current::after,
	.step li:nth-child(2).is-current::after {
		border-color: transparent transparent transparent #58B7B8 ;
	}
	
	.step2 li:nth-child(1).is-current::after,
	.step2 li:nth-child(2).is-current::after {
		border-color: transparent transparent transparent #007A9F ;
	}
	
	.policy_chack {
		margin: 0 0 50px 0;
		padding: 50px;
		text-align: center;
		border: 1px solid #ccc;
		font-size: 15px;
	}
	
	.policy_chack a {
		color: #58B7B8;
		text-decoration: none;
	}
}

/* Small than tablet */
@media (min-width: 768px) {
	
	
	
}


/* Larger than tablet */
@media (min-width: 992px) {
	
	.inner_form_bg {
		margin: 0;
		padding: 0 0 80px 0;
		background: #fff;
	}
	
	.inner_form_bg h2 {
		margin: 0 0 50px 0;
		padding: 50px 0;
		font-size: 25px;
		letter-spacing: 1px;
		font-weight: 600;
		text-align: center;
		color: #fff;
	}
	
	.form-area {
		margin: 0 auto;
		padding: 0 5%;
		max-width: 1100px;
	}
	
	.subject {
		display: none;
	}
	
	.form-area h3 {
		margin: 0 0 20px 0;
		padding: 10px 20px;
		font-size: 20px;
		letter-spacing: 1px;
		font-weight: 600;
		background: #F5F5F5;
	}
	
	.green {
		background: #58B7B8;
	}
	
	.inner_form_bg p,
	.inner_form_bg p.complete {
		margin: 0 0 50px 0;
		padding: 0;
		font-size: 15px;
		line-height: 1.8;
	}
	
	.inner_form_bg p.complete span {
		margin: 0 0 10px 0;
		padding: 0;
		font-size: 18px;
		font-weight: 600;
		display: block;
		text-align: center;
	}
	
	.inner_form_bg p a {
		color: #58B7B8;
		text-decoration: none;
	}
	
	.inner_form_bg dl {
		margin: 0 0 50px 0;
		padding: 0;
		background: #F5F5F5;
		border-left: 1px solid #ccc;
		border-right: 1px solid #ccc;
		border-bottom: 1px solid #ccc;
		display: -webkit-flex;
		display: flex;
		flex-wrap: wrap;
		font-size: 15px;
		line-height: 1.8;
	}
	
	.inner_form_bg dt {
		margin: 0;
		padding: 20px;
		width: 30%;
		border-top: 1px solid #ccc;
	}
	
	.inner_form_bg dt span {
		margin: 0 0 0 5px;
		padding: 0;
		color: #AA2E2E;
	}
	
	.inner_form_bg dd {
		margin: 0;
		padding: 20px;
		width: 70%;
		background: #fff;
		border-top: 1px solid #ccc;
	}
	
	.inner_form_bg dd span.ub {
		margin: 0 5px;
		padding: 0;
	}
	
	.inner_form_bg dd span.info {
		margin: 10px 0 0 0;
		padding: 0;
		display: block;
		font-size: 14px;
	}
	
	.inner_form_bg dd span.info_top {
		margin: 0 0 10px 0;
		padding: 0;
		display: block;
		font-size: 14px;
	}
	
	.step,
	.step2 {
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
		justify-content: center;
		margin: 0 0 30px 0;
		padding: 0;
	}
	
	.step li,
	.step2 li {
		position: relative;
		padding: 20px 30px;
		margin: 0 25px 10px 0;
		background: #F5F5F5;
		width: 33.3%;
		text-align: center;
		font-size: 18px;
	}
	
	.step li span,
	.step2 li span {
		padding: 0;
		margin: 0;
		font-size: 15px;
	}

	.step li:nth-child(1)::after,
	.step li:nth-child(2)::after,
	.step2 li:nth-child(1)::after,
	.step2 li:nth-child(2)::after {
		content: "";
		position: absolute;
		top: 0;
		right: -30px;
		border-width: 44px 15px;
		border-color: transparent transparent transparent #F5F5F5 ;
		border-style: solid;
	}
	
	
	.policy_chack {
		margin: 0 0 50px 0;
		padding: 50px;
		text-align: center;
		border: 1px solid #ccc;
		font-size: 15px;
	}
	
}

/*--------------------------------------------------------------
form style
--------------------------------------------------------------*/

/* mobile */
@media (min-width: 300px) {
	
	input[type=text] {
		width: 100%;
		height: 40px;
		padding: 1em 10px;
		border: 1px solid #B7B6B6;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		font-size: 13px;
		background: #FFF;
	}
	
	input[type=text].name {
		width: 70%;
		height: 60px;
		margin: 0 0 10px 0;
		padding: 1em 10px;
		font-size: 12px;
		border-radius: 5px;
	}
	
	input[type=text].txtype {
		width: 90%;
		height: 60px;
		margin: 0 10px 0 0;
		padding: 1em 10px;
		font-size: 12px;
		border-radius: 5px;
	}
	
	input[type=text].pref {
		width: 40%;
		height: 60px;
		margin: 0 10px 0 0;
		padding: 1em 10px;
		font-size: 12px;
		border-radius: 5px;
	}
	
	input[type=text].year {
		width: 50px;
		height: 60px;
		padding: 1em 10px;
		font-size: 12px;
		border-radius: 5px;
	}
	
	input[type=text].company {
		width: 100%;
		height: 60px;
		padding: 1em 10px;
		font-size: 12px;
		border-radius: 5px;
	}
	
	form dd select {
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
		height: 60px;
		margin: 0;
		padding: 4px 14px 6px;
		border: 1px solid #B7B6B6;
		background: #fff;
		box-sizing: border-box;
		background-image: url("../images/triangle.svg");
		background-repeat: no-repeat;
		background-size: 6px 15px;
		background-position: right 10px center;
		font-size: 12px;
		border-radius: 5px;
		color: #000;
	}
	
	form dd select.post {
		width: 40%;
		margin: 0;
	}
	
	form dd select.schedule {
		width: 60px;
	}
	
	form textarea {
		width: 100%;
		height: 150px;
		padding: 1em 10px;
		font-size: 12px;
		border-radius: 5px;
		border: 1px solid #B7B6B6;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		background: #FFF;
	}
	
	textarea:focus,
	input:focus {
		background-color: #F3F8F7;
	}
	
	.form_btn,
	.back_btn {
		position: relative;
		width: 90%;
		height: 64px;
		margin: 0 auto;
	}
	
	input.submit-btn,
	.back_btn a {
		margin: 0;
		padding: 0;
		display: inline-block;
		width: 100%;
		height: 100%;
		text-align: center;
		text-decoration: none;
		line-height: 64px;
		outline: none;
		font-size: 15px;
		background-color: #026ED9;
		color: #FFF;
		box-sizing: border-box;
		cursor: pointer;
		border-radius: 5px;
		
	}
	
	.form_btn span,
	.back_btn a span {
		position: absolute;
		top: 50%;
		left: 10px;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
		color: #FFF;
		font-size: 13px;
	}

}

/* Small than tablet */
@media (min-width: 768px) {
	
	input[type=text].rt {
		width: 500px;
		height: 60px;
		padding: 1em 10px;
		font-size: 12px;
	}
	
	.form-inner textarea {
		width: 100%;
		height: 150px;
	}
	
}


/* Larger than tablet */
@media (min-width: 992px) {
	
	input[type=text].name {
		width: 180px;
		height: 60px;
		margin: 0 10px 0 0;
		padding: 1em 10px;
		font-size: 13px;
		border-radius: 5px;
	}
	
	input[type=text].txtype {
		width: 70%;
		height: 60px;
		margin: 0 10px 0 0;
		padding: 1em 10px;
		font-size: 13px;
		border-radius: 5px;
	}
	
	input[type=text].pref {
		width: 180px;
		height: 60px;
		margin: 0 10px 0 0;
		padding: 1em 10px;
		font-size: 13px;
		border-radius: 5px;
	}
	
	input[type=text].company {
		width: 100%;
		height: 60px;
		padding: 1em 10px;
		font-size: 13px;
		border-radius: 5px;
	}
	
	.form-area textarea {
		width: 100%;
		height: 150px;
		padding: 1em 10px;
		font-size: 13px;
		border-radius: 5px;
	}
	
	form dd select {
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
		height: 60px;
		margin: 0;
		padding: 4px 14px 6px;
		border: 1px solid #B7B6B6;
		background: #fff;
		box-sizing: border-box;
		background-image: url("../images/triangle.svg");
		background-repeat: no-repeat;
		background-size: 6px 15px;
		background-position: right 10px center;
		font-size: 13px;
	}
	
	form dd select.post {
		width: 180px;
	}
	
	.form_btn,
	.back_btn {
		position: relative;
		width: 250px;
		height: 64px;
		margin: 0 auto;
	}
	
	input.submit-btn,
	.back_btn a {
		margin: 0;
		padding: 0;
		display: inline-block;
		width: 100%;
		height: 100%;
		text-align: center;
		text-decoration: none;
		line-height: 64px;
		outline: none;
		font-size: 15px;
		background-color: #026ED9;
		color: #FFF;
		box-sizing: border-box;
		cursor: pointer;
		
	}

}


/*--------------------------------------------------------------
Validate
--------------------------------------------------------------*/

input[type=text].error,
textarea.error,
form dd select.error {
	background-color: #FFF7CB;
}

label.error {
	display: block;
	line-height: 1.2;
	margin-top: 0.5em;
	margin-bottom: 0.5em;
	color: #C00;
	font-size: 13px;
}