*{
	padding: 0;
	margin: 0;
	border: 0;
	box-sizing: border-box;
	font-size: 100%;
	list-style: none;
}
html{
	font-size: 62.5%;
	-webkit-font-smoothing: antialiased;
}
body{
	font-size: 2rem;
	font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
	line-height: 1.8;
	line-break: strict;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
.wrap{
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
	width: 100%;
	max-width: 800px;
	margin: auto;
}
amp-img{width:100%;height:auto;}
a{text-decoration:none;}
strong{background:linear-gradient(transparent 40%, #ffff66 0%);}
em{color:#ffff66;font-style:normal;font-weight:bold;}

.hdrA{
	padding: 20px;
	background: #2494a5;
	color: #fff;
	font-weight: bold;
	font-size: 160%;
	line-height: 1.4;
	font-feature-settings: "palt";
	letter-spacing: 0.02em;
	text-align: center;
	position: relative;
}
.hdrA::after{
	content: "";
	display: block;
	width: 0;
	height: 0;
	border: solid 40px transparent;
	border-top: solid 30px #2494a5;
	position: absolute;
	bottom: -69px;
	left: 50%;
	transform: translate(-50%, 0);
}



header div{
	background: rgb(1,120,101);
	background: linear-gradient(180deg, rgba(1,120,101,1) 10%, rgba(18,204,174,1) 100%);
	padding: 40px 0;
}

/* 申し込みボタン動き */
.btn{
	display: block;
	width: 92%;
	margin: auto;
	position: relative;
	animation: bound 0.8s infinite;
}
.btn amp-img{
	display: block;
	animation: hop 2.4s infinite;
}
@keyframes bound{
0%,100%{transform:translateY(0px);}
10%{transform:translateY(-10px);}
20%{transform:translateY(-18px);}
30%{transform:translateY(-22px);}
40%{transform:translateY(-24px);}
50%{transform:translateY(-25px);}
60%{transform:translateY(-24px);}
70%{transform:translateY(-22px);}
80%{transform:translateY(-18px);}
90%{transform:translateY(-10px);}
}
@keyframes hop{
0%,40%{transform:skew(0deg,0deg)}
5%{transform:skew(5deg,5deg)}
10%{transform:skew(-4deg,-4deg)}
15%{transform:skew(3deg,3deg)}
20%{transform:skew(-2deg,-2deg)}
25%{transform:skew(1deg,1deg)}
30%{transform:skew(-0.6deg,-0.6deg)}
35%{transform:skew(0.3deg,0.3deg)}
}
.btn:hover{
	cursor: pointer;
	opacity: 0.8;
}



.merit{
	padding: 50px 4%;
	background: #fffced;
}
.merit h2{
	width: 80%;
	margin: auto;
}
.merit section{
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
	padding-bottom: 30px;
	border-radius: 15px;
	overflow: hidden;
	margin-top: 40px;
	background: #fff;
}
.merit h3{
	padding: 10px;
	background: #017865;
	color: #fff;
	text-align: center;
	font-size: 150%;
}
.merit span{
	display: block;
	text-align: center;
	font-size: 200%;
	font-weight: bold;
	line-height: 1.3;
	margin: 30px auto;
	font-feature-settings: "palt";
}
.merit p{
	background-image:
		linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 100%),
		linear-gradient(180deg, #ccc 1px, transparent 1px);
	background-size: 8px 100%,100% 2em;
	line-height: 2em;
	margin: 30px 30px 0;
}



.step{
	padding: 50px 4%;
	background: #fffced;
}
.step h2{
	width: 80%;
	margin: 0 auto 40px;
}
.step li{
	display: flex;
	align-items: center;
	width: 100%;
	box-shadow: 0 0 10px rgba(0,0,0,0.05);
	margin-bottom: 50px;
	border-radius: 10px;
	background: #fff;
	position: relative;
}
.step li::after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 20px 40px 0 40px;
	border-color: #999999 transparent transparent transparent;
	position: absolute;
	bottom: -35px;
	left: calc(50% - 40px);
}
.step li:last-child{
	margin-bottom: 0;
}
.step li:last-child::after{
	display: none;
}
.step li > *{
	padding: 20px;
	display: block;
}
.step h3{
	color: #fff;
	width: 7em;
	text-align: center;
	font-size: 120%;
	border-radius: 10px 0 0 10px;
}
.step li p{
	width: calc(100% - 7em);
	font-weight: bold;
}
.step li:first-child h3{
	background: #017865;
}
.step li:nth-child(2) h3{
	background: #148875;
}
.step li:nth-child(3) h3{
	background: #289884;
}
.step li:nth-child(4) h3{
	background: #3ba793;
}
.step li:last-child h3{
	background: #4eb7a3;
}



.contents{
	padding: 50px 4%;
	background: #f9f9f9;
}
.contents h2{
	width: 80%;
	margin: auto;
}
.contents section{
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
	border-radius: 15px;
	overflow: hidden;
	margin-top: 40px;
	background: #fff;
}
.contents h3{
	padding: 10px;
	background: #017865;
	color: #fff;
	text-align: center;
	font-size: 150%;
}
.contents h3.vip{
	background: rgb(210,164,43);
	background: linear-gradient(90deg, rgba(210,164,43,1) 0%, rgba(249,223,142,1) 50%, rgba(210,164,43,1) 100%);
}
.contents span{
	display: block;
	font-size: 80%;
	width: 8em;
	background: #eee;
	margin:  10px auto 0;
}
.contents h3 + p{
	display: block;
	width: calc(100% - 60px);
	text-align: center;
	font-size: 180%;
	font-weight: bold;
	line-height: 1.2;
	margin: auto;
	padding: 30px 0 20px;
	font-feature-settings: "palt";
	border-bottom: dotted 1px #ccc;
}
.check{
	padding: 40px;
}
.check li{
	line-height: 1.4;
	margin-bottom: 15px;
	background: url(./images/check.svg) no-repeat left 2px;
	background-size: 1.4em;
	padding-left: 1.8em;
}
.check li:last-child{
	margin-bottom: 0;
}
.contents ul + p{
	padding: 0 40px 40px;
	font-size: 90%;
	text-align: center;
}



.tokuten{
	background: url(./images/bg.jpg) no-repeat center;
	background-size: cover;
}
.tokuten section{
	position: relative;
	overflow: visible;
}
.tokuten section::before,
.tokuten section::after{
	content: "";
	display: block;
	width: 120px;
	height: 120px;
	background: url(./images/ribbon.svg) no-repeat;
	background-size: 120px;
	position: absolute;
}
.tokuten section::before{
	right: -6px;
	top: -6px;
}
.tokuten section::after{
	transform: rotate(180deg);
	left: -6px;
	bottom: -6px;
}



.price{
	padding-bottom: 50px;
}
.price figure{
	width: 90%;
	margin: 50px auto 40px;
}
.price p{
	text-align: center;
	font-weight: bold;
	margin-bottom: 60px;
	font-size: 120%;
}



.message div{
	padding: 50px 4%;
}
.message p{
	margin-bottom: 1em;
}
.message p:last-child{
	margin-bottom: 0;
}
.tar{
	text-align: right;
}



.apply{
	padding-bottom: 50px;
}
.apply a{
	display: block;
	width: 92%;
	margin: auto;
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
	transition: 0.2s;
}
.apply a:hover{
	opacity: 0.8;
}
.apply .normal{
	border: solid 2px #157766;
	margin: 50px auto 40px;
}
.apply .vip{
	border: solid 2px #b69b3a;
}
.apply ul{
	width: 92%;
	margin: 50px auto 0;
	font-size: 80%;
	padding: 30px;
	background: #f6f6f6;
}



footer{
	text-align: center;
	padding: 30px 4%;
	font-size: 80%;
}
footer a{
	color: #000;
	display: inline-block;
	transition: 0.2s;
}
footer a::after{
	content: "|";
	display: inline-block;
	margin: 0 10px;
}
footer a:last-of-type::after{
	display: none;
}
footer a:hover{
	opacity: 0.6;
}









@media only screen and (max-width: 767px){
body{font-size:1.8rem;}
strong{background:linear-gradient(transparent 50%, #ffff66 0%);}

.hdrA{
	padding: 15px 10px;
	font-size: 110%;
}
.hdrA::after{
	border: solid 30px transparent;
	border-top: solid 20px #2494a5;
	bottom: -49px;
}



header div{
	padding: 20px 0;
}
@keyframes bound{
0%,100%{transform:translateY(0px);}
10%{transform:translateY(-8px);}
20%{transform:translateY(-12px);}
30%{transform:translateY(-14px);}
40%{transform:translateY(-15px);}
50%{transform:translateY(-16px);}
60%{transform:translateY(-15px);}
70%{transform:translateY(-14px);}
80%{transform:translateY(-12px);}
90%{transform:translateY(-8px);}
}



.merit{
	padding: 40px 4%;
}
.merit section{
	padding-bottom: 20px;
	border-radius: 10px;
	margin-top: 20px;
}
.merit h3{
	padding: 5px 10px;
	font-size: 120%;
}
.merit span{
	font-size: 140%;
	margin: 20px auto;
}
.merit p{
	margin: 20px 20px 0;
}



.step{
	padding: 40px 4%;
}
.step h2{
	margin: 0 auto 20px;
}
.step li{
	display: block;
}
.step li > *{
	padding: 5px;
}
.step h3{
	width: 100%;
	font-size: 120%;
	border-radius: 10px 10px 0 0;
}
.step li p{
	width: 100%;
	padding: 15px 20px;
	text-align: center;
}



.contents{
	padding: 40px 4%;
}
.contents section{
	margin-top: 20px;
}
.contents h3{
	padding: 5px;
	font-size: 120%;
}
.contents h3 + p{
	width: 100%;
	font-size: 140%;
	line-height: 1.4;
	padding: 20px 10px;
}
.check{
	padding: 25px;
}
.check li{
	margin-bottom: 10px;
}
.contents ul + p{
	padding: 0 20px 30px;
	font-size: 80%;
	text-align: left;
	line-height: 1.6;
}



.tokuten h2{
	width: 90%;
}
.tokuten section::before,
.tokuten section::after{
	width: 65px;
	height: 65px;
	background-size: 65px;
}
.tokuten section::before{
	right: -4px;
	top: -4px;
}
.tokuten section::after{
	left: -4px;
	bottom: -4px;
}



.price{
	padding-bottom: 30px;
}
.price figure{
	margin: 40px auto 30px;
}
.price p{
	margin-bottom: 40px;
}



.message div{
	padding: 40px 4%;
}



.apply{
	padding-bottom: 20px;
}
.apply .normal{
	border: solid 2px #157766;
	margin: 40px auto 20px;
}
.apply ul{
	margin: 30px auto 0;
	padding: 20px;
}



footer{
	padding: 20px 1%;
	font-size: 65%;
}
footer a::after{
	margin: 0 5px;
}



}/* sp-end */



@media only screen and (min-width: 768px){
.sp{display:none;}
}
@media only screen and (max-width: 767px){
.pc{display:none;}
}