@charset "utf-8";


:root{
	--red: #650125;
	--pink: #d3014a;
}

body {
	/*ゴシック*/font-family: "Noto Sans TC";/*,"Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
	/*明朝font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", "Noto Serif JP", serif;*/
	color: #345571;
	font-size: 16px;
	font-weight: bolder;
	line-height: 1.5;
	background-color: #fff;
	/*background-image: url(../img/bg_sikaku_side.png), url(../img/bg_kazu_left.png), url(../img/bg_kazu_right.png), url(../img/bg1.jpg);
	background-position: center center, left top, right top, center top;
	background-size: 100% auto, auto auto, auto auto, 100% auto;
	background-repeat: repeat-y, repeat-y, repeat-y, no-repeat;
	background-attachment: scroll, scroll, scroll, scroll;*/
}


h2 {
	display: block;
	padding: 30px 0;
}
h2.top {
	position: relative;
	padding: 0;
	margin: auto;
	z-index: 1;
}
h2 img {
	display: block;
	width: 100%;
	max-width: 800px;
	margin: auto;
}



.show_pc {
	display: inherit;
}
.show_sp {
	display: none;
}





/* subnav
---------------------------------------------*/
.subnav {
	/*position: sticky;
	top: 10px;*/
	text-align: center;
	padding: 30px 15px 15px 15px;
}
.subnav a img {
	display: block;
	width: 100%;
}
.subnav a {
	box-sizing: border-box;
	position: relative;
	display: inline-block;
	color: #0f79e6;
	line-height: 1em;
	background: #92e2ff;
	width: 35%;
	max-width: 200px;
	/*margin: 5px;*/
	margin: 15px 5px 5px 5px;
	border: solid 1px #fff;
}
.subnav a:hover {
	background: #86b8ff;
	border: solid 1px #d2ccff;
}
.subnav a.select {
	background: #fff;
	border: solid 1px #fff;
	box-shadow: 5px 5px #92e2ff;
}
.subnav span {
	box-sizing: border-box;
	display: block;
	position: absolute;
	top: -35%;
	color: #fff;
	font-size: 10px;
	font-weight: bold;
	line-height: 1;
	text-align: center;
	background: #26cdee;
	width: 100%;
	padding: 2px;
}




/* footer
------------------------------*/
#graffitiBox {
	text-align: center;
	background-color: #66caef;
	background-image: url("../img/bg3.jpg");
	padding: 50px;
}
#graffitiBox img {
	display: block;
	width: 100%;
}
#graffitiBox a {
	box-sizing: border-box;
	display: inline-block;
	width: 30%;
	max-width: 465px;
	margin: auto;
	border: solid 1px #380909;
	box-shadow: 0 0 3px #fff;
}



/*#bg1, #bg2, #bg3, #bg4 {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center top;
}
#bg1 {
	background-image: url("../img/bg1.jpg");
}*/
#bg1::after, #bg2::after, #bg3::after, #bg4::after, #bg5::after, #bg6::after, #bg7::after, #bg8::after, #bg9::after {
	content: "";
	position: fixed;
	top: 0;
	height: 100vh;
	left: 0;
	right: 0;
	z-index: -2;
	background-position: center top;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
}
#bg1::after {
	background-image: url("../img/bg_g1.jpg");
}
#bg2::after {
	background-image: url("../img/bg_g2.jpg");
}
#bg3::after {
	background-image: url("../img/bg_g3.jpg");
}
#bg4::after {
	background-image: url("../img/bg_g4.jpg");
}
#bg5::after {
	background-image: url("../img/bg_g5.jpg");
}
#bg6::after {
	background-image: url("../img/bg_g6.jpg");
}
#bg7::after {
	background-image: url("../img/bg_g7.jpg");
}
#bg8::after {
	background-image: url("../img/bg_g8.jpg");
}
#bg9::after {
	background-image: url("../img/bg_g9.jpg");
}



/*op
---------------------------------------------*/
#opBox {
	position: absolute;
	top: 0;
	left: 0;
	/*bottom: 0;
	right: 0;*/
	background: #fff;
}
#op {
	position: fixed;
	background-color: #fff;
	background-image: url(../img/op/bg.jpg);
    background-position: center top;
	background-size: 140% auto;
	background-repeat: no-repeat;
	width: 100%;
	height: 100vh;
	z-index: 10000;
	  animation: bg 3s 1 ease;
}
@keyframes bg {
  0% {
    background-position: center center;
  }
  100% {
    background-position: center top;
  }
}
#op #opWhite {
	display: none;
	background: #fff;
	width: 100%;
	height: 100vh;
}
.fadeIn{
	animation-name:fadeInAnime;
animation-duration:5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeInAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}



/*top
---------------------------------------------*/
#topAll {
	background-color: #fff;
	background-image: url(../img/bg_sikaku_side.png), url(../img/bg_kazu_left.png), url(../img/bg_kazu_right.png), url(../img/bg1.jpg);
	background-position: center center, left top, right top, center top;
	background-size: 100% auto, auto auto, auto auto, 100% auto;
	background-repeat: repeat-y, repeat-y, repeat-y, no-repeat;
	background-attachment: scroll, scroll, scroll, scroll;
	overflow: hidden;
}
#topImg {
	position: relative;
}
#topImg img {
	display: block;
}
#topImg #keyVisual {
	width: 100%;
}
#topImg #dendo {
	position: absolute;
}

#topicBanner {
	display: block;
	position: absolute;
	bottom: 0;
	right: 0;
	width: 30%;
	max-width: 576px;
}
#topicBanner img {
	display: block;
	width: 100%;
}

#topMovieAll {
	box-sizing: border-box;
	position: absolute;
	left: 2%;
	bottom: 4%;
	background: #cbfffd;
	width: 23%;
	padding: 5px;
	margin: auto;
	border: solid 1px #1baaaf;
}
#topMovie {
	box-sizing: border-box;
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	border: solid 2px #1baaaf;
	overflow: hidden;
}
#topMovie::after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: "";
	display: block;
	background-image: url("../img/playmovie_off.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: auto 50%;
	z-index: 2;
	transition: transform .5s ease;
}
#topMovie:hover::after {
	background-image: url("../img/playmovie_on.png");
	transform: scale(1.2);
}
#topMovieKazari {
	position: relative;
}
#topMovieKazari #sikakuLtL,
#topMovieKazari #sikakuLtS,
#topMovieKazari #sikakuRbL,
#topMovieKazari #sikakuRbS {
	display: block;
	position: absolute;
}
#topMovieKazari #sikakuLtL,
#topMovieKazari #sikakuRbL {
	width: 20%;
}
#topMovieKazari #sikakuLtS,
#topMovieKazari #sikakuRbS {
	width: 10%;
}
#topMovieKazari #sikakuLtL {
	top: -15%;
	left: -10%;
	animation: rotation 6s linear infinite;
}
#topMovieKazari #sikakuLtS {
	top: -30%;
	left: 0;
	animation: rotation 4s linear infinite;
}
#topMovieKazari #sikakuRbL {
	bottom: -15%;
	right: -10%;
	animation: rotation 4s linear infinite;
}
#topMovieKazari #sikakuRbS {
	bottom: 20%;
	right: -10%;
	animation: rotation 6s linear infinite;
}
@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

#bannerArea {
	background: rgb(148,221,255,0.5);
	background: linear-gradient(90deg, rgba(148,221,255,0) 0%, rgba(176,226,255,0.5) 50%, rgba(148,221,255,0) 100%);
	padding: 50px;
	margin: 50px auto;
	border-top: 10px solid;
	border-bottom: 10px solid;
	border-image: linear-gradient(to right, transparent, #5ff3ff, transparent) 1;
}
#bannerArea img {
	box-sizing: border-box;
	display: block;
	width: 100%;
}
#bannerArea .sliderTop {
	padding: 0 10px;
}

.scrollline {
	display: block;
	width: 5px;
	margin: auto;
}

.topContentBoxBg {
	position: relative;
	width: 100%;
	max-width: 800px;
	padding: 0 0 50px 0;
	margin: auto auto 50px auto;
}
.topContentBoxBg::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	/*height: 100vh;*/
	left: 0;
	right: 0;
	/*z-index: -2;*/
	z-index: 0;
	background-color: #bbe7f8;
	background-image: url(../img/bg2.jpg);
	-webkit-mask: url(../img/bg_boxmask.png) center / 100% 100% no-repeat;
	mask: url(../img/bg_boxmask.png) center / 100% 100% no-repeat;
}
.topContentBox {
	position: relative;
	width: 90%;
	margin: auto;
	z-index: 1;
}


#topNewsAll {
	width: 70%;
	margin: auto;
}
dl#newsAll {
	/*height: 10em;
	overflow: auto;*/
	text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff;
}
dl#newsAll dt {
	font-weight: bold;
	color: #14c3ce;
}
dl#newsAll dd {
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: dashed 1px #345571;
}
dl#newsAll a {
	display: block;
	/*text-indent: -1em;
	padding-left: 1em;*/
}
/*#topNewsAll a::before {
	content: "・";
}*/
dl#newsAll a:not(.non):hover {
	color: #345571;
}
#topNewsAll a.moreBtn {
	display: block;
	background-image: url(../img/btn_more_bg.png);
	background-size: 100% auto;
	background-position: center top;
	background-repeat: no-repeat;
	width: 50%;
	min-width: 200px;
	max-width: 460px;
	margin: auto;
}
#topNewsAll a.moreBtn img {
	display: block;
	width: 100%;
	margin: auto;
	opacity: 0;
}
#topNewsAll a.moreBtn:hover {
	background-position: center bottom;
}



/*news
---------------------------------------------*/
#secNewsAll {
	box-sizing: border-box;
	background: rgba(255,255,255,0.7);
	width: 90%;
	max-width: 1000px;
	padding: 15px;
	margin: auto auto 100px auto;
}



/*story
---------------------------------------------*/
#storyAll {
	background-image: url("../img/bg_sikaku_side.png");
	background-repeat: repeat-y;
	background-position: center top;
	background-size: 100% auto;
	margin-bottom: 100px;
}
#storyTxt {
	display: block;
	width: 90%;
	max-width: 600px;
	margin: auto;
}

p#kankou {
	display: block;
	background-color: #8dbfe7;
	background-image: url(../kankou/img/mds_dasshed.png), url(../kankou/img/mds_bg.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom;
	padding: 15px 10px;
	border-top: solid 1px #fff;
	border-bottom: solid 1px #fff; 
}
p#kankou img {
	display: block;
	width: 50%;
	/*max-width: 679px;*/
	max-width: 400px;
	margin: auto;
}
#kankouMapAll {
	position: relative;
}
#kankouMapAll #kankouMap {
	display: block;
	width: 100%;
}
#kankouMapAll a {
	position: absolute;
	display: block;
	width: 16%;
}
#kankouMapAll a img {
	display: block;
	width: 100%;
}
#kankouMapAll a.map0 { /* ツリー */
	top: 15.5%;
	left: 8%;
}
#kankouMapAll a.map1 { /* 学校 */
	top: 33.5%;
	left: 1.1%;
}
#kankouMapAll a.map2 { /* 海岸通り */
	top: 30.8%;
	left: 44%;
}
#kankouMapAll a.map3 { /* 図書館 */
	top: 46%;
	right: 4%;
}
#kankouMapAll a.map4 { /* レストラン */
	top: 48.7%;
	left: 27%;
}
#kankouMapAll a.map5 { /* 公園 */
	top: 48.5%;
	left: 6.3%;
}
#kankouMapAll a.map6 { /* 特異点 */
	top: 66.5%;
	right: 10.2%;
}



/*chara
---------------------------------------------*/
#charaSerectTop {
	/*position: relative;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-align-items: stretch;
	align-items: stretch;
	height: 700px;
	overflow: auto;*/
	width: 100%;
	margin: auto auto 100px auto;
}
#charaSerectTop a {
	display: inline-block;
	text-align: center;
}
/* 中央以外のスライド */
#charaSerectTop a {
	/*filter: grayscale(80%);*/
  transform: scale(.8);
  transition: opacity .5s, transform .5s;
}
/* 中央のスライド */
#charaSerectTop .slider a.slick-center {
	/*filter: grayscale(0);*/
  transform: scale(1);
}
#charaSerectTop img.tatie {
	display: block;
	width: 100%;
	margin: auto;
}
.slick-arrow:before{
	content:""!important;
}
.slick-arrow:before{
    content:""!important;
    width: 100%!important;
    height: 100%!important;
    position: absolute;
    top: 0;
    left: 0;
}

.slick-next:before{
    background: url(../chara/img/btn_next_off.png)!important;
    background-size: contain!important;
}
.slick-next:hover:before{
    background: url(../chara/img/btn_next_on.png)!important;
    background-size: contain!important;
}

.slick-prev:before{
    background: url(../chara/img/btn_prev_off.png)!important;
    background-size: contain!important;
}
.slick-prev:hover:before{
    background: url(../chara/img/btn_prev_on.png)!important;
    background-size: contain!important;
}
.slick-arrow{
    z-index:2!important;
    width:4%!important;
	aspect-ratio: 13/24!important;
    height:auto!important;
}

.slick-next{
    right:0!important;
}

.slick-prev{
    left:0!important;
}


#charaProfAll {
	position: relative;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: flex-start;
	align-items: flex-start;
	width: 80%;
	max-width: 1000px;
	margin: auto;
}
#charaProfAll img {
	display: block;
	width: 100%;
}
#charaProfImg,
#charaProfTxt {
	box-sizing: border-box;
	position: relative;
	width: 50%;
}
#charaProfImg {
	order: 2;
}
#charaProfTxt {
	order: 1;
}
#charaProfImg #kirikae {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	width: 25%;
	max-width: 200px;
	z-index: 10;
	cursor: pointer;
}
#charaProfImg #cImg {
	position: relative;
}
#charaProfImg #cImg #cImg1 {
}
#charaProfImg #cImg #cImg2 {
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
}
#charaProfImg #cSerif {
	display: block;
	position: absolute;
	top: 15%;
	right: 5%;
	width: 20%;
	max-width: 159px;
}
#charaProfTxt #charaName {
	display: block;
	width: 100%;
	margin-bottom: 30px;
}
#charaProfTxt #charaTxt {
	line-height: 2.4;
	background-color: rgba(255,255,255,0.7);
	background-image: url(../chara/img/text_line.png);
	background-size: 14.7px auto;
	padding: 15px;
	font-weight: 500; /* <<< 加粗設定 */
	font-family: 'Noto Sans TC', sans-serif; /* 引入的字體 */
}


#voice {
	text-align: center;
	padding: 30px 15px;
}
#voice a {
	display: inline-block;
	width: 30%;
	max-width: 250px;
	cursor: pointer;
}
#voice a:hover {
	opacity: 0.7;
}
#voice .play-bt {
}
#voice .stop-bt {
	opacity: 0.7;
}
#voice a img {
	display: block;
	width: 100%;
}

#btnPrev,
#btnNext {
	display: block;
	box-sizing: border-box;
	position: fixed;
	top: 50%;
	background-size: 100% 100%;
	background-repeat: no-repeat;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	width: 4%;
	z-index: 10;
}
#btnPrev {
	left: 0;
}
#btnPrev:hover {
	background-image: url(../chara/img/btn_prev_on.png);
}
#btnNext {
	right: 0;
}
#btnNext:hover {
	background-image: url(../chara/img/btn_next_on.png);
}
#btnPrev:hover img,
#btnNext:hover img {
	opacity: 0;
}
#btnPrev img,
#btnNext img {
	display: block;
	width: 100%;
}

#charaSerectSec {
	text-align: center;
	background-image: url("../img/bg2.jpg");
	padding: 50px 15px;
}
#charaSerectSec a {
	display: inline-block;
	width: 23%;
	margin: 1%;
	max-width: 150px;
}
#charaSerectSec img {
	display: block;
	width: 100%;
}

#cBackAll {
	text-align: center;
	background-image: url(../img/bg3.jpg);
	padding: 2px;
	border-top: solid 2px #fff;
	border-bottom: solid 2px #fff;
}
#cBackAll a {
	display: block;
	background-image: url(../chara/img/btn_back_all_on.png);
	background-size: 100% 100%;
	width: 30%;
	max-width: 300px;
	padding: 0;
	margin: auto;
}
#cBackAll a:hover img {
	opacity: 0;
}
#cBackAll img {
	display: block;
	width: 100%;
	padding: 0;
	margin: 0;
}



/*gallery
---------------------------------------------*/
.galleryBox {
	text-align: center;
	width: 90%;
	max-width: 1000px;
	margin: auto auto 5% auto;
}
.galleryBox a {
	box-sizing: border-box;
	display: inline-block;
	position: relative;
	vertical-align: bottom;
	background: rgba(106,86,255,1);
	width: 20%;
	margin: 1.5%;
	border: solid 8px #fff;
	box-shadow: 1px 1px 2px 2px #2ab8b9;
}
.galleryBox img {
	box-sizing: border-box;
	display: block;
	width: 100%;
	margin: auto;
}
.galleryBox a:hover img {
	opacity: 0.7;
}
.galleryBox img.newIon {
	
}



/*add
---------------------------------------------*/
.addBox {
	box-sizing: border-box;
	background: rgba(255,255,255,0.6);
	width: 90%;
	max-width: 1000px;
	padding: 3%;
	margin: auto auto 5% auto;
}
.addBoxBorder{
	padding: 3%;
	border: solid 3px #fff;
}
.addBox img {
	box-sizing: border-box;
	display: block;
	width: 100%;
	margin: auto;
}
.addBox img.cg {
	border: solid 10px #fff;
}
.addBox img.epiChara {
	max-width: 9250px;
}
.newEpiBox {

}
.newEpiBox dl {
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: flex-start;
	align-items: flex-start;
	margin-top: 1em;
}
.newEpiBox dt,
.newEpiBox dd {
	box-sizing: border-box;
}
.newEpiBox dt {
	color: #fff;
	text-align: center;
	background: #11ced0;
	width: 20%;
	padding: 5px;
}
.newEpiBox dd {
	text-indent: -1em;
	width: 80%;
	padding: 5px 5px 5px 1em;
}
.newEpiBox {
	
}



/*system
---------------------------------------------*/
.systemBox {
	background: rgba(193,238,255,0.8);
	width: 90%;
	max-width: 1000px;
	margin: auto auto 5% auto;
}
.systemBox dt {
	color: #0f79e6;
	font-size: 26px;
	font-weight: bold;
	text-align: center;
	background: #fff;
	padding: 14px;
	border-bottom: solid 8px #7cdbdc;
}
.systemBox dd {
	padding: 3%;
	border-top: solid 10px #fff;
}
.systemBox .systemImg {
	margin-bottom: 1.5em;
}
.systemBox img {
	box-sizing: border-box;
	display: block;
	width: 100%;
	border: solid 2px #119697;
}



/*sound
---------------------------------------------*/
.musicBox {
	box-sizing: border-box;
	color: #345571;
	text-align: center;
	background: rgba(124,219,220,0.8);
	width: 90%;
	max-width: 1000px;
	margin: auto auto 5% auto;
	border: solid 5px #fff;
	text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff;
}
.musicBox div.songCate {
	padding: 1em;
}
.musicBox div.songTitle {
	color: #0f79e6;
	font-size: 36px;
	font-weight: bold;
	background-color: rgba(255,255,255,0.8);
	background-image: url(../music/img/songtitle_line.png);
	background-repeat: repeat-x;
	background-position: center bottom;
	padding: 0.8em;
}
.musicBox div.songStaff {
	padding: 1.5em 1em;
}



/*movie
---------------------------------------------*/
.movieAll {
	width: 100%;
	max-width: 700px;
	margin: auto;
}
.movieAll a {
	position: relative;
	box-sizing: border-box;
	display: inline-block;
	/*明朝*/font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", "Noto Serif JP", serif;
	text-align: center;
	background: #000;
	padding: 5px;
	margin-bottom: 50px;
	box-shadow: 0 0 5px #8dc2f9;
	overflow: hidden;
}
.movieAll a:last-child {
	margin-bottom: 0;
}
.movieAll a::after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: "";
	display: block;
	background-image: url("../img/btn_play.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: auto 30%;
	z-index: 2;
	transition: transform .5s ease;
}
.movieAll a:hover::after {
  transform: scale(1.5);
}
.movieAll img {
	display: inline-block;
	width: 100%;
}
.movieAll p {
	padding: 10px;
}
.movieAll small {
	display: block;
	font-size: 14px;
}



/*special
---------------------------------------------*/
.spMovieBox {
	text-align: center;
	margin-bottom: 100px;
}
.spMovieBox li {
	box-sizing: border-box;
	display: inline-block;
	position: relative;
	background: #fff;
	width: 45%;
	padding: 5px;
	margin: 1%;
	border: solid 2px #0f8aeb;
	box-shadow: 0 0 10px #7cdbdc, 0 0 10px #7cdbdc, 0 0 10px #7cdbdc;
}
.spMovieBox a {
	display: block;
	position: relative;
	cursor: pointer;
	overflow: hidden;
}
.spMovieBox a::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: "";
	display: block;
	background-color: none;
	background-image: url("../special/img/movie_frame.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 100% auto;
	z-index: 2;
}
.spMovieBox a:hover::before {
	background-color: rgba(106,86,255,0.5);
}
.spMovieBox a::after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: "";
	display: block;
	background-image: url("../img/playmovie_off.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: auto 50%;
	z-index: 3;
	transition: transform .5s ease;
}
.spMovieBox a:hover::after {
	background-image: url("../img/playmovie_on.png");
  transform: scale(1.2);
}
.spMovieBox img {
	display: block;
	width: 100%;
	margin: auto;
}
.spMovieBox span {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	line-height: 1;
	text-align: center;
	background: #26cdee;
	padding: 5px;
}
.youtube {
	box-sizing: border-box;
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}
.youtube iframe {
	box-sizing: border-box;
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

/*interview*/
.interviewBox {
	width: 90%;
	max-width: 700px;
	margin: auto auto 5% auto;
}
.interviewBox img {
	display: block;
	width: 100%;
	max-width: 700px;
	margin: auto;
}
.interviewBox dl {
	background: rgba(255,255,255,0.8);
	padding: 1em;
	margin-top: 1em;
	border: solid 2px #aacef7;
}
.interviewBox dl dt {
	color: #fff;
	background: #50cecf;
	padding: 10px;
}
.interviewBox dl dd {
	padding: 10px;
}
.snsIconAll,
.snsHeaderAll {
	text-align: center;
	width: 90%;
	margin: auto auto 5% auto;
}
.snsIconAll {
	max-width: 700px;
}
.snsHeaderAll {
	max-width: 1000px;
}
.snsIconAll img {
	display: inline-block;
	width: 23%;
	margin: 1%;
}
.snsHeaderAll img {
	display: inline-block;
	width: 45%;
	margin: 1%;
}






/*info
---------------------------------------------*/
.secProduct {
	padding: 0 3%;
	margin: auto auto 100px auto;
}
#specAll {
	display: block;
}
#specAll #package,
#specAll #spec {
	box-sizing: border-box;
	width: 100%;
}
#specAll #package {
	padding-bottom: 30px;
}
#specAll #package img {
	display: block;
	width: 100%;
	max-width: 700px;
	margin: auto;
}
#specAll #spec {
}
#specAll #spec table {
	box-sizing: border-box;
	border-collapse: separate;
	border-spacing: 5px 5px;
	background: rgba(255,255,255,0.8);
	width: 100%;
	max-width: 700px;
	padding: 10px;
	margin: auto;
	border: solid 1px #8dc2f9;
}
#specAll #spec th,
#specAll #spec td {
	/*display: inline-block;*/
	padding: 5px 10px;
}
#specAll #spec th {
	color: #fff;
	text-align: center;
	vertical-align: middle;
	background: #8dc2f9;
}
#specAll #spec td {
	border-bottom: dashed 2px #8dc2f9;
}
/*#specAll #spec span {
	display: inline-block;
	background: rgba(0,0,0,0.5);
}*/

.limipreAll {
	width: 100%;
	max-width: 700px;
	margin: auto;
}
.limipreImg {
	
}
.limipreImg img {
	display: block;
	width: 100%;
	margin: auto;
}
.limipreTxt dl {
	margin-top: 30px;
}
.limipreTxt dt {
	font-weight: bold;
	text-align: center;
	background: #8dc2f9;
	padding: 5px 10px;
}
.limipreTxt dd {
	background: rgba(255,255,255,0.8);
	border: solid 2px #8dc2f9;
	padding: 10px;
	margin-bottom: 15px;
}
.limipreTxt dd strong {
	color: #8dc2f9;
	display: block;
}
.tokutenCast li {
	display: inline-block;
}
.tokutenCast li:not(:last-child)::after {
	content: " ／";
}
.limipreTxt hr {
	margin: 10px 0;
	border-top: dashed 2px #8dc2f9;
}

.shopAll .tokutenAtt {
	padding-top: 10px;
	border-top: dashed 1px #8dc2f9;
}
.tokutenAtt {
	display: block;
	width: 100%;
	max-width: 700px;
	margin: auto;
}
.tokutenAtt li {
	font-size: 12px;
	text-indent: -1em;
	padding-left: 1em;
}

.shopAll {
	width: 100%;
	max-width: 700px;
	margin: auto;
}
.shopBox {
	box-sizing: border-box;
	background: rgba(255,255,255,0.8);
	width: 100%;
	padding: 10px;
	margin-bottom: 1em;
	border: solid 2px #8dc2f9;
}
.shopBox img {
	display: block;
	width: 100%;
	max-width: 800px;
	margin: 1em auto;
}
.shopName {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	padding: 10px;
	border-bottom: dashed 2px #8dc2f9;
}
.shopSet {
	margin-top: 1em;
}
.shopSet p {
	color: #fff;
	font-weight: bold;
	text-align: center;
	background: #1b7dd0;
	padding: 5px;
}
.shopSet dl {
	margin-bottom: 1em;
}
.shopBox dt {
	font-weight: bold;
	background: #8dc2f9;
	padding: 5px;
	margin-top: 5px;
}
.shopBox dd {
	font-size: 14px;
	padding: 5px 0 10px 10px;
	border: solid 1px #8dc2f9;
}
.shopBox dd strong {
	display: block;
}
.shopBox hr {
	margin: 10px 0;
	border-top: dashed 2px #8dc2f9;
}
.shopBox a {
	display: block;
	color: #fff;
	text-align: center;
	background: #11ced0;
	width: 80%;
	padding: 10px;
	margin: 10px auto;
	border: solid 2px #fff;
	border-radius: 10px;
	box-shadow: 0 0 5px #11ced0, 0 0 5px #11ced0, 0 0 5px #11ced0;
}
.shopBox a:hover {
	opacity: 0.7;
}







/* ウィンドウ幅が0-767pxの場合に適用するCSS */
@media screen and (max-width:767px){
	
	body {
		font-size: 14px;
	}
	
	
	h2 {
		padding: 15px 0;
		margin: auto;
	}


	.show_pc {
		display: none;
	}
	.show_sp {
		display: inherit;
	}





	/* subnav
	---------------------------------------------*/
	.subnav {
		top: 0px;
	}
	.subnav a {
		width: 45%;
	}
	.subnav a.select {
		box-shadow: 3px 3px #92e2ff;
	}




	/* footer
	------------------------------*/
	#graffitiBox {
		padding: 5%;
	}
	#graffitiBox a {
		width: 80%;
	}



	/*top
	---------------------------------------------*/
	#topImg #dendo {
		position: absolute;
	}

	/*#topicBanner {
		display: block;
		top: 65%;
		bottom: auto;
		width: 60%;
	}*/

	#topicBanner {
		position: relative;
		width: 60%;
		margin: -15% 0 30px auto;
	}

	#topMovieAll {
		position: relative;
		left: auto;
		bottom: auto;
		width: 90%;
		padding: 5px;
	}
	#topMovie {
		box-sizing: border-box;
		position: relative;
		display: block;
		aspect-ratio: 16 / 9;
		border: solid 2px #1baaaf;
		overflow: hidden;
	}
	#topMovie::after {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		content: "";
		display: block;
		background-image: url("../img/playmovie_off.png");
		background-repeat: no-repeat;
		background-position: center center;
		background-size: auto 50%;
		z-index: 2;
		transition: transform .5s ease;
	}
	#topMovie:hover::after {
		background-image: url("../img/playmovie_on.png");
	  transform: scale(1.2);
	}
	#topMovie .sikakuL,
	#topMovie .sikakuS {
		position: absolute;
	}
	#topMovie .sikakuL {
	}
	#topMovie .sikakuS {
	}

	#bannerArea {
		padding: 30px;
		margin: 30px auto 50px auto;
		border-top: 5px solid;
		border-bottom: 5px solid;
	}
	#bannerArea .sliderTop {
		padding: 0 10px;
	}

	.scrollline {
		width: 3px;
	}

	.topContentBoxBg {
		margin: auto auto 25px auto;
	}


	#topNewsAll {
		width: 90%;
	}
	#topNewsAll a.moreBtn {
		display: block;
		width: 50%;
		max-width: 460px;
		margin: auto;
	}



	/*story
	---------------------------------------------*/



	/*chara
	---------------------------------------------*/
	
	.slick-arrow{
		width:8%!important;
		aspect-ratio: 13/24!important;
		height:auto!important;
	}
	
	#charaProfAll {
		display: block;
		width: 100%;
	}
	#charaProfImg,
	#charaProfTxt {
	}
	#charaProfImg {
		position: absolute;
		left: 5%;
		order: 1;
		width: 90%;
 		margin: auto;
	}
	#charaProfTxt {
		order: 2;
		width: 100%;
		padding-top: 160%;
	}
	#charaProfImg #kirikae {
		right: 3%;
	}
	#charaProfTxt #charaName {
		width: 80%;
	}
	#charaProfTxt #charaTxt {
		background-size: 12.5px auto;
		padding: 10px;
		width: 90%;
		margin: auto auto 50px auto;
		font-weight: 500; /* <<< 加粗設定 */
	font-family: 'Noto Sans TC', sans-serif; /* 引入的字體 */
	}


	#voice {
	}
	#voice a {
		width: 30%;
	}
	
	#btnPrev,
	#btnNext {
		width: 8%;
	}



	/*gallery
	---------------------------------------------*/
	.galleryBox a {
		width: 40%;
		margin: 3%;
	}







	/*system
	---------------------------------------------*/
	.systemBox dt {
		font-size: 20px;
		border-bottom: solid 5px #7cdbdc;
	}



	/*sound
	---------------------------------------------*/
	.musicBox div.songTitle {
		font-size: 24px;
		padding: 0.8em;
	}



	/*movie
	---------------------------------------------*/



	/*special
	---------------------------------------------*/
	.spMovieBox {
		margin-bottom: 50px;
	}
	.spMovieBox li {
		width: 90%;
		margin: 0 0 15px 0;
	}
	.snsIconAll img {
		width: 45%;;
	}
	.snsHeaderAll img {
		width: 100%;
		margin: 0 0 10px 0;
	}



	/*info
	---------------------------------------------*/
	#specAll #spec table {
		padding: 0;
	}
	#specAll #package {
		padding-bottom: 30px;
	}
	#specAll #spec th,
	#specAll #spec td {
		display: block;
		box-sizing: border-box;
		text-align: center;
		width: 100%;
	}
	#specAll #spec td {
		border-bottom: none;
	}

	.limipreAll {
		display: block;
	}
	.limipreAll .limipreImg,
	.limipreAll .limipreTxt {
		width: 100%;
	}
	.limipreAll .limipreImg {
		padding-right: 0;
		margin-bottom: 10px;
	}
	.limipreAll .limipreTxt dt {
		font-size: 18px;
	}
	.limipreAll .limipreTxt dt:not(:last-child) {
		margin-top: 1em;
	}
	.limipreAll .limipreTxt dd {
		margin-top: 10px;
	}
	.limipreAll .limipreTxt .tokutenAtt {
		margin-top: 1em;
	}
	
	.shopName {
		font-size: 18px;
	}
}