@charset "UTF-8";
/* 調整用スタイル */

main {
  background-color: rgba(0,0,0,0.00);
}
main.wrap::before {
  content: "";
  display: block;
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: -1;
  width: 100%;
  height: 100vh;
  background-image: url("../common/back1.jpg");
  background-size: cover;
	background-position: center center;
  background-repeat: no-repeat;
}

.top_mar { margin-top: 80px; }
@media screen and (max-width: 960px) {
	.top_mar { margin-top: 60px; }
}

@media screen and (max-width: 960px) {
  main {
    background: url("../common/back_all_sp0.jpg") center top repeat;
  }
}

.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_intro {
	border-top: 1px #8D8A77 solid;
	background-image: linear-gradient(to bottom, rgba(0,0,0,0.80) 50%, rgba(0,0,0,0.40) 100%);
}
section.bg_color {
	border-top: 1px #8D8A77 solid;
	background-image: linear-gradient(to bottom, rgba(0,0,0,0.80) 50%, rgba(0,0,0,0.40) 100%);
}
section.bg_color2 {
	border-top: 1px #8D8A77 solid;
	background-image: linear-gradient(to bottom, rgba(97,67,21,0.15) 50%, rgba(97,67,21,0.00) 100%);
	margin-bottom: 5rem;
}

@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 { width: 100%; margin: 0 auto; margin-top: 80px; background: url("../common/.jpg") 50% 0 no-repeat; background-image: linear-gradient(to bottom, rgba(0,0,0,0.80) 50%, rgba(0,0,0,0.60) 100%); }

/* イントロのみ */

#intro_main1 {
	margin-top: 80px;
  height: 680px;
  background-image : url("../introduction_img/sub_visPC1.jpg");
  background-position : center center;
}
 
.catch_copy_size {
	margin: 0 auto;
  width: 100%; max-width: 897px;
	padding-bottom: 0px;
}
@media screen and (max-width: 960px) {
  .catch_copy_size {
    margin: 0 auto;
    width: 100%;
		padding-top: 10px;
		padding-bottom: 0px;
  }
}

.title10 {
  /* Googleフォントの指定 (例: Roboto) */
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  font-style: normal;
	text-align: center;
  font-size: 5.0rem;

  /* 背景にグラデーションを設定 */
  background: linear-gradient(to right, #ff7e5f, #feb47b);
  
  /* 背景をテキストの形にクリップ（くり抜き）する */
  -webkit-background-clip: text;
  background-clip: text; /* 標準プロパティ */
  
  /* テキストの色を透明にする */
  -webkit-text-fill-color: transparent;
  text-fill-color: transparent; /* 標準プロパティ */

  /* 環境によってはベンダープレフィックスが必要 */
  /* SafariなどWebKit系のブラウザでは -webkit- が必須 */
}


/* タイトル */
.title_box {
	position: relative;
	text-align: center;
}
.title {
	color: #E0E89E;
	font-family: "Amiri", serif;
  font-weight: 700;
  font-style: normal;
	text-align: center;
  font-size: 4.7rem;
	letter-spacing: 0.05rem;
  line-height: 1;
  margin: 0px 0;
	padding: 0px 0;
}

@media screen and (max-width: 960px) {
  .title {
    font-size: 3.5rem;
		letter-spacing: -0.05rem;
    margin: 0px 0;
  }
}
.title2 {
	color: #E4ECD7;
  font-weight: 600;
  font-style: normal;
	text-align: center;
  font-size: 2.8rem;
	letter-spacing: 0.2rem;
  line-height: 1;
  margin: 40px 0 10px 0;
}

@media screen and (max-width: 960px) {
  .title2 {
    font-size: 2.2rem;
    margin: 10px 0 10px 0;
  }
}
/* キャッチ（テキスト） */
.catch_copy1 {
	color: #E0E89E;
  font-weight: 900;
  font-style: normal;
  font-size: 3.3rem;
	letter-spacing: 0.0rem;
  line-height: 1.4;
  margin: 0px 0 10px 0;
}

@media screen and (max-width: 960px) {
  .catch_copy1 {
    font-size: 2.3rem;
    margin: 6px 0 6px 0;
  }
}
.catch_big1 { font-size: 130%; }

/* テキストエリア */
.text__area {
	margin: 0 auto;
	width: 100%; max-width: 1100px;
  line-height: 1.8;
}

@media screen and (max-width: 960px) {
  .text__area {
    width: 100%;
    line-height: 1.8;
  }
}

/* タイトル */
.sub_title1 {
  font-size: 2.8rem; font-weight: bold;
	color: #FAF7CC;
	text-shadow: 1px 1px 2px #0B0A07;
	padding: 0.2rem 0 0.8rem 2.4rem;
	margin-top: 0px;
	margin-bottom: 25px;
  letter-spacing: 0px;
	border-left: 6px #0B0A07 solid;
	border-bottom: 1px #4E4A3E 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: 2.2rem;
		padding: 0.2rem 0 0.8rem 1.8rem;
		margin-bottom: 18px;
  }
  .sub_title3 {
    font-size: 1.8rem;
		padding: 0px 0px 0px 0px;
  }
}

/* イントロ */
.intro_copy1 {
	color: #FAF7CC;
  font-weight: 900;
  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) {
  .intro_copy1 {
    font-size: 1.7rem;
    margin: 6px 0 6px 0;
  }
}
.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_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; }
}

/* STORYタイトル */
.story_title {
	color: #FAF7CC;
  font-weight: 900;
  font-style: normal;
  font-size: 3.5rem;
	letter-spacing: 0.0rem;
  line-height: 1.4;
  margin: 0px;
}

@media screen and (max-width: 960px) {
  .story_title {
    font-size: 2.5rem;
    margin: 0px;
  }
}

.story_big1 { font-size: 1.5em; }

/* movie */
.movie-wrap {
	position: relative;
	padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
	background: rgba(0,0,0,0.40);
	border: 1px solid #a08352;
	border-image: linear-gradient(to right, #AB997A, #886D4F);
	border-image-slice: 1;
}
 
.movie-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.mov_text_right {
	text-align: right; width: 100%; margin: 0 auto; margin: 0.7rem 0 1.5rem 0; }

/* news */
.info_box {
	border: solid 0px;
	width: 100%; max-width: 1100px; height: 380px; overflow: auto;
	margin: 0 auto;
  margin-top: 0px;
	margin-bottom: 0px;
}
.divdate {
	text-align: center;
	width: 145px;
  font-family: 'Roboto Condensed', sans-serif;
	padding: 3px 12px 3px 12px;
  margin-top: 30px;
	font-size: 1.5rem;
  font-weight : bold;
  color: #000000;
	border: #FAF7CC solid;
  border-radius: 0.0rem;
  border-width : 0px 1px 1px 0px;
	background-image: linear-gradient(to bottom, rgba(250,247,204,0.70) 0%, rgba(250,247,204,0.50) 100%);
}

.divinfo {
	text-align: left;
	padding: 15px 10px 40px 15px;
  margin-left: 0px;
  overflow: visible;
	border-bottom: 1px #8D8A77 solid;
	line-height: 1.50;
	
}
.divinfo {
  position: relative;
}
.divinfo a{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent:-999px;
}
.divinfo:hover{
  color: #FFFFFF;
  background-color: rgba(0,0,0,0.35);
}

@media screen and (max-width: 960px) {
  /* news */
  .info_box {
    width: 100%; height: 380px; overflow: auto;
		margin-bottom: 0px;
  }
  .divdate {
    width: 110px;
    padding: 2px 5px 2px 5px;
    margin-top: 20px;
		font-size: 1.4rem;
  }
  .divinfo {
    padding: 12px 0px 16px 0px;
  }
}

/* テキスト関連 */
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: #e4ecd7; font-weight: bold; }
.midashi_text2 { color: #E0E89E; 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: -.2em; width: 2em; margin-right: .5em; }
.moji_tume1 { letter-spacing: -1px; }
.moji_ake1 { letter-spacing: 1px; }

@media screen and (max-width: 960px) {
	.moji_spacing { letter-spacing: -2.6em; width: 1rem; margin-right: 1.7em; }
}

.text_arrow { color: #D3CA51; font-weight: bold; }
.text_arrow2 { color: #E06937; font-weight: bold; }

.text1em {
	padding-left: 1em;
  text-indent: -1em; }

.text1em_all {
	padding-left: 1rem; }

.text_yellow1 { color: #E5D6AB; font-weight: bold; }
.text_yellow2 { color: #9C7605; 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;
}

.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: #FCC03D; text-decoration: none; }
/* 訪問済み */
a:visited { color: #FCC03D; text-decoration: none; }
/* カーソルが上に乗った状態 */
a:hover { color: #FC913E; 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: 1px #8D8A77 solid;
	background-image: linear-gradient(to bottom, rgba(0,0,0,0.60) 50%, rgba(0,0,0,0.80) 100%);
	margin-top: 0px;
}
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.55rem; color: #e4ecd7; }
.copyright2 {
	padding: 12px 0px 0px 0px;
  font-size: 1.3rem; color: #CED7BF; }

@media screen and (max-width: 960px) {
  footer {
    margin-top: 0px;
  }
  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: rgba(31,28,18,0.85);
  transition: opacity .6s ease;
  color: #FDF6F7;
  align-items: center;
  text-decoration: none;
  font-size: 34px;
  border-radius: 100%;
	border: 1px #636158 solid;
}
.pagetop a:hover { opacity: 0.7; }

.snsicon_x {
  position: fixed;
	right: 17px;
  bottom: 92px;
  margin: 0;
  transition: .3s;
  opacity: 1;
  visibility: visible;
}
.snsicon_x a {
  position: relative;
  display: flex;
  width: 62px;
  height: 62px;
  justify-content: center;
	background-color: rgba(31,28,18,0.85);
  transition: opacity .6s ease;
  align-items: center;
  border-radius: 100%;
	border: 1px #636158 solid;
}
.snsicon_x a:hover { opacity: 0.7; }

.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_x {
    right: 14px;
    bottom: 65px;
  }
	.snsicon_x a {
		width: 42px;
    height: 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.3em; font-weight: bold; line-height: 1; }
.big2 { font-size: 1.6em; 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.2em; }
  .big2 { font-size: 1.35em; }
  .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; }
}