html {
	font-size:62.5%;
}
body {
	color:#111;
	font-family: 'EB Garamond', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	background-color: #080406;
	height:100%;
	line-height: 1.8;
}

ol, ul {
	list-style: none;
}

h1 {
}
h2 {
	font-size:3.7rem;
	font-weight: normal;
	font-family: 'EB Garamond', serif;
	color: #cdb04d;
}
h3 {
	font-size:2rem;
	font-weight: normal;
	color: #cdb04d;
}
p {
	font-size:1.7rem;
}
.mg12{margin-top: 12px;}
.mg20{margin-top: 20px;}
.mg30{margin-top: 30px;}
.mg40{margin-top: 40px;}
.mg60{margin-top: 60px;}
.mg80{margin-top: 80px;}
.mg100{margin-top: 100px;}
.mg120{margin-top: 120px;}
.mg160{margin-top: 160px;}
.sp80{height: 80px;}

a.btnStyleA {
	position: relative;
	display: block;
	border-radius: 4px;
	background: rgba(255, 255, 255, 0.2);
	line-height: 40px;
	-webkit-transition: .2s;
	transition: .2s;
	cursor: pointer;
	padding: 0 2rem 0 2rem;
	text-align: center;
	text-decoration: none;
	font-size: 16px;
	color: #FFF;
	max-width:200px;
	margin:0 auto;
}
a.btnStyleA:hover {
	background: rgba(255, 255, 255, 0.5);
	color: #FFF;
}

/*for Loader-------------------------------------------------------------*/
.flbackdrop {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: #03240c;
	z-index: 99999;
}

/*common Wrap-------------------------------------------------------------*/
.wrap90{
	width:90%;
	margin: 0 auto;
}
.lmt750{
		max-width: 750px;
	}
	.lmt750 img{
		width: 100%;
		height: auto;
	}

/*for Home-------------------------------------------------------------*/
.wrapHome {
	position: relative;
	height:100vh;
	width:100%;
	display: flex;
	justify-content: space-between;
}
	.wrapHome_inL {
		position: relative;
		height:100%;
		width: 50%;
		z-index: 10;
	}
		.wrapHome_inL h1 img{
			width: 300px;
			height: auto;
		}
		.wrapHome_inL .wrapHome_inL_btm{
			position: absolute;
			left: 0;
			bottom: 20px;
			width: 330px;
			height: 130px;
		}
	.wrapHome_inR {
		position: relative;
		height:100%;
		width: 50%;
		text-align: right;
		z-index: 10;
	}
		.wrapHome_inR h2 {
			width: 100%;
			height: 100%;
		}
		.wrapHome_inR h2 img {
			width: auto;
			height: 100%;
		}
	/*SP*/
	.wrapHome_SPin1, .wrapHome_SPin2 {
		position: relative;
		display: none;
		width: 100%;
		text-align: center;
		z-index: 10;
	}
		.wrapHome_SPin2{
			position: absolute;
			bottom: 70px;
			width: 100vw;
			height: 90px;
		}
		.wrapHome_SPin1 h1, .wrapHome_SPin2 h3 {
			width: 100%;
			max-width: 750px;
			margin: 0 auto;
		}
		.wrapHome_SPin1 h1 img, .wrapHome_SPin2 h3 img {
			width: 100%;
			height: auto;
		}
	.wrap_slick{
		position: absolute;
		top:0;
		left: 0;
		width: 100%;
		height: 100vh;
		overflow: hidden;
		z-index: 1;
	}
	#slick_wrap{
		position: relative;
		width: 100%;
		height: 100vh;
	}
		#slick_wrap li{
			position: relative;
			width: 100%;
			height: 100vh;
			background-position: center center;
		    background-size:cover;
		    background-repeat: no-repeat;
		}
		#slick_wrap li.vis_bg1{
			background-image: url(../img/vis_bg1.jpg);
		}
		#slick_wrap li.vis_bg2{
			background-image: url(../img/vis_bg2.jpg);
		}
		#slick_wrap li.vis_bg3{
			background-image: url(../img/vis_bg3.jpg);
		}

	#nextAnim a{
		display: block;
	}
		#nextAnim a span {
			position: absolute;
			display: block;
			bottom: 20px;
			left: 30px;
			width: 16px;
			height: 16px;
			border-left: 1px solid #fff;
			border-bottom: 1px solid #fff;
			-webkit-transform: rotate(-45deg);
			transform: rotate(-45deg);
			-webkit-animation: sdb 1.5s infinite;
			animation: sdb 1.5s infinite;
			box-sizing: border-box;
		}
		@-webkit-keyframes sdb {
			0% {
			-webkit-transform: rotate(-45deg) translate(0, 0);
			opacity: 0;
			}
			50% {
			opacity: 1;
			}
			100% {
			-webkit-transform: rotate(-45deg) translate(-10px, 10px);
			opacity: 0;
			}
		}
		@keyframes sdb {
			0% {
			transform: rotate(-45deg) translate(0, 0);
			opacity: 0;
			}
			50% {
			opacity: 1;
			}
			100% {
			transform: rotate(-45deg) translate(-10px, 10px);
			opacity: 0;
			}
		}
	.snsArea{
		position: absolute;
		left: 50px;
		bottom: 2px;
		display: flex;
	}
		.snsArea li{
			margin-left: 10px;
			display: block;
		}
	.snsAreaSP{
		position: relative;
		width: 100%;
		display: flex;
		justify-content: center;
	}
		.snsAreaSP li{
			margin-left: 5px;
			margin-right: 5px;
			display: block;
		}

/*for Outline-------------------------------------------------------------*/
.wrapOutline {
	position: relative;
	width:100%;
	background-color: #FFF;
	padding-top: 200px;
	padding-bottom: 100px;
}
	.wrapOutline h2 {
		width: 100%;
		text-align: center;
	}
	.wrapOutline .outline_copy {
		width: 100%;
		max-width: 1100px;
		margin: 0 auto;
	}
	.wrapOutline .outline_copy img {
		width: 100%;
		height: auto;
	}
	.wrapOutline a:hover {
			opacity:0.7;
		}
	
/*for Comment-------------------------------------------------------------*/
.wrapComment {
	position: relative;
	width:100%;
	background-color: #8b2b2b;
	padding-top: 150px;
	padding-bottom: 100px;
}
	.wrapComment h2 {
		width: 100%;
		text-align: center;
	}
	.wrapComment h3 {
		width: 100%;
		text-align: center;
	}
	.wrapComment .comment_img {
		width: 90%;
		max-width: 370px;
		margin: 0 auto;
	}
	.wrapComment .comment_img img {
		width: 100%;
		height: auto;
	}
	.wrapComment p {
		color: #FFF;
	}


/*for Photo-------------------------------------------------------------*/
.wrapPhoto {
	position: relative;
	width:100%;
	background-color: #FFF;
	padding-top: 150px;
	padding-bottom: 100px;
}
	.wrapPhoto h2 {
		width: 100%;
		text-align: center;
	}
	.photo_Gallery{
		list-style: none;
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		width: 100%;
		max-width:1100px;
		margin: 0 auto;
		margin-top: 60px;
	}
		.photo_Gallery li{
			display: block;
			width: 200px;
			height: 200px;
			overflow: hidden;
			margin: 10px;
		}
		.photo_Gallery li a img {
			width: 100%;
			height: 100%;
			transition-duration: 0.3s;
		}
		.photo_Gallery li a img:hover {
			transform: scale(1.1);
			transition-duration: 0.3s;
		}
	@media (max-width:639px) {
		.photo_Gallery li{
			width: 45%;
			height: auto;
			margin: 2%;
		}
	}
/*for Information-------------------------------------------------------------*/
.wrapInformation {
	position: relative;
	width:100%;
	background-color: #130900;
	padding-top: 150px;
}
	.wrapInformation h2 {
		width: 100%;
		text-align: center;
	}
	.wrapInformation .info_ds {
		width: 90%;
		max-width: 700px;
		margin: 0 auto;
	}
		.wrapInformation .info_ds img {
			width: 100%;
			height: auto;
			margin-top: 60px;
		}
	.wrapInformation .info_Image {
		width: 100%;
		margin: 0;
		overflow:hidden;
	}
	.info_Image img {
		width: 100%;
		margin: 0;
		height: auto;
	}
	.wrapInformation .info_wrap {
		width: 840px;
		margin: 0 auto;
		margin-top: 40px;
		display: flex;
		justify-content: space-between;
	}
		.info_wrapIn {
			width: 400px;
			line-height: 1;
		}
		.info_wrapIn img {
			width: 100%;
			height: auto;
		}
	/*SP*/
	@media (max-width:839px) {
		.wrapInformation .info_wrap{
			width: 90%;
			display:block;
			margin-top: 0;
		}
		.info_wrapIn{
			width: 100%;
			height: auto;
			display: block;
			margin: 0 auto;
			margin-top: 40px;
		}
	}
/*for Ticket-------------------------------------------------------------*/
.wrapTicket {
	position: relative;
	width:100%;
	background-color: #265538;
	padding-top: 150px;
	padding-bottom: 100px;
}
	.wrapTicket h2 {
		width: 100%;
		text-align: center;
	}
	.wrapTicket .ticket_price {
		width: 90%;
		max-width: 600px;
		margin: 0 auto;
	}
		.wrapTicket .ticket_price img {
			width: 100%;
			height: auto;
			margin-top: 60px;
		}
	.wrapTicket .ticket_txt {
		width: 90%;
		max-width: 600px;
		margin: 0 auto;
	}
		.wrapTicket .ticket_txt p {
			font-size: 1.2rem;
			color: #CCC;
		}
		.wrapTicket .ticket_txt p a {
			color: #CCC;
		}
	.wrapTicket .ticket_list {
		width: 90%;
		max-width: 600px;
		margin: 0 auto;
		margin-top: 60px;
	}
	.wrapTicket .ticket_list {
		width: 90%;
		max-width: 600px;
		margin: 0 auto;
		margin-top: 60px;
	}
	.ticket_list a {
			display: block;
			margin-top: 10px;
		}
		.ticket_list img {
			width: 100%;
			height: auto;
		}
		.ticket_list a:hover {
			opacity:0.7;
		}
	.wrapTicket .ticket_wrap {
		width: 840px;
		margin: 0 auto;
		margin-top: 60px;
		display: flex;
		justify-content: space-between;
	}
		.ticket_wrapIn {
			width: 400px;
			line-height: 1;
		}
		.ticket_wrapIn a {
			display: block;
			margin-top: 10px;
		}
		.ticket_wrapIn img {
			width: 100%;
			height: auto;
		}
		.ticket_wrapIn a:hover {
			opacity:0.7;
		}
	/*SP*/
	@media (max-width:839px) {
		.wrapTicket .ticket_wrap{
			width: 90%;
			display:block;
			margin-top: 0;
		}
		.ticket_wrapIn{
			display: block;
			margin: 0 auto;
			margin-top: 40px;
		}
	}
/*for Access-------------------------------------------------------------*/
.wrapAccess {
	position: relative;
	width:100%;
	background-color: #FFF;
	padding-top: 150px;
	padding-bottom: 100px;
}
	.wrapAccess h2 {
		width: 100%;
		text-align: center;
	}
	.wrapAccess .access_wrap {
		width: 90%;
		max-width: 600px;
		margin: 0 auto;
		margin-top: 60px;
	}
		.wrapAccess .access_wrap a:link {
			color: #333;
		}
		.wrapAccess .access_wrap a:visited {
			color: #333;
		}
		.wrapAccess .access_wrap a:hover {
			text-decoration: none;
		}
		.wrapAccess .access_wrap .txtSmall {
			font-size: 1.4rem;
			margin-top: 1.8rem;
		}
	.wrapAccess .access_map {
		width: 90%;
	    max-width: 600px;
		margin: 0 auto;
		margin-top: 40px;
	}
		.google_map{
		    position:relative;
		    width: 100%;
		    height:0;
		    padding-top:70%;
		}
		.google_map iframe{
		    position:absolute;
		    top:0;
		    left:0;
		    width:100%;
		    height:100%;
		}


/*for Footer-------------------------------------------------------------*/
footer{
	width: 100%;
	text-align: center;
	display: block;
	padding: 50px 0;
}
	footer p{
		font-size: 1rem;
		color: #CCC;
	}
	footer .footer_wrap {
		width: 90%;
	    max-width: 600px;
		margin: 0 auto;
		padding-bottom: 30px;
	}
		footer .footer_wrap img {
			width: 100%;
			height: auto;
		}
.wrapBtn {
	display:block;
	width: 90%;
	margin: 0 auto; 
	padding: 0;
	padding-bottom: 30px;
	display: flex; 
	justify-content: center;
	}
a.btnStyle {
	position: relative;
	display: block;
	border-radius: 4px;
	background: #333;
	line-height: 40px;
	-webkit-transition: .2s;
	transition: .2s;
	cursor: pointer;
	width: 20%;
	text-align: center;
	text-decoration: none;
	margin-left: 3px;
	margin-right: 3px;
	font-size: 14px;
	color: #ccc;
}
a.btnStyle:hover {
	background: #999;
	color: #111;
}
a.btnTXT{
	font-size: 1.1rem;
}
a.btnSNS{
	font-size: 2rem;
}

/*for PAGETOP-------------------------------------------------------------*/
#page-top {
    position: fixed;
    bottom: 0.8rem;
    right: 0.8rem;
}
	#page-top a {
	    width: 60px;
	    height: 60px;
	    text-align: center;
	    display: block;
	    -webkit-transition: all 0.5s ease;
		transition: all 0.5s ease;
	}
	#page-top a img {
	    width: 100%;
	    height: auto;
	}
	#page-top a:hover {
		opacity: 0.4;
	}


/*navi*/
.navi_wrap{
	position: absolute;
	bottom:-38px;
	height:38px;
	width: 100%;
	overflow: hidden;
	text-align: center;
	background-color: #080406;
	padding-top: 1.4rem;
	z-index: 1;
	-webkit-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
.navi_fixed {
	position: fixed;
	top: 0px;
	z-index: 1;
	width: 100%;
	background-color: #FFF;
}
	.navi_btn {
		display: inline-block;
		margin-left: 16px;
		font-size: 1.6rem;
		font-family: 'EB Garamond', serif;
		line-height: 1.2;
	}
	.navi_btn.firstBtn{
		margin-left: 0;
	}
	.navi_btn a{
		text-decoration: none;
		color: #20582c;
		text-align: center;
	}
	.navi_btn a::after {
		content: '';
		display: block;
		width: 0;
		margin: 0 auto;
		border-bottom: 1px solid #20582c;
		transition: width 0.3s ease-in-out;
	}
	.navi_btn a:hover::after {
		width: 100%;
	}
@media (max-width:640px) {
	.navi_wrap {display: none;}
	.navi_fixed {display: none;}
}



/*-----header-----*/
.header_area{
	position: fixed;
	width: 98.5%;
	z-index: 200;
	text-align: right;
	padding-top: 14px;
}

/*Modal*/
#modal-main {
  display: none;
  z-index: 301;
  width: 90%;
  max-width: 500px;
  margin: 0;
  padding: 2.8rem;
  position:fixed;
  background-color: #ffffff;
  color: #414141;
  font-size: 1.4rem;
  line-height: 1.6;
}

#modal-main h3 img {
  width: 100%;
  height: auto;
}

#modal-bg {
  display:none;
  width:100%;
  height:130%;
  background-color:rgba(0,0,0, 0.50);
  position:fixed;
  top:0;
  left:0;
  z-index: 300;
}

/*---------------------------------------------------------------------------------------------*/
.scroll-infinity{
	width:100%;
	margin-top: 3rem;
}
@keyframes infinity-scroll-left {
	from {
	transform: translateX(0);
	}
	to {
	transform: translateX(-100%);
	}
}
.scroll-infinity__wrap {
	display: flex;
	overflow: hidden;
}
.scroll-infinity__list {
	display: flex;
	list-style: none;
	padding: 0
}
.scroll-infinity__list--left {
	animation: infinity-scroll-left 40s infinite linear 0.5s both;
}
.scroll-infinity__item {
	width: calc(120vw / 4);
	margin-left:2px;
}

.scroll-infinity__item img {
	width: 100%;
	height:auto;
}

@keyframes infinity-scroll-right {
	from {
	transform: translateX(-100%);
	}
	to {
	transform: translateX(0%);
	}
}
.scroll-infinity__list--right{
  animation :infinity-scroll-right 40s infinite linear 0.5s both;
}

@media (max-width:840px) {
	.scroll-infinity__item {
	width: calc(120vw / 2.5);
	}
	.scroll-infinity__list--left {
	animation: infinity-scroll-left 30s infinite linear 0.5s both;
	}
	.scroll-infinity__list--right{
	animation :infinity-scroll-right 30s infinite linear 0.5s both;
	}
}

/*---------------------------------------------------------------------------------------------*/
@media (max-width:939px) {
	#slick_wrap li{
		background-position: 45% 40%;
	    background-size: 160% auto;
	}
	.wrapHome_inL, .wrapHome_inR{
		display: none;
	}
	.wrapHome{
		display: block;
	}
	.wrapHome_SPin1, .wrapHome_SPin2 {
		display: block;
	}
	#nextAnim a span {
		bottom: 30px;
	}
	/*WRAP*/
	.wrapOutline, .wrapComment, .wrapHistory, .wrapPhoto, .wrapInformation, .wrapTicket, .wrapAccess {
		padding-top: 80px;
	}
	/*History*/
	dt h3{
		font-size: 3rem;
	}


@media (max-width:640px) {
	#page-top a {
	    width: 40px;
	    height: 40px;
	}
	/*History*/
	dd .history_copy{
	   display: block;
	}
		dd .history_copy .history_copyIn{
		   width: 100%;
		}
}


