@charset "UTF-8";



/* ------------------------------
	.mv
------------------------------ */
.mv{
	height: 495px;
	background: url(../img/about/mv_img.jpg) no-repeat center center;
	background-size: cover;
}


@media screen and (max-width: 768px){
	.mv{
		height: 50vw;
	}
}



/* ------------------------------
	.about
------------------------------ */
.about{
	padding: 30px 0 0;
}

.lead{
	padding-bottom: 3%;
	background: url(../img/about/lead_bg.png) no-repeat right bottom;
}

.lead .ttl{
	margin-bottom: 40px;
}

.lead .txt.kokoro{
	margin-top: 20px;
	font-size: 2.0rem;
}

.lead_wrap{
	margin-top: 95px;
}

.lead_box{
	width: 48%;
}

.lead_box + .lead_box{
	margin-top: 40px;
}

.lead_box .lead_txt{
	margin-bottom: 15px;
}


@media screen and (max-width: 768px){
	.about{
		padding: 8vw 0 0;
	}

	.lead{
		padding-bottom: 42vw;
		background-size: 100%;
	}

	.lead .ttl{
		width: 20%;
		margin: 0 auto 5vw;
	}
	.lead .ttl + .center{
		width: 70%;
		margin: 0 auto;
	}

	.lead .txt.kokoro{
		margin-top: 3.5vw;
		font-size: 4.2vw;
	}

	.lead_wrap{
		margin-top: 10vw;
	}

	.lead_box + .lead_box{
		margin-top: 6vw;
	}

	.lead_box .lead_txt{
		width: 14vw;
		margin-bottom: 2vw;
	}

	.lead_box{
		width: 100%;
	}
}




/* ------------------------------
	.pride
------------------------------ */
.pride{
	margin-top: 130px;
}

.pride_wrap{
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

.pride_wrap + .pride_wrap{
	margin-top: 100px;
}

.pride_wrap .img{
	flex-shrink: 0;
	width: 48%;
}

.pride_wrap:nth-child(even) .img{
	order: 2;
}
.pride_wrap:nth-child(even) .txt_box{
	order: 1;
}

.pride_wrap .txt_box{
	width: 43%;
}

.pride_wrap .ttl{
	margin-bottom: 0.4em;
	letter-spacing: 0.1em;
	font-size: 2.5rem;
	line-height: 1.6;
	word-break: break-all;
}

.pride_wrap .txt{
	word-break: break-all;
	line-height: 1.625;
}

.pride_wrap .box-ttl{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 40px;
}
.pride_wrap.reverse .box-ttl{
	margin-left: 16%;
	margin-right: -16%;
}
.pride_wrap .box-ttl .kokoro{
	font-size: 2.5rem;
	line-height: 1.6;

}
.pride_wrap .box-ttl .num{
	font-weight: 600;
	color: #90c766;
	font-family: Arial, "sans-serif";
	margin-right: 20px;
}

.pride_wrap:nth-child(1) .box-ttl{
	color: #90c766;
}
.pride_wrap:nth-child(2) .box-ttl{
	color: #1ca8a8;
}
.pride_wrap:nth-child(3) .box-ttl{
	color: #f08428;
}


@media screen and (max-width: 768px){
	.pride{
		margin-top: 10vw;
	}

	.pride_wrap{
		flex-direction: column;
	}
	.pride_wrap + .pride_wrap{
		margin-top: 12vw;
	}

	.pride_wrap .img{
		width: 80%;
	}

	.pride_wrap .txt_box{
		width: 100%;
	}

	.pride_wrap:nth-child(even) .img{
		order: 1;
	}
	.pride_wrap:nth-child(even) .txt_box{
		order: 2;
	}

	.pride_wrap .box-ttl{
		display: block;
		margin-bottom: 6%;
		margin-top: -6vw;
	}
	.pride_wrap .box-ttl .kokoro{
		font-size: 5.4vw;
	}
	.pride_wrap .box-ttl .num{
		display: block;
		width: 10vw;
		font-size: 10vw;
		margin-right: 0;
		margin-bottom: 4%;
	}
}



/* ------------------------------
	.sec_reason
------------------------------ */
.sec_reason{
	position: relative;
	padding: 30px 0 0 0;
	margin-top: 150px;
	box-sizing: border-box;
}

.sec_reason .sec_ttl.ico{
	background: url(../img/about/sec_ttl_ico.svg) no-repeat center top;
}

.reason_box{
	position: relative;
	display: flex;
	background: #fefcf5;
}
.reason_box.reverse{
	flex-direction: row-reverse;
}
.reason_box .wrapIn{
	width: 50%;
}
.reason_box .txt{
	min-height: 31vw;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.reason_box.reverse .txt{
	align-items: flex-end;
}

.reason_box .txt .box-ttl{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 40px;
}
.reason_box.reverse .txt .box-ttl{
	margin-left: 16%;
	margin-right: -16%;
}
.reason_box .txt .box-ttl .kokoro{
	font-size: 2.5rem;
	line-height: 1.6;

}
.reason_box .txt .box-ttl .num{
	font-size: 8.5rem;
	font-weight: 600;
	color: #90c766;
	font-family: Arial, "sans-serif";
	margin-right: 20px;
}
.reason_box:nth-of-type(2) .txt .box-ttl .num{ color: #1ca8a8;}
.reason_box:nth-of-type(3) .txt .box-ttl .num{ color: #f08428;}

.reason_box .txt p{
	font-size: 1.6rem;
	line-height: 1.625;
	padding-right: 16%;
}
.reason_box .txt p+p{ margin-top: 20px;}

.reason_box.reverse .txt p{
	padding-right: 0;
	padding-left: 16%;
}

.reason_box .img{
	width: 50%;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
}

.reason_box:nth-of-type(1) .img{
	background: url(../img/top/img01_reason.jpg) no-repeat center center;
	background-size: cover;
}
.reason_box:nth-of-type(2) .img{
	background: url(../img/top/img02_reason.jpg) no-repeat center center;
	background-size: cover;
}
.reason_box:nth-of-type(3) .img{
	background: url(../img/top/img03_reason.jpg) no-repeat center center;
	background-size: cover;
}


.reason_box.reverse .img{
	left: 0;
	right: auto;
}
.reason_box .img img{
	width: 100%;
	max-width: inherit;
}

@media screen and (max-width: 1400px) {
	.reason_box .txt{
		justify-content: flex-start;
		padding: 30px 0;
		min-height: inherit;
	}
	.reason_box.reverse .txt .box-ttl{
		margin-left: 8%;
		margin-right: 0%;
	}
	.reason_box.reverse .txt p{
		padding-left: 8%;
	}

}
@media screen and (max-width: 768px) {
	.sec_reason{
		margin-top: 12vw;
		padding: 8% 0 0 0;
	}

	.reason_box,
	.reason_box.reverse {
		display: flex;
		flex-direction: column-reverse;
	}

	.reason_box .wrapIn{
		width: 100%;
	}
	.reason_box .txt{
		min-height: inherit;
		display: block;
		margin-top: 5%;
		padding: 0 0 8%;
	}

	.reason_box .txt .box-ttl{
		display: block;
		margin-bottom: 6%;
		margin-top: 4%;
	}
	.reason_box.reverse .txt .box-ttl{
		margin-left: 0;
		margin-right: 0;
	}
	.reason_box .txt .box-ttl .kokoro{
		font-size: 5.4vw;
	}
	.reason_box .txt .box-ttl .num{
		display: block;
		font-size: 10vw;
		margin-right: 0;
		margin-bottom: 4%;
	}
	.reason_box:nth-of-type(2) .txt .box-ttl .num{ color: #1ca8a8;}
	.reason_box:nth-of-type(3) .txt .box-ttl .num{ color: #f08428;}

	.reason_box .txt p{
		font-size: 3.6vw;
		padding-right: 0;
	}
	.reason_box .txt p+p{ margin-top: 4%;}

	.reason_box.reverse .txt p{
		padding-left: 0;
	}

	.reason_box .img{
		width: 100%;
		height: 63vw;
		position: relative;
	}

	.sec_reason .sec_ttl.ico{
		background-size: 35%;
	}

}




/* ------------------------------
	.message
------------------------------ */
.message{
	margin-top: 130px;
}

.message .ttl{
	margin-bottom: 55px;
	margin-top: 25px;
	font-size: 2.0rem;
	letter-spacing: 0.05em;
}

.message .flex{
	display: flex;
	justify-content: space-between;
}

.message .txt_box{
	width: 50%;
}

.message .txt_box .img{
	margin-top: 25px;
}
.message .txt_box .img,
.message .txt_box .img img{
	pointer-events: none;
}

.message .flex > .img{
	position: relative;
	width: 50%;
	text-align: center;
}

.message .flex > .img span{
	position: absolute;
	right: 10px;
	bottom: 150px;
	content: "";
	display: block;
	width: 170px;
	height: 170px;
	background: url(../img/common/sec_ttl_ico.svg) no-repeat center center;
	background-size: 100%;
}


@media screen and (max-width: 768px){
	.message{
		margin-top: 10vw;
	}

	.message .flex{
		flex-direction: column;
	}

	.message .message_txt{
		width: 55%;
		margin: 0 auto;
	}

	.message .ttl{
		margin: 3vw 0 8vw;
		font-size: 4.5vw;
	}

	.message .txt_box{
		order: 2;
		width: 100%;
	}

	.message .txt_box .img{
		margin-top: 2vw;
		width: 40%;
		margin-left: auto;
	}

	.message .flex > .img{
		order: 1;
		width: 70%;
		margin: 0 auto 6vw;
	}
	.message .img img{
		width: 100%;
	}

	.message .flex > .img span{
		right: -12%;
		bottom: -5vw;
		width: 25vw;
		height: 25vw;
	}
}




/* ------------------------------
	.summary
------------------------------ */
.summary{
	position: relative;
	padding: 10px 0 180px;
	margin-top: 200px;
	background: #fefcf5;
}

.summary::before{
	position: absolute;
	top: -5.9vw;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 6vw;
	background: url(../img/about/summary_bg.svg) no-repeat center top;
	background-size: 100%;
}

.summary_wrap{
	max-width: 680px;
	margin: 0 auto;
}

.summary_box{
	display: flex;
	width: 100%;
	padding: 15px 0;
}
.summary_box + .summary_box{
	border-top: 1px solid #90c766;
}

.summary_box dt{
	flex-shrink: 0;
	width: 180px;
	padding-left: 35px;
}

.summary_box dd{
	width: 100%;
}


@media screen and (max-width: 768px){
	.summary{
		margin-top: 18vw;
		padding: 5vw 0 22vw;
	}

	.summary .sec_ttl{
		margin-bottom: 5%;
	}

	.summary_box{
		flex-direction: column;
		padding: 5vw 0;
	}

	.summary_box dt{
		width: 100%;
		padding-left: 0;
		padding-bottom: 1.5vw;
	}
}