@charset "utf-8";
/* CSS Document */

.copy{
	margin-bottom: 100px;
}

.contents_wrap {
    margin-top: 70px;
}

@media screen and (max-width: 979px) {
    .contents_wrap {
        margin-top: 0;
    }
}



.common_sub_ttl_wrap{
	background: #FDFAF4 url("../images/service_head_bg.jpg") left bottom;
	background-repeat: no-repeat;
	background-size: cover;

}

@media screen and (max-width: 640px) {
	.common_sub_ttl_wrap{
	background: #FDFAF4 url("../images/service_head_bg_sp.jpg") left bottom;
	background-size: cover;
}
	}




.common_sub_ttl{
	color: var(--brown);
	font-size: 1.875rem;
	font-weight: 700;
	text-align: center;
	padding: 2rem 1rem 3rem;
	box-sizing: border-box;
}

.common_sub_ttl span{
	    position: relative;
    display: inline-block;
    padding: 0 2.5rem;
    font-size: var(--font-size21);
    font-weight: 600;
    margin-top: 1rem;
    line-height: 1.2;
}


.common_sub_ttl span:before {
    left: 0;
}

.common_sub_ttl span:after {
    right: 0;
}


.common_sub_ttl span:before,.common_sub_ttl span:after{
	content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 20px;
    height: 1px;
    background-color: var(--brown);
}


.intro_wrap_top{
	padding: 6% 0 11%;
	box-sizing: border-box;
	position: relative;
}
.intro_wrap_top>img{
	width: 90%;
	max-width: 1000px;
	position: absolute;
	bottom: -30px;
	left: 50%;
	transform: translateX(-50%);

}

.intro_service{
	background:url("../images/intro_bg.png") no-repeat;
	background-size:100%;
	background-position: center;
}

.intro_wrap_top h3{
	text-align: center;
}
.intro_wrap_top h3 img{
		width: 50%;
	max-width: 500px;
}

.main-container{
	margin: 130px auto 20px;
}
.main-bg{
	margin: 60px auto 80px;
}
.main-wrap{
	display: flex;
	align-items: flex-start;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 20px;
}
.main-wrap img{
	max-width: 480px;
	object-fit: contain;
}
.main-contents{
	margin-left: 3%;
}
.step-title{
	font-size: 2rem;
	font-family: "Noto Sans JP", sans-serif;
  	font-weight: 500;
	color: #285254;
	border-left: 3px solid #285254;
	padding-left: 0.5em;
}
.step-lead{
	margin: 20px 0 30px;
}
.step-lead span{
	background: linear-gradient(transparent 40%, #FDFFC5 40%);
	font-size: 1.5rem;
	padding: 0 0.5em 0;
}
.contents-box{
	font-size: 0.9em;
	background-color: #EDFDFF;
	border-radius: 20px;
	padding: 2rem;
	color: #0f0f0f;
	box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1);
	line-height: 1.5;
	max-width: 650px;
	letter-spacing: 0.05em;
}
.contents-box-link{
	text-align: center;
}
.contents-box-link a{
	display: block;
	text-decoration: none;
	color: #DA3A3A;
	margin: 1rem auto 0;
	background-color: #FFE3E2;
	border-radius: 5px;
	padding: 1em 1.8rem 1rem 1rem;
	width:90%;
	max-width: 310px;
	font-family: "Noto Sans JP", sans-serif;
	position: relative;
}
.contents-box-link a::after{
	content: '';
	display: inline-block;
	background-image: url(../images/link_arrow.png);
	background-repeat: no-repeat;
	background-size: contain;
	width: 0.8em;
	height: 0.8em;
	position: absolute;
	top: 38%;
	right: 5%;
}
.contents-sub{
	margin-top: 1.5em;
}
.main-bg-2{
	background-color: #EDFDFF;
	padding: 60px 0 100px;
}
.main-contents-2{
	margin: 0 3% 0 0;
}
.contents-box-2{
	background-color: #fff;
}
@media screen and (max-width: 979px) {
	.break{
		display: none;
	}
    .main-wrap{
		flex-direction: column;
	}
	.reverse{
		flex-direction: column-reverse;
	}
	.main-container{
		margin: 100px auto 70px;
	}
	.main-bg{
		margin: 40px 0 60px;
	}
	.main-bg-2{
		padding: 40px 0 60px;
	}
	.main-wrap picture{
		display: block;
		margin: 0 auto;
	}
	.main-wrap img{
		width: 100%;
	}
	.main-contents{
		margin: 0 auto;
		display: block;
	}
	.step-title{
		border: none;
		padding: 0;
		font-size: 25px;
		margin-top: 1em;
		font-weight: 600;
	}
	.step-lead span{
		font-size: 20px;
	}
	.contents-box{
		text-align: left;
		font-size: 0.9em;
		/*line-height: 1;*/
	}
}
@media screen and (max-width: 640px) {
	.intro_sp_top{
		width: 100%;
	}
	
	.intro_wrap h3 img{
		width: 90%;
	}

	.intro_wrap_top{
		background:url("../images/intro_bg.png") no-repeat center;
		background-size: 200%;
		padding: 6rem 0 6rem;
		position: relative;
		z-index: -1;
	}
	
	.intro_wrap_top h3 img{
		width: 100%;
	}
	.intro_wrap_top>img{
		display: none;
	}
	.main-container{
		margin-top: -60px;
	}
}