@charset "UTF-8";
/*――――――――――――――――――
mv
―――――――――――――――――――*/
#ec #under_mv {
	background-image: url(../img/ec/under_mv.jpg);
}
@media only screen and (max-width: 767px) {
	#ec #under_mv .ttl br {
		display: none;
	}
}

/*――――――――――――――――――
section02
―――――――――――――――――――*/
#ec #section02 {
	background: #f3f5f7 url(../img/common/wave.svg) repeat-x center top;
	padding: 70px 0 80px;
}
#ec #section02 h2 {
	color: #76a0f4;
	font-weight: bold;
	font-size: 39px;
	text-align: center;
	margin-bottom: 45px;
}
#ec #section02 .flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 28px 0;
}
#ec #section02 .flex > div {
	background: #fff;
	width: 48.5%;
	padding: 0 16px;
}
#ec #section02 .flex .w_ttl {
	display: flex;
	align-items: flex-end;
	gap: 0 24px;
	padding: 20px 0 14px;
	border-bottom: solid 1px #ccc;
}
#ec #section02 .flex .w_ttl .point {
	line-height: 1.2;
}
#ec #section02 .flex .w_ttl .point img{
	max-width: 130px;
}
#ec #section02 .flex .w_ttl h3 {
	font-weight: bold;
	font-size: 25px;
	line-height: 1.4;
}
#ec #section02 .flex .text {
	padding: 18px 8px 25px;
}
#ec #section02 .flex .text p {
	font-size: 17px;
}
@media only screen and (max-width: 1023px) {
	#ec #section02 .flex > div {
		width: 100%;
	}
	#ec #section02 .flex .w_ttl h3 {
		font-size: 22px;
	}
	#ec #section02 h2,
	#ec #section03 h2 {
		font-size: 30px;
		margin-bottom: 30px;
	}
}
@media only screen and (max-width: 767px) {
	#ec #section02 {
		padding: 60px 0 50px;
	}
	#ec #section02 .flex .w_ttl img {
		max-width: 80px;
	}
	#ec #section02 .flex .w_ttl .point img{
		max-width: 100px;
	}
	#ec #section02 .flex .w_ttl h3 {
		font-size: 18px;
	}
	#ec #section02 .flex .w_ttl h3 br{
		display: none;
	}
	#ec #section02 .flex .text p {
		font-size: 15px;
		line-height: 1.8;
	}
	#ec #section02 h2,
	#ec #section03 h2 {
		font-size: 22px;
		margin-bottom: 20px;
	}
}

/*――――――――――――――――――
section04
―――――――――――――――――――*/
#ec #section04 {
	padding: 70px 0 70px;
}
#ec #section04 h2 {
	font-size: 37px;
	font-weight: bold;
	position: relative;
	margin-bottom: 20px;
}
#ec #section04 h2:after {
	position: absolute;
	right: 0;
	top: 50%;
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	background: #181818;
}
#ec #section04 h2 span {
	position: relative;
	z-index: 1;
	display: inline-block;
	background: #fff;
	padding-right: 20px;
}
#ec #section04 .works {
	display: flex;
	gap:2%;
	flex-direction: row;
	flex-wrap: wrap;
	align-content: center;
	justify-content: center;
	align-items: center;
	margin-bottom: 20px;
}
#ec #section04 .works .w_left {
	width: 64%;
}
#ec #section04 .works .w_right {
	width: 34%;
}
#ec #section04 .works .w_ttl {
	line-height: 1.1;
	background: url(../img/common/line.svg) no-repeat left center;
	min-height: 80px;
	padding: 10px 0 0 22px;
	margin-bottom: 10px;
}
#ec #section04 .works .w_ttl h3 {
	font-weight: bold;
	font-size: 23px;
	color: #76a0f4;
	margin-bottom: 10px;
}
#ec #section04 .works .w_ttl p {
	font-size: 17px;
	color: #4d4d4d;
}
#ec #section04 .works .w_text p {
	font-size: 16px;
}

@media only screen and (max-width: 1023px) {
	#ec #section04 h2 {
		font-size: 30px;
	}
}
@media only screen and (max-width: 767px) {
	#ec #section04 h2 {
		font-size: 20px;
	}
	#ec #section04 h2 span {
		padding-right: 10px;
	}
	#ec #section04 .works .w_left {
		width: 100%;
		order: 2;
	}
	#ec #section04 .works .w_right {
		width: 100%;
		text-align: center;
		margin:20px auto;
		order: 1;
	}
	#ec #section04 .works .w_right img{
		width: 90%;
	}
	#ec #section04 .works.works01 {
		margin-bottom: 45px;
	}
	#ec #section04 .works .w_ttl {
		min-height: 70px;
	}
	#ec #section04 .works .w_ttl h3 {
		font-size: 20px;
	}
	#ec #section04 .works .w_ttl p {
		font-size: 16px;
	}
	#ec #section04 .works .w_text p {
		font-size: 15px;
		margin-bottom: 15px;
	}
}
