@charset "utf-8";
html{
	-webkit-text-size-adjust: 100%;
}
body {
	font-family: "Noto Sans JP", sans-serif;
	font-size:min(1.6vw,16px);
	text-align:center;
	color:#222;
	line-height:2.1;
	font-feature-settings: "palt";
}

@media screen and (max-width:750px){
	body {
		font-size:3.7vw;
		line-height:1.7;
	}
}


a {
	color:#222;
	transition : opacity 0.4s;
	-webkit-transition : opacity 0.4s;
	opacity:1;
	outline:none;
}
a:hover {
	opacity: 0.7;
}

@media screen and (max-width:750px){
	a:hover {
		opacity: 1;
	}
}

img{
	max-width:100%;
	vertical-align:bottom;
}

.only_smart,
.only_smart_i,
.only_smart_f{
	display:none !important;
}

@media screen and (max-width:750px){
	.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{
}
.inner{
	max-width:980px;
	width:90%;
	margin:auto;
}

@media screen and (max-width:750px){
	.inner{
		width:90%;
	}
}


/* 色関係 */
.blue{
	color:#0749b9;
}
.bg_blue{
	color:#fff;
	background-color:#0749b9;
}
.bg_blue_l{
	color:#fff;
	background:linear-gradient(90deg, #022d8c, #156ff6);
}
.bg_blue_r{
	color:#fff;
	background:linear-gradient(90deg, #0091ff, #0429c7);
}

.bg_blue_r2{
	color:#fff;
	background:linear-gradient(90deg, #156ff6, #022d8c);
}
 
.bg_blue_l2{
	color:#fff;
	background:linear-gradient(90deg, #0645b3, #0b56cd);
}
.bg_gray{
	background:linear-gradient(90deg, #eef6f9, #f5eef9);
}
.white{
	color:#fff;
}
.bg_white{
	background-color:#fff;
}


/* 書式 */
.text_left{
	text-align:left;
}
.text_right{
	text-align:right;
}
.bold{
	font-weight:bold;
}
.heavy{
	font-weight:900;
}
.blc{
	display:block;
}


/* .btn */
.btn{
	line-height:3.4;
	letter-spacing:0.04em;
	display:inline-block;
	padding:0 1em 0 2em;
	font-weight:bold;
	color:#fff;
	border-radius:100px;
	box-shadow:0 5px 16px rgba(133,182,255,0.5);
}
.btn:after{
	content:'';
	display:inline-block;
	vertical-align:0.25em;
	width:1em;
	height:0.25em;
	margin-left:0.5em;
	transform: skewX(45deg);
	border-right:2px solid #fff;
	border-bottom:1px solid #fff;
}

@media screen and (max-width:750px){
	.btn{
		line-height:3.2;
		padding:0 0.5em 0 0;
		position:relative;
	}
	.btn:after{
		position:absolute;
		right:1em;
		top:50%;
		transform: skewX(45deg) translateY(-50%);
	}
}


/* header */
header{
	width:100%;
	height:100px;
	padding:0 30px;
	background-color:#fff;
	box-shadow:0 15px 15px rgba(0,0,0,0.1);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	position:fixed;
	z-index:100;
}
header .head_logo{
	line-height:1;
	width:170px;
	display:block;
}
header .head_nav ul{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
}
header .head_nav ul li{
	font-size:15px;
}
header .head_nav ul li:nth-child(n+2){
	margin-left:3.5em;
}
header .head_nav ul li a{
	font-weight:bold;
	letter-spacing:0.04em;
}
header .head_nav ul li .btn{
	font-weight:500;
}

@media screen and (max-width:1340px){
	header{
		width:100%;
		height:100px;
		padding:0 15px;
	}
	header .head_nav ul li:nth-child(n+2){
		margin-left:1em;
	}
}

@media screen and (max-width:1024px){
	header{
		height:70px;
	}
	header .head_logo{
		width:140px;
	}
	header .head_nav{
		width:100%;
		height:calc(100vh - 70px);
		padding-top:50px;
		display:none;
		border-top:1px solid #ccc;
		position:fixed;
		top:70px;
		left:0;
		background-color:#fff;
	}
	header .head_nav ul{
		display:block;
	}
	header .head_nav ul li:nth-child(n+2){
		margin:1em 0 0;
	}
	header .head_nav ul li .btn{
		width:16em;
	}
}

@media screen and (max-width:750px){
	header{
		height:50px;
		box-shadow:0 3px 7px rgba(0,0,0,0.1);
	}
	header .head_logo{
		width:110px;
	}
	header .head_nav{
		height:calc(100vh - 50px);
		top:50px;
	}
}


/* #btnmenu */
#btnmenu{
	width:50px;
	height:50px;
	margin:0 0 0 1em;
	padding:0;
	position:relative;
	z-index:101;
	cursor:pointer;
	display:none;
}
@media screen and (max-width:1024px){
	#btnmenu{
		display:block;
	}
}
#btnmenu span{
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 30px;
	height: 4px;
	border-radius:0px;
	margin: -2px 0 0 -20px;
	background: #0749b9;
	-webkit-transition: .2s;
	transition: .2s;
}
#btnmenu span:before,
#btnmenu span:after{
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	height: 4px;
	background: #0749b9;
	border-radius:0px;
	-webkit-transition: .3s;
	transition: .3s;
}

#btnmenu span:before{
	width: 40px;
	margin-top: -15px;
}

#btnmenu span:after{
	width: 20px;
	margin-top: 12px;
}
#btnmenu.close span{
	width:50px;
	height:50px;
	margin-top:-25px;
	margin-left:-35px;
	box-shadow:none;
	background-color:transparent;
	border-radius:0;
}

#btnmenu.close span:before,
#btnmenu.close span:after{
	margin-top: 0;
	background-color:#0749b9;
}

#btnmenu.close span:before{
	width: 40px;
	height: 4px;
	margin: -3px 0 0 15px;
	border-radius:0px;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
}
#btnmenu.close span:after{
	width: 40px;
	height: 4px;
	margin: -3px 0 0 15px;
	border-radius:0px;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}

@media screen and (max-width:750px){
	#btnmenu{
		width:40px;
		height:40px;
		margin:0 0 0 0.5em;
	}
	#btnmenu span{
		width: 20px;
		height: 3px;
		border-radius:0px;
		margin: -2px 0 0 -15px;
	}
	#btnmenu span:before,
	#btnmenu span:after{
		height: 3px;
	}

	#btnmenu span:before{
		width: 30px;
		margin-top: -12px;
	}

	#btnmenu span:after{
		width: 12px;
		margin-top: 8px;
	}
	#btnmenu.close span{
		width:40px;
		height:40px;
		margin-top:-10px;
		margin-left:-30px;
	}
	#btnmenu.close span:before{
		width: 30px;
		height: 3px;
		margin: -12px 0 0 15px;
		border-radius:0px;
	}
	#btnmenu.close span:after{
		width: 30px;
		height: 3px;
		margin: -12px 0 0 15px;
	}
}



/* article */
article{
	padding-top:100px;
}

@media screen and (max-width:1024px){
	article{
		padding-top:70px;
	}
}

@media screen and (max-width:750px){
	article{
		padding-top:50px;
	}
}



/* #mv */
#mv{
	padding:3% 10% 4%;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	overflow:hidden;
}
#mv .sec{
	width:54%;
	text-align:left;
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: flex-start;
	align-items: flex-start;
	-webkit-flex-direction: column;
	flex-direction: column;
}
#mv .sec .top{
	margin-bottom:1em;
	font-size:1.1vw;
	font-weight:500;
	letter-spacing:0.08em;
}
#mv .sec h1{
	line-height:1.4;
}
#mv .sec h1 .small{
	display:block;
	font-size:1.8vw;
	letter-spacing:0.14em;
}
#mv .sec h1 .middle{
	display:block;
	font-size:2.6vw;
	letter-spacing:0.14em;
}
#mv .sec h1 .large{
	display:block;
	font-size:3.7vw;
	letter-spacing:0.14em;
}
#mv .sec .lead{
	margin-top:1em;
	font-size:0.9vw;
	letter-spacing:0.08em;
}
#mv .sec .features{
	margin-top:3%;
	display: -webkit-flex;
	display: flex;
}
#mv .sec .features li{
	width:8vw;
	margin-right:1vw;
}
#mv .sec .btn{
	margin-top:5%;
	font-size:1.25vw;
	letter-spacing:0.08em;
	background:linear-gradient(90deg, #2ca4ff, #6887ff);
	box-shadow:none;
	-webkit-order: 1;
	order: 1;
}
#mv .fig{
	width:52%;
	margin-left:-6%;
	transform:translateX(2%);
}

@media screen and (max-width:750px){
	#mv{
		padding:5% 3% 7%;
		display:block;
	}
	#mv .sec{
		width:auto;
		text-align:center;
		display: block;
	}
	#mv .sec .top{
		margin-bottom:1em;
		font-size:3.3vw;
		letter-spacing:0.08em;
		padding-left:0.08em;
	}
	#mv .sec h1{
		line-height:1.6;
	}
	#mv .sec h1 .small{
		font-size:4.6vw;
		letter-spacing:0.14em;
		padding-left:0.14em;
	}
	#mv .sec h1 .middle{
		font-size:5.8vw;
		letter-spacing:0.14em;
		padding-left:0.14em;
	}
	#mv .sec h1 .large{
		line-height:1.2;
		font-size:8.6vw;
		letter-spacing:0.14em;
		padding-left:0.14em;
	}
	#mv .sec .lead{
		margin-top:1em;
		font-size:3.4vw;
		letter-spacing:0.08em;
		text-align:left;
	}
	#mv .sec .features{
		margin-top:7%;
		-webkit-justify-content: center;
    justify-content: center;
	}
	#mv .sec .features li{
		width:24vw;
		margin:0 1%;
	}
	#mv .sec .btn{
		width:100%;
		margin-top:5%;
		font-size:5.3vw;
		background:linear-gradient(90deg, #2ca4ff, #6887ff);
	}
	#mv .fig{
		width:auto;
		margin:5% 3%;
		transform:none;
	}
}


/* .cta */
.cta{
	padding:min(5%,50px) 0;
	background:url(../img/cta_bg.png)no-repeat center center;
	background-size:cover;
}
.cta h2{
	line-height:1.6;
	font-size:min(2.7vw,27px);
	letter-spacing:0.1em;
	padding-left:0.1em;
}
.cta p{
	margin-top:min(2%,20px);
	font-size:min(1.5vw,15px);
	font-weight:bold;
	letter-spacing:0.06em;
	text-indent:0.06em;
}
.cta .btn{
	line-height:3;
	margin-top:min(1%,10px);
	padding-left:4em;
	font-size:min(2.4vw,24px);
	letter-spacing:0.08em;
}
.btn:after{
	margin-left:1em;
}

@media screen and (max-width:750px){
	.cta{
		padding:12% 0;
		background:url(../img/cta_bg_s.png)no-repeat center center;
		background-size:cover;
	}
	.cta h2{
		line-height:1.5;
		font-size:5vw;
	}
	.cta h2 .large{
		display:block;
		font-size:6.5vw;
	}
	.cta p{
		margin-top:3%;
		font-size:3.7vw;
	}
	.cta .btn{
		width:90%;
		line-height:3.2;
		margin:3% auto 0;
		padding:0 0.5em 0 0;
		font-size:4.6vw;
	}
	.btn:after{
		margin-left:0;
		right:0.7em;
	}
}


/* .cont */
.cont{
	padding:min(9%,90px) 0 min(12%,120px);
}
.cont .tit{
	line-height:1.7;
	font-size:min(4vw,40px);
	letter-spacing:0.14em;
	padding-left:0.14em;
}
.cont .tit + .lead{
	margin-top:min(3%,30px);
	letter-spacing:0.06em;
	padding-left:0.06em;
}

.cont .arrow{
	width:3.5em;
	display:inline-block;
	margin-top:min(3%,30px);
}


@media screen and (max-width:750px){
	.cont{
		padding:15% 0 18%;
	}
	.cont .tit{
		line-height:1.5;
		font-size:6vw;
	}
	.cont .tit + .lead{
		margin-top:5%;
		padding:0 5%;
		text-align:left;
	}
	.cont .arrow{
		width:2em;
		margin-top:5%;
	}
}


/* #cont1 */
#cont1 {
}
#cont1 .cont_wrapper{
	margin-top:min(3%,30px);
	padding:min(6%,60px) 0 min(4%,40px);
	background:url(../img/cont1_bg.png)no-repeat center center;
	background-size:auto 100%;
}
#cont1 .cont_wrapper div{
	background-color:#fff;
	padding:0 0 min(5%,50px);
	border-radius:1em;
	box-shadow:0 0 40px rgba(0,58,145,0.15);
}
#cont1 .cont_wrapper div:last-child{
	margin-top:min(10%,100px);
}
#cont1 .cont_wrapper div dt{
	width:48%;
	line-height:2.8;
	margin:auto;
	font-size:min(2.2vw,22px);
	font-weight:bold;
	position:relative;
	border-radius:100px;
	letter-spacing:0.06em;
	text-indent:0.06em;
	transform:translateY(-70%);
}
#cont1 .cont_wrapper div dt:after{
	content:'';
	display:block;
	width:1.2em;
	height:0.6em;
	background-color:#0749b9;
	clip-path:polygon(0 0, 100% 0, 50% 100%);
	position:absolute;
	left:50%;
	top:calc(100% - 1px);
	transform:translateX(-50%);
}
#cont1 .cont_wrapper div dd p{
	padding:0 min(7%,70px);
	text-align:left;
	letter-spacing:0.04em;
}
#cont1 .cont_wrapper div dd figure{
	margin-top:min(5%,50px);
}
#cont1 .bottom{
	margin-top:min(3%,30px);
	padding:min(1.5%,15px) min(1.5%,15px) min(3%,30px) min(15%,150px);
	border:2px solid #0749b9;
	border-radius:1em;
	position:relative;
}
#cont1 .arrow{
	margin-top:min(1.5%,15px);
}
#cont1 .bottom img{
	width:min(12%,110px);
	position:absolute;
	left:5%;
	bottom:5%;
}

#cont1 .bottom p{
	font-size:min(2vw,22px);
	letter-spacing:0.08em;
}

@media screen and (max-width:750px){
	#cont1 .cont_wrapper{
		margin-top:12%;
		padding:0;
		background-image:none;
	}
	#cont1 .cont_wrapper div{
		background-color:#fff;
		padding:0 5% 5%;
		border-radius:0.5em;
		box-shadow:0 0 20px rgba(0,58,145,0.15);
	}
	#cont1 .cont_wrapper div:last-child{
		margin-top:18%;
	}
	#cont1 .cont_wrapper div dt{
		width:auto;
		line-height:2.5;
		font-size:4.2vw;
	}
	#cont1 .cont_wrapper div dd p{
		padding:0;
	}
	#cont1 .cont_wrapper div dd figure{
		margin-top:5%;
	}
	#cont1 .arrow{
		margin-top:7%;
	}
	#cont1 .bottom{
		margin-top:3%;
		padding:3% 3% 3% 18%;
		border:2px solid #0749b9;
		border-radius:1em;
	}
	#cont1 .bottom img{
		width:17%;
		position:absolute;
		left:1.5%;
		bottom:50%;
		transform:translateY(50%);
	}
	#cont1 .bottom p{
		font-size:3.7vw;
		text-align:left;
	}
}


/* #cont2 */
#cont2{
	background:url(../img/cont2_bg.png)repeat-y center center;
	background-size:100% auto;
}
#cont2 .tit .small{
	font-size:min(2.4vw,24px);
	letter-spacing:0.14em;
	text-indent:0.14em;
}
#cont2 .troubles{
	max-width:1240px;
	width:94%;
	margin-top:min(9%,110px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	background:url(../img/cont2_img.png)no-repeat center bottom;
	background-size:30% auto;
}
#cont2 .troubles li{
	width:24%;
	aspect-ratio:300 / 140;
	line-height:1.5;
	margin-top:1.5%;
	font-size:min(1.5vw,18px);
	font-weight:bold;
	background-color:#fff;
	border-radius:1em;
	text-align:left;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	box-shadow:0 0 40px rgba(0,58,145,0.15);
}
#cont2 .troubles li:nth-child(2),
#cont2 .troubles li:nth-child(3){
	transform:translateY(-50%);
}
#cont2 .bottom{
	margin-top:min(3%,30px);
	font-size:min(2.4vw,24px);
	letter-spacing:0.08em;
	padding-left:0.08em;
}

@media screen and (max-width:750px){
	#cont2 .tit .small{
		font-size:3.8vw;
	}
	#cont2 .troubles{
		width:90%;
		margin-top:5%;
		padding-bottom:40%;
		display: block;
		background:url(../img/cont2_img.png)no-repeat center bottom;
		background-size:80% auto;
	}
	#cont2 .troubles li{
		width:auto;
		aspect-ratio:690 / 130;
		line-height:1.5;
		margin-top:3%;
		padding:0 6%;
		font-size:4vw;
		border-radius:0.5em;
		box-shadow:0 0 20px rgba(0,58,145,0.15);
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
	}
	#cont2 .troubles li:nth-child(2),
	#cont2 .troubles li:nth-child(3){
		transform:none;
	}
	#cont2 .bottom{
		margin-top:5%;
		font-size:3.7vw;
	}
}


/* #cont3 */
#cont3{
}
#cont3 .point{
	max-width:1240px;
	width:94%;
}
#cont3 .point li{
	margin-top:min(7%,90px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont3 .point li:nth-child(even){
	-webkit-flex-direction: row-reverse;
	flex-direction: row-reverse;
}
#cont3 .point li section{
	width:min(40%,490px);
	padding-left:min(4vw,50px);
	text-align:left;
}
#cont3 .point li:nth-child(even) section{
	padding-left:0;
	padding-right:min(4vw,50px);
}
#cont3 .point li section h3{
	line-height:1.9;
	font-size:min(2.2vw,28px);
	letter-spacing:0.06em;
}
#cont3 .point li section h3 .en{
	line-height:1.4;
	font-family: arial, sans-serif;
	font-size:min(3.6vw,45px);
	letter-spacing:normal;
	display: block;
}
#cont3 .point li section h3 .en:before{
	content:'point';
	font-size:min(1.7vw,22px);
	font-weight:normal;
}
#cont3 .point li section h3 .en:after{
	content:'';
	display:inline-block;
	vertical-align:-0.45em;
	width:1px;
	height:1em;
	margin-left:0.15em;
	border-right:1px solid;
	transform:rotate(45deg);
}
#cont3 .point li section p{
	margin-top:1em;
	letter-spacing:0.06em;
}
#cont3 .point li figure{
	width:min(55%,690px);
}

@media screen and (max-width:1200px){
	#cont3 .point li section{
		padding-left:0;
	}
	#cont3 .point li:nth-child(even) section{
		padding-right:0;
	}
}

@media screen and (max-width:750px){
	#cont3 .point{
		width:90%;
	}
	#cont3 .point li{
		margin-top:12%;
		display: block;
	}
	#cont3 .point li section{
		width:auto;
	}
	#cont3 .point li section h3{
		line-height:1.5;
		font-size:4.6vw;
		display: -webkit-flex;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
	}
	#cont3 .point li section h3 .en{
		font-size:8.4vw;
		margin-right:0.6em;
	}
	#cont3 .point li section h3 .en:before{
		font-size:3.8vw;
	}
	#cont3 .point li section h3 .jp{
		flex:1;
	}
	#cont3 .point li figure{
		width:auto;
		margin-top:9%;
	}
}


/* #cont4 */
#cont4{
	padding-bottom:min(22%,220px);
}
#cont4 .tit{
	line-height:1.7;
}
#cont4 .tit .small{
	display:block;
	font-size:min(3.2vw,32px);
}
#cont4 .point{
	max-width:1240px;
	margin-top:min(12%,120px);
	background:url(../img/cont4_bg.png)no-repeat center center;
	background-size:53% auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}
#cont4 .point > li{
	width:min(46.7%,580px);
	position:relative;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
}
#cont4 .point > li:nth-child(even){
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
}
#cont4 .point > li:nth-child(n+3){
	margin-top:min(24vw,240px);
}
#cont4 .point > li figure{
	width:52%;
	position:absolute;
	left:0;
	top:0;
	transform:translateY(-50%);
}
#cont4 .point > li:nth-child(even) figure{
	left:auto;
	right:0;
}
#cont4 .point > li:nth-child(n+3) figure{
	top:auto;
	bottom:0;
	transform:translateY(50%);
}

#cont4 .point > li section{
	width:68%;
	position:relative;
	background-color:#fff;
	border-radius:1em;
	box-shadow:0 0 40px rgba(0,58,145,0.15);
}
#cont4 .point > li section h3{
	border-radius:1em 1em 0 0;
	background-color:#3680ff;
	position:relative;
}
#cont4 .point > li:nth-child(2) section h3{
	background-color:#7bacff;
}
#cont4 .point > li:nth-child(3) section h3{
	background-color:#6c74de;
}
#cont4 .point > li:last-child section h3{
	background-color:#aa6cde;
}
#cont4 .point > li section h3 .fuki{
	width:100%;
	display:block;
	line-height:1.6;
	padding:0.5em 0 2.3em;
	font-size:min(1.4vw,18px);
	letter-spacing:0.06em;
	padding-left:0.06em;
	background:url(../img/cont4_fuki_bg.png)no-repeat center top;
	background-size:auto 100%;
	position:absolute;
	transform:translateY(-55%);
}
#cont4 .point > li section h3 .large{
	display:block;
	padding:1.2em 0 0.8em;
	font-size:min(2.1vw,27px);
	letter-spacing:0.06em;
	text-indent:0.06em;
	color:#fff;
}
#cont4 .point > li section .check{
	padding:6% 9% 9%;
}
#cont4 .point > li section .check li{
	padding-left:2em;
	font-size:min(1.3vw,17px);
	font-weight:bold;
	text-align:left;
	background:url(../img/cont4_check.png)no-repeat left center;
	background-size:1em auto;
}

@media screen and (max-width:750px){
	#cont4 .tit{
		line-height:1.5;
	}
	#cont4 .tit .small{
		margin-bottom:0.3em;
		font-size:4.8vw;
	}
	#cont4 .point{
		margin-top:9%;
		background-image:none;
		display: block;
	}
	#cont4 .point > li{
		width:auto;
		margin-top:5%;
		position:static;
		display: block;
	}
	#cont4 .point > li:nth-child(n+3){
		margin-top:5%;
	}
	#cont4 .point > li figure{
		width:42%;
		position:static;
		left:auto;
		top:auto;
		transform:none;
		margin:0 auto 1.5%;
	}
	#cont4 .point > li:nth-child(even) figure{
		left:auto;
		right:auto;
	}
	#cont4 .point > li:nth-child(n+3) figure{
		top:auto;
		bottom:auto;
		transform:none;
	}

	#cont4 .point > li section{
		width:auto;
		box-shadow:0 0 20px rgba(0,58,145,0.15);
	}
	#cont4 .point > li section h3 .fuki{
		font-size:3.6vw;
	}
	#cont4 .point > li section h3 .large{
		font-size:5.3vw;
	}
	#cont4 .point > li section .check{
		padding:6% 15% 9%;
	}
	#cont4 .point > li section .check li{
		font-size:3.7vw;
	}
}


/* #cont5 */
#cont5{
	background:url(../img/cont5_bg.webp)no-repeat center center;
	background-size:cover;
}
#cont5 .tit{
	color:#fff;
}
#cont5 .tit .small{
	font-size:min(3.2vw,32px);
}
#cont5 .lead{
	color:#fff;
}
#cont5 .slick{
	max-width:1240px;
	width:94%;
	margin-top:min(2%,20px);
	opacity: 0;
	transition: opacity .3s linear;
}
#cont5 .slick.slick-initialized{
	opacity:1;
}
#cont5 .slick .item{
	padding:20px min(4vw,50px);
}
#cont5 .slick .item .bg_white{
	height:100%;
	padding:5% 7%;
	background-color:#fff;
	box-shadow:0 0 40px rgba(0,58,145,0.15);
	border-radius:1em;
}
#cont5 .slick .item .bg_white h3{
	line-height:1.4;
	font-size:min(2vw,26px);
	letter-spacing:0.06em;
	text-indent:0.06em;
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
}
#cont5 .slick .item .bg_white h3 .case{
	line-height:1.8;
	margin-right:1em;
	padding:0 0.8em;
	font-size:min(1.3vw,16px);
	font-weight:bold;
	color:#fff;
	background-color:#2b5abe;
	border-radius:100px;
}
#cont5 .slick .item .bg_white h3 .large{
	flex:1;
	text-align:left;
}
#cont5 .slick .item .bg_white dl{
	margin-top:min(3%,30px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	background:url(../img/cont5_arrow.png)no-repeat center center;
	background-size:1.5em auto;
}
#cont5 .slick .item .bg_white dl div{
	width:47%;
	border-radius:1em;
	background:#f8f8f8;
	overflow:hidden;
}
#cont5 .slick .item .bg_white dl div dt{
	line-height:2.6;
	letter-spacing:0.06em;
	text-indent:0.06em;
}
#cont5 .slick .item .bg_white dl div:first-child dt{
	background-color:#bcd0e7;
}
#cont5 .slick .item .bg_white dl div:last-child dt{
	color:#fff;
	background-color:#2b5abe;
}
#cont5 .slick .item .bg_white dl div dd{
	aspect-ratio: 465 / 170;
	padding:5% 7%;
	text-align:left;
	letter-spacing:0.06em;
}

@media screen and (max-width:750px){
	#cont5{
		padding-top:12%;
		background:#445d92 url(../img/cont5_bg_s.webp)no-repeat center center;
		background-size:cover;
		overflow:hidden;
	}
	
	#cont5 .tit .small{
		font-size:4.8vw;
	}
	#cont5 .slick{
		width:98%;
		margin-top:min(1.5%,15px);
	}
	#cont5 .slick .item{
		padding:10px 3vw;
	}
	#cont5 .slick .item .bg_white{
		height:100%;
		padding:5% 7%;
		background-color:#fff;
		box-shadow:0 0 40px rgba(0,58,145,0.15);
		border-radius:1em;
	}
	#cont5 .slick .item .bg_white h3{
		line-height:1.4;
		font-size:min(2vw,26px);
		letter-spacing:0.06em;
		text-indent:0.06em;
		display: block;
	}
	#cont5 .slick .item .bg_white h3 .case{
		display:inline-block;
		line-height:1.8;
		margin-right:0;
		padding:0 0.8em;
		font-size:3.2vw;
	}
	#cont5 .slick .item .bg_white h3 .large{
		display:block;
		margin-top:0.5em;
		font-size:4.4vw;
	}
	#cont5 .slick .item .bg_white dl{
		margin-top:7%;
		display: block;
		background:url(../img/cont5_arrow_s.png)no-repeat center center;
		background-size:1.5em auto;
	}
	#cont5 .slick .item .bg_white dl div{
		width:auto;
		aspect-ratio:610 / 360;
	}
	#cont5 .slick .item .bg_white dl div:last-child{
		margin-top:2.5em;
	}
	#cont5 .slick .item .bg_white dl div dt{
		font-size:3vw;
	}
	#cont5 .slick .item .bg_white dl div dd{
		aspect-ratio: auto;
	}
}


/* #cont6 */
#cont6{
}
#cont6 .voice{
	max-width:1240px;
	width:94%;
	margin-top:min(7%,70px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont6 .voice li{
	width:min(30%,374px);
	text-align:left;
}
#cont6 .voice li figure figcaption{
	line-height:1.6;
	margin-top:1.5em;
	font-size:min(1.7vw,18px);
	font-weight:bold;
}
#cont6 .voice li figure figcaption .large{
	display:block;
	letter-spacing:0.06em;
}
#cont6 .voice li figure figcaption .small{
	margin-top:1em;
	display:block;
	font-size:min(1.3vw,16px);
	letter-spacing:0.06em;
	color:#999;
}
#cont6 .voice li p{
	margin-top:1.5em;
	letter-spacing:0.06em;
}

@media screen and (max-width:750px){
	#cont6 .voice{
		max-width:1240px;
		width:84%;
		margin-top:0;
		display: block;
	}
	#cont6 .voice li{
		width:auto;
		margin-top:12%;
	}
	#cont6 .voice li figure figcaption{
		line-height:1.6;
		margin-top:1.5em;
		font-size:4vw;
	}
	#cont6 .voice li figure figcaption .small{
		margin-top:0.8em;
		font-size:3.7vw;
	}
	#cont6 .voice li p{
		margin-top:1em;
	}
}


/* #cont7 */
#cont7{
}
#cont7 .step{
	margin-top:min(5%,50px);
	max-width:760px;
	width:80%;
}
#cont7 .step li{
	padding:0 0 min(8%,60px) min(9%,90px);
	border-left:4px solid #7bacff;
	text-align:left;
	position:relative;
}
#cont7 .step li:last-child{
	padding-bottom:0;
	border-left:4px solid transparent;
}
#cont7 .step li .num{
	width:2.5em;
	height:2.5em;
	line-height:1;
	font-family:arial;
	font-size:min(3.3vw,33px);
	font-weight:bold;
	border-radius:50%;
	border:2px solid #0749b9;
	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;
	top:0;
	transform:translate(calc(-50% - 2px),-1%);
}
#cont7 .step li .num:before{
	content:'STEP';
	font-size:min(1.2vw,12px);
}
#cont7 .step li h3{
	line-height:1.4;
	font-size:min(2.2vw,22px);
	letter-spacing:0.06em;
}
#cont7 .step li p{
	line-height:1.66;
	margin-top:0.3em;
	letter-spacing:0.06em;
}
#cont7 .step li p .marker{
	font-size:min(2vw,20px);
	background:linear-gradient(transparent 60%, #ff0 60%);
}

@media screen and (max-width:750px){
	#cont7 .step{
		margin-top:9%;
		width:80%;
	}
	#cont7 .step li{
		padding:0 0 9% 15%;
		border-left:2px solid #7bacff;
	}
	#cont7 .step li:last-child{
		border-left:2px solid transparent;
	}
	#cont7 .step li .num{
		width:2.5em;
		height:2.5em;
		font-size:5.8vw;
		border:1px solid #008a20;
		transform:translate(calc(-50% - 1px),-1%);
	}
	#cont7 .step li .num:before{
		font-size:2.1vw;
	}
	#cont7 .step li h3{
		font-size:4.6vw;
		white-space:nowrap;
	}
	#cont7 .step li p{
		font-size:4vw;
	}
	#cont7 .step li p .marker{
		line-height:1.2;
		font-size:4.8vw;
	}
}


/* #cont8 */
#cont8{
}
#cont8 .plan{
	max-width:1240px;
	width:94%;
	margin-top:min(5%,50px);
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont8 .plan > li{
	width:30%;
	padding-bottom:3%;
	background-color:#fff;
	box-shadow:0 0 40px rgba(0,58,145,0.15);
	border-radius:1em;
	overflow:hidden;
}
#cont8 .plan > li h3{
	line-height:2.8;
	font-size:min(2vw,26px);
	letter-spacing:0.06em;
	text-indent:0.06em;
	color:#fff;
	background-color:#7bacff;
}
#cont8 .plan > li:nth-child(2) h3{
	background-color:#0749b9;
}
#cont8 .plan > li:last-child h3{
	background-color:#6c74de;
}
#cont8 .plan > li dl{
	padding:5% 8% 3%;
}
#cont8 .plan > li dl > div{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
}
#cont8 .plan > li dl > div:last-child{
	margin-top:1em;
	-webkit-align-items: flex-start;
	align-items: flex-start;
}
#cont8 .plan > li dl > div dt{
	width:5em;
	font-size:min(1.1vw,14px);
	font-weight:bold;
	background-color:#f5f5f5;
}
#cont8 .plan > li dl > div dd{
	flex:1;
	margin-left:min(1.1vw,14px);
	line-height:1.5;
	text-align:left;
	letter-spacing:0.02em;
}
#cont8 .plan > li dl > div dd .large{
	font-size:min(3.6vw,45px);
	font-weight:bold;
}
#cont8 .plan > li dl > div dd .middle{
	font-size:min(2.9vw,36px);
	font-weight:bold;
}
#cont8 .plan > li dl > div dd .small{
	height:4.8em;
	display:block;
	padding-right:1em;
	font-size:min(1.3vw,16px);
	letter-spacing:0.04em;
	transform:translateY(-0.3em);
}
#cont8 .plan > li dl > div dd .yen{
	line-height:1.2;
	display:inline-block;
	font-size:min(1.4vw,18px);
	font-weight:bold;
	position:relative;
}
#cont8 .plan > li dl > div dd .syen{
	line-height:1.2;
	display:inline-block;
	font-size:min(1.3vw,16px);
	font-weight:bold;
	position:relative;
}
#cont8 .plan > li dl > div dd .yen:before,
#cont8 .plan > li dl > div dd .syen:before{
	content:'（税込）';
	font-size:min(1vw,13px);
	color:#222;
	letter-spacing:0.06em;
	position:absolute;
	bottom:100%;
	white-space:nowrap;
}
#cont8 .plan > li h4{
	margin:1.5% 8%;
	font-size:min(1.1vw,14px);
	letter-spacing:0.06em;
	text-indent:0.06em;
	background-color:#ecf0f7;
}
#cont8 .plan > li:nth-child(2) h4{
	background-color:#c1d8ff;
}
#cont8 .plan > li:last-child h4{
	background-color:#e1e3ff;
}
#cont8 .plan > li ul{
	padding:0 12.5%;
}
#cont8 .plan > li ul li{
	line-height:1.5;
	margin-top:1em;
	padding-left:2em;
	font-size:min(1.3vw,16px);
	font-weight:bold;
	letter-spacing:0.06em;
	text-align:left;
	background:url(../img/cont4_check.png)no-repeat left 0.5em;
	background-size:1.1em auto;
}
#cont8 .bottom{
	margin-top:min(5%,50px);
	font-size:min(1.7vw,17px);
}

@media screen and (max-width:750px){
	#cont8 .lead{
		text-align:center;
	}
	#cont8 .plan{
		width:90%;
		margin-top:-3%;
		display: block;
	}
	#cont8 .plan > li{
		width:auto;
		margin-top:12%;
		padding-bottom:9%;
		box-shadow:0 0 20px rgba(0,58,145,0.15);
		border-radius:0.6em;
	}
	#cont8 .plan > li h3{
		line-height:2.8;
		font-size:6.4vw;
	}
	#cont8 .plan > li dl > div dt{
		line-height:2;
		font-size:3.4vw;
	}
	#cont8 .plan > li dl > div dd{
		margin-left:3vw;
	}
	#cont8 .plan > li dl > div dd .large{
		font-size:11vw;
	}
	#cont8 .plan > li dl > div dd .middle{
		font-size:8.8vw;
	}
	#cont8 .plan > li dl > div dd .small{
		height:4.5em;
		display:block;
		padding-right:0;
		font-size:4vw;
	}
	#cont8 .plan > li dl > div dd .yen{
		font-size:4.4vw;
	}
	#cont8 .plan > li dl > div dd .syen{
		font-size:3.8vw;
	}
	#cont8 .plan > li dl > div dd .yen:before,
	#cont8 .plan > li dl > div dd .syen:before{
		content:'（税込）';
		font-size:3.2vw;
	}
	#cont8 .plan > li h4{
		line-height:2.4;
		font-size:3.4vw;
	}
	#cont8 .plan > li ul li{
		font-size:3.7vw;
	}
	#cont8 .bottom{
		font-size:3.7vw;
	}
}


/* #cont9 */
#cont9{
}
#cont9 .faq{
	max-width:840px;
	margin-top:min(3%,30px);
}
#cont9 .faq div{
	padding:1em 0;
	font-size:min(2.8vw,28px);
	text-align:left;
	border-bottom:1px solid #ccc;
}
#cont9 .faq div dt{
	padding:0 1.8em;
	position:relative;
	cursor:pointer;
}
#cont9 .faq div dt:before{
	content:'Q.';
	line-height:1;
	font-weight:bold;
	transform-origin:left center;
	transform:scaleX(1.05);
	position:absolute;
	left:0;
	top:0;
}
#cont9 .faq div dt:after{
	content:'';
	display:block;
	width:0.3em;
	height:0.3em;
	border-right:min(0.3vw,3px) solid;
	border-bottom:min(0.3vw,3px) solid;
	position:absolute;
	right:0.3em;
	top:50%;
	transform:translateY(-50%) rotate(45deg);
}
#cont9 .faq div dt.close:after{
	transform:translateY(-50%) rotate(-135deg);
}
#cont9 .faq div dt p{
	line-height:1.7;
	font-size:min(2vw,20px);
	font-weight:bold;
	letter-spacing:0.06em;
}
#cont9 .faq div dd{
	margin-top:0.8em;
	padding-left:1.8em;
	position:relative;
	display:none;
}
#cont9 .faq div dd:before{
	content:'A.';
	line-height:1;
	font-weight:bold;
	transform-origin:left center;
	transform:scaleX(1.2);
	position:absolute;
	left:0;
	top:0;
}
#cont9 .faq div dd p{
	font-size:min(1.7vw,17px);
	letter-spacing:0.06em;
}

#cont9 .bottom{
	margin-top:min(9%,90px);
	border-radius:0.7em;
	font-size:min(1.85vw,20px);
}

@media screen and (max-width:750px){
	#cont9 .faq div{
		padding:0.5em 0;
		font-size:5.3vw;
	}
	#cont9 .faq div dt:after{
		width:0.6em;
		height:0.6em;
		border-right:1vw solid;
		border-bottom:1vw solid;
		right:0;
		top:0.3em;
		transform: rotate(45deg);
	}
	#cont9 .faq div dt.close:after{
		top:0.8em;
	}
	#cont9 .faq div dt p{
		font-size:3.7vw;
	}
	#cont9 .faq div dd{
		margin-top:0.3em;
	}
	#cont9 .faq div dd p{
		font-size:3.7vw;
	}
	#cont9 .faq div dd p .red{
		font-size:4vw;
	}
	
	#cont9 .bottom{
		font-size:3.4vw;
	}
}

/* #contact */
#contact{
}
#contact .lead{
	margin-top:min(3%,30px);
	letter-spacing:0.06em;
	padding-left:0.06em;
}

#contact form .inner{
	max-width:700px;
	font-size:16px;
	text-align:left;
}
#contact form > dl{
	margin-top:min(5vw,50px);
}
#contact form > dl div{
	margin-bottom:0.5em;
}
#contact form > dl dt{
	line-height:1;
	margin-bottom:0.8em;
	font-weight:bold;
	letter-spacing:0.06em;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: flex-end;
	align-items: flex-end;
}
#contact form > dl dt.hissu:after{
	content:'必須';
	padding:0 0.8em;
	line-height:1.6;
	font-size:12px;
	font-weight:normal;
	color:#fff;
	background-color:#363636;
}
#contact form > dl dd{
	margin-bottom:1.5em;
	font-weight:normal;
}
#contact form .privacy{
	font-size:14px;
	text-align:left;
}
#contact form .privacy a{
	border-bottom:1px solid;
	cursor:pointer;
}

@media screen and (max-width:750px){
	#contact .lead{
		padding:0 4%;
		text-align:left;
	}
	#contact form > dl dt.hissu:after{
		font-size:10px;
	}
}


/* テキストボックス */
input[type="text"],
input[type="email"],
input[type="tel"]{
	width:100%;
	height:3.8em;
	padding:0 1em;
	background-color:#fff;
	border:1px solid #ccc;
	border-radius:0.6em;
	outline:none;
}


/* テキストエリア */
textarea{
	width:100%;
	min-height: 18em;
	padding:0.5em 1em;
	background-color:#fff;
	border: 1px solid #ccc;
	border-radius:0.6em;
	vertical-align:bottom;
	outline:none;
}
@media screen and (max-width:750px){
	textarea{
		min-height: 9em;
	}
}


/* 送信ボタン */
#contact button[type="submit"],
button.btn{
	width:430px;
	line-height:70px;
	margin:min(5%,50px) auto 0;
	padding:0;
	font-size:24px;
	font-weight:bold;
	color:#fff;
	letter-spacing:0.08em;
	position:relative;
	cursor:pointer;
}
#contact button[type="submit"]:after,
button.btn:after{
	margin-left:0;
	position:absolute;
	right:1em;
	top:50%;
	transform: skewX(45deg) translateY(-50%);
}

@media screen and (max-width:750px){
	#contact button[type="submit"],
	#contact button.btn {
		width:90%;
		line-height:2.8;
		margin-top:12%;
		font-size:5.3vw;
	}
	
}

/* プレイスホルダー */
input::placeholder,
textarea::placeholder{
	color:#999999;
}
input:-ms-input-placeholder,
textarea::placeholder{
	color:#999999;
}
input::-ms-input-placeholder,
textarea::placeholder{
	color:#999999;
}

/* エラー */
form label.error {
	margin:0 0 0;
	color: red;
	display:block;
	font-weight:bold;
	text-align:left;
}


/* .confirm */
#contact.confirm{
}
#contact.confirm p{
	font-size:18px;
}
#contact.confirm p .red{
	margin-top:30px;
	display:block;
	font-size:38px;
	color:#f00;
}
#contact.confirm form > dl{
	margin-top:50px;
}
#contact.confirm dl > dt{
	width:auto;
	margin:0;
	line-height:2;
	padding:1.5em 2.5em;
	font-size:17px;
	font-weight:bold;
	float:left;
}
#contact.confirm dl > dd{
	margin:0;
	padding:1.5em 0 1.5em 16em;
	font-size:17px;
	border-bottom:1px solid #ddd;
}
#contact.confirm dl > dd:first-of-type{
	border-top:1px solid #ddd;
}
#contact.confirm .contact_btn{
	margin-top:50px;
	position:relative;
}
#contact.confirm .contact_btn button{
	margin:0 auto;
}
#contact.confirm .contact_btn button[type="button"]{
	font-size:20px;
	font-weight:500;
	position:absolute;
	left:0;
	top:50%;
	transform:translateY(-50%);
	cursor:pointer;
}
#contact.confirm .contact_btn button[type="button"] img{
	margin-right:0.5em;
	vertical-align:-0.1em;
}


@media screen and (max-width:1024px){
	#contact.confirm .contact_btn{
		position:static;
	}
	#contact.confirm .contact_btn button[type="button"]{
		display:block;
		width:6em;
		margin:1em auto 0;
		position:static;
		left:auto;
		top:auto;
		transform:none;
	}
}

@media screen and (max-width:750px){
	#contact.confirm{
		padding:9% 0;
	}
	#contact.confirm p{
		font-size:3.6vw;
	}
	#contact.confirm p .red{
		margin-top:5%;
		font-size:5vw;
	}
	#contact.confirm form{
		padding:5%;
		font-size:3.5vw;
	}
	#contact.confirm form > dl{
		margin-top:0;
	}
	#contact.confirm dl > dt{
		padding:1.2em 0 0;
		font-size:3.5vw;
		float:none;
	}
	#contact.confirm dl > dd{
		padding:0 0 1.2em;
		font-size:3.5vw;
	}
	#contact.confirm dl > dd:first-of-type{
		border-top:none;
	}
	#contact.confirm .contact_btn{
		margin-top:9%;
	}
	#contact.confirm .contact_btn button[type="button"]{
		font-size:3.4vw;
	}
	#contact.confirm .contact_btn button[type="button"] img{
		width:1.5em;
	}
}


/* #thanks */
#thanks{
	min-height:80vh;
}
#thanks h2{
	font-size:min(2.8vw,28px);
	letter-spacing:0.04em;
	text-indent:0.04em;
}
#thanks h2 .large{
	line-height:1.2;
	display:block;
	font-size:min(7.5vw,75px);
	letter-spacing:0;
	text-indent:0;
}
#thanks h2 + .lead{
	line-height:2.6;
	margin-top:min(3%,30px);
	font-size:15px;
	letter-spacing:0.04em;
	padding-left:0.04em;
}
#thanks .inner{
	max-width:760px;
	margin-top:min(5%,50px);
	padding:40px;
	font-size:14px;
	text-align:left;
	letter-spacing:0.06em;
	background-color:#fff;
	border-radius:1em;
}
#thanks .inner dd ul{
	margin-top:1.8em;
}
#thanks .btn{
	display:inline-block;
	width:276px;
	line-height:3.2;
	margin:min(7%,70px) auto 0;
	font-size:15px;
	font-weight:bold;
	letter-spacing:0.08em;
	text-indent:0.08em;
	cursor:pointer;
}

@media screen and (max-width:750px){
	#thanks{
		padding-left:0;
		padding-right:0;
	}
	#thanks h2{
		font-size:4.8vw;
	}
	#thanks h2 .large{
		font-size:8.5vw;
	}
	#thanks h2 + .lead{
		line-height:1.5;
		padding:0 5%;
		font-size:3.6vw;
		text-align:left;
	}
	#thanks .inner{
		margin-top:5%;
		padding:5%;
		font-size:3.4vw;
	}
	#thanks .btn{
		width:80%;
		margin:9% auto 0;
		font-size:4vw;
	}
}


/* #overlay */
html.overlay {
	overflow: hidden;
	height: 100%;
}
#overlay {
	position: fixed;
	width: 100%;
	height: 100vh;
	padding:50px 5%;
	top: 0;
	left: 0;
	z-index: 102;
	background-color: rgba(0, 0, 0, 0.5);
	display: none;
}
#overlay .sec{
	max-width:800px;
	width:90%;
	height:100%;
	overflow:auto;
	margin:auto;
	padding:5%;
	text-align:left;
	background-color:#fff;
}
#overlay .sec .lead{
	margin-top:1em;
}
#overlay .sec .cont_list{
	margin-top:1em;
}
#overlay .sec .cont_list > dt:before{
	content:"■";
	margin-right:0.3em;
}
#overlay .sec .cont_list > dd{
	margin-bottom:1em;
}
#overlay .sec .cont_list > dd .disc{
	padding-left:1.5em;
}
#overlay .sec .cont_list > dd .disc li{
	list-style:disc;
	word-break: break-all;
}
#overlay .sec .cont_list > dd .address{
	margin-top:1em;
	line-height:1.5;
}
#overlay .sec .cont_list > dd .url{
	overflow-wrap: break-word;
}
#overlay .sec .close{
	display:block;
	width:4em;
	margin:1.5em auto 0;
	color:#fff;
	background-color:#222;
	cursor:pointer;
}

@media screen and (max-width:750px){
	#overlay {
		padding:25px 5%;
	}
	#overlay .sec{
		height:calc(100dvh - 50px);
		font-size:3.5vw;
	}
}


/* footer */
footer{
	padding:min(3%,30px) 0;
}
footer .nav{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
}
footer .nav li{
	margin:0 1em;
}
footer .nav li a{
	font-size:14px;
	font-weight:bold;
	color:#fff;
	letter-spacing:0.04em;
	text-indent:0.04em;
}
footer .copy{
	margin-top:0.5em;
	font-size:12px;
	letter-spacing:0.04em;
	text-indent:0.04em;
}

@media screen and (max-width:750px){
	footer{
		padding:5% 0;
	}
	footer .nav{
		display: block;
	}
	footer .nav li{
		margin:0;
	}
	footer .nav li a{
		font-size:3.2vw;
		font-weight:500;
	}
	footer .copy{
		margin-top:2em;
		font-size:2.8vw;
	}
}


/* #topbtn */
#topbtn{
	width:50px;
	line-height:50px;
	font-size:21px;
	font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
	border-radius:50%;
	color:#fff;
	background-color:#ff8400;
	box-shadow:0 0 3px rgba(0,0,0,0.3);
	position:fixed;
	z-index:102;
	right:20px;
	bottom:-150px;
	-webkit-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
@media screen and (max-width:750px){
	#topbtn{
		width:40px;
		line-height:40px;
		font-size:18px;
		right:15px;
	}
}


/* #bottom_nav */
#bottom_nav{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	width:7em;
	height:7em;
	line-height:1.3;
	margin-bottom:1em;
	padding:0 0 0.6em;
	font-size:min(2.1vw,21px);
	letter-spacing:0.08em;
	text-indent:0.08em;
	background:linear-gradient(90deg, #2ca4ff, #6887ff);
	border-radius:50%;
	position:fixed;
	right:20px;
	bottom:-300px;
	-webkit-transition: bottom 0.8s;
	-webkit-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
#bottom_nav:hover{
	opacity:1;
}
#bottom_nav:after{
	margin-left:0;
	position:absolute;
	right:50%;
	bottom:1em;
	transform: skewX(45deg) translateX(50%);
}

@media screen and (max-width:750px){
	#bottom_nav{
		display:block;
		width:100%;
		height:auto;
		line-height:3.4;
		margin:0;
		padding:0;
		font-size:5.3vw;
		background:linear-gradient(90deg, #2ca4ff, #6887ff);
		border-radius:0;
		box-shadow:none;
		right:0;
	}
	#bottom_nav:after{
		right:1em;
		top:50%;
		transform: skewX(45deg) translateY(-50%);
	}
}


/* fadein */
.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_0 {
	opacity : 0;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 2s;
	transition-duration : 2s;
}

.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;
}

.fadein.scrollin,
.fadein_0.scrollin{
	opacity : 1;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
}

