@charset "utf-8";

/*---------------------------------------------
	body
---------------------------------------------*/
html {
	scroll-behavior: smooth;
	font-size: 62.5%;
}

/* 10px */
body {
	width: 100%;
	font-size: 1.6rem;
	color: #333;
	line-height: 1.8;
	text-align: left;
	-webkit-text-size-adjust: 100%;
	font-weight: 500;
	font-family: 'Noto Serif JP', serif;
	background-size: auto 500px;
	overflow: hidden;
}

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

.gothic {
	font-family: "Noto Sans JP", sans-serif;
}



/*---------------------------------------------
	Anchor
---------------------------------------------*/
a {
	outline: none;
}

a:link {
	color: #fff;
	text-decoration: none;
}

a:visited {
	color: #fff;
	text-decoration: none;
}

a:hover {
	color: #f1c791;
	text-decoration: none;
}

a:active {
	color: #f1c791;
	text-decoration: none;
}

a {
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}

/*---------------------------------------------
	p
---------------------------------------------*/
p {
	margin-bottom: 1em;
}

.only_pc {
	display: block;
}

.only_sp {
	display: none;
}

.only_pc_line {
	display: inline-block;
	padding: 0 5px;
}

.sp_br {
	display: none;
}



/*---------------------------------------------
 ** ON OFF hover
---------------------------------------------*/
.hover {
	-webkit-transition: 0.5s ease-in-out;
	-moz-transition: 0.5s ease-in-out;
	-o-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;
}

.hover:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}


#bg01 {
	background: url(../img/main_bg.png) repeat-x bottom left #ed7faf;
	padding-top: 0%;
}

#main {
	width: 100%;
	max-width: 1500px;
	height: 1710px;
	margin: 0 auto;
	background: url(../img/main_tree.png) no-repeat top center;
	background-size: auto 100%;
	padding: 0% 0;
	box-sizing: border-box;
	color: #fff;
}

#main_in {
	width: 95%;
	max-width: 1040px;
	height: 1710px;
	margin: 0 auto;
	position: relative;
}

.main_cast {
	width: 95%;
	display: block;
	position: absolute;
	top: 178px;
	left: -0.5%;
	margin: 0 auto;
	pointer-events: none;
}

.main_snow {
	width: 89%;
	display: block;
	position: absolute;
	top: 2px;
	left: 2%;
	margin: 0 auto;
	pointer-events: none;
}

.main_arrow {
	display: inline-block;
	width: 15%;
	position: absolute;
	bottom: 3%;
	left: 0;
	right: 0;
	margin: 0 auto;
	transition: all 0.5s;
	padding: 2%;
}

.main_arrow:hover {
	bottom: 2%;
}

#sns ul {
	width: 98%;
	display: flex;
	margin: 0 auto;
	justify-content: flex-end;
	padding-top: 10px;
}


#sns ul li a {
	display: block;
	padding: 0 10px 10px;
}

#sns ul li a:hover {
	background: #ac824d;
	color: #fff;
}

#sns ul li:nth-child(1) a {
	width: 49px;
}

#sns ul li:nth-child(2) a {
	width: 12px;
}

#sns ul li:nth-child(3) a {
	width: 21px;
}

#sns ul li:nth-child(4) a {
	width: 22px;
}

#sns ul li:nth-child(5) a {
	background: url(../img/icon_ballet.png) no-repeat left 10px top 10px;
	background-size: 18px auto;
	font-size: 80%;
	padding: 6px 10px 8px 32px;
	margin-left: 20px;
	z-index: 2;
}

#sns ul li:nth-child(5) a:hover {
	background: url(../img/icon_ballet.png) no-repeat left 10px top 10px #ac824d;
	background-size: 18px auto;
}

#logo {
	width: 190px;
	position: absolute;
	top: 16px;
	right: 0;
}

#logo #menu {
	margin: 5% auto;
}

#logo #menu p {
	border-bottom: 1px solid #fff;
	letter-spacing: 0.05em;
	font-size: 110%;
}

#logo #menu ul li a {
	display: block;
	padding: 1px 10px;
	box-sizing: border-box;
	font-size: 105%;
	letter-spacing: 0.01em;
}

#logo #menu ul li a::first-letter {
	font-size: 80%;
	vertical-align: 2px;
	padding-right: 3px;
}

#logo #menu ul li a:hover {
	background: #ac824d;
	color: #fff;
}

#logo #menu ul li a span {
	font-size: 80%;
	display: inline-block;
	margin-left: 5px;
}

#main_data {
	width: 375px;
	position: absolute;
	top: 2px;
	left: 0;
	line-height: 1.6;
}

.bunka {
	background: url(../img/icon_bunka.png) no-repeat left top;
	background-size: 60px auto;
	padding: 10px 0 5px 70px;
	font-size: 70%;
	line-height: 1.6;
	margin-bottom: 30px;
	pointer-events: none;
}

#main_data>img {
	width: 90%;
}

.place {
	font-size: 160%;
	margin: 5px 0 15px;
}

h2 {
	font-size: 120%;
	margin-bottom: 20px;
}

.price {
	max-width: 310px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 5px;
}

.price dl {
	width: 45%;
}

.price dl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	font-size: 100%;
	line-height: 1.8;
}

.price dl:nth-child(2n-1) {
	margin-right: 2%;
}

.price dl dt {
	width: 36%;
	text-align: left;
	letter-spacing: 0.1em;
}

.price dl:nth-child(2n) dt {
	width: 32%;
}

.price dl:last-child dt {
	letter-spacing: -0.05em;
}

.price dl dd {
	width: 57%;
	text-align: left;
}

.price dl dd::before {
	content: '…';
	display: inline-block;
	margin-right: 2%;
}

.note {
	font-size: 70%;
}

.text_link {
	font-size: 115%;
	display: inline-block;
	margin: 3% auto 5%;
}

.text_link span {
	font-size: 40%;
	vertical-align: 1px;
	padding-left: 5px;
}

.text_link a {
	display: block;
	padding: 0 3px 2px;
	border-bottom: 1px solid #fff;
}

.text_link a:hover {
	border-bottom: 1px solid #f1c791;
}


.btn a {
	max-width: 291px;
	background: url(../img/btn_bg.png) repeat-x;
	background-size: auto 100%;
	display: block;
	padding: 7px 10px;
	box-sizing: border-box;
	font-size: 110%;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
	transition: all 0.5s;
	font-family: 'Noto Serif JP', serif;
}

.btn a:hover {
	background: url(../img/btn_bg02.png) repeat-x;
	background-size: auto 100%;
	color: #fff;
}

.btn a span {
	font-size: 80%;
	display: block;
	font-weight: normal;
}

#main .contact {
	margin: 5% 0;
}

#main .contact dt {
	font-size: 85%;
	margin-bottom: 7px;
	text-indent: -7px;
}

#main .contact dd {
	line-height: 1.8;
	font-size: 90%;
}

.main_txt_sp {
	display: none;
}


#bg02 {
	padding-top: 0%;
	background: #c8e3f6;
}

#story {
	width: 100%;
	max-width: 1500px;
	height: 2440px;
	margin: 0 auto;
	background: url(../img/story_snow.png) no-repeat top center;
	background-size: cover;
	box-sizing: border-box;
}

#story_in {
	width: 90%;
	max-width: 1040px;
	height: 2500px;
	margin: 0 auto;
	position: relative;
	padding: 5% 0 0;
	box-sizing: border-box;
}

@media screen and (max-width: 1115px) {
	#story {
		height: 2550px;
	}

	#story_in {
		height: 2600px
	}
}

#story h3 {
	width: 80%;
	max-width: 250px;
	margin: 0 auto 5%;
}

.story_box {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	font-size: 95%;
	line-height: 2.0;
	margin-bottom: 7%;
}

.story_box>div {
	width: 50%;
}

.story_box>img {
	width: 45%;
}

#cast {
	width: 100%;
	max-width: 1040px;
	margin: 0 auto;
	position: relative;
	padding: 5% 0 0;
	color: #333;
}

#cast ul {
	max-width: 950px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
}

#cast ul li {
	width: 20%;
	margin: 0 2.5% 2%;
	text-align: center;
	font-size: 85%;
	line-height: 1.4;
}


#cast ul li a {
	color: #006fbc !important;
}

#cast ul li img {
	margin-bottom: 4px;
	display: inline-block;
	transition: all 0.5s;
}

#cast ul li a:hover img {
	filter: drop-shadow(0px 0px 10px #006fbc);
	opacity: 0.9;
}

#cast ul li span {
	font-size: 90%;
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	display: block;
	font-weight: bold;
}

#cast p {
	text-align: center;
	font-size: 80%;
	margin: 1% auto 3%;
	font-weight: 300;
}

#midokoro {
	background: url(../img/midokoro_bg.png);
	background-size: 100%;
	padding: 2% 6%;
	box-sizing: border-box;
}

#midokoro h4 {
	font-size: 120%;
	text-align: center;
	letter-spacing: 0.1em;
	color: #006fbc;
	margin-bottom: 20px;
}

#midokoro>div {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}

#midokoro>div p {
	width: 48%;
	font-size: 90%;
	line-height: 2.0;
}

#midokoro>div img {
	width: 47%;
}

#bg03 {
	background: url(../img/staff_bg.png) repeat-x bottom left #ed7faf;
	padding-top: 0%;
}

#staff {
	width: 100%;
	max-width: 1500px;
	height: 1200px;
	margin: 0 auto;
	background: url(../img/staff_snow.png) no-repeat top center;
	background-size: 100%;
	padding: 3% 0;
	box-sizing: border-box;
	color: #fff;
}

#music {
	width: 95%;
	max-width: 1040px;
	margin: 0 auto 3%;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	padding-left: 5%;
	box-sizing: border-box;
}

#music dl {
	width: 40%;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	margin-right: 5%;
	margin-bottom: 10px;
	letter-spacing: 0.05em;
}

#music dl dt {
	font-size: 100%;
	display: inline-block;
	padding-right: 10px;
}

#music dl dd {
	font-size: 100%;
	padding-top: 0;
	display: inline-block;
	font-weight: 300;
	position: relative;
}

#music dl dd::before {
	content: '…';
	display: inline-block;
	padding: 0 5px 0 5px;
}

#staff_data {
	width: 95%;
	max-width: 1040px;
	padding-left: 5%;
	margin: 0 auto 3%;
	box-sizing: border-box;
}

#staff_data h3 {
	position: relative;
	margin-bottom: 2%;
}

#staff_data h3 img {
	width: 165px;
	display: block;
}

#staff_data h3:before {
	content: '';
	width: calc(100% - 185px);
	height: 1px;
	background: #fff;
	display: block;
	position: absolute;
	right: 0;
	top: 12px;
}

#staff_data dl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}

#staff_data dl dt {
	width: 200px;
	font-size: 90%;
	margin-bottom: 5px;
	letter-spacing: 0.02em;
}

#staff_data dl dd {
	width: calc(100% - 210px);
	font-size: 85%;
	margin-bottom: 5px;
	font-weight: 300;
	letter-spacing: 0.02em;
}

#staff_data dl dd ul li {
	display: inline-block;
}

#ticket {
	width: 95%;
	max-width: 1040px;
	padding-left: 5%;
	margin: 0 auto 2%;
	box-sizing: border-box;
}

#ticket h3 {
	position: relative;
	margin-bottom: 2%;
}

#ticket h3 img {
	width: 280px;
	display: block;
}

#ticket h3:before {
	content: '';
	width: calc(100% - 300px);
	height: 1px;
	background: #fff;
	display: block;
	position: absolute;
	right: 0;
	top: 12px;
}

#ticket dl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}

#ticket dl dt {
	width: 240px;
	font-size: 105%;
	margin-bottom: 5px;
	letter-spacing: 0.02em;
	font-weight: 300;
}

#ticket dl dd {
	width: calc(100% - 250px);
	font-size: 105%;
	margin-bottom: 5px;
	font-weight: 300;
}

#ticket dl dt.tiket_long {
	width: 360px;
}

#ticket .btn {
	display: inline-block;
	margin-left: 5%;
}

#ticket .btn a {
	width: 250px;
	font-size: 80%;
	line-height: 1.2;
	padding: 3px 0;
}

#ticket dl dd.tiket_long {
	width: calc(100% - 380px);
}

#ticket p {
	font-weight: 300 !important;
	margin-top: 10px;
}


#sponsor {
	width: 95%;
	max-width: 1040px;
	padding-left: 5%;
	margin: 0 auto 3%;
	box-sizing: border-box;
}

#sponsor dl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}

#sponsor dl dt {
	width: 80px;
	font-size: 90%;
	margin-bottom: 5px;
	letter-spacing: 0.02em;
	font-weight: 300;
}

#sponsor dl dd {
	width: calc(100% - 100px);
	font-size: 90%;
	margin-bottom: 5px;
	font-weight: 300;
}

#sponsor dl dd ul li {
	display: inline-block;
}

#hole {
	margin: 2% auto;
}

#hole h4 {
	font-size: 130%;
	font-weight: bold;
	letter-spacing: 0.02em;
}

#hole>div {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	font-weight: 300;
	font-size: 90%;
}

#hole>div p {
	margin-right: 2%;
	letter-spacing: 0.02em;
}

#hole>div p:last-child a {
	border-bottom: 1px solid #fff;
	padding-bottom: 2px;
}

#hole>div p:last-child a:hover {
	border-bottom: 1px solid #f1c791;
}

#hole>div p:last-child span {
	font-size: 60%;
}


#pageTop {
	position: fixed;
	bottom: 10px;
	right: 5px;
	z-index: 999;
}

#pageTop a {
	display: block;
	width: 50px;
	height: 60px;
	background: url(../img/page_top.png) no-repeat;
	background-size: 100%;
	-moz-border-radius: 0px;
	-webkit-border-radius: 0px;
	border-radius: 0px;
}

#pageTop a:hover {
	text-decoration: none;
	opacity: 0.7;
}