@charset "utf-8";
body {
	-webkit-text-size-adjust: 100%;
	font-family: "Noto Sans JP", sans-serif;
	font-size:min(1.8vw,18px);
	text-align:center;
	color:#3c3c3c;
	line-height:1.7;
	font-feature-settings: "palt";
}
@media screen and (max-width:768px){
	body {
		font-size:3.4vw;
	}
}

.en{
	font-family: "Oswald", sans-serif;
}

a {
	transition : opacity 0.4s;
	-webkit-transition : opacity 0.4s;
	opacity:1;
	outline:none;
	color:#5b5b5b;
}
a:hover {
	opacity: 0.8;
}

img{
	max-width:100%;
}

.only_smart,
.only_smart_i,
.only_smart_f{
	display:none !important;
}
@media screen and (max-width:768px){
	.only_pc{
		display:none !important;
	}
	.only_smart{
		display:block !important;
	}
	.only_smart_i{
		display:inline-block !important;
	}
	.only_smart_f{
		display: -webkit-flex!important;
		display: flex!important;
	}
}

#wrapper{
	overflow:hidden;
}


.inner{
	max-width:1000px;
	width:94%;
	margin:auto;
}

@media screen and (max-width:768px){
	.inner{
		width:90%;
	}
}


/* 色関係 */
.bg_green{
	color:#fff;
	background-color:#00b837;
}
.blue{
	color:#004099;
}
.bg_blue{
	color:#fff;
	background-color:#004099;
}


/* 書式 */
.text_left{
	text-align:left !important;
}
.text_right{
	text-align:right !important;
}
.text_center{
	text-align:center !important;
}

.bold{
	font-weight:bold;
}
.heavy{
	font-weight:900;
}

.blc{
	display:block;
}


/* .btn */
.btn{
	display:inline-block;
	width:17em;
	line-height:3;
	font-size:min(2.8vw,28px);
	font-weight:bold;
	position:relative;
}
.btn:after{
	content:'';
	display:block;
	width:0.8em;
	height:0.8em;
	border-top:1px solid;
	border-right:1px solid;
	position:absolute;
	right:1em;
	top:50%;
	transform:translateY(-50%) rotate(45deg);
}
.btn_list li:nth-child(n+2){
	margin-top:2.5%;
}

.pay_list{
	margin-top:min(7%,70px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	gap: 30px;
}
.pay_list li:first-child{
	width:48%;
}
.pay_list li:last-child{
	width:48%;
}
.pay_list li .btn{
	width:100%;
}


@media screen and (max-width:768px){
	.btn{
		font-size:3.8vw;
	}
	
	.pay_list{
		width:70%;
		margin-top:9%;
		flex-flow: column nowrap;
		align-items: center;
	}
	.pay_list li:first-child{
		width:100%;
	}
	.pay_list li:last-child{
		width:100%;
		margin-top:5%;
	}
}


/* header */
header{
	height:124px;
	line-height:124px;
	padding-left:20px;
	text-align:left;
}
header .head_logo{
	width:326px;
	display:inline-block;
}

@media screen and (max-width:1400px){
	header{
		height:90px;
		line-height:90px;
		padding-left:10px;
	}
	header .head_logo{
		width:236px;
	}
}

@media screen and (max-width:768px){
	header{
		height:50px;
		line-height:50px;
	}
	header .head_logo{
		width:136px;
	}
}


/* article */


/* #mv */
#mv .mv_bottom{
	margin-top:-16%;
	padding:6% 0 7%;
	background:url(../images/mv_bottom.webp)no-repeat center top;
	background-size:100% auto;
	background-size:cover;
	position:relative;
}
#mv .mv_bottom .mv_logo{
	width:28%;
}
#mv .mv_bottom h1{
	margin-top:0.8em;
	line-height:1.1;
	font-size:5.4vw;
	font-weight:900;
}
#mv .mv_bottom h1 .middle{
	font-size:3.7vw;
}
#mv .mv_bottom h1 .small{
	display:block;
	margin-top:0.5em;
	font-size:3.3vw;
}
#mv .mv_bottom .btn_list{
	margin-top:7%;
}
#mv .mv_bottom .btn_list .btn{
	font-size:1.75vw;
}

@media screen and (max-width:1024px){
	#mv .mv_bottom .btn_list .btn{
		font-size:2.8vw;
	}
}

@media screen and (max-width:768px){
	#mv .mv_bottom{
		padding-bottom:12%;
	}
	#mv .mv_bottom h1{
		margin-top:0.5em;
		font-size:7vw;
	}
	#mv .mv_bottom h1 .middle{
		font-size:5vw;
	}
	#mv .mv_bottom h1 .small{
		font-size:4.5vw;
	}
	#mv .mv_bottom .btn_list{
		margin-top:5%;
	}
	.btn_list li:nth-child(n+2){
		margin-top:1em;
	}
	#mv .mv_bottom .btn_list .btn{
		font-size:3.8vw;
	}
}


/* .cont */
.cont{
	padding:min(9vw,90px) 0 min(12vw,120px);
}
.cont .tit{
	line-height:1.8;
}
.cont .tit .jp{
	display:block;
	font-size:min(4.1vw,41px);
}
.cont .tit .en{
	display:block;
	font-size:min(1.6vw,16px);
	font-weight:normal;
	letter-spacing:0.08em;
	text-indent:0.08em;
	color:#d3d3d3;
}


@media screen and (max-width:768px){
	.cont{
		padding:12% 0;
	}
	.cont .tit .jp{
		font-size:8vw;
	}
	.cont .tit .en{
		font-size:3.2vw;
	}
}


/* #cont1 */
#cont1{
	background:url(../images/cont1_bg.webp)no-repeat center center;
	background-size:cover;
}
#cont1 h2{
	line-height:1.2;
	font-size:min(8.7vw,87px);
	font-weight:900;
}
#cont1 h2 .middle{
	font-size:min(5.9vw,59px);
}
#cont1 h2 .small{
	display:block;
	font-size:min(4.2vw,42px);
	font-weight:bold;
}
#cont1 .trouble{
	margin-top:min(8%,80px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont1 .trouble li{
	width:min(31%,301px);
}
#cont1 .trouble li figure figcaption{
	height:2.6em;
	margin:0.8em 0;
	line-height:1.3;
	font-size:min(2.6vw,26px);
	font-weight:bold;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}
#cont1 .trouble li p{
	padding-top:1em;
	border-top:1px dashed;
	font-weight:bold;
}

#cont1 .cause{
	margin-top:min(5%,50px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont1 .cause li figure figcaption{
	margin-bottom:0.5em;
	font-size:min(2vw,22px);
	white-space:nowrap;
}
#cont1 .cause li figure img{
	height:min(30vw,327px);
}

#cont1 .bottom{
	margin-top:min(5%,50px);
	font-size:min(3.4vw,37px);
	font-weight:900;
}
#cont1 .bottom .large{
	font-size:min(5.1vw,55px);
}
#cont1 .btn_list{
	margin-top:min(5%,50px);
}
#cont1 .btn_list li .btn{
	width:18.5em;
}

@media screen and (max-width:768px){
	#cont1 h2{
		font-size:9vw;
	}
	#cont1 h2 .middle{
		font-size:6.2vw;
	}
	#cont1 h2 .small{
		font-size:4.5vw;
	}
	#cont1 .trouble{
		width:80%;
		display: block;
	}
	#cont1 .trouble li{
		width:auto;
		margin-top:9%;
	}
	#cont1 .trouble li figure figcaption{
		height:auto;
		margin:0.3em 0;
		font-size:4.5vw;
		display: block;
	}
	#cont1 .trouble li p{
		padding-top:0.5em;
	}

	#cont1 .cause{
		margin-top:12%;
		display: block;
	}
	#cont1 .cause li:nth-child(n+2){
		margin-top:9%;
	}
	#cont1 .cause li figure figcaption{
		margin-bottom:0.3em;
		font-size:4vw;
	}
	#cont1 .cause li:first-child figure figcaption{
		margin-bottom:-0.5em;
	}
	#cont1 .cause li figure img{
		height:50vw;
	}

	#cont1 .bottom{
		line-height:1.5;
		margin-top:9%;
		font-size:4vw;
	}
	#cont1 .bottom .large{
		display:block;
		font-size:6vw;
	}
	#cont1 .btn_list{
		margin-top:9%;
	}
}


/* #cont2 */
#cont2 .tit{
	line-height:1.3;
}
#cont2 .tit .jp.large{
	font-size:min(6.8vw,68px);
	font-weight:900;
}
#cont2 .tit .jp .xlarge{
	line-height:1;
	font-size:min(9vw,90px);
}
#cont2 .tit .en{
	font-size:min(3vw,30px);
	opacity:0.3;
}

#cont2 .learn{
	margin-top:min(5%,50px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}
#cont2 .learn li{
	width:min(32%,317px);
	margin-top:3%;
}
#cont2 .learn li section{
	padding:9% 0 12%;
	color:#3c3c3c;
	background-color:#fff;
	border-radius:0 0 2em 2em;
}
#cont2 .learn li section h3{
	font-size:min(3vw,30px);
	line-height:1.1;
	height:2.2em;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}
#cont2 .learn li section p{
	margin-top:0.5em;
	font-weight:bold;
}
#cont2 .btn{
	margin-top:min(9%,90px);
}

@media screen and (max-width:768px){
	#cont2 .tit .jp.large{
		font-size:7.2vw;
	}
	#cont2 .tit .jp .xlarge{
		font-size:9.4vw;
	}
	#cont2 .tit .en{
		font-size:3.4vw;
	}
	#cont2 .learn{
		margin-top:3%;
	}
	#cont2 .learn li{
		width:48%;
		margin-top:5%;
	}
	#cont2 .learn li section{
		padding:7% 0 9%;
		border-radius:0 0 1.5em 1.5em;
	}
	#cont2 .learn li section h3{
		font-size:4vw;
	}
	#cont2 .learn li section p{
		margin-top:0.3em;
		font-size:3.2vw;
	}
	#cont2 .btn{
		margin-top:min(9%,90px);
	}
}


/* #cont3 */
#cont3 .fuki{
	margin-bottom:1em;
	line-height:1.5;
	display:inline-block;
	padding:0 0.5em;
	font-size:min(3.5vw,35px);
	color:#fff;
	background-color:#bc0048;
	position:relative;
}
#cont3 .fuki:after{
	content:'';
	display:block;
	width:0.6em;
	height:0.6em;
	background-color:#bc0048;
	clip-path:polygon(0 0, 100% 0, 50% 100%);
	position:absolute;
	top:calc(100% - 1px);
	left:50%;
	transform:translateX(-50%);
}
#cont3 h2{
	font-weight:900;
}
#cont3 h2 .small{
	display:block;
	margin-bottom:0.15em;
	font-size:min(4.5vw,45px);
}
#cont3 h2 .ssmall{
	font-size:min(3.1vw,31px);
}
#cont3 h2 .xlarge{
	display:inline-block;
	margin-right:0.15em;
	padding:0.3em;
	line-height:1.1;
	font-size:min(6.8vw,68px);
	position:relative;
}
#cont3 h2 .xlarge:before{
	content:'';
	display:block;
	width:1.5em;
	height:1.5em;
	border-top:1px solid;
	border-left:1px solid;
	position:absolute;
	left:0;
	top:0;
}
#cont3 h2 .xlarge:after{
	content:'';
	display:block;
	width:1.5em;
	height:1.5em;
	border-bottom:1px solid;
	border-right:1px solid;
	position:absolute;
	right:0;
	bottom:0;
}
#cont3 h2 .middle{
	font-size:min(5.5vw,50px);
}
#cont3 h2 .large{
	display:block;
	font-size:min(6.3vw,63px);
}
#cont3 .fig1{
	margin-top:min(1.5vw,15px);
}
#cont3 .detail{
	margin-top:min(3vw,30px);
}
#cont3 .detail > dt{
	font-size:min(3.4vw,34px);
	background-color:#ccd9eb;
}
#cont3 .detail > dd{
	line-height:1.4;
	padding:1em 0 1.8em;
	font-size:min(2.7vw,27px);
}
#cont3 .detail > dd ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}
#cont3 .detail > dd ul li{
	margin:0 0.5em;
}
#cont3 .detail > dd ul li:before{
	content:'';
	display:inline-block;
	width:0.8em;
	height:0.8em;
	background-color:#004099;
	border-radius:50%;
}
#cont3 .detail > dd ul .w100{
	width:100%;
}
#cont3 .detail > dd .num_list{
	width:90%;
	margin:auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	counter-reset: listnum;
}
#cont3 .detail > dd .num_list div{
	width:48%;
	padding-left:1.2em;
	text-align:left;
	position:relative;
}
#cont3 .detail > dd .num_list div:before{
	counter-increment: listnum;
	content: counter(listnum); 
	display:block;
	width:1.2em;
	height:1.2em;
	line-height:1.3em;
	font-family:arial;
	font-size:min(2.2vw,22px);
	text-align:center;
	color:#fff;
	background-color:#004099;
	border-radius:50%;
	position:absolute;
	left:0;
	top:0.25em;
}
#cont3 .detail > dd .num_list div:nth-child(n+3){
	margin-top:1em;
}
#cont3 .detail > dd .num_list div dt{
	margin-bottom:0.3em;
}
#cont3 .detail > dd .num_list div dd{
	padding-left:0.5em;
	text-indent:-0.5em;
	font-size:min(2.2vw,22px);
	font-weight:500;
}
#cont3 .btn_list{
	margin-top:min(9%,90px);
}

@media screen and (max-width:768px){
	#cont3 .fuki{
		font-size:4vw;
	}
	#cont3 h2 .small{
		font-size:5vw;
	}
	#cont3 h2 .ssmall{
		font-size:3.4vw;
	}
	#cont3 h2 .xlarge{
		font-size:7.2vw;
	}
	#cont3 h2 .middle{
		font-size:6vw;
	}
	#cont3 h2 .large{
		font-size:6.8vw;
	}
	#cont3 .detail > dt{
		font-size:4.2vw;
	}
	#cont3 .detail > dd{
		font-size:3.8vw;
	}
	#cont3 .detail > dd ul{
		display:block;
		padding:0 5%;
		text-align:left;
	}
	#cont3 .detail > dd .num_list{
		display:block;
	}
	#cont3 .detail > dd .num_list div{
		width:auto;
	}
	#cont3 .detail > dd .num_list div:before{
		font-size:3.4vw;
	}
	#cont3 .detail > dd .num_list div:nth-child(n+2){
		margin-top:1em;
	}
	#cont3 .detail > dd .num_list div dd{
		font-size:3.6vw;
	}
}


/* #cont4 */
#cont4{
	background-color:#f3f4f4;
}
#cont4 .step{
	margin-top:min(9%,90px);
}
#cont4 .step li{
	margin-bottom:2em;
	aspect-ratio:1000 / 140;
	font-weight:bold;
	background-color:#fff;
	border:3px solid #004099;
	border-radius:1em;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	position:relative;
}
#cont4 .step li:nth-child(3){
	margin-bottom:3em;
}
#cont4 .step li:after{
	content:'';
	display:block;
	width:2em;
	height:1em;
	background-color:#004099;
	clip-path:polygon(0 0, 100% 0, 50% 100%);
	position:absolute;
	top:calc(100% + 0.7em);
	left:50%;
	transform:translateX(-50%);
}
#cont4 .step li:last-child{
	margin-bottom:0;
}
#cont4 .step li:last-child:after{
	content:none;
}
#cont4 .step li .num{
	width:2.2em;
	height:2.2em;
	line-height:1.1;
	border-radius:50%;
	font-size:min(4.5vw,45px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	-webkit-flex-direction: column;
	flex-direction: column;
	position:absolute;
	left:0.3em;
	top:50%;
	transform:translateY(-50%);
}
#cont4 .step li .num:before{
	content:'STEP';
	font-size:min(1.8vw,18px);
}
#cont4 .step li p{
	line-height:1.2;
	font-size:min(3vw,30px);
}
#cont4 .step li p .small{
	display:block;
	font-size:min(1.8vw,18px);
}
#cont4 .step li:last-child{
	padding-top:0.5em;
}
#cont4 .step li .top{
	display:inline-block;
	padding:0 0.5em;
	font-size:min(2.6vw,26px);
	border-radius:100px;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-50%);
}
#cont4 .btn{
	margin-top:min(9%,90px);
}

@media screen and (max-width:768px){
	#cont4 .step li{
		aspect-ratio:1000 / 220;
		border:2px solid #004099;
		border-radius:0.5em;
	}
	#cont4 .step li:nth-child(3){
		margin-bottom:3em;
	}
	#cont4 .step li .num{
		font-size:5vw;
	}
	#cont4 .step li .num:before{
		content:'STEP';
		font-size:2.2vw;
	}
	#cont4 .step li p{
		font-size:4vw;
	}
	#cont4 .step li p .small{
		font-size:2.2vw;
	}
	#cont4 .step li .top{
		font-size:3.2vw;
	}
}


/* #cont5 */
#cont5 .cont_wrapper{
	margin-top:min(9%,90px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont5 .cont_wrapper .fig1{
	width:min(28%,286px);
}
#cont5 .cont_wrapper .fig1 figcaption{
	margin-top:0.5em;
}
#cont5 .cont_wrapper .fig1 figcaption .large{
	font-size:min(2vw,20px);
}
#cont5 .cont_wrapper .fig1 figcaption .small{
	display:block;
	line-height:1.3;
	margin-top:0.5em;
	font-size:min(1.4vw,16px);
	text-align:left;
	white-space:nowrap;
}
#cont5 .cont_wrapper section{
	width:min(67%,673px);
}
#cont5 .cont_wrapper section h3{
	font-size:min(4vw,42px);
	white-space:nowrap;
}
#cont5 .cont_wrapper section .flex{
	margin-top:1em;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont5 .cont_wrapper section .flex p{
	width:63%;
	font-weight:500;
	text-align:left;
}
#cont5 .cont_wrapper section .flex .fig2{
	width:32%;
}
#cont5 .cont_wrapper section .flex .fig2 figcaption{
	margin-top:0.5em;
	font-size:min(1.6vw,16px);
}
#cont5 .cont_wrapper section .flex .fig2 figcaption a{
	display:block;
	width:80%;
	line-height:2.4;
	margin:0.5em auto 0;
	color:#fff;
	background-color:#ee8534;
}
#cont5 .btn{
	margin-top:min(7%,70px);
	cursor:pointer;
}

@media screen and (max-width:768px){
	#cont5 .cont_wrapper{
		display: block;
	}
	#cont5 .cont_wrapper .fig1{
		width:70%;
		margin:auto;
	}
	#cont5 .cont_wrapper .fig1 figcaption{
		margin-top:0.5em;
	}
	#cont5 .cont_wrapper .fig1 figcaption .large{
		font-size:4vw;
	}
	#cont5 .cont_wrapper .fig1 figcaption .small{
		font-size:3.2vw;
	}
	#cont5 .cont_wrapper section{
		width:auto;
		margin-top:9%;
	}
	#cont5 .cont_wrapper section h3{
		font-size:5.6vw;
	}
	#cont5 .cont_wrapper section .flex{
		margin-top:1em;
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: space-between;
		justify-content: space-between;
	}
	#cont5 .cont_wrapper section .flex p{
		width:63%;
	}
	#cont5 .cont_wrapper section .flex .fig2{
		width:32%;
	}
	#cont5 .cont_wrapper section .flex .fig2 figcaption{
		font-size:3.4vw;
	}
	#cont5 .cont_wrapper section .flex .fig2 figcaption a{
		width:100%;
	}
}


/* #overlay */
html.overlay {
	overflow: hidden;
	height: 100%;
}
#overlay {
	position: fixed;
	width: 100%;
	height: 100dvh;
	padding:50px 5%;
	top: 0;
	left: 0;
	z-index: 102;
	background-color: rgba(0, 0, 0, 0.5);
	overflow:auto;
	display: none;
}
#overlay .sec{
	max-width:500px;
	width:90%;
	margin:auto;
	background-color:#fff;
}
#overlay .sec .close_wrapper{
	line-height:1;
	text-align:right;
	margin-right:0.3em;
}
#overlay .sec .close{
	display:inline-block;
	width:1em;
	font-size:32px;
	font-weight:normal;
	cursor:pointer;
}
#overlay .sec .profile{
	padding:0 5% 9%;
}
#overlay .sec .profile > dt{
	margin-top:0.5em;
}
#overlay .sec .profile > dd{
	margin-top:0.5em;
	font-size:min(1.6vw,16px);
	text-align:left;
}
#overlay .sec .profile > dd .history1 dt,
#overlay .sec .profile > dd .history2 dt{
	float:left;
}
#overlay .sec .profile > dd .history1 dd{
	padding-left:4em;
}
#overlay .sec .profile > dd .list{
	padding-left:1.5em;
}
#overlay .sec .profile > dd .list li{
	list-style:disc;
}
#overlay .sec .profile > dd .history2 dd{
	padding-left:6em;
}

@media screen and (max-width:750px){
	#overlay {
		padding:25px 0;
	}
	#overlay .sec{
		font-size:3.6vw;
		max-width:100%;
		width:90%;
	}
	#overlay .sec .close{
		font-size:6vw;
	}
	#overlay .sec .profile > dd{
		font-size:3.2vw;
	}
}


/* #cont6 */
#cont6{
	background-color:#fdc648;
}
#cont6 .tit .en{
	color:#fff;
}
#cont6 .recommend{
	margin-top:min(9%,90px);
}
#cont6 .recommend li{
	padding:min(4%,40px) min(3%,30px);
	background-color:#fff;
	border-radius:1em;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont6 .recommend li:nth-child(n+2){
	margin-top:min(5%,50px);
}
#cont6 .recommend li figure{
	width:min(20%,183px);
}
#cont6 .recommend li section{
	width:min(77%,720px);
	text-align:left;
}
#cont6 .recommend li section h3 .large{
	font-size:min(2.4vw,24px);
}
#cont6 .recommend li section h3 .small{
	margin-left:0.5em;
	vertical-align:0.1em;
}
#cont6 .recommend li section p{
	margin-top:0.5em;
	font-weight:500;
}
#cont6 .recommend li section .more_link{
	display:inline-block;
	margin-top:1em;
	border-bottom:1px solid;
	cursor:pointer;
}
#cont6 .recommend li section .more_voice{
	margin-top:1em;
	display:none;
}

@media screen and (max-width:768px){
	#cont6 .recommend li{
		border-radius:0.5em;
	}
	#cont6 .recommend li section h3 .large{
		font-size:4vw;
	}
	#cont6 .recommend li section p{
		margin-top:0.3em;
		font-weight:500;
	}
	#cont6 .recommend li section .more_link{
		margin-top:0.5em;
	}
}


/* #cont7 */
#cont7 h3{
	margin-top:min(5%,50px);
}
#cont7 h3 .large{
	font-size:min(10vw,100px);
	color:#fdc648;
	position:relative;
}
#cont7 h3 .large:before{
	content:'';
	display:block;
	width:1.5em;
	height:1em;
	background:url(../images/cont7_tit.png)no-repeat center top;
	background-size:100% auto;
	position:absolute;
	top:0;
	left:50%;
	transform:translateX(-50%);
}
#cont7 .flow{
	margin-top:min(5%,50px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont7 .flow li{
	width:min(31.5%,315px);
	aspect-ratio:315 / 268;
	border:3px solid #004099;
	border-radius:2em;
	font-weight:bold;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	position:relative;
}
#cont7 .flow li .num{
	width:2.2em;
	height:2.2em;
	line-height:1.1;
	border-radius:50%;
	font-size:min(4.5vw,45px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	-webkit-flex-direction: column;
	flex-direction: column;
	position:absolute;
	left:50%;
	top:0;
	transform:translate(-50%,-50%);
}
#cont7 .flow li .num:before{
	content:'STEP';
	font-size:min(1.8vw,18px);
}
#cont7 .flow li p{
	line-height:1.2;
	margin-top:0.7em;
	font-size:min(3vw,30px);
}
#cont7 .price{
	display:inline-block;
	margin-top:min(3%,30px);
	font-size:min(5.6vw,56px);
	font-weight:bold;
}
#cont7 .price .large{
	line-height:1;
	margin:0 0.15em;
	font-size:min(9.3vw,93px);
}
#cont7 .price .small{
	font-size:min(3vw,30px);
}
#cont7 .price .period{
	line-height:2.2;
	display:block;
	border-radius:100px;
}
#cont7 .start-date{
	color: red;
	line-height:1.2;
	margin-top:0.5em;
	font-size:min(9.3vw,93px);
	font-weight: 700;
}

@media screen and (max-width:768px){
	#cont7 h3 .jp{
		font-size:7vw;
	}
	#cont7 h3 .large{
		font-size:16vw;
	}
	#cont7 .flow{
		margin-top:min(5%,50px);
		display: block;
	}
	#cont7 .flow li{
		width:auto;
		height:7em;
		margin-top:9%;
		aspect-ratio:auto;
		border:2px solid #004099;
		border-radius:1em;
	}
	#cont7 .flow li .num{
		font-size:5vw;
	}
	#cont7 .flow li .num:before{
		font-size:2.2vw;
	}
	#cont7 .flow li p{
		font-size:4.2vw;
	}
	#cont7 .flow li p br{
		display:none;
	}
	#cont7 .price{
		margin-top:5%;
		font-size:5.8vw;
	}
	#cont7 .price .large{
		font-size:9.8vw;
	}
	#cont7 .price .small{
		font-size:3.2vw;
	}
	#cont7 .price .period{
		font-size:4vw;
		line-height:2.2;
		display:block;
		border-radius:100px;
	}
	#cont7 .start-date{
		font-size:9.8vw;
	}
}


/* #cont8 */
#cont8{
	padding:min(5vw,50px) 0 min(6vw,60px);
	background:url(../images/cont8_bg.webp)no-repeat center center;
	background-size:cover;
}
#cont8 .tit .en{
	margin-top:-0.5em;
	color:#fff;
	font-size:min(2.8vw,28px);
}
#cont8 .special{
	margin-top:min(5%,50px);
}
#cont8 .special li{
	aspect-ratio:1000 / 187;
	margin-top:min(1.5%,15px);
	font-size:min(3.5vw,37px);
	font-weight:bold;
	background:url(../images/cont8_list.png)no-repeat center center;
	background-size:100% 100%;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

@media screen and (max-width:768px){
	#cont8 .tit .en{
		font-size:3.8vw;
	}
	#cont8 .special li{
		line-height:1.3;
		aspect-ratio:1000 / 320;
		font-size:4vw;
	}
}


/* #cont9 */
#cont9 .faq{
	margin-top:min(5%,50px);
}
#cont9 .faq div{
	font-size:min(3.2vw,32px);
	font-weight:bold;
}
#cont9 .faq div dt{
	margin-top:0.5em;
	padding:0.5em 2.4em;
	position:relative;
}
#cont9 .faq div dt:before{
	content:'Q';
	display:block;
	width:1.6em;
	height:1.6em;
	line-height:1.4em;
	color:#004099;
	background-color:#fff;
	border-radius:50%;
	position:absolute;
	left:0.4em;
	cursor:pointer;
}
#cont9 .faq div dt:after{
	content:'＋';
	display:block;
	font-size:min(3.8vw,38px);
	font-weight:900;
	width:1.2em;
	height:1.2em;
	line-height:1em;
	position:absolute;
	right:0.4em;
	top:0.5em;
	cursor: pointer;
}
#cont9 .faq div dt.close:after{
	content:'－';
}
#cont9 .faq div dt p{
	padding:0.1em 0;
	font-size:min(2.6vw,26px);
	text-align:left;
}

#cont9 .faq div dd{
	padding:0.5em 0.4em 0.8em 2.4em;
	position:relative;
	display:none;
}
#cont9 .faq div dd:before{
	content:'A';
	display:block;
	width:1.6em;
	height:1.6em;
	line-height:1.4em;
	color:#fff;
	background-color:#004099;
	border-radius:50%;
	position:absolute;
	left:0.4em;
}
#cont9 .faq div dd p{
	padding:0.7em 0;
	font-size:min(1.6vw,16px);
	font-weight:500;
	text-align:left;
}

@media screen and (max-width:768px){
	#cont9 .faq div{
		font-size:5vw;
	}
	#cont9 .faq div dt{
		margin-top:0.5em;
		padding:0.5em 2.4em;
		position:relative;
	}
	#cont9 .faq div dt:after{
		content:'＋';
		display:block;
		font-size:6vw;
		font-weight:900;
		width:1.2em;
		height:1.2em;
		line-height:1em;
		position:absolute;
		right:0.4em;
		top:0.5em;
	}
	#cont9 .faq div dt p{
		padding:0.1em 0;
		font-size:4.2vw;
	}

	#cont9 .faq div dd{
		padding:0.5em 0.4em 0.8em 2.4em;
		position:relative;
		display:none;
	}
	#cont9 .faq div dd p{
		padding:0.3em 0;
		font-size:3.6vw;
	}
}


/* #cont10 */
#cont10{
	aspect-ratio:3200 / 1282;
	background:url(../images/cont10_bg.webp)no-repeat center center;
	background-size:100% auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}
#cont10 p .large{
	line-height:1.2;
	display:block;
	font-size:4.7vw;
	font-weight:900;
}
#cont10 p .middle{
	font-size:3.6vw;
}
#cont10 p .small{
	margin-top:0.5em;
	display:block;
	font-size:1.6vw;
	font-weight:bold;
}

@media screen and (max-width:768px){
	#cont10{
		aspect-ratio:2800 / 1282;
		background:url(../images/cont10_bg_s.webp)no-repeat center center;
		background-size:100% auto;
	}
	#cont10 p .large{
		font-size:5.6vw;
	}
	#cont10 p .middle{
		font-size:4.4vw;
	}
	#cont10 p .small{
		font-size:2.5vw;
	}
}

/* footer */
.bottom{
	padding:min(7%,70px) 0;
}

@media screen and (max-width:768px){
	.bottom{
		padding:9% 0;
	}
}

footer {
	background-color: #fff;
	border-top: 1px solid #3c3c3c;
	height: 124px;
	padding-left: 20px;
	padding-right: 20px;
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: center;
}

footer .head_logo{
	width:236px;
	display:inline-block;
}

@media screen and (max-width:1400px){
	footer{
		height: 90px;
		padding-left:10px;
	}
	footer .head_logo{
		width:236px;
	}
}

@media screen and (max-width:768px){
	footer{
		height:50px;
	}
	footer .head_logo{
		width:136px;
	}
}

footer .links li a {
	text-decoration: underline;
	font-size: 0.8em;
}

@media screen and (max-width:768px){
	footer .links li a {
		font-size: 0.6em;
	}
}

/* top_top */
#topbtn{
	width:50px;
	height:50px;
	line-height:45px;
	font-size:21px;
	border-radius:50%;
	color:#fff;
	background-color:rgba(0,0,0,0.5);
	position:fixed;
	z-index:99;
	right:20px;
	bottom:-150px;
	-webkit-transition: bottom 0.8s;
	-moz-transition: bottom 0.8s;
	-ms-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
@media screen and (max-width:768px){
	#topbtn{
		width:40px;
		height:40px;
		line-height:38px;
		font-size:18px;
		right:15px;
	}
}




/* fadein */
.fadein0 {
	opacity : 0;
	-webkit-transition-property: opacity;
	transition-property : opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein {
	opacity : 0;
	-webkit-transform : translate(0, 70px);
	transform : translate(0, 70px);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_l {
	opacity : 0;
	-webkit-transform : translate(-100px, 0);
	transform : translate(-100px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_r {
	opacity : 0;
	-webkit-transform : translate(100px, 0);
	transform : translate(100px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.delay1 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.2s;
	transition-delay : 0.2s;
}
.delay2 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.4s;
	transition-delay : 0.4s;
}
.delay3 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.6s;
	transition-delay : 0.6s;
}
.delay4 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.8s;
	transition-delay : 0.8s;
}
.delay5 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 1.0s;
	transition-delay : 1.0s;
}
.delay6 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 1.2s;
	transition-delay : 1.2s;
}

.fadein0.scrollin,
.fadein.scrollin,
.fadein_l.scrollin,
.fadein_r.scrollin{
	opacity : 1;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
}

.privacy {
	text-align: left;
	max-width: 800px;
	margin: 40px auto;
	padding: 0 10px;
}
.privacy p {
	margin-bottom: 20px;
}
.comp {
	max-width: 800px;
	margin: 40px auto;
	padding: 0 10px;
}
.comp h2 {
	margin-bottom: 10px;
}
.comp p {
	margin-bottom: 20px;
}
