@charset "utf-8";
/*
@media (min-width: 1025px) {
	.frame {
		padding: 120px 0 50px;
	}
}

@media (width <= 1024px) {
	.frame {
		padding: 70px 15px 30px;
	}
}
*/
/*---------------------------------------------------------------------- step --*/

.step {
	display: flex;
	display: none;
	justify-content: space-between;
	position: relative;
}

.step:after {
	position: absolute;
	top: 50%;
	left: 0;
	content: '';
	width: 100%;
	height: 0;
	border-top: 1px dotted #aaa;
	z-index: 0;
}

.step_item {
	width: 150px;
	height: 150px;
	padding: 55px 0 0;
	border: 3px dashed #ccc;
	border-radius: 100px;
	background: #FFF;
	z-index: 1;
}

.si_active {
	border: 3px solid #337;
	background: ;
}

.si_complete {
	position: relative;
	border: none;
}

.si_complete:after {
	content: '';
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 3px solid #226;
	border-radius: 100px;
	background: url(/asset/image/contact/complete2_226.png?m=20000101) no-repeat center / 100% auto;
	opacity: 0.1;
	z-index: 5;
}

.step_number {
	line-height: 1em;
	font-family: RobotoCond-B;
	font-size: 14px;
	text-align: center;
}

.step_title {
	font-family: YuGo-B;
	text-align: center;
}

@media (min-width: 1025px) {
	.step {
		margin: 0 180px 50px;
	}

	.global .step_title {
		font-size: 16px;
	}
}

@media (width <= 1024px) {
	.step {
		margin: 15px 0 30px;
	}

	.step_item {
		width: 75px;
		height: 75px;
		padding: 20px 0 0;
	}
}






/*---------------------------------------------------------------------- cover_large --*/

.form {
	padding: 100px;
	border: 1px solid #f0f0f0;
	border-radius: var(--border_radius);
	background: #f7f7f7;
}

@media (min-width: 1025px) {
	.form {
		margin-top: 50px;
	}
}

@media (width <= 1024px) {
	.form {
		margin-top: 30px;
		padding: 15px;
	}
}

.form dl {
	display: flex;
	padding-bottom: 15px;
}

.form dt {
	width: 250px;
	line-height: 44px;
	font-family: YuGo-B;
	font-size: ;
}

.form dt p {
	padding-right: 15px;
	line-height: 18px;
	font-size: 13px;
}

.form dd {
	width: calc(100% - 250px);
}

.column_two {
	display: flex;
}

.column_two li {
	display: flex;
	width: 50%;
}

.column_two span {
	width: 50px;
	line-height: 44px;
	text-align: center;
}

.form input:not([type="submit"]):not([type="checkbox"]), .form select, .form textarea {
	width: 100%;
	padding: 5px 10px;
	border: 1px solid #f0f0f0;
	border-radius: 5px;
	background: #fff;

	font-size: 20px;
}

.form textarea {
	height: 300px;
}


.form *::placeholder {
	color: #ccc;
}

.global *::placeholder {
	color: #FFF;
}

.required {
	margin-left: 10px;
	padding: 1px 8px 0;
	border: 1px solid #226;
	border-radius: 15px;

	font-size: 12px;
	font-weight: bold;
	color: #226;
}

@media (width <= 1024px) {
	.form dl {
		flex-wrap: wrap;
	}

	.form dt {
		width: 100%;
		line-height: 30px;
		font-size: 13px;
	}

	.form dd {
		width: 100%;
	}

	.column_two span {
		width: 30px;
		font-size: 10px;
		letter-spacing: -1px;
	}

	.form input:not([type="submit"]):not([type="checkbox"]), .form select, .form textarea {
		font-size: 16px;
	}

	.required {
		margin-left: 5px;
		font-size: 10px;
	}
}

/*----------> ▼ .checkbox, .radio_button --*/

.checkbox {
	display: flex;
	flex-wrap: wrap;
}

.checkbox label {
	border-radius: 5px;
	font-size: 20px;
	text-align: center;
	cursor: pointer;
}

.checkbox label p {
	letter-spacing: 2px;

	text-align: center;
	color: #fff;
	font-weight: bold;
}

.global label p {
	letter-spacing: 0;
}

.checkbox input {
	margin-top: -5px;
}

.checkbox label:nth-child(1) {
	background: url(/asset/image/contact/research.jpg?m=20000101) center / cover;
}

.checkbox label:nth-child(2) {
	background: url(/asset/image/contact/construction.jpg?m=20000101) center / cover;
}

.checkbox label:nth-child(3) {
	background: url(/asset/image/contact/environment.jpg?m=20000101) center / cover;
}

.checkbox label:nth-child(4) {
	background: url(/asset/image/contact/overseas.jpg?m=20000101) center / cover;
}

.checkbox label:nth-child(5) {
	background: url(/asset/image/contact/other.jpg?m=20000101) center / cover;
}

@media (min-width: 1025px) {
	.checkbox label {
		width: calc((100% - 30px) / 3);
		padding: 40px 0 25px;
		margin-right: 15px;
	}

	.checkbox label:nth-child(3n) {
		margin-right: 0;
	}

	.checkbox label:nth-child(n + 4) {
		margin-top: 15px;
	}
}

@media (width <= 1024px) {
	.checkbox label {
		width: calc((100% - 15px) / 2);
		padding: 40px 0 25px;
		margin-top: 15px;
		margin-right: 15px;
	}

	.checkbox label:nth-child(2n) {
		margin-right: 0;
	}
}

/*----------> ▼ .checkbox, .radio_button --*/

.radio_button {
	display: flex;
	flex-wrap: wrap;
}

.radio_button input {
	display: none;
}

.radio_button label {
	border: 1px solid #226;
	border-radius: 5px;
	font-size: 20px;
	cursor: pointer;
}

.radio_button label p {
	line-height: 50px;
	letter-spacing: 2px;

	text-align: center;
	color: #226;
	font-size: 18px;
	font-weight: bold;
}

.radio_button input:checked + label {
	background: #226;
}

.radio_button input:checked + label p {
	color: #FFF;
}

.radio_button label {
	width: calc((100% - 15px) /2);
}

.radio_button label:nth-of-type(2n) {
	margin-left: 15px;
}

@media (width <= 1024px) {
	.radio_button label p {
		line-height: 40px;
		letter-spacing: 2px;
		font-size: 14px;
	}
}

/*----------> ▼ agreement --*/

.policy {
	height: 295px;
	padding: 30px;
	border-radius: var(--border_radius);
	background: #eee;
	overflow-y: scroll;
}

.policy dl {
	flex-wrap: wrap;
}

.policy dt, .policy dd {
	width: 100%;
}

.policy h3 {
	margin-bottom: 15px;
	padding-left: 10px;
	border-left: 5px solid #aaa;
	font-weight: bold;
}

.policy dt {
	margin-top: 15px;
	font-weight: bold;
}

@media (width <= 1024px) {
	.policy {
		height: 190px;
		padding: 15px;
	}

	.policy * {
		font-size: 10px;
	}
}

.agreement_box {
	display: flex;
	justify-content: center;
	padding: 25px 0;
}

.agreement_box input {
	width: inherit;
}

.agreement_box label {
	margin: 0 15px;
	font-weight: bold;
	color: #999;
	text-decoration: underline;
	cursor: pointer;
}

.go_back {
	margin-right: 15px;
	padding: 15px 50px;
	border: 1px solid #c00;
	border-radius: 100px;
	background: #FFF;
	font-weight: bold;
	color: #C00;
	text-align: center;
}

.submit {
	padding: 25px 100px;
	border-radius: 100px;
	background: #ddd;
	font-weight: bold;
	color: #FFF;
	text-align: center;
}

.margin {
	margin-top: 15px;
}

@media (min-width: 1025px) {
	.agreement_box label, .go_back, .submit {
		transition: 0.2s;
	}

	.agreement_box label:hover {
		color: #444;
	}

	.go_back:hover {
		border: 1px solid #C00;
		background: #C00 !important;
		color: #FFF;
	}

	.submit:hover {
		background: #226 !important;
	}
}

@media (width <= 1024px) {
	.submit {
		padding: 15px 50px;
		background: #226;
		clor: #FFF;
	}
}

@media (width <= 500px) {
	.go_back {
		min-width: 80%;
		margin-right: 0;
	}

	.submit {
		min-width: 80%;
		margin-top: 15px;
	}
}


/*---------------------------------------------------------------------- contact_tel --*/

.contact_tel {
	padding: 100px 0;
}

.contact_tel * {
	text-align: center;
}

.ct_title {
	font-size: 36px;
	font-weight: bold;
	color: ;
}

.ct_cover {
	margin-top: 30px;
	padding: 40px 50px 50px;
	border-radius: 5px;
	background: #dfefff;
}

.ct_number {
	font-family: Helvetica-B;
	font-size: 58px;
	color: #226;
}

.ct_number span {
	display: none;
	font-size: 24px;
	font-weight: bold;
}

.global .ct_number {
	padding-left: 50px;
}

.ct_cover .ct_note {
	font-weight: bold;
	color: #226;
}

@media (width <= 1024px) {
	.ct_cover {
		background: #dfefff;
	}
}

@media (width <= 768px) {
	.contact_tel {
		padding: 30px 0;
	}

	.ct_cover {
		padding: 20px 30px;
		background: #dfefff;
	}

	.ct_number {
		font-size: 40px;
	}
}

@media (width <= 500px) {
	.ct_number {
		font-size: 32px;
	}
}



.error {
	margin-bottom: 15px;
	border-radius: 3px;
	background: #c00;
	padding: 10px 15px;
	color: #FFF;
}


.form_title {
	margin-bottom: 5px;
	padding: 10px 15px;
	border: 0px solid #226;
	background: #226;
	font-weight: ;
	color: #FFF;
}

.form_text {
	margin: 50px 0;
	text-align: center;
	font-size: ;
	font-weight: bold;
}

.form_bold {
	text-align: center;
	font-size: 30px;
	font-weight: bold;
}

@media (width <= 1024px) {
	.form_bold {
		font-size: 24px;
	}
}

@media (width <= 767px) {
	.form_text {
		text-align: left;
	}
}


/*---------------------------------------------------------------------- confirm --*/

.confirm {
	display: flex;
	flex-wrap: wrap;
	background: #FFF;
	margin-bottom: 50px;
	padding-bottom: 0 !important;
}

.confirm dt {
	width: 20%;
	font-weight: bold;
}

.confirm dd {
	width: 80%;
	font-size: 18px;
}

.confirm_complete dt {
	width: 45%;
	text-align: right;
}

.confirm_complete dd {
	width: 55%;
	text-align: left;
}

.confirm dt, .confirm dd {
	padding: 20px 15px;
	border-bottom: 3px solid #f7f7f7;
	line-height: 24px;
}


@media (width <= 1024px) {
	.confirm {
		margin-bottom: 15px;
		padding-bottom: 15px !important;
	}

	.confirm dt {
		padding: 15px 15px 5px;
		font-size: 12px;
		line-height: 18px;
		text-align: left;
	}

	.confirm dd {
		padding: 0px 15px 5px;
		line-height: 18px;
		font-size: 16px;
	}

	.confirm dt, .confirm dd {
		width: 100%;
		border-bottom: none;
	}
}