@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual .bgBox {
	margin-bottom: -41px;
	padding: 20px 0;
	height: calc(100vh - 11.146vw);
	min-height: 500px;
	display: flex;
	align-items: center;
	position: relative;
	box-sizing: border-box;
	background: url(../img/index/main_visual.png) no-repeat center center / cover;
	z-index: 1;
}
.mainVisual .bgBox::before {
	width: 100%;
	height: 100px;
	position: absolute;
	left: 0;
	bottom: -2px;
	background: url(../img/index/bg01.png) no-repeat center center / cover;
	content: "";
}
.mainVisual .titleBox {
	margin: -72px auto 0;
	padding: 0 48px;
	width: 100%;
	max-width: 1290px;
	position: relative;
	z-index: 2;
}
.mainVisual .bgBox h2 {
	margin-bottom: 12px;
	font-size: 4rem;
	font-weight: 700;
	font-family: 'Noto Serif JP', serif;
}
.mainVisual .bgBox p {
	margin-bottom: 10px;
	font-size: 2rem;
	line-height: 1.45;
	font-family: 'Noto Serif JP', serif;
}
.mainVisual .enTitel {
	margin: 0 6px 0 -6px;
	width: auto;
	height: 11.146vw;
	position: relative;
	z-index: 2;
	text-align: center;
}
.mainVisual .enTitel img {
	width: 1400px;
	/* max-width: inherit; */
	max-width: 90%;
}
#main {
	margin-bottom: 99px;
	padding-top: 71px;
}
#main .message {
	margin-bottom: 106px;
}
#main .message .comCtrText {
	margin-bottom: 0;
}
#main .business {
	padding: 76px 0 80px;
	position: relative;
	background: #FFF url(../img/common/bg01.png) repeat left top -10px / 10px auto;
}
#main .business::before {
	/* margin-left: -732px;
	width: 306px;
	height: 458px; */
	/* margin-left: -600px; */
	margin-left: -560px;
	width: 290px;
	height: 420px;
	position: absolute;
	top: -212px;
	left: 50%;
	transform: translate(-50%);
	content: "";
	background: url(../img/index/bg03.png) no-repeat left top / cover;
}
#main .business::after {
	/* margin-right: -770px;
	width: 245px;
	height: 527px; */
	/* margin-right: -640px; */
  width: 190px;
  height: 407px;
	position: absolute;
	/* bottom: 62px; */
	bottom: 0px;
	/* right: 50%; */
	right:1vw;
	/* transform: translate(50%); */
	background: url(../img/index/bg04.png) no-repeat right bottom / cover;
	content: "";
}
#main .business .headLine03 {
	margin-bottom: 56px;
}
#main .business .imgList {
	margin-top: -20px;
	position: relative;
	z-index: 2;
}
#main .business .imgList li {
	margin-top: 20px;
	width: 48.4%;
}
#main .business .imgList .phoBox {
	margin-bottom: 28px;
}
#main .business .imgList .phoBox img {
	width: 100%;
}
#main .business .imgList h4 {
	margin-bottom: 17px;
	/* font-size: 2.3rem; */
	font-size: 2.1rem;
}
#main .business .imgList p {
	margin-bottom: 37px;
	/* font-size: 1.7rem; */
	font-size: 1.5rem;
	line-height: 1.75;
}
#main .company {
	margin-bottom: 85px;
	padding: 109px 0 117px;
	background: url(../img/index/bg02.png) no-repeat center center / cover;
}
#main .comContactBox .title {
	margin-bottom: 77px;
}
@media all and (max-width: 1099px) {
	.mainVisual .bgBox {
		margin-bottom: -14px;
		padding: 20px 0;
		height: auto;
		min-height: 656px;
		background-image: url(../img/index/main_visual_sp.png);
	}
	.mainVisual .bgBox::before {
		display: none;
	}
	.mainVisual .titleBox {
		margin: -241px auto 0;
		padding: 0 29px;
		width: 100%;
		max-width: inherit;
	}
	.mainVisual .bgBox h2 {
		margin-bottom: 15px;
		font-size: 3.5rem;
		line-height: 1.24;
	}
	.mainVisual .bgBox p {
		margin-bottom: 10px;
		font-size: 1.8rem;
		line-height: 1.59;
	}
	.mainVisual .enTitel {
		margin: 0 0 0 -1px;
		height: 32.267vw;
	}
	#main {
		margin-bottom: 97px;
		padding-top: 40px;
	}
	#main .message {
		margin-bottom: 58px;
	}
	#main .business {
		padding: 45px 0 97px;
	}
	#main .business::before {
		margin-left: 0;
		width: 78px;
		height: 105px;
		top: -17px;
		left: 28px;
		transform: none;
		background-image: url(../img/index/bg03_sp.png);
	}
	#main .business::after {
		margin-right: 0;
		width: 54px;
		height: 115px;
		right: 23px;
		bottom: 23px;
		transform: none;
	}
	#main .business .headLine03 {
		margin-bottom: 35px;
	}
	#main .business .imgList {
		margin-top: 0;
		display: block;
	}
	#main .business .imgList li {
		margin: 0 0 61px;
		width: 100%;
	}
	#main .business .imgList li:last-child {
		margin-bottom: 0;
	}
	#main .business .imgList .phoBox {
		margin-bottom: 23px;
	}
	#main .business .imgList h4 {
		margin-bottom: 5px;
		font-size: 1.8rem;
	}
	#main .business .imgList p {
		margin-bottom: 23px;
	}
	#main .company {
		margin-bottom: 49px;
		padding: 56px 0 50px;
		background-image: url(../img/index/bg02_sp.png);
	}
	#main .comContactBox .title {
		margin-bottom: 50px;
	}	
}