@charset "UTF-8";
/* 調整用スタイル */

/* main.wrap::before {
  content: "";
  display: block;
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: -1;
  width: 100%;
  height: 100vh;
  background: url("../common/back_all.jpg") center center repeat;
} */

main {
	background: url("../common/back_all0.jpg") center top repeat;
}

@media screen and (max-width: 960px) {
  main {
    background: url("../common/back_all_sp0.jpg") center top repeat;
  }
}

.pctop_mar { margin-top: 80px; }
.sptop_mar { margin-top: 50px; }

.top_mar { margin-top: 80px; }
@media screen and (max-width: 960px) {
	.top_mar { margin-top: 50px; }
}


section {
	margin: auto;
  padding: 70px 7% 90px;
}
section.bg_color {
	border-top: 1px #4D3A1E solid;
	background-image: linear-gradient(to bottom, rgba(0,0,0,0.50) 50%, rgba(65,26,14,0.25) 100%);
}
section.bg_color2 {
	border-top: 1px #434648 solid;
	background-image: linear-gradient(to bottom, rgba(0,0,0,0.00) 50%, rgba(0,0,0,0.30) 100%);
}

@media screen and (max-width: 960px) {
	
  /* main.wrap::before {
    background-image: url("../common/back1sp.jpg");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
  } */
	section {
		padding: 40px 7% 50px;
	}
}

#main_vis_back { position: relative; width: 100%; height: 880px; margin: 0 auto; padding-top: 0px; background: url("../top_img/main1.png") 50% 80px no-repeat;
	background-color: rgba(0,0,0,0.30); }

.top_waku {
  width : 980px;
  height : 800px;
  position : relative;
}
.logo1 {
  background-image : url("../top_img/title_logo1.png");
  background-position : center center;
  width: 940px;
  height: 501px;
  top: 180px;
  left: 20px;
  position: absolute;
  background-repeat: no-repeat;

}

/* イントロのみ */
#intro_main1 {
 height: 0;
 padding-top: 43.72%;
/* 表示画像の高さ ÷ 表示画像の幅 × 100 */
 background: url(../introduction_img/intro_vis_pc1.jpg) 50% 0 / contain no-repeat scroll padding-box border-box transparent;
}
 
.catch_copy_size {
	margin: 0 auto;
  width: 100%; max-width: 897px;
	padding-bottom: 0px;
}
.gensaku_size {
	margin: 4rem auto;
  width: 100%; max-width: 500px;
	padding-bottom: 0px;
}
@media screen and (max-width: 960px) {
  .catch_copy_size {
    margin: 0 auto;
    width: 100%;
		padding-top: 10px;
		padding-bottom: 0px;
  }
  .gensaku_size {
    margin: 2rem auto;
    width: 95%;
		padding-bottom: 0px;
  }
}

/* タイトル */
.title {
	color: #FFFFFF;
  font-weight: 600;
  font-style: normal;
	text-align: center;
  font-size: 4.0rem;
	letter-spacing: 0.05rem;
  line-height: 1;
  margin: 10px 0 10px 0;
	text-shadow: 0px 0px 0px #FFFFFF;
}

@media screen and (max-width: 960px) {
  .title {
    font-size: 2.8rem;
    margin: 10px 0 10px 0;
  }
}
.title2 {
	color: #F25C00;
	font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-style: normal;
	text-align: center;
  font-size: 4.0rem;
	letter-spacing: 0.2rem;
  line-height: 1;
  margin: 10px 0 10px 0;
	text-shadow: 0px 0px 0px #FFFFFF;
}

@media screen and (max-width: 960px) {
  .title2 {
    font-size: 3.0rem;
    margin: 10px 0 10px 0;
  }
}
/* STORYタイトル */
.story_title {
	color: #fff;
	font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
	letter-spacing: 0.0rem;
  line-height: 1.4;
  margin: 0px 0 10px 0;
}

@media screen and (max-width: 960px) {
  .story_title {
    font-size: 2.0rem;
    margin: 6px 0 6px 0;
  }
}
.midashi_title1 {
	font-size: 3.2rem; font-weight: bold;
	text-shadow: 3px 3px 3px rgba(255,251,230,1.00);
  padding: 18px 5.2rem 5px;
}
.midashi_back {
	height: 110px;
	position: relative;
	left: -2rem;
	background: url("../common/midashi_back1.png") left top no-repeat;
	background-size: contain;
}

@media screen and (max-width: 960px) {
  /* タイトル */
  .midashi_title1 {
    font-size: 2.2rem;
		padding: 1.5rem 0 0 3rem;
  }
  .midashi_back {
    height: 70px;
    position: relative;
    left: -1.3rem;
    background: url("../common/midashi_back1.png") left top no-repeat;
    background-size: contain;
  }
}

/* テキストエリア */
.text__area {
	margin: 0 auto;
	width: 100%; max-width: 900px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
}

.text__area_cast {
	margin: 0 auto;
	width: 100%; max-width: 900px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
  display: flex;
  justify-content: flex-end;
}

@media screen and (max-width: 960px) {
  .text__area {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
  }

  .text__area_cast {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
  }
}

/* タイトル */
.sub_title1 {
  font-size: 2.4rem; font-weight: bold;
	color: #F25C00;
	padding: 0.5rem 0 1rem 2.6rem;
	margin-top: 50px;
	margin-bottom: 25px;
  letter-spacing: 0px;
	border-left: 6px #7F4D3F solid;
	border-bottom: 1px #7F4D3F solid;
}
.sub_title3 {
  font-size: 2.2rem;
	padding: 0px 0px 0px 0px;
	font-weight: bold; color: #000000;
	font-family: 'Hiragino Mincho ProN、ヒラギノ明朝 ProN', serif;
  letter-spacing: 0px;
  background: -webkit-linear-gradient(top, #E6CAB9 20%, #E8B493 95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 960px) {
  .sub_title1 {
    font-size: 1.9rem;
		padding: 0.5rem 0 1rem 2.0rem;
		margin-bottom: 18px;
  }
  .sub_title3 {
    font-size: 1.8rem;
		padding: 0px 0px 0px 0px;
  }
}

/* movie */
.movie-wrap {
	position: relative;
	padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
	background: rgba(0,28,38,1.00);
	border: 1px solid #7F4D3F;
}
 
.movie-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.mov_name1 {
	text-align: center;
  font-size: 170%;
	padding: 0.6em 0px 0.6em 0px;
	font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0px;
  line-height: 1.4;
}

.mov_text_right {
	text-align: right; width: 100%; margin: 0 auto; margin: 0.5rem 0 2rem 0; }

.mov_table1 {
	width: 100%; margin: 0 auto;
	padding: 0px 0px 0px 0px; }

.td_mov { width: 48%; border: 1px #A4965C solid; padding: 9px;
	background-color: rgba(0,0,0,0.50); }
.td_mov_sp { width: 4%; }
.mov_text {
	text-align: center;
	padding: 8px; }
.linkup a{ display: block; }

.td_photo { width: 48%; }

/* ## Rollover set ## */
a:hover.movie_lo { 
    opacity: 0.8; 
    filter: alpha(opacity=80); 
    -moz-opacity: 0.8; }

/*sp*/
@media screen and (max-width: 700px) {
	
  .mov_name1 {
    font-size: 1.7rem;
  }
	.td_mov { width: 48.5%; padding: 5px; }
	.td_mov_sp { width: 3%; }
	.mov_text {
		text-align: center;
		padding: 6px; }
	.td_photo { width: 48.5%; }
}


/* 2カラムから1カラム */
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}
table th.left {
  width: 30%;
  background-color: rgba(38,6,27,0.00);
  border: 0px solid #d8a563;
  box-sizing: border-box;
  padding: 0px;
  vertical-align: middle;
  font-weight: bold;
  text-align: center;
}
table td.right {
  background-color: rgba(38,6,27,0.0);
  border: 0px solid #ccc;
  box-sizing: border-box;
  vertical-align: top;
  text-align: left;
}
.right_text1 {
  padding: 0px 0px 0px 20px;
}
@media all and (max-width: 960px) {
  table th.left, table td.right {
    display: block;
    width: 100%;
    border-bottom: none;
  }
  .right_text1 {
    padding: 1em 0px 0px 0px;
  }
}

/* イントロ */
.intro_copy1 {
	font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-style: normal;
	text-align: center;
  font-size: 4.0rem;
	letter-spacing: 0.1rem;
  line-height: 1.8;
}

@media screen and (max-width: 960px) {
  .intro_copy1 {
    font-size: 2.4rem;
    letter-spacing: -0.02em;
    line-height: 1.65;
  }
}
.intro_box1 {
	margin: 0 auto;
	width: 100%; max-width: 900px;	
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
	margin-bottom: 0px;
	padding: 30px 0px 35px 0px;
	background-color: rgba(30,33,38,0.20);
	opacity: 1.0;
	border: 1px #434648 solid;
  border-radius: 1.3rem;
}
.box2 {
	width: 100%; max-width: 850px;
	margin: 0 auto;
	margin-bottom: 40px;
	padding: 30px 0px 35px 0px;
	background-image: linear-gradient(to bottom, rgba(255,255,255,0.15) 50%, rgba(182,177,83,0.20) 100%);
	opacity: 1.0;
	border: 1px #CAB870 solid;
  border-radius: 1.2rem;
}
.box_kado {
	width: 100%; max-width: 850px;
	margin: 0 auto;
	margin-bottom: 40px;
	padding: 30px 0px 35px 0px;
  background:
		linear-gradient(135deg, transparent 15px, rgba(0,0,0,0.25) 0) top left, /*重なり順番1*/
    linear-gradient(-135deg, transparent 15px, rgba(0,0,0,0.25) 0) top right, /*重なり順番2*/
		linear-gradient(-45deg, transparent 15px, rgba(0,0,0,0.25) 0) bottom right, /*重なり順番3*/
    linear-gradient(45deg, transparent 15px, rgba(0,0,0,0.25) 0) bottom left; /*重なり順番4*/
	background-size: 50% 50%;
  background-repeat: no-repeat;
}
.box_text1 {
	text-align: left; width: 91%; max-width: 900px; margin: 0 auto;
}

@media screen and (max-width: 960px) {
  .intro_box1 {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.7;
		margin-bottom: 0px;
    padding: 2.0rem 0px;
  }
	.box2 {
    width: 100%;
    margin: 0 auto;
    margin-top: 0px;
    padding: 20px 0px 20px 0px;
  }
	.box_text1 {
    text-align: left; width: 88%; margin: 0 auto; }
}

/* news */
.info_box {
	border: solid 0px;
	width: 100%; max-width: 980px; height: 380px; overflow: auto;
	margin: 0 auto;
  margin-top: 0px;
	margin-bottom: 50px;
}
.divdate {
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
	text-align: center;
	width: 155px;
	padding: 3px 12px 3px 12px;
  margin-top: 30px;
	font-size: 16px;
  color: #FDF6F7;
  background-color: rgba(164,44,7,0.75);
  background-position : center center;
}

.divinfo {
	text-align: left;
	padding: 15px 10px 20px 15px;
  margin-left: 0px;
  overflow: visible;
	border-bottom: 1px #4D3A1E solid;
  color: #FDF6F7;
}
.divinfo {
  position: relative;
}
.divinfo a{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent:-999px;
}
.divinfo:hover{
  color: #bfbfbf;
  background-color: rgba(0,0,0,0.20);
}

@media screen and (max-width: 960px) {
  /* news */
  .info_box {
    width: 100%; height: 380px; overflow: auto;
		margin-bottom: 30px;
  }
  .divdate {
    width: 120px;
    padding: 1px 3px 1px 3px;
    margin-top: 20px;
		font-size: 14px;
  }
  .divinfo {
    padding: 12px 10px 16px 10px;
  }
}

/* チケットbox */
.tic_box1 {
	margin: 0 auto;
	width: 100%; max-width: 900px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
	margin-bottom: 30px;
	padding: 30px 0px 35px 0px;
	background-color: rgba(8,74,97,0.45);
	opacity: 1.0;
	border: 1px #589BB2 solid;
  border-radius: 1.3rem;
}

@media screen and (max-width: 960px) {
  /* news */
  .tic_box1 {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.7;
		margin-bottom: 20px;
    padding: 1.8rem 0px;
  }
}

/* キャスト */
.comment_box1 {
	margin: 0 auto;
	width: 100%; max-width: 800px;
  font-size: 1.55rem;
  line-height: 1.8;
	margin-bottom: 25px;
	padding: 25px 0px 28px 0px;
	background-color: rgba(30,33,38,0.30);
	opacity: 1.0;
	border: 1px #B89C88 solid;
  border-radius: 1.3rem;
}

@media screen and (max-width: 960px) {
  /* news */
  .comment_box1 {
    width: 100%;
    font-size: 1.4rem;
    line-height: 1.6;
		margin-bottom: 10px;
    padding: 1.7rem 0px;
  }
}

/* キャストエリア */
.cast__area {
	margin: 0 auto;
	width: 100%; max-width: 1000px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
}

@media screen and (max-width: 960px) {
  .cast__area {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
  }
}

/* グッズカラム　2カラムから1カラム */
.goods_box {
	width: 100%; max-width: 980px;
  margin: 0 auto;
	padding-bottom: 0px;
  display: flex;
  flex-wrap: wrap;
}
.goods--l {
  width: 300px;
}
.goods--r {
  width: calc(100% - 300px);
  padding: 0 0 0 0px;
}

.goods_img { text-align: left; width: 300px; }

.goods_text1 {
  text-align: left; width: 100%; margin-top: 0rem; padding-left: 30px; }
.goods_text2 {
  text-align: left; width: 100%; }

@media screen and (max-width: 960px) {
  .goods_box {
    width: 100%;
  }
  .goods--l,
  .goods_img {
    width: 85%;
		text-align: center;
    margin: 0 auto;
  }
  .goods--r {
    width: 100%;
    margin: 0 auto;
  }
  .goods_text1 {
    text-align: left; width: 100%; margin-top: 1.3rem; padding-left: 0px; }
  .goods_text2 {
    text-align: left; width: 100%; margin-top: 1.3rem; }
}


/* テキスト関連 */
small {
  font-size: 0.85em;
	line-height: 1.65;
}
small2 {
  font-size: 0.9em;
  line-height: 1.65;
}

.title_font1 {
	font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-style: normal;
}

.midashi_text1 { color: #D18B1C; font-weight: bold; }
.midashi_text2 { color: #F25C00; font-weight: bold; text-shadow: 0px 0px 0px rgba(255,209,0,1.00); }
.midashi_text3 { color: #fff; font-weight: bold; }
.midashi_text4 { font-weight: bold;
	background: -webkit-linear-gradient(top, #FFFFFF 20%, #A6A6A6 95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; }

.moji_spacing { letter-spacing: -2.5px; }
.moji_tume1 { letter-spacing: -1px; }
.moji_ake1 { letter-spacing: 1px; }

.text_arrow { color: #9f9f9f; font-weight: bold; }
.text_arrow2 { color: #071933; font-weight: bold; }

.text1em {
	padding-left: 1em;
  text-indent: -1em; }

.text1em_all {
	padding-left: 1rem; }

.text_yellow1 { color: #E5D6AB; font-weight: bold; }
.text_orange1 { color: #FF4700; font-weight: bold; }
.text_white1 { color: #FFFFFF; font-weight: bold; }
.text_white2 { color: #FFFFFF; }

.text_background {
	color: #ffffff;
  display: inline;
  padding: 12px 25px;
  background: linear-gradient(transparent 0%, #000000 0%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.text_background2 {
	font-family: 'Oswald', sans-serif;
	color: #ffffff;
	font-size: 4.5rem; font-weight: bold;
  display: inline;
  padding: 7px 3rem;
  background: linear-gradient(transparent 50%, #e83828 100%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.main_text_right {
	text-align: right; width: 100%; margin: 0 auto; margin: 0.5rem 0 2rem 0; }

.mincho {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
}

/* 未訪問 */
a:link { color: #C35500; text-decoration: none; }
/* 訪問済み */
a:visited { color: #C35500; text-decoration: none; }
/* カーソルが上に乗った状態 */
a:hover { color: #D12C4A; text-decoration: underline; }


/* flyer */
.flyer_box1 {
	margin: 0 auto;
	width: 100%; max-width: 770px;
	padding-bottom: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.flyer_sp { width: 30px; }
.flyer_photo { width: 370px;
	border: 1px #434648 solid; }


/* footer
------------------------------------------------------------*/
footer {
	border-top: 2px #4D3A1E solid;
	background-image: linear-gradient(to bottom, rgba(255,255,255,0.00) 50%, rgba(255,255,255,0.08) 100%); }
footer #ticket_btn {
  position: fixed;
  left: 20px;
  bottom: 20px;
  line-height: 0;
}
footer #ticket_btn img {
  width: 85%;
}
footer #footer_items {
  padding: 3.5em 7% 3.5em;
  margin: 0 auto;
  text-align: center;
  font-size: 1.4rem;
  font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  letter-spacing: 0.0rem;
}

.copyright1 { font-size: 1.5rem; color: #FDF6F7; }
.copyright2 {
	padding: 10px 0px 0px 0px;
  font-size: 1.3rem; color: #FDF6F7; }

@media screen and (max-width: 960px) {
  footer #ticket_btn {
    position: fixed;
    left: 10px;
    bottom: 10px;
  }
  footer #ticket_btn img {
		width: 55%;
  }
  footer #footer_items {
    padding: 2.5em 5% 2.2em;
  }
	
  .copyright1 { font-size: 1.2rem; }
  .copyright2 {
    padding: 7px 0px 0px 0px;
    font-size: 1.0rem; }
}


/* TOPへ戻る NEW!
------------------------------------------------------------*/
.pagetop {
  position: fixed;
	right: 17px;
  bottom: 17px;
  margin: 0;
  transition: .3s;
  opacity: 1;
  visibility: visible;
}
.pagetop a {
  position: relative;
  display: flex;
  width: 62px;
  height: 62px;
  justify-content: center;
	background-color: #232323;
  transition: opacity .6s ease;
  color: #FDF6F7;
  align-items: center;
  text-decoration: none;
  font-size: 34px;
  border-radius: 100%;
	border: 1px #773C0F solid;
}
.pagetop a:hover { opacity: 0.7; }

#snsicon {
  /* display: none; */
  position: fixed;
  right: 17px;
  bottom: 92px;
  line-height: 0;
  border-radius: 100%;
	border: 1px #773C0F solid;
}
.snssize { width: 62px; }
.fotter_logo { width: 130px; margin-bottom: 2rem; }

@media screen and (max-width: 960px) {
  .pagetop {
    right: 14px;
    bottom: 14px;
  }
	.pagetop a {
		width: 42px;
    height: 42px;
		font-size: 25px;
	}

  #snsicon {
    /* display: none; */
    position: fixed;
    right: 14px;
    bottom: 65px;
    line-height: 0;
		z-index: 2;
  }
  .snssize { width: 42px; }
  .fotter_logo { width: 90px; }
}

.img100per { width: 100%; }
.img90per { width: 90%; }
.img80per { width: 80%; }
.img70per { width: 70%; }
.img60per { width: 60%; }
.img50per { width: 50%; }
.img40per { width: 40%; }

.big00 { font-size: 1.05em; font-weight: bold; line-height: 1; }
.big0 { font-size: 1.1em; font-weight: bold; line-height: 1; }
.big1 { font-size: 1.4em; font-weight: bold; line-height: 1; }
.big2 { font-size: 1.7em; font-weight: bold; line-height: 1.1; }
.big3 { font-size: 2.0em; font-weight: bold; line-height: 1.2; }
.big4 { font-size: 2.5em; font-weight: bold; line-height: 1.3; }
.big9 { font-size: 4.6em; font-weight: bold; line-height: 1.3; }

.small1 { font-size: 90%; }
.small2 { font-size: 80%; }
.small3 { font-size: 70%; line-height: 1; }

.mar_t5 { margin-top: 5px; }
.mar_t10 { margin-top: 10px; }
.mar_t15 { margin-top: 15px; }
.mar_t20 { margin-top: 20px; }
.mar_t25 { margin-top: 25px; }
.mar_t30 { margin-top: 30px; }
.mar_t40 { margin-top: 40px; }
.mar_t45 { margin-top: 45px; }
.mar_t50 { margin-top: 50px; }
.mar_t60 { margin-top: 60px; }
.mar_t70 { margin-top: 70px; }
.mar_t80 { margin-top: 80px; }
.mar_t90 { margin-top: 90px; }
.mar_t100 { margin-top: 100px; }
.mar_t120 { margin-top: 120px; }

.mar_b70 { margin-bottom: 70px; }
.mar_b80 { margin-bottom: 80px; }
.mar_b90 { margin-bottom: 90px; }
.mar_b100 { margin-bottom: 100px; }

@media screen and (max-width: 960px) {
  .big0 { font-size: 1.05em; }
  .big1 { font-size: 1.25em; }
  .big2 { font-size: 1.5em; }
  .big3 { font-size: 1.8em; }
  .big4 { font-size: 2.2em; }
  .big9 { font-size: 3.8em; }

  .mar_t10 { margin-top: 8px; }
  .mar_t15 { margin-top: 13px; }
  .mar_t20 { margin-top: 16px; }
  .mar_t25 { margin-top: 20px; }
  .mar_t30 { margin-top: 24px; }
  .mar_t40 { margin-top: 28px; }
  .mar_t45 { margin-top: 32px; }
  .mar_t50 { margin-top: 38px; }
  .mar_t60 { margin-top: 45px; }
  .mar_t70 { margin-top: 50px; }
  .mar_t80 { margin-top: 60px; }
  .mar_t90 { margin-top: 65px; }
  .mar_t100 { margin-top: 75px; }
  .mar_t120 { margin-top: 90px; }

  .mar_b70 { margin-bottom: 50px; }
  .mar_b80 { margin-bottom: 60px; }
  .mar_b90 { margin-bottom: 65px; }
  .mar_b100 { margin-bottom: 75px; }
}