@charset "utf-8";
/*------------------------------------------------------------
	business
------------------------------------------------------------*/
#main .service {
	padding: 7.5rem 0 16.3rem;
}
#main .topBox .textBox {
	width: 61rem;
	color: #231815;
}
#main .topBox .ttl {
	margin-bottom: 2.8rem;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.66;
}
#main .topBox p {
	text-align: justify;
	line-height: 2.35;
}
#main .topBox .img {
	width: 43.7rem;
	margin: -7.1rem 0.2rem 0 0;
}
#main .topBox .img img {
	width: 100%;
}
#main .service .listUl {
	margin: 13rem -12rem 0;
}
#main .service .listUl li {
	margin-bottom: 11.2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
#main .service .listUl li:last-child {
	margin-bottom: 0 !important;
}
#main .service .listUl .pho {
	width: 66.3rem;
	position: relative;
}
#main .service .listUl .pho:before {
	position: absolute;
	left: 0;
	bottom: -0.6rem;
	height: 0.6rem;
	width: 38.3rem;
	background-color: #29DE3C;
	content: "";
}
#main .service .listUl .textBox {
	width: 61rem;
	margin: -1.2rem 0 0 5rem;
	color: #231815;
}
#main .service .listUl .title {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
#main .service .listUl .txt01 {
	width: 14.1rem;
	height: 8.9rem;
	font-size: 2.6rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	overflow: hidden;
	border-radius: 5rem;
}
#main .service .listUl .txt01 .bg_line {
	width: 100%;
	height: 100%;
	display: flex !important;
	align-items: center;
	justify-content: center;
	text-align: center;
	--bgcolor: linear-gradient(90deg, rgba(60, 244, 78, 1) 0.02%, rgba(42, 203, 57, 1) 100%);
}
#main .service .listUl .txt02 {
	width: calc(100% - 17.5rem);
	margin-top: 1rem;
	line-height: 1.66;
	font-weight: 700;
	font-size: 2.4rem;
}
#main .service .listUl p {
	margin: 2.6rem 0 0 6.9rem;
	padding: 0 0 0.7rem 4rem;
	text-align: justify;
	line-height: 2.35;
	border-left: 0.2rem solid #29DE3C;
}
#main .project {
	padding: 9.3rem 0 27.2rem;
	color: #231815;
	background-color: #F7F7F7;
}
#main .project .topBox {
	margin-bottom: 3.6rem;
}
#main .project .info {
	margin: 0 -1rem 6.3rem;
}
#main .project .info:last-child {
	margin-bottom: 0 !important;
}
#main .project .info .ttl {
	width: fit-content;
	padding: 0 3.3rem 0.6rem 3.5rem;
	font-size: 3.2rem;
	font-weight: 700;
	border-bottom: 0.6rem solid #29DE3C;
}
#main .project .info .ttl .sml {
	margin: -0.4rem 0 0 0.3rem;
	display: inline-block;
	vertical-align: middle;
	font-weight: 400;
	font-size: 1.7rem;
}
#main .project .whiteBg {
	background-color: #fff;
}
#main .project .whiteBg .textBox {
	position: relative;
	padding: 8.4rem 8.6rem 6.2rem;
}
#main .project .whiteBg .title {
	margin-bottom: 3.1rem;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.66;
}
#main .project .whiteBg .txt {
	position: absolute;
	right: -3.4rem;
	top: 7rem;
	width: 34.5rem;
	height: 12rem;
	font-size: 1.8rem;
}
#main .project .whiteBg .txt .bg_line {
	width: 100%;
	height: 100%;
	padding: 1.9rem 2rem 2rem 6.2rem;
	display: block;
	--bgcolor: url(../img/business/bg_line_bg.webp) no-repeat;
	background-size: 100% 100%;
}
#main .project .whiteBg .txt .bg_line::after {
	background-size: 100% 100%;
}
#main .project .whiteBg .txt01 .bg_line {
	padding-left: 4.2rem;
}
#main .project .whiteBg .txt02 .bg_line {
	padding-left: 2.2rem;
}
#main .project .whiteBg .text {
	line-height: 2.35;
	text-align: justify;
}
#main .project .whiteBg .phoList li {
	width: calc(100% / 3);
	position: relative;
}
#main .project .whiteBg .phoList img {
	width: 100%;
	height: 100%;
}
#main .project .whiteBg .phoList .comLink {
	position: absolute;
	right: 1.9rem;
	top: -2.7rem;
	z-index: 1;
}
#main .project .whiteBg .phoList .comLink01 {
	right: 50%;
	transform: translateX(50%);
}
@media all and (min-width: 897px) {
	#main .service .listUl li:nth-child(2n) .pho {
		order: -1;
	}
	#main .service .listUl li:nth-child(2n) .textBox {
		margin: -1.2rem 5rem 0 0;
	}
	#main .service .listUl li:nth-child(2n) .txt01 {
		order: 1;
	}
	#main .service .listUl li:nth-child(2n) p {
		margin: 2.6rem 6.9rem 0 0;
		padding: 0 4rem 0.7rem 0;
		border-right: 0.2rem solid #29DE3C;
		border-left: none;
	}
	#main .service .listUl .title01 .txt01 {
		width: 20rem;
	}
	#main .service .listUl .title01 .txt02 {
		width: calc(100% - 21rem);
	}
	#main .project .topBox .textBox {
		width: 64rem;
	}
	#main .project .topBox .ttl {
		margin-bottom: 2.2rem;
	}
	#main .project .topBox .img {
		width: 43.7rem;
		margin-top: -9.7rem;
	}
}
@media all and (max-width: 896px) {
	#main .service {
		padding: 4.8rem 0 9rem;
	}
	#main .topBox {
		display: block;
	}
	#main .topBox .textBox {
		width: auto;
	}
	#main .topBox .ttl {
		margin-bottom: 1.4rem;
		font-size: 2.2rem;
		line-height: 1.63;
	}
	#main .topBox p {
		line-height: 2.06;
		letter-spacing: -0.02em;
	}
	#main .topBox .img {
		width: auto;
		margin: 3.7rem -1.4rem 0;
	}
	#main .service .listUl {
		margin: 5.8rem -2.5rem 0;
	}
	#main .service .listUl li {
		margin-bottom: 6.6rem;
		display: block;
	}
	#main .service .listUl .pho {
		width: auto;
	}
	#main .service .listUl .pho:before {
		width: 20.8rem;
	}
	#main .service .listUl .textBox {
		width: auto;
		margin: 0 0 2.9rem;
	}
	#main .service .listUl .txt01 {
		width: 11.7rem;
		height: 8.4rem;
		font-size: 2.3rem;
		border-radius: 0 5rem 5rem 0;
	}
	#main .service .listUl .txt01 .bg_line {
		padding-right: 0.6rem;
		line-height: 1.1;
	}
	#main .service .listUl .txt02 {
		width: calc(100% - 13.2rem);
		margin-top: 0.2rem;
		line-height: 1.57;
		font-size: 2.1rem;
	}
	#main .service .listUl p {
		margin: 2rem 0 0 2.3rem;
		padding: 0 2.5rem 0.4rem 2.4rem;
		line-height: 2.06;
	}
	#main .project {
		padding: 5.8rem 0 10rem;
	}
	#main .project .topBox {
		margin-bottom: 4.4rem;
	}
	#main .project .info {
		margin: 0 0 3.9rem -2.5rem;
	}
	#main .project .info .ttl {
		padding: 0 0.2rem 0.2rem 2.4rem;
		font-size: 2.8rem;
	}
	#main .project .info .ttl .sml {
		margin: -0.6rem -0.7rem 0.7rem;
		display: block;
		font-size: 1.6rem;
	}
	#main .project .whiteBg .textBox {
		padding: 3.7rem 2.4rem 5rem;
	}
	#main .project .whiteBg .title {
		margin-bottom: 2.2rem;
		font-size: 2.1rem;
		line-height: 1.57;
	}
	#main .project .whiteBg .txt {
		position: static;
		margin: 0 -5rem -0.7rem auto;
		width: 27.4rem;
		height: 11.5rem;
		font-size: 1.6rem;
		line-height: 1.58;
	}
	#main .project .whiteBg .txt .bg_line {
		padding: 1.9rem 2rem 2rem 3.8rem !important;
		--bgcolor: url(../img/business/bg_line_bg_sp.webp) no-repeat;
		background-size: 100% 100%;
	}
	#main .project .whiteBg .txt .bg_line::after {
		background-size: 100% 100%;
	}
	#main .project .whiteBg .txt01 {
		width: 31.4rem;
	}
	#main .project .whiteBg .txt01 .bg_line {
		--bgcolor: url(../img/business/bg_line_bg02_sp.webp) no-repeat;
		background-size: 100% 100%;
	}
	#main .project .whiteBg .txt01 .bg_line::after {
		background-size: 100% 100%;
	}
	#main .project .whiteBg .txt02 {
		width: 34rem;
	}
	#main .project .whiteBg .txt02 .bg_line {
		--bgcolor: url(../img/business/bg_line_bg03_sp.webp) no-repeat;
		background-size: 100% 100%;
	}
	#main .project .whiteBg .txt02 .bg_line::after {
		background-size: 100% 100%;
	}
	#main .project .whiteBg .text {
		line-height: 2.06;
	}
	#main .project .whiteBg .phoList {
		margin-right: -2.5rem;
	}
	#main .project .whiteBg .phoList .comLink {
		right: auto;
		left: 2.7rem;
		top: -2.5rem;
	}
	#main .project .whiteBg .phoList .comLink01 {
		display: none;
	}
}