@charset "utf-8";
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-JYJ */
/* clearfix */	
.clearfix:after {content: "";display: block;clear: both;}
/* flex */	
.flex,.flexA,.flexB,.flexC {display: flex;flex-wrap: wrap;}
.flexA {justify-content: space-around;}
.flexB {justify-content: space-between;}
.flexC {justify-content: center;}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
/* content */
.content {
	padding: 0 5.5rem
}
/* heading */
.heading{
	margin-bottom: 3rem;
	font-size: 4rem;
	text-align: center;
	line-height: 1.15;
	letter-spacing: 0.1rem;
	font-weight: 600;
}
/* comBtn */
.comBtn a {
	padding: 1rem 5rem 1rem 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 14rem;
	text-align: center;
	font-size: 3.6rem;
	line-height: 1.277;
	letter-spacing: 0.36px;
	color: #fff;
	border-radius: 7rem;
	background: #00843D;
	box-sizing: border-box;
	font-feature-settings: "palt";
	font-weight: 600;
	position: relative;
	overflow: hidden;
}
.comBtn a:after {
	margin-top: -1.6rem;
	position: absolute;
	top: 50%;
	right: 4rem;
	width: 2.3rem;
	height: 2.3rem;
	border-top: 2px solid ;
	border-right: 2px solid ;
	transform: rotate(45deg);
	content: "";
	transition: 0.3s;
	border-color: currentColor;
}
.comBtn a::before {
    width: 100%;
    height: 100%;
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    background: #fff;
    opacity: 0;
    transition: 0.3s;
    pointer-events: none;
}
@media all and (min-width: 897px) {
    .comBtn a:hover::before{
        opacity: 0.3;
    }
}
/* pageTitle */
.pageTitle {
	margin-bottom: 5.9rem;
	padding-top: 1rem;
	height: 22rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	position: relative;
	border-top: 0.1rem solid #E6E6E6;
}
.pageTitle::after {
	content: "";
	width: 9rem;
	height: 6.6rem;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -5.9rem;
	background: url("../img/common/icon.png") no-repeat left top / 100% 100%;
}
.pageTitle h2 {
	font-size: 4rem;
	line-height: 1.25;
	font-weight: 600;
	text-align: center;
	letter-spacing: 0.1rem;
	color: #00843D;
}
#main {
	padding-top: 11rem
}
/* lightTxt */
.lightTxt {
	background: linear-gradient(to bottom, #fff 43%,#FFCD00 20%);
}
/* headLine */
.headLine {
	margin: 0 -1rem 3.5rem -1rem;
	padding: 0.5rem 0 0 0rem;
	font-size: 3.8rem;
	font-weight: 600;
	line-height: 1.315;
	color: #00843D;
	display: flex;
	align-items: flex-start;
}
.animation.headLine .jp {
	min-height: 11rem;
	display: flex;
	align-items: center;
	flex: 1;
}
.animation.headLine .en {
	margin: 0.7rem 2.8rem 0 0;
	padding: 1.2rem 1rem 0.5rem;
	width: 10rem;
	height: 10rem;
	font-weight: bold;
	font-size: 5.2rem;
	color: #FFF;
	border-radius: 50%;
	background: #00843D;
	display: block;
	text-align: center;
	box-sizing: border-box;
	font-family: "Inria Sans", sans-serif;
}
/* innerBox */
.innerBox {
	padding: 2.8rem 4rem 3.6rem;
	font-size: 2.8rem;
	line-height: 1.857;
	letter-spacing: 0.07rem;
	background: #fff;
	border-radius: 3.6rem;
	text-align: justify;
	font-weight: 600;
	font-feature-settings: "palt";
}
.innerBox .note {
	font-size: 2.6rem;
	line-height: 1.615;
	letter-spacing: 0.05em;
	font-weight: 300;
}
.innerBox .note02 {
	font-size: 2.4rem;
	line-height: 1.708;
}
.innerBox p + .note {
	margin-top: 0.2rem
}
.innerBox p + .note02 {
	margin-top: 1rem;
}
.innerBox .note + .img {
	margin: 2.2rem auto 1.1rem
}
.innerBox .img {
	margin: 0 auto;
}
.innerBox .img img {
	width: 100%;
}
.innerBox .textList li {
	padding-left: 2.4rem;
	text-indent: -2.4rem;
}
.innerBox .textList li::before {
	content: "・ ";
}
.innerBox .subBox h3 {
	font-size: 2.8rem;
	font-weight: 600;
	line-height: 1.4;
}
.innerBox .subBox h3 small {
	font-size: 2.4rem;
}
.innerBox .subBox  p {
	margin-bottom: 2.7rem;
	font-size: 2.4rem;
	line-height: 1.708;
	font-weight: 300;
	letter-spacing: 0.04em;
	text-align: left;
}
.innerBox .subBox  p:last-child {
	margin-bottom: 0;
}
#main .innerBox ~ .comBtn {
	margin: 5rem -1rem 0;
}
/* slider */
.slider {
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
}
.slider img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.slider li {
	height: 100vh;
}
@media all and (max-width: 896px) {
	.slider {
		display: none;
	}
}
/* comLinkBox */
.comLinkBox {
	padding: 1.3rem 4rem 3.4rem 4.8rem;
	background: #fff;
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.comLinkBox::before {
	content: "";
	width: 100%;
	height: 5.7rem;
	position: absolute;
	left: 0;
	top: -5.6rem;
	background: url("../img/common/bg03.png") repeat-x left top / 100% 5.7rem;
}
.comLinkBox .imgLink {
	width: 18rem
}
.comLinkBox .list {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex: 1;
	gap:2.8rem
}
.comLinkBox .list li {
	width: auto;
}
.comLinkBox .imgLink img {
	width: auto;
	height: 8rem
}
@media all and (min-width: 897px) {
	.comLinkBox .imgLink a:hover {
		opacity: 0.7;
	}
}

/* fadeInUp */
.animation .jsTtl {
	display: block;
	overflow: hidden;
}
.animation .jsTxt {
	display: block;
	transform: translateY(100%);
	transition: 1.0s cubic-bezier(0.68, -0.6, 0.32, 1.6);
}
.animation.visible .jsTxt {
	transform: translateY(0);
}
.fadeInUp {
	opacity: 0;
	transform: translateY(4rem);
	transition: all 1s 0.2s;
}
.fadeInUp.visible {
	opacity: 1;
	transform: translateY(0);
}