@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Lora:400,400i,700,700i|Noto+Serif+JP:200,300,400,500,600,700,900');

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

body {
	color: #333;
	font-family: "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 100%;
  line-height: 1.5;
  position: relative;
  /*z-index: -1;*/
}

a {
	color: #000;
}

.pc {
	display: block!important;
}

.sp {
	display: none!important;
}

.pc_blanc {
  display: inline-block!important;
}

/* ----------------------------------------
module
----------------------------------------- */

/* hidetxt */
.hidetxt a {
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

a {
	transition: 0.5s;
}
a:hover {
	opacity: 0.8;
}

.lora {
	font-family: 'Lora', serif;
}
.notoSerifjp {
	font-family: 'Noto Serif JP', serif;
}

section h1.title {
	margin-bottom: 3em;
	color: #f7b52c;
	text-align: center;
	font-size: 1.63rem;
	position: relative;
}
section h1.title span {
	display: inline-block;
	width: auto;
	position: relative;
	z-index: 10;
}
section h1.title:before, section h1.title:after {
	content: '';
	display: block;
	background-color: #71562e;
	width: 30%;
	height: 1px;
	position: absolute;
	top: calc(50% - 1px);
	left: 0;
}
section h1.title:after {
	left: auto;
	right: 0;
}
section h1.title span:after {
	display: inline-block;
	content: attr(title);
	vertical-align: middle;
	margin-left: 1em;
	font-size: 0.88rem;
	font-weight: normal;
}

/* ----------------------------------------
header
----------------------------------------- */

header {
	width: 100%;
	height: 72px;
  background-image: linear-gradient(85deg, #d0121b, #a60d0d);
	transition: all 0.25s ease;
	-webkit-transition: all 0.25s ease;
	position: static;
	top: -72px;
	left: 0;
	z-index: 100;
}
header.fixed {
	transition: all 0.8s ease;
	-webkit-transition: all 0.8s ease;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
}

/* gnav */
header .gnav {
	padding-top: 1.4em;
	text-align: center;
}
header .gnav li {
	display: inline-block;
	margin: 0 1.8em;
}
header .gnav li:last-child {
	margin-right: 0;
}

header .gnav li a {
	display: inline-block;
	width: 100%;
	text-align: center;
	color: #fff;
	font-size: 0.94rem;
	font-weight: bold;
	text-shadow: 0px 5px 7px rgba(0, 0, 0, 0.08);
}
header .gnav li a:after {
	content: attr(title);
	display: inline-block;
	margin-left: 1em;
	font-size: 0.75rem;
	font-family: 'Lora', serif;
}

/* ----------------------------------------
mv
----------------------------------------- */

#mv {
	background-image: url(../img/bg_mv.jpg);
	background-repeat: no-repeat;
	background-position: 0 0;
	-webkit-background-size: cover;
	background-size: cover;
}

#mv .wrap {
	width: 100%;
	max-width: 960px;
	padding: 3% 0 5%;
	margin: 0 auto;
	position: relative;
}

#mv .copy_01 {
	width: 99px;
	position: absolute;
	right: 6%;
	top: 33%;
}
#mv .copy_02 {
	width: 82px;
	position: absolute;
	left: 6%;
	top: 42%;
}

#mv .hero {
	width: 1028px;
	margin-bottom: 5%;
	position: relative;
	left: -24px;
}

#mv h1 {
	width: 100%;
	max-width: 446px;
	height: auto;
	margin: 0 auto 0.5em;
}

#mv .outline {
	margin-bottom: 5%;
	text-align: center;
  font-size: 1rem;
  font-weight: 900;
}
#mv .outline .lora {
	display: block;
	margin-top: 0.5em;
  font-size: 0.81rem;
  font-weight: bold;
}

#mv h2 {
	margin-bottom: 2em;
  font-size: 1.63rem;
  font-weight: 900;
  text-align: center;
  color: #d0121b;
}

#mv .anchorlink_hall {
	width: auto;
	max-width: 980px;
	display: flex;
	flex-wrap: nowrap;
	margin: 0 auto;
}
#mv .anchorlink_hall li {
	width: 100%;
	padding: 5px;
	text-align: center;
  border: solid 1px #d0121b;
  background-color: #ffffff;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
#mv .anchorlink_hall li:nth-child(2) {
	margin: 0 1%;
}

#mv .anchorlink_hall li a {
	display: block;
	padding-bottom: 1.5em;
	position: relative;
}
#mv .anchorlink_hall a:hover {
	text-decoration: none;
}
#mv .anchorlink_hall a:after {
	content: '';
	display: block;
  width: 11px;
  height: 7px;
  margin-left: -5px;
  background-image: url(../img/ico_ankerlink.png);
  background-repeat: no-repeat;
  background-position: 0 0;
  -webkit-background-size: contain;
  background-size: contain;
  position: absolute;
  left: 50%;
  bottom: 6%;
}

#mv .anchorlink_hall h3 {
	margin-bottom: 0.5em;
	padding: .3em;
	font-size: 1.06rem;
	font-weight: bold;
	color: #fff;
	background-color: #d0121b;
}
#mv .anchorlink_hall h3:after {
	content: attr(title);
	display: inline-block;
	margin-left: .5em;
	vertical-align: middle;
	font-size: 0.75rem;
	font-family: 'Lora', serif;
}

#mv .anchorlink_hall .date {
	line-height: 1.6;
	font-size: 2.06rem;
	font-weight: 900;
}
#mv .anchorlink_hall .date .year {
	font-size: 1.31rem;
}
#mv .anchorlink_hall .date .weekday {
	font-size: 1.06rem;
}

#mv .anchorlink_hall .hall {
	font-size: 1.06rem;
  font-weight: 900;
}

#mv .anchorlink_hall .event {
	font-size: 1.16rem;
  font-weight: 900;
  color: #d0121b;
}

/* ----------------------------------------
about
----------------------------------------- */

.bg_about {
	background-image: url(../img/bg_about.jpg);
	background-repeat: no-repeat;
	background-position: 50% 0;
	-webkit-background-size: 100% auto;
	background-size: 100% auto;
	background-color: #000;
	position: relative;
	z-index: 0;
}

#about {
	/*margin-top: -72px;
	padding-top: 72px;*/
	position: relative;
}
#about:after {
	content: '';
	display: block;
  width: 295px;
  height: 284px;
  background-image: url(../img/img_about_01.png);
  background-repeat: no-repeat;
  background-position: 0 0;
  -webkit-background-size: contain;
  background-size: contain;
  position: absolute;
  right: 0;
  bottom: -8%;
}

#about .wrap {
	width: auto;
	max-width: 820px;
	margin: 0 auto 5%;
	padding-top: 8%;
	position: relative;
	z-index: 10;
}

#about h2 {
	margin-bottom: 1.5em;
	text-shadow: 0 0 17px rgba(0, 0, 0, 0.55);
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.56;
  text-align: center;
  color: #f7b52c;
}

#about h2.small {
  font-size: 1.4rem;
}

#about .txt {
  text-shadow: 0 0 17px rgba(0, 0, 0, 0.55);
  font-size: 1rem;
  font-weight: normal;
  font-style: normal;
  font-stretch: normal;
  line-height: 2.38;
  letter-spacing: normal;
  text-align: left;
  color: #ffffff;
  margin-bottom: 3em;
}

#about .txt strong {
  color: #f7b52c;
}

/* ----------------------------------------
 about02
----------------------------------------- */
#about02 .wrap {
	width: auto;
	max-width: 800px;
	margin: 10em auto 8em;
  padding: 30px 40px 45px;
	position: relative;
	z-index: 10;
  background-color: #620000;
  border: solid 1px #a60000;
}

#about02 .txt {
  text-shadow: 0 0 17px rgba(0, 0, 0, 0.55);
  font-size: 1rem;
  font-weight: normal;
  font-style: normal;
  font-stretch: normal;
  line-height: 1.8;
  letter-spacing: normal;
  text-align: left;
  color: #ffffff;
}

#about .txt strong {
  color: #f7b52c;
}

#about02 h2 {
  text-align: center;
  width: 135px;
  position: absolute;
  top: -47px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

#about02 h3 {
  color: #f7b52c;
  font-size: 1.4rem; 
  margin-bottom: .3em;
}

#about02 .name_txt {
  color: #fff;
  font-size: 1.1rem;
  margin-bottom: 1em;
}

#about02 .txt {
  color: #fff;
  font-size: 1rem;
}

#about02 h4 {
  color: #f7b52c;
  font-size: 1.1rem;
  font-weight: 100;
  margin-bottom: 1em;
}

/*story*/

#about02.story .wrap {
	margin: 6em auto 5em;
}

#about02 .wraparound {
  overflow: hidden;
}

#about02 .wraparound .left {
 width:57%;
 float: left; 
}

#about02 .wraparound .right {
  margin-top: 1em;
  width:40%;
  float: right; 
}



/* ----------------------------------------
cast-staff
----------------------------------------- */

#cast-staff {
	margin-top: -72px;
	padding-top: 72px;
	position: relative;
}

#cast-staff .wrap {
	width: 1000px;
	margin: 0 auto;
	padding: 3% 0 7%;
}

/* card_image */
.card_image {
	text-align: center;
}

.card_image li {
	display: inline-block;
	vertical-align: top;
}
.card_image li a {
	color: #fff;
}

/* card_image mein */
#cast-staff .card_image.mein {
	margin-bottom: 10%;
}

#cast-staff .card_image.mein .name {
	margin-bottom: .8em;
	line-height: 1.6;
	padding-top: 1.5em;
	text-align: center;
	font-size: 1rem;
}
#cast-staff .card_image.mein .name .small {
	display: block;
	font-size: 0.88rem;
}

#cast-staff .card_image.mein .lora {
	line-height: 1.54;
	font-size: 0.81rem;
}
#cast-staff .card_image.mein .lora .small {
	font-size: 0.69rem;
	font-style: normal;
	display: block;
}

#cast-staff .card_image.mein li {
	width: auto;
	max-width: 224px;
	margin: 0 4%;
}

.module_castlist {
	width: 48%;
	float: left;
}
.module_castlist.first {
	margin: 0 2% 0 2%;
}

.module_castlist .ttl_title {
	width: 100%;
	margin-bottom: 2em;
	padding: .5em 0;
	text-align: left;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.module_castlist.first .ttl_title {
	padding-left: 2em;
	background-image: linear-gradient(to left, #980b12, #c20e17);
}
.module_castlist.second .ttl_title {
	padding-left: 1.5em;
  background-image: linear-gradient(to left, #71562e, #bd7f22);
}

.module_castlist .ttl_title .date {
	display: inline-block;
	color: #fff;
	font-size: 1.03rem;
	font-weight: 900;
}
.module_castlist .ttl_title .date:first-child {
	margin-right: .8em;
}
.module_castlist .ttl_title .date .small {
	color: #fff;
	font-size: 0.7rem;
	font-weight: 900;
}
.module_castlist .ttl_title .date .small.sapporo {
	margin-right: 1em;
}
.module_castlist .ttl_title .date:after {
	content: attr(title);
	display: inline-block;
	margin-left: 0.6em;
	vertical-align: middle;
	font-family: Lora;
  font-size: 0.69rem;
}

.module_castlist .card_image {
	text-align: left;
}
.module_castlist .card_image.sub {
	margin-top: 8%;
	border-top: 1px solid #71562e;
}

.module_castlist .card_image.main li {
	margin-top: 0;
}
.module_castlist .card_image li {
	width: 23.15%;
	margin: 8% .5% 0;
	text-align: center;
	vertical-align: top;
}

.module_castlist .card_image .famous {
	line-height: 1.3;
	margin-bottom: 0.8em;
	padding-top: 16px;
	font-size: 0.75rem;
}
.module_castlist .card_image .famous .lora {
	display: inline-block;
	width: 100%;
	font-size: 0.63rem;
}

.module_castlist .card_image .name {
	line-height: 1.3;
	font-size: 0.75rem;
}
.module_castlist .card_image .name .lora {
	display: inline-block;
	width: 100%;
	font-size: 0.63rem;
	font-weight: bold;
}

#cast-staff .staff {
	margin: 5% 0 0;
	padding: 5% 0;
	border-top: 1px solid #71562e;
	border-bottom: 1px solid #71562e;
	clear: both;
}

#cast-staff .staff table {
	width: 86%;
	margin: 0 auto;
	line-height: 1.8;
	text-align: left;
	font-size: 1rem;
	color: #fff;
}

#cast-staff .staff table th, #cast-staff .staff table td {
	padding: 0.4em;
}
#cast-staff .staff table th {
	width: 18%;
	vertical-align: top;
}
#cast-staff .staff table td {
	width: 38%;
}
#cast-staff .staff table td.en {
	width: auto;
	color: #f7b52c;
}
#cast-staff .staff table td .small {
	display: block;
	font-size: 0.81rem;
}

#cast-staff .attention {
	line-height: 1.3;
	text-align: center;
	font-size: 16px;
}

#cast-staff .attention .en {
	font-size: 12px;
}

/* ----------------------------------------
tickets
----------------------------------------- */

#tickets {
	margin-top: -72px;
	padding-top: 72px;
}

#tickets > .wrap {
	width: auto;
	max-width: 1000px;
	margin: 0 auto;
	padding: 7% 0 0;
}

#tickets .title {
	color: #333;
}
section#tickets h1.title:before, section#tickets h1.title:after {
	background-color: #c7c7c7;
}

#tickets .module {
	width: auto;
  max-width: 960px;
	margin: calc(-72px - 3%) auto 0;
	padding-top: calc(72px + 3%);
  overflow: hidden;
}
#tickets .module .wrap {
	margin-bottom: 5%;
  padding: 3%;
  border-radius: 5px;
  border: solid 1px #e8e8e8;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
#tickets .module:last-child .wrap {
	margin-bottom: 0;
}

#tickets .module .left {
  width: 49%;
  padding-top: .5em;
  float: left;
}

#tickets .module .left h2 {
	margin-bottom: .5em;
	font-size: 1.5rem;
}

#tickets .module .left .date {
	margin-bottom: .5em;
	font-size: 1rem;
	font-weight: bold;
}
#tickets .module .left .date .small {
	font-size: 0.81rem;
}

#tickets .module .left .price {
	margin-bottom: .5em;
	font-size: 0.94rem;
}
#tickets .module .left .price .small {
	font-size: 0.75rem;
}

#tickets .module .left .txt {
	line-height: 1.5;
	font-size: 0.88rem;
}

#tickets .module .left .sns {
	display: flex;
	margin-top: 0.8em;
}
#tickets .module .left .sns li {
	width: 33px;
	margin-left: .5em;
}
#tickets .module .left .sns li:first-child {
	margin-left: 0;
}

#tickets .module .pic {
  width: 49%;
  float: right;
}

#tickets .module .halllink {
	width: 100%;
	padding-top: 5%;
	clear: right;
}

#tickets .module .halllink li {
	width: 49%;
	float: left;
}
#tickets .module .halllink li:last-child {
	margin-left: 2%;
}

#tickets .module .halllink li a {
	display: block;
	padding: 0.9em;
	text-align: center;
	color: #fff;
	font-size: 1.13rem;
  border-radius: 3px;
  background-color: #333;
}
#tickets .module .halllink li:last-child a {
	background-color: #d0121b;
}
#tickets .module .halllink li a:after {
	content: attr(title);
	display: inline-block;F
	margin-left: .5em;
	vertical-align: middle;
	font-size: .8rem;
}

#tickets .module .halllink li a:before {
	content: '';
	display: inline-block;
	width: 15px;
  height: 19px;
  margin: -4px .5em 0 0;
  vertical-align: middle;
  background-image: url(../img/ico_access.png);
  background-repeat: no-repeat;
  background-position: 0 0;
  -webkit-background-size: contain;
  background-size: contain;
}
#tickets .module .halllink li:last-child a:before {
	width: 20px;
  height: 16px;
  background-image: url(../img/ico_tickets.png);
}

/*events*/

#tickets .events  {
  margin-top: 7em;
}

#tickets .events h2.title {
	margin-bottom: 2em;
	color: #333;
	text-align: center;
	font-size: 1.63rem;
	position: relative;
}
#tickets .events h2.title span {
	display: inline-block;
	width: auto;
	position: relative;
	z-index: 10;
}
#tickets .events h2.title:before, #tickets .events h2.title:after {
	content: '';
	display: block;
	background-color: #c7c7c7;
	width: 30%;
	height: 1px;
	position: absolute;
	top: calc(50% - 1px);
	left: 0;
}
#tickets .events h2.title:after {
	left: auto;
	right: 0;
}
#tickets .events h2.title span:after {
	display: inline-block;
	content: attr(title);
	vertical-align: middle;
	margin-left: 1em;
	font-size: 0.88rem;
	font-weight: normal;
}

#tickets .contents {
  margin-bottom: 4em;
}

#tickets .contents:last-child {
  margin-bottom: 1em;
}

#tickets .events h3 {
  font-size: 1.3rem;
  position: relative;
  margin-bottom: .3em;
}

#tickets .events h3:before {
  content: "";
  display: block;
  position: absolute;
  left: -29px;
  height: 1.5em;
  border-left: solid 8px #ff0000;
}

#tickets .events p.txt , #tickets .events .wraparound .txt {
  line-height: 1.8;
  font-size: .88rem
}

#tickets .events .about {
  font-size: 1.1rem;
  font-weight: 900;
  line-height: 1.9;
}
#tickets .events .price {
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.9;
  margin-bottom: .5em;
}

#tickets .events .wraparound {
  overflow: hidden;
}

#tickets .events .wraparound .left {
  width: 70%;
  float: left;
}

#tickets .events .wraparound .right {
  width: 24%;
  float:right;
}

#tickets .events .guest {
  overflow: hidden;
  margin-top: 2em;
}

#tickets .events .guest li {
  width: 120px;
  font-size: .78rem;
  text-align: center;
  line-height: 1.4;
  float: left;
  margin-right: 20px;
}

#tickets .events .guest li img {
  margin-bottom: 1em;
}

#tickets .events .guest li strong {
  font-size: .88rem;
}

#tickets .events .guest li .en {
  font-weight: 900;
  font-size: .6rem;
}

#tickets .events .box {
  border: solid 3px #bb8126;
  padding: 24px 26px;
  margin-bottom: 10px;
}

#tickets .events .box .detail {
  font-size: 1.2rem;
  font-weight: 900;
  margin-bottom: .4em;
}

#tickets .events .box .gold {
  color: #bb8126;
}

#tickets .events .box .small {
  font-size: 1rem;
}

#tickets .events .box .nenrei {
  font-size: .8rem;
}

#tickets .events .txt.small {
  font-size: .8em;
}

#tickets .events .contents .txt-link {
  text-decoration: underline;
}

#tickets .events .contents .txt-link:hover {
  text-decoration: none;
  opacity: 0.5;
}

/* ----------------------------------------
footer
----------------------------------------- */

footer {
	width: 1000px;
	margin: 10% auto 0;
	padding-bottom: 7%;
	position: relative;
	clear: both;
}

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

footer .pagetop {
	display: none;
	width: 61px;
	position: fixed;
	bottom: 534px;
	right: 74px;
	z-index: 100;
}

/* footer_part_1 */
footer .footer_part_1 {
	margin-bottom: 3em;
	text-align: center;
	font-size: 1.06rem;
	line-height: 1.9;
}

.footer_part_1 .logo {
	display: inline-block;
	width: 120px;
	vertical-align: top;
	margin: -.2em .2em 0 0;
}

/* footer_part_2 */
footer .footer_part_2 {
	margin: 0 auto 5%;
	text-align: center;
}

footer .footer_part_2 li {
	display: inline-block;
	margin: 0 2%;
}
footer .footer_part_2 li.bunka {
	width: 95px;
}
footer .footer_part_2 li.beyond {
	width: 58px;
}
footer .footer_part_2 li.aifj {
	width: 210px;
}

/* hglogo */
footer .halllogo {
	text-align: center;
}

footer .halllogo li {
	display: inline-block;
	margin: 0 1.5%;
}
footer .halllogo li:nth-child(-n+2) {
	width: 166px;
}
footer .halllogo li:nth-child(3) {
	width: 136px;
}

footer .copy {
	margin-top: 2em;
	text-align: center;
	font-size: 0.63rem;
}


@media screen and (max-width: 860px) {

	.pc {
		display: none!important;
	}

	.sp {
		display: block!important;
	}

  .pc_blanc {
    display: none!important;
  }
  
	/*
	module
	*/

	section h1.title {
		font-size: 1.2rem;
	}
	section h1.title span:after {
		font-size: .7rem;
	}
	section h1.title:before, section h1.title:after {
		width: 18%;
	}
	section h1.title span {
		padding: 0 .5em;
		background-color: #000;
	}

	/*
	header
	*/

	header {
		height: auto;
		padding: 5% 0;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
	}

	header .gnav {
		padding: 0;
		text-align: center;
	}

	header .gnav li {
		margin: 0 .2em;
	}

	/*
	mv
	*/

	#mv .wrap {
		padding: 3% 0 12%;
	}

	#mv .hero {
		width: 96%;
		margin: 0 0 5% 2%;
		left: 0;
	}

	#mv h1 {
		width: 60%;
		margin-bottom: 5%;
	}

	#mv .copy_01 {
		width: 13vw;
		top: 14.8%;
	}
	#mv .copy_02 {
		width: 10vw;
		top: 18%;
	}
	@media screen and (orientation: landscape) {
		#mv .copy_01 {
			top: 20%;
		}
		#mv .copy_02 {
			top: 24%;
		}
	}

	#mv .outline {
		padding: 0 .5em;
		font-size: .8rem;
	}
	#mv .outline .lora {
		font-size: .6rem;
	}

	#mv h2 {
		padding: 0 .5em;
		font-size: 1.1rem;
	}

	#mv .anchorlink_hall {
		display: block;
		width: 90%;
	}

	#mv .anchorlink_hall li:nth-child(2) {
		margin: 5% 0;
	}

	.bg_about {
		-webkit-background-size: 200% auto;
		background-size: 200% auto;
	}

	#cast-staff,
	#tickets, #tickets .module {
		margin-top: calc(-130px - 6%);
		padding-top: calc(130px + 6%);
	}

	#about .wrap {
		width: 90%;
		padding-top: 12%;
		margin-bottom: 8%;
	}

	#about h2 {
		font-size: 1.3rem;
	}

	#about .txt {
		line-height: 2;
	}

	#about:after {
		display: none;
	}

  /*about02*/
  
  #about02 .wraparound .left {
   width:100%;
   float: none; 
  }

  #about02 .wraparound .right {
    margin-top: 1em;
    margin-bottom: 2em;
    width:100%;
    float: none; 
  }
  
  
	/*
	cast-staff
	*/

	#cast-staff .wrap {
		width: 90%;
		padding-bottom: 12%;
	}

	#cast-staff .card_image.mein {
		margin-bottom: 12%;
	}
	#cast-staff .card_image.mein li {
		margin: 5% 2% 0;
	}

	.module_castlist {
		width: 100%;
		float: none;
	}
	.module_castlist.first {
		margin: 0 0 8%;
	}

	.module_castlist .ttl_title .date .small.sapporo {
		margin-right: 0;
	}

	.module_castlist .card_image li {
		width: 22.8%;
	}

	#cast-staff .staff table {
		font-size: 0.9rem;
	}

	#cast-staff .staff table th {
		width: 28%;
	}

	#cast-staff .staff table td {
		vertical-align: top;
	}

	#tickets .wrap {
		width: 90%;
		padding-top: 12%;
	}

	#tickets .module .wrap {
		width: 100%;
		padding: 6%;
	}

	#tickets .module .left {
		width: 100%;
		margin-bottom: 8%;
		float: none;
	}

	#tickets .module .left h2 {
		font-size: 1.3rem;
	}

	#tickets .module .left .date {
		font-size: .9rem;
	}

	#tickets .module .left .price {
		font-size: .8rem;
	}

	#tickets .module .left .txt {
		line-height: 1.3;
		font-size: .7rem;
	}

	#tickets .module .pic {
		width: 100%;
		float: none;
	}

	#tickets .module .halllink li a {
		font-size: .9rem;
	}
	#tickets .module .halllink li a:after {
		display: block;
		margin: 0 auto;
	}

	#tickets h1.title span {
		background-color: #fff;
	}

  
  /*tickets events*/
  
  #tickets .events h2.title {
		font-size: 1.2rem;
	}
	#tickets .events h2.title span:after {
		font-size: .7rem;
	}
	#tickets .events h2.title:before, #tickets .events h2.title:after {
		width: 18%;
	}
	#tickets .events h2.title span {
		padding: 0 .5em;
	}
  
  
  #tickets .events h3:before {
    left: -7%;
    height: 1.5em;
    border-left: solid 8px #ff0000;
  }
  
  #tickets .events .wraparound .left {
    width: 100%;
    float: none;
  }

  #tickets .events .wraparound .right {
    width: 60%;
    float: none;
    margin-left: auto;
    margin-right: auto;
  }


  #tickets .events .guest li {
    width: 47%;
    margin-right: 6%;
  }
  
  #tickets .events .guest li:nth-child(2n) {
    margin-right: 0;
    margin-bottom: 2em;
  }
  
  #tickets .events .guest li:last-child {
    margin-bottom: 0;
  }
  
	footer {
		width: 90%;
		margin-top: 12%;
	}

	footer .pagetop {
		width: 40px	;
		bottom: 5%;
		right: 5%;
	}

	footer .footer_part_1 {
		line-height: 1.7;
		font-size: 0.8rem;
	}

	footer .footer_part_2 {
		display: flex;
		width: 40%;
	}
	footer .footer_part_2 li.bunka, footer .footer_part_2 li.beyond, footer .footer_part_2 li.aifj {
		width: auto;
	}

	footer .halllogo {
		display: flex;
	}
	footer .halllogo li:nth-child(-n+2) {
		width: auto;
	}
	footer .halllogo li:nth-child(3) {
		width: auto;
	}

}


@media screen and (max-width: 374px) {
	#mv .copy_01 {
		top: 13%;
	}
	#mv .copy_02 {
		top: 15%;
	}

	.module_castlist .card_image li {
		width: 22.6%;
	}

	#cast-staff,
	#tickets, #tickets .module {
		margin-top: calc(-160px - 6%);
		padding-top: calc(160px + 6%);
	}

	#tickets .module .halllink li a {
		font-size: .8rem;
	}
}

@media screen and (min-width: 861px) and (max-width: 1023px) {
	#mv .copy_01 {
		top: 43%;
	}
	#mv .copy_02 {
		top: 45%;
	}
}

@media screen and (min-width: 500px) and (max-width: 860px) {
	#mv .copy_01 {
		top: 25%;
	}
	#mv .copy_02 {
		top: 28%;
	}
}

/* ----------------------------------------
magnific-popup
----------------------------------------- */

.mfp-wrap {
	overflow-x: hidden;
	overflow-y: auto;
}

.modal-staff {
  position: relative;
}

.modal-staff_inner {
  position: relative;
  display: table;
  width: 96%;
  max-width: 1200px;
  margin: 5% auto;
  padding: 40px 25px;
  background: #fff;
  box-sizing: border-box;
}

.mfp-close-btn-in .mfp-close {
	display: none;
}

.modal-dismiss {
	width: 20px;
	height: 20px;
  position: absolute;
  top: 10px;
  right: 10px;
}

.modal-dismiss a {
  width: 44px;
  height: 44px;
  text-align: center;
}

.modal-dismiss a img {
  display: inline-block;
  vertical-align: middle;
  line-height: 44px;
}

.modal_image {
  display: block;
  vertical-align: top;
  width: 100%;
  padding-bottom: 24px;
  box-sizing: border-box;
}

.modal_content {
  display: block;
  vertical-align: middle;
  width: 100%;
}

.modal_meta {
	margin-bottom: .2em;
	font-size: 1.13rem;
	font-weight: bold;
}
.modal_meta .lang_en_serif {
	margin-left: .5em;
	font-size: 0.7rem;
	color: #ccaf08;
	font-weight: normal;
}

.modal_heading {
  margin-bottom: 6px;
  font-weight: bold;
  font-size: 1.3rem;
}
.modal_heading .small {
	font-size: .8rem;
	vertical-align: middle;
}

.modal_heading-en {
  margin-bottom: 10px;
  font-size: 0.7rem;
  color: #ccaf08;
}

.modal_caetgory {
  margin-bottom: 10px;
  font-weight: bold;
  font-size: 13px;
}

.modal_text {
  font-size: 0.9rem;
  line-height: 1.8;
}


@media screen and (min-width: 787px) {
  .modal-staff_inner {
    padding: 20px;
  }
  .modal-dismiss {
    top: 20px;
    right: 20px;
  }
  .modal_image {
    padding-right: 20px;
  }

  .modal_heading {
    margin-bottom: 10px;
    font-size: 28px;
  }
  .modal_heading-en {
    margin-bottom: 15px;
    font-size: 12px;
  }
  .modal_text {
    font-size: 14px;
    line-height: 1.6;
  }
}

@media screen and (min-width: 1200px) {
  .modal-staff_inner {
    padding: 0;
  }

  .modal-dismiss {
  	width: 20px;
    top: 34px;
    right: 34px;
  }

  .modal_image {
    display: table-cell;
    vertical-align: top;
    box-sizing: border-box;
    width: 500px;
    padding-bottom: 0;
    padding-right: 0;
    vertical-align: middle;
  }
  .modal_image img {
    width: 500px;
    height: 680px;
  }
  .modal-orchestra .modal_image img {
  	width: 540px;
		height: 360px;
  }

  .modal_content {
    display: table-cell;
    vertical-align: middle;
    width: auto;
    padding-left: 95px;
    padding-right: 90px;
  }
  .modal-orchestra .modal_content {
  	padding: 0 4%;
  }

  .modal_heading {
    margin-bottom: 0;
    font-size: 2.125rem;
  }
  .modal_heading .small {
  	display: inline-block;
  	vertical-align: middle;
  	margin-right: .5em;
    font-size: 1.25rem;
  }

  .modal_heading-en {
    margin-bottom: 2em;
		color: #ccaf08;
		font-size: .75rem;
		font-weight: 400;
  }
  .modal_text {
  	line-height: 1.8;
    font-size: .9rem;
  }
}