body{
	background-color: #09090d;
	color: #fff;
}
#wrapper{
	width: 100%;
    height: 100%;
    font-family: 'Frank Ruhl Libre', serif;
    font-family: 'Noto Serif JP', serif;
}
#particles-js{ 
	position:fixed;/*描画固定*/
	z-index:1;/*描画を一番下に*/
	width: 100%;
	height: 100%;
	mix-blend-mode: screen;
}
/***************** font **********************/
body{
font-size: clamp(14px, 1.8vw, 18px);
text-justify: inter-character;
}
.font_midashi{
	font-size: clamp(32px, 6.5vw, 80px);
	letter-spacing: -3px;

}
.font_midashi-2{
	font-size: clamp(18px, 3vw, 30px);
	line-height: 2.5;
}
.font_small{
	font-size: clamp(10px, 1vw, 10px);

}
/***************** 改行850より小さいとき改行をつける **********************/
.br_sp{display: none;}

@media screen and (max-width: 850px){
	.br_sp{
		display:block;
	}
}
/***************** header **********************/
header{
	position: fixed;
	z-index: 1000;
	width: 100%;
	padding: 0 2.14vw 0;
	opacity: 0;
}
header > .content{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}
header > .content > h1{
	width:8.5vw;
}
/*****  *****/
.icon{
	display: flex;
	flex-direction: row;
	width: 8vw;
}

.icon li a{
	text-align: center;
	display: block;
	background-color: #09090d;
	padding: 5px;

}
.icon li a img{
	margin:0 auto;
}
.lang_switch{
	display: flex;
	flex-direction: row;
}
.twitter{
	margin-right: 1vw;
	border-radius: 4px;
	overflow: hidden;
	border: 1px solid #7979c9;
	max-width: 80px;
}
.lang_switch{
	border-radius: 4px;
	overflow: hidden;
	border: 1px solid #7979c9;
	max-width: 160px;
}
.active a{background-color: #7979c9 !important;}



@media screen and (max-width: 850px){
	header > .content > h1{
	width:25vw;
}
	.icon{
	width: 25vw;
}

}
/***************** nav **********************/
nav{position: fixed;
	z-index: 99;
	bottom: 0;
	width: 100%;
	display: block;
	overflow: hidden;	
}
nav img{position: relative;
	z-index: 1;

	width: 22.3vw;
margin-left: 77.7vw;
opacity: 0;}

.btn_overlay{
	background: rgb(0,0,0);
background: linear-gradient(0deg, rgba(0,0,0,0.8981967787114846) 0%, rgba(0,0,0,0) 60%);
position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}
.fixed {
   /* position: fixed;
    bottom: 0;
    width: 100%;*/
}
@media screen and (max-width: 850px){
	nav img{position: relative;
	z-index: 1;

	width: 50vw;
margin-left: 50vw;}
}
/***************** kv **********************/
#kv{

}
.kv_content{
	position:relative;
	/*padding: 9vw 0 24vw;
    perspective: 52.08334vw;*/
    height: 65vw;
    z-index: 0;
}
.kv_img{
	background-image: url(../img/kv_pc.png);
	height: 100%;
    background-size: cover;
    background-position: top left;
    background-repeat: no-repeat;
    opacity: 0;
}
.kv_img
 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
    z-index: 1;
    content: '';
}
@media screen and (max-width: 850px){
	.kv_content{
	position:relative;
	/*padding: 9vw 0 24vw;
    perspective: 52.08334vw;*/
    height: 90vw;
    z-index: 0;
    padding: 100vw 0;
}
.kv_img{
	background-image: url(../img/kv_sp.png);
	height: 100%;
    background-size: cover;
    background-position: top left;
    background-repeat: no-repeat;
    opacity: 0;
}
}

.kv_content::before, .kv_content::after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
    z-index: 1;
    content: '';
}
.kv_logo{
	position:absolute;
	z-index: 2;
	width: 30vw;/*1400pxで415px*/	
	opacity: 0;
	top: 25vw;
	left: 52vw;
}
.kv_catch{
	opacity: 0;
	position: absolute;
	z-index: 1;
	top: 11vw;
	left: 45vw;
	width: 45vw;
	/*padding-bottom: 20.8vw;*/
	
}

@media screen and (max-width: 850px){
.kv_logo{
	position:absolute;
	z-index: 2;
	width: 65vw;/*1400pxで415px*/	
	opacity: 0;
	top: 100vw;
  left: 55%;
  transform: translateX(-50%);
  -webkit- transform: translateX(-50%);
}
.kv_catch{
	position:absolute;
	z-index: 2;
	width: 100%;/*1400pxで415px*/	
	opacity: 0;
	top: 180vw;
  left: 0;

}

}





#main{
	position: relative;
	background-image: url(../img/bg_about.png);
	/*padding-top: 3.75vw;*/
    padding-bottom: 7vw;
    background-position: top center;
    background-repeat: no-repeat;
    background-size: 100% auto;  
}
.about_content{
	max-width: 1300px;
	margin: 0 auto;
	position: relative;
	    padding: 8vw 5vw 3.02084vw 5vw;
}
.abouttit_bg{
	width: 100vw;
  margin: 0 calc(50% - 50vw);
position: absolute;
top: 0;
}
.abouttit_bg img{
	width: 100%;
}
.about_content h2{
	text-align: center;
}
.about_content .title_about{
	position: relative;
	z-index: 1;
	display: block;
	text-align: center;
	background: rgb(107,114,217);
background: linear-gradient(90deg, rgba(107,114,217,1) 0%, rgba(220,171,97,1) 100%); /* 背景色にグラデーションを指定 */
  color: red; /* 非対応のブラウザの為に色を設定 */
  -webkit-background-clip: text; /* テキストで切り抜く */
  -webkit-text-fill-color: transparent; /* 切り抜いた部分は背景を表示 */
}
.about_content .title_about {
/*font-size:5vw ;*/
}

.about_content h3{
	margin-top: 6vw;
	margin-bottom: 8vw;
}
.about_content h3 p{
	text-align: center;
	font-weight:500;
	position: relative;
	z-index: 1;
}
@media screen and (max-width: 850px){
	#main{
    background-position: bottom center;
    background-size: cover;
}
	.about_content{
	position: relative;
	    padding: 40vw 4.9vw 3.02084vw 4.9vw;
}


.abouttit_bg{

top: 30vw;
}
.title_about{
	width: 100vw;
  margin: 0 calc(50% - 50vw);
}

	.about_content .title_about span{
	display: inline-block;
}

.about_content h3{
	width: auto;
	margin: 20vw 0 30vw;
}
.about_content h3 p{
	/*font-size: 4vw;*/
}
}




.about_lead{	
	margin-top:5.11vw ;
	line-height: 1.8;
}
.about_lead_center{
	margin-top:5.11vw ;
	line-height: 1.8;
	text-align: center;
}
.about_lead dl{
	display: flex;
	flex-direction: row;
	align-items: center;


}
.about_lead dl dt{
	margin-right: 2vw;
}
.font_common{/*font-size: 1.29vw;*/}
.font_schedule{/*font-size: 2.2vw;*/}

.title_card{
	width: 13vw;
}
@media screen and (max-width: 850px){
	.about_lead{	
	
	margin-top:8vw ;
	width: 100%;
	line-height: 1.8;
}
.about_lead dl{
	display: flex;
	flex-direction:column;
	align-items:center;
}

.kachi{flex-direction:column-reverse !important;}

.title_card{
	width: 25vw;
}
.about_lead dl dt{
	margin-right: 0;
	margin-bottom: 2vw;
}
.font_common{/*font-size: 3vw;*/}
.font_schedule{/*font-size: 4vw;*/}
}

.howto_x{

}
.howto_bf{
	background-image: url(../img/bg_line.png) ;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top right;
	width: 100vw;
  margin: 0 calc(50% - 50vw);
/*background-color: #FF0000;*/

}
.howto_bf_innner{
	max-width: 1300px;
	margin: 0 auto;
	position: relative;
	 padding: 8vw 5vw 3.02084vw 5vw;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: flex-end;
}
.howto_bf_innner div{
	width: 50%;
  text-shadow: 4px 4px 4px #000, -4px -4px 4px #000,
  -4px 4px 4px #000,  4px -4px 4px #000,
  4px 0 4px #000, -4px  0 4px #000,
  0 4px 4px #000,  0 -4px 4px #000;

}
.howto_bf h4{
	padding-bottom:1vw ;
	margin-bottom: 1vw;
	border-bottom: 1px solid #fff;
}
.x-img{
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
}

.x-img .left{
	width: 50px;
	margin-right: 20px;
}
.x-img .left img{
	width: 100%;
}

@media screen and (max-width: 850px){
	.howto_bf{
	background-image: url(../img/bg_line_sp.png) ;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center 0;
	width: 100vw;
  margin: 0 calc(50% - 50vw);
/*background-color: #FF0000;*/

}
.howto_bf_innner{
	 padding: 8vw 5vw 3.02084vw 5vw;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-start;
}
.howto_bf_innner div{
	width: 100%;
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);

}
.howto_bf_innner .left{
	margin-bottom: 4vw;
	padding-top: 100px;
}

.howto_x{
	margin: 30vw 0 20vw;

}
.x-img .left{
	width: 30px;
	margin-right: 20px;
}
}


#product{
	background-image: url(../img/bg_product.png);
	/*height: 39.375vw;*/
	position: relative;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    overflow: hidden;
}
.product_content{
	max-width: 1300px;
	margin: 0 auto;
	padding: 8vw 4.53125vw 8vw 4.53125vw;
	position: relative;
	z-index: 1;

}
.product_list{
	width: 40vw;
}
.product_list .detail{
	display: flex;
	align-items: center;
	/*font-size: 0.8vw;*/
	padding: 1.5vw;
	border-top: solid 1px #fff;
}
.product_list .detail:last-child{
	border-bottom: solid 1px #fff;
}
.product_list .detail p{display: inline-block;}

.product_list .detail .left{
	width: 12vw;
}
.product_list .detail .right{

}

small{
	display: block;
	margin-top: 3vw;
	padding-bottom:1vw ;
	/*font-size: 0.6vw;*/
	text-align: center;
}
#footer{
	position: relative;
	background-color: #09090d;
	width: 100%;
}
.footer_content{
	margin: 0 auto;
	padding: 4vw 0 10vw}

.footer_link{
	padding-bottom: 2vw;
	margin-bottom: 2vw;
	text-align: center;
}
.footer_link a:link,
.footer_link a:hover,
.footer_link a:visited{
	/*font-size: 0.8vw;*/
	color: #fff;
	text-decoration: none;
}

.brands {
	width: 30vw;
	margin: 4vw auto 0 !important;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
grid-template-rows: 1fr;
grid-column-gap: 20px;
grid-row-gap: 0px;
}
.brands__item img {
    display: block;
    /* Make sure max-width is added */
    object-fit: contain;
    max-width: 100%;
    height: 45px;
}
.brands__item a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    border-radius: 8px;
    padding: 20px 0;
}
@media screen and (max-width: 850px){
	.footer_content{
	margin: 0 auto;
	padding: 10vw 0 35vw}

	.brands {
	width: 100%;
	margin: 8vw auto !important;
}

	.brands__item img {
    display: block;
    /* Make sure max-width is added */
    object-fit: contain;
    max-width: 100%;
    height: 30px;
}

	#product{
	background-image: url(../img/bg_product.png);
	position: relative;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    overflow: hidden;
}
.product_content{
	padding: 18vw 4.9vw ;
	position: relative;
	z-index: 1;

}
.product_list{
	width:100%;
}
.product_list .detail{
	/*font-size: 2.5vw;*/
	padding: 5vw 2vw;
	border-top: solid 1px #fff;
}
.product_list .detail .left{
	width: 23vw;
}
.product_link li{
	width: 100%;
}
.product_link li img{
	width: 10vw;

}
small{
	display: block;
	margin-top: 3vw;
	/*font-size: 2vw;*/
}
.footer_link a:link,
.footer_link a:hover,
.footer_link a:visited{
	/*font-size: 2.5vw;*/
	color: #fff;
	text-decoration: none;
}
}

