@charset "UTF-8";
/* CSS Document */
	
body{
	margin:0px;
	background: #fff;
	font-family: "Shippori Mincho", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
	font-weight: 400;
	font-size: 15px;
	line-height: 27px;
	color:#222;
	height:100%;
	box-sizing: border-box;
}

html{
	height:100%;
}

img { border-style:none;
	vertical-align: bottom;}

a img { border-style:none;}

a:hover img { border-style:none; }

*{
margin: 0;
padding: 0;
}

ol, ul {
	list-style: none;
}

.cf:before,
.cf:after {
  content: "";
  display: table;}
.cf:after {
  clear: both;}
.cf {
  *zoom: 1;}


.pcview{
	width:100%;
}

.spview{
	display: none;
}

.scrollShowEffect1 {
	-webkit-transition: all 1.0s;
	   -moz-transition: all 1.0s;
	    -ms-transition: all 1.0s;
	     -o-transition: all 1.0s;
	        transition: all 1.0s;
	-webkit-transition-delay: 0s;
	   -moz-transition-delay: 0s;
	    -ms-transition-delay: 0s;
	     -o-transition-delay: 0s;
	        transition-delay: 0s;
	opacity:0;
}

.scrollShowEffect2 {
	-webkit-transition: all 1.0s;
	   -moz-transition: all 1.0s;
	    -ms-transition: all 1.0s;
	     -o-transition: all 1.0s;
	        transition: all 1.0s;
	-webkit-transition-delay: 0.3s;
	   -moz-transition-delay: 0.3s;
	    -ms-transition-delay: 0.3s;
	     -o-transition-delay: 0.3s;
	        transition-delay: 0.3s;
	opacity:0;
}

.scrollShowEffect3 {
	-webkit-transition: all 1.0s;
	   -moz-transition: all 1.0s;
	    -ms-transition: all 1.0s;
	     -o-transition: all 1.0s;
	        transition: all 1.0s;
	-webkit-transition-delay: 0.6s;
	   -moz-transition-delay: 0.6s;
	    -ms-transition-delay: 0.6s;
	     -o-transition-delay: 0.6s;
	        transition-delay: 0.6s;
	opacity:0;
}


.scrollShowEffect-R {
	-webkit-transform: translate3d(30%, 0%, 0);
	   -moz-transform: translate3d(30%, 0%, 0);
	    -ms-transform: translate3d(30%, 0%, 0);
	     -o-transform: translate3d(30%, 0%, 0);
	        transform: translate3d(30%, 0%, 0);
}
.scrollShowEffect-L {
	-webkit-transform: translate3d(-30%, 0%, 0);
	   -moz-transform: translate3d(-30%, 0%, 0);
	    -ms-transform: translate3d(-30%, 0%, 0);
	     -o-transform: translate3d(-30%, 0%, 0);
	        transform: translate3d(-30%, 0%, 0);
}
.scrollShowEffect-B {
	-webkit-transform: translate3d(0, 50px, 0);
	   -moz-transform: translate3d(0, 50px, 0);
	    -ms-transform: translate3d(0, 50px, 0);
	     -o-transform: translate3d(0, 50px, 0);
	        transform: translate3d(0, 50px, 0);
}

.scrollShowEffect-T {
	-webkit-transform: translate3d(0, -50px, 0);
	   -moz-transform: translate3d(0, -50px, 0);
	    -ms-transform: translate3d(0, -50px, 0);
	     -o-transform: translate3d(0, -50px, 0);
	        transform: translate3d(0, -50px, 0);
}

.scrollShowEffect-Z {
	-webkit-transform: scale( 0.2,  0.2);
	transform: scale( 0.2,  0.2);
}

.scrollShowEffect-O {
	-webkit-transform: scale( 1.2,  1.2);
	transform: scale( 1.2,  1.2);
}


.scrollShowEffect1.showItem {
	opacity:1;
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}

.scrollShowEffect2.showItem {
	opacity:1;
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}

.scrollShowEffect3.showItem {
	opacity:1;
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}

.mb0{
	width:100%;
	overflow: hidden; /* heightを戻す */
}

.mb5{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 5px;
	line-height: 140%;
}

.mb10{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 10px;
}

.mb20{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 20px;
}

.mb30{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 30px;
}

.mb50{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 50px;
}

.mb80{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 80px;
}

.mb100{
	width:100%;
	overflow: hidden; /* heightを戻す */
	margin-bottom: 100px;
}

.pcbr {
	display:inline;
}

.loading{
  width: 100vw;
  height: 100vh;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1300;
}

.loading img{
  width: 400px;
}


#header_wrapper{
	width:100%;
	overflow: hidden;
	line-height: 100%;
    position: fixed;
    left:0;
    top:0;
	z-index: 100;
    box-sizing: border-box;
    background-color:#fff;
    box-shadow: 0px 0px 15px -5px #000;
}

.headermenu nav{
	width: 80%;
    box-sizing: border-box;
	font-family: "Ubuntu Mono", monospace;
    font-weight: 400;
    font-style: italic;
    font-size: 16px;
    line-height: 12px;
    overflow: hidden;
	float: left;
}

.headermenu nav ul li {
	display: inline-block;
    margin-right: -8px;
}

.headermenu a {
  transition: 0.5s;
  display: block;
  text-decoration: none;
  color: #4767a1;
  box-sizing: border-box;
  padding:16px 25px 16px 25px ;
}

.headermenu a:hover {
  transition: 0.5s;
  text-decoration: none;
  outline: none;
  background-color:#4767a1;
  color: #fff
}

.headermenu li:last-child{
  margin-right: 0;
  padding-right: 0;
}

.snsbtn{
    width:57.5px;
    height: 57.5px;
	line-height: 100%;
    float: right;
	position: relative;
}

.snsbtn img{
	width:100%;
	height: auto;
}

.snsbtn a{
  display: block;
  position: relative;
  outline: none;
}
  
.snsbtn .hoverimg{
  position: absolute;
  bottom:0%;
  left:0%;
  -webkit-transition: 1s;
     -moz-transition: 1s;
      -ms-transition: 1s;
       -o-transition: 1s;
          transition: 1s;
  z-index: 301;
	outline: none;
	opacity: 0;
}

.snsbtn a:hover .hoverimg{
  	bottom: 0%;
	outline: none;
	text-decoration: transparent;
	opacity: 1;
}

.menuj{
	font-size: 9px;
	font-weight: 500;
	font-style: italic;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

#top_wrapper{
    width:100%;
	height: auto;
	position: relative;
	overflow: hidden;
	box-sizing: border-box;
	margin-top:55px;
}

#top_wrapper img{
	width:100%;
	height: auto;
}

.spmain{
    display: none;
}

.main{
	width:100%;
	opacity: 0;
    -webkit-transition: all 1.0s;
    -moz-transition: all 1.0s;
    -o-transition: all 1.0s;
    -ms-transition: all 1.0s;
    transition: all 1.0s;
}
  
.showNavi .main{
  opacity:1;
  -webkit-transition-delay:0.5s;
  transition-delay:0.5s;
}

.topbtn_wrapper {
	width:50%;
	right: 8.5%;
	bottom:14%;
	opacity: 0;
	position: absolute;
    display: flex;
    flex-wrap: wrap;       /* 折り返しを許可 */
    justify-content: center; /* 全体を中央寄せ */
    gap: 20px;             /* ボタン同士の間隔（適宜調整） */
    max-width: 600px;      /* 2つ並んだ時にちょうど良い幅に制限（重要） */
    margin: 0 auto;        /* コンテナ自体を中央に */
}

.showNavi .topbtn_wrapper{
  opacity:1;
  -webkit-transition-delay:1.5s;
  transition-delay:1.5s;
}

.topbtn {
    /* ボタン2つ分が1行に収まり、3つ目が落ちるサイズ感にする */
    flex: 0 1 calc(50% - 10px); 
    min-width: 250px;      /* スマホで横並びがキツい場合の最小幅 */
    text-align: center;
}

.topbtn img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
}

.topbtn img {
	transition-duration: 0.5s;
    cursor: pointer;
}

.topbtn img:hover {
	opacity: 0.5;
	transition-duration: 0.5s;
    cursor: pointer;
}

#intro_wrapper{
	width:100%;
	overflow: hidden;
}

#intro_wrapper img{
	width:100%;
	height: auto;
}

#intro_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:7% 15%;
}

.intromidashi{
	width:80%;
	margin-bottom: 30px;
}

.introphoto{
	width:50%;
	float: left;
}

.pt{
	width:100%;
    font-size: 34px;
    line-height: 30px;
	font-family: "Ubuntu Mono", monospace;
    font-weight: 400;
    font-style: italic;
	box-sizing: border-box;
}

.ptj{
	width:100%;
    font-size: 14px;
    line-height: 14px;
    letter-spacing: 1px;
    font-weight: 400;
	font-family: "Zen Kaku Gothic New", sans-serif;
	box-sizing: border-box;
	font-style: italic;
}

.textcenter{
	text-align: center;
}

.colorblue{
	color:#4767a1;
}

.colorwhite{
	color:#fff;
}

.coloryellow{
	color:#c8c810;
}

#story_wrapper{
	width:100%;
	overflow: hidden;
}

#story_wrapper img{
	width:100%;
	height: auto;
}

#story_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:7% 15%;
}

.storymidashi{
	width:60%;
	margin-bottom: 30px;
}


#staff_wrapper{
	width:100%;
	overflow: hidden;
	background-color: #677288;
	color: #fff;
}

#staff_wrapper img{
	width:100%;
	height: auto;
}

#staff_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:7% 10%;
}

.staffphoto{
	width:33.333333%;
	float: left;
}

.staffbox{
	width:46%;
	float: left;
	margin-right: 8%;
}

.staffbox:nth-child(2) {
  margin-right: 0;
}

.staffimg{
	width:70%;
	margin:0 auto 20px;
	box-sizing: border-box;
	border:1px solid #fff;
}

.staffname{
	width:100%;
	font-size: 26px;
	font-weight: 700;
	margin-bottom: 5px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	text-align: center;
}

.staffnames{
	width:100%;
	font-size: 16px;
	font-weight: 500;
	text-align: center;
	margin-bottom: 30px;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.staffbox2{
	width:100%;
	font-size: 16px;
	font-weight: 500;
	line-height: 30px;
	text-align: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

#prizereview_wrapper{
	width:100%;
	overflow: hidden;
}

#prizereview_wrapper img{
	width:100%;
	height: auto;
}

#prizereview_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:7% 10%;
}

.prize{
	width:100%;
	margin-bottom: 100px;
}

.commentbox_wrapper{
	width:100%;
	height: auto;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	box-sizing: border-box;
}

.commentbox{
	width:24%;
	float: left;
	margin-right: 1.333333%;
	margin-bottom: 1.333333%;
	box-sizing: border-box;
	padding:2%;
	border-top: 1px solid #4767a1;
}

.commentbox:nth-child(4n) {
  margin-right:0;
}

.commenttext{
	width:100%;
	color: #4767a1;
	box-sizing: border-box;
	font-size: 18px;
	line-height: 29px;
	margin-bottom: 20px;
	font-weight: 600;
}

.commentname1{
	width:100%;
	font-size: 15px;
	font-weight: 700;
	color:#4767a1;
	line-height: 15px;
	margin-bottom: 5px;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.commentname2{
	width:100%;
	font-size:12px;
	font-weight: 500;
	color:#4767a1;
	line-height: 20px;
	font-family: "Zen Kaku Gothic New", sans-serif;
}


#footer{
	width:100%;
	padding:5% 0;
	text-align: center;
}

#footer img{
	width:100%;
	height: auto;
}

.footerlogo{
	width:35%;
	margin:0 auto 50px;
}

.cf_midashi{
	display:inline-block;
	margin-bottom:20px;
	font-size: 14px;
	line-height: 24px;
	font-weight: 700;
	background-color: #4767a1;
	box-sizing: border-box;
	padding:0.5% 2%;
	text-align: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color: #fff;
}

#witness_wrapper{
	width:100%;
	background-color: #e6e08e;
	overflow: hidden;
}

#witness_wrapper img{
	width:100%;
	height: auto;
}

#witness_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:7% 10%;
}

.witnessbox{
	width:32%;
	float: left;
	margin-right: 2%;
	margin-bottom: 2%;
	box-sizing: border-box;
	padding:2%;
	border-top: 1px solid #4767a1;
}

.witnessbox:nth-child(3n) {
  margin-right:0;
}

.witnessname{
	width:100%;
	font-size: 18px;
	font-weight: 700;
	color:#4767a1;
	line-height: 18px;
	margin-bottom: 10px;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.witnessnames{
	font-size: 13px;
	font-weight: 700;
}

.witnesstext{
	width:100%;
	font-size: 14px;
	font-weight: 500;
	color:#4767a1;
	line-height: 24px;
}

.cf_name{
	width:1024px;
	margin:0 auto;
	font-size: 16px;
	font-weight: 500;
	line-height: 30px;
}


#tokusyu_wrapper{
	width:100%;
	background-color: #fff;
	overflow: hidden;
}

#tokusyu_wrapper img{
	width:100%;
	height: auto;
}

#tokusyu_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:7% 10%;
}

.tokusyu_midashi{
	width:60%;
	margin:0 auto 30px;
}

.tokusyu_midashitext{
	width:60%;
	font-size: 16px;
	font-weight: 600;
	margin:0 auto 10px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color:#000;
}

.tokusyu_midashiname1{
	width:60%;
	font-size: 16px;
	font-weight: 700;
	margin:0 auto 5px;
	text-align: center;
	color:#000;
}

.tokusyu_midashiname2{
	width:60%;
	font-size: 12px;
	font-weight: 700;
	margin:0 auto 50px;
	text-align: center;
	color:#000;
}

.tokusyubox_wrapper{
	width:100%;
	overflow: hidden; /* heightを戻す */
	padding:0;
	display:-webkit-box;
	display:-moz-box;
	display:-ms-box;
	display:-webkit-flexbox;
	display:-moz-flexbox;
	display:-ms-flexbox;
	display:-webkit-flex;
	display:-moz-flex;
	display:-ms-flex;
	display:flex;
	-webkit-box-lines:multiple;
	-moz-box-lines:multiple;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	margin-bottom: 100px;
}

.tokusyubox{
	width:32%;
	float: left;
	margin-right: 2%;
	margin-bottom: 2%;
	box-sizing: border-box;
	padding:2%;
	border: 1px solid #000;
}

.tokusyubox:nth-child(3n) {
    margin-right:0;
}

.tokusyuimg{
	width:100%;
	margin-bottom: 20px;
}

.tokusyutitle1{
	width:100%;
	font-size: 12px;
	font-weight: 500;
	line-height: 12px;
	margin-bottom: 7px;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.tokusyutitle2{
	width:100%;
	font-size: 20px;
	line-height: 20px;
	font-weight: 700;
	margin-bottom: 20px;
	text-indent: -10px;
}
.tokusyutitles{
	font-size: 11px;
	padding-left: 10px;
}

.tokusyudetail{
	width:100%;
	font-size: 11px;
	line-height: 20px;
	margin-bottom: 20px;
}

.tokusyutext{
	width:100%;
	font-size: 13px;
	line-height: 23px;
}

.schebox{
	width:48%;
	float: left;
	margin-right: 4%;
}

.schebox:nth-child(2n) {
    margin-right:0;
}

.sche{
	width:100%;
	padding:5px;
	border-bottom: 1px solid #4767a1;
	margin-bottom: 5px;
	font-size: 14px;
	line-height: 24px;
	text-align: center;
}

.attention{
	width:100%;
	text-align: center;
	font-size: 12px;
	line-height: 20px;
}


.attention a{
	color: #4767a1;
	text-decoration: none;
}

.attention a:hover{
	color: #999;
	text-decoration: underline;
}


.topbtn2{
	width:18%;
	position: absolute;
	right: 17%;
	bottom:14%;
	opacity: 0;
    -webkit-transition: all 1.0s;
    -moz-transition: all 1.0s;
    -o-transition: all 1.0s;
    -ms-transition: all 1.0s;
    transition: all 1.0s;
	overflow: hidden;
}
  
.showNavi .topbtn2{
  opacity:1;
  -webkit-transition-delay:1.7s;
  transition-delay:1.7s;
}


.topbtn2 img {
	transition-duration: 0.5s;
    cursor: pointer;
}

.topbtn2 img:hover {
	opacity: 0.5;
	transition-duration: 0.5s;
    cursor: pointer;
}

@media screen and (max-width:1024px){
	
.scrollShowEffect1 {
	opacity:1;
}

.scrollShowEffect2 {
	opacity:1;
}

.scrollShowEffect3 {
	opacity:1;
}


.scrollShowEffect-R {
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}
.scrollShowEffect-L {
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}
.scrollShowEffect-B {
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}

.scrollShowEffect-T {
	-webkit-transform: translate3d(0, 0, 0);
	   -moz-transform: translate3d(0, 0, 0);
	    -ms-transform: translate3d(0, 0, 0);
	     -o-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}

.scrollShowEffect-Z {
	-webkit-transform: scale( 1.0,  1.0);
	transform: scale( 1.0,  1.0);
}

.scrollShowEffect-O {
	-webkit-transform: scale( 1.0,  1.0);
	transform: scale( 1.0,  1.0);
}
	
	
.loading img{
  	width:250px;
	padding-bottom: 50px;
}
	
.pcview{
	display: none;
}

.spview{
	display: inherit;
	width:100%;
}

.pcbr {
	display:none;
}

	
.brtext::before {
	content: "\A" ;
	white-space: pre ;
}

.btn-trigger_fix{
	width:100%;
	position: fixed;
	bottom:0;
	right: 0;
    z-index: 100;
    box-shadow: 0px 0px 15px -5px #000;
}

.btn-trigger_wrapper{
	width:100%;
    background-color: #4767a1;
	border-top:1px solid #fff;
    text-align: center;
    padding-top:2%;
    padding-bottom:1%;
}

.btn-trigger {
  position: relative;
  width: 36px;
  height: 25px;
  margin:0 auto;
  cursor: pointer;
}

.btn-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
  border-radius: 2px;
}
.btn-trigger, .btn-trigger span {
  display: inline-block;
  transition: all .5s;
  box-sizing: border-box;
}
.btn-trigger span:nth-of-type(1) {
  top: 0;
}
.btn-trigger span:nth-of-type(2) {
  top: 11.5px;
}
.btn-trigger span:nth-of-type(3) {
  bottom: 0;
}

#btn08.active span:nth-of-type(1) {
  -webkit-transform: translateY(11px) rotate(-315deg);
  transform: translateY(11px) rotate(-315deg);
}
#btn08.active span:nth-of-type(2) {
  opacity: 0;
}
#btn08.active span:nth-of-type(3) {
  -webkit-transform: translateY(-11px) rotate(315deg);
  transform: translateY(-11px) rotate(315deg);
}

nav.globalMenuSp {
  position: fixed;
  z-index : -10;
  bottom  : 0;
  left : 0;
  width: 100%;
  height: 100%;
  margin-bottom:-100%;
  opacity: 0;
  background-color: rgba(255,255,255,0.9);
  box-sizing: border-box;
  padding:20% 10% 20% 10%;
  -webkit-transition-property: all;
     -moz-transition-property: all;
      -ms-transition-property: all;
       -o-transition-property: all;
          transition-property: all;
  -webkit-transition: .6s ease;
     -moz-transition: .6s ease;
      -ms-transition: .6s ease;
       -o-transition: .6s ease;
          transition: .6s ease;
	display: table;
}

nav.globalMenuSp.active {
  opacity: 100;
  margin-bottom:0;
  z-index : 50;
}

.globalMenuSp img{
	width:100%;
	height: auto;
}

#header_wrapper{
    display: none;
}
	
.menu_wrapper{
	width:100%;
	display: table-cell;
	vertical-align: middle;
	font-family: "Ubuntu Mono", monospace;
    font-weight: 400;
    font-style: italic;
}

.menu{
    width:100%;
	box-sizing: border-box;
    margin-bottom: 4%;
    text-align: center;
    display: block;
    font-size: 16px;
	line-height: 10px;
    line-height: 100%;
    letter-spacing: 1px;
    font-weight: 600;
}

.menu a {
  display: block;
  transition: 0.5s;
  text-decoration: none;
  outline: none;
  color: #4767a1;
}

.menu a:hover {
  transition: 0.5s;
  text-decoration: none;
  outline: none;
  color: #4767a1;
}
	
.menu:last-child {
  margin-bottom: 12%;
}
	
.sns_wrapper{
    width:40%;
	margin:0 auto;
	overflow: hidden;
}
	
.sns{
    width:40%;
	float: left;
	margin-right: 20%;
}
	
.sns:nth-child(2) {
  margin-right:0;
}
	
#top_wrapper{
    width:100%;
	height: auto;
	position: inherit;
	overflow: hidden;
	box-sizing: border-box;
	margin-top:0;
}

.spmain{
    display: inherit;
	width:100%;
}

.main{
	display: none;
}


#footer{
	width:100%;
	padding:7% 0 17% 0;
}

.footerlogo{
	width:90%;
	margin:0 auto 30px;
}
	
#intro_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:15% 10%;
}

.intromidashi{
	width:100%;
	margin-bottom: 30px;
}

.introphoto{
	width:50%;
	float: left;
}

.pt{
	width:100%;
    font-size: 30px;
    line-height: 28px;
	font-family: "Ubuntu Mono", monospace;
    font-weight: 400;
    font-style: italic;
	box-sizing: border-box;
}
	
#story_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:15% 10%;
}

.storymidashi{
	width:100%;
	margin-bottom: 30px;
}

#staff_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:15% 10%;
}
.staffbox{
	width:100%;
	float: none;
	margin-right: 0;
	margin-bottom: 50px;
}

.staffimg{
	width:100%;
	margin:0 auto 20px;
	box-sizing: border-box;
	border:1px solid #fff;
}

.staffname{
	width:100%;
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 5px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	text-align: left;
}

.staffnames{
	width:100%;
	font-size: 14px;
	font-weight: 500;
	text-align: left;
	margin-bottom: 10px;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.staffbox2{
	width:100%;
	font-size: 14px;
	font-weight: 500;
	line-height: 30px;
	text-align: left;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

#prizereview_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:15% 10%;
}
.commentbox{
	width:100%;
	float: none;
	margin-right:0;
	margin-bottom:30px;
	box-sizing: border-box;
	padding:4%;
	border-top: 1px solid #4767a1;
}

.commenttext{
	width:100%;
	color: #4767a1;
	box-sizing: border-box;
	font-size: 16px;
	line-height: 26px;
	margin-bottom: 20px;
	font-weight: 600;
}
	
.cf_midashi{
	display:inline-block;
	margin-bottom:20px;
	font-size: 14px;
	line-height: 14px;
	font-weight: 700;
	background-color: #4767a1;
	box-sizing: border-box;
	padding:1.5% 3%;
	text-align: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color: #fff;
}

.topbtn_wrapper{
	width:100%;
	position: inherit;
	right:0;
	bottom:0;
	opacity:1;
	box-sizing: border-box;
	padding:2%;
	overflow: hidden;
}
	
.cf_midashi{
	width:100%;
	display:inherit;
	margin-bottom:20px;
	font-size: 14px;
	line-height: 24px;
	font-weight: 700;
	background-color: #4767a1;
	box-sizing: border-box;
	padding:3% 5%;
	text-align: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color: #fff;
}

.cf_name{
	width:80%;
	margin:0 auto;
	font-size: 12px;
	line-height: 20px;
}
	

#tokusyu_inner{
	width:100%;
	overflow: hidden;
	box-sizing: border-box;
	padding:10% 10%;
}

.tokusyu_midashi{
	width:100%;
	margin:0 auto 30px;
}

.tokusyu_midashitext{
	width:100%;
	font-size: 16px;
	font-weight: 600;
	margin:0 auto 20px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color:#000;
}

.tokusyu_midashiname1{
	width:100%;
	font-size: 16px;
	line-height: 16px;
	font-weight: 700;
	margin:0 auto 5px;
	text-align: left;
	color:#000;
}

.tokusyu_midashiname2{
	width:100%;
	font-size: 10px;
	font-weight: 700;
	margin:0 auto 50px;
	text-align: left;
	color:#000;
}

.tokusyubox{
	width:100%;
	float: none;
	margin-right:0;
	margin-bottom: 20px;
	box-sizing: border-box;
	padding:5%;
	border: 1px solid #000;
}

.tokusyutitle2{
	width:100%;
	font-size: 17px;
	line-height: 17px;
	font-weight: 700;
	margin-bottom: 20px;
	text-indent: -10px;
}
.schebox{
	width:100%;
	float: none;
	margin-right: 0;
}

.sche{
	width:100%;
	padding:5px;
	border-bottom: 1px solid #4767a1;
	margin-bottom: 5px;
	font-size: 14px;
	line-height: 24px;
	text-align: left;
}

.attention{
	width:100%;
	text-align: left;
	font-size: 11px;
	line-height: 20px;
}

.topbtn2{
	width:95%;
	position: inherit;
	right: 0;
	bottom:0;
	opacity:1;
	margin:0 auto 20px;
	overflow: hidden;
}
  
.topbtn_wrapper {
        flex-direction: column; 
        align-items: center;
    gap: 10px;
}

    .topbtn {
        flex: 0 1 auto; 
        width: 100%;
    }
	
}

*, ::after, ::before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

*:focus {
  outline: none;
}

.modal-contents {
  display:none;
  position: fixed;
  width: 100%;
  height: 100%;
	font-weight: bold;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background:rgba(0,0,0,0.9);
  z-index: 9998; }
  .modal-contents .modal-contents-inner {
    position: relative;
    width: 100%;
    height: 100%; }
    .modal-contents .modal-contents-inner .modal-contents-iframe {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      z-index: 9998;
      width: 100%; }
      .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-player {
        width: 80%;
        text-align: center;
        position: relative;
        padding-top: 42.5%;
        height: 0;
        overflow: hidden;
        display: block;
        margin: 0 auto; }
        .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-player iframe {
          width: 100%;
          height: 100%;
          display: block;
          position: absolute;
          top: 50%;
          left: 50%;
          -webkit-transform: translate(-50%, -50%);
          -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%); }
      .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn {
        width: 80%;
        margin: 0.5% auto 0;
        font-size: 0;
        text-align: center;
        /* visibility: hidden; */
      }
        .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
          border: 1px solid #111;
          background-color: #4767a1;
          width: 50%;
          height: auto;
          box-sizing: border-box;
          padding:0.5% 0;
          display: inline-block;
          vertical-align: middle;
          text-align: center;
          font-size: 13px;
          line-height: 23px;
          color: #e6e08e;
          cursor: pointer;
          -webkit-transition: all .3s;
          transition: all .3s; }
          @media screen and (min-width: 769px) {
            .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
              font-size: 0.8vw; } }
          @media screen and (max-width: 1024px) and (min-width: 768px) {
            .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
              font-size: 0.8vw; } }
          @media screen and (max-width: 768px) {
            .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
              font-size: 0.8vw; } }
        .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li:hover,
        .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li.current {
          border: 1px solid #111;
          background-color: #e6e08e;
          color: #4767a1;  }
    .modal-contents .modal-contents-inner .modal-close {
      width: 3%;
      display: block;
      position: absolute;
      top: 3.5%;
      right: 1.5%;
      z-index: 9999;
      cursor: pointer; }



@media screen and (max-width: 768px) {
  .modal-contents .modal-contents-inner {
    position: absolute;
    width: 100%;
    height: auto;
    padding: 0 5%;
    top: 50%;
    left: 0;
    right: 0;
    -webkit-transform: translate(0%, -50%);
    -ms-transform: translate(0%, -50%);
    transform: translate(0%, -50%); }
    .modal-contents .modal-contents-inner .modal-contents-iframe {
      position: static;
      -webkit-transform: none;
      -ms-transform: none;
      transform: none; }
      .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-player {
        padding-bottom: 26%;
        padding-top: 30%;
        width: 100%; }
      .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn {
        width: 100%; }
        .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
          display: block;
          width: 100%;
          text-align: center;
          line-height: 23px;
          font-size: 13px; } }
        @media screen and (max-width: 768px) and (min-width: 769px) {
          .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
            font-size: 0.9vw; } }
        @media screen and (max-width: 768px) and (max-width: 1024px) and (min-width: 768px) {
          .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
            font-size: 0.82031vw; } }
        @media screen and (max-width: 768px) and (max-width: 768px) {
          .modal-contents .modal-contents-inner .modal-contents-iframe .modal-contents-iframe-btn li {
            font-size: 2.2vw; 
          box-sizing: border-box;
          padding:0.5% 0;} }

@media screen and (max-width: 768px) {
    .modal-contents .modal-contents-inner span.modal-close {
      width: 7%;
      top: -15%;
      right: 5.5%; }
  .cast-modal .modal-close {
    width: 7%;
    top: 3%;
    right: 5.5%; }
  .cast-modal .modal-list ul li {
    overflow-y: scroll;
    height: 175vw; }
    .cast-modal .modal-list ul li .inner {
      top: 12%;
      -webkit-transform: translate(-50%, 0%);
      -ms-transform: translate(-50%, 0%);
      transform: translate(-50%, 0%); }
      .cast-modal .modal-list ul li .inner > * {
        display: block;
        width: 100%; }
      .cast-modal .modal-list ul li .inner .text {
        padding: 5% 0%; }
        .cast-modal .modal-list ul li .inner .text h2 {
          font-size: 14px; } }
        @media screen and (max-width: 768px) and (min-width: 769px) {
          .cast-modal .modal-list ul li .inner .text h2 {
            font-size: 0.8vw; } }
        @media screen and (max-width: 768px) and (max-width: 1024px) and (min-width: 768px) {
          .cast-modal .modal-list ul li .inner .text h2 {
            font-size: 1.0vw; } }
        @media screen and (max-width: 768px) and (max-width: 768px) {
          .cast-modal .modal-list ul li .inner .text h2 {
            font-size: 1.33333vw; } }




            
.remodal-is-opened{
    display:block;
}
