@charset "UTF-8";
/* pc <--> sp
-------------------------------------- */
#mediaQuery { display: none; font-family: 'sp'; }

@media all and (min-width: 768px) { #mediaQuery { font-family: 'pc'; } }

@media all and (max-width: 767px) { .viewPc { display: none !important; } }

@media all and (min-width: 768px) { .viewSp { display: none !important; } }

/* clearfix
-------------------------------------- */
.cf:after { content: ''; display: block; clear: both; }

/*  module
================================================ */
.mod_color_pink { color: #f53c7f; }

.mod_btn01 { margin: auto; max-width: 240px; text-align: center; font-size: 14px; }

.mod_btn01 a { display: block; padding: 12px; text-decoration: none; background: #6f6f6f; color: #fff; border: 1px solid #fff; font-weight: 700; border-radius: 45px; }

@media all and (min-width: 768px) { .mod_btn01 { max-width: 400px; font-size: 18px; }
  .mod_btn01 a { padding: 16px; border-radius: 60px; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  .mod_btn01 a:hover { background: #a2a2a2; } }

/*  #container
================================================ */
#container { font-size: 12px; line-height: 1.5; font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; font-weight: 500; /*overflow: hidden;*/ }

#container img { width: 100%; max-width: 100%; height: auto; }

#container .alpha { display: block; text-decoration: none; }

@media all and (min-width: 768px) { #container { font-size: 14px; }
  #container img { width: auto; }
  #container .alpha { -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #container .alpha:hover { opacity: .7; } }

/* #mainVisual
================================================ */
#mainVisual { position: relative;text-align: center;background: url(../img/bg_pattern01.png) center; }

#mainVisual img { max-width: 100%;margin:0 auto; }

/*  #lNavi
================================================ */
#lNavi { padding: 24px 0 28px; background: url("../img/bg_pattern01.png") repeat center/auto; }

#lNavi .list { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -ms-flex-wrap: wrap; flex-wrap: wrap; }

#lNavi .item { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; height: 86px; border-right: 1px solid #222443; color: #fff; }

#lNavi .item:last-child { border-right: 0; }

#lNavi .item img { height: 63px; width: auto; }

@media all and (max-width: 350px) { #lNavi .list .item img { height: 54px; } }

@media all and (min-width: 768px) { #lNavi { padding: 47px 0 52px; }
  #lNavi .list { max-width: 860px; margin: auto; }
  #lNavi .item { height: 100px; border: none; }
  #lNavi .item img { height: 42px; } }

@media all and (min-width: 1000px) { #lNavi .item img { height: 54px; } }

/* #mainContents
================================================ */
#mainContents { background: url("../img/bg_gallery02_sp.png") repeat center/cover; }

@media all and (min-width: 768px) { #mainContents { background-image: url("../img/bg_gallery02_pc.png"); } }

/*  #back
================================================ */
#back { padding-top: 12px; text-align: right; font-size: 14px; }

#back .inner { display: block; padding: 0 15px; }

#back a { font-weight: 700; color: #fff; /*text-decoration: underline; */}
#back {
	position: sticky;
	top: 0;
	z-index: 2;
}
#back a {
	padding: 0.5rem 1.5rem;
	border: 1px solid #999;
	background: #38373d;
}
@media all and (min-width: 768px) { #back { padding-top: 18px; font-size: 16px; letter-spacing: .075em; }
  #back .inner { /*max-width: 1060px;*/ margin: auto; padding: 0 30px; }
  #back a { text-decoration: none; }
  #back a:hover { text-decoration: underline; } }

/*  #gallery
================================================ */
#gallery .galleryInner { padding: 84px 16px 0; }

#gallery .leadTit { position: relative; padding-bottom: 62px; text-align: center; }

#gallery .leadTit img { display: block; width: auto; margin: 0 auto; }

#gallery .leadTit .en { height: 16px; }

#gallery .leadTit .ja { margin-top: 22px; height: 14px; }

#gallery .listGallery { margin: 60px 20px 0; }

#gallery .listGallery .item + .item { margin-top: 54px; }

@media all and (min-width: 768px) { #gallery .galleryInner { max-width: 1000px; margin: auto; padding: 80px 80px 0; }
  #gallery .leadTit { padding-bottom: 110px; }
  #gallery .leadTit .en { height: 24px; }
  #gallery .leadTit .ja { margin-top: 48px; height: 22px; }
  #gallery .listGallery { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 60px -30px 0; }
  #gallery .listGallery .item { width: calc(50% - 60px); margin: 0 30px; }
  #gallery .listGallery .item + .item { margin-top: 0; }
  #gallery .listGallery .item + .item + .item { margin-top: 60px; } }

@media all and (min-width: 1000px) { #gallery .listGallery { margin: 60px -60px 0; }
  #gallery .listGallery .item { width: calc(50% - 120px); margin: 0 60px; }
  #gallery .listGallery .item + .item + .item { margin-top: 82px; } }

/*  #check
================================================ */
#check .checkInner { padding: 76px 17px 100px; }

#check .tit { position: relative; margin-bottom: 15px; z-index: 1; }

#check .listCheck { padding: 0 20px; }

#check .listCheck .item { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; padding: 19px 0 20px; border-bottom: 1px dotted #dddbdb; }

#check .listCheck .img { width: 75px; padding-right: 15px; }

#check .listCheck .areaTxt { width: calc(100% - 75px); line-height: 1.42; }

#check .listCheck .titTxt { font-size: 14px; }

#check .listCheck .titTxt a { color: #f53c7f; text-decoration: underline; }

#check .listCheck .txt { margin-top: 8px; color: #fff; }

@media all and (min-width: 768px) { #check .checkInner { max-width: 630px; margin: auto; padding: 170px 15px 100px; }
  #check .tit { margin-bottom: 0; }
  #check .listCheck { padding: 53px 30px 0; border-radius: 5px; }
  #check .listCheck .item { padding: 25px 0 29px; }
  #check .listCheck .img { width: auto; -ms-flex-preferred-size: 1; flex-basis: 1; padding: 4px 0 0 0; }
  #check .listCheck .areaTxt { width: calc(100% - 156px); line-height: 1.73; }
  #check .listCheck .titTxt { font-size: 15px; line-height: 2; }
  #check .listCheck .titTxt a:hover { text-decoration: none; }
  #check .listCheck .txt { font-size: 14px; margin-top: 0; } }

#voice + #check .checkInner { padding: 0 17px 100px; }

/*  #seat
================================================ */
#seat .inner { padding: 95px 16px 95px; }

#seat .leadTit { position: relative; padding-bottom: 90px; text-align: center; }

#seat .leadTit img { display: block; width: auto; margin: 0 auto; }

#seat .leadTit .en { height: 21px; }

#seat .leadTit .ja { margin-top: 16px; height: 14px; }

#seat .list { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 -8px 0; }

#seat .list .item { width: calc(50% - 16px); margin: 0 8px; border-radius: 2px; }

#seat .list .item:nth-child(n+3) { margin-top: 16px; }

#seat .list .img { position: relative; padding-bottom: 10px; }

#seat .list .areaTxt { padding: 13px 11px 16px; line-height: 1.73; border-top: 1px solid #8e8e91; color: #fff; }

#seat .list .tit { font-size: 13px; font-weight: 700; }

#seat .list .txt { font-size: 12px; line-height: 1.4; }

.movieWrap{
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.movieWrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

@media all and (min-width: 768px) { #seat .inner { max-width: 1030px; margin: auto; padding: 127px 15px 127px; }
  #seat .leadTit { padding-bottom: 22px; }
  #seat .leadTit .en { height: 31px; }
  #seat .leadTit .ja { margin-top: 41px; height: 22px; }
  #seat .list { margin: 75px -25px 0; }
  #seat .list .item { width: calc(33.333% - 50px); margin: 0 25px; }
  #seat .list .item:nth-child(n+3) { margin-top: 0; }
  #seat .list .item:nth-child(n+3) + .item { margin-top: 15px; }
  #seat .list .img { padding-bottom: 20px; }
  #seat .list .areaTxt { padding: 11px 34px 40px; }
  #seat .list .tit { font-size: 18px; }
  #seat .list .txt { font-size: 14px; line-height: 1.7; }
 }

/*  #voice
================================================ */
#voice .inner { padding: 76px 0 84px; }

#voice .leadTit { position: relative; padding-bottom: 76px; text-align: center; }

#voice .leadTit img { display: block; width: auto; margin: 0 auto; }

#voice .leadTit .en { height: 17px; }

#voice .leadTit .ja { margin-top: 22px; height: 14px; }

#voice .list { padding: 0 18px 28px 28px; background-size: 8px; }

#voice .list .item { position: relative; background: #fff; border-radius: 18px; }

#voice .list .item:after { position: absolute; bottom: 1px; right: 50px; content: ""; display: block; -webkit-transform: translateY(100%); -ms-transform: translateY(100%); transform: translateY(100%); border-style: solid; border-width: 13px 10px 0; border-color: #fff transparent transparent; filter: drop-shadow(-5px 5px 3px #040404); }

#voice .list .item:before { position: absolute; top: 0; bottom: 3px; left: 0; right: 0; content: ""; display: block; background: #fff; border-radius: 18px; filter: drop-shadow(-5px 5px 3px #040404); }

#voice .list .item + .item { margin-top: 35px; }

#voice .list .content { position: relative; z-index: 1; padding: 8px 18px 32px; background: #fff; margin-left: -10px; border-radius: 18px; }

#voice .list .age { position: relative; padding: 10px 0 0 36px; font-size: 14px; font-weight: 700; }

#voice .list .age:before { position: absolute; top: 0; left: -4px; content: ""; display: block; width: 28px; height: 24px; background: url("../img/ico_voice01.png") no-repeat center/contain; }

#voice .list .txt { margin-top: 1px; line-height: 28px; background: url("../img/bg_voice01_sp.png"); background-size: auto 28px; background-position: top -1px left 50%; }

#voice .list strong { font-weight: 700; }

#voice .voiceBtn { margin-top: 28px; }

@media all and (min-width: 768px) { #voice .inner { max-width: 1100px; margin: auto; padding: 107px 30px 85px; }
  #voice .leadTit { padding-bottom: 91px; }
  #voice .leadTit .en { height: 26px; }
  #voice .leadTit .ja { margin-top: 50px; height: 23px; }
  #voice .listWrap { display: -webkit-box; display: -ms-flexbox; display: flex; margin: 0 -20px; }
  #voice .listWrap .list { width: calc(50% - 40px); margin: 0 20px; }
  #voice .list { position: relative; margin: 0 -20px 0; padding: 0; background: transparent; }
  #voice .list:after { content: ""; display: block; clear: both; }
  #voice .list .item { z-index: 1; width: 100%; margin: 0 0 42px; border-radius: 30px; }
  #voice .list .item + .item { margin-top: 0; }
  #voice .list .item:after { right: 70px; border-width: 20px 14px 0; }
  #voice .list .item:before { position: absolute; top: 0; bottom: 3px; left: 0; right: 0; content: ""; display: block; background: #fff; border-radius: 30px; filter: drop-shadow(-5px 5px 3px #040404); }
  #voice .list .item + .item { margin-top: 0; }
  #voice .list .item + .item + .item { margin-top: 42px; }
  #voice .list .content { padding: 15px 40px 42px; margin-left: 0; border-radius: 30px; }
  #voice .list .age { padding: 12px 0 0 48px; font-size: 18px; }
  #voice .list .age:before { left: -18px; width: 40px; height: 36px; }
  #voice .list .txt { margin-top: 5px; line-height: 36px; background: url("../img/bg_voice01_pc.png"); background-size: auto 36px; background-position: top -1px left 50%; }
  #voice .voiceBtn { margin-top: 28px; } }

@media all and (max-width: 350px) { #voice .leadTit .en { height: 15px; }
  #voice .leadTit .ja { height: 12px; } }

/*  #reservation
================================================ */
#reservation { background: url(../img/bg_pattern01.png); }

#reservation .inner { padding: 46px 0 120px; }

#reservation .leadTit { position: relative; padding-bottom: 35px; text-align: center; }

#reservation .leadTit img { display: block; width: auto; margin: 0 auto; }

#reservation .leadTit .en { height: 16px; }

#reservation .leadTit .ja { margin-top: 22px; height: 14px; }

#reservation .content { padding: 0 18px; }

@media all and (min-width: 768px) { #reservation .inner { max-width: 1030px; margin: auto; padding: 86px 15px 135px; }
  #reservation .leadTit { padding-bottom: 90px; }
  #reservation .leadTit .en { height: 24px; }
  #reservation .leadTit .ja { margin-top: 47px; height: 23px; }}

@media all and (max-width: 350px) { #reservation .leadTit .en { height: 15px; }
  #reservation .leadTit .ja { height: 12px; } }



.wrap-news{
  margin-left: auto;
  margin-right: auto;
  width:100%;
  max-width: 1000px;
  padding:0 80px;
  margin-top: 82px;
}
#seat > .wrap-news{
	margin-top:-60px;
	margin-bottom: 60px;
}
.wrap-news-inner{
  padding:48px 24px 24px;
  background:#fff;
  border-radius: 2px;
}
.wrap-news .movieWrap{
  margin-bottom: 0;
}
.title-news{
  font-family: 'Cinzel', serif;
  font-size: 20px;
  font-weight: 600;
  color: #47464d;
}
.wrap-header .title-news{
  margin-bottom: 24px;
  text-align: center;
  font-family: 'Cinzel', serif;
  font-size: 30px;
  font-weight: 600;
  color: #47464d;
}
.wrap-header .title-news span{
  letter-spacing: 1em;
}
.wrap-header{
  margin-bottom: 80px;
  text-align: center;
  color: #47464d;
}
.wrap-header p{
  font-size: 20px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  letter-spacing: 0.5em;
}
.text-news{
  font-size: 16px;
}
@media all and (max-width: 768px) {
.wrap-news{
  padding:0 36px;
}
.wrap-news-inner{
  padding:32px 16px 16px;
}
.wrap-header{
  margin-bottom: 36px;
}
.wrap-header p{
  font-size: 16px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  letter-spacing: 0.5em;
}
.title-news{
  font-size: 18px;
}
.wrap-header .title-news{
  margin-bottom: 12px;
  font-size: 20px;
}
.text-news{
  font-size: 14px;
}
}



.wrap-taisaku{
  text-align: center;
  padding: 18px 0;
  background: #feebf2;
}
.wrap-taisaku-next{
  text-align: center;
  padding: 18px 0;
}
.btn-taisaku{
  display: block;
  padding: 10px 18px 11px;
  background: #fff;
  color: #333;
  border-radius: 4px;
  text-decoration: none;
  line-height: 1.4;
  position: relative;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  box-shadow: 1px 1px 4px 1px rgb(0 0 0 / 15%);
}
.btn-taisaku:after{
  content: "\f24d";
  font-family: "Font Awesome 5 Free";
  font-weight: normal;
  margin-left: 12px;
  color: #f53c7f;
}
.btn-taisaku:hover{
  text-decoration: none;
  opacity: 0.7;
}
.wrap-taisaku-next .btn-taisaku{
  display: block;
  padding: 9px 10px 11px;
  font-weight: normal;
  font-size: 16px;
  color: #f53c7f;
  background:none;
  text-decoration: underline;
}
.wrap-taisaku-next .btn-taisaku:after{
  content: "\f24d";
  font-family: "Font Awesome 5 Free";
  font-weight: normal;
  margin-left: 12px;
}
.wrap-taisaku-next .btn-taisaku:hover{
  text-decoration: none;
}
.wrap-taisaku-next .btn-rosen{
  display: block;
  padding: 9px 10px 11px;
  background: #f53c7f;
  color: #fff;
  border-radius: 4px;
  text-decoration: none;
  line-height: 1.4;
  position: relative;
  font-size: 16px;
  font-weight: bold;
}
.wrap-taisaku-next .btn-rosen:after{
  content: "\f107";
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  margin-left: 12px;
}
@media all and (max-width: 768px) {
.wrap-taisaku{
  padding: 12px 0;
}
.btn-taisaku{
  display: block;
  line-height: 1.4;
  font-size: 13px;
}
.wrap-taisaku-next .btn-taisaku{
  font-size: 13px;
}
.wrap-taisaku-next .btn-taisaku{
  background:none;
  text-decoration: underline;
  color: #333;
}
.wrap-taisaku-next .btn-rosen{
  margin-bottom: 12px;
}
}


.wrap-taisakulist{
  text-align: center;
  padding: 18px 0;
  background: #feebf2;
}
#taisaku .wrap-taisakulist{
  text-align: left;
  padding: 18px 18px;
}
.list-taisaku{
  margin-bottom: 12px;
}
.list-taisaku li{
  position: relative;
  padding-left: 20px;
  font-size: 16px;
}
.list-taisaku li:before{
  content: "\f14a";
  font-family: "Font Awesome 5 Free";
  font-weight: normal;
  position: absolute;
  top: 2px;
  left: 0;
  font-size: 80%;
}
.list-taisaku li + li{
  margin-top: 6px;
}



.wrap-salenews{
  text-align: center;
  padding: 10px 0;
  background: #fffde5;
}
.news-title{
  text-align: center;
  font-size: 18px;
  margin-bottom: 36px;
  position: relative;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 10px;
  font-weight: 900;
}
.news-title span{
    padding: 0 40px;
}
.news-title span b{
    color: #be222e;
    font-size: 24px;
}
.news-title:before,
.news-title:after{
    content: "";
    display: inline-block;
    width: 2px;
    height: 36px;
    background: #be222e;
    border-radius: 2px;
}
.news-title:before{
    -webkit-transform: rotate(-30deg);
    -ms-transform: rotate(-30deg);
    transform: rotate(-30deg);
}
.news-title:after{
    -webkit-transform: rotate(30deg);
    -ms-transform: rotate(30deg);
    transform: rotate(30deg);
}
.wrap-salenews .news-title{
  font-size: 14px;
  margin-bottom: 0px;
}
.wrap-salenews .news-title span b{
    font-size: 16px;
}
@media all and (max-width: 768px) {
.news-title{
  font-size: 14px;
  margin-bottom: 36px;
}
.news-title span{
    padding: 0 20px;
}
.news-title span b{
    font-size: 18px;
}
}

/*  .acc-box
================================================ */
.acc-box{
	max-width: 1030px;
	margin: 0 auto;
}
.acc-box .card{
	border: none;
	position: relative;
	min-width: 0;
	word-wrap: break-word;
	background-color: #fff;
	background-clip: border-box;
	box-shadow: 1px 1px 4px 1px rgb(0 0 0 / 15%);
	border-radius: 4px;
	overflow: hidden;
}
.acc-box .card-header{
	padding:0;
	border:none;
	padding: 0;
	margin-bottom: 0;
}
.acc-box .card-header a,
.acc-box .card-header button{
	display:block;
	padding:12px 24px 12px 24px;
	position: relative;
	color:#333;
	background:#fff;
	font-size: 16px;
	width: 100%;
	text-align: left;
	cursor: pointer;
	font-weight: bold;
}
.acc-box .card-header a:hover,
.acc-box .card-header button:hover{
	cursor:pointer;
	background:#FFF;
	opacity:1.0;
	text-decoration:none;
}
.acc-box .card-header a:after,
.acc-box .card-header button:after{
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 20px;
	content: "\f077";
	font-family: "Font Awesome 5 Free";
	font-weight:900;
	color:#f53c7f;
	font-size: 12px;
}
.acc-box .card-header a.collapsed:after,
.acc-box .card-header button.collapsed:after{
	content: "\f078";
}
.acc-box .card-header a,
.acc-box .card-header button{
	border-bottom: dotted 1px #ccc;
	text-align: center;
}
.acc-box .card-header a.collapsed,
.acc-box .card-header button.collapsed{
	border-bottom: none;
}
.acc-box .card-body{
	padding:15px;
}
.acc-box .card-body p{
	font-size:14px;
	line-height:1.6;
	margin-left:5px;
	margin:0;
}
.acc-box .card-body p + p{
	margin-top:1em;
}

@media(max-width:767px) {
	.acc-box .card-header a{
		display:block;
		padding:12px 24px 12px 12px;
	}
	.acc-box .card-header a:after{
		font-size:14px;
		right:10px;
	}
	.acc-box .card-body p{
		padding:0px;
		line-height:1.8;
		margin-left:0;
	}

}


/*レビュー設置用スタイル*/
.review-box{
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 1px 1px 4px 1px rgba(0,0,0,0.2);
}
.review-box .reviewWidget_title_container{
  display: none;
}
.review-box .reviewWidget_title{
  margin-top: 0;
  padding-top: 0;
  font-size: 16px;
}
.review-box .review-widget-summary-container .starRating span:last-child{
  margin-right: 0;
}
.review-box .review-widget-summary-container .starRating{
  display: flex;
  align-items: center;
  justify-content: center;
}
.review-box .review-container{
  margin-bottom: 0;
}
.review-box .reviewWidget_inner{
  padding: 0;
}
