@charset "utf-8";
/* ヘッダー */
header {
	position: relative;
	margin: 0 auto;
}
header #keyvisual {
	position: relative;
	margin: 0 auto;
	width: 100%;
	overflow: hidden;
}
header #keyvisual img{
	position: relative;
	margin: 0 auto;
	width: 100%;
}
header #keyvisual a{
	position: absolute;
	top: 5px;
	left: 5px;
	width: 20%;
	max-width: 100px;
	display: block;
}

#main-contents{
	position: relative; 
	margin: 0 auto;
	padding:0;
}

/* catch */
#catch  {
	position: relative;
	margin: 0 auto;
	padding: 15px 0 20px 0;
	background-image: url("../img/bar01.svg"), url("../img/bar02.svg"), url("../img/bg_catch.jpg");
	background-repeat: no-repeat, no-repeat, no-repeat;
	background-position: 0 0, 0 100%, 50% 0;
	background-size: 100% 10px, 100% 15px, cover;
}
#catch .catchTxt{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
	z-index: 50;
}

/* cm */
#cm{
	position: relative;
	margin: 0 auto;
	padding-bottom: 60px;
	background-image: url("../img/bg_top.jpg");
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: cover;
}
#cm::after{
	position: absolute;
	top:-100px;
	left: 0;
	width: 50%;
	max-width: 303px;
	height: 100%;
	content: '';
	background-image: url("../img/icon_catch.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
	mix-blend-mode: overlay;
}
#cm .btn_ticket{
	position: relative;
	margin: 0 auto 30px auto;
	width: calc(100% - 30px);
	transform: translateY(-5px);
	z-index: 10;
}
#cm .cmWrap{position: relative;}
#cm .bg01{
	position: absolute;
	top: -20px;
	left: 0;
	width: 50px;
	height: 90px;
	background-image: url("../img/icon_cm01.png");
	background-repeat: no-repeat;
	background-position: -12px 0;
	background-size: contain;
}
#cm .bg02{
	position: absolute;
	top: -35px;
	right: 43px;
	width: 32px;
	height: 48px;
	background-image: url("../img/icon_cm02.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
}
#cm .bg03{
	position: absolute;
	bottom: -40px;
	right: 0;
	width: 64px;
	height: 80px;
	background-image: url("../img/icon_cm03.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
}
#cm .bg04{
	position: absolute;
	top: -25px;
	right: 10px;
	width: 35px;
	height: 37px;
	background-image: url("../img/icon_cm04.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
}

/* about */
#about {
	position: relative;
	margin: 0 auto;
	padding: 0 0 70px 0;
	background-image: url("../img/bg_about01.png"), url("../img/bg_about.jpg");
	background-repeat: no-repeat,no-repeat;
	background-position: 50% 0, 50% 0;
	background-size: 100% auto, cover;
}
#about::before{
	position: absolute;
	top:-20px;
	left: 0;
	width: 100%;
	height: 40px;
	content: '';
	display: block;
	background-image: url("../img/line_dark.png");
	background-repeat: repeat-x;
	background-position: 50% 0;
	background-size: contain;
}
#about h2{
	position: relative;
	margin: 0 auto;
	max-width: 640px;
	transform: translateY(-20px);
}
#about .lead{
	position: relative;
	margin: 15px auto;
	text-align: center;
	color: #ffffff;
}

/* chara */
#chara{
	position: relative;
	margin: 0 auto;
}
#chara .charaWrap{position: relative;}
#chara h3{
	position: absolute;
	top: 25px;
	left: 10px;
	width: calc(50% - 20px);
}
#chara .charaData{
	position: relative;
	margin: 0 auto;
}
#chara .charaData .name{
	position: absolute;
	top: 15%;
	left: 0;
	width: 100%;
	padding: 20px 0 10px 0;
	background-color: #ff4189;
}
#chara .charaData .name .nameImg{
	position: relative;
	margin: 0 0 0 20px;
	width: calc(54% - 30px);
}
#chara .prof{position: relative;	z-index: 81;}
#chara .charaData .name .profiedata{
	position: relative;
	margin: 10px 0 0 calc(16% - 5px);
	width: 34%;
	cursor: pointer;
}
#chara .charaData .charaImg{
	position: relative;
	margin: 0 0 0 auto;
	width: calc(50% + 15px);
	z-index: 80;
}
#chara .charaData .voice{
	position: absolute;
	top:-5px;
	left: 33%;
	width: 20%;
	max-width: 100px;
}
#chara .charaTxt{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 70px);
	background-color: #ffffff;
	border-radius: 20px;
	padding: 15px;
}
#chara .profile{
	position: relative;
	margin: 10px auto 50px auto;
	width: calc(100% - 80px);
	max-width: 900px;
	gap: 20px;
	background-color: #7A0C7B;
	border-radius: 15px;
	padding: 20px;
}
#chara .profile .gif{
	position: relative;
	margin: 0;
	padding: 0;
	border-radius: 5px;
	overflow: hidden;
	border: solid 1px #ffffff;
}
#chara .profile .gif img{width: 100%;}
#chara .profile .txtWrap{position: relative; margin: 0;}
#chara .profile .txt{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 20px);
}
#chara .profile .txt img{margin: 0 auto;}

/* point */
#point {
	position: relative;
	margin: 0 auto;
}
#point .ttl{
	position: relative;
	margin: 25px auto 15px auto;
	width: calc(100% - 50px);
	background-color: #ff4189;
	border-radius: 15px;
	padding: 10px 15px;
	z-index: 7;
}
#point .ttl::after{
	position: absolute;
	bottom: -23px;
	right: 18%;
	height: 25px;
	width: 25px;
	content: '';
	background-color: #ff4189;
	clip-path: polygon(100% 0, 48% 0, 20% 100%);
}
#point .ttl.point02::after{
	right: auto;
	left: 18%;
	clip-path: polygon(48% 0, 0 0, 80% 100%);
}
#point .ttl img{
	position: relative;
	margin: 0 auto;
}
#point .gif{
	position: relative;
	margin: 0 auto;
	padding: 0;
	width: calc(100% - 50px);
	border-radius: 15px;
	overflow: hidden;
	border: solid 1px #ffffff;
	box-shadow: -1px 4px 0px 1px #770aaf;
	z-index: 6;
}
#point .gif img{width: 100%;}
#point .txt{
	position: relative;
	margin: -10px auto 0 auto;
	width: calc(100% - 100px);
	transform: translateX(15px);
	background-color: #ffffff;
	border-radius: 15px;
	padding: 40px 20px 20px 20px;
	z-index: 5;
}
#point .txt p{
	position: relative;
	margin: 0 auto;
}
#point .txt p.border{
	margin: 15px auto 0 auto;
	border-top: dotted 2px #EBDDF0;
	padding-top: 15px;
}

/* product */
#product{
	position: relative;
	margin: 0 auto;
	padding: 0 0 30px 0;
	background-color: #160429;
	background-image: url("../img/bg_reccomend.png");
	background-repeat: no-repeat;
	background-position: 50% 220px;
	background-size: cover;
}
#product::before{
	position: absolute;
	top:-20px;
	left: 0;
	width: 100%;
	height: 40px;
	content: '';
	display: block;
	background-image: url("../img/line_dark.png");
	background-repeat: repeat-x;
	background-position: 50% 0;
	background-size: contain;
}
#product h2{
	position: relative;
	margin: 0 auto;
	max-width: 640px;
	transform: translateY(-20px);
}
#product h3{
	position: relative;
	margin: 0 auto;
	width: 84%;
	max-width: 400px;
	transform: translateY(calc(-50% - 15px));
}
#product .box{
	position: relative;
	margin: 0 auto 50px auto;
	background-color: #ffffff;
	border-radius: 15px;
	padding: 15px;
	width: calc(100% - 70px);
}
#product #select{position: relative;}
#product #select ul{
	position: relative;
	margin: 0 auto 15px auto;
	width: calc(100% - 60px);
	max-width: 300px;
	gap: 0 10px;
}
#product #select ul li{
	position: relative;
	margin: 0;
	padding: 3px 0;
	width: calc(50% - 5px);
	border-radius: 100px;
	background-color: #dbc1f3;
	color: #9959d5;
	font-size: 90%;
	text-align: center;
	line-height: 1.3em;
}
#product #select ul li:nth-child(2){line-height: 2.6em;}
#product #select ul li.active{
	background-color: #ffffff;
	color: #51019c;
}
#product #select ul li .icon{
	position: absolute;
	bottom: -8px;
	left: -13px;
	width: 30px;
	height: 35px;
	display: none;
}
#product #select ul li:nth-child(2) .icon{left:auto;right: -13px;}
#product #select ul li.active .icon{display: block;}
#product #select ul li span{font-size: 90%;}
#product #select .box .productWrap{position: relative;display: none;}
#product #select .box .productWrap.active{display: block;}
#product #select .box .prodicon01{
	position: absolute;
	top: 10%;
	left: -20px;
	width: 60px;
	height: 80px;
	background-image: url("../img/prod_icon01.png");
	background-repeat: no-repeat;
	background-position: -8px 0;
	background-size: contain;
}
#product #select .box .prodicon02{
	position: absolute;
	top: 40%;
	right: -20px;
	width: 45px;
	height: 85px;
	background-image: url("../img/prod_icon02.png");
	background-repeat: no-repeat;
	background-position:100% 0;
	background-size: contain;
}
#product #select .box .Img{
	position: relative;
	margin: 5px auto 0 auto;
	width: 80%;
}
#product #select .box .price{
	position: relative;
	margin: 20px auto 15px auto;
	text-align: center;
}
#product #select .box .price span{
	font-size: 150%;
	font-weight: 700;
}
#product #select .box .steam{
	position: relative;
	margin: 20px auto;
	text-align: center;
}
#product #select .box .steam img{
	position: relative;
	margin: 0 auto;
}
#product #select .box .steam p{
	position: relative;
	margin: 10px auto 0 auto;
}
#product #select .box .soon{
	position: relative;
	padding: 5em 0;
	text-align: center;
	font-size: 140%;
	font-weight: 700;
	color: #51019c;
}
#product #game ul{
	position: relative;
	margin: 0 auto;
}
#product #game ul li{
	position: relative;
	margin: 0 auto 8px auto;
	width: 100%;
	gap: 0 8px;
}
#product #game ul li .contentsL{
	position: relative;
	margin: 0;
	width: 30%;
}
#product #game ul li .contentsR{
	position: relative;
	margin: 0;
	width: calc(70% - 8px);
}
#product #game ul li p{
	position: relative;
	margin: 0 auto;
	font-size: 86%;
	line-height: 1.5em;
}
#product #game ul li p span{
	font-size: 120%;
	color: #51019c;
	font-weight: bold;
	display: block;
	line-height: 1.6em;
}
#product #game ul li .cautionWrap{margin: 5px auto 0 auto;}
#product #game .guideline{
	position: relative;
	margin: 30px auto 20px auto;
}
#product #game .guideline .button{margin: 10px auto 0 auto;}

#product .threearticles{
	position: relative;
	margin: -20px auto 10px auto;
	width: calc(100% - 40px);
}

/* howto */
#howto{
	position: relative;
	margin: 0 auto;
	padding-bottom: 50px;
}
#product #howto h3{
	width: calc(100% - 70px);
	transform: translateY(50%);
	z-index: 10;
}
#product #howto h3 img{
	position: relative;
	margin: 0 auto;
	width: 84%;
	display: block;
}
#howto .howtoWrap {
	position: relative;
	margin: 0 auto;
}
#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: 33px;
	width: 33px;
	opacity: 1;
	transform: translateY(0);
	z-index: 200;
}
#howto .howtoWrap .splide__arrow:disabled {opacity: 0;}
#howto .howtoWrap ul{position: relative;margin: 0 auto;}
#howto .howtoWrap ul li{
	position: relative;
	margin: 0;
	padding: 0 30px;
	display: flex;
	align-items: stretch;
}
#howto .howtoWrap .txtWrap {
	position: relative;
	margin: 0 auto;
	background-color: #ffffff;
	width: 100%;
	border-radius: 15px;
	padding: 30px 15px 25px 15px;
	outline: solid 3px #51019c;
	outline-offset: -4px;
	z-index: 100;
}
#howto .howtoWrap .step {
	position: absolute;
	top:25px;
	left: -20px;
	width: 40%;
}
#howto .howtoWrap .Img {
	position: relative;
	margin: 30px 0 20px auto;
	width: 55%;
	transform: translateX(-20px);
}
#howto .howtoWrap p{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 20px);
	text-align: center;
	font-size: 90%;
}
#howto .howtoWrap .button{
	margin: 1em auto 0 auto;
	width: 80%;
}

/* release */
#release {
	position: relative;
	margin: 0 auto;
	z-index: 20;
}
#release p{
	position: relative;
	margin: -10px auto 0 auto !important;
	text-align: center;
	padding-bottom: 10px;
}

/* tokuten */
#tokuten{
	position: relative;
	margin:-10px auto 0 auto;
}
#tokuten .icon{
	position: absolute;
	top: -40px;
	left: 2px;
	width: 70px;
	height: 50px;
	background-image: url("../img/icon_game.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
}
#tokuten h4{
	position: relative;
	margin: 10px auto 0 auto;
}
#tokuten .tokutenImg{
	position: relative;
	margin: 15px  auto;
}
#tokuten .Txt{
	position: relative;
	margin:0 auto;
	padding-top: 20px;
	font-size: 80%;
	text-align: center;
}
#tokuten .Txt img{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 30px);
	max-width: 380px;
}

/* notes */
#notes {
	position: relative;
	margin:0 auto;
	background-color: #ff2c71;
	padding: 35px 0;
	background-image: url("../img/bg_faq.jpg");
	background-repeat: repeat-y;
	background-position: 50% 0;
	background-size: 100% auto;
}
#notes::before{
	position: absolute;
	top:-20px;
	left: 0;
	width: 100%;
	height: 40px;
	content: '';
	display: block;
	background-image: url("../img/line_light.png");
	background-repeat: repeat-x;
	background-position: 50% 0;
	background-size: contain;
}
#notes .bg01{
	position: absolute;
	top: -65px;
	right: 0;
	width: 140px;
	height: 75px;
	background-image: url("../img/icon_faq01.png");
	background-repeat: no-repeat;
	background-position: 100% 0;
	background-size: contain;
}
#notes .bg02{
	position: absolute;
	top: -15px;
	left: 10px;
	width: 40px;
	height: 46px;
	background-image: url("../img/icon_faq02.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
}
#notes .bg03{
	position: absolute;
	bottom: 300px;
	left: 0;
	width: 52px;
	height: 45px;
	background-image: url("../img/icon_faq03.png");
	background-repeat: no-repeat;
	background-position: -7px 0;
	background-size: contain;
}
#notes .bg04{
	position: absolute;
	bottom: -18px;
	right: 5px;
	width: 64px;
	height: 68px;
	background-image: url("../img/icon_faq04.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
	z-index: 30;
}
#notes .bg05{
	position: absolute;
	top:20px;
	left: 3px;
	width: 130px;
	height: 130px;
	background-image: url("../img/icon_faq05.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
	mix-blend-mode: overlay;
}
#notes .precautionWrap{
	position: relative;
	margin: 0 auto 18px auto;
	width: calc(100% - 40px);
	background-color: #ffffff;
	outline: 2px solid #ff2c71;
	outline-offset: -3px;
	border-radius: 15px;
}
#notes .precautionWrap .ttl{
	position: relative;
	margin: 0 auto;
	padding: 14px 0 ;
	cursor: pointer;
}
#notes .precautionWrap .ttl img{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 540px;
}
#notes .ttl::after{
	position: absolute;
	top:50%;
	right: 10px;
	content: '\025bc';
	display: block;
	transition: all .3s ease-out;
	transform: translateY(-50%);
	color: #ff2c71;
	font-size: 70%;
}
#notes .ttl.disp::after{transform: translateY(-50%) rotate(-180deg);}
#notes .faqWrap{
	position: relative;
	margin: 0 auto;
	padding: 10px 0 30px 0;
	display: none;
	z-index: 9;
}
#notes .CatTtl{
	position: relative;
	margin: 0 auto;
	padding: 8px 10px;
	width: calc(100% - 45px);
	max-width: 800px;
	text-align: center;
	font-size: 102%;
	font-weight: 700;
	line-height: 1em;
	color: #51019c;
	border-bottom: dotted 3px #EABFF1;
}
#notes .CatTtl.marginTop{margin: 10px auto 0 auto;}
#notes  #limitlist .CatTtl{margin: 10px auto 0 auto;}
#notes  #limitlist .CatTtl.margin{margin: 20px auto 10px auto;}
#notes .faqWrap dl{position: relative;}
#notes .faqWrap dl dd{padding: 15px 0;}
#notes #faq.faqWrap dl dd{padding: 5px 0 0 0;}
#notes .faqWrap dl dd p, #notes .faqWrap dl dd div{
	position: relative;
	width: calc(100% - 45px);
	margin: 0 auto;
	padding-bottom: .8em;
	text-align: left;
}
#notes #cautionlist.faqWrap dl dd p, #notes #faq.faqWrap dl dt p, #notes #faq.faqWrap dl dd p, #notes #limitlist dd p, #notes .attWrap p{padding-left: 1.1em;}
#notes #cautionlist.faqWrap dl dt{position: relative;}
#notes #cautionlist.faqWrap dl dt.margin{margin: 20px auto 0 auto;}
#notes #faq.faqWrap dl dt p{
	position: relative;
	color: #51019c;
	text-align: left;
	margin: 0 auto;
	width: calc(100% - 45px);
}
#notes #cautionlist.faqWrap dl dd p::before, #notes #faq.faqWrap dl dt p::before, #notes #faq.faqWrap dl dd p::before, #notes #limitlist dd p::before, #notes .attWrap p::before{
	position: absolute;
	content: '・';
	left: 0;
}
#notes #faq.faqWrap dl dt p::before{content: 'Q.';}
#notes #faq.faqWrap dl dd p::before{content: 'A.';}
#notes .attWrap{margin: 0 auto 10px auto; width: calc(100% - 1.5em) !important;transform: translateX(.5em);}
#notes .attWrap p::before{content: '※' !important;}
#notes .attWrap p{font-size: 88% !important;padding-bottom: .2em !important;}

#notes #limitlist .lead{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 50px);
	max-width: 800px;
}
#notes  #limitlist dl{margin: 0 auto;width: calc(100% - 20px);}
#notes #limitlist .lead{margin: 10px auto 5px auto;}

/* env */
#env h3{
	position: relative;
	margin: 0 auto;
	padding-bottom: 5px;
	text-align: center;
}
#env table{
	position: relative;
	margin: 5px auto 10px auto;
	width: calc(100% - 30px);
	border-collapse: collapse;
	border: solid 1px #E3E3E3;
}
#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: #DDCBE1;
	border: solid 1px #E3E3E3;
}
#env table tr td{
	width: 50%;
	padding: 10px;
	border: solid 1px #E3E3E3;
}

/* aboutrdgame */
#aboutrdgame{
	position: relative;
	margin: 0 auto;
	background-color: #86083f;
	padding: 30px 0;
}
#aboutrdgame .bg{
	position: absolute;
	top:0;
	left: 0; 
	width: 100%;
	height: 100%;
	background-image: url("../img/bar03.svg"), url("../img/bar04.svg"), url("../img/bg_footer.png");
	background-repeat: no-repeat, no-repeat, no-repeat;
	background-position: 0 0, 0 calc(100% + 5px), 50% 0;
	background-size: 100% 15px, 100% 15px, cover;
}
#aboutrdgame .btn{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 40px);
}

/* ニュース */
#notes .newsWrap{position: relative;z-index: 100;}
#notes .newsWrap h2{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#notes .newsWrap .contetsWrap{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 46px);
	border: solid 3px #ff3878;
	outline: solid 1px #ffffff;
	outline-offset: -1px;
	max-width: 960px;
	background-color:#ffffff;
	border-radius: 15px;
}
#notes .newsBox{
	position: relative;
	margin: 0 auto;
	padding: 20px 0 20px 15px;
}
#notes .newsBox ul{
	position: relative;
	margin:0 auto;
	width: 100%;
	/*height: 160px;*/
	height: 80px;
    overflow: hidden;
	z-index: 80;
}
#notes .newsBox ul li{
	position: relative;
	margin:0 0 10px 0;
	width: calc(100% - 15px);
    padding: 0 0 5px 0;
	line-height: 1.4em;
}
#notes .newsBox ul li p.date{
	position: relative;
	color: #51019c;
	font-size: 90%;
	width: 100%;
}
#notes .newsBox ul li a, #news .newsBox ul li p{
	position: relative;
	width: 100%;
}

/* ----- pc ----- */
@media screen and (min-width: 641px) {
	/* ヘッダー */
	header #keyvisual a{
		top: 15px;
		left: 15px;
		max-width: 120px;
	}

	/* catch */
	#catch  {
		padding: 25px 0 30px 0;
		background-image: url("../img/bar01.svg"), url("../img/bar02.svg"), url("../img/bg_catch_pc.jpg");
		background-size: 100% 14px, 100% 20px, cover;
	}
	#catch .catchTxt{max-width: 908px;}

	/* cm */
	#cm{
		padding-bottom: 80px;
		background-image: url("../img/bg_top_pc.jpg");
		background-size: cover;
	}
	#cm::after{top:-120px;left:calc(50% - 500px);max-width: 250px;}
	#cm .btn_ticket{
		margin: 0 auto 30px auto;
		padding-top: 30px;
		max-width: 420px;
		transform: translateY(0);
	}
	#cm .bg01{
		top: -20px;
		left: calc(50% - 420px);
		width: 70px;
		height: 110px;
		background-position: 0 0;
	}
	#cm .bg02{
		top: -55px;
		right: calc(50% - 360px);
		width: 52px;
		height: 68px;
	}
	#cm .bg03{
		bottom: -40px;
		right: calc(50% - 420px);
		width: 84px;
		height: 90px;
	}
	#cm .bg04{
		top: -45px;
		right: calc(50% - 420px);
		width: 55px;
		height: 57px;
	}

	/* about */
	#about {
		padding: 0 0 90px 0;
		background-image: url("../img/bg_about01_pc.png"), url("../img/bg_about_pc.jpg");
	}
	#about::before{
		top:-30px;
		height: 60px;
	}
	#about h2{max-width: 600px;}
	#about .lead{margin: 20px auto;}

	/* chara */
	#chara .charaData{margin: 10px auto 0 auto;}
	#chara .charaData .name{
		top: 23%;
		padding: 40px 0;
	}
	#chara .charaData .name .nameImg{
		margin: 0;
		width: calc(50% - 30px);
	}
	#chara .charaData .name .nameImg img{
		position: relative;
		margin: 0 0 0 auto;
	}
	#chara .charaTxt{
		margin: 0 auto;
		max-width: 740px;
		border-radius: 20px;
		padding: 40px;
		text-align: center;
	}
	#chara .charaTxt::before{
		top:-38px;
		height: 40px;
		width: 40px;
	}
	#chara .profile{margin: 15px auto 70px auto;}
	#chara .charaData .name .profiedata{
		margin: 20px 0 0 calc(50% - 155px);
		width: 160px;
	}
	#chara .charaData .voice{
		top:45px;
		left: calc(50% - 90px);
		max-width: 120px;
	}

	/* point */
	#point .ttl{
		margin: 45px auto 25px auto;
		max-width: 780px;
		padding: 15px 20px;
	}
	#point .ttl::after{
		bottom: -28px;
		height: 30px;
		width: 30px;
	}

	/* product */
	#product{
		padding: 0 0 30px 0;
		background-image: url("../img/bg_reccomend.png");
		background-repeat: repeat-x;
		background-position: 50% 220px;
		background-size: 600px auto;
	}
	#product::before{
		top:-30px;
		height: 60px;
	}
	#product h2{max-width: 600px;}
	#product h3{
		max-width: 350px;
		transform: translateY(calc(-50% - 40px));
	}
	#product .box{
		margin: 0 auto 90px auto;
		padding: 40px;
		max-width: 880px;
	}
	#product #select ul{
		margin: 0 auto 20px auto;
		max-width: 600px;
		gap: 0 10px;
	}
	#product #select ul li{
		padding: 15px 0;
		width: calc(50% - 5px);
		cursor: pointer;
	}
	#product #select ul li:nth-child(2){line-height: 1.3em;}
	#product #select ul li .icon{
		bottom: -8px;
		left: -13px;
		width: 40px;
		height: 45px;
	}
	#product #select ul li span{font-size: 86%;}
	#product #select .box .prodicon01{
		top: 30%;
		left: -40px;
		width: 80px;
		height: 100px;
		background-position: 0 0;
	}
	#product #select .box .prodicon02{
		top: auto;
		bottom: 3%;
		right: -20px;
		width: 65px;
		height: 105px;
	}
	#product #select .productWrap .flexbox{gap:0 20px;}
	#product #select .box .Img, #product #select .box .text{
		position: relative;
		margin: 0;
		width: calc(50% - 10px);
	}
	#product #select .box .Img img{
		position: relative;
		margin: 0 20px 0 auto;
		width: 70%;
	}
	#product #select .box .price{margin: 0 auto 25px auto;}
	#product #select .box .price span{font-size: 180%;}
	#product #select .box .steam{margin: 30px auto;}
	#product #select .box .steam img{max-width: 360px;}
	#product #select .box .steam p{padding-top: 20px;}
	#product #select .box .soon{
		font-size: 190%;
		padding: 5em 0;
	}
	#product #game ul{
		max-width: 640px;
		gap: 0 10px;
	}
	#product #game ul li{
		margin: 0;
		width: calc(33.333% - 12px);
		gap: 10px 0;
	}
	#product #game ul li .contentsL{width: 100%;}
	#product #game ul li .contentsR{width: 100%;}
	#product #game ul li img{
		position: relative;
		margin: 0 auto;
		 width: 50%;
	}
	#product #game ul li p{text-align: center;}
	#product #game .guideline{
		margin: 50px auto 20px auto;
		text-align: center;
	}
	#product #game .guideline .button{margin: 15px auto 0 auto;max-width: 480px;}

	#product .threearticles{
		margin: -30px auto 30px auto;
		max-width: 740px;
	}

	/* howto */
	#howto{padding-bottom: 90px;}
	#product #howto h3{width: min(350px, 84%);}
	#product #howto h3 img{width: 100%;}
	#howto .howtoWrap {max-width: 800px;}
	#howto .howtoWrap .txtWrap {padding: 50px 15px 25px 15px;}
	#howto .howtoWrap .step {top:45px;}

	/* tokuten */
	#tokuten{margin:-20px auto 0 auto;}
	#tokuten .icon{
		top: -70px;
		left: calc(50% - 400px);
		width: 110px;
		height: 90px;
	}
	#tokuten h4{max-width: 460px;}
	#tokuten .tokutenImg{
		margin: 20px  auto;
		max-width: 640px;
	}
	#tokuten .Txt{padding-top: 40px;font-size: 90%;}

	/* notes */
	#notes {
		padding: 35px 0 70px 0;
		background-repeat: repeat;
		background-size: 640px auto;
	}
	#notes::before{
		top:-30px;
		height: 60px;
	}
	#notes .bg01{
		top: -95px;
		width: 200px;
		height: 115px;
	}
	#notes .bg02{
		top: -25px;
		left: 10%;
		width: 60px;
		height: 76px;
	}
	#notes .bg03{
		bottom: 390px;
		left: 5%;
		width: 82px;
		height: 75px;
		background-position: 0 0;
	}
	#notes .bg04{
		bottom: -30px;
		right: 15px;
		width: 94px;
		height: 98px;
	}
	#notes .bg05{
		top:20px;
		left: 1%;
		width: 160px;
		height: 160px;
	}
	#notes .precautionWrap{
		margin: 0 auto 24px auto;
		max-width: 960px;
	}
	#notes .precautionWrap .ttl{padding: 20px 0 ;}
	#notes .precautionWrap .ttl img{max-width: 440px;}
	#notes .ttl::after{
		right: 30px;
		font-size: 90%;
	}
	#notes .CatTtl{margin: 0 auto 10px auto;}
	#notes .CatTtl.marginTop{margin: 10px auto 10px auto;}
	#notes  #limitlist .CatTtl{margin: 10px auto 20px auto;}
	#notes  #limitlist .CatTtl.margin{margin: 20px auto 20px auto;}
	#notes .faqWrap dl dd p, #notes .faqWrap dl dd div{max-width: 800px;}
	#notes #faq.faqWrap dl dt p{max-width: 800px;}
	#notes #limitlist .lead{max-width: 800px;}

	/* env */
	#env table{max-width: 800px;}

	/* aboutrdgame */
	#aboutrdgame{padding: 50px 0;}
	#aboutrdgame .bg{
		background-image: url("../img/bar03.svg"), url("../img/bar04.svg"), url("../img/bg_footer_pc.png");
		background-position: 0 0, 0 calc(100% + 5px), 50% 0;
		background-size: 100% 25px, 100% 25px, cover;
	}
	#aboutrdgame .btn{
		max-width: 420px;
		cursor: pointer;
	}
	
	/* ニュース */
	#notes .newsBox{padding: 30px 50px 30px 50px;}

}

/* point */
@media screen and (min-width: 900px) {
	#chara .profile .gifWrap{position: relative;margin: 0; width:calc(50% - 20px);}
	#chara .profile .txtWrap{
		width: calc(50% - 20px);
		max-width: 380px;
	}

	#point .gifWrap, #point .txtWrap{
		position: relative;
		margin: 0 auto;
		width: 100%;
		max-width: 960px;
	}
	#point .txtWrap{margin: -250px auto 100px auto;}
	#point .gif{margin: 0; width: 50%; max-width: 500px;}
	#point .txt{
		margin: 0 0 0 auto;
		width: calc(50% - 10px);
		max-width: 400px;
		transform: translateX(0);
		padding: 40px 40px 40px 220px;
	}
}
