@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=RocknRoll+One&display=swap');

/*////////////////////////////////////////////////////////////////////////
reset
////////////////////////////////////////////////////////////////////////*/
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	vertical-align: top;
}

html {
	/*image-rendering: -webkit-optimize-contrast;*/
}

body{
	overflow-y: scroll; /* スクロールバー常に表示 */
}

html,body {
	font-size-adjust:100%;
	-webkit-font-size-adjust: 100%;
}

body,h1,h2,h3,h4,h5,h6,p,img,
hr,li,ul,dl,dt,dd
{
	padding: 0;
	margin: 0;
	border: 0;
	list-style: none;
}

table th{font-weight:normal;}

img{
	border:0px;
	image-rendering:auto;
}

.clear{clear:both;}
.hidden{overflow: hidden;}
.fixed{position: fixed;}

/*////////////////////////////////////////////////////////////////////////
基本カラー
////////////////////////////////////////////////////////////////////////*/
:root{
	
--red:#cf1314;
--orange:#ff8645;
--yellow:#ffad01;
--skyBlue:#3fa9e7;
--milk:#d6b89e;
--white:#fff6ef;
--gray:#999;
--brown:#391414;
--black:#131313;

	
--black30: rgba(0,0,0,0.3);
--black50: rgba(0,0,0,0.5);
--black60: rgba(0,0,0,0.6);
--black80: rgba(0,0,0,0.8);
--white20: rgba(255,255,255,0.2);
--white30: rgba(255,255,255,0.3);
--white50: rgba(255,255,255,0.5);
--white80: rgba(255,255,255,0.8);
	

--fontJa: "RocknRoll One", serif;
--fontMin: 'Noto Serif JP',"游明朝", YuMincho, "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
--fontMei:"メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	
}


/*////////////////////////////////////////////////////////////////////////
基本
////////////////////////////////////////////////////////////////////////*/
.non{
	opacity:0.3;
	cursor:default;
	pointer-events: none;
}

ruby {
        display: inline-table;
        border-collapse: collapse;
        margin: 0;
        padding: 0;
        border: none;
        white-space: nowrap;
        text-indent: 0;
        vertical-align: bottom;
        text-decoration: inherit;
        text-align: center;
        }
ruby>rt {
    display: table-header-group;
    height: 25%;
    margin: 0;
    padding: 0 0.125em;
    border: none;
    font: inherit;
    line-height: 1.1em;
	text-align: center;
	font-size: 50%;
	position: relative;
	transform: translateY(0.5em);
    }

br.txtCutNone{display:none;}

a{
	color: var(--white);
	text-decoration:none;
	outline:none;
}

a:hover{
	text-decoration: none;
}

::selection {
	color: #fff;
	background-color:#00b4c8;
}
::-moz-selection {
	color: #fff;
	background-color:#00b4c8;
}

hr.solidLine{
	border-top: solid 1px var(--gray);
}

.txtCutNone{
	display: none;
}

.fadeUp{
	opacity: 0;
	position: relative;
	bottom: -20px;
}

.fadeInSet{
	opacity: 0;
	animation: fadeInSet 0.3s linear forwards;
}

@keyframes fadeInSet {
  0% {
	transform:scale(1.2);
	opacity: 0;
  }
  100% {
	transform:scale(1);
	opacity: 1;
  }
}

img.newIcon{
	width: 100% !important;
	height: auto !important
}

/*////////////////////////////////////////////////////////////////////////
埋め込み動画
////////////////////////////////////////////////////////////////////////*/
/*---------------------------------------------
基本枠
---------------------------------------------*/
.inMovie{
	display: block;
	background-color: #000;
	overflow: hidden;
}

/*---------------------------------------------
youtubeデフォ
---------------------------------------------*/
.inMovie .youtube{
	position: relative;
	padding-bottom: 116.25%;
	height: 0;
	overflow: hidden;
	margin-top: -30%;
	margin-bottom: -30%;
}

.inMovie .youtube iframe,
.inMovie .youtubeShorts iframe{
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}

.inMovie .youtubeShorts{
	position: relative;
	padding-bottom: 250%;
	height: 0;
	overflow: hidden;
	margin-top: -36%;
	margin-bottom: -36.5%;
}

.movieCover{
	position: absolute;
	z-index: 1;
	left: 0;
	top: 0;
}


/*////////////////////////////////////////////////////////////////////////
全体ボックス
////////////////////////////////////////////////////////////////////////*/
@keyframes bgAnime {
  0%   { background-position: 0 0; } 
  100% { background-position: 541px -437px; }
}

html, body {
	width: 100%;
	height: 100%;
	position: relative;
}

html{
	background-color: var(--brown);
	cursor:url("../img/cursor.png"), default;
}

body{
	font-family:var(--fontMei);
	font-size:min(1.2vw,18px);
	color: var(--brown);
	min-width: 1300px;
}

h1{
	width: 100%;
	margin: auto;
	text-align: center;
	pointer-events: none;
	background-image: url("../img/title_line.png");
	background-repeat: repeat-x;
	background-position: center bottom;
	padding: 0.5em 0;
	margin-bottom: 1em;
}

h1 img{
	width: 70%;
	max-width: 1300px;
}


h2{
	color: var(--white);
	font-weight: normal;
	border: solid 3px var(--brown);
	padding: 0.5em;
	background-color: var(--skyBlue);
	transition: 0.3s;
	text-align: center;
	font-family: var(--fontJa);
	margin:1em auto 2em;
	box-shadow: 6px 6px var(--orange);
}

.moreLink{
	border: solid 3px var(--white);
	padding: 0.5em;
	width: 100%;
	max-width: 18em;
	background-color: var(--skyBlue);
	display: block;
	transition: 0.3s;
	position: relative;
	text-align: center;
	font-family: var(--fontJa);
	font-size: 140%;
	border-radius: calc(1px / 0);
	overflow: hidden;
	margin: auto;
	background-image: url("../img/tex_dot.png");
	background-position: center -20px;
}

.moreLink:hover {
	background-color: var(--orange);
	transform: scale(1.1);
	transition: 0.3s;
}

.kitteLine{
	background-image: url("../img/kitte_line.png");
	background-size: 61px;
	background-repeat: repeat-x;
	background-position: center top;
	width: 100%;
	height: 1.5em;
}

/*////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////*/
#loading{
	width:100%;
	height: 100%;
	position:fixed;
	z-index:999;
	display: flex;
    justify-content: center;
    align-items: center;
	text-align:center;
	pointer-events: none;
	font-family: var(--fontJa);
	color: var(--white);
	background-image: url("../img/bg.jpg");
	animation: bgAnime 15s infinite linear;
}

#loading p{
	display: block;
	width: 100%;
	padding: 5px;
	background-color: var(--white);
}

#loading p img{
	width: 50%;
	max-width: 300px;
}

#backTop{
	position: fixed;
	z-index: 9;
	right: 1%;
	bottom: 1%;
	padding: 2.5em;
	border-radius: calc(1px / 0);
	background-color: var(--blue);
	max-width:  150px;/* 円のサイズ（高さにもなる） */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	background-image: url("../img/backtop.jpg");
	background-position: center center;
	background-size: 100%;
	transition: 0.3s;
	border: solid 2px var(--white);
}


#backTop:hover{
	transform: scale(1.3);
	transition: 0.3s;
}

#wrap{
	background-image: url("../img/bg.jpg");
	animation: bgAnime 15s infinite linear;
}

#mainBox{
	width: 100%;
	margin: auto;
	opacity: 0;
	position: relative;
}

.inBox{
	max-width: 1300px;
	padding:0 2em;
	margin: auto;
}

.indent{
	padding-left: 1em;
}

.indent li{
	text-indent: -1em;
	margin-bottom: 5px;
}

.letterBox{
	width: 96%;
	margin: auto;
	background-image:url("../img/tex_1.jpg");
	background-position: center center;
	background-size: auto;
	background-repeat:repeat;
	border: solid 3px var(--milk);
	outline: solid 20px  var(--white);
	position: relative;
	box-shadow: 0 0 40px var(--brown);
	padding: 2em;
}

.new{
	position: absolute;
	top: -0.5em;
	left: -0.5em;
	width: 2.2em;
	z-index: 1;
}

/*////////////////////////////////////////////////////////////////////////
ヘッダー
////////////////////////////////////////////////////////////////////////*/
header{
	position: relative;
	background-color: var(--brown);
	border-bottom: 5px solid var(--white);
	z-index:1000;
}

header .logo{
	position: absolute;
	left: 0;
	z-index: 1;
	width: 10.5%;
	transition: 0.3s;
	top: 50%;
    transform: translate(0, -50%);
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
}

header .logo:hover{
	opacity: 0.6;
	transition: 0.3s;
}

header .logo img{
	width: 100%;
}

header nav{
	text-align: center;
	position: relative;
	display: flex;
}

header nav ul{
	margin: auto;
	width: 100%;
	max-width: 1500px;
}

header nav ul li{
	position: relative;
	display: inline-block;
	overflow: hidden;
	padding: 1.2em 0.5em 1.2em;
	transition: 0.3s;
}

header nav ul li img{
	height: 1.2em;
	padding: 0 0.8em;
}

header nav ul li small{
	display: block;
	border-top: 1px solid var(--white);
	opacity: 0.5;
	margin-top: 0.2em;
	padding-top: 0.2em;
	font-size: 70%;
}

header nav ul li:hover,
header nav ul li.select{
	background-color: var(--skyBlue);
	transition: 0.3s;
}

.navBtn{
	display: none;
}

header nav ul li .naviNew{
	position: absolute;
	bottom: 5%;
	left: -5%;
	width: 3.3em;
	z-index: 1;
}

.indexNavi ul li .naviNew{
	left: inherit;
	right: 2%;
	bottom: inherit;
	top: 5%;
	width: 2.5em;
}

/*---------------------------------------------
サブナビ
---------------------------------------------*/
#subNavi{
	margin-bottom: 3em;
	text-align: center;
}

#subNavi .nomalNavi li{
	display:inline-block;
	position: relative;
	margin:0.5%;
	width: 32%;
	max-width: 363px;
	background-image: url("../img/subnav_off.png");
	background-size: 100%;
}

#subNavi .nomalNavi li img{
	width: 100%;
}

#subNavi .nomalNavi li:hover, #subNavi .nomalNavi li.select{
	background-image: url("../img/subnav_on.png");
	background-size: 100%;
	/*transform: translate(0, -10px);
	transition: 0.3s;*/
}

#subNavi .nomalNavi li:hover a img:not(.newIcon), #subNavi .nomalNavi li.select a img:not(.newIcon){
	filter: brightness(100);
}

#subNavi .nomalNavi .story li{
	width: 49%;
}


/*////////////////////////////////////////////////////////////////////////
トップページ
////////////////////////////////////////////////////////////////////////*/
#top #key{
	position: relative;
}

#top #key #kv{
	overflow: hidden;
}

#top #key img.keyImg{
	width: 100%;
	pointer-events: none;
	position: relative;
	margin-top: -3.5%;
}

#top #key img.kitte{
	width: 50%;
	max-width: 500px;
	position: absolute;
	left: -2em;
	bottom: -1.5em;
}

#top #key .keyOnBox{
	position: absolute;
	left:0;
	top:33em;
	width: 40%;
	margin: auto;
}

#top #key .keyOnBox .logo{
	width: 100%;
	max-width: 700px;
	padding:0 1em;
}

#top #key .keyOnBox .logo img{
	width: 100%;
	pointer-events: none;
}

.indexNavi{
	max-width: 280px;
	width: 18%;
	font-family: var(--fontMei);
	position: absolute;
	background-color: inherit;
	border-bottom: none;
	padding-top: 1em;
}

.indexNavi .logo{
	display: none;
}

.indexNavi ul li{
	width: 100%;
	display: inline-block;
	padding:0.4em 1em;
	background-color: var(--brown);
	margin-bottom: 0.3em;
	border: solid 1px var(--brown);
	border-left: none;
	transition: 0.3s;
	text-align: left;
}

.indexNavi ul li img{
	height: 1em;
	vertical-align: bottom;
	padding: 0;
}

.indexNavi ul li small{
	display: block;
	margin-top: 0.5em;
	padding-top: 0.2em;
	border-top: 1px solid var(--white);
	font-size: 60%;
	opacity: 0.5;
}

.indexNavi ul li:hover,
.indexNavi ul li.select{
	background-color: var(--skyBlue);
	border: solid 1px var(--white);
	border-left: none;
	transition: 0.3s;
	width: 110%;
}

/*---------------------------------------------
新着
---------------------------------------------*/
#top .news{
	width: 100%;
	padding-left: 45%;
	font-weight: bold;
	margin-top: -2em;
}

#top .mds img{
	width: 50%;
	max-width: 400px;
}

#top .news .mds{
	text-align: right;
}

#top .news .txtAria{
	position: relative;
	padding:0.8em 0 0.8em 5em;
	border-radius: calc(1px / 0) 0 0 calc(1px / 0) ;
	background-color: var(--white);
	border: solid 2px var(--orange);
	border-right: none;
	outline: solid 10px  var(--white);
	line-height: 1.3em;
}

#top .news .mail{
	position: absolute;
	left: -2em;
	top: 0.2em;
	width:6.5em;
}

#top .news .mail img{
	width: 100%;
}

#top .news .day{
	display: block;
	letter-spacing: 0.05em;
	border-bottom: 1px dashed var(--orange);
	margin-bottom: 0.5em;
	padding-bottom: 0.3em;
}

#top .news .txt a{
	background-color: var(--skyBlue);
	padding: 0 0.5em;
	margin-bottom: 0.1em;
	display: inline-block;
}

#top .news .txt a:hover{
	background-color: var(--orange);
}

#top .news .more{
	text-align: center;
	padding: 0.5em;
	line-height: 1em;
	position: absolute;
	z-index: 1;
	right: 0.4em;
	bottom: -1em;
	transition: 0.5s;
	transform: rotate(90deg);
	background-color: var(--skyBlue);
	border-radius: calc(1px / 0);
	border: solid 1px var(--white);
	font-size: 180%;
}

#top .news .more:hover{
	transform: rotate(90deg) scale(1.3);
	transition: 0.3s;
}


/*---------------------------------------------
バナー
---------------------------------------------*/
#top #bannerAria{
	margin-top: 3em;
}

#top #bannerBox{
	background-image: url("../img/tex_dot_1.jpg");
	background-position: center top;
	border-top: 3px solid var(--orange);
	border-bottom: 3px solid var(--orange);
	outline: solid 10px  var(--white);
	text-align: center;
	padding: 5em 0 4em;
}

#top #bannerBox img{
	width: 98%;
	margin: 0.5%;
	margin-bottom: 0.2em;
	border: solid 2px var(--brown);
}

#top #bannerBox .slick-dotted.slick-slider{
	margin-bottom: 0;
}

#top #bannerBox .slick-dots{
	position: relative;
	bottom: 0;
}

#top #bannerBox .slick-dots li button:before{
    color: var(--red);
}

#top #bannerBox .slick-dots li.slick-active button:before{
   color: var(--red);
}


/*---------------------------------------------
ストーリー
---------------------------------------------*/
#top #topStory{
	position: relative;
	margin: 14em auto 0;
	background-image:url("../img/mark.png"), url("../img/tex_1.jpg");
	background-position:  center center,  center center;
	background-size: 40%, auto;
	background-repeat: no-repeat, repeat;
	border-radius: 50px;
	border: solid 3px var(--milk);
	outline: solid 20px  var(--white);
	transform: rotate(-2deg);
	width: calc(100% - 50px);
	max-width: 1500px;
	padding: 10em 4% 4%;
}

#top #topStory #letter{
	position: relative;
	background-image: url("../img/border.png");
}

#top #topStory #letter img.kitte{
	position: absolute;
	top: -15em;
	left: -8em;
	width: 25%;
	pointer-events: none;
}

#top #topStory .inBox{
	position: relative;
	padding: 0;
	transform: rotate(2deg);
}

#top #topStory h2{
	position: absolute;
	top: -13em;
	left: 0;
	width: 100%;
	max-width: 1252px;
	margin: auto;
	pointer-events: none;
	background-color: inherit;
	border: none;
	box-shadow: none;
}

#top #topStory h2 img.catch{
	width: 100%;
}

#top #topStory h2 img.point{
	position: absolute;
	left: 5%;
	top: 0%;
	width: 24.5%;
}

#top #topStory .txtAria{
	font-size: 130%;
	position: relative;
	font-family: var(--fontJa);
}

#top #topStory .txtAria .movieBox{
	display: block;
	width: 53%;
	border: solid 5px var(--brown);
	position: relative;
	z-index: 1;
	box-shadow: 6px 6px var(--orange);
}

#top #topStory .txtAria .movieBox .img{
	position: relative;
	overflow: hidden;
}

#top #topStory .txtAria .movieBox .img img{
	width: 100%;
}

#top #topStory .txtAria .movieBox .icon{
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	border: 0;
	z-index: 1;
	transition-duration: 0.3s;
}

#top #topStory .txtAria .movieBox:hover .icon{
  transform: scale(1.2);
  transition-duration: 0.3s;
}


#top #topStory .txtAria .txt{
	position: relative;
	z-index: 1;
	pointer-events: none;
	padding:2em 0 3em;
}

#top #topStory .txtAria .txt img{
	width: 54%;
	max-width: 800px;
}

#top #topStory img.chara{
	position: absolute;
	right: 0;
	top: -1em;
	width: 70%;
	z-index: 0;
	pointer-events: none;
}

#top #topStory .moreLink{
	position: relative;
}


/*---------------------------------------------
システム
---------------------------------------------*/
#top #topSystem{
	margin: 8em auto 8em;
}

#top #topSystem h2{
	width: 100%;
	margin: auto;
	pointer-events: none;
	background-color: inherit;
	border: none;
	box-shadow: none;
	position: relative;
	z-index: 1;
}

#top #topSystem h2 img.catch{
	width: 100%;
}

#top #topSystem .txtAria{
	margin: -6em auto 0;
	padding-bottom: 4em;
	position: relative;
}

#top #topSystem .txtAria img.kitte{
	position: absolute;
	bottom: -2em;
	left: -8em;
	width: 25%;
	pointer-events: none;
	border: none;
	outline: none;
}

#top #topSystem .txtAria img.catch4{
	position: absolute;
	bottom: 5em;
	right: -2em;
	width: 65%;
	pointer-events: none;
	border: none;
	outline: none;
}


#top #topSystem .txtAria  img{
	width: 100%;
	outline: solid 20px var(--white);
	border: solid 3px var(--brown);
}



/*---------------------------------------------
スペック
---------------------------------------------*/
#top #topInfo{
	padding: 2em 0 3em;
	position: relative;
	background-color: var(--white);
}

#top #topInfo #specBox{
	width: 95%;
	margin: auto;
	border: solid 3px var(--orange);
	border-radius: 50px;
	padding: 5em 0;
	background-image: url("../img/tex_top.png"), url("../img/tex_bottom.png"), url("../img/tex_dot_1.jpg");
	background-position: left top, right bottom, center bottom;
	background-repeat: no-repeat, no-repeat, repeat-x;
	background-size: 100%, 100%, auto;
}

#top #topInfo .logo{
	width: 30%;
	margin: 0 auto 1em;
}

#top #topInfo .logo img{
	width: 100%;
}

#top #topInfo .jacket{
	width: 80%;
	margin-top: 0.3em;
	margin: 0 auto;
}

#top #topInfo .jacket img{
	width: 100%;
	border: solid 10px var(--white);
	outline: solid 1px var(--red);
}

#top #topInfo .specAria{
	width: 80%;
	margin: 0 auto;
}

#top #topInfo .specAria table {
	width: 100%;
	display: block;
	line-height: 1.3em;
	font-weight: bold;
	text-align: center;
	margin-bottom: 1em;
}

#top #topInfo .specAria table tbody{
	width: 100% !important;
	display: block;
}

#top #topInfo .specAria table tr{
	display: block;
	padding-top: 0.3em;
}

#top #topInfo .specAria table th{
	color: var(--white);
	width: 100%;
	display: block;
	background-color: var(--red);
	border-radius: calc(1px / 0);
	padding: 0.5em;
	font-family: var(--fontJa);
	box-shadow: 0 3px var(--orange);
}

#top #topInfo .specAria table td{
	width: 100%;
	display: block;
	padding: 0.5em 0 0.5em;
}


/*////////////////////////////////////////////////////////////////////////
ストーリー
////////////////////////////////////////////////////////////////////////*/
#story{
	padding: 0 0 8em;
	overflow: hidden;
	position: relative;
}

#story #storyAria{
	position: relative;
}

#story #storyAria .photo{
	position: absolute;
	z-index: 0;
	width: 70%;
	border: solid 10px var(--white);
}

#story #storyAria .photo img{
	width: 100%;
	border: solid 1px var(--brown);
}

#story #storyAria .photo1{
	top: -4%;
	left: 2%;
	transform: rotate(2deg);
}

#story #storyAria .photo2{
	bottom: -4%;
	right: 3%;
	transform: rotate(-4deg);
}

#story #storyAria .photo3{
	bottom: -10%;
	right: 5%;
	transform: rotate(3deg);
}


#story #storyTxt{
	position: relative;
	margin: 5em  auto 0;
	background-image:url("../img/tex_2.jpg");
	background-position: center center;
	background-size: auto;
	background-repeat:repeat;
	border-radius: 50px;
	border: solid 10px var(--white);
	transform: rotate(-2deg);
	width: 98%;
	max-width: 1300px;
	padding: 0.5em;
}

#story #storyTxt img.kitte{
	position: absolute;
	right: 0;
	top: -4em;
	width: 12%;
}

#story #storyTxt img.poten{
	position: absolute;
	left: -2em;
	bottom: -3em;
	width: 15%;
	animation: fuwafuwa 1.8s ease-in-out infinite alternate-reverse;
}

@keyframes fuwafuwa {
  0% {transform: translateY(-10%);}
  100% {transform: translateY(10%);}
}

#story #storyTxt #letter{
	background-image:url("../img/mark.png"), url("../img/letter_bottom.jpg"), url("../img/tex_1.jpg");
	background-position:  center center, right bottom, center center;
	background-size: 40%, 50%, auto;
	background-repeat: no-repeat, no-repeat, repeat;
	padding: 3em 5em;
	border-radius: 36px;
}

#story #storyTxt .inBox{
	position: relative;
	padding: 0;
	transform: rotate(2deg);
}

#story #storyTxt .txtAria{
	font-size: 130%;
	position: relative;
	font-family: var(--fontJa);
	padding-top: 2em;
}

#story #storyTxt .txtAria .txt{
	position: relative;
	z-index: 1;
	padding-bottom: 3em;
	pointer-events: none;
}

#story #storyTxt .txtAria .txt img{
	width: 60%;
	max-width: 800px;
}

#story #storyTxt .txtAria .txt img.txt2{
	margin-top: 1.5em;
	width: 1000px;
}

#story #storyTxt img.chara{
	position: absolute;
	right: -3em;
	top: 1em;
	width: 75%;
	z-index: 0;
	pointer-events: none;
}



/*---------------------------------------------
world
---------------------------------------------*/
#story #worldAria{
	position: relative;
}

#story .worldTxt{
	position: relative;
	margin: auto;
	max-width: 1300px;
	padding: 3em;
	text-align: center;
	/*font-family: var(--fontJa);*/
	font-weight: bold;
}

#story .worldTxt .point{
	color: var(--red);
}

#story .worldTxt .date{
	text-align: right;
	color: var(--milk);
	font-family: var(--fontMei);
}

#story .worldTxt .date2{
	text-align: center;
	border-top: 1px solid var(--milk);
	margin: 2em auto 0;
	padding: 0.5em 0 0;
}

#story .worldTxt .catch{
	border-top: 1px solid var(--milk);
	border-bottom:1px solid var(--milk);
	margin: 0 auto 1em;
	padding: 1em 0;
	font-size: 150%;
}

#story .worldTxt .catch img{
	width: 100%;
	max-width: 800px;
}

#story .worldTxt .ss img{
	border: solid 1em var(--white);
	outline: 2px solid var(--milk);
	margin: 1em auto 2em;
	width: 100%;
	max-width: 1000px;
}

#story .worldTxt .ss2 img{
	border: solid 1em var(--white);
	outline: 2px solid var(--milk);
	margin: 1em 0.5% 2em;
	width: 49%;
	max-width: 494px;
}

#story .worldTxt .txt{
	width: 85%;
	margin: 0 auto;
	margin-bottom: 5em;
	font-size:max(1.3vw,16px);
}



/*////////////////////////////////////////////////////////////////////////
キャラ
////////////////////////////////////////////////////////////////////////*/
#chara{
	padding-bottom: 5em;
	overflow: hidden;
	position: relative;
	
	background-image: url("../img/letter.png"), url("../img/envelope.png");
	background-position: 5% 95%, 95% 95%;
	background-size: 60%, 40%;
	background-repeat: no-repeat, no-repeat;
}

#chara .inBox{
	padding: 0;
}

/*---------------------------------------------
ナビ
---------------------------------------------*/
#chara .charaNavi ul{
	position: relative;
	z-index: 1;
}
#chara .charaNavi ul li{
	width: 9%;
	transition: 0.1s;
	display: inline-block;
	position: relative;
}

#chara .charaNavi ul li img{
	width: 100%;
}

#chara .charaNavi ul li:hover, #chara .charaNavi ul li.select{
	transform: translate(0, -10px) rotate(2deg);
	transition: 0.1s;
}

/*---------------------------------------------
キャラ個別
---------------------------------------------*/
#chara #charaArea{
	width: 96%;
	margin: auto;
	background-image:url("../img/tex_1.jpg");
	background-position: center center;
	background-size: auto;
	background-repeat:repeat;
	border: solid 3px var(--milk);
	outline: solid 20px  var(--white);
	position: relative;
	box-shadow: 0 0 40px var(--brown);
}

/*---------------------------------------------
上エリア
---------------------------------------------*/
#chara #charaArea #topBox{
	background-image:url("../img/mark.png");
	background-position:  center center;
	background-size: 40%;
	background-repeat: no-repeat;
	direction: rtl;
	position: relative;
}

#chara #charaArea #topBox #charaImg{
	width: calc(100% + 10%);
	margin: -5% -10% 5% -50%;
	display: inline-block;
	position: relative;
	z-index: 0;
	pointer-events: none;
}

#chara #charaArea #topBox #charaImg img{
	width: 105%;
}

#chara #charaArea #topBox #charaImg .selif{
	width: 28%;
	position: absolute;
	transform: rotate(5deg);
	top:45%;
	right: 9em;
}

#chara #charaArea #topBox #charaImg .selif2{
	top: 15em;
	right: 12em;
}

#chara #charaArea #topBox #topLeftArea{
	width: 50%;
	display: inline-block;
	direction: ltr;
	padding: 1em 0 1em 2em;
	position: relative;
	z-index: 1;
}

#chara #charaArea #topBox #name{
	margin-left: -5em;
	margin-bottom: 3em;
}

#chara #charaArea #topBox #name img{
	width: 100%;
}

/*---------------------------------------------
ボイス
---------------------------------------------*/
#chara #charaArea #topBox #voiceBox{
	margin-left: -5em;
	background-image: url("../img/chara/sv_mds.jpg");
	background-position: left center;
	background-repeat: no-repeat;
	background-size: 30%;
	padding-left: 38%;
}

#chara #charaArea #topBox #voiceBox .sv{
	cursor: pointer;
	color: #fff;
	position: relative;
	display: inline-block;
	width: 16.6%;
}

#chara #charaArea #topBox #voiceBox .sv img{
	width: 100%;
	z-index: 1;
	position: relative;
	padding: 2% 0;
}

#chara #charaArea #topBox #voiceBox .play-bt,
#chara #charaArea #topBox #voiceBox .stop-bt{
	display:block;
	cursor: pointer;
	background-image: url("../img/chara/svbg_off.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 100%;
}

#chara #charaArea #topBox #voiceBox .stop-bt{
	background-image: url("../img/chara/svbg_on.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 100%;
}

@media (hover: hover) {
#chara #charaArea #topBox #voiceBox .play-bt:hover{
		background-image: url("../img/chara/svbg_on.png");
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 100%;
	}
}

@media (hover: none) {
#chara #charaArea #topBox #voiceBox .play-bt:active{
		background-image: url("../img/chara/svbg_on.png");
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 100%;
		-webkit-tap-highlight-color: transparent;
	}
}

/*---------------------------------------------
テキスト
---------------------------------------------*/
#chara #charaArea #topBox #txtBox{
	background-image: url("../img/chara/txt_bg_2.png");
	background-position: left center;
	border: solid 3px var(--brown);
	padding: 0 0 0 3em;
	margin: 3em auto;
	position: relative;
}

#chara #charaArea #topBox #txtBox #team{
	position:absolute;
	left: -2.5em;
	bottom: -2.5em;
	width: 28%;
	transform: rotate(-10deg);
}

#chara #charaArea #topBox #txtBox #team img{
	width: 100%;
}

#chara #charaArea #topBox #txtBox #inTxt{
	background-image: url("../img/chara/txt_bg.jpg");
	background-position: center left;
	background-repeat: repeat-y;
	padding:1em;
}

#chara #charaArea #topBox #txtBox #inTxt #txt{
	border: solid 2px var(--yellow);
	padding: 4em 3em;
	background-color: var(--white);
	text-align: center;
	font-size: 90%;
	font-weight: bold;
}

/*---------------------------------------------
下エリア
---------------------------------------------*/
#chara #charaArea #bottomBox{
	border-top: solid 2px var(--milk);
	padding: 3em 1em 2em;
	position: relative;
	/*direction: rtl;*/
	text-align: center;
}

#chara #charaArea #bottomBox .short{
	width: 24.25%;
	margin-right: 1.5%;
	display: inline-block;
	position: relative;
	border: solid 3px var(--brown);
	pointer-events: none;
	display: none;
}

#chara #charaArea #bottomBox #nomal,
#chara #charaArea #bottomBox #nomalImg{
	width: 85%;
	border: solid 3px var(--brown);
	padding: 1em;
	display: inline-block;
	position: relative;
	overflow: hidden;
	pointer-events: none;
}

#chara #charaArea #bottomBox #nomalMini,
#chara #charaArea #bottomBox #nomalMiniImg{
	width: 38.3%;
	border: solid 3px var(--brown);
	padding: 1em;
	display: inline-block;
	position: relative;
	margin-top: 0em;
	overflow: hidden;
}


/*
#chara #charaArea #bottomBox #nomal{
	width: 100%;
	border: solid 3px var(--brown);
	padding: 1em;
	display: block;
	position: relative;
	margin-top: 2em;
	overflow: hidden;
}
*/

#chara #charaArea #bottomBox #nomalImg img,
#chara #charaArea #bottomBox #nomalMiniImg img{
	width: 100%;
}

#chara #charaArea #bottomBox .mds{
	width: 30%;
	position: absolute;
	right: -3em;
	top: 0em;
	z-index: 1;
}

#chara #charaArea #bottomBox .short2{
	margin-right: 4%;
}

#chara #charaArea #bottomBox .short .mds{
	width: 115%;
	position: absolute;
	right: inherit;
	left: -20%;
	top: -10%;
	z-index: 1;
}

#chara #charaArea #bottomBox .mds img,
#chara #charaArea #bottomBox .short .mds img{
	width: 100%;
}


#chara #charaArea #bottomBox .short .movie .zoom{
	position: absolute;
	left: -10%;
	bottom: -5%;
	z-index: 1;
	background-color: var(--orange);
	font-size: 250%;
	line-height: 0.8em;
	padding: 0.3em 0.3em 0.2em 0.2em;
	pointer-events: auto!important;
	border: solid 3px var(--black);
	border-radius: calc(1px / 0);
	transition-duration: 0.3s;
}

#chara #charaArea #bottomBox .short .movie .zoom:hover{
	background-color: var(--red);
	transform: scale(1.2);
	transition-duration: 0.3s;
}


/*////////////////////////////////////////////////////////////////////////
システム
////////////////////////////////////////////////////////////////////////*/
#system{
	padding-bottom: 5em;
	overflow: hidden;
	position: relative;
	text-align: center;
}

#system .sysBox{
	margin:0 auto 3em;
}

#system .sysBox:first-of-type{
	margin-top: 5em;
}

#system .sysBox .slick-dotted.slick-slider{
	margin-bottom: 0;
}

#system .sysBox .slick-dots{
	position: relative;
	bottom: -0.5em;
}

#system .sysBox .slick-dots li button:before{
    color: var(--white);
}

#system .sysBox .slick-dots li.slick-active button:before{
   color: var(--white);
}


#system .harf{
	width: 45%;
	display: inline-block;
}

#system .rtl{
	direction: rtl;
}

#system .txt{
	font-weight: bold;
	text-align: center;
	direction: ltr;
	width: 46%;
	padding:3em 1.5em;
	font-size: 90%;
	line-height: 1.8em;
	background-image: url("../img/tex_dot_1.jpg");
	background-position: center bottom;
	background-size: 2%;
	background-repeat: repeat-x;
	background-color: var(--white);
	transform: rotate(-3deg);
	position: relative;
}

#system .txt .kitte{
	position: absolute;
	bottom: -5em;
	width: 30%;
}

#system .txt .kitte img,
#system .txt .omoi img{
	width: 100%;
}

#system .txt .omoi{
	position: absolute;
	bottom: -13em;
	right: -4em;
	width: 45%;
	z-index: 1;
}



#system .txt .inTxt{
	transform: rotate(3deg);
}

#system .txt .inTxt .title{
	background-color: var(--orange);
	padding: 0.5em;
	margin-bottom: 1em;
	font-size: 120%;
	font-family: var(--fontJa);
	font-weight: normal;
	border-radius: calc(1px / 0);
	color: var(--white);
}

#system .right{
	margin-right: 4%;
	margin-top: 2em;
}

#system .left{
	margin-left: 4%;
}

#system span.marker {
	text-decoration: underline; 
	text-decoration-thickness: 0.5em; 
	text-decoration-color: rgba(63,169,239,0.5);
	text-underline-offset: -0.2em;
	text-decoration-skip-ink: none; 
	font-family: var(--fontJa);
	font-weight: normal;
	font-size: 110%;
	margin-top: -0.15em;
	display: inline-block
}

#system .img{
	width: 50%;
	direction: ltr;
}

#system .img img{
	width: 100%;
}


/*////////////////////////////////////////////////////////////////////////
ムービー
////////////////////////////////////////////////////////////////////////*/
#movie{
	padding-bottom: 5em;
	overflow: hidden;
	position: relative;
	text-align: center;
}

#movie .movieBox{
	width: 48%;
	display: inline-block;
	text-align: center;
	background-image: url("../img/tex_1.jpg");
	border: solid 2px var(--milk);
	outline: solid 5px var(--white);
	padding: 1em;
}

#movie .movieBox .img{
	position: relative;
	overflow: hidden;
	border: solid 2px var(--milk);
}

#movie .movieBox .title{
	border: solid 3px var(--white);
	padding: 0.3em;
	width: 100%;
	background-color: var(--skyBlue);
	display: block;
	transition: 0.3s;
	position: relative;
	text-align: center;
	font-family: var(--fontJa);
	border-radius: calc(1px / 0);
	overflow: hidden;
	margin: auto;
	background-image: url("../img/tex_dot.png");
	background-position: center -20px;
	margin-top: 0.2em;
}

#movie .movieBox .img img{
	width: 100%;
}

#movie .movieBox .icon{
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	border: 0;
	z-index: 1;
	transition-duration: 0.3s;
}

#movie .movieBox:hover .icon{
  transform: scale(1.2);
  transition-duration: 0.3s;
}





/*////////////////////////////////////////////////////////////////////////
スペシャル
////////////////////////////////////////////////////////////////////////*/
#special{
	padding-bottom: 5em;
	overflow: hidden;
	position: relative;
	text-align: center;
}

/*---------------------------------------------
サウンド
---------------------------------------------*/
#special .sound{
	position: relative;
}

#special .sound .photo{
	position: absolute;
	bottom: -1em;
	left: -3em;
	width: 55%;
	transform: rotate(-5deg);
	border: solid 10px var(--white);
	z-index: 0;
}

#special .sound .photo2{
	position: absolute;
	right: -3em;
	top: -1em;
	width: 55%;
	transform: rotate(5deg);
	border: solid 10px var(--white);
	z-index: 0;
}

#special .sound .song{
	width: 44%;
	display: inline-block;
	margin: 5% 3%;
	padding: 5em 2em 3em;
	font-family: var(--fontJa);
	position: relative;
	background-image: url("../img/tex_dot_1.jpg");
	background-position: center bottom;
	background-color: var(--white);
	background-size: 2%;
	background-repeat: repeat-x;
}

#special .sound .song2{
	margin-top: 10em;
}

#special .sound .song .title{
	position: absolute;
	left: 0;
	right: 0;
	top: -4em;
}

#special .sound .song .title img{
	width: 100%;
}

#special .sound .song .txt p{
	border-bottom:  2px dashed var(--milk);
	padding: 0.5em 0 0.2em;
}

#special .sound .song img.kitte{
	position: absolute;
	bottom: -5em;
	left: -5em;
	width: 30%;
}

#special .sound .song img.kitte2{
	position: absolute;
	bottom: -5em;
	right: -5em;
	width: 35%;
}

#special .artist{
	margin-top: 4em;
	padding: 4em 3em 3em;
	position: relative;
}

#special .artist .kitte{
	position: absolute;
	bottom: -1em;
	right: -3em;
	width: 20%;
	z-index: 0;
}

#special .artist .img{
	width: 30%;
	display: inline-block;
}

#special .artist .img img{
	border: solid 1em var(--white);
	outline: 2px solid var(--milk);
	width: 100%;
}

#special .artist .txt{
	width: 70%;
	display: inline-block;
	padding-left: 2em;
	text-align: left;
}

#special .artist .txt .name{
	margin-bottom: 1em;
	color: var(--white);
	width: 100%;
	display: block;
	background-color: var(--orange);
	box-shadow: 0 3px var(--brown);
	border-radius: calc(1px / 0);
	padding:0.5em 1em;
	font-family: var(--fontJa);
	text-align: center;
	font-size: 150%;
	letter-spacing: 0.1em;
	background-image: url("../img/tex_dot.png");
	background-position: center 10%;
}

#special .artist .txt .txtLink{
	background-color: var(--skyBlue);
	padding: 0.5em;
	font-family: var(--fontJa);
	display: inline-block;
	margin-bottom: 0.5em;
	margin-right: 1%;
}

#special .artist .txt .txtLink:hover{
	background-color: var(--orange);
}

#special .artist .txt .linkIcon img:hover{
	transform: scale(1.1);
	transition: 0.3s;
}

#special .artist .txt .linkIcon img{
	width: 24%;
	margin-right: 1%;
	border: solid 1px var(--brown);
	max-width: 50px;
	transition: 0.3s;
}


/*---------------------------------------------
キャストコメント
---------------------------------------------*/
#special .castComment .cast{
	position: relative;
	text-align: left;
	margin-bottom: 6em;
	font-weight: bold;
}

#special .castComment .cast img.kitte2{
	position: absolute;
	bottom: -3em;
	left: -3em;
	width: 15%;
}

#special .castComment .cast .img{
	width: 20%;
	display: inline-block;
	border: solid  2px var(--milk);
}

#special .castComment .cast .img img,
#special .castComment .cast .txt .name img{
	width: 100%;
}

#special .castComment .cast .txt{
	width: 80%;
	display: inline-block;
	padding-left: 2em;
	font-size: 90%;
}

#special .castComment .cast .txt dt{
	border: solid 3px var(--white);
	padding: 0.5em 1em;
	width: 100%;
	background-color: var(--skyBlue);
	color: var(--white);
	display: block;
	transition: 0.3s;
	border-radius: calc(1px / 0);
	margin:1em auto 0.5em;
	background-image: url("../img/tex_dot.png");
	background-position: center -20px;
}

/*---------------------------------------------
スペック
---------------------------------------------*/
#product .spec{
	position: relative;
	background-color: var(--white);
}

#top #topInfo .logo{
	width: 30%;
	margin: 0 auto 1em;
}

#top #topInfo .logo img{
	width: 100%;
}

#product .spec .jacket{
	width: 50%;
	display: inline-block;
	margin-top: 0.3em;
}

#product .spec .jacket img{
	width: 100%;
	/*
	border: solid 10px var(--white);
	outline: solid 1px var(--red);
	*/
}

#product .spec .specAria{
	width: 50%;
	padding-left: 3%;
	display: inline-block;
}

#product .spec .specAria table {
	width: 100%;
	display: block;
	letter-spacing: 0.05em;
	line-height: 1.3em;
	font-weight: bold;
	text-align: center;
	margin-bottom: 1em;
}

#product .spec .specAria table tbody{
	width: 100% !important;
	display: block;
}

#product .spec .specAria table tr{
	display: block;
	padding-top: 0.3em;
}

#product .spec .specAria table th{
	color: var(--white);
	width: 100%;
	display: block;
	background-color: var(--orange);
	box-shadow: 0 3px var(--brown);
	border-radius: calc(1px / 0);
	padding: 0.5em;
	font-family: var(--fontJa);
}

#product .spec .specAria table td{
	width: 100%;
	display: block;
	padding: 0.5em 0 0.5em;
}

#product .se{
	padding: 3em 0 6em;
	background-image: url("../img/tex_1.jpg");
	background-position: right bottom;
	background-repeat: no-repeat;
	background-attachment: fixed;
}

#product .specialEdition img,
#product .pre .preItem img{
	width: 95%;
	display: block;
	margin: 0 auto 3em;
}

#product .specialEdition ul li,
#product .pre .preItem ul li{
	width: 48%;
	margin: 1%;
	display: inline-block;
	font-size: 85%;
	text-align: left;
}

#product .specialEdition ul li span,
#product .pre .preItem ul li span{
	padding: 0 1.5em;
	display: block;
}

#product .specialEdition ul li p,
#product .pre .preItem ul li p{
	color: var(--white);
	padding: 0.5em 1.5em;
	background-color: var(--orange);
	transition: 0.3s;
	font-family: var(--fontJa);
	border-radius: calc(1px / 0);
	margin-bottom: 0.5em;
	font-size: 120%;
}


/*---------------------------------------------
予約特典
---------------------------------------------*/
#product .topCoution{
	margin-bottom: 3em;
	text-align: left;
}

#product .pre .preItem ul li{
	width: 100%;
	margin: auto;
	display: block;
}

#product .pre .movie{
	max-width: 500px;
	margin:0 auto 2em;
	display: block;
	text-align: center;
	background-image: url("../img/tex_1.jpg");
	border: solid 2px var(--milk);
	outline: solid 5px var(--white);
	padding: 1em;
}

#product .pre .movie .inMovie .youtube{
	padding-bottom: 127.5%;
}

/*---------------------------------------------
店舗特典
---------------------------------------------*/
#product .bonus{
}

#product .bonus .shopList{
	width: 48%;
	margin:0 1% 3%;
	display: inline-block;
	border: 2px solid var(--brown);
	text-align: left;
	background-color: var(--white);
}

#product .bonus .shopList .txt{
	padding: 3% 5% 5%;
}

#product .bonus .shopList .itemImg{
	text-align: center;
	margin-bottom: 1em;
}

#product .bonus .shopList .itemImg .popup{
	position: relative;
	width: 48%;
	margin: 1%;
	display: inline-block;
}

#product .bonus .shopList .itemImg img{
	border: solid 1px var(--gray);
	width: 100%;
}

#product .bonus .shopList .itemImg .popup .zoom{
	position: absolute;
	line-height: 1em;
	left: 0;
	bottom: 0;
	background-color: var(--black30);
	color: var(--white);
	padding: 0.4em;
	font-family: var(--fontJa);
	font-size: 120%;
}

#product .bonus .shopList .popup .zoom:hover{
	opacity: 0.5;
}

#product .bonus .shopList .shopName{
	background-color:var(--skyBlue);
	background-image: url("../img/tex_dot.png");
	background-position: center 10%;
	color: var(--white);
	padding:1em 0.5em;
	text-align: center;
	font-size:120%;
	font-family: var(--fontJa);
	border-bottom: 2px solid var(--brown);
}

#product .bonus .shopList .item{
	margin-bottom: 0.2em;
	padding:0.5em 1.5em;
	border-radius: calc(1px / 0);
	background-color: var(--orange);
	font-family: var(--fontJa);
	color: var(--white);
}

#product .bonus .shopList .shopSet{
	/*
	display: inline-block;
	width: 48%;
	margin: 1%;
	*/
	padding: 2em 1em;
	margin: 1em auto;
	border: 2px solid var(--red);
	background-color: var(--white30);
}

#product .bonus .shopList .itemImg .popup{
	width: 32%;
	margin: 0.5%;
}


#product .bonus .shopList .itemImg .big{
	width: 98%;
	margin: 1% auto;
	display: block;
	/*max-width: 430px;*/
}

#product .bonus .shopList .setName{
	border-bottom: 3px solid var(--red);
	font-family: var(--fontJa);
	color: var(--red);
	margin-bottom: 1em;
	font-weight: bold;
	letter-spacing: 0.05em;
}

#product .bonus .shopList small ul,
#product .bonus  .coution,
#product .pre .coution{
	padding-left: 1em;
	font-size: 90%;
	margin-top: 1em;
}

#product .bonus .shopList small ul li,
#product .bonus  .coution li,
#product .pre .coution li{
	text-indent: -1em;
	margin-bottom: 0.2em;
}

#product .bonus .shopList .storeLink{
	color: #fff;
	text-align: center;
	font-family: var(--fontJa);
	background-color: var(--brown);
	padding: 1em;
}

#product .bonus .shopList .storeLink p{
	border-bottom: dashed 1px var(--white);
	margin-bottom: 0.5em;
	padding-bottom: 0.5em;
}

#product .bonus .shopList .storeLink li{
	width: 45%;
	margin: 1%;
	display: inline-block;
	padding: 1em;
	border-radius: 10px;
	color: var(--white);
	background-color: var(--red);
	border: solid 1px var(--white);
}

#product .bonus .shopList .storeLink li:hover{
	color: var(--red);
	background-color: var(--white);
	border: solid 1px var(--brown);
}


#product .bonus .shopList  table{
	margin: 3%;
	width: 94%;
	border-collapse : collapse;
}
#product .bonus .shopList  table td{
	border: solid 2px #ffa1a2;
	text-align: center;
}
#product .bonus .shopList  table td.storeLink{
	background-color: #fff6ef;
}
#product .bonus .shopList  table td.shop_logo{
	font-size: 1.4vw;
	vertical-align: middle;
}
#product .bonus .shopList  table td.shop_logo img{
	width: 70%;
}
#product .bonus .shopList  table .storeLink a{
	width: 100%;
	margin: 0%;
	display: inline-block;
	padding: 1em;
	border-radius: 10px;
	color: var(--white);
	background-color: var(--red);
	border: solid 1px var(--white);
}

#product .bonus .shopList table .storeLink a:hover{
	color: var(--red);
	background-color: var(--white);
	border: solid 1px var(--brown);
}


/*######################################################################
メディアクエリ
######################################################################*/
/*//////////////////////////////////////////////////////////////////////*/
@media screen and (max-width: 1800px) {
/*//////////////////////////////////////////////////////////////////////*/
#chara{
	background-position: -5% 100%, 105% 100%;
	background-size: 70%, 50%;
}
	
/*//////////////////////////////////////////////////////////////////////*/
}
@media screen and (max-width: 1300px) {
/*//////////////////////////////////////////////////////////////////////*/
body{
	font-size: 16px;
}
	
/*//////////////////////////////////////////////////////////////////////*/
}
@media screen and (max-width: 1000px) {
/*//////////////////////////////////////////////////////////////////////*/
	

/*//////////////////////////////////////////////////////////////////////*/
}
@media screen and (max-width: 800px) {
/*//////////////////////////////////////////////////////////////////////*/
br.txtCutNone{display:block;}
br.txtCut{display:none;}
.txtCutNone{display:block;}
.txtCut{display:none;}
	
	
#wrap, #loading{
	background-size: 80%;
}
	
	
body{
	min-width:inherit;
	font-size: 13px;
}

h1{
	background-size: 3%;
	margin:0 auto 2em;
	padding: 0 0 0.5em;
}

h1 img{
	width: 100%;
}
	
.inBox{
	padding:0 1em;
}

.letterBox{
	border: solid 2px var(--milk);
	outline: solid 10px  var(--white);
	padding: 1.5em 1em;
}
	
.kitteLine{
	background-size: 31px;
	height: 1em;
}
	

	
/*---------------------------------------------
バックトップ
---------------------------------------------*/
#backTop{
	padding: 2em;
}

/*////////////////////////////////////////////////////////////////////////
ヘッダー
////////////////////////////////////////////////////////////////////////*/
header, .indexNavi{
	position: fixed;
	z-index: 998;
	margin-top: 0;
}
	
header nav,
.indexNavi nav {
	width: 100%;
	right: 0;
	height: 100%;
	position: fixed;
	background-image: url("../img/bg.jpg");
	background-size: 80%;
	animation: bgAnime 15s infinite linear;
	transform: translateY(-100%); /* 初期状態で上に隠す */
	display: block; /* display: none; を使わない */
	top: -100vh; /* 画面外に完全に隠す */
	transition: top 0.3s ease-in-out;
	padding: 70px 0;
	overflow-y: scroll;/* 縦スクロールを有効にする */
}

header.open nav,
.indexNavi.open nav {
	transform: translateY(0); /* 表示状態 */
	top: 0; /* 表示時に通常位置へ */
}


header nav ul li,
.indexNavi nav ul li{
	display: block;
	width: 80%;
	margin: auto;
	margin-bottom: 1em;
	position: relative;
	background-color: var(--brown);
	border: solid 1px var(--white);
	text-align: center;
	padding: 1em 1em 0.5em;
}

header nav ul li small,
.indexNavi nav ul li small{
	font-size: 100%;
	margin-top: 0.2em;
	padding-top: 0.2em;
}
	
.indexNavi ul li img{
	vertical-align: inherit;
	height: 1.2em;
	padding: 0 0.8em;
}

.indexNavi ul li:hover,
.indexNavi ul li.select{
	width: 80% !important;
	border: solid 1px var(--white);
}
	
.navBtn {
    position: fixed;
    cursor: pointer;
	width: 60px;
	height: 60px;
	/*
    width: 5vw;
    height: 5vw;
	*/
    z-index: 1001;
    right: 0;
    top: 0;
    padding: 1vw; /* ビューポートの幅に基づいたパディング */
	background-color: var(--brown);
	border: solid 1px var(--white);
}

.navBtn:hover{
	background-color: var(--skyBlue);
}

.navBtn:hover span{
}
	
.navBtn span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    background: var(--white);
    width: 50%; /* アイコンの幅を調整 */
    height: 5%;  /* アイコンの高さを調整 */
}

.navBtn span:nth-of-type(1) {
    top: 34%; /* アイコンの位置調整 */
    left: 25%; /* アイコンの位置調整 */
    transform: rotate(0deg);
}

.navBtn span:nth-of-type(2) {
    top: 49%; /* アイコンの位置調整 */
    left: 25%; /* アイコンの位置調整 */
    transform: rotate(0deg);
}

.navBtn span:nth-of-type(3) {
    top: 64%; /* アイコンの位置調整 */
    left: 25%; /* アイコンの位置調整 */
    transform: rotate(0deg);
}

.navBtn.active span:nth-of-type(1) {
    top: 50%;
    left: 50%;
    width: 50%;
    height: 5%;
    transform: translate(-50%, -50%) rotate(-45deg);
}

.navBtn.active span:nth-of-type(2) {
    opacity: 0;
}

.navBtn.active span:nth-of-type(3) {
    top: 50%;
    left: 50%;
    width: 50%;
    height: 5%;
    transform: translate(-50%, -50%) rotate(45deg);
}

header nav ul li .naviNew,
.indexNavi nav ul li .naviNew{
	right: inherit;
	left: 0;
	top: inherit;
	bottom: 10%;
	width: 5em;
	height:auto !important;
}
	
/*---------------------------------------------
サブナビ
---------------------------------------------*/
#subNavi .nomalNavi li{
	width: 49%;
}


/*////////////////////////////////////////////////////////////////////////
トップページ
////////////////////////////////////////////////////////////////////////*/
#top #key img.keyImg{
	width: 130%;
	margin-left: -28%;
	margin-top: 4%;
}

#top #key img.kitte{
	width: 30%;
	bottom: inherit;
	top: -3em;
}

#top #key .keyOnBox{
	position: relative;
	top:0;
	width: 100%;
	margin-top: -6em;
	overflow: hidden;
}

#top #key .keyOnBox .logo{
	width: 90%;
	margin: auto;
}

/*---------------------------------------------
新着
---------------------------------------------*/
#top .news{
	padding: 0;
	margin-left:5%;
	margin-top:5em;
	width: calc(100% - 5%);
}
	
#top .news .mail{
	top: 0.8em;
	width:4.5em;
}
	
#top .news .mds{
	margin-bottom: 4px;
}

#top .news .txtAria{
	outline: solid 5px  var(--white);
	padding-left: 3em;
}	
	
#top .news .more{
	bottom: -1.5em;
}
	
	
/*---------------------------------------------
バナー
---------------------------------------------*/
#top #bannerBox{
	outline: solid 5px  var(--white);
	padding: 2em 0;
	overflow: hidden;
}
	
/*---------------------------------------------
トップストーリー
---------------------------------------------*/
#top #topStory{
	margin: 10em auto 5em;
	background-size: 70%, auto;
	border-radius: 20px;
	border: solid 2px var(--milk);
	outline: solid 5px  var(--white);
	padding: 0 4%;
	transform: none;
}

#top #topStory #letter{
	background-size: 0.4px;
	margin: 5em auto 0;
}

#top #topStory #letter img.kitte{
	top: -8em;
	left: -6em;
	width: 50%;
}

#top #topStory .inBox{
	transform: none;
	top: -10em;
}

#top #topStory h2{
	position: relative;
	top:0;
	left:-5%;
	right: 0;
	width: 110%;
	padding: 0;
}

#top #topStory .txtAria .movieBox{
	width: 100%;
	margin: 2em auto 0;
}
	
#top #topStory .txtAria .txt{
	padding-bottom:2em;
}

#top #topStory .txtAria .txt img{
	width: 100%;
}

#top #topStory img.chara{
	position: relative;
	right: inherit;
	left: -30%;
	top: 0;
	width: 130%;
	margin-bottom: -8em;
}

#top #topStory .moreLink{
	position: relative;
	bottom: -5em;
}

/*---------------------------------------------
システム
---------------------------------------------*/
#top #topSystem{
	margin: 0 auto 8em;
}
	
#top #topSystem .txtAria{
	margin: -4em auto 0;
	padding-bottom: 0;
}
	
#top #topSystem .txtAria img.kitte{
	bottom: 2em;
	left: inherit;
	right: -2em;
	width: 35%;
}

#top #topSystem .txtAria img.catch4{
	position: relative;
	bottom: 1em;
	right: 0;
	width: 100%;
	pointer-events: none;
	border: none;
}
	
#top #topSystem .txtAria img{
	border: solid 2px var(--brown);
	outline: solid 10px var(--white);
}

	
/*---------------------------------------------
スペック
---------------------------------------------*/
#top #topInfo #specBox{
	width: 94%;
	border: solid 2px var(--orange);
	border-radius: 20px;
	padding: 3em 0em;
	background-size: 200%, 200%, auto;
}

#top #topInfo .logo{
	width: 80%;
	margin: 0 auto 1em;
}

#top #topInfo .jacket{
	width: 100%;
	display: block;
	margin-top: 0;
	margin-bottom: 1em;
}

#top #topInfo .jacket img{
	width: 100%;
	border: solid 5px var(--white);
}

#top #topInfo .specAria{
	width: 100%;
	padding-left: 0;
	display: block;
}

#top #topInfo .specAria table {
	width: 100%;
	display: block;
	margin-bottom:0;
}

#top #topInfo .specAria table tr{
	padding-top: 1em;
}
	
#top #topInfo .specAria table td{
	font-weight:normal;
}
	
	

/*////////////////////////////////////////////////////////////////////////
ストーリー
////////////////////////////////////////////////////////////////////////*/
#story{
	padding: 0 0 8em;
}

#story #storyAria .photo{
	width: 100%;
}

#story #storyAria .photo1{
	top: -5%;
}

#story #storyAria .photo2{
	bottom: -4%;
}

#story #storyAria .photo3{
	bottom: -8%;
}

#story #storyTxt{
	border-radius: 20px;
	border: solid 10px var(--white);
	padding: 0.2em;
}

#story #storyTxt img.kitte{
	right: -3em;
	top: -5em;
	width: 30%;
}

#story #storyTxt img.poten{
	bottom: -5em;
	width: 30%;
	z-index: 1;
}

#story #storyTxt #letter{
	background-size: 70%, 80%, auto;
	padding: 1em 2em;
	border-radius: 16px;
}

#story #storyTxt .txtAria .txt{
	padding-bottom:2em;
}

#story #storyTxt .txtAria .txt img{
	width: 100%;
}
	
#top #topStory .txtAria .movie{
	width: 100%;
	box-shadow: 6px 6px var(--orange);
	margin: 2em auto 0em;
}

#top #topStory .txtAria .txt{
	position: relative;
	z-index: 1;
	pointer-events: none;
	padding:2em 0 1em;
}
	
#story #storyTxt img.chara{
	position: relative;
	right: inherit;
	left: -30%;
	top: 0;
	width: 130%;
	margin-bottom: 0;
}
#story .worldTxt .txt{
	width: 95%;
}


/*////////////////////////////////////////////////////////////////////////
キャラ
////////////////////////////////////////////////////////////////////////*/
#chara{
	padding-bottom: 3em;
	overflow: hidden;
	position: relative;
	background-image: none;
}

#chara .inBox{
	padding: 1em;
}

/*---------------------------------------------
ナビ
---------------------------------------------*/
#chara .charaNavi ul li{
	width: 16.6%;
}

/*---------------------------------------------
キャラ個別
---------------------------------------------*/
#chara #charaArea{
	border: solid 2px var(--milk);
	outline: solid 10px  var(--white);
}

/*---------------------------------------------
上エリア
---------------------------------------------*/
#chara #charaArea #topBox{
	background-size: 90%;
	background-position:  center 10em;
	padding-bottom: 5%;
}

#chara #charaArea #topBox #charaImg{
	width: calc(200% + 10%);
	margin: -3em -20% 2em 0;
	display: block;
}

#chara #charaArea #topBox #topLeftArea{
	width: 100%;
	display: block;
	padding: 0 1em;
}

#chara #charaArea #topBox #name{
	margin-left: -3em;
}

/*---------------------------------------------
ボイス
---------------------------------------------*/
#chara #charaArea #topBox #voiceBox{
	margin: 1em 0 3em -3em;
	padding: 5.5em 0 0 3em;
	background-position: left top;
	background-size: 180px;
}

/*---------------------------------------------
テキスト
---------------------------------------------*/
#chara #charaArea #topBox #txtBox{
	background-size: 90%;
	padding: 0 0 0 2em;
}

#chara #charaArea #topBox #txtBox #team{
	width: 25%;
	max-width: 100px;
	bottom: -5em;
}

#chara #charaArea #topBox #txtBox #inTxt #txt{
	font-size: 100%;
	text-align: left;
	font-weight: normal;
	padding: 5em 1em;
	m
}

/*---------------------------------------------
下エリア
---------------------------------------------*/
#chara #charaArea #bottomBox #short{
	width: 100%;
	margin-right: 0;
	display: block;
	position: relative;
	border: solid 3px var(--brown);
	overflow: hidden;
}

#chara #charaArea #bottomBox #nomal{
	width: 100%;
	border: solid 2px var(--brown);
	padding: 0.5em;
	display: block;
	margin-top: 10%;
	margin-bottom: 2em;
}

#chara #charaArea #bottomBox .mds{
	width: 70%;
}

	
/*////////////////////////////////////////////////////////////////////////
システム
////////////////////////////////////////////////////////////////////////*/
	#system{
		padding-bottom: 0;
	}
	
#system .harf{
	width: 100%;
	display: block;
}
	
#system .txt .inTxt .title{
	padding: 0.5em 1em;
	text-align: center;
}

#system .txt{
	width: 100%;
	display: block;
	padding:3em 2em;
	margin: 3em auto 10em;
	font-size: 100%;
	text-align: left;
}	
	
	

/*////////////////////////////////////////////////////////////////////////
ムービー
////////////////////////////////////////////////////////////////////////*/
#movie{
	padding: 0 0 8em;
}

#movie .movieBox{
	width: 100%;
	margin: auto;
	padding: 1.5em;
}
	
	
/*////////////////////////////////////////////////////////////////////////
スペシャル
////////////////////////////////////////////////////////////////////////*/

	
/*////////////////////////////////////////////////////////////////////////
製品情報
////////////////////////////////////////////////////////////////////////*/
#product{
	padding: 0 0 8em;
}

/*---------------------------------------------
スペック
---------------------------------------------*/
#product .spec{
	position: relative;
	background-color: var(--white);
}

#product .spec .jacket{
	width: 100%;
	display: block;
	margin-top: 0;
	margin: 0 auto 1em;
}

#product .spec .jacket img{
	border: solid 5px var(--white);
	outline: solid 1px var(--red);
}
	
#product .spec .specAria{
	width: 100%;
	padding-left:0;
	display:block;
}

#product .spec .specAria table tr{
	padding-top: 1em;
	font-size: 110%;
}
	
#product .spec .specAria table td{
	font-size: 90%;
	font-weight: normal;
}

#product .specialEdition ul li,
#product .pre .preItem ul li{
	width: 100%;
	margin: 1% auto;
	display: block;
	font-size: 100%;
}

#product .specialEdition ul li span,
#product .pre .preItem ul li span{
	padding: 0 1.5em 1.5em;
}

#product .specialEdition ul li p,
#product .pre .preItem ul li p{
	font-size: 110%;
}


/*---------------------------------------------
店舗特典
---------------------------------------------*/
#product .bonus .shopList{
	width: 100%;
	margin: 1em auto 2em;
	display: block;
}

#product .bonus .shopList img{
	width: 100%;
	display: block;
	margin-bottom:2em;
}

#product .bonus .shopList .shopName{
	padding:1em 0.5em;
	font-size:120%;
}

#product .bonus .shopList .item{
	font-size:110%;
}

#product .bonus .shopList .setName{
	font-size:110%;
}

#product .bonus .shopList small ul,
#product .bonus  .coution,
#product .pre .coution{
	font-size: 100%;
}
	
#product .bonus .shopList .storeLink img{
	width:25%;
	margin: 0 auto!important;
}
#product .bonus .shopList  table td.shop_logo img{
	min-width: 120px;
}
#product .bonus .shopList  table .storeLink a{
	font-size: 9px;
}	
#product .bonus .shopList  table td.shop_logo{
	font-size: 3vw;
}	
	
	
/*//////////////////////////////////////////////////////////////////////*/
}
@media screen and (max-width: 480px) {
/*//////////////////////////////////////////////////////////////////////*/


	
	
/*//////////////////////////////////////////////////////////////////////*/
}
/*//////////////////////////////////////////////////////////////////////*/











