@charset "utf-8";
/* CSS Document */

body {
	/*font-family: 'Noto Sans JP', "游ゴシック", "Yu Gothic", YuGothic, 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, 'メイリオ', Osaka, 'MS PGothic', arial, helvetica, sans-serif;*/
    font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
    font-weight: normal;    
    padding: 0px;
	margin: 0px;
    color: #1b1b1b;
}
* {
	padding: 0px;
	margin: 0px;
	-webkit-text-size-adjust: 100%;
}
img {
	border:none;
	max-width:100%;
	vertical-align: bottom;
}
a {
    text-decoration: none;
}
ul, ol {
    list-style: none;
}

.flex_box {
    display: flex;
    flex-wrap: nowrap;
	margin-right: 15%;
}

.flex_box2{
	display: flex;
	flex-wrap: nowrap;
}
#wrapper {
	width: 100%;
	height: auto;
}

#wrapper {
  background-image: url('../images/bg-fix.jpg');
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}

/* header
-------------------------------------------------------------------------*/
header {
    position: absolute;
    top: 0px;
    left: 0;
    width: 100%;
    justify-content: space-between;
    align-items: center;
	background: rgba(255,255,255,0.9);
	padding: 12px 0;

}
.logo {
    width: 273px;
    display: flex;
    justify-content: space-between;
}
.navi_r_box ul {
    width: 25%;
    justify-content: space-between;
    align-items: center;
}
.navi_r_box li {
    width: auto;
    text-align: center;
	margin-left: 1.3em;
}
.navi_r_box a {
    color: #fb8699;
    font-size: 0.95vw;
	width: 2em;
	padding-bottom: 0.3em;
	transition: 0.6s;
	border-bottom: 5px solid #fff;
	border-color: rgba(0,0,0,0.0);
	
}

.navi_r_box a:hover {
	border-bottom: 5px solid #fb8699;
	transition: 0.6s;
}



.fixed {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 9;
    background: rgba(255,255,255,0.9);
    padding: 12px 0;
	border-bottom: 1px solid #e5e5e5;
}
.fixed02 {
	position: fixed;
	top: 82px;
	left: 0;
	width: 100%;
	z-index: 9;
    background: #fff;
}

.header_navi{
	font-family: 'Anton', sans-serif;
    font-family: anton;
    font-size: 18px;
    letter-spacing: 0.1em;
}

.navi_box{
	display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    width: 80%;
    margin: 0 auto;
	max-width: 1300px;	
	min-width: 880px;
}

.navi_r_box{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    font-family: 'Anton', sans-serif;
    font-family: anton;
    font-size: 18px;
    letter-spacing: 0.1em;
	margin-top: 1.29em;
}


.bg_fil_01{
	width:100%;
	background:rgb(255,255,255,0.7);
}

.bg_fil_02{
	width:100%;
	background:rgb(251,134,153,0.7);
}

.bg_fil_03{
	width:100%;
	background:rgb(251,134,153,0.7);
	height:31em;
}

.bg_fil_04{
	width:100%;
	background:rgb(251,134,153,0.7);
	height:41em;
}
.bg_fil_05{
	width:100%;
	background:rgb(251 246 134 / 70%);
	height:25em;
}
.hd-link01 img,
.hd-link02 img{
	height: 22px;
	margin-top: 29px;	
}

	
/*info
-------------------------------------------------------------------------*/
#info{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;

}

.inner_Box {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding:2em 0 3.5em;
}

.news_box{
	border: 0px solid #000;
    border-radius: 8px;
    padding: 3em 4.5em 2em;
    margin-top: 2em;
    background: rgb(251,134,153,0.15);
	box-shadow:4px 4px 8px 0 rgba(0,0,0,0.2);
}

.news_box > img {
    margin-top: -4.6em;
    margin-bottom: 2em;
	margin-left: -5.5em;
}

.news_box > ul{
	height:8em;
	overflow-y: scroll;
}

.news_box > ul > li{
	display: flex;
	flex-flow: row wrap;
	border-bottom: 1px dotted #999;
	padding: 10px 0;
	margin-right: 1em;
}


.news_box > ul > li > span{
	width: 7em;
	font-weight:bold;
	color:#C03;
	display: block;
	margin-top: 3px;
}

.special-info{
	text-align: center;
    width: 90%;
    margin: 2em auto -1em;
    background: rgb(251, 134, 153, 0.15);
    box-shadow: 4px 4px 8px 0 rgba(0,0,0,0.2);
    padding: 1em;
    border-radius: 8px;
}


/*story
-------------------------------------------------------------------------*/
#story{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;
	height:35em;	
}

.contents_ttl{
	margin-left:-1.05em;
	margin-bottom:2em;
}

.contents_story{
    position: relative;
    top: -2em;
    left: 11.8em;
    width: 390px;
    height: 390px;
    border-radius: 190px;
    background: rgb(251,134,153,0.8);
	box-shadow:4px 4px 8px 0 rgba(0,0,0,0.2);
	text-align:center;
}

.contents_story img{
    width: 93%;
    margin: 14px auto;
}

.contents_story2{
    position: relative;
    top: -38em;
    left: 35em;
    width: 500px;
    height: 500px;
    border-radius: 250px;
    background: rgb(251,134,153,1.0);
	box-shadow:4px 4px 8px 0 rgba(0,0,0,0.2);
}

.story_ttl{
	width: 500px;
    color: #fff;
    text-align: center;
    padding-top: 1.5em;
    font-size: 28px;
}

.story_text{
	width: 370px;
    color: #fff;
    margin: 0 auto;
    text-align: left;
	padding-top: 1.3em;
}



/*movie
-------------------------------------------------------------------------*/
#movie{
	width:100%;
	display: block;
	margin-top:-166px;
	padding-top:102px;
}

.youtube {
	width: 100%;
	aspect-ratio: 16 / 9;
	margin: 0 auto;
	box-shadow:8px 8px 16px 0 rgba(0,0,0,0.3);

}
.youtube iframe {
	width: 100%;
	height: 100%;
}



/*character
-------------------------------------------------------------------------*/
#character{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;	
}

.bx-wrapper .bx-controls-auto,
.bx-wrapper .bx-pager {
    bottom: -30px !important;
}

.bx-wrapper {
    background-color: transparent !important;
    margin-top: 0px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	margin-bottom: 1em !important;
    border: none !important;
    box-shadow: none !important;
}
.bx-wrapper img {
    display: block !important;
    margin: 0px auto !important;
}

.sl_contents{
	position:relative;
}

.sl-link{
	width: 20%;
    max-width: 147px;
    display: flex;
    justify-content: space-around;
    position: absolute;
    bottom: 1em;
    right: 1em;
}
.sl-link img{
	width: 100%;
}

.link002{
	margin-left: 0.4em
}

.link001 img{
	transition: 0.6s;	
}


.link001 img:hover{
	opacity:0.5;
	transition: 0.6s;	
}

.link002 img{
	transition: 0.6s;	
}


.link002 img:hover{
	opacity:0.5;
	transition: 0.6s;	
}

/*download
-------------------------------------------------------------------------*/
#download{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;	
}

.download-btn{
	text-align:center;
	margin-top:0;
}

.download-btn img{
    width: 80%;
    background: rgb(251, 134, 153, 0.8);
    padding: 1em 4em;
    color: #fff;
    border: 4px #fff solid;
    border-radius: 400px;
    text-align: center;
    transition: 0.5s;
    max-width: 1100px;
    margin: 0 auto;
}

.download-btn img:hover{
    background: rgb(255 196 0 / 66%);
	color: #fb8699;
	transition: 0.5s;
}


/*creator
-------------------------------------------------------------------------*/
#creator{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;	
}

.cr_flex{
	display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

.creator_box{
	width: 544px;
    background: #fff;
	margin-bottom:1em;
    display: flex;
    border-radius: 15px;
    padding: 1em;
	box-shadow:4px 4px 8px 0 rgba(0,0,0,0.3);
}

.cr_text{
	position:relative;
}

.creator_box img{
	width: 200px;
	margin-right:1em;
}

.cr_name{
	font-size: 22px;
    margin-bottom: 0.6em;
    font-weight: bolder;
    margin-top: 0.4em;
}

.cr_roll{
	font-size: 16px;
}

.link003{
	position: absolute;
    top: 8px;
    right: 0px;
    width: 32px;
}

.link003 img{
	transition: 0.6s;	
}


.link003 img:hover{
	opacity:0.5;
	transition: 0.6s;	
}


/*goods
-------------------------------------------------------------------------*/
#goods{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;	
}

.goods-item{
	width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

.goods-item img{
	width: 48%;
}

.goods-text{
    text-align: center;
    margin: 1em;
}

.link-btn{
	text-align:center;
	margin-top:3em;
}

.link-btn a{
	margin-top: 1em;
    width: 13em;
    background: rgb(251,134,153,0.8);
    padding: 1em 2em;
    color: #fff;
    border: 1px #fff solid;
    border-radius: 40px;
    text-align: center;
    font-size: 23px;
	transition: 0.5s;
}

.link-btn a:hover{
    background: #fff;
	color: #fb8699;
	transition: 0.5s;
}

/*spec
-------------------------------------------------------------------------*/
#spec{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;	
}

.sp_box{
	display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
	margin-bottom:0.7em;
}

.sp_left_box{
	background: rgb(251,134,153,0.8);
	color:#fff;
    width: 29%;
    padding: 1em;
    font-size: 1.2rem;
    font-weight: 600;
}

.sp_right_box{
    background: rgb(255,217,217,0.8);
	color:#444;
    width: 63%;
    padding: 1em;
    font-size: 1.2rem;
    font-weight: 600;
}

/*guideline
-------------------------------------------------------------------------*/
#guideline{
	width:100%;
	display: block;
	margin-top:-102px;
	padding-top:102px;	
}
.guide_box
{
    background: rgb(255, 255, 255, 0.6);
    padding: 2em 3em;
}
.guide_ttl_ct {
	text-align:center;
    font-size: 22px;
    font-weight: bold;
    color: #fb4b90;
    margin-bottom: 1em;
}

.guide_ttl {
    font-size: 20px;
    font-weight: bold;
    color: #fb4b90;
    margin-bottom: 0.5em;
}

.guide_txt{
	margin-bottom:2.5em;

}

.guide_txt_bt{
	margin-bottom:0em;

}

.guide_txt ul{
	margin-top:1em;
}

.guide_txt li{
	text-indent:-0.87em;
	margin-left:0.87em;
	margin-bottom:0.3em;
}

.copy-ttl{
	font-weight:bold;
	margin-bottom:1em;
	color: #373737;
}
.copy-txt{
	color: #444;
}

.copy-txt a{
	color: #444;
}
/*special
-------------------------------------------------------------------------*/
#special{
	width:100%;
	display: block;
}

.sp_flex{
	display: flex;
    justify-content: center;
    background: rgba(255, 255, 255, 0.3);
    padding: 1em;
    border-radius: 30px;
	margin-top: 1em;
}

.contents_ttl2{
	margin-left:-1.05em;
	margin-bottom:0em;
}

.contents_special{
    width: 493px;
    height: auto;
    z-index: 2;
}

.contents_special img{
    margin: 8px auto;
}

.contents_special2{
    width: 450px;
    height: 450px;
    border-radius: 250px;
    background: rgb(251, 134, 153, 1.0);
    box-shadow: 4px 4px 8px 0 rgba(0,0,0,0.2);
    margin-top: 0;
    margin-left: -25px;
}

.special_ttl {
    color: #fff;
    text-align: center;
    padding-top: 3.5em;
    font-size: 24px;
}

.special_text {
    width: 398px;
    color: #fff;
    margin: 0 auto;
    text-align: left;
    padding-top: 3.3em;
    text-align: center;
}

.switch_image {
    position: relative;
}

.switch_image img {
    transition: opacity 0.5s;
}
.switch_image:hover img:first-of-type {
    opacity: 0;
}
.switch_image img:last-of-type {
    position: absolute;
    top: 0px;
    left: 0px;
    opacity: 0;
}
.switch_image:hover img:last-of-type {
    opacity: 1;
}


/* footer
-----------------------------------------------------------------------------------*/
footer {
	background: #fb8699;
    background-size:100%;
}
.foot_logo {
    margin: 0 auto;
    display: block;
    width: 20%;
    padding: 5rem 0 1.5rem 0;
}
.foot_txt {
    text-align: center;
    font-size: 14px;
    color: #fff;
    padding-bottom: 4.5rem
}
small {
	display: block;
	text-align: center;
	color: #fff;
	font-size: 0.75rem;
	letter-spacing: 1px;
	padding: 10px 0;
}
/* ハンバーガーメニュー
-----------------------------------------------------------------------------------*/
nav.NavMenu{
	position: fixed; /*表示位置を固定*/
	z-index: 4; /*重ね順を変更*/
	top: 0; /*表示位置を指定*/
	left: 0; /*表示位置を指定*/
	/*background: #fff;*//*背景を白にする*/
	color: #fff; /*文字色を黒にする*/
	text-align: center; /*テキストを中央揃え*/
	width: 50%; /*全幅表示*/
	transform: translateX(200%); /*ナビを右に隠す*/
	transition: all 0.6s; /*アニメーションの時間を指定*/
}
nav.NavMenu ul{
	/*background: #ccc;*/ /*背景をグレーにする*/
	background: rgba(0,0,0,0.8);
	width: 100%;
	margin: 0 auto;
	padding: 0;
	height: 100vh;
	overflow-y: auto;
}
nav.NavMenu ul li{
	font-size: 1.1em;
	list-style-type: none;
	padding: 0;
	width: 94%;
	margin: 0 auto;
	border-bottom: 1px dotted #f5f5f5;
}
nav.NavMenu ul li:last-child{
	padding-bottom: 0;
	border-bottom: none; /*最後のメニュー項目のみ下線を消す*/
}
nav.NavMenu ul li a{
	display: block; /*クリックできる領域を広げる*/
	color: #fff;
	padding: 1em 0;
}
/*トグルボタンが押されたときに付与するクラス*/
nav.NavMenu.active{
	transform: translateX(100%);
}
/*トグルボタンのスタイルを指定*/
.Toggle {
	display: block;
	position: fixed;    /* bodyに対しての絶対位置指定 */
	right: 13px;
	top: 12px;
	width: 42px;
	height: 42px;
	cursor: pointer;
	z-index: 5;
} 
.Toggle span {
	display: block;
	position: absolute;
	width: 30px;
	border-bottom: solid 3px #000;
	-webkit-transition: .35s ease-in-out;	/*変化の速度を指定*/
	-moz-transition: .35s ease-in-out;		/*変化の速度を指定*/
	transition: .35s ease-in-out;			/*変化の速度を指定*/
	left: 6px;
} 
.Toggle span:nth-child(1) {
	top: 9px;
} 
.Toggle span:nth-child(2) {
	top: 18px;
} 
.Toggle span:nth-child(3) {
	top: 27px;
}
.Toggle.active span {
		border-bottom: solid 3px #fff;
}
/* 最初のspanをマイナス45度に */
.Toggle.active span:nth-child(1) {
	top: 18px;
	left: 6px;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	transform: rotate(-45deg);
} 
/* 2番目と3番目のspanを45度に */
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
	top: 18px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	transform: rotate(45deg);
}

.menu_logo {
	width: 18%;
	margin: 0 auto;
	padding: 2rem 0 1rem 0;
}

/* pc/sp
-----------------------------------------------------------------------------------*/
.pc {
	display:block;
}

.sp {
    display: none;
}

.pc_n{
	display:flex;
}

/* ページトップへ戻る */
.pageTop {
	display:none;
	position:relative;
	width:90%;
	max-width:900px;
	height:0;
	margin:0 auto;
}
.pageTop a {
	position: fixed;
	bottom: 0px;
	right:0;
	display: block;
	width: 66px;
	hegiht:66px;
	margin-right:2em;
	padding:1em 0 1em 2px;
	background:#232323;
	text-align:center;
	outline:none;
	text-decoration: none;
	z-index:9999;
	border-radius:3px 3px 0 0;
	opacity: 0.6;
}
.pageTop a:before,
.pageTop a:after {
	position:absolute;
	left:50%;
	content:"";
	width:0px;
	height:0px;
	margin-left:-10px;
	border:10px solid transparent;
}
.pageTop a:before {
	top:50%;
	margin-top:-13px;
}
.pageTop a:after {
	top:50%;
	margin-top:-15px;
	border-bottom:10px solid #fff; /* 矢印の色 */
}


