@charset "utf-8";
/* ヘッダー */
header {
	position: relative;
	margin: 0 auto;
	display: block;
	width: 100%;
}
header .attention{
	position: relative;
	margin:  0 auto;
	padding: 5px 10px;
	text-align: center;
	background-color: #036A44;
	font-size: 90%;
	line-height: 1.8em;
	font-weight: 500;
	opacity: 0;
}
header .attention p, header .attention a{color: #ffffff;}
header .attention.display{opacity: 1;transition: opacity .5s ease-out;}

header #keyvisual{
	position: relative;
	margin: 0 auto;
	width: 100%;
	padding-top: 141.40625%;
	overflow: hidden;
}
header #keyvisual01 {
	position: absolute;
	top:0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-image: url("../img/main.jpg");
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: cover;
	clip-path: circle(0 at 50% 50%);
}
header #keyvisualbg{
	position: absolute;
	top:50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 0;
	height: 0;
	opacity: 0;
	outline: solid 3px #08F4A8;
	outline-offset: -1px;
	border-radius: 50%;
	box-shadow: 0px 0px 24px -2px rgba(0,238,104,1) inset;
	background-image: url("../img/bg_eye.png");
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: cover;
	z-index: 100;
}
header #keyvisual01.display{animation: keyDisplay 4s ease 0s 1 normal forwards;}
header #keyvisualbg.display{animation: keyDisplaybg 4s ease 0s 1 normal forwards;}
@keyframes keyDisplay {
	0% {
		clip-path: circle(0 at 50% 50%);
	}
	8%, 18% {
		clip-path: circle(90px at 50% 50%);
	}
	25%{
		clip-path: circle(0 at 50% 50%);
	}
	30%, 38%{
		clip-path: circle(90px at 80% 20%);
	}
	45%{
		clip-path: circle(0 at 80% 20%);
	}
	65%{
		clip-path: circle(90px at 90% 80%);
	}
	80%{
		clip-path: circle(90px at 20% 80%);
	}
	90%{
		clip-path: circle(90px at 50% 50%);
	}
	95%{
		clip-path: circle(0 at 50% 50%);
	}
	100%{
		clip-path: circle(100% at 50% 50%);
	}
}
@keyframes keyDisplaybg {
	0%, 100% {
		width: 0;
		height: 0;
		opacity: 0;
		top:50%;
		left: 50%;
	}
	8%, 18% {
		width: 180px;
		height: 180px;
		top:50%;
		left: 50%;
		opacity: 1;
	}
	25% {
		width: 0;
		height: 0;
		opacity: 0;
		top:50%;
		left: 50%;
	}
	30%, 38%{
		top: 20%;
		left: 80%;
		width: 180px;
		height: 180px;
		opacity: 1;
	}
	45% {
		width: 0;
		height: 0;
		opacity: 1;
		top: 20%;
		left: 80%;
	}
	65%{
		top:80%;
		left: 90%;
		width: 180px;
		height: 180px;
		opacity: 1;
	}
	80%{
		top:80%;
		left: 20%;
		width: 180px;
		height: 180px;
		opacity: 1;
	}
	90%{
		top: 50%;
		left: 50%;
		width: 180px;
		height: 180px;
		opacity: 1;
	}
	95%{
		width: 0;
		height: 0;
		opacity: 0;
	}
}
header #keyvisual02 {
	position: absolute;
	top:0;
	left: 0;
	display: block;
	background-image: url("../img/main01.jpg");
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: cover;
	width: 100%;
	height: 100%;
	opacity: 0;
}


/* catch */
#catch {
	position: relative;
	margin: 0 auto;
	padding-bottom: 20px;
	background-image: url("../img/bg_catch.jpg");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: cover;
	opacity: 0;
}
#catch.display{opacity: 1;transition: opacity .5s ease-out;}
#catch .catch{
	position: relative;
	width: 100%;
	max-width: 640px;
	margin: 0 auto;
}
#catch .catch img{
	position: relative;
	margin: 0 auto;
}

/* photo */
#photo {
	position: relative;
	margin: 0 auto;
	padding: 0;
}
#photo .photoWrap {
	position: relative;
	margin: 0 auto;
	padding: 0;
}
.splide__list {height: auto;}


/* cm */
#cm{
	position: relative;
	margin: 0 auto;
}
#cm .movieWrap{max-width: 100%;}
#cm .movie{
	background-image: url('http://i.ytimg.com/vi/2TY1yBrjnNI/maxresdefault.jpg');
	background-position: 50% 50%;
	background-size: cover;
	background-repeat: no-repeat;
	opacity: 0.6;
}
#cm .mBtn{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
}
#cm .mBtn img{
	position: absolute;
	top:50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 50%;
	max-width: 100px;
	transition: transform .3s ease-out;
}
#cm .mBtn img:hover{transform: translate(-50%, -50%) scale(1.04, 1.04);}
#cm .mBtn::before{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
	mix-blend-mode: overlay;
	background-image: url("../img/cm_cover.png");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	content: '';
}

/* ポイント */
#point{
	position: relative;
	margin: 0 auto;
	padding-top: 30px;
}
#point h2{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#point ul{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 1100px;
}
#point ul li{
	position: relative;
	margin: 0 auto 20px auto;
	width: 100%;
	gap: 10px 0;
}
#point ul li .Img{
	position: relative;
	margin: 0;
	width: 100%;
}
#point ul li .Txt{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
	gap:0 10px;
}
#point ul li .Txt.order{flex-direction:row-reverse;}
#point ul li .Txt .ttl{
	position: relative;
	margin: 0;
	padding-right: 8px;
	width: 1.2em;
	text-align: center;
	border-right: solid 1px #0f8b6c;
	font-size: 120%;
	line-height: 1.2em;
}
#point ul li .Txt.order .ttl{
	padding-right: 0;
	padding-left: 8px;
	border-left: solid 1px #0f8b6c;
	border-right:none;
}
#point ul li .Txt .ttl span{
	color: #32f5c5;
	font-size: 140%;
	line-height: 2em;
}
#point ul li .Txt .pointTXt{
	position: relative;
	margin: 0;
	padding: 0;
	width: calc(100% - 1.8em - 19px);
}
#point ul li .Txt .pointTXt .catch{
	position: relative;
	padding-bottom: 8px;
	color: #32f5c5;
	font-size: min(3.75vw, .18rem);
}
#point ul li .Txt .pointTXt .text{
	position: relative;
	font-size: min(3.3vw, .14rem);
	line-height: 1.6em;
}
#point .Img.bgmovie{
	padding: 5px 0;
	background-image: url("../img/point01.png");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: 50% 50%;
}
#point .Img .pointmovie{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
}
#point .Img .pointmovie video{ border: solid 1px #089d9f;}

/* ストーリー */
#story {
	position: relative;
	margin: 0 auto;
	padding: 15px 0 80px 0;
	z-index: 10;
}
#story::before{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
	content: '';
	display: block;
	background-image: url("../img/bg_story.png");
	background-size: 100% auto;
	background-repeat: repeat-y;
	background-position: 50% 50%;
	background-color: #06242d;
	clip-path: polygon(0 70px, 100% 0%, 100% calc(100% - 70px), 0% 100%);
}
#story .icon01{
	position: absolute;
	top:-20px;
	right: -10px;
	width: 23%;
}
#story .icon02{
	position: absolute;
	bottom:-20px;
	left: 10px;
	width: 42%;
}
#story h2{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#story .storyWrap {
	position: relative;
	margin: 0 auto;
}
#story .storyWrap .Txt{
	position: relative;
	margin: 0 auto;
	padding: 0 0 20px 0;
	width: calc(100% - 30px);
	text-align: center;
}
#story .storyWrap .Txt p{padding-top: 20px;}
#story .moretxt{
	position: relative;
	margin: 0 auto;
	display: none;
}
#story .btn_more{
	position: relative;
	margin: 30px auto 0 auto;
	border: solid 1px #94999C;
	font-size: 90%;
	color: #C7D1D6;
	width: 8em;
	padding: 2px 0;
	cursor: pointer;
	transition: all .3s ease-out;
}
#story .btn_more:hover{background-color: #73767B;}
#story .btn_more.disp{
	border: solid 1px #5A5C5C;
	color: #5A5C5C;
}
.contentsS{
	position: relative;
	opacity: 0;
	filter: blur(50);
	will-change: animation;
}
.contDispS{animation: fadeInS 1.8s ease-in 0.5s 1 normal forwards;}
@keyframes fadeInS {
	0%{opacity: 0;filter: blur(50);}
	50% { opacity: 0.5;filter: blur(40);}
	100% { opacity: 1;filter: blur(0);}
}

.bg{
	position: relative;
	margin: -20px auto 0 auto;
	padding-bottom: 90px;
	background: #00000f;
	background: linear-gradient(180deg,#00000f 0%, #002c1f 100%);
}
.bg::after{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
	content: '';
	display: block;
	background-image: url("../img/bg_eye.png");
	background-position: -220px 33%;
	background-repeat: no-repeat;
	background-size: 440px auto;
}
/* バナー */
#special{
	position: relative;
	margin: 0 auto;
	padding-top: 50px;
	z-index: 30;
}
#special h2{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#special .specialWrap {
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#special .specialWrap .splide__arrows .splide__arrow--prev {top: 40%;left: -5px;transform: rotate(180deg);}
#special .specialWrap .splide__arrows .splide__arrow--next {top: 40%;right: -5px;}
#special .specialWrap .splide__arrow {
	background: transparent;
	border-radius: 0;
	height: 59px;
	width: 35px;
	opacity: 1;
	transform: translateY(0);
}
#special .specialWrap .splide__arrow img{width: 15px;}
#special .specialWrap .splide__arrow:disabled {opacity: 0;}

#special .box{
	position: relative;
	margin: 20px auto 30px auto;
	width: calc(100% - 60px);
	max-width: 640px;
}
#special .specialWrap .box{margin: 20px auto 0 auto;}
#special a{
	position: relative;
	margin: 0 auto;
	display: block;
}
#special .border{border: solid 1px #B6B6B6;}

#special .previcon, #special .newicon{
	position: relative;
	display: block;
}
#special .newicon{margin: 20px auto 0 auto;}
/*#special .previcon::after, #special .newicon::after{
	position: absolute;
	top: -12px;
	left: -12px;
	content: '';
	width: 50px;
	height: 50px;
	display: block;
	background-position: 0 0;
	background-size: contain;
	background-repeat: no-repeat;
}
#special .previcon::after{background-image: url("../img/iconprev.png");}
#special .newicon::after{background-image: url("../img/iconnew.png");}
*/
/* 参加方法 */
#howto {
	position: relative;
	margin: 0 auto;
	padding-top: 50px;
	z-index: 10;
}
#howto h2{
	position: relative;
	margin: 0 auto;
	padding-top: 10px;
	width: 100%;
	max-width: 640px;
}
#howto .howtoWrap {
	position: relative;
	margin: 10px auto 0 auto;
	width: 100%;
	max-width: 1000px;
}
#howto .howtoWrap .splide__arrows .splide__arrow--prev {left: 5px;transform: rotate(180deg);}
#howto .howtoWrap .splide__arrows .splide__arrow--next {right: 5px;}
#howto .howtoWrap .splide__arrow {
	background: transparent;
	border-radius: 0;
	height: 59px;
	width: 35px;
	opacity: 1;
	transform: translateY(0);
}
#howto .howtoWrap .splide__arrow img{width: 15px;}
#howto .howtoWrap .splide__arrow:disabled {opacity: 0;}

#howto .howtoWrap ul li{
	position: relative;
	margin: 0;
	padding-top:40px;
	width: 100%;
	display: flex;
	align-items: stretch;
}
#howto .howtoWrap .ImgTtl {
	position: absolute;
	top: -35px;
	left: 0;
	width: 100%;
}
#howto .howtoWrap .ImgTtl img{
	position: relative;
	margin: 0 auto;
	height: 28px;
	width: auto;
}
#howto .howtoWrap .txtWrap {
	position: relative;
	margin: 0 auto;
	border: solid 1px #ffffff;
	padding-bottom: 20px;
	box-sizing: border-box;
	width: calc(100% - 80px);
}
#howto .howtoWrap .Img {
	position: relative;
	margin: 0 auto;
	width: 70%;
}
#howto .howtoWrap p{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
}
#howto .howtoWrap .ttl {
	color: #7bf532;
	text-align: center;
	line-height: 1.6em;
	font-size: .17rem;
	padding-bottom: 10px;
}
#howto .howtoWrap .button{
	width: calc(100% - 70px);
	margin: 20px auto 0 auto;
}
#howto .txtWrap .cautionWrap{
	position: relative;
	margin: 10px auto 0 auto;
	width: calc(100% - 10px);
}
#howto .txtWrap .cautionWrap p{
	position: relative;
	padding-left: 1.1em;
	font-size: 86%;
}
#howto .txtWrap .cautionWrap p::before{
	position: absolute;
	top:0;
	left: 0;
	content: '※';
}
#howto #stream{
	position: relative;
	margin: 45px auto 0 auto;
	text-align: center;
}
#howto #stream .button{
	margin: 20px auto 20px auto;
	width: calc(100% - 70px);
}
#howto #stream .button p{position: relative;padding: 10px 0;}
/*#howto #stream .button p::after{
	position: absolute;
	top: -15px;
	left: -30px;
	content: '';
	width: 40px;
	height: 40px;
	display: block;
	background-image: url("../img/iconnew.png");
	background-position: 0 0;
	background-size: contain;
	background-repeat: no-repeat;
}*/
#howto .first{
	position: relative;
	margin: 40px auto;
	width: calc(100% - 30px);
	max-width: 800px;
	border: solid 1px #ffffff;
}

/* product */
#product{
	position: relative;
	margin: -70px auto 0 auto;
	padding: 0 0 40px 0;
}
#product .bg{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url("../img/bg_product.jpg");
	background-position: 0 0;
	background-size: contain;
	background-repeat: repeat;
	clip-path: polygon(0 70px, 100% 0%, 100% 100%, 0% 100%);
}
#product .bg::after{display: none;}
#product h2{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#product #item{
	position: relative;
	margin: 20px auto;
	width: calc(100% - 30px);
	max-width: 600px;
}
#product #item ul{
	position: relative;
	margin: 0 auto;
	padding-bottom: 1em;
	gap: 0 10px;
}
#product #item ul li{
	position: relative;
	margin: 0;
	padding: 8px 0;
	line-height: 1em;
	width: calc(50% - 7px);
	border: solid 1px #7bf532;
	text-align: center;
	cursor: pointer;
	transition: all .3s ease-out;
}
#product #item ul li:hover{background-color: #7bf532;color: #00000f;}
#product #item ul li.active{
	background-color: #7bf532;
	color: #00000f;
}
#product #item ul li.active::after{
	position: absolute;
	bottom: -0.8em;
	left: 50%;
	transform: translateX(-50%) scale(1, 0.9);
	content: '\025bc';
	color: #7bf532;
}
#product #item ul li p{position: relative;}
#product #itemImg{
	position: relative;
	margin: 0 auto 25px auto;
	width: 100%;
	max-width: 960px;
}
#product #itemImg .tab{position: relative;display: none;}
#product #itemImg .tab.active{display: block;}
#product #itemImg .price{
	position: relative;
	margin: 0 auto;
	padding:10px 0;
	text-align: center;
}
#product #itemImg .price span{font-size: 220%;}
#product #itemImg .tab .flexbox{gap: 0 20px;}
#product #itemImg .tab .Img{
	position: relative;
	margin: 0 0 10px 0;
	width: 100%;
	max-width: 380px;
}
#product #itemImg .tab .item{
	position: relative;
	margin: 0;
	width: 100%;
	max-width: 550px;
}
#product #itemImg  .tab .button{ margin: 15px auto;font-size: 96%;color: #00000f;cursor: pointer;transition: all .3s ease-out;}
#product #itemImg  .tab a{display: block;}
#product #itemImg .tab .item h3{
	position: relative;
	margin: 20px auto 10px auto;
	color: #7bf532;
	border-bottom: solid 1px #7bf532;
	font-size: 120%;
	padding: 0 5px;
}
#product #itemImg .tab .item .lists{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
}
#product #itemImg .tab .item .margin{padding: 20px 0 0 0;}

#product #game{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
	gap: 10px 0;
	max-width: 960px;
}
#product #game dt{
	position: relative;
	margin: 15px 0 0 0;
	background-color: #0f8b6c;
	color: #00000f;
	text-align: center;
	font-weight: 900;
	line-height: 1em;
	padding: 8px 0;
	width: 100%;
}
#product #game dd{
	position: relative;
	margin: 0;
	width: 100%;
	text-align:center;
}
#product #game dd.play{gap: 20px;}
#product #game dd.play .Img{
	position: relative;
	margin: 0;
	width: 20%;
	max-width: 100px;
}
#product #game dd.play .Txt{
	position: relative;
	margin: 0;
	width: calc(80% - 40px);
	padding-top: 1em;
	text-align: left;
}
#product #game dd.pricelist{gap: 5px 20px;}
#product #game dd.pricelist p{
	position: relative;
	margin: 0;
	width: calc(50% - 10px);
}

#product .tokuten{
	position: relative;
	margin: 50px auto 0 auto;
	text-align: center;
	width: calc(100% - 30px);
}
#product .tokuten h3{
	position: relative;
	margin: 0 auto 15px auto;
	width: 100%;
	max-width: 640px;
}
#product .tokuten .Img{
	position: relative;
	margin: 10px auto 0 auto;
	max-width: 800px;
}
#product .tokuten .cautionWrap{
	position: relative;
	margin: 10px auto 0 auto;
	max-width: 560px;
	text-align: left;
}
#product .scrapdan{
	position: relative;
	margin: 30px auto 0 auto;
}
#product .scrapdan p{
	position: relative;
	font-size: 90%;
}
#product .scrapdan img{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
	max-width: 380px;
}

/* env */
#precautions .bg{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #00000f;
	background: linear-gradient(180deg,#00000f 0%, #002c1f 100%);
	clip-path: polygon(0 70px, 100% 0%, 100% calc(100% - 70px), 0% 100%);
}
#precautions .bg::after{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
	content: '';
	display: block;
	background-image: url("../img/bg_eye.png");
	background-position: calc(100% + 220px) 100%;
	background-repeat: no-repeat;
	background-size: 440px auto;
}
#env table{
	position: relative;
	margin: 5px auto 10px auto;
	width: calc(100% - 30px);
	max-width: 960px;
}
#env table tr, #env table tr th, #env table tr td {position: relative;text-align: center;}
#env table tr th{
	padding: 5px 10px;
	background-color: #0f8b6c;
	border: solid 1px #32f5c5;
}
#env table tr td{
	width: 50%;
	padding: 10px;
	border: solid 1px #32f5c5;
}
#env h3{
	position: relative;
	margin: 0 auto;
	width: 100%;
	text-align: center;
	color: #32f5c5;
	font-size: 120%;
	padding: 0;
}
#env .cautionWrap{
	position: relative;
	margin: 0 auto 0 auto;
	width: calc(100% - 30px);
	max-width: 830px;
}
#env .testenv .cautionWrap{
	margin:10px auto 0 auto;
	width: 100%;
	max-width: 620px;
}
#env .testenv{
	position: relative;
	margin: 50px auto 0 auto;
	width: calc(100% - 30px);
}
#env .testenv p{font-size: 100%;}
#env .testenv .trial{
	position: relative;
	margin: 0 auto 20px auto;
}

/* FAQ */
#precautions {
  position: relative;
  margin: 0 auto;
  padding: 70px 0 40px 0;
}
#precautions .precautionWrap{
	position: relative;
	margin: 0 auto 21px auto;
	width: calc(100% - 30px);
	max-width: 960px;
	border: solid 1px #ffffff;
}
#precautions .precautionWrap .ttl{
	position: relative;
	margin: 0 auto;
	padding: 10px 0 ;
	text-align: center;
	cursor: pointer;
	font-size: 140%;
}
#precautions .precautionWrap .ttl img{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 580px;
}
#precautions .ttl::after{
	position: absolute;
	top:50%;
	right: 10px;
	content: '';
	display: block;
	transition: all .3s ease-out;
	transform: translateY(-50%);
	height: 7px;
	width: 13px;
	background-image: url("../img/arrow02.png");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: 50% 50%;
}
#precautions .ttl.disp::after{transform: translateY(-50%) rotate(-180deg);}
#precautions .faqWrap{
	position: relative;
	margin: 0 auto;
	padding: 0;
	height: 0;
	overflow: hidden;
	transition: all .3s ease-out;
	z-index: 9;
}
#precautions .CatTtl{
	position: relative;
	margin: 0 auto;
	padding: 3px 10px;
	width: calc(100% - 45px);
	max-width: 800px;
	text-align: center;
	font-size: 102%;
	font-weight: 700;
	color: #32f5c5;
	border-bottom: solid 1px #32f5c5;
}
#precautions .CatTtl.marginTop{margin: 20px auto 0 auto;}
#precautions #limitlist p.lead{width: calc(100% - 30px);max-width: 800px;margin: 5px auto 0 auto;}
#precautions  #limitlist .CatTtl{margin: 30px auto 0 auto;}
#precautions  #limitlist .CatTtl.margin{margin: 30px auto 10px auto;}
#precautions .faqWrap.disp{height: auto !important;padding: 20px 0; margin: 0 auto; }
#precautions .faqWrap dl{position: relative;}
#precautions .faqWrap dl dd{padding: 15px 0;}
#precautions #faq.faqWrap dl dd{padding: 5px 0 0 0;}
#precautions .faqWrap dl dd p, #precautions .faqWrap dl dd div{
	position: relative;
	width: calc(100% - 45px);
	max-width: 800px;
	margin: 0 auto;
	padding-bottom: .8em;
	text-align: left;
	line-height: 1.5em;
}
#precautions .faqWrap dl dd .title{
	position: relative;
	width: calc(100% - 50px);
	margin: 5px auto 0 auto;
	text-align: left;
	font-weight: bold;
}
#precautions #cautionlist.faqWrap dl dd p, #precautions #faq.faqWrap dl dt p, #precautions #faq.faqWrap dl dd p, #precautions #limitlist dd p, #precautions .attWrap p{padding-left: 1.2em;}
#precautions #faq.faqWrap dl dt p{
	position: relative;
	color: #32f5c5;
	font-weight: 700;
	text-align: left;
	margin: 0 auto;
	width: calc(100% - 50px);
	max-width: 800px;
	line-height: 1.6em;
}
#precautions #cautionlist.faqWrap dl dd p::before, #precautions #faq.faqWrap dl dt p::before, #precautions #faq.faqWrap dl dd p::before, #precautions #limitlist dd p::before, #precautions .attWrap p::before{
	position: absolute;
	content: '・';
	left: 0;
}
#precautions #faq.faqWrap dl dt p::before{content: 'Q.';}
#precautions #faq.faqWrap dl dd p::before{content: 'A.';}
#precautions .attWrap{margin: 0 auto 10px auto; width: calc(100% - 1.5em) !important;transform: translateX(.5em);}
#precautions .attWrap p::before{content: '※' !important;}
#precautions .attWrap p{font-size: 88% !important;padding-bottom: .2em !important;}

.btn.realdgame{
	position: relative;
	margin: 40px auto 0 auto;
	width: calc(100% - 30px);
	max-width: 380px;
}

/* ----- pc ----- */
@media screen and (min-width: 641px) {

	/* ヘッダー */
	header .attention{
		font-size: 110%;
		line-height: 1.8em;
	}
	header #keyvisual{padding-top: 56.25%;}
	header #keyvisual01 {background-image: url("../img/main_pc.jpg");}
	header #keyvisual02 {background-image: url("../img/main01_pc.jpg");}
	header #keyvisual01.display{animation: keyDisplay_pc 4s ease 0s 1 normal forwards;}
	header #keyvisualbg.display{animation: keyDisplaybg_pc 4s ease 0s 1 normal forwards;}
	@keyframes keyDisplay_pc {
		0% {
			clip-path: circle(0 at 50% 50%);
		}
		8%, 18% {
			clip-path: circle(150px at 50% 50%);
		}
		25%{
			clip-path: circle(0 at 50% 50%);
		}
		30%, 38%{
			clip-path: circle(150px at 80% 20%);
		}
		45%{
			clip-path: circle(0 at 80% 20%);
		}
		65%{
			clip-path: circle(150px at 90% 80%);
		}
		80%{
			clip-path: circle(150px at 20% 80%);
		}
		90%{
			clip-path: circle(150px at 50% 50%);
		}
		95%{
			clip-path: circle(0 at 50% 50%);
		}
		100%{
			clip-path: circle(100% at 50% 50%);
		}
	}
	@keyframes keyDisplaybg_pc {
		0%, 100% {
			width: 0;
			height: 0;
			opacity: 0;
			top:50%;
			left: 50%;
		}
		8%, 18% {
			width: 300px;
			height: 300px;
			top:50%;
			left: 50%;
			opacity: 1;
		}
		25% {
			width: 0;
			height: 0;
			opacity: 0;
			top:50%;
			left: 50%;
		}
		30%, 38%{
			top: 20%;
			left: 80%;
			width: 300px;
			height: 300px;
			opacity: 1;
		}
		45% {
			width: 0;
			height: 0;
			opacity: 1;
			top: 20%;
			left: 80%;
		}
		65%{
			top:80%;
			left: 90%;
			width: 300px;
			height: 300px;
			opacity: 1;
		}
		80%{
			top:80%;
			left: 20%;
			width: 300px;
			height: 300px;
			opacity: 1;
		}
		90%{
			top: 50%;
			left: 50%;
			width: 300px;
			height: 300px;
			opacity: 1;
		}
		95%{
			width: 0;
			height: 0;
			opacity: 0;
		}
	}

	/* catch */
	#catch {
		padding-top: 20px;
		background-image: url("../img/bg_catch_pc.jpg");
	}
	#catch .catch{max-width: 799px;}

	/* cm */
	#cm .movie{padding-top: 360px;}
	#cm .mBtn img{max-width: 149px;}
	#cm .mBtn::before{background-image: url("../img/cm_cover_pc.png");}

	/* ポイント */
	#point{padding-top: 60px;}
	#point ul{margin: 20px auto 0 auto;}
	#point ul li{
		margin: 0 auto 30px auto;
		gap: 10px 0;
	}
	#point ul li.blockorder{flex-direction:row-reverse;}
	#point ul li .Img{width: 53%;}
	#point ul li .Txt{
		margin: 0;
		width: calc(48% - 30px);
	}
	#point ul li .Txt .ttl{
		padding-top: 10px;
		padding-bottom: 10px;
		width: 1.2em;
		font-size: 130%;
		line-height: 1.2em;
	}
	#point ul li .Txt .ttl span{
		font-size: 150%;
		line-height: 2em;
	}
	#point ul li .Txt .pointTXt{
		padding: 10px 0;
		width: calc(100% - 1.8em - 29px);
	}
	#point ul li .Txt .pointTXt .catch{
		padding-bottom: 25px;
		font-size: min(3.75vw, .20rem);
	}
	#point ul li .Txt .pointTXt .text{
		font-size: min(3.3vw, .16rem);
		line-height: 1.6em;
	}
	#point .Img.bgmovie{padding: 10px 0;}
	#point .Img .pointmovie{width: calc(100% - 50px);}
	#point .Img .pointmovie video{ border: solid 2px #089d9f;}


	/* ストーリー */
	#story {padding: 70px 0 180px 0;}
	#story::before{clip-path: polygon(0 200px, 100% 0%, 100% calc(100% - 200px), 0% 100%);}
	#story .storyWrap .Txt{padding: 0 0 40px 0;}
	#story .storyWrap .Txt p{padding-top: 35px;font-size: min(1.5vw, .18rem);line-height: 2em;}
	#story .btn_more{
		margin: 50px auto 0 auto;
		width: 12em;
		padding: 2px 0;
	}
	
	.bg{
		margin: 60px auto 0 auto;
		padding-bottom: 320px;
	}
	.bg::after{
		background-position: -380px 33%;
		background-size: 780px auto;
	}
	
	/* バナー */
	#special{
		margin: -170px auto 0 auto;
		padding-top: 0;
	}
	#special .specialWrap .splide__arrows .splide__arrow--prev {top: 45%;left: -25px;}
	#special .specialWrap .splide__arrows .splide__arrow--next {top: 45%;right: -25px;}
	#special .specialWrap .splide__arrow img{width: 18px;}

	#special .box{
		margin: 30px auto 40px auto;
		max-width: 560px;
	}
	#special .specialWrap .box{margin: 30px auto 0 auto;}
	#special .newicon{margin: 30px auto 0 auto;}
	#special .previcon::after, #special .newicon::after{
		top: -25px;
		left: -25px;
		width: 90px;
		height: 90px;
	}

	/* 参加方法 */
	#howto {padding-top: 70px;}
	#howto .howtoWrap {
		margin: 20px auto 0 auto;
		max-width: 960px;
	}

	#howto .howtoWrap ul li{padding-top:50px;}
	#howto .howtoWrap .ImgTtl {top: -45px;}
	#howto .howtoWrap .ImgTtl img{
		height: 35px;
		width: auto;
	}
	#howto .howtoWrap .txtWrap {
		padding-bottom: 30px;
		width: 100%;
	}
	#howto .howtoWrap p{width: calc(100% - 40px);}
	#howto .howtoWrap .ttl {
		line-height: 1.6em;
		font-size: .24rem;
		padding-bottom: 30px;
	}
	#howto .howtoWrap .button{
		width: calc(100% - 80px);
		margin: 35px auto 0 auto;
	}
	#howto .txtWrap .cautionWrap{width: calc(100% - 15px);}
	#howto #stream{margin: 70px auto 0 auto;}
	#howto #stream .button{margin: 20px auto 30px auto;}
	#howto #stream .button p::after{
		top: -20px;
		left: -40px;
		width: 50px;
		height: 50px;
	}
	#howto .first{margin: 70px auto 0 auto;}

	/* product */
	#product{
		margin: -280px auto 0 auto;
		padding: 140px 0 10px 0;
	}
	#product .bg{
		background-size: auto;
		clip-path: polygon(0 220px, 100% 0%, 100% 100%, 0% 100%);
	}
	#product #item{
		margin: 50px auto;
		max-width: 960px;
	}
	#product #item ul{
		max-width: 500px;
		gap: 0 20px;
	}
	#product #item ul li{width: calc(50% - 12px);}
	#product #item ul li p::after{
		top: -35px;
		right: -15px;
		width: 45px;
		height: 45px;
	}
	#product #itemImg{
		margin: 0 auto 30px auto;
	}
	#product #itemImg .price{padding:20px 0;}
	#product #itemImg .tab .item h3{margin: 0 auto 15px auto;}
	#product #itemImg .tab .item .margin{padding: 20px 0 30px 0;}
	
	#product #game{
		gap: 0;
		max-width: 960px;
		border-bottom: solid 1px #0f8b6c;
	}
	#product #game dt{
		margin: 0;
		width: 30%;
		display: flex;
		align-items: center;
		justify-content: center;
		border-top: solid 1px #00000f;
	}
	#product #game dt:first-child{border-top: solid 1px #0f8b6c;}
	#product #game dd{
		width: calc(70% - 80px);
		text-align:left;
		padding: 25px 40px;
		border-top: solid 1px #0f8b6c;
	}
	#product #game dd.play{gap: 20px 40px;	align-items: center;}
	#product #game dd.play .Img{
		width: 15%;
		max-width: auto;
	}
	#product #game dd.play .Txt{width: calc(85% - 40px);}
	#product #game dd.pricelist{gap: 5px 20px;}
	#product .tokuten{margin: 90px auto 0 auto;}
	#product .tokuten .Img{max-width: 580px;}
	#product .scrapdan{margin:50px auto 0 auto;}

	/* env */
	#precautions .bg{
		padding-bottom: 180px;
		clip-path: polygon(0 220px, 100% 0%, 100% calc(100% - 220px), 0% 100%);
	}
	#precautions .bg::after{
		background-position: calc(100% + 390px) 100%;
		background-size: 780px auto;
	}
	#env table{margin: 0 auto;table-layout: fixed;width: calc(100% - 60px);max-width: 830px;}
	#env table.tb02{margin:-1px auto 0 auto;}
	#env table tr th{padding: 20px;width: calc(41% - 42px);}
	#env table tr th.pc{width: 18%;display: table-cell;}
	#env table tr td{padding: 20px;width: calc(41% - 42px);}
	#env table tr td.pc{width: 18%;display: table-cell;background-color: #02251a;vertical-align: middle;}
	#env table tr.pcdisp{display: none;}

	#env .testenv{margin: 80px auto 30px auto;}
	#env .testenv a.button{padding: 10px 20px;}
	#env .testenv .cautionWrap{margin:15px auto 0 auto;}
	#env .testenv .trial{
		margin: 0 auto 30px auto;
		max-width: 620px;
	}

	/* FAQ */
	#precautions {padding: 160px 0 100px 0;}
	#precautions .precautionWrap{margin: 0 auto 26px auto;}
	#precautions .precautionWrap .ttl{
		padding: 25px 0 ;
		font-size: 150%;
	}
	#precautions .ttl::after{
		right: 15px;
		height: 11px;
		width: 22px;
	}
	#precautions .CatTtl{
		padding: 3px 15px;
		font-size: 112%;
	}
	#precautions .CatTtl.marginTop{margin: 30px auto 0 auto;}
	#precautions #faq.faqWrap dl dd{padding: 5px 0 10px 0;}

	#precautions #limitlist dl{max-width: 830px;margin: 0 auto 30px auto;}

	.btn.realdgame{margin: 80px auto 0 auto;}

}
