@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;
}
/* comBtn */
.comBtn a {
    padding: 1rem 6rem 1rem 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 66rem;
    height: 14rem;
    text-align: center;
    font-size: 4rem;
    line-height: 1.277;
    letter-spacing: 0.02em;
    color: #fff;
    border-radius: 7rem;
    background: #00843D;
    box-sizing: border-box;
    font-weight: 700;
    position: relative;
}
.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;
}
@media all and (min-width: 897px) {
    .comBtn a:hover {
        opacity: 0.7;
    }
}
/* pageTitle */
.pageTitle {
    margin-bottom: 5.8rem;
    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;
    text-align: center;
    letter-spacing: 0.02em;
    color: #00843D;
}
#main {
    padding-top: 11rem
}
/* lightTxt */
.lightTxt {
    font-weight: 700;
    background: linear-gradient(to bottom, #fff 43%,#FFCD00 20%);
}
/* headLine */
.headLine {
    margin: 0 -1rem 3.1rem -1rem;
    padding: 0.5rem 0 0 0rem;
    font-size: 4rem;
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: 0.02em;
    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: 1rem 3rem 0 0;
    padding: 1.2rem 1rem 0.5rem;
    width: 10rem;
    height: 10rem;
    font-weight: 700;
    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: 3.3rem 4rem 3.3rem;
    font-size: 3.2rem;
    line-height: 1.375;
    letter-spacing: 0.03rem;
    background: #fff;
    border-radius: 3.6rem;
    font-weight: 500;
}
.innerBox .note {
    font-size: 2.8rem;
    line-height: 1.428;
    letter-spacing: 0.03rem;
    font-weight: 400;
}
.innerBox .list li {
    padding-left: 2rem;
    text-indent: -2rem;
}
.innerBox .note li {
    padding-left: 1.5rem;
    text-indent: -1.5rem;
}
.innerBox p + .note {
    margin-top: 1rem
}
.innerBox .note + .img {
    margin: 2.2rem auto 1.1rem
}
.innerBox .img {
    margin: 0 auto;
}
.innerBox .img img {
    width: 100%;
}
.innerBox ul.note {
    margin-top: 0;
}
#main .innerBox ~ .comBtn {
    margin: 5.8rem -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);
}