@charset "UTF-8";

/* ------------------------------------------------
                    TOP
--------------------------------------------------- */
/*---------- MV ----------*/
.sec-mv {
	width: 100%;
	padding: 155px 0 135px;
	text-align: center;
	background: url("../../img/top/bg_mv.jpg") center center no-repeat;
	background-size: cover;
	position: relative;
	z-index: 1;
}

.mv-copy {
	margin-bottom: 80px;
	font-size: 3.8rem;
	font-weight: 900;
	line-height: 1.4;
}
.mv-logo {
	width: 80%;
	max-width: 676px;
	margin: 0 auto;
}
a.btn-mv-dl {
	width: 80%;
	max-width: 500px;
	margin: 90px auto 0;
	padding: 30px;
	display: block;
	border-radius: 50px;
	background: linear-gradient(45deg, #004831, #218341, #32a144, #c4d700);
	box-shadow: 7px 7px 0 rgba(20,29,29,0.3);
	color: #fff;
	font-size: 2.0rem;
	font-weight: 700;
	line-height: 1;
	position: relative;
}
a.btn-mv-dl::before {
	content: '';
	width: 10px;
	height: 20px;
	background: url("../../img/common/icon_arrow_w.svg") center center no-repeat;
	background-size: 100%;
	position: absolute;
	top: calc(50% - 10px);
	left: 30px;
}
a.btn-mv-dl::after {
	content: '';
	width: 34px;
	height: 38px;
	background: url("../../img/common/icon_dl_w.svg") center center no-repeat;
	background-size: 100%;
	position: absolute;
	top: calc(50% - 19px);
	right: 25px;
}

@media (max-width: 1000px) {
	.mv-copy {
		font-size: 3.8vw;
	}
}

@media (max-width: 768px) {
	.sec-mv {
		width: 100%;
		padding: 20vw 0 30vw;
	}

	.mv-copy {
		margin-bottom: 12vw;
		font-size: 4.8vw;
	}
	.mv-logo {
		width: 80%;
		max-width: 676px;
		margin: 0 auto;
	}
	a.btn-mv-dl {
		width: 80%;
		max-width: 500px;
		margin: 12vw auto 0;
		padding: 4.5vw 6vw;
		display: block;
		border-radius: 10vw;
		font-size: 4.0vw;
	}
	a.btn-mv-dl::before {
		content: '';
		width: 2vw;
		height: 4vw;
		position: absolute;
		top: calc(50% - 2vw);
		left: 6vw;
	}
	a.btn-mv-dl::after {
		content: '';
		width: 6vw;
		height: 8vw;
		position: absolute;
		top: calc(50% - 4vw);
		right: 5vw;
	}
    
}



/*---------- 共通パーツ ----------*/
.sec-ttl-en {
	margin-bottom: 40px;
	font-size: 7.4rem;
	line-height: 1;
}

.sec-ttl-txt {
	font-size: 3.0rem;
	font-weight: 700;
	line-height: 1;
}


@media (max-width: 768px) {
	.sec-ttl-en {
		margin-bottom: 8vw;
		font-size: 12.8vw;
	}

	.sec-ttl-txt {
		font-size: 5.4vw;
	}
    
}


/*---------- News ----------*/
.sec-news {
	width: 100%;
	margin: -50px auto 100px;
	position: relative;
	z-index: 2;
}
.sec-news .cont-inn {
	padding: 30px 30px 30px 60px;
	background: #fff;
	border-radius: 20px;
	box-shadow: 0 0 16px rgba(186,186,194,0.5);
	align-items: center;
}
.sec-news-ttl {
	margin-right: 40px;
	padding-right: 50px;
	border-right: 1px solid #ddddee;
	font-size: 2.8rem;
	line-height: 1;
}

.news-wrap {
	display: flex;
	align-items: center;
	margin-right: auto;
}
.news-date {
	font-size: 1.7rem;
	margin-right: 50px;
}
.news-ttl {
	font-size: 1.6rem;
}


@media (max-width: 950px) {
	.sec-news-ttl {
		width: calc(28% - 4vw);
		margin-right: 4vw;
		padding-right: 4vw;
		border-right: 1px solid #ddddee;
		font-size: 2.8rem;
		line-height: 1;
	}
	.news-wrap {
		width: 72%;
	}
	.sec-news .btn-black.btn-small {
		margin-top: 20px;
		margin-left: auto;
	}
    
}


@media (max-width: 768px) {
	.sec-news {
		width: 100%;
		margin: -18vw auto 16vw;
	}
	.sec-news .cont-inn {
		padding: 6vw;
		border-radius: 4vw;
	}
	.sec-news-ttl {
		margin-right: 0;
		margin-bottom: 2vw;
		padding-right: 0;
		border-right: none;
		font-size: 5.6vw;
	}

	.news-wrap {
		width: 100%;
		display: flex;
		align-items: flex-start;
		margin-right: auto;
	}
	.news-date {
		font-size: 3.8vw;
		margin-right: 4vw;
	}
	.news-ttl {
		font-size: 3.6vw;
	}
	.sec-news .btn-black.btn-small {
		margin-top: 4vw;
	}
    
}

/*---------- About ----------*/
.sec-about {
	width: 100%;
	margin-bottom: 40px;
	padding: 115px 0 120px;
	position: relative;
}
.sec-about::before {
	content: '';
	width: 65%;
	height: 100%;
	background: #f3f8f6;
	border-radius: 0 40px 40px 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.sec-about .cont-inn {
	position: relative;
	z-index: 2;
}

/* title */
.sec-about .sec-ttl-en {
	margin-bottom: 30px;
}

.about-logo {
	align-items: center;
}
.about-logo img {
	width: 80%;
	max-width: 224px;
}
.about-logo .about-logo-txt {
	margin: 0 12px;
	font-size: 3.0rem;
	font-weight: 700;
}

/* intro */
.about-intro-wrap {
	width: 100%;
	margin: 0 auto 45px;
	align-items: center;
	justify-content: space-between;
}
.about-txt-wrap {
	width: 460px;
	margin: 20px 0;
}
.about-copy {
	margin-bottom: 50px;
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 2;
}
.about-txt {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 2.4;
}
.about-img {
	width: calc(96% - 460px);
}


@media (max-width: 1100px) {
	.about-txt-wrap {
		width: 50%;
		margin: 20px 0;
	}
	.about-copy {
		margin-bottom: 50px;
		font-size: 2.2vw;
	}
	.about-txt {
		font-size: 1.4vw;
	}

	.about-img {
		width: 48%;
	}
	
}


@media (max-width: 768px) {
	.sec-about {
		width: 100%;
		margin-bottom: 8vw;
		padding: 14vw 0 14vw;
		position: relative;
	}
	.sec-about::before {
		content: '';
		width: 80%;
		height: 100%;
		border-radius: 0 8vw 8vw 0;
	}

	/* title */
	.sec-about .sec-ttl-en {
		margin-bottom: 6vw;
	}
	.about-logo img {
		width: 80%;
		max-width: 224px;
	}
	.about-logo .about-logo-txt {
		font-size: 4.6vw;
		margin: 0 2.2vw;
	}

	/* intro */
	.about-intro-wrap {
		width: 100%;
		margin: 0 auto 10vw;
		align-items: center;
		justify-content: space-between;
	}
	.about-txt-wrap {
		width: 100%;
		margin: 8vw auto;
	}
	.about-copy {
		margin-bottom: 8vw;
		font-size: 4.6vw;
	}
	.about-txt {
		font-size: 3.8vw;
	}

	.about-img {
		width: 95%;
		margin-right: auto;
	}
    
}



/* detail */
.about-detail-wrap {
	align-items: stretch;
	justify-content: center;
	flex-wrap: wrap;
}
.about-detail-box {
	width: 29%;
	margin-right: 6.5%;
	margin-top: 35px;
	display: flex;
	flex-direction: column;
}
.about-detail-box:nth-child(3), 
.about-detail-box:last-child {
	margin-right: 0;
}

.about-detail-ttl-wrap {
	width: 100%;
	padding: 30px;
	border-radius: 20px;
	color: #fff;
	font-weight: 700;
	flex-grow: 1;
}
.about-detail-box.box-01 .about-detail-ttl-wrap {
	background: #004831;
}
.about-detail-box.box-02 .about-detail-ttl-wrap {
	background: #0b3d2c;
}
.about-detail-box.box-03 .about-detail-ttl-wrap {
	background: #132d24;
}
.about-detail-box.box-04 .about-detail-ttl-wrap {
	background: #132d24;
}
.about-detail-box.box-05 .about-detail-ttl-wrap {
	background: #14201e;
}

.about-detail-ttl {
	margin-bottom: 20px;
	display: flex;
	flex-direction: column;
	text-align: center;
}
.about-detail-ttl-en {
	margin-bottom: 15px;
	align-items: center;
	justify-content: center;
	font-size: 3.2rem;
	font-weight: 600;
	line-height: 1;
	position: relative;
}
.about-detail-box.box-01 .about-detail-ttl-en::before {
	content: '';
	width: 29px;
	height: 41px;
	margin-right: 15px;
	background: url("../../img/top/icon_about_01.svg") center center no-repeat;
	background-size: 100%;
}
.about-detail-box.box-02 .about-detail-ttl-en::before {
	content: '';
	width: 35px;
	height: 41px;
	margin-right: 15px;
	background: url("../../img/top/icon_about_02.svg") center center no-repeat;
	background-size: 100%;
}
.about-detail-box.box-03 .about-detail-ttl-en::before {
	content: '';
	width: 35px;
	height: 41px;
	margin-right: 15px;
	background: url("../../img/top/icon_about_03.svg") center center no-repeat;
	background-size: 100%;
}
.about-detail-box.box-04 .about-detail-ttl-en::before {
	content: '';
	width: 33px;
	height: 41px;
	margin-right: 15px;
	background: url("../../img/top/icon_about_04.svg") center center no-repeat;
	background-size: 100%;
}
.about-detail-box.box-05 .about-detail-ttl-en::before {
	content: '';
	width: 33px;
	height: 41px;
	margin-right: 15px;
	background: url("../../img/top/icon_about_05.svg") center center no-repeat;
	background-size: 100%;
}

.about-detail-ttl-ja {
	font-size: 1.7rem;
	line-height: 1;
}

.about-detail-list li {
	margin-bottom: 12px;
	padding-left: 30px;
	align-items: center;
	position: relative;
	line-height: 1;
}
.about-detail-list li:last-child {
	margin-bottom: 0;
}
.about-detail-list li.is-checked::before {
	content: '';
	width: 19px;
	height: 16px;
	background: url("../../img/top/icon_check_checked.svg") center center no-repeat;
	background-size: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.about-detail-list li.is-no-checked::before {
	content: '';
	width: 19px;
	height: 16px;
	background: url("../../img/top/icon_check.svg") center center no-repeat;
	background-size: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.about-detail-txt {
	margin: 25px auto;
	text-align: center;
	font-weight: 700;
	line-height: 2;
}
.about-detail-txt .only-wide {
	display: block;
}
.about-detail-txt .only-semiwide {
	display: none;
}
.about-detail-txt .only-seminarrow {
	display: none;
}

.about-detail-txt .font-size-s {
	font-size: 1.2rem;
}


.about-detail-box .btn-white {
	margin-top: auto;
}



@media (max-width: 1360px) {

	.about-detail-ttl-en {
		font-size: 1.8vw;
	}
	.about-detail-ttl-ja {
		font-size: 1.1vw;
	}
	.about-detail-txt {
		font-size: 1.0vw;
	}

}
@media (max-width: 1470px) {
	.about-detail-box {
		width: 31%;
		margin-right: 3.5%;
	}

	.about-detail-ttl-en {
		font-size: 2.2vw;
	}
}
@media (max-width: 1310px) {
	.about-detail-txt .only-semiwide {
		display: block;
	}
}
@media (max-width: 950px) {
	.about-detail-box {
		width: 47.5%;
		margin-right: 5%;
	}
	.about-detail-box:nth-child(3){
		margin-right: 5%;
	}
	.about-detail-box:nth-child(2), 
	.about-detail-box:nth-child(4), 
	.about-detail-box:last-child {
		margin-right: 0;
	}

	.about-detail-ttl-en {
		font-size: 2.8vw;
	}
	.about-detail-ttl-ja {
		font-size: 1.6vw;
	}
	.about-detail-txt {
		font-size: 1.5vw;
	}
	.about-detail-txt .only-wide {
		display: none;
	}
	.about-detail-txt .only-semiwide {
		display: none;
	}
	.about-detail-txt .only-seminarrow {
		display: block;
	}
}


@media (max-width: 768px) {
	.about-detail-box {
		width: 100%;
		margin-right: 0;
		margin-top: 12vw;
	}
	.about-detail-box:nth-child(3){
		margin-right: 0;
	}

	.about-detail-ttl-wrap {
		width: 100%;
		padding: 4vw;
		border-radius: 4vw;
	}

	.about-detail-ttl {
		margin-bottom: 3vw;
	}
	.about-detail-ttl-en {
		margin-bottom: 3vw;
		font-size: 5.2vw;
	}
	.about-detail-ttl-ja {
		font-size: 4.2vw;
	}
	.about-detail-txt {
		font-size: 3.6vw;
	}
	.about-detail-box.box-01 .about-detail-ttl-en::before {
		content: '';
		width: 5.8vw;
		height: 7vw;
		margin-right: 3vw;
	}
	.about-detail-box.box-02 .about-detail-ttl-en::before {
		content: '';
		width: 7vw;
		height: 6.8vw;
		margin-right: 3vw;
	}
	.about-detail-box.box-03 .about-detail-ttl-en::before {
		content: '';
		width: 7vw;
		height: 5.4vw;
		margin-right: 3vw;
	}
	.about-detail-box.box-04 .about-detail-ttl-en::before {
		content: '';
		width: 6.4vw;
		height: 3vw;
		margin-right: 3vw;
	}
	.about-detail-box.box-05 .about-detail-ttl-en::before {
		content: '';
		width: 33px;
		height: 41px;
		margin-right: 15px;
		background: url("../../img/top/icon_about_05.svg") center center no-repeat;
		background-size: 100%;
	}

	.about-detail-ttl-ja {
		font-size: 3.8vw;
	}

	.about-detail-list li {
		margin-bottom: 2.2vw;
		padding-left: 6vw;
	}
	.about-detail-list li:last-child {
		margin-bottom: 0;
	}
	.about-detail-list li.is-checked::before {
		content: '';
		width: 4vw;
		height: 3.5vw;
	}
	.about-detail-list li.is-no-checked::before {
		content: '';
		width: 4vw;
		height: 3.5vw;
	}

	.about-detail-txt {
		margin: 3vw auto;
		text-align: center;
		font-weight: 700;
		line-height: 2;
	}
	.about-detail-txt .font-size-s {
		font-size: 3.0vw;
	}
	.about-detail-txt .only-seminarrow {
		display: none;
	}


	.about-detail-box .btn-white {
		margin: 0 auto;
	}
}


/*---------- Link----------*/
.sec-link {
	width: 100%;
	margin-bottom: 120px;
	padding: 115px 0 100px;
	position: relative;
}
.sec-link::before {
	content: '';
	width: 65%;
	height: 100%;
	background: url("../../img/top/bg_link.jpg") center center no-repeat;
	background-size: cover;
	border-radius: 0 40px 40px 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.sec-link .cont-inn {
	justify-content: space-between;
	position: relative;
	z-index: 2;
}

.link-item {
	width: calc((100% - 120px) / 3);
	text-align: center;
}
.link-item-ttl {
	margin-bottom: 60px;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.5;
	position: relative;
}
.link-item-ttl::after {
	content: '';
	width: 40px;
	height: 1px;
	position: absolute;
	bottom: -30px;
	left: calc(50% - 20px);
}
.link-item.item-01 .link-item-ttl::after {
	background: #c4d700;
}
.link-item.item-02 .link-item-ttl::after {
	background: #004831;
}
.link-item.item-03 .link-item-ttl::after {
	background: #e95501;
}

@media (max-width: 1250px) {
	.link-item-ttl {
		font-size: 1.8vw;
	}
    .link-item a.btn-lightgreen, 
    .link-item a.btn-green, 
	.link-item a.btn-orange {
		font-size: 1.4vw;
	}
}

@media (max-width: 950px) {

	.link-item {
		width: calc((100% - 60px) / 2);
		text-align: center;
	}
	.link-item.item-03 {
		margin: 50px auto 0;
	}
    .link-item a.btn-lightgreen, 
    .link-item a.btn-green, 
	.link-item a.btn-orange {
		font-size: 1.4vw;
	}
}

@media (max-width: 768px) {
	.sec-link {
		width: 100%;
		margin-bottom: 16vw;
		padding: 14vw 0 14vw;
	}
	.sec-link::before {
		content: '';
		width: 80%;
		height: 100%;
		border-radius: 0 8vw 8vw 0;
	}
	.sec-link .cont-inn {
		justify-content: space-between;
		position: relative;
		z-index: 2;
	}

	.link-item {
		width: 100%;
		margin-bottom: 10vw;
	}
	.link-item.item-03 {
		margin: 0 auto;
	}
	.link-item-ttl {
		margin-bottom: 8vw;
		font-size: 4.6vw;
	}
	.link-item-ttl::after {
		content: '';
		width: 8vw;
		height: 1px;
		position: absolute;
		bottom: -4vw;
		left: calc(50% - 4vw);
	}
    .link-item a.btn-lightgreen, 
    .link-item a.btn-green, 
	.link-item a.btn-orange {
		font-size: 3.6vw;
		margin: 0 auto;
	}
    
}



/*---------- Document ----------*/
.sec-document {
	width: 100%;
	margin-bottom: 120px;
	padding: 120px 0;
	position: relative;
}
.sec-document::before {
	content: '';
	width: 65%;
	height: 100%;
	background: #f4f4f4;
	border-radius: 40px 0 0 40px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
}
.sec-document .cont-inn {
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	position: relative;
	z-index: 2;
}
.sec-document .sec-ttl-wrap {
	width: 100%;
	margin-bottom: 60px;
	text-align: right;
	order: 1;
}
.document-img-wrap {
	width: calc(96% - 580px);
	order: 3;
}

.document-txt-wrap {
	width: 580px;
	order: 2;
}
.document-copy {
	margin-bottom: 50px;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 2.2;
}
.document-txt {
	margin-bottom: 60px;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 2;
}
.document-txt-wrap .btn-download-lightgreen {
	max-width: 488px;
	margin-right: auto;
}

@media (max-width: 1200px) {
	.sec-document .cont-inn {
		align-items: center;
	}
	.document-img-wrap {
		width: 42%;
	}

	.document-txt-wrap {
		width: 54%;
	}
	.document-copy {
		font-size: 1.8vw;
	}
	.document-txt {
		font-size: 1.4vw;
	}
}

@media (max-width: 768px) {
	.sec-document {
		width: 100%;
		margin-bottom: 16vw;
		padding: 14vw 0 14vw;
	}
	.sec-document::before {
		content: '';
		width: 80%;
		height: 100%;
		border-radius: 8vw 0 0 8vw;
	}
	.sec-document .cont-inn {
		flex-wrap: wrap;
		align-items: flex-end;
		justify-content: space-between;
		position: relative;
		z-index: 2;
	}
	.sec-document .sec-ttl-wrap {
		width: 100%;
		margin-bottom: 12vw;
	}
	.document-img-wrap {
		width: 100%;
		margin-bottom: 8vw;
		order: 2;
	}

	.document-txt-wrap {
		width: 100%;
		order: 3;
	}
	.document-copy {
		margin-bottom: 8vw;
		font-size: 4.4vw;
	}
	.document-txt {
		margin-bottom: 10vw;
		font-size: 3.8vw;
	}
	.document-txt-wrap .btn-download-lightgreen {
		max-width: initial;
		margin: 0 auto;
	}
}




/*---------- Price ----------*/
.sec-price {
	width: 100%;
	margin-bottom: 120px;
	padding: 120px 0;
	position: relative;
}
.sec-price::before {
	content: '';
	width: 65%;
	height: 100%;
	background: url("../../img/top/bg_price.jpg") center center no-repeat;
	background-size: cover;
	border-radius: 0 40px 40px 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.sec-price .cont-inn {
	position: relative;
	z-index: 2;
}
.sec-price .sec-ttl-wrap {
	width: 30%;
	color: #fff;
}
.price-cont-wrap {
	width: 70%;
	flex-wrap: wrap;
	justify-content: space-between;
}
.price-logo-wrap {
	width: 35%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #004831;
	border-radius: 30px;
	color: #fff;
}
.price-logo {
	width: 80%;
	max-width: 220px;
	margin: 0 auto 48px;
	position: relative;
}
.price-logo::after {
	content: '';
	width: 40px;
	height: 2px;
	background: #c4d700;
	position: absolute;
	bottom: -22px;
	left: calc(50% - 20px);
}

.price-unit {
	font-size: 1.8rem;
	font-weight: 700;
}
.price-unit .font-size-l {
	font-size: 2.4rem;
}

.price-list-wrap {
	width: calc(65% - 12px);
}

.price-list li {
	width: 100%;
	margin-bottom: 4px;
	padding: 30px 50px;
	background: #141d1d;
	border-radius: 30px;
	color: #fff;
	position: relative;
}
.price-list li:last-child {
	margin-bottom: 0;
}
.price-list li::before {
	content: '';
	width: 6px;
	height: 6px;
	background: #fff;
	border-radius: 50%;
	position: absolute;
	top: calc(50% - 3px);
	left: -40px;
}
.price-list li::after {
	content: '';
	width: 40px;
	height: 2px;
	background: linear-gradient(45deg, #fff, #141d1d);
	position: absolute;
	top: calc(50% - 1px);
	left: -40px;
}


.price-list-ttl {
	width: 50%;
	border-right: 2px solid #c4d700;
	flex-direction: column;
}
.price-list-ttl-en {
	margin-bottom: 5px;
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1;
}
.price-list-ttl-ja {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1;
}

.price-list-price {
	padding-left: 20px;
	font-weight: 700;
}
.price-list-price .font-size-l {
	font-size: 2.0rem;
}
.price-list-price .font-size-l .txt-jost {
	font-size: 2.4rem;
}

.price-cont-wrap .txt-caption {
	width: 100%;
	margin: 20px auto 40px;
	font-size: 1.3rem;
	font-weight: 700;
}

.price-cont-wrap .btn-white-black {
	max-width: 488px;
	margin: 0 auto;
}


@media (max-width: 1440px) {
	.sec-price .sec-ttl-wrap {
		width: 25%;
	}
	.price-cont-wrap {
		width: 75%;
	}

	.price-list li {
		width: 100%;
		padding: 3vw 3vw;
	}
	.price-list-ttl {
		width: 55%;
	}
	.price-list-ttl-en {
		font-size: 1.6vw;
	}
	.price-list-ttl-ja {
		font-size: 1.3vw;
	}
	.price-list-price .font-size-l {
		font-size: 1.3vw;
	}
	.price-list-price .font-size-l .txt-jost {
		font-size: 1.8vw;
	}
}


@media (max-width: 950px) {
	.sec-price .sec-ttl-wrap {
		width: 100%;
	}
	.price-cont-wrap {
		width: 100%;
		margin-top: 30px;
	}
	.price-list-ttl-en {
		font-size: 2.0vw;
	}
	.price-list-ttl-ja {
		font-size: 1.8vw;
	}
	.price-list-price .font-size-l {
		font-size: 1.8vw;
	}
	.price-list-price .font-size-l .txt-jost {
		font-size: 2.0vw;
	}
}


@media (max-width: 768px) {
	.sec-price {
		width: 100%;
		margin-bottom: 16vw;
		padding: 14vw 0 14vw;
	}
	.sec-price::before {
		content: '';
		width: 80%;
		height: 100%;
		border-radius: 0 8vw 8vw 0;
	}
	.sec-price .sec-ttl-wrap {
		width: 100%;
	}
	.price-cont-wrap {
		width: 100%;
		margin-top: 8vw;
	}
	.price-logo-wrap {
		width: 40%;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		background: #004831;
		border-radius: 30px;
		color: #fff;
	}
	.price-logo {
		width: 80%;
		max-width: 220px;
		margin: 0 auto 10vw;
		position: relative;
	}
	.price-logo::after {
		content: '';
		width: 8vw;
		height: 2px;
		background: #c4d700;
		position: absolute;
		bottom: -5vw;
		left: calc(50% - 4vw);
	}

	.price-unit {
		font-size: 3.4vw;
	}
	.price-unit .font-size-l {
		font-size: 4.4vw;
	}

	.price-list-wrap {
		width: calc(60% - 2.2vw);
	}

	.price-list li {
		width: 100%;
		margin-bottom: 1vw;
		padding: 4vw 5vw;
		border-radius: 4vw;
		color: #fff;
		position: relative;
	}
	.price-list li:last-child {
		margin-bottom: 0;
	}
	.price-list li::before {
		content: '';
		width: 6px;
		height: 6px;
		background: #fff;
		border-radius: 50%;
		position: absolute;
		top: calc(50% - 3px);
		left: -8vw;
	}
	.price-list li::after {
		content: '';
		width: 8vw;
		height: 2px;
		background: linear-gradient(45deg, #fff, #141d1d);
		position: absolute;
		top: calc(50% - 1px);
		left: -8vw;
	}


	.price-list-ttl {
		width: 100%;
		margin-bottom: 3vw;
		padding-bottom: 3vw;
		border-right: none;
		border-bottom: 2px solid #c4d700;
	}
	.price-list-ttl-en {
		margin-bottom: 2vw;
		font-size: 4.6vw;
	}
	.price-list-ttl-ja {
		font-size: 3.4vw;
	}

	.price-list-price {
		padding-left: 0;
	}
	.price-list-price .font-size-l {
		font-size: 3.6vw;
	}
	.price-list-price .font-size-l .txt-jost {
		font-size: 4.6vw;
	}

	.price-cont-wrap .txt-caption {
		width: 100%;
		margin: 3vw auto 8vw;
		font-size: 2.8vw;
	}

	.price-cont-wrap .btn-white-black {
		width: 96%;
		max-width: initial;
		margin: 0 auto;
		font-size: 3.6vw;
	}
    
}



/*---------- FAQ ----------*/
.sec-faq {
	width: 100%;
	margin: 0 auto 120px;
	padding: 120px 0;
	position: relative;
}
.sec-faq::before {
	content: '';
	width: 62%;
	height: 100%;
	background: url("../../img/top/bg_faq.jpg") center center no-repeat;
	background-size: cover;
	border-radius: 40px 0 0 40px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
}
.sec-faq .cont-inn {
	align-items: flex-start;
	justify-content: space-between;
	flex-direction: row-reverse;
	position: relative;
	z-index: 2;
}
.sec-faq .sec-ttl-wrap {
	text-align: right;
	color: #fff;
}
.sec-faq .sec-ttl-txt {
	font-size: 3.0rem;
}

.faq-box-wrap {
	width: 68%;
	margin-right: auto;
}
.faq-box {
	width: 100%;
	margin-bottom: 30px;
	background: #fff;
	border: 2px solid #141d1d;
	border-radius: 30px;
}
.faq-box:last-child {
	margin-bottom: 0;
}
.faq-q {
	cursor: pointer;
}
.faq-q, .faq-a {
	align-items: stretch;
	position: relative;
}
.faq-q::after {
	content: '';
	width: 16px;
	height: 8px;
	background: url("../../img/common/icon_arrow_toggle.svg") center center no-repeat;
	background-size: 100%;
	position: absolute;
	top: calc(50% - 4px);
	right: 30px;
	transition: 0.3s ease-in-out;
}
.faq-q.is-open::after {
	transform:rotate(180deg);
}
.is-accordion-cont {
	display: none;
}
.faq-a {
	align-items: stretch;
	border-top: 1px solid #80a398;
}
.faq-box-num {
	width: 80px;
	padding: 30px 0;
	display: flex;
	align-items: center;
	justify-content: center;
	border-right: 1px solid #80a398;
	color: #80a398;
	text-align: center;
	font-size: 2.0rem;
	font-weight: 700;
}
.faq-box-txt-q {
	width: calc(100% - 80px);
	padding: 30px 60px 30px 30px;
	font-size: 1.7rem;
	font-weight: 700;
}
.faq-box-txt-a {
	width: calc(100% - 80px);
	padding: 30px;
	font-size: 1.5rem;
	font-weight: 700;
}


@media (max-width: 768px) {
	.sec-faq {
		width: 100%;
		margin: 0 auto 16vw;
		padding: 14vw 0 14vw;
	}
	.sec-faq::before {
		content: '';
		width: 80%;
		height: 100%;
		border-radius: 8vw 0 0 8vw;
	}
	.sec-faq .cont-inn {
		align-items: flex-start;
		justify-content: space-between;
		flex-direction: row-reverse;
		position: relative;
		z-index: 2;
	}
	.sec-faq .sec-ttl-wrap {
		text-align: right;
		color: #fff;
	}
	.sec-faq .sec-ttl-txt {
		font-size: 5.4vw;
	}

	.faq-box-wrap {
		width: 100%;
		margin-top: 10vw;
		margin-right: auto;
	}
	.faq-box {
		width: 100%;
		margin-bottom: 6vw;
		border-radius: 4vw;
	}
	.faq-box:last-child {
		margin-bottom: 0;
	}
	.faq-q {
		cursor: pointer;
	}
	.faq-q, .faq-a {
		align-items: stretch;
		position: relative;
	}
	.faq-q::after {
		content: '';
		width: 4vw;
		height: 2vw;
		top: calc(50% - 1vw);
		right: 4vw;
	}
	.faq-box-num {
		width: 16vw;
		padding: 5vw 0;
		display: flex;
		align-items: center;
		justify-content: center;
		border-right: 1px solid #80a398;
		color: #80a398;
		text-align: center;
		font-size: 2.0rem;
		font-weight: 700;
	}
	.faq-box-txt-q {
		width: calc(100% - 16vw);
		padding: 5vw 10vw 5vw 5vw;
		font-size: 3.5vw;
	}
	.faq-box-txt-a {
		width: calc(100% - 16vw);
		padding: 5vw;
		font-size: 3.2vw;
	}
    
}