@charset "utf-8";

/*******************************
  個別設定
*******************************/

#section01 {
	margin: 65px 0 0;
}
#section02 {
	margin: 125px 0 0;
}

#main .wrap {
	width: 960px;
}
#main section .wrap {
	position: relative;
}
#main section .text {
	width: 530px;
}
#main .sectionTitle {
	padding: 0 0 0 74px;
	position: relative;
	font-size: 20px;
	font-weight: normal;
	line-height: 35px;
}
#main .sectionTitle .firstLetter {
	position: absolute;
	top: 0;
	left: 0;
	font-size: 65px;
	line-height: 63px;
	transform: translateY(5%);
}
@media all and (-ms-high-contrast:none) {
	#main .sectionTitle .firstLetter {
		top: 2px;
	}
}
#main section p {
	margin: 30px 0 0;
}
#main section .image {
	width: 572px;
	position: absolute;
	top: 0;
}
#section01 .image {
	right: 10px;
	transform: translateX(240px);
}
#section02 .text {
	margin: 0 0 0 430px;
}
#section02 .image {
	left: 10px;
	transform: translateX(-240px);
}
@media only screen and (max-width:640px) {
	#section01 {
		margin: calc(100vw * 70 / 640) 0 0;
	}
	#section02 {
		margin: calc(100vw * 130 / 640) 0 0;
	}

	#main .wrap {
		width: auto;
	}
	#main section .text {
		width: auto;
	}
	#main .sectionTitle {
		padding: 0 0 0 3.6em;
		font-size: calc(13.5em / 14);
		font-weight: normal;
		line-height: 1.8em;
	}
	#main .sectionTitle .firstLetter {
		font-size: 3.6em;
		font-weight: bold;
		line-height: 1;
	}
	#main section p {
		margin: calc(100vw * 30 / 640) 0 0;
	}
	#main .image.sp {
		display: block;
		width: auto;
		margin: 0;
		position: static;
		transform: none;
	}
	#main .image.sp img {
		display: block;
	}
	#section02 .text {
		margin: 0;
	}
	#section02 .sectionTitle br {
		display: none;
	}
}

#block01 {
	margin: 50px 0 75px;
}
#block01 .text {
	margin: 85px 0 0;
	text-align: center;
}
#block01 .image02 {
	width: 860px;
	margin: 50px auto 0;
}
#block01 ul {
	display: flex;
	margin: 60px auto 0;
	flex-wrap: wrap;
	justify-content: space-between;
}
#block01 li {
	width: 462px;
	margin: 35px 0 0;
}
#block01 li:nth-child(-n+2) {
	margin-top: 0;
}
#block01 li .label .en {
	font-size: 24px;
	font-weight: bold;
}
#block01 li .label .ja {
	font-size: 10px;
}
#block01 li .label {
	margin: 15px 0 0;
	border-bottom: 1px solid #e5e5e5;
	padding: 0 0 13px;
}
#block01 li p {
	margin: 15px 0 0;
	line-height: 26px;
}
@media only screen and (max-width:640px) {
	#block01 {
		margin: calc(100vw * 50 / 640) 0 calc(100vw * 80 / 640);
	}
	#block01 .text {
		margin: calc(100vw * 90 / 640) 0 0;
		text-align: left;
	}
	#block01 .image02 {
		width: auto;
		margin: calc(100vw * 50 / 640) auto 0;
	}
	#block01 ul {
		display: block;
		margin: calc(100vw * 30 / 640) auto 0;
	}
	#block01 li,
	#block01 li:nth-child(2) {
		width: auto;
		margin: calc(100vw * 40 / 640) 0 0;
	}
	#block01 li:nth-child(1) {
		margin-top: 0;
	}
	#block01 li .label .en {
		font-size: calc(24em / 14);
		line-height: 1.2;
	}
	#block01 li p {
		line-height: calc(26 / 14);
	}
}








