@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
	margin: 0 2.2rem;
	position: relative;
}
.mainVisual::after {
	position: absolute;
	z-index: 1;
	content: "";
	left: 50%;
	transform: translateX(-50%);
	bottom: -1px;
	width: 100rem;
	height: 10.1rem;
	background: url(../img/index/main_bg.png) no-repeat center bottom / 100% auto;
	pointer-events: none;
}
.mainVisual .photo {
	border-radius: 1.9rem;
	overflow: hidden;
}
.mainVisual .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mainVisual .innerBox {
	padding: 0 2rem;
	width: 100%;
	max-width: 172rem;
	position: absolute;
	z-index: 2;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.mainVisual .innerBox .title {
	margin-bottom: 0.7rem;
}
.mainVisual .innerBox .title span {
	padding: 0 1.4rem 0.4rem;
	font-weight: 600;
	font-size: 5.5rem;
	letter-spacing: 0.075em;
	line-height: 1.8;
	color: #5BAF84;
	background: -webkit-linear-gradient(#fff,#fff) repeat-x left bottom  / 100% 8.5rem;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	box-shadow: 0 0 1rem 0.5rem rgba(0, 0, 0, 0.2);
}
.mainVisual .innerBox .text {
	margin-bottom: 1rem;
}
.mainVisual .innerBox .text span {
	padding: 0.2rem 1rem 0.7rem;
	font-weight: 600;
	font-size: 2.2rem;
	letter-spacing: 0.075em;
	line-height: 2.2;
	background: -webkit-linear-gradient(#fff,#fff) repeat-x left bottom  / 100% 4.1rem;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	box-shadow: 0 0 1rem 0.5rem rgba(0, 0, 0, 0.2);
}
#main .news {
	position: relative;
	z-index: 1;
	margin-top: -7.2rem;
	padding: 1px 0 8rem;
}
#main .news .content {
	max-width: 123.7rem;
}
#main .about {
	position: relative;
	z-index: 3;
	padding: 13.8rem 0 10rem;
	background: url(../img/index/about_bg.png) no-repeat left top / cover;
}
#main .about::after {
	position: absolute;
	z-index: 1;
	top: 100%;
	left: 0;
	width: 100%;
	height: 20rem;
	background: url(../img/index/about_bg01.png) no-repeat left top / 100% auto;
	content: "";
	pointer-events: none;
}
#main .about .content {
	position: relative;
	max-width: 147.5rem;
}
#main .about .headLine01 {
	margin: 0 0 3.8rem -2rem;
	width: fit-content;
	min-width: 26.5rem;
}
#main .about .headLine01 img {
	margin-bottom: 1rem;
}
#main .about .imgBox {
	align-items: flex-start;
}
#main .about .imgBox .textBox {
	padding: 0 2rem 0 12rem;
	flex: 1;
}
#main .about .imgBox .textBox .title {
	margin-bottom: 4rem;
	font-size: 3rem;
	font-weight: 600;
	color: #5BAF84;
	letter-spacing: 0.075em;
	line-height: 1.7;
}
#main .about .imgBox .textBox .text {
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	line-height: 2.75;
}
#main .about .imgBox .photoBox {
	position: relative;
	margin-top: 4.2rem;
	width: 47.74%;
}
#main .about .imgBox .photoBox img {
	width: 100%;
}
#main .about .imgBox .photoBox::before {
	position: absolute;
	top: 4.3rem;
	left: -4.5rem;
	content: "";
	z-index: 1;
	width: 18.5rem;
	height: 7.4rem;
	background: url(../img/index/about_img01.png) no-repeat left top / 100%;
}
#main .about .imgBox .photoBox::after {
	position: absolute;
	bottom: -2.5rem;
	right: -8.3rem;
	content: "";
	z-index: 1;
	width: 20.6rem;
	height: 9.4rem;
	background: url(../img/index/about_img02.png) no-repeat left top / 100%;
}
#main .about .imgBox .photoBox img {
	border-radius: 3rem;
}
#main .about .comBtn {
	margin: -0.2rem 0 0 12rem;
}
#main .about .image01,
#main .about .image02,
#main .about .image03 {
	position: absolute;
	z-index: 3;
}
#main .about .image01 {
	width: 18.2rem;
	left: -10.5rem;
	bottom: -3rem;
}
#main .about .image02 {
	width: 9.1rem;
	right: -12.8rem;
	bottom: -10.2rem;
}
#main .about .image03 {
	width: 15.4rem;
	height: 8.4rem;
	right: 5.3rem;
	bottom: -20.5rem;
}
#main .areaBox {
	padding: 20.8rem 0 20rem;
	position: relative;
	z-index: 2;
	background-color: #D7F6E6;
}
#main .areaBox::after {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	z-index: 1;
	content: "";
	height: 20rem;
	background: url(../img/index/area_bg01.png) no-repeat left top / 100% auto;
	pointer-events: none;
}
#main .areaBox .bg01 {
	position: absolute;
	z-index: 3;
	right: 0;
	top: -5.8rem;
	width: 60.6rem;
	height: 47rem;
	pointer-events: none;
}
#main .areaBox .bg02 {
	position: absolute;
	z-index: 3;
	width: 91.2rem;
	height: 95rem;
	left: 0;
	bottom: -6.5rem;
	overflow: hidden;
	pointer-events: none;
}
#main .areaBox .content {
	position: relative;
	z-index: 4;
}
#main .areaBox .linkUl {
	position: relative;
	z-index: 4;
	gap: 3.5rem 1.5575%;
}
#main .areaBox .linkUl li {
	width: 32.295%;
}
#main .areaBox .linkUl a {
	padding: 8rem 0;
	position: relative;
	display: flex;
	align-items: center;
	min-height: 26.5rem;
	height: 100%;
	border-radius: 3rem;
	overflow: hidden;
}
#main .areaBox .linkUl a:hover {
	opacity: 0.7;
}
#main .areaBox .linkUl .photo {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}
#main .areaBox .linkUl .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}
#main .areaBox .linkUl .bg {
	display: block;
	
	background-color: #fff;
}
#main .areaBox .linkUl .titleBox {
	padding: 0 1rem;
	margin: 0 auto;
	width: fit-content;
	height: fit-content;
	position: relative;
	z-index: 2;
	text-align: center;
	font-size: 3.6rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	color: #5BAF84;
	background-color: #fff;
}
#main .areaBox .linkUl .li01 .titleBox .text {
	padding-left: 6.7rem;
	background: url(../img/index/area_img01.png) no-repeat left bottom 0.3rem/ 6.1rem;
}
#main .areaBox .linkUl .li02 .titleBox .text {
	padding-left: 5rem;
	background: url(../img/index/area_img02.png) no-repeat left bottom 0.5rem/ 4.6rem;
}
#main .areaBox .linkUl .li03 .titleBox .text {
	padding-left: 3.7rem;
	background: url(../img/index/area_img03.png) no-repeat left bottom 0.5rem/ 3.2rem;
}
#main .areaBox .linkUl .li04 .titleBox .text {
	padding: 0 1.3rem 0 6rem;
	background: url(../img/index/area_img04.png) no-repeat left bottom 0.5rem/ 5.5rem;
}
#main .areaBox .linkUl .li05 .titleBox .text {
	padding: 0 3.5rem 0 5rem;
	background: url(../img/index/area_img05.png) no-repeat left bottom 0.2rem/ 4.3rem;
}
#main .areaBox .linkUl .li06 .titleBox .text {
	padding: 0 3.5rem 0 7rem;
	background: url(../img/index/area_img06.png) no-repeat left bottom 0.5rem/ 6.6rem;
}
#main .areaBox .linkUl .titleBox .en {
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	font-weight: 500;
	color: #2A2A2A;
	display: block;
}
#main .areaBox .linkUl .titleBox img {
	position: absolute;
	bottom: 0.5rem;
	right: 100%;
	z-index: 1;
}
#main .areaBox .linkUl .else .titleBox {
	font-size: 3rem;
	letter-spacing: 0;
}
#main .contact {
	margin-top: -12.2rem;
	padding: 1px 2rem 0;
	position: relative;
	z-index: 4;
}
#main .contact .content {
	padding: 8rem 2rem 10.8rem;
	max-width: 168rem;
	position: relative;
	background: url(../img/index/contact_bg.png) no-repeat left top / 100% 100%;
	border-radius: 0 0 2.6rem 2.6rem;
}
#main .contact .image01,
#main .contact .image02 {
	position: absolute;
	top: 0;
	z-index: 2;
}
#main .contact .image01 {
	width: 22.7rem;
	left: calc(50% - 48rem);
}
#main .contact .image02 {
	top: 9rem;
	width: 25.1rem;
	left: calc(50% + 25rem);
}
#main .contact .headLine01 {
	margin-bottom: 6.5rem;
	color: #fff;
	background-image: url(../img/common/h_line02.png);
	text-shadow: 0 0 1rem rgba(0, 0, 0, 0.3);
}
#main .contact .headLine01 .jp {
	color: #fff;
}
#main .contact .innerBox {
	margin: 0 auto;
	max-width: 88rem;
	flex-direction: row-reverse;
}
#main .contact .innerBox .sub {
	margin-left: 2rem;
	flex: 1;
}
#main .contact .innerBox .comBtn a {
	background-color: #ED798D;
}
#main .contact .innerBox .text {
	width: 44rem;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	line-height: 1.8;
	text-shadow: 0 0 1rem rgba(0, 0, 0, 0.5);
}
@media all and (min-width: 897px) and (max-width: 1600px) {
	.mainVisual::after {
		width: 85rem;
	}
	.mainVisual .innerBox .title span {
		font-size: 4rem;
	}
	.mainVisual .innerBox .text span {
		font-size: 2rem;
	}
	#main .about .imgBox .textBox .title {
		font-size: 2.7rem;
	}
	#main .about .imgBox .textBox .text {
		letter-spacing: 0.05em;
	}
}
@media all and (min-width: 897px) and (max-width: 1700px) {
	#main .about .image01 {
		left: 0;
		width: 13rem;
	}
	#main .about .image02 {
		right: -3vw;
		width: 8rem;
	}
}
@media all and (min-width: 897px) and (max-width: 1570px) {
	#main .about .image02 {
		right: 0;
		width: 6.5rem;
	}
}
@media all and (max-width: 896px) {
	.mainVisual {
		margin: 0 1rem;
	}
	.mainVisual::after {
		width: 70%;
	}
	.mainVisual .innerBox {
		padding: 0 1rem;
		max-width: 100%;
	}
	.mainVisual .photo {
		height: 25rem;
		display: block;
		border-radius: 1rem;
	}
	.mainVisual .innerBox .title span {
		padding: 0 0.5rem 0.2rem;
		font-size: 1.8rem;
	}
	.mainVisual .innerBox .text span {
		padding: 0.2rem 0.5rem 0.3rem;
		font-size: 1.2rem;
		background-size: 100% 3rem;
	}
	#main .news {
		margin-top: 0;
		padding: 1rem 0 5rem;
	}
	#main .about {
		padding: 5rem 0;
	}
	#main .about::after {
		height: 20rem;
	}
	#main .about .headLine01 {
		margin: 0 auto 3rem;
		min-width: fit-content;
	}
	#main .about .imgBox {
		margin-bottom: 5rem;
		display: block;
	}
	#main .about .imgBox .textBox {
		margin-bottom: 3rem;
		padding: 0;
	}
	#main .about .imgBox .textBox .title {
		margin-bottom: 2rem;
		font-size: 1.8rem;
	}
	#main .about .imgBox .textBox .text {
		font-size: 1.4rem;
		line-height: 2;
	}
	#main .about .imgBox .photoBox {
		margin-top: 0;
		width: auto;
	}
	#main .about .imgBox .photoBox::before {
		top: 2rem;
		left: -1rem;
		width: 10rem;
	}
	#main .about .imgBox .photoBox::after {
		bottom: -5rem;
		right: -2rem;
		width: 11rem;
	}
	#main .about .imgBox .photoBox img {
		border-radius: 1rem;
	}
	#main .about .comBtn {
		margin: 0 auto;
	}
	#main .about .image01 {
		width: 8rem;
		left: 0;
		bottom: 0;
	}
	#main .about .image02 {
		width: 5rem;
		right: 0;
		bottom: -7rem;
	}
	#main .about .image03 {
		width: 8rem;
		right: 5.3rem;
		bottom: -12rem;
	}
	#main .areaBox {
		padding: 8rem 0 15rem;
	}
	#main .areaBox .bg01 {
		top: -2rem;
		width: 20rem;
		height: fit-content;
	}
	#main .areaBox .bg02 {
		width: 25rem;
		height: fit-content;
		bottom: 0;
	}
	#main .areaBox .linkUl {
		display: block;
	}
	#main .areaBox .linkUl li {
		margin-bottom: 3rem;
		width: auto;
	}
	#main .areaBox .linkUl a {
		height: 50vw;
		min-height: fit-content;
		max-height: 40rem;
		border-radius: 1.5rem;
	}
	#main .areaBox .linkUl .titleBox {
		font-size: 2.2rem !important;
	}
	#main .areaBox .linkUl .li01 .titleBox .text {
		padding: 0 2rem 0 5rem;
		background-size: 4rem auto;
	}
	#main .areaBox .linkUl .li02 .titleBox .text {
		padding: 0 1rem 0 5rem;
		background-size: 4rem auto;
	}
	#main .areaBox .linkUl .li03 .titleBox .text {
		padding: 0 1rem 0 4rem;
		background-size: 2.8rem auto;
	}
	#main .areaBox .linkUl .li04 .titleBox .text {
		padding: 0 2rem 0 4rem;
		background-size: 3.5rem auto;
	}
	#main .areaBox .linkUl .li05 .titleBox .text {
		padding: 0 1.5rem 0 4rem;
		background-size: 3.5rem auto;
	}
	#main .areaBox .linkUl .li06 .titleBox .text {
		padding: 0 1rem 0 5.5rem;
		background-size: 5rem auto;
	}
	#main .areaBox .linkUl .titleBox .en {
		font-size: 1.4rem;
	}
	#main .areaBox .linkUl .titleBox img {
		max-height: 3.5rem;
	}
	#main .contact {
		margin-top: -11rem;
	}
	#main .contact .content {
		padding: 5rem 2rem 4rem;
		border-radius: 0 0 0.5rem 0.5rem;
	}
	#main .contact .image01 {
		width: 11rem;
		left: 1rem;
	}
	#main .contact .image02 {
		top: 4rem;
		width: 10rem;
		left: auto;
		right: 1rem;
	}
	#main .contact .headLine01 {
		margin-bottom: 3rem;
	}
	#main .contact .innerBox {
		max-width: 100%;
		display: block;
	}
	#main .contact .innerBox .sub {
		margin-left: 0;
	}
	#main .contact .innerBox .text {
		margin-bottom: 2rem;
		width: auto;
		font-size: 1.4rem;
	}
}