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

/* CSSリセット */
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,
pre,abbr,address,cite,code,del,dfnrem,img,ins,kbd,q,samp,small,
strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,
caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,
figure,footer,header,hgroup,menu,nav,section,summary,time,mark,
audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;
vertical-align:baseline;background:transparent;}
body{line-height:1}article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section{display:block}
ul{list-style:none}blockquote,q{quotes:none}blockquote:before,
blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;
font-size:100%;vertical-align:baseline;background:transparent}
del{text-decoration:line-through}abbr[title],dfn[title]
{border-bottom:1px dotted;cursor:help}
table{border-collapse:collapse;border-spacing:0}
hr{display:block;height:1px;border:0;border-top:1px solid #ccc;
margin:1em 0;padding:0}input,select{vertical-align:middle}

html,body{
	font-size:16px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	background: #420F14;
	color: #ffffff;
	line-height: 1.7;
	font-weight: 400;
	line-break: normal;
}

input,textarea{
	font-family: -apple-system, BlinkMacSystemFont,"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

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

.center{
	text-align: center;
}

.headimg{
	height: 0;
	padding-top: 52.5%;
	margin: auto;
	background: url('./ogp_ginka_shirube.jpg') center center;
	background-size:cover;
}

/* メニュー */
.nav {
	font-size: 0.8rem;
	display: flex;
	justify-content: space-around;
	max-width: 800px;
}

nav>ul>li {
	text-align: center;
	margin: 0;
}

nav{
	margin: 2rem 0;
	background: #2f1010;
	box-shadow: 0 3px 4px rgba(0, 0, 0, 0.32);/*影*/
}

nav>ul>li>a{
	display: block;
	padding: 0.5rem;
	border: none;
	background: transparent;
	color: #fff;
	text-decoration: none;
}

nav>ul>li>a:hover{
	display: block;
	padding: 0.5rem;
	border: none;
	background: transparent;
	color: #fff;
	text-decoration: none;
	text-shadow: 0 0 15px #fff,0 0 20px #c6b923,0 0 25px #fff;
	transition: 1s;
}

/* メインコンテンツ　*/

div#wrapper{
	width: 100%;
	margin: auto;
	overflow: hidden;
}

.headimg {
	margin-bottom: 2rem;
}


/* メイン(内容)　*/

h3,h4,p,ul,table{
	width: 90%;
}

section>h4,ul,p,table{
	max-width: 500px;
}

h3{
	font-weight:normal;
	font-size:1.5rem;
	text-align: center;
	color:#fff;
	margin: 0 auto 3rem;
	padding: 1rem 0 1rem 0;
	background: #2f1010;
	box-shadow: 0 3px 4px rgba(0, 0, 0, 0.32);/*影*/
	width: 100%;
}

h4{
	font-size: 2rem;
	margin: 2rem auto 0.5rem;
	font-weight: normal;
}

h5{
	font-size: 1.2rem;
	font-weight: 400;}

p{
	margin: 0.75rem auto;
	}

	.jisage{
		padding-left: 1rem;
	}

	.caution{
		padding-left: 1rem;
		text-indent: -1rem;
	}

ul{
	margin: 0 auto;
}

ul.lil{
	margin: 0 0 1rem 1rem;
}

li{
	margin-bottom: 0.5rem;
}

.border-red{
	font-size: 0.9rem;
	border:#7d0022 2px solid;
	box-sizing: border-box;
	margin-top: 1rem;
	padding: 0.5rem;
	background-color: rgba(47, 16, 16, 0.2);
}

table{
	display: block;
	max-width: 500px;
	margin:auto;
}

td,th{
	padding: 0.5rem;
	line-height: 1.7em;
}

iframe{
	display: block;
	margin: auto;
	overflow:hidden;
}

p>span.kerning{
	font-size: 1.2rem;
	letter-spacing: -0.25rem;
}

.hanten{
  background: red;
  color: white;
}

/* フォントサイズ */
.fs_12{
font-size: 1.2rem;
		}
.fs_085{
			font-size: 0.85rem;
		}
.fs_08{
	    font-size: 0.8rem;
	  }


/* 背景固定 */
.js-parallax {
width: 100%;
margin: 0 auto;
background: url(./img/02.jpg) no-repeat center top;
background-attachment: fixed;
}
@media screen and (max-width: 767px) {
.js-parallax {
background-size: cover;
background-attachment: scroll;
}
}


/* 各コンテンツの背景など　*/

.block {
	display: block;
  width: 100%;
  align-items: center;
  justify-content: center;
  top: 0;
	padding-bottom: 10rem;
}

#about{
	background: url(./img/02.jpg) no-repeat center top;
}
#story{
	background: #000;
	color: #fff;
	padding-bottom: 0;
	margin-bottom: 0;
}
#ticket{
	background: url(./img/04.jpg) no-repeat center top;
}
#caststaff{
	background: url(./img/03.jpg) no-repeat center top;
}
#access{
	background: url(./img/05.jpg)  no-repeat 20% top;
}
#mail{
	background: url(./img/06.jpg)  no-repeat center top;
}
#character{
	background: url(./img/07.jpg)  no-repeat center top;
}

@media screen and (min-width: 768px) {
	#about{background-attachment: fixed; background-size: cover;}
	#ticket{background-attachment: fixed; background-size: cover;}
	#caststaff{background-attachment: fixed; background-size: cover;}
	#access{background-attachment: fixed; background-size: cover;}
	#mail{background-attachment: fixed; background-size: cover;}
	#character{background-attachment: fixed; background-size: cover;}
}

@media only screen and (max-width: 767px), only screen and (max-device-width: 1024px) {
    #about{background-attachment: scroll;}
    #ticket{background-attachment: scroll;}
    #caststaff{background-attachment: scroll;}
    #access{background-attachment: scroll;}
    #mail{background-attachment: scroll;}
    #character{background-attachment: scroll;}
}

/* 取り消し線 */

.del {
color: #7d0022;
text-decoration : line-through ;
		}
.del span {
color: #000;
		}
.kanbai{
color: #7d0022;
		}

/* オープニングアニメーション　*/
.start {
	background: #5E161B;
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index:999999;
}
.start p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: 9999;
	width: 280px;
}


/* あらすじ装飾 */
section.story>p{
	font-size: 1.25rem;
	margin-bottom: 5rem;
}
.akari{
	text-shadow: 0 0 15px #fff,0 0 20px #c6b923,0 0 25px #fff;
}
.koyumeisi{
	font-size: 1.5rem;
}
.gradient{
  background: #000;
  background: -webkit-linear-gradient(-45deg, rgba(255,255,255,1) 0%,rgba(255,255,255,.8) 17%,rgba(255,255,255,.6) 33%,rgba(255,255,255,.4) 67%,rgba(255,255,255,0.3) 83%,rgba(0,0,0,1) 100%);
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
}
.serifu{
	font-weight: bold;
	color:#5d3030;
	text-shadow:
        1px 1px 1px #fff,
        1px -1px 1px #fff,
        -1px 1px 1px #fff,
        -1px -1px 1px #fff,
        0 0 22px #fff;
}


/* リンクの設定　*/

section a{
	text-decoration:none;
	color: #c6b923;
	outline:none;
	background: #7d0022;
	padding: .5% 3%;
	border: #7d0022 2px solid;
	border-radius: 10px;
	transition: 1s;
	box-shadow: 0 3px 4px rgba(0, 0, 0, 0.32);/*影*/
	}

section a:hover{
	text-decoration:none;
	color: #7d0022;
	outline:none;
	background: #c6b923;
	padding: .5% 3%;
	border: #7d0022 2px solid;
	border-radius: 10px;
	box-shadow: 0 3px 4px rgba(0, 0, 0, 0.32);/*影*/
}

.border-red a{
	color: #fff;
	background: transparent;
	box-shadow: none;
	border: none;
	text-decoration: underline;
}

.border-red a:hover{
	color: #fff;
	background: transparent;
	box-shadow: none;
	border: none;
	text-decoration: underline;
}

	/* character */
	#character ul{
		max-width: 1200px;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	#character a{
		padding: 20px;
		border: none;
		width: 180px;
		display: block;
	}
	@media screen and (max-width: 767px) {
		#character a{
			width: 160px;
		}
	}

	#character a:hover{
		opacity: 0.5;
	}
	#character li{
		display: inline-block;
	}

	.modal{
		margin: 1.5rem;
	}

	.modal>div>h5{
		max-width: 400px;
		margin: auto;
	}

	.modal>div>p{
		max-width: 400px;
		margin:.75rem auto 1.75rem;
		font-weight: 400;
	}

	.characterimg{
		margin: 1.5rem;
	}

	#character li a{
        border-radius: 0;
        padding: 0;
        background: transparent;
        box-shadow: 0 0 0 0;
      }


	/* footer */

	footer{
		background: #2f1010;
		padding: 2%;
		letter-spacing: .35em;
	}

	footer a{
		color:#fff;
		background: none;
		padding: 0;
		border: none;
	}
	footer a:hover{
		color:#fff;
		background: none;
		opacity: .6;
		padding: 0;
		border: none;
	}

	/* TOP戻るボタン */

	#pageTop{
		background: #fff;
		border-radius:10px;
		color:#2f1010;
		padding:10px;
		position:fixed;
		bottom:10px;
		right:10px;
		text-decoration: none;
		line-height: 1;
	}

	#pageTop:hover{
		opacity: .7;
	}

	/* 導入アニメーション */
	.animation {
		color: inherit;
/*	  display: flex;
	  justify-content: center;
	  margin-top: 10vh;
	  padding: 2rem 40px; */
	}
	.animation .anm_mod {
	  opacity: 0;
	  transform: translate3d(0, 100%, 0);
	  transition: all 2s ease;
	  align-items: center;
	}
	.animation .anm_mod.left {
	  transform: translate3d(-100%, 0, 0);
	}
	.animation .anm_mod.right {
	  transform: translate3d(100%, 0, 0);
	}
	.animation .anm_mod.delay {
	  transition: all 3s ease;
	}
	.animation .anm_mod.delay4s {
	  transition: all 4s ease;
	}
	.animation .anm_mod.fast {
	  transition: all 0.8 ease;
	}
	.animation .anm_mod.ginaka {
	  transform: translate3d(0, 0, 0);
	}

	.animation .anm_mod.active {
	  opacity: 1;
	  transform: translate3d(0, 0, 0);
	}
