@charset "utf-8";

/* ヘッダー */
header #keyvisual{
	background-image: url("../img/maiinBg.jpg");
	background-position: 50% 2%;
	background-size: 150% auto;
	padding-top: 100px;
}
header .head{padding: 5px;background-color: #045858;}
header .head h1 img{
	position: relative;
	margin: 0 ;
	height:30px;
	width: auto;
}
#preticket{padding: 0;}

/* 注意事項 */
#cautionlist{
    position: relative;
	margin: 0 auto;
}
#cautionlist::before, #goods::before{
	position: absolute;
	content: '';
	display: block;
	width: 100%;
	height: 50px;
	left: 0;
	background-image: url("../img/bg_white.svg");
	background-repeat: no-repeat;
	background-size: 101% 100%;
	background-position: 0 0;
	top:-50px;
}
#cautionlist::after, #goods::after{
	position: absolute;
	content: '';
	top:-80px;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-image: url("../img/ttl_pages.svg");
	background-repeat: no-repeat;
	background-size: 20% auto;
	background-position: -2px 0;
}
#cautionlist .cautioWrap, #goods .cautioWrap{
	position: relative;
	padding: 0 0 100px 0;
	background-image: url("../img/bg_circle.svg"), url("../img/bg_faq.svg"), url("../img/bg_faq.svg"), url("../img/bg_circle.svg");
	background-repeat: no-repeat,no-repeat, no-repeat, no-repeat;
	background-size: 90% auto, 48% auto, 48% auto, 94% auto;
	background-position: calc(100% + 60px) 40px, -60px 50%, -10px 100%, calc(100% + 60px) 60%;
}
#cautionlist dl{
    position: relative;
	margin: 0 auto;
}
#cautionlist dl.marginbottom{margin: 0 auto 50px auto;}
#cautionlist dt{
    position: relative;
	margin: 0 auto;
    font-size: .18rem;
    padding: 30px 0 25px 0;
	font-weight: 900;
	text-align: center;
	color: #045858;
}
#cautionlist dd p{
    position: relative;
	margin: 0 auto;
    padding: 0 0 15px 0;
}
#cautionlist dd p::before{
	position: relative;
	content: '・';
	display: inline-block;
	top:0;
	left: 0;
}
#cautionlist dd p .Block{padding-left: 1.2em;}
#cautionlist dd a{text-decoration: underline;}
#cautionlist dd .ttl{
    position: relative;
	margin: 0 auto;
    font-size: .15rem;
    padding: 15px 0;
	font-weight: 900;
	text-align: center;
}

/* よくある質問 */
#faq{
    position: relative;
	margin: 0 auto;
	padding: 0 0 50px 0;
	background-color: #090f0c;
	z-index: 1;
}
#faq::before, #faq::after{
	position: absolute;
	content: '';
	display: block;
	width: 100%;
	height: 50px;
	left: 0;
	background-repeat: no-repeat;
	background-size: 101% 100%;
	background-image: url("../img/bg_dark.svg");
	background-position: 50% 0;
}
#faq::before{top: -50px;}
#faq::after{bottom: -50px;transform: scale(-1,-1);}
#faq dl{
	position: relative;
	margin: 40px auto 0 auto;
	line-height: 1.5em;
	width: calc(100% - 40px);
}
#faq dl dt{
	position: relative;
	margin: 20px auto 5px auto;
	font-weight: 700;
	color: #56c19f;
}
#faq dl dt::before{
	position: relative;
	content: 'Q.';
    display: inline-block;
    width: 1.5em;
    left: 0;
}
#faq dl dd{
	position: relative;
	margin: 0 auto;
	color: #ffffff;
}
#faq dl dd::before{
	position: relative;
	content: 'A.';
    display: inline-block;
    width: 1.5em;
    left: 0;
}

/* 利用制限 */
#limit{
    position: relative;
	margin: 0 auto;
	padding: 40px 0 100px 0;
	background-repeat: no-repeat;
	background-size: 50% auto;
	background-image: url("../img/ttl_limit.svg");
	background-position: -70px -60px;
	overflow: hidden;
}
#limit::before{
    position: absolute;
	bottom:0;
	left: 0;
	content: '';
	display: block;
	width: 100%;
	height: 30%;
	background-repeat: no-repeat;
	background-size: 90% auto;
	background-image: url("../img/bg_circle.svg");
	background-position: calc(100% + 40px) 100%;
}
#limit dl{
    position: relative;
    margin: 40px auto 0 auto;
	width: calc(100% - 20px);
    border-top: solid 1px #045858;
    border-left: solid 1px #045858;
    border-right: solid 1px #045858;
    display:-webkit-box;
	display:-webkit-flex;
	display:-ms-flexbox;
	display:flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: space-between;
}
#limit dt{
    width: calc(35% - 21px);
    padding: 15px 10px;
    text-align: center;
    background-color: #56c19f;
    border-bottom: solid 1px #045858;
}
#limit dd{
    width: calc(65% - 20px);
    padding: 15px 10px;
    border-bottom: solid 1px #045858;
	text-align: center;
	font-size: .14rem;
	font-weight: 700;
}
#limit dd p{
	padding-top: 10px;
	font-size: .12rem;
	font-weight: 500;
	text-align: left;
} 

/* グッズ */
#goods, #goods ul{
	position: relative;
	margin: 0 auto;
}
#goods ul li{
	position: relative;
	width: calc(100% - 40px);
	margin: 0 auto 60px auto;
}
#goods ul li .ttl{
	font-size: .18rem;
    padding: 20px 0 5px 0;
	font-weight: 900;
	text-align: center;
	color: #045858;
	border-bottom: solid 1px #045858;
}
#goods ul li .ttl span{font-size: .15rem;}
#goods ul li .price{
	text-align: right;
	padding:10px 0;
	font-size: .16rem;
	font-weight: 900;
}
#goods ul li .spec{padding:0 10px;}
#goods p.caution{text-align: right;margin: -20px 10px 0 0;}


/* ----- pc ----- */
@media screen and (min-width: 641px) {
	
	/* ヘッダー */
	header .head{display: none;}
	header #keyvisual{
		background-position: 50% 5%;
		padding-top: 220px;
	}

	/* 注意事項 */
	#cautionlist{padding: 20px 0 80px 0;}
	#cautionlist::after, #goods::after{
		top:-170px;
		background-size: 129px auto;
	}
	#cautionlist::before, #goods::before{
		height: 120px;
		top:-120px;
	}

	#cautionlist .cautioWrap{background-size: 580px auto, 360px auto,360px auto,580px auto;}
	 #goods .cautioWrap{background-size: 580px auto, 0 0, 360px auto,0 0;}
	#cautionlist dl.marginbottom{margin: 0 auto 20px auto;}
	#cautionlist dt{
		font-size: .24rem;
		padding: 100px 0 40px 0;
	}
	#cautionlist dd .ttl{
		font-size: .16rem;
		padding: 30px 0;
	}

	/* よくある質問 */
	#faq{padding: 0 0 80px 0;}
	#faq dl{width: 960px;}
	#faq dl dt{margin: 30px auto 5px auto;}
	#faq::before, #faq::after{height: 120px;}
	#faq::before{top: -120px;}
	#faq::after{bottom: -120px;}

	/* 利用制限 */
	#limit{
		padding: 100px 0 100px 0;
		background-size: 350px auto;
		background-position:calc(50% - 460px) -60px;
	}
	#limit::before{
		width: 100%;
		height: 100%;
		background-size: 720px auto;
		background-position: calc(100% + 40px) 100%;
	}
	#limit dl{
		margin: 20px auto 0 auto;
		width: 740px;
	}
	#limit dt{font-size: .14rem;}
	#limit dd{font-size: .18rem;}
	#limit dd p{
		padding-top: 10px;
		font-size: .14rem;
	} 
	
	/* グッズ */
	#goods ul li{
		width: 280px;
		margin: 0 20px 60px 20px;
	}
	#goods ul li .spec{font-size: .14rem;}
	#goods p.caution{width: 980px; margin:0 auto;}

}