@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main {
	overflow: hidden;
}
#main .mainVisual {
	position: relative;
}
#main .mainVisual .title {
	position: absolute;
	left: 50%;
	top: 50%;
	margin: -3vw 0 0 -21.187vw;
	width: 42.4vw;
}
#main .mainVisual .movie video {
	display: block;
	width: 100%;
}
#main .news {
	padding: 5.7rem 0 4rem;
	background: #00954D;
}
#main .news .ttlBox {
	margin: 0 0 3rem 5rem;
	align-items: flex-start;
}
#main .news h2 {
	font-size: 4.1rem;
	line-height: 1;
	letter-spacing: 0.09em;
}
#main .news h2 .fadeTxt {
	--start-color: #fff;
	--end-color: #000;
}
#main .news .comBtn {
	margin: 1.5rem 0 0 1.7rem;
}
#main .news .slider {
	position: relative;
}
#main .news .slider .prev,
#main .news .slider .next {
	position: absolute;
	right: 5.5rem;
	top: -6.8rem;
	width: 4.9rem;
	transition: .5s;
	cursor: pointer;
}
#main .news .slider .prev img,
#main .news .slider .next img {
	transition: opacity .5s;
}
#main .news .slider .prev {
	right: 10.9rem;
}
#main .news .slider .prev .over,
#main .news .slider .next .over {
	position: absolute;
	left: 0;
	top: 0;
	opacity: 0;
}
#main .comNewsList li {
	width: calc((100% - 1.5rem)/4);
}
#main .comNewsList .photo {
	aspect-ratio: 1/1;
}
#main .comNewsList .photo img {
	border-radius: 50%;
}
#main .comNewsList .txtBox {
	margin: 1.5rem auto 0;
	width: fit-content;
}
#main .comNewsList .ttl {
	font-size: 1.6rem;
}
#main .comNewsList .comTag span {
	background: #00BF4D;
}
#main .comNewsList .date {
	margin: 0.2rem 0 0 1rem;
	font-size: 1.2rem;
	letter-spacing: 0;
}
#main .about {
	padding: 6rem 0 19.3rem;
	background: #F6F7E3;
	overflow: hidden;
}
#main .about .topBox {
	margin: 0 auto;
	max-width: 101.5rem;
}
#main .about .topBox .phoBox {
	margin: 0.7rem 4rem 0 0;
	width: 19rem;
}
#main .about .topBox .txtBox {
	flex: 1;
}
#main .about .topBox .txtBox h3 {
	margin-bottom: 2.2rem;
	font-size: 5.56rem;
	line-height: 1;
	font-weight: 400;
	letter-spacing: 0.38em;
}
#main .about .topBox .txtBox p {
	margin-right: 3.5rem;
	color: #363636;
	line-height: 2;
	letter-spacing: 0.02em;
	text-align: justify;
}
#main .about .inner {
	position: relative;
}
#main .about .inner .infoList {
	position: relative;
	z-index: 1;
}
#main .about .inner .infoList li {
	width: 46rem;
}
#main .about .inner .infoList a {
	display: block;
	padding: 5rem 4.5rem 4.6rem 5rem;
	background: rgba(255, 255, 255, 0.85);
	border-radius: 2.8rem;
}
#main .about .inner .infoList h4 {
	margin-bottom: 0.5rem;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	padding-right: 3.4rem;
	transition: .5s;
	display: inline-block;
	background: url(../img/common/arrow04.svg) no-repeat right center/2.5rem 0.7rem;
}
#main .about .inner .infoList p {
	line-height: 2.1;
	text-align: justify;
	letter-spacing: 0.05em;
}
#main .about .inner .infoList .liStyle {
	position: relative;
}
#main .about .inner .infoList .liStyle:after {
	position: absolute;
	left: -3rem;
	bottom: -2.2rem;
	width: 7.7rem;
	aspect-ratio: 1/1;
	background: url(../img/index/about_img10.png) no-repeat left top/100%;
	content: "";
}
#main .about .inner .picture {
	position: absolute;
	left: -37.4rem;
	top: 3.1rem;
	width: 70rem;
}
#main .about .inner .picture02 {
	left: auto !important;
	top: 3.4rem;
	right: -6.7rem;
	width: 56.6rem;
}
#main .about .inner .picture03 {
	left: auto !important;
	top: auto;
	bottom: -7.8rem;
  right: 17.4rem;
	width: 32.5rem;
}
#main .about .inner01 {
	padding: 13.6rem 21rem 14.4rem;
}
#main .about .inner01 .infoList {
	margin-left: 9.5rem;
}
#main .about .inner02 h3 {
	margin: 0 0 5rem 5rem;
}
#main .about .inner02 .infoList {
	align-items: flex-start;
}
#main .about .inner02 .infoList .item06:after {
	bottom: auto;
	top: -3.7rem;
	left: -0.6rem;
	width: 7.6rem;
	background-image: url(../img/index/about_img06.png);
}
#main .about .inner02 .picture {
	width: 54.1rem;
	left: -8rem;
	top: 20.9rem;
}
#main .about .inner02 .picture01 {
	z-index: 2;
}
#main .about .inner02 .picture02 {
	width: 89.7rem;
	top: 40rem;
	right: -23.9rem;
}
#main .about .inner03 {
	padding: 10.5rem 16.5rem;
	min-height: 75rem;
}
#main .about .inner03 h3 {
	margin: 0 0 7.3rem 14.5rem;
}
#main .about .inner03 h3:after {
	left: calc(50% - 3rem);
	transform: rotate(45deg);
}
#main .about .inner03 .infoList li {
	width: 44.5rem;
}
#main .about .inner03 .infoList .liStyle:after {
	width: 7.1rem;
	left: auto;
	right: -2.7rem;
	bottom: auto;
	top: -3.3rem;
	aspect-ratio: 142/161;
	background-image: url(../img/index/about_img07.png);
}
#main .about .inner03 .infoList h4 {
	letter-spacing: 0.03em;
	padding-right: 2.8rem;
}
#main .about .inner03 .picture {
	width: 97rem;
	top: 23.5rem;
	left: -28.4rem;
}
#main .about .inner03 .picture02 {
	width: 52rem;
	top: 14rem;
	right: 3.2rem;
}
#main .arrow {
	margin: 1.7rem auto 0;
	width: 5.7rem;
	position: relative;
	line-height: 0;
}
#main .arrow img {
	height: 0.7rem;
	transition: opacity .5s;
}
#main .arrow .over {
	opacity: 0;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
}
#main .linkList {
	gap: 1.2rem;
}
#main .linkList li {
	width: calc((100% - 2.4rem)/3);
}
#main .linkList a {
	display: block;
	line-height: 0;
}
#main .linkList h3 {
	transition: .5s;
	line-height: 1.5;
}
#main .linkList h3 .large {
	margin-bottom: 1.2rem;
	font-size: 3rem;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	letter-spacing: 0;
}
#main .linkList .photo {
	border-radius: 3rem;
	overflow: hidden;
	position: relative;
}
#main .linkList .photo img {
	width: 100%;
	transition: .5s;
}
#main .linkList .photo p {
	position: absolute;
	padding: 1.4rem 2rem 1.5rem;
	left: 50%;
	min-width: 26.7rem;
	transform: translateX(-50%);
	bottom: 3.3rem;
	color: #fff;
	white-space: nowrap;
	font-size: 2.9rem;
	line-height: 1.1;
	letter-spacing: 0.15em;
	text-align: center;
	border-radius: 1.6rem;
	background-color: rgba(2, 132, 48, 0.8);
	z-index: 1;
}
#main .linkList .photo p.on {
	transform: translate(-50%,0);
}
#main .linkList .photo p:before {
	position: absolute;
	left: 50%;
	top: -1rem;
	margin-left: -0.8rem;
	width: 1.5rem;
	height: 1rem;
	background-color: rgba(2, 132, 48, 0.8);
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	content: "";
}
#main .linkList .arrow {
	margin: 1.3rem 0 0 auto;
}
#main .solution {
	padding: 7.5rem 0 8.5rem;
}
#main .solution h2 {
	margin-bottom: 7.5rem;
}
#main .solution .inner {
	margin-bottom: 7rem;
}
#main .solution .inner:last-child {
	margin-bottom: 0 !important;
}
#main .solution .photo a {
	display: block;
	overflow: hidden;
}
#main .solution .photo img {
	width: 100%;
	transition: .5s;
}
#main .solution .case {
	margin-bottom: 7.2rem;
}
#main .solution .case a {
	display: block;
	margin: 0 auto;
	width: fit-content;
}
#main .solution .case h3 {
	margin-bottom: 1.5rem;
	transition: .5s;
}
#main .solution .case .photo {
	margin: 0 auto;
	max-width: 88.8rem;
	border-radius: 20rem;
	overflow: hidden;
}
#main .company {
	margin-bottom: 8rem;
}
#main .company h2 {
	margin-bottom: 2.8rem;
}
#main .company h2 .sml {
	margin-top: 2.8rem;
}
#main .company .bgBox {
	padding: 11.5rem 0 9.2rem;
	background: #00A23E;
}
#main .recruit {
	padding: 4.2rem 0 11.8rem;
}
#main .recruit h2 {
	margin-bottom: 3.2rem;
}
#main .recruit .photo a {
	display: block;
	position: relative;
	overflow: hidden;
}
#main .recruit .photo .title {
	position: absolute;
	left: 50%;
	top: 50%;
	margin: -4.4vw 0 0 -24.5vw;
	color: #fff;
	font-size: 5.275vw;
	line-height: 1;
	white-space: nowrap;
	letter-spacing: 0.07em;
	-webkit-text-stroke: 0.1rem #000;
	text-shadow: 0.2rem 0.2rem 0 #000;
	transition: .5s;
	z-index: 1;
}
#main .recruit .photo img {
	width: 100%;
	transition: .5s;
}
#main {
	margin-bottom: 0;
}
#main .infiniteslide_wrap {
	overflow: visible !important;
}
@media all and (hover: hover) and (min-width: 897px) {
	#main .news h2 a:hover {
		color: #fff;
	}
	#main .about .inner .infoList a:hover h4 {
		color: #00A23E;
		background-image: url(../img/common/arrow04_over.svg);
	}
	#main .news .slider .prev:hover .out,
	#main .news .slider .next:hover .out {
		opacity: 0;
	}
	#main .news .slider .prev:hover .over,
	#main .news .slider .next:hover .over {
		opacity: 1;
	}
	#main a:hover .headLine03,#main .solution .headLine03 a:hover {
		color: #00A23E;
	}
	#main .solution .photo a:hover img,
	#main .case a:hover .photo img,
	#main .linkList a:hover .photo img,
	#main .recruit .photo a:hover img {
		transform: scale(1.04);
	}
	#main a:hover .arrow .out {
		opacity: 0;
	}
	#main a:hover .arrow .over {
		opacity: 1;
	}
	#main .company a:hover .headLine03 {
		color: #fff !important;
	}
	#main .recruit .photo a:hover .title {
		color: #00A23E;
	}
}
@media all and (max-width: 1200px) {
	#main .mainVisual .title {
		margin: -5.4rem 0 0 -20.5rem;
		width: 50.9rem;
	}
	#main .recruit .photo .title {
		margin: -5rem 0 0 -27rem;
		font-size: 6.35rem;
	}
}
@media all and (min-width: 897px) {
	#main .comNewsList .slick-slide {
		margin-right: 0.5rem;
		width: 28.2rem;
	}
	#main .about .inner02 .infoList .item01 {
		margin: 0 2.3rem 0 15.7rem;
		width: 50.6rem;
	}
	#main .about .inner02 .infoList .item02 {
		width: 45rem;
		margin: -14.7rem 6.5rem 2.5rem auto;
	}
	#main .about .inner02 .infoList .item03 {
		margin: 0 0 2.3rem 43.7rem;
		width: 45rem;
	}
	#main .about .inner02 .infoList .item04 {
		width: 54.7rem;
		margin: 0 3.5rem -0.5rem auto;
	}
	#main .about .inner02 .infoList .item04 a {
		min-height: 18.5rem;
	}
	#main .about .inner02 .infoList .item05 {
		width: 50.2rem;
	}
	#main .about .inner02 .infoList .item05 p {
		letter-spacing: 0;
	}
	#main .about .inner02 .infoList .item06 {
		margin: -15rem 17.3rem 0 auto;
		width: 46.2rem;
	}
	#main .about .inner02 .infoList .item06 p {
		letter-spacing: 0;
	}
}
@media all and (min-width: 897px) and (max-width: 1280px) {
	#main .about .inner02 .infoList .item02 {
		margin-right: 2rem;
	}
}
@media all and (max-width: 896px) {
	#main .mainVisual .title {
		margin: -9.2vw 0 0 -43.9vw;
		width: 88vw;
	}
	#main .news {
		padding: 5.7rem 0 7rem;
	}
	#main .news .ttlBox {
		margin: 0 0 2.7rem 0.8rem;
	}
	#main .news h2 {
		width: 100%;
		font-size: 4.3rem;
	}
	#main .news .comBtn {
		margin: 0.7rem 0 0;
	}
	#main .news .slider .prev,
	#main .news .slider .next {
		right: 1.1rem;
		top: -6.9rem;
		width: 4.3rem;
	}
	#main .news .slider .prev {
		right: 5.8rem;
	}
	#main .comNewsList {
		gap: 1.5rem 2.6rem;
	}
	#main .comNewsList li {
		width: calc((100% - 2.6rem)/2);
	}
	#main .comNewsList .ttl {
		margin-bottom: 1rem;
		height: auto !important;
		font-size: 1.7rem;
		line-height: 1.47;
		letter-spacing: 0.04em;
	}
	#main .comNewsList .tagBox {
		display: block;
	}
	#main .comNewsList .comTag span {
		font-size: 1.5rem;
		min-width: 13rem;
	}
	#main .comNewsList .date {
		margin: 0.4rem 0 0;
		font-size: 1.5rem;
	}
	#main .about {
		padding: 5.5rem 0 13.5rem;
	}
	#main .about .topBox {
		display: block;
	}
	#main .about .topBox .phoBox {
		margin: 0 auto 1.8rem;
		width: 21.9rem;
	}
	#main .about .topBox .txtBox {
		flex: 1;
		text-align: center;
	}
	#main .about .topBox .txtBox h3 {
		margin: 0 -1.5rem 2.6rem -0.7rem;
		font-size: 5.4rem;
		line-height: 1.1;
		text-align: center;
		letter-spacing: 0.16em;
	}
	#main .about .topBox .txtBox p {
		margin-right: 0;
		line-height: 1.88;
	}
	#main .about .inner .infoList li {
		width: auto !important;
	}
	#main .about .inner .infoList a {
		padding: 3.5rem 2.8rem 3.3rem;
		border-radius: 1.4rem;
	}
	#main .about .inner .infoList li:not(:last-child) {
		margin-bottom: 3.5rem;
	}
	#main .about .inner .infoList h4 {
		margin-bottom: 1rem;
		font-size: 2rem;
		line-height: 1.25;
		padding-right: 0;
		background: none;
	}
	#main .about .inner .infoList h4:after {
		margin-left: 1.2rem;
		display: inline-block;
		content: "";
		width: 3.2rem;
		height: 0.9rem;
		vertical-align: 0.6rem;
		background: url(../img/common/arrow04.svg) no-repeat left top/100% 100%;
	}
	#main .about .inner .infoList p {
		line-height: 1.56;
		letter-spacing: 0.07em;
	}
	#main .about .inner .infoList .liStyle:after {
		left: 3rem;
		bottom: -4.2rem;
		width: 6rem;
	}
	#main .about .inner .picture {
		left: -2.5rem;
		top: 4.5rem;
		width: 37.1rem;
	}
	#main .about .inner .picture02 {
		top: auto;
		bottom: 8.7rem;
		right: -2.2rem;
		width: 24.9rem;
	}
	#main .about .inner .picture03 {
		width: 20.3rem;
		top: auto;
		bottom: 0;
		right: auto;
		left: -0.9rem !important;
	}
	#main .about .inner01 {
		padding: 13.8rem 0 25.3rem;
	}
	#main .about .inner01 .infoList {
		margin-left: 0;
	}
	#main .about .inner01 .picture02 {
		z-index: 1;
	}
	#main .about .inner02 {
		padding: 2.5rem 0 20.7rem;
	}
	#main .about .inner02 h3 {
		margin: 0 0 4.2rem;
		letter-spacing: 0.28em;
	}
	#main .about .inner02 h3:before {
		left: 6rem;
	}
	#main .about .inner02 h3:after {
		left: calc(50% - 2.9rem);
		transform: rotate(-45deg);
	}
	#main .about .inner02 .infoList .item06:after {
		bottom: auto;
		top: -3.7rem;
		left: -0.6rem;
		width: 7.6rem;
		background-image: url(../img/index/about_img06.png);
	}
	#main .about .inner02 .infoList .item03 {
		margin-left: 13rem;
		position: relative;
	}
	#main .about .inner02 .infoList .item03 .picture {
		width: 15.7rem;
		top: -5.2rem;
		left: -13.7rem;
	}
	#main .about .inner02 .infoList .item04 {
		margin-right: 13rem;
		position: relative;
	}
	#main .about .inner02 .infoList .item04 .picture {
		width: 16.1rem;
		top: 1rem;
		left: auto;
		right: -13.8rem;
	}
	#main .about .inner02 .infoList .item04 h4 {
		margin-right: -0.5rem;
	}
	#main .about .inner02 .infoList .item04 p {
		letter-spacing: 0;
	}
	#main .about .inner02 .infoList .item06 h4 {
		letter-spacing: 0.03em;
	}
	#main .about .inner02 .infoList .item06:after {
		width: 5rem;
		left: 2rem;
		top: -2.5rem;
	}
	#main .about .inner02 .picture02 {
		width: 39.1rem;
		top: auto;
		bottom: 0;
		right: -2.5rem;
	}
	#main .about .inner03 {
		padding: 2.3rem 0 23.5rem;
		min-height: inherit;
	}
	#main .about .inner03 h3 {
		margin: 0 0 4rem;
		padding: 1.1rem 0.5rem;
		letter-spacing: 0.25em;
	}
	#main .about .inner03 h3:before {
		left: 6rem;
	}
	#main .about .inner03 h3:after {
		left: calc(50% - 2.4rem);
		transform: rotate(-45deg);
	}
	#main .about .inner03 .infoList .liStyle:after {
		width: 6.9rem;
		left: auto;
		right: 3rem;
		top: -3.9rem;
	}
	#main .about .inner03 .infoList h4 {
		letter-spacing: 0.03em;
	}
	#main .about .inner03 .infoList h4 a {
		padding-right: 2.8rem;
	}
	#main .about .inner03 .picture {
		width: 33.6rem;
		top: auto;
		bottom: 0;
		left: -15.1rem;
	}
	#main .about .inner03 .picture02 {
		width: 24rem;
		top: auto;
		bottom: 4.3rem;
		right: 0;
		z-index: 1;
	}
	#main .arrow {
		margin-top: 1.4rem;
		width: 5.6rem;
		text-align: center;
	}
	#main .arrow img {
		height: 0.6rem;
	}
	#main .linkList {
		margin: 0 1.4rem;
		gap: 3.7rem 0;
	}
	#main .linkList li {
		width: 100%;
	}
	#main .linkList h3 {
		margin-bottom: 0.8rem;
	}
	#main .linkList h3 .large {
		margin-bottom: 0.6rem;
		font-size: 3.2rem;
		letter-spacing: 0.03em;
	}
	#main .linkList .photo {
		border-radius: 1.5rem;
	}
	#main .linkList .photo p {
		padding: 1.1rem 1.7rem 1.2rem;
		min-width: 22.6rem;
		bottom: 2rem;
		font-size: 2.5rem;
		letter-spacing: 0.15em;
		border-radius: 1.6rem;
	}
	#main .linkList .photo p:before {
		margin-left: -0.7rem;
		width: 1.4rem;
	}
	#main .linkList .arrow {
		margin-top: 1rem;
		text-align: right;
	}
	#main .solution {
		padding: 1.3rem 0 4rem;
	}
	#main .solution h2 {
		margin-bottom: 5.6rem;
	}
	#main .solution .inner {
		margin-bottom: 6.2rem;
	}
	#main .solution .inner01 h3 .large {
		margin-bottom: 0.6rem;
	}
	#main .solution .case {
		margin-bottom: 4rem;
	}
	#main .solution .case h3 {
		margin-bottom: 1rem;
	}
	#main .solution .case .photo {
		margin: 0 -1.3rem;
		max-width: inherit;
	}
	#main .company h2 {
		margin-bottom: 2.3rem;
	}
	#main .company h2 .sml {
		margin-top: 1.5rem;
	}
	#main .company .bgBox {
		padding: 7.5rem 0 7rem;
	}
	#main .company .linkList {
		gap: 3rem 0;
	}
	#main .company .linkList h3 {
		margin-bottom: 1.4rem;
	}
	#main .company .linkList h3 .large {
		margin-bottom: 0.3rem;
		line-height: 1.12;
	}
	#main .company .linkList .arrow {
		margin-top: 1.2rem;
	}
	#main .recruit {
		padding: 5.5rem 0 5.3rem;
	}
	#main .recruit h2 {
		margin-bottom: 1.3rem;
	}
	#main .recruit .photo .title {
		margin: -6.7vw 0 0 -45vw;
		font-size: 10vw;
		letter-spacing: 0.04em;
		text-shadow: 1px 1px 0 #000;
	}
}