@charset "UTF-8";


/*-----------------------------------

	system_block

-----------------------------------*/
#system_block {
	padding-bottom: 100px;
}
#system_block .contents_inner {
	background: url(../img/common/headline_bg.png) no-repeat top left/510px 348px;
	margin-top: -110px;
    padding-top: 110px;
}

@media screen and (max-width: 640px) {
	#system_block {
		padding-bottom: 50px;
	}
	#system_block .contents_inner {
		background: url(../img/common/headline_bg.png) no-repeat top left/336px 229px;
		margin-top: -50px;
		padding-top: 50px;
	}
}
/*-- intro --*/
#system_block #intro {
	margin-bottom: 80px;
}
#system_block #intro h2 {
	font-size: 20px;
	line-height: 1;
	margin-bottom: 50px;
}
#system_block #intro h2::before {
	content: "SYSTEM";
	font-size: 62px;
	font-family: 'Montserrat', sans-serif;
	display: block;
	margin-bottom: 30px;
}
#system_block #intro > p {
	color: #333333;
}
#system_block #intro .wrap {
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 80px 0 40px;
}
#system_block #intro .wrap .imageArea {
	width: 40%;
}
#system_block #intro .wrap .imageArea img {
	border-radius: 10px;
}
#system_block #intro .wrap .textArea {
	width: 51%;
	padding-top: 50px;
}
#system_block #intro .wrap .textArea h3 {
	font-size: 28px;
	line-height: 1.5;
	margin-bottom: 30px;
}
#system_block #intro .wrap .textArea p:first-of-type {
	margin-bottom: 20px;
}
#system_block #intro .box {
	border: 2px solid #fee9e6;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
#system_block #intro .box .before {
	width: 45%;
	padding: 50px 0;
	background: #fee9e6;
	position: relative;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
#system_block #intro .box .before::after {
	content: "";
	width: 60px;
	height: 100%;
	background: url(../img/system/intro_box_arrow.png) center center/100% 100%;
	position: absolute;
	top: 0;
	left: 100%;
}
#system_block #intro .box .before h3 {
	font-size: 24px;
	line-height: 1.4;
	letter-spacing: 0;
	margin-bottom: 20px;
	color: #fa6a8c;
}
#system_block #intro .box .before ul li {
	position: relative;
	font-size: 16px;
	font-weight: 600;
	padding-left: 23px;
}
#system_block #intro .box .before ul li::before {
	content: "";
	width: 16px;
	height: 14px;
	background: url(../img/system/check_icon.png) no-repeat center/contain;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
#system_block #intro .box .after {
	width: 55%;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
#system_block #intro .box .after p {
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0;
}
@media screen and (max-width: 1130px) {
	#system_block #intro .box .before {
		padding: 50px 0 50px 50px;
	}
	#system_block #intro .box .before h3 {
		font-size: 20px;
		margin-bottom: 15px;
	}
}
@media screen and (max-width: 960px) {
	#system_block #intro .wrap .textArea {
		width: 55%;
		padding-top: 0;
	}
	#system_block #intro .wrap .textArea h3 {
		font-size: 24px;
	}
	#system_block #intro .box .before {
		padding: 30px 0;
	}
}
@media screen and (max-width: 840px) {
	#system_block #intro .contents_inner {
		margin-top: -80px;
		padding-top: 80px;
	}
	#system_block #intro h2 {
		font-size: 18px;
	}
	#system_block #intro h2::before {
		font-size: 46px;
		margin-bottom: 20px;
	}
	#system_block #intro .box {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}
	#system_block #intro .box .before {
		width: 100%;
	}
	#system_block #intro .box .before::after {
		content: "";
		width: 100%;
		height: 40px;
		background: url(../img/system/sp/intro_box_arrow.png) center center/100% 100%;
		top: 100%;
		left: 0;
	}	
	#system_block #intro .box .after {
		width: 100%;
		padding: 80px 0 30px;
	}
}
@media screen and (max-width: 640px) {
	#system_block #intro {
		margin-bottom: 40px;
	}
	#system_block #intro h2 {
		font-size: 16px;
		margin-bottom: 30px;
	}
	#system_block #intro h2::before {
		font-size: 34px;
	}
	#system_block #intro .wrap {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		gap: 20px;
		max-width: 380px;
		width: 100%;
		margin: 40px auto 20px;
	}
	#system_block #intro .wrap .imageArea {
		width: 100%;
	}
	#system_block #intro .wrap .textArea {
		width: 100%;
	}
	#system_block #intro .wrap .textArea h3 {
		font-size: 20px;
		margin-bottom: 20px;
	}
	#system_block #intro .box {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}
	#system_block #intro .box .before ul li {
		font-size: 14px;
	}
	#system_block #intro .box .after p {
		font-size: 14px;
	}
	
}
/*-- box --*/
#system_block #box {
	background: #f7f5f2;
	padding: 80px 0;
}
#system_block #box h3 {
	font-size: 28px;
	line-height: 1;
	padding-top: 20px;
	position: relative;
	margin-bottom: 30px;
}
#system_block #box h3::before {
	content: "";
	width: 29px;
	height: 4px;
	background: #fa6a8c;
	position: absolute;
	top: 0;
	left: 0;
}
#system_block #box h3 br {
	display: none;
}
#system_block #box h4 {
	font-size: 22px;
	color: #fa6a8c;
	font-family: 'Montserrat', sans-serif, 'Noto Sans JP', sans-serif;
	line-height: 1.4;
}
#system_block #box .wrap {
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 40px;
}
#system_block #box .wrap .textArea {
	width: 48%;
}
#system_block #box .wrap .textArea p {
	margin-bottom: 20px;
}
#system_block #box .wrap .imageArea {
	width: 42%;
}
#system_block #box .item {
	border: 1px solid #fa6a8c;
	padding: 40px;
	margin-bottom: 30px;
}
#system_block #box .item .ttl {
	font-size: 20px;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 20px;
}
#system_block #box .item ul {
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	gap: 10px calc((100% - (24% * 4)) / 3);
}
#system_block #box .item ul li {
	width: 24%;
	background: #fee9e6;
	padding: 10px 0;
	text-align: center;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.4;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
#system_block #box .pinkBox {
	border: 1px solid #fa6a8c;
	background: #FFF;
	padding: 40px;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 50px;
	color: #333333;
	margin-bottom: 20px;
}
#system_block #box .pinkBox ul li {
	padding-left: 23px;
	font-weight: 600;
	position: relative;
}
#system_block #box .pinkBox ul li::before {
	content: "";
	width: 16px;
	height: 14px;
	background: url(../img/system/check_icon.png) no-repeat center/contain;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}

@media screen and (max-width: 840px) {
	#system_block #box h3 {
		line-height: 1.4;
	}
	#system_block #box h3 br {
		display: inline-block;
	}
	#system_block #box .wrap {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		gap: 30px;
	}
	#system_block #box .wrap .textArea {
		width: 100%;
	}
	#system_block #box .wrap .imageArea {
		max-width: 400px;
		width: 100%;
		margin: 0 auto;
	}
	#system_block #box .item ul {
		gap: 10px calc((100% - (32% * 3)) / 2);
	}
	#system_block #box .item ul li {
		width: 32%;
	}
	#system_block #box .pinkBox {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		gap: 0;
	}
	#system_block #box .pinkBox ul {
		width: 310px;
	}
}
@media screen and (max-width: 640px) {
	#system_block #box {
		padding: 40px 10px;
	}
	#system_block #box h3 {
		font-size: 22px;
		padding-top: 15px;
		margin-bottom: 20px;
	}
	#system_block #box h3::before {
		content: "";
		width: 20px;
		height: 3px;
	}
	#system_block #box h4 {
		font-size: 18px;
	}
	#system_block #box .item {
		padding: 20px;
		margin-bottom: 20px;
	}
	#system_block #box .item .ttl {
		font-size: 18px;
		margin-bottom: 15px;
	}
	#system_block #box .item ul {
		gap: 10px calc(100% - (49% * 2));
	}
	#system_block #box .item ul li {
		width: 49%;
	}
	#system_block #box .pinkBox {
		padding: 20px;
	}
	#system_block #box .pinkBox ul {
		width: 275px;
	}
}