@charset "utf-8";
/*------------------------------------------------------------
	business02
------------------------------------------------------------*/
#main .comLinkList {
	margin-bottom: 99px;
}
#main .topBox {
	margin-bottom: 125px;
}
#main .topBox .comImgBox:last-of-type {
	margin-bottom: 0;
}
#main .topBox .imgBox01 {
	margin-bottom: 57px;
}
#main .topBox .imgBox01 .photoBox {
	margin-right: 4.4%;
	width: 38.22%;
}
#main .topBox .imgBox02 {
	align-items: flex-start;
}
#main .topBox .imgBox02 .textBox {
	margin-top: 20px;
}
#main .topBox .imgBox02 .photoBox {
	text-align: center;
}
#main .topBox .imgBox02 .photoBox img {
	width: 100%;
	max-width: 380px;
}
#main .topBox .imgBox02 .photoBox p {
	margin-top: 19px;
	font-size: 1rem;
	text-align: center;
}
#main .comBgBox {
	margin-bottom: 151px;
	padding: 145px 0 130px;
}
#main .service {
	margin-bottom: -200px;
	position: relative;
	padding-bottom: 123px;
	border-radius: 0 0 0 200px;
	background-color: #fff;
	z-index: 3;
}
#main .service h2 {
	margin-bottom: 75px;
}
#main .service .comPhotoList {
	margin: -20px -15px 87px;
}
#main .service .comPhotoList .pho {
	margin-bottom: 12px;
}
#main .service .comPhotoList li {
	margin: 20px 11px 0;
}
#main .service .comPhotoList p {
	color: #3B4043;
	display: flex;
	justify-content: center;
	align-items: center;
}
#main .service h3 {
	margin-bottom: 45px;
	font-size: 2rem;
	text-align: center;
}
#main .service .linkList {
	margin: -37px auto 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .service .linkList::after {
	width: calc((100% - 74px) / 3);
	content: '';
}
#main .service .linkList li {
	margin-top: 37px;
	width: calc((100% - 74px) / 3);
}
#main .service .linkList a {
	display: block;
	position: relative;
}
#main .service .linkList a span {
	display: block;
	width: 100%;
	position: absolute;
	left: 0;
	top: 50%;
	color: #fff;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.6;
	text-align: center;
	transform: translateY(-50%);
}
#main .btmBox {
	margin-bottom: -96px;
	padding-top: 304px;
	background-color: #FAFAFB;
}
#main .btmBox .comImgBox {
	margin-bottom: 0;
	position: relative;
	z-index: 2;
}
#main .btmBox .comImgBox .photoBox {
	width: 50%;
}
#main .btmBox .comImgBox .textBox {
	width: 40.85%;
}
#main .btmBox .comImgBox .textBox h2 {
	margin-bottom: 7px;
	padding: 0;
	font-size: 2.4rem;
	border: none;
}
#main .btmBox .comImgBox .textBox p {
	margin: 0 0 40px;
	font-size: 1.6rem;
	line-height: 2;
}
#main .btmBox .comImgBox .textBox .comLink a span {
	padding-bottom: 0;
}
.comContactBox::before {
	background-color: #FAFAFB;
}
@media all and (min-width: 897px) {
	#main .service .linkList a:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#main .comLinkList {
		margin-bottom: 67px;
	}
	#main .topBox {
		margin-bottom: 109px;
	}
	#main .topBox .imgBox01 {
		margin-bottom: 82px;
	}
	#main .topBox .imgBox01 .photoBox {
		margin: 0 -16px 0 20px;
		width: auto;
		overflow-x: auto;
	}
	#main .topBox .imgBox01 .photoBox img {
		max-width: inherit;
		width: calc(100% + 23px);
	}
	#main .topBox .imgBox01 .textBox {
		margin-bottom: 72px;
	}
	#main .topBox .imgBox01 .textBox h2 {
		margin-bottom: 15px;
		padding-bottom: 11px;
	}
	#main .topBox .imgBox02 {
		align-items: flex-start;
	}
	#main .topBox .imgBox02 .textBox {
		margin: 0 0 91px 8px;
	}
	#main .topBox .imgBox02 .textBox h2 {
		margin-bottom: 14px;
		padding-bottom: 11px;
	}
	#main .topBox .imgBox02 .photoBox {
		margin: 0 15px 0 8px;
	}
	#main .topBox .imgBox02 .photoBox img {
		width: 100%;
		max-width: inherit;
	}
	#main .topBox .imgBox02 .photoBox p {
		display: none;
	}
	#main .comBgBox {
		margin-bottom: 63px;
		padding: 70px 8px 69px;
	}
	#main .service {
		margin-bottom: 0;
		padding-bottom: 56px;
		border-radius: 0;
	}
	#main .service h2 {
		margin-bottom: 37px;
	}
	#main .service .comPhotoList {
		margin: -27px 13px 56px;
	}
	#main .service .comPhotoList .pho {
		margin-bottom: 8px;
	}
	#main .service .comPhotoList li {
		margin: 27px 0 0;
	}
	#main .service .comPhotoList p {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#main .service .comPhotoList li:last-of-type p {
		margin: 0 -8px;
	}
	#main .service h3 {
		margin-bottom: 24px;
		line-height: 1.8;
	}
	#main .service .linkList {
		margin: 0;
		display: block;
	}
	#main .service .linkList::after {
		display: none;
	}
	#main .service .linkList li {
		margin: 0 0 20px;
		width: auto;
	}
	#main .service .linkList li:last-of-type {
		margin-bottom: 0;
	}
	#main .service .linkList a {
		display: block;
		position: relative;
	}
	#main .service .linkList a img {
		width: 100%;
	}
	#main .service .linkList a span {
		display: block;
		width: 100%;
		position: absolute;
		left: 0;
		top: 50%;
		color: #fff;
		font-size: 2rem;
		font-weight: 700;
		line-height: 1.6;
		text-align: center;
		transform: translateY(-50%);
	}
	#main .btmBox {
		margin-bottom: -11px;
		padding-top: 64px;
	}
	#main .btmBox .comImgBox {
		margin-bottom: 0;
		position: relative;
		z-index: 2;
	}
	#main .btmBox .comImgBox .photoBox {
		width: auto;
	}
	#main .btmBox .comImgBox .textBox {
		margin-top: 27px;
		width: auto;
	}
	#main .btmBox .comImgBox .textBox h2 {
		margin-bottom: 8px;
	}
	#main .btmBox .comImgBox .textBox p {
		margin: 0 0 26px;
		font-size: 1.4rem;
		line-height: 1.86;
		letter-spacing: 0;
	}
	#main .btmBox .comImgBox .textBox .comLink {
		text-align: right;
	}
	#main .btmBox .comImgBox .textBox .comLink a span {
		padding-bottom: 0;
	}
}