@charset "utf-8";
html {
	-webkit-text-size-adjust: 100%;
}
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size:min(1.8vw,18px);
	font-weight:bold;
	text-align:center;
	line-height:1.7;
	color:#231815;
	background-color:#F2F0DC;
	font-feature-settings: "palt";
}

@media screen and (max-width:750px){
	body {
		font-size:3.6vw;
	}
}

.en{
	font-family: "Barlow", sans-serif;
}

a {
	color:#231815;
	-webkit-transition : opacity 0.4s;
	transition : opacity 0.4s;
	opacity:1;
	outline:none;
}
a:hover {
	opacity: 0.7;
}

img{
	max-width:100%;
}

.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{
	overflow:hidden;
}


.inner{
	max-width:1200px;
	width:94%;
	margin:auto;
}

@media screen and (max-width:750px){
	.inner{
		width:92%;
	}
}


/* 色 */
.bg_black{
	color:#fff;
	background-color:#231815;
}
.bg_white{
	background-color:#fff;
}

.bg_green{
	color:#fff;
	background-color:#00B900;
}
.bg_blue{
	color:#fff;
	background-color:#1A6FC9;
}
.bg_orange{
	background-color:#F4C917;
}



/* 書式 */
.bold{
	font-weight:bold;
}


/* .btn */
.btn{
	margin-top:0.3em;
	line-height:3;
	display:block;
	font-size:min(1.6vw,20px);
	font-weight:bold;
	letter-spacing:0.1em;
	text-indent:0.1em;
	border-radius:100px;
}
.btn.bg_green{
	background:#00B900 url(../images/icon_arrow.svg)no-repeat right 1em center;
	background-size:0.6em auto;
}
.btn.bg_blue{
	background:#1A6FC9 url(../images/icon_arrow.svg)no-repeat right 1em center;
	background-size:0.6em auto;
}

@media screen and (max-width:750px){
	.btn{
		line-height:4.2;
		font-size:3.5vw;
	}
	.btn.bg_green,
	.btn.bg_blue{
		background-position:right 1.5em center;
	}
}


/* header */
header{
	padding-top:min(8.3%,100px);
	background:url(../images/mv_bg.png)no-repeat center bottom;
	background-size:cover;
}
header #mv{
	position:relative;
}
header #mv .fig{
	width:min(75%,843px);
	position:absolute;
	left:calc(min(56%,650px) + min(7%,90px));
}
header #mv .sec{
	width:min(56%,650px);
	position:relative;
}
header #mv .sec .img_book{
	width:22%;
	position:absolute;
	left:0;
}
header #mv .sec h1{
	padding-left:24%;
	text-align:left;
	position:relative;
}
header #mv .sec h1 .fuki{
	line-height:2.2;
	display:inline-block;
	padding:0 0.5em;
	font-size:min(1.6vw,20px);
	font-weight:900;
	letter-spacing:0.08em;
	text-indent:0.08em;
	background:url(../images/mv_fuki.png)no-repeat center center;
	background-size:100% 100%;
}
header #mv .sec h1 .en{
	line-height:1.1;
	font-size:min(6vw,72px);
	letter-spacing:0.1em;
}
header #mv .sec h1 .bg_black{
	line-height:2.4;
	display:inline-block;
	padding:0 1.5em;
	font-size:min(1.46vw,18px);
	letter-spacing:0.08em;
	text-indent:0.08em;
	position:absolute;
	right:0;
	bottom:1em;
}
header #mv .sec .lead{
	margin-top:1.5em;
	font-size:min(1.45vw,16px);
	font-weight:900;
	text-align:left;
	letter-spacing:0.1em;
}
header #mv .sec p{
	margin-top:0.5em;
}
header #mv .sec section{
	margin-top:1.5em;
	padding:5% 0;
	border-radius:0.4em;
}
header #mv .sec section h2{
	font-size:min(1.3vw,16px);
	font-weight:900;
	letter-spacing:0.1em;
}
header #mv .sec section h2 span{
	display:inline-block;
	padding:0 0.5em;
	font-size:min(1.5vw,18px);
	font-weight:bold;
	text-indent:0.1em;
}
header #mv .sec section dl{
	margin-top:3%;
	display: -webkit-flex;
	display: flex;
}
header #mv .sec section dl div{
	width:50%;
	padding: 0 3%;
}
header #mv .sec section dl div:first-child{
	border-right:3px dotted #C0C0C0;
}
header #mv .sec section dl div dt{
	font-size:min(1.3vw,16px);
	font-weight:900;
}
header #mv .sec section dl div dt img{
	width:2em;
	margin-right:0.3em;
	vertical-align:-0.5em;
}
header #mv .sec section dl div dt span{
	font-size:min(1.6vw,20px);
}

@media screen and (max-width:750px){
	header{
		padding-top:5%;
		background:url(../images/mv_bg_s.png)no-repeat center bottom;
		background-size:cover;
	}
	header #mv{
		position:static;
	}
	header #mv .fig{
		width:auto;
		position:static;
		left:auto;
	}
	header #mv .sec{
		width:auto;
		position:relative;
		margin-top:9%;
	}
	header #mv .sec .img_book{
		width:22.5%;
		position:absolute;
		left:0;
	}
	header #mv .sec h1{
		padding-left:25%;
		text-align:left;
		position:relative;
	}
	header #mv .sec h1 .fuki{
		padding:0 0.8em;
		font-size:3vw;
	}
	header #mv .sec h1 .en{
		font-size:10vw;
	}
	header #mv .sec h1 .bg_black{
		padding:0 0.5em;
		font-size:3vw;
		bottom:0.5em;
	}
	header #mv .sec .lead{
		margin-top:1em;
		font-size:3.5vw;
	}
	header #mv .sec section{
		margin-top:1.8em;
		padding:7%;
		border-radius:0.6em;
	}
	header #mv .sec section h2{
		line-height:2.2;
		font-size:3.5vw;
	}
	header #mv .sec section h2 span{
		font-size:4.1vw;
	}
	header #mv .sec section dl{
		margin-top:0;
		display: block;
	}
	header #mv .sec section dl div{
		width:auto;
		padding:5% 0 0;
	}
	header #mv .sec section dl div:first-child{
		border-right:none;
	}
	header #mv .sec section dl div dt{
		font-size:3.5vw;
	}
	header #mv .sec section dl div dt img{
		width:2em;
		margin-right:0.3em;
		vertical-align:-0.5em;
	}
	header #mv .sec section dl div dt span{
		font-size:4.6vw;
	}
}


/* article */
article{
}




/* #mv */
#mv{
}

@media screen and (max-width:750px){
}


/* .cont */
.cont{
	padding:min(18%,180px) 0 min(9%,90px);
}
.cont .tit{
	max-width:1440px;
	margin:auto;
	position:relative;
}
.cont .tit:before{
	content:'';
	display:block;
	width:min(2vw,38px);
	height:100%;
	background-color:#231815;
	position:absolute;
	left:0;
	top:0;
}
.cont .tit .tit_wrapper{
	line-height:1;
	display:block;
	text-align:left;
}
.cont .tit .tit_wrapper .en{
	display:block;
	font-size:min(2.6vw,32px);
	letter-spacing:0.1em;
}
.cont .tit .tit_wrapper .jp{
	display:block;
	margin-top:0.3em;
	font-size:min(4.6vw,56px);
	font-weight:900;
	letter-spacing:0.1em;
}
.cont .tit .tit_wrapper .jp .large{
	line-height:0;
	font-family: "Barlow", sans-serif;
	font-size:min(6.3vw,76px);
}


@media screen and (max-width:750px){
	.cont{
		padding:24% 0 18%;
	}
	
	.cont .tit:before{
		width:4vw;
	}
	.cont .tit .tit_wrapper{
		width:86%;
	}
	.cont .tit .tit_wrapper .en{
		font-size:4.1vw;
	}
	.cont .tit .tit_wrapper .jp{
		margin-top:0.6em;
		font-size:7.1vw;
	}
	.cont .tit .tit_wrapper .jp .large{
		font-size:11vw;
	}
}


/* #cont1 */
#cont1{
}
#cont1 .flex_wrapper{
	margin-left:calc(50% - 600px);
	display:flex;
}
#cont1 .flex_wrapper .point_list{
	width:680px;
}
#cont1 .flex_wrapper .point_list li{
	padding:min(33%,400px) 0 0;
	text-align:left;
}
#cont1 .flex_wrapper .point_list li:first-child{
	padding-top:min(15%,180px);
}
#cont1 .flex_wrapper .point_list li:last-child{
	padding-bottom:min(16%,200px);
	padding-bottom:100px;
}
#cont1 .flex_wrapper .point_list li .num{
	display:inline-block;
	line-height:2.2;
	padding:0 0.5em;
	font-size:min(1.7vw,20px);
	font-weight:bold;
	letter-spacing:0.1em;
	text-indent:0.1em;
}
#cont1 .flex_wrapper .point_list li .num:before{
	content:'POINT';
	margin-right:0.5em;
}
#cont1 .flex_wrapper .point_list li h3{
	line-height:1.4;
	margin-top:0.3em;
	font-size:min(3.3vw,40px);
	font-weight:900;
	letter-spacing:0.1em;
}
#cont1 .flex_wrapper .point_list li p{
	margin-top:1.2em;
	padding-top:1.5em;
	font-weight:bold;
	border-top:1px solid;
}

#cont1 .flex_wrapper .fig_wrapper{
	flex:1;
	position:relative;
}

#cont1 .flex_wrapper .fig_wrapper .fig_list{
	width:min(100%,640px);
	aspect-ratio:1280 / 910;
	position:absolute;
	top:50px;
	bottom:auto;
	z-index:2;
	border:1px solid transparent;
}
#cont1 .flex_wrapper .fig_wrapper .fig_list.fixed{
	width:min(44%,640px);
	position:fixed;
	top:160px;
	bottom:auto;
}
#cont1 .flex_wrapper .fig_wrapper .fig_list.bottom{
	position:absolute;
	top:auto;
	bottom:0;
}
#cont1 .flex_wrapper .fig_wrapper .fig_list:before{
	content:'';
	display:block;
	width:135px;
	height:135px;
	background:url(../images/cont1_bg.png)no-repeat left top;
	background-size:100% auto;
	position:absolute;
	top:0;
	right:0;
	transform:translateY(-60%);
}
#cont1 .flex_wrapper .fig_wrapper .fig_list:after{
	content:'';
	display:block;
	width:135px;
	height:135px;
	background:url(../images/cont1_bg.png)no-repeat left top;
	background-size:100% auto;
	position:absolute;
	bottom:0;
	left:0;
	z-index:-1;
	transform:translate(-30%,30%);
}

#cont1 .flex_wrapper .fig_wrapper .fig_list li{
	width:100%;
	height:100%;
	position:absolute;
	opacity:0;
	transform:translateX(10%);
	-webkit-transition : opacity 0.4s, transform 0.4s;
	transition : opacity 0.4s, transform 0.4s;
}
#cont1 .flex_wrapper .fig_wrapper .fig_list li.active{
	opacity:1;
	transform:translateX(0);
}

@media screen and (max-width:1440px){
	#cont1 .flex_wrapper .fig_wrapper .fig_list.fixed{
		top:50px;
	}
}

@media screen and (max-width:1300px){
	#cont1 .flex_wrapper{
		margin-left:3%;
		display:flex;
	}
	#cont1 .flex_wrapper .point_list{
		width:50%;
	}
	#cont1 .flex_wrapper .point_list li:last-child{
		padding-bottom:15%;
	}
	#cont1 .flex_wrapper .point_list li .num{
		display:inline-block;
		line-height:2.2;
		padding:0 0.5em;
		font-size:min(1.7vw,20px);
		font-weight:bold;
		letter-spacing:0.1em;
		text-indent:0.1em;
	}
	#cont1 .flex_wrapper .point_list li .num:before{
		content:'POINT';
		margin-right:0.5em;
	}
	#cont1 .flex_wrapper .point_list li h3{
		line-height:1.4;
		margin-top:0.3em;
		font-size:min(3.3vw,40px);
		font-weight:900;
		letter-spacing:0.1em;
	}
	#cont1 .flex_wrapper .point_list li p{
		margin-top:1.2em;
		padding-top:1.5em;
		padding-right:3%;
		font-weight:bold;
		border-top:1px solid;
	}

	#cont1 .flex_wrapper .fig_wrapper .fig_list{
		width:100%;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list.fixed{
		width:48.4%;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list:before{
		width:10vw;
		height:10vw;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list:after{
		width:10vw;
		height:10vw;
	}
}

@media screen and (max-width:750px){
	#cont1 .flex_wrapper{
		width:auto;
		margin:0;
		display:block;
	}
	#cont1 .flex_wrapper .point_list{
		width:auto;
	}
	#cont1 .flex_wrapper .point_list li{
		padding:16% 0 0;
	}
	#cont1 .flex_wrapper .point_list li:first-child{
		padding-top:16%;
	}
	#cont1 .flex_wrapper .point_list li figure{
		margin:0 0 5% 4%;
		position:relative;
		z-index:2;
	}
	#cont1 .flex_wrapper .point_list li figure:before{
		content:'';
		display:block;
		width:20vw;
		height:20vw;
		background:url(../images/cont1_bg.png)no-repeat left top;
		background-size:100% auto;
		position:absolute;
		top:0;
		right:0;
		z-index:-1;
		transform:translateY(-70%);
	}
	#cont1 .flex_wrapper .point_list li figure:after{
		content:'';
		display:block;
		width:20vw;
		height:20vw;
		background:url(../images/cont1_bg.png)no-repeat left top;
		background-size:100% auto;
		position:absolute;
		bottom:0;
		left:0;
		z-index:-1;
		transform:translate(-30%,40%);
	}
	#cont1 .flex_wrapper .point_list li .num{
		margin-left:4%;
		font-size:3.5vw;
		position:relative;
		z-index:2;
	}
	#cont1 .flex_wrapper .point_list li h3{
		margin:0.3em 4% 0;
		font-size:6.6vw;
	}
	#cont1 .flex_wrapper .point_list li p{
		margin:1em 4% 0;
		padding-top:1.2em;
	}

	#cont1 .flex_wrapper .fig_wrapper{
		flex:1;
		position:relative;
	}

	#cont1 .flex_wrapper .fig_wrapper .fig_list{
		width:640px;
		aspect-ratio:1280 / 910;
		position:absolute;
		top:50px;
		bottom:auto;
		z-index:2;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list.fixed{
		position:fixed;
		top:50px;
		bottom:auto;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list.bottom{
		position:absolute;
		top:auto;
		bottom:0;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list:before{
		content:'';
		display:block;
		width:135px;
		height:135px;
		background:url(../images/cont1_bg.png)no-repeat left top;
		background-size:100% auto;
		position:absolute;
		top:0;
		right:0;
		transform:translateY(-60%);
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list:after{
		content:'';
		display:block;
		width:135px;
		height:135px;
		background:url(../images/cont1_bg.png)no-repeat left top;
		background-size:100% auto;
		position:absolute;
		bottom:0;
		left:0;
		z-index:-1;
		transform:translate(-30%,30%);
	}

	#cont1 .flex_wrapper .fig_wrapper .fig_list li{
		width:100%;
		height:100%;
		position:absolute;
		opacity:0;
		transform:translateX(10%);
		-webkit-transition : opacity 0.4s, transform 0.4s;
		transition : opacity 0.4s, transform 0.4s;
	}
	#cont1 .flex_wrapper .fig_wrapper .fig_list li.active{
		opacity:1;
		transform:translateX(0);
	}
}


/* .cta */
.cta{
	padding:min(7%,90px) 0;
	background:url(../images/cta_bg.webp)no-repeat center center;
	background-size:cover;
}
.cta .flex_wrapper{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
.cta .flex_wrapper > figure{
	width:min(34%,404px);
}
.cta .flex_wrapper section{
	width:min(63%,756px);
}
.cta .flex_wrapper section h2{
	line-height:1.4;
	font-size:min(2.8vw,36px);
	font-weight:900;
	letter-spacing:0.1em;
	padding-left:0.1em;
	color:#fff;
	white-space:nowrap;
}
.cta .flex_wrapper section h2 .large{
	line-height:1.7;
	display:block;
	font-size:min(4vw,56px);
}
.cta .flex_wrapper section p{
	font-size:min(1.6vw,20px);
	font-weight:bold;
	letter-spacing:0.1em;
	padding-left:0.1em;
	color:#fff;
}
.cta .flex_wrapper section p span{
	margin-top:1em;
	display:inline-block;
	line-height:2.2;
	padding:0 0.5em;
	color:#231815;
}
.cta .flex_wrapper section dl{
	margin-top:8%;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}
.cta .flex_wrapper section dl div{
	width:49%;
	padding: 0 3% 3%;
	background-color:#fff;
	border-radius:0.5em;
}
.cta .flex_wrapper section dl div dt{
	padding-top:16%;
	font-size:min(1.5vw,18px);
	font-weight:900;
	letter-spacing:0.1em;
	text-indent:0.1em;
	position:relative;
	z-index:2;
}
.cta .flex_wrapper section dl div dt figure{
	width:5em;
	height:5em;
	margin:auto;
	background-color:#fff;
	border-radius:100%;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	position:absolute;
	left:50%;
	top:0;
	z-index:-1;
	transform:translate(-50%,-40%);
}
.cta .flex_wrapper section dl div dt figure img{
	width:2.6em;
}
.cta .flex_wrapper section dl div dt span{
	font-size:min(2vw,24px);
}
.cta .flex_wrapper section dl div dd p{
	line-height:1.5;
	height:6em;
	margin:1em 0 1em;
	font-size:min(1.3vw,16px);
	font-weight:bold;
	letter-spacing:0.1em;
	padding-left:0.1em;
	color:#231815;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

@media screen and (max-width:750px){
	.cta{
		padding:12% 0;
		background:url(../images/cta_bg_s.webp)no-repeat center center;
		background-size:cover;
	}
	.cta .flex_wrapper{
		width:88%;
		display: block;
	}
	.cta .flex_wrapper > figure{
		width:auto;
		padding:0 15%;
	}
	.cta .flex_wrapper section{
		width:auto;
		margin-top:9%;
	}
	.cta .flex_wrapper section h2{
		font-size:6.6vw;
	}
	.cta .flex_wrapper section h2 .large{
		font-size:11vw;
	}
	.cta .flex_wrapper section p{
		font-size:4.1vw;
	}
	.cta .flex_wrapper section p span{
		margin:1em 0 0.3em;
		line-height:2;
		font-size:4.7vw;
	}
	.cta .flex_wrapper section dl{
		margin-top:12%;
		display: block;
	}
	.cta .flex_wrapper section dl div{
		width:auto;
		margin-top:16%;
		padding: 0 7% 7%;
	}
	.cta .flex_wrapper section dl div dt{
		padding-top:12%;
		font-size:4.6vw;
	}
	.cta .flex_wrapper section dl div dt figure{
		width:4.8em;
		height:4.8em;
	}
	.cta .flex_wrapper section dl div dt figure img{
		width:2.6em;
	}
	.cta .flex_wrapper section dl div dt span{
		font-size:6.1vw;
	}
	.cta .flex_wrapper section dl div dd p{
		height:auto;
		margin:0.6em 0;
		font-size:4.1vw;
	}
}


/* #cont2 */
#cont2{
}
#cont2 .lead{
	margin-top:min(4%,50px);
	text-align:left;
	letter-spacing:0.1em;
}
#cont2 .fig{
	width:min(70%,688px);
	margin-top:min(4%,50px);
}
#cont2 .merit{
	max-width:1240px;
	width:98%;
	margin-top:min(4%,50px);
	display: -webkit-flex;
	display: flex;
}
#cont2 .merit li{
	width:33.33%;
	padding:0 2%;
	text-align:left;
}
#cont2 .merit li:nth-child(n+2){
	border-left:3px dotted #C0C0C0;
}
#cont2 .merit li .num{
	line-height:2;
	display:inline-block;
	padding:0 0.8em;
	font-size:min(1.6vw,16px);
	letter-spacing:0.1em;
	text-indent:0.1em;
}
#cont2 .merit li .num:before{
	content:'MERIT';
	margin-right:0.3em;
}
#cont2 .merit li h3{
	margin-top:0.3em;
	font-size:min(2.7vw,32px);
	font-weight:900;
	letter-spacing:0.1em;
	white-space:nowrap;
}
#cont2 .merit li p{
	margin-top:1em;
	letter-spacing:0.1em;
}

@media screen and (max-width:1200px){
	#cont2 .lead br{
		display:none;
	}
}

@media screen and (max-width:750px){
	#cont2 .tit .jp{
		margin-top:0.1em;
		font-size:9.2vw;
		white-space:nowrap;
	}
	#cont2 .lead{
		margin-top:7%;
	}
	#cont2 .fig{
		width:94%;
		margin-top:9%;
	}
	#cont2 .merit{
		width:92%;
		margin-top:min(4%,50px);
		display: block;
	}
	#cont2 .merit li{
		width:auto;
		padding:6% 0;
	}
	#cont2 .merit li:nth-child(n+2){
		border-left:none;
		border-top:3px dotted #C0C0C0;
	}
	#cont2 .merit li .num{
		line-height:2;
		padding:0 0.8em;
		font-size:4.1vw;
	}
	#cont2 .merit li h3{
		margin-top:0.3em;
		font-size:6.6vw;
	}
	#cont2 .merit li p{
		margin-top:1em;
		letter-spacing:0.1em;
	}
}


/* .cta2 */
.cta2{
	padding-top:min(4%,40px);
	background:#F4C917 url(../images/cta2_bg.png)no-repeat center bottom;
	background-size:1440px auto;
}
.cta2 .flex_wrapper{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	-webkit-flex-direction: row-reverse;
	flex-direction: row-reverse;
}
.cta2 .flex_wrapper section{
	width:min(47%,550px);
	padding-bottom:3%;
}
.cta2 .flex_wrapper section h2{
	line-height:1.4;
	font-size:min(3vw,36px);
	font-weight:900;
	letter-spacing:0.1em;
	padding-left:0.1em;
	white-space:nowrap;
}
.cta2 .flex_wrapper section .btn{
	width:86%;
	margin:1em auto 0;
}
.cta2 .flex_wrapper section .btn img{
	width:0.6em;
}
.cta2 .flex_wrapper figure{
	width:min(50%,607px);
}

@media screen and (max-width:1440px){
	.cta2{
		background-size:100% auto;
	}
}

@media screen and (max-width:750px){
	.cta2{
		padding-top:15%;
		background:#F4C917 url(../images/cta2_bg_s.png)no-repeat center center;
		background-size:100% auto;
	}
	.cta2 .flex_wrapper{
		display: block;
		width:90%;
	}
	.cta2 .flex_wrapper section{
		width:auto;
		padding-bottom:3%;
	}
	.cta2 .flex_wrapper section h2{
		font-size:6.6vw;
	}
	.cta2 .flex_wrapper section .btn{
		width:100%;
		line-height:1.4;
		margin:7% auto 12%;
		padding:1em 0;
	}
	.cta2 .flex_wrapper section .btn span{
		display:inline-block;
		text-align:left;
	}
	.cta2 .flex_wrapper section .btn img{
		width:0.9em;
		margin-left:0.3em;
		vertical-align:0.6em;
	}
	.cta2 .flex_wrapper figure{
		width:auto;
	}
}


/* footer */
footer{
	padding:min(7%,70px) 0 150px;
	background-color:#fff;
}
footer .links{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}
footer .links li{
	line-height:1.3;
	padding:0 1.2em;
	font-size:min(1.6vw,16px);
	font-weight:900;
}
footer .links li:nth-child(n+2){
	border-left:3px solid;
}
footer .links li a{
	letter-spacing:0.04em;
	text-indent:0.04em;
	text-decoration:underline;
}
footer .foot_logo{
	margin:min(5%,50px) auto;
	width:min(31%,310px);
}
footer .copy{
	font-size:min(1.3vw,13px);
}

@media screen and (max-width:750px){
	footer{
		padding:15% 5% 30%;
	}
	footer .links li{
		margin-top:1em;
		font-size:4vw;
	}
	footer .links li:nth-child(n+2){
		border-left:0.8vw solid;
	}
	footer .links li:nth-child(4){
		border-left:none;
	}
	footer .links li a{
		letter-spacing:0.04em;
		text-indent:0.04em;
		text-decoration:underline;
	}
	footer .foot_logo{
		margin:9% auto;
		width:60%;
	}
	footer .copy{
		font-size:3.2vw;
	}
}


/* #bottom_nav */
#bottom_nav{
	width:702px;
	border-radius:0.4em;
	display: -webkit-flex;
	display: flex;
	position:fixed;
	bottom:-300px;
	left:50%;
	z-index:100;
	transform:translateX(-50%);
	-webkit-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
#bottom_nav div{
	width:50%;
	padding: 1.5% 2.5%;
	position:relative;
}
#bottom_nav div:first-child:after{
	content:'';
	display:block;
	width:1px;
	height:60%;
	border-right:3px dotted #C0C0C0;
	position:absolute;
	right:0;
	top:50%;
	transform:translateY(-50%);
}
#bottom_nav div dt{
	font-size:min(1.2vw,14px);
	font-weight:900;
}
#bottom_nav div dt img{
	width:2em;
	margin-right:0.3em;
	vertical-align:-0.5em;
}
#bottom_nav div dt span{
	font-size:min(1.5vw,18px);
}
#bottom_nav div dd .btn{
	line-height:3.4;
	font-size:min(1.4vw,16px);
}

@media screen and (max-width:750px){
	#bottom_nav{
		width:100%;
		padding:0 1%;
		border-radius:0;
		left:0;
		bottom:0;
		transform:none;
	}
	#bottom_nav div{
		width:50%;
		padding: 2.5% 2%;
		position:static;
	}
	#bottom_nav div:first-child:after{
		content:none;
	}
	#bottom_nav div dt{
		font-size:3.1vw;
	}
	#bottom_nav div dt img{
		display:none;
	}
	#bottom_nav div dt span{
		font-size:3.6vw;
	}
	#bottom_nav div dd .btn{
		line-height:3;
		font-size:3.6vw;
	}
	#bottom_nav .btn.bg_green{
		background:#00B900;
	}
	#bottom_nav .btn.bg_blue{
		background:#1A6FC9;
	}
}


/* fadein */
.fadein {
	opacity : 0;
	-webkit-transform : translate(0, 40px);
	transform : translate(0, 40px);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_0 {
	opacity : 0.01;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_l {
	opacity : 0;
	-webkit-transform : translate(-50px, 0);
	transform : translate(-50px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_r {
	opacity : 0;
	-webkit-transform : translate(50px, 0);
	transform : translate(50px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
@media screen and (max-width:750px){
	.fadein_l,
	.fadein_r {
		-webkit-transform : translate(0, 40px);
		transform : translate(0, 40px);
	}
}


.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;
}

.fadein.scrollin,
.fadein_0.scrollin,
.fadein_l.scrollin,
.fadein_r.scrollin{
	opacity : 1;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
}
