/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc {
  display: block !important;
}
.sp {
  display: none !important;
}
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
}
/* --------------------------------------------- */
/* ▼モバイルファースト (全環境に共通のデザイン) */
/* --------------------------------------------- */
* {
  margin: 0;
  padding: 0;
}
html {
  color: #333;
  font-family: YuGothic, 'Yu Gothic', sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 62.5%; /* 16px x 0.625 = 10px(=1rem) */
  scroll-behavior: smooth;
}
body {
  font-size: 1.3rem; /* 13px */
  line-height: 1.6;
  letter-spacing: 1px;
  font-feature-settings: "palt";
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -o-text-size-adjust: 100%;
  text-size-adjust: 100%;
  position: relative;
  text-align: center;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}
div {
  position: relative;
}
fieldset, img {
  border: 0
}
ol, ul {
  list-style: none;
}
/*link*/
a {
  color: #333;
  text-decoration: none;
}
a:link {
  color: #333;
  text-decoration: none;
}
a:visited {
  color: #333;
  text-decoration: none;
}
a:hover {
  color: #C6AE67;
  text-decoration: none;
}
a:hover img {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -moz-opacity: 0.8;
  padding-top: 0px;
  transition: .3s;
}
img {
  border-style: none;
  z-index: 0;
  vertical-align: bottom;
  line-height: 1.0em;
  width: 100%;
  height: auto;
}
/*font*/
.en_font {
  font-family: "adobe-caslon-pro", serif;
  letter-spacing: 2px;
}
.en_font.bold {
  font-weight: 700;
}
.en_font_minion {
  font-family: minion-3, serif;
  font-weight: 600;
}
h2 img {
  width: auto;
  height: 40px;
  margin: auto;
}
#area-1, #area-2, #area-3 {
  z-index: -1;
  margin-top: -70px;
  padding-top: 70px;
}
.w1000 {
  width: 90%;
  max-width: 1000px;
  margin: auto;
}
.w1100 {
  width: 90%;
  max-width: 1100px;
  margin: auto;
}
/*top*/
.mv {
  padding: 70px 0 0;
  background: #D4C495;
  color: #40220F;
  font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
  font-weight: bold;
}
.mv p span {
  position: absolute;
  top: -1.3em;
  left: 50%;
  transform: translate(-50%, 0%);
  width: 90%;
}
.mv p {
  position: relative;
  padding: 1.8em 0 1.5em;
  font-size: 5vw;
  letter-spacing: 4px;
}
.sns_box {
  background: #2E1300;
  color: #C6AE67;
  font-family: "adobe-caslon-pro", serif;
  letter-spacing: 2px;
  font-size: 2.0rem;
  padding: 1em 0 0.6em;
}
.sns_box a {
  color: #fff;
  padding: 0 0 0 18px;
  font-size: 2.8rem;
}
.sns_box a:hover {
  color: #C6AE67;
}
.about_bg {
  padding: 3em 0;
  background: #d4c495;
  position: relative;
}
.food_bg {
  padding: 3em 0;
  background: #d2850e;
  color: #fff;
  position: relative;
}
.stage_bg {
  padding: 3em 0;
  background: #865e97;
  color: #fff;
}
.shop_bg {
  padding: 3em 0;
  background: #248fb1;
  color: #fff;
}
.culture_bg {
  padding: 3em 0;
  background: #b9577a;
  color: #fff;
}
.contents_top_txt {
  text-align: left;
  width: 90%;
  margin: 1.5em auto 0;
  line-height: 1.8;
}
.contents_top_txt span {
  font-weight: bold;
  letter-spacing: 2px;
  font-size: 1.7rem;
  margin: 0 auto 15px;
  display: block;
  text-align: center;
}
.comingsoon {
  display: inline-block;
  font-weight: bold;
  background: #4AA3BE;
  padding: 5px 20px;
  border-radius: 50px;
  margin: 1em auto 0;
  font-size: 1.6rem;
}
.about {
  position: relative;
  width: 90%;
  margin: auto;
  background: #fff;
  padding: 2em 0 2em;
  border: 10px solid #5f1985;
  box-sizing: border-box;
}
.about::before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: calc(100% + 20px);
  height: calc(100% + 20px);
  content: '';
  background-image: url("/img/2025/ganesh01.webp"), url("/img/2025/ganesh02.webp"), url("/img/2025/ganesh03.webp"), url("/img/2025/ganesh04.webp");
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-size: 60px, 60px, 60px, 60px;
  background-position: top 0px left 0px, top 0px right 0px, bottom 0 left 0, bottom 0 right 0;
  z-index: 1;
}
.about::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
  border: 5px solid;
  box-sizing: border-box;
  border-image: linear-gradient(to bottom, #e4cf83, #e4cf83, #c6642a, #e4cf83, #e4cf83, #c6642a) 1;
}
.about01 {
  width: 80%;
  margin: auto;
}
.about01 div {
  font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
  color: #910782;
  font-size: 2.4rem;
  margin: 0 auto 0.5em;
}
.about01 div span {
  display: inline-block;
  background: #910782;
  padding: 2px 10px;
  color: #fff;
  font-size: 1.5rem;
}
.about01 p {
  text-align: left;
}
.about02 {
  margin: 2em auto 0;
  width: 80%;
  position: relative;
}
.about02::after {
  position: absolute;
  content: '';
  bottom: -2em;
  left: -80px;
  display: block;
  width: 150px;
  height: 150px;
  background-image: url("/img/2025/ganesh.webp");
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 5;
}
.about02 > p {
  color: #910782;
  font-weight: bold;
  font-size: 2rem;
}
.about02 > p span {
  background: linear-gradient(transparent 70%, #e6bb45 70%);
}
.about02_in {
  text-align: left;
  font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
}
.about02_in01 {
  margin: 1em auto 1em;
}
.about02_in01 p {
  background: #910782;
  color: #fff;
  padding: 3px 10px;
  font-size: 1.4rem;
  margin: 0 auto 0.5em;
}
.about02_in01 ul {}
.about02_in01 ul li {
  position: relative;
  color: #910782;
  padding: 4px 0 4px 20px;
  font-size: 1.5rem;
}
.about02_in01 ul li::before {
  position: absolute;
  top: 4px;
  left: 0;
  content: '●';
  color: #f7b52c;
}
.about02_in02 {
  width: 75%;
  margin: 0 0 0 auto;
}
.about02_in02 p {
  text-align: center;
  position: relative;
  width: 170px;
  margin: 0 auto 0.5em 0;
}
.about02_in02 p span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  font-size: 1.5rem;
  color: #fff;
}
.about02_in02 ul {}
.about02_in02 ul li {
  color: #604c3f;
  padding: 4px 0 4px 25px;
  font-size: 1.6rem;
  position: relative;
  counter-increment: mycounter;
}
.about02_in02 ul li::before {
  position: absolute;
  top: 8px;
  left: 0px;
  width: 20px;
  height: 20px;
  line-height: 20px;
  font-size: 1.3rem;
  color: #fff;
  background: #910782;
  border-radius: 50%;
  text-align: center;
  content: counter(mycounter, decimal);
  font-family: YuGothic, 'Yu Gothic', sans-serif;
}
.food {
  width: 95%;
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0 auto 0em;
  justify-content: flex-start;
}
.food li {
  position: relative;
  margin: 1.5em 8px 0em;
  width: calc(100% / 2 - 16px);
  text-align: left;
}
.food li p span {
  position: absolute;
  bottom: 100%;
  left: 0;
  font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
  font-size: 1.1rem;
  display: inline-block;
  background: #905b01;
  padding: 2px 10px;
}
.food li p {
  position: relative;
  font-weight: bold;
  font-size: 1.5rem;
  letter-spacing: 2px;
  padding: 0.5em 0 0;
}
.food_img {
  width: 90%;
  margin: 3em auto 0;
}
.mayo_japan_txt {
  width: 80%;
  margin: 1em auto 2em;
}
.mayo_japan_txt div {
  background: #A38F4A;
  font-weight: bold;
  letter-spacing: 2px;
  margin: 0 auto 10px;
  padding: 0 0 5px;
}
.mayo_japan_txt div span {
  display: block;
  font-family: "adobe-caslon-pro", serif;
  font-weight: 400;
  font-size: 2.3rem;
  background: #50355c;
  padding: 8px 0 3px;
  margin: 0 auto 5px;
}
.session {
  margin: 0 auto 3em;
}
.session > p {
  font-weight: bold;
  color: #f0e62a;
  font-size: 1.6rem;
  margin: 0 auto 0.5em;
  letter-spacing: 2px;
}
.session > p span {
  display: inline-block;
}
.session img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.session ul {
  width: 90%;
  margin: auto;
}
.session ul li {
  margin: 1em auto 0;
  text-align: left;
}
.session ul li span {
  display: block;
  font-weight: bold;
  margin: 0 auto 0.2em;
  font-size: 1.8rem;
}
.live_ttl {
  width: 80%;
  background: #A38F4A;
  font-weight: bold;
  letter-spacing: 2px;
  margin: 0 auto 0px;
  padding: 0 0 5px;
}
.live_ttl span {
  display: block;
  font-family: "adobe-caslon-pro", serif;
  font-weight: 400;
  font-size: 2.3rem;
  background: #50355c;
  padding: 8px 0 3px;
  margin: 0 auto 5px;
}
.live {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 1em auto 0em;
  justify-content: space-between;
}
.live li {
  margin: 1.5em 8px 0em;
  width: calc(100% / 2 - 16px);
  text-align: left;
}
.live li div {
  margin: 10px auto 3px;
  font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
  font-size: 1.1rem;
}
.live li div span {
  display: inline-block;
  padding: 3px 10px;
  margin: 0 auto 5px;
  background: #9A873E;
  color: #fff;
}
.live li div span.cate {
  background: #50355c;
}
.live li p {
  font-weight: bold;
  font-size: 1.5rem;
  letter-spacing: 2px;
}
.live li p span {
  font-weight: 400;
  display: block;
  margin: 5px auto 0;
  font-size: 1.3rem;
}
.shop {
  width: 85%;
  margin: auto;
}
.shop li {
  margin: 1.5em auto 0;
  text-align: left;
}
.shop_ttl {
  margin: 0 auto 0.5em;
}
.shop_ttl div {
  font-family: 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', sans-serif;
  font-size: 1.2rem;
  background: #96843e;
  margin: 0 auto 0.5em;
}
.shop_ttl div span {
  display: inline-block;
  padding: 3px 10px;
  margin: 0 10px 0 0px;
  background: #046181;
  color: #fff;
}
.shop_ttl p {
  font-weight: bold;
  font-size: 1.8rem;
  letter-spacing: 2px;
}
.shop li > p {}
.rental {
  margin: 1.5em auto 0;
}
.rental img:last-of-type {
  margin: 1em auto 0;
}
.experience {
  margin: 3em auto 0;
}
.experience_txt {
  margin: 0 auto 1em;
}
.experience_txt div {
  font-weight: bold;
  font-size: 1.8rem;
  letter-spacing: 2px;
  width: 250px;
  margin: 0 auto 0.5em;
  background-image: url("/img/2025/experience_ttl.webp");
  background-size: 250px 45px;
  background-repeat: no-repeat;
  line-height: 2.5;
  height: 50px;
}
.experience_txt p {
  font-weight: bold;
  letter-spacing: 2px;
  font-size: 1.6rem;
}
.experience_txt p span {
  display: none;
}
.experience_img {}
.experience_img p {
  text-align: left;
  margin: 1em auto 0;
}
.experienc_sub {
  margin: 2em auto 1em;
}
.experienc_sub_img {
  width: 70%;
  margin: 0 auto 1em;
}
.experienc_sub_txt {}
.experienc_sub_txt p {
  text-align: left;
}
.experienc_sub_txt p span {
  display: block;
  text-align: center;
  font-size: 1.7rem;
  letter-spacing: 2px;
  margin: 0 auto 5px;
}
.experienc_sub_txt img {
  width: 180px;
  margin: 0 auto 1em;
}
/* ------------------------------------ */
/* ▼PC用デザインとして付け足すデザイン */
/* ------------------------------------ */
@media all and (min-width: 768px) {
  body {
    font-size: 1.5rem; /* 15px */
    line-height: 1.8;
  }
  h2 img {
    height: 70px;
  }
  .mv p span {
    top: -1.3em;
    max-width: 800px;
  }
  .mv p {
    padding: 2em 0 1.5em;
    font-size: 3vw;
    letter-spacing: 10px;
  }
  .sns_box {
    letter-spacing: 5px;
    font-size: 3.5rem;
    padding: 0.8em 0 0.4em;
  }
  .sns_box a {
    padding: 0 0 0 25px;
    font-size: 5rem;
  }
  .about_bg {
    padding: 5em 0;
  }
  .food_bg {
    padding: 5em 0;
  }
  .shop_bg {
    padding: 5em 0;
  }
  .stage_bg {
    padding: 5em 0;
  }
  .culture_bg {
    padding: 5em 0;
  }
  .contents_top_txt {
    max-width: 900px;
    margin: 2em auto 0;
    line-height: 2;
    font-size: 1.8rem;
  }
  .contents_top_txt span {
    display: block;
    font-weight: bold;
    letter-spacing: 4px;
    font-size: 3rem;
    margin: 0 auto 15px;
    line-height: 1.6;
  }
  .comingsoon {
    padding: 5px 50px;
    margin: 2em auto 0;
    font-size: 2rem;
    letter-spacing: 2px;
  }
  .about {
    max-width: 1100px;
    padding: 3em 0 4em;
    border: 20px solid #5f1985;
  }
  .about::before {
    top: -20px;
    left: -20px;
    width: calc(100% + 40px);
    height: calc(100% + 40px);
    background-size: 160px, 160px, 160px, 160px;
  }
  .about01 {
    width: 85%;
    margin: auto;
  }
  .about01 div {
    font-size: 4rem;
  }
  .about01 div span {
    padding: 2px 10px;
    font-size: 3rem;
  }
  .about01 p {
    font-size: 2rem;
    line-height: 2;
  }
  .about02 {
    margin: 2em auto 0;
    width: 85%;
  }
  .about02::after {
    bottom: -4em;
    left: -150px;
    width: 322px;
    height: 353px;
  }
  .about02 > p {
    font-size: 3.5rem;
  }
  .about02_in {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin: 2em auto 0em;
    justify-content: flex-end;
  }
  .about02_in01 {
    margin: 0;
    width: 230px;
  }
  .about02_in01 p {
    padding: 1px 15px;
    font-size: 2rem;
    margin: 0 auto 0.5em;
  }
  .about02_in01 ul {}
  .about02_in01 ul li {
    padding: 4px 0 4px 30px;
    font-size: 1.8rem;
  }
  .about02_in01 ul li::before {
    position: absolute;
    top: 4px;
    left: 0;
    content: '●';
    color: #f7b52c;
  }
  .about02_in02 {
    width: 400px;
    margin: 0 0 0 50px;
  }
  .about02_in02 p {
    width: 230px;
    margin: 0 auto 0.5em 0;
  }
  .about02_in02 p span {
    font-size: 2rem;
  }
  .about02_in02 ul {}
  .about02_in02 ul li {
    padding: 4px 0 4px 45px;
    font-size: 2.2rem;
  }
  .about02_in02 ul li::before {
    top: 8px;
    width: 30px;
    height: 30px;
    line-height: 30px;
    font-size: 2rem;
  }
  .food {
    max-width: 1100px;
    position: relative;
  }
  .food li {
    position: relative;
    margin: 2em 13px 0em;
    width: calc(100% / 3 - 26px);
  }
  .food li p span {
    font-size: 1.4rem;
    padding: 2px 10px;
  }
  .food li p {
    font-size: 1.7rem;
    padding: 0.5em 0 0;
  }
  .food_img {
    position: absolute;
    bottom: 1em;
    right: 0;
    width: 50%;
    margin: 0;
  }
  .mayo_japan_txt {
    width: 600px;
    margin: 2em auto 2em;
  }
  .mayo_japan_txt div {
    font-size: 1.8rem;
    margin: 0 auto 20px;
  }
  .mayo_japan_txt div span {
    font-size: 3.2vw;
    padding: 8px 0 0px;
  }
  .session {
    margin: 0 auto 3em;
  }
  .session > p {
    font-size: 2.8rem;
    margin: 0 auto 0.5em;
  }
  .session img {
    height: 400px;
  }
  .session ul {
    width: 90%;
    margin: 2em auto 0;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: space-between;
  }
  .session ul li {
    margin: 0;
    text-align: left;
    width: 48%;
    letter-spacing: 2px;
    font-size: 1.7rem;
  }
  .session ul li span {
    font-size: 2.8rem;
  }
  .live {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin: 5em auto 0em;
    justify-content: flex-start;
  }
  .live li {
    margin: 1.5em 13px 0em;
    width: calc(100% / 3 - 26px);
  }
  .live li div {
    margin: 10px auto 10px;
    font-size: 1.4rem;
  }
  .live li div span {
    padding: 3px 10px;
    margin: 0;
  }
  .live li p {
    font-size: 1.7rem;
    letter-spacing: 2px;
  }
  .live li p span {
    font-size: 1.5rem;
  }
  .live li p.ttl {
    text-align: center;
    background: #A38F4A;
    font-weight: bold;
    letter-spacing: 2px;
    margin: 0 auto 0px;
    padding: 0 0 5px;
    font-size: 1.8rem;
  }
  .live li p.ttl span {
    display: block;
    font-family: "adobe-caslon-pro", serif;
    font-weight: 400;
    font-size: 3.2vw;
    background: #50355c;
    padding: 70px 0 55px;
    line-height: 1.5;
    margin: 0 auto 5px;
  }
  .shop {
    max-width: 1000px;
    margin: auto;
  }
  .shop li {
    margin: 3em auto 0;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: space-between;
  }
  .shop_ttl {
    width: 50%;
    margin: 0;
  }
  .shop_ttl div {
    font-size: 1.8rem;
    margin: 0 auto 0.5em;
  }
  .shop_ttl div span {
    padding: 3px 10px;
    margin: 0 10px 0 0px;
  }
  .shop_ttl p {
    font-size: 3rem;
  }
  .shop li > p {
    width: 45%;
    font-size: 2rem;
  }
  .culture_txt {
    margin: 1.5em auto 0;
    font-size: 2.5rem;
  }
  .live_ttl {
    max-width: 550px;
    padding: 0 0 5px;
    font-size: 1.8rem;
    letter-spacing: 2px;
  }
  .live_ttl span {
    line-height: 1.3;
    font-size: 3.2vw;
    padding: 15px 0 0px;
    margin: 0 auto 5px;
  }
  .rental {
    margin: 3em auto 0;
  }
  .rental img:last-of-type {
    margin: 3em auto 0;
  }
  .experience {
    margin: 8em auto 0;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: space-between;
  }
  .experience_txt {
    margin: 0;
    width: 45%;
  }
  .experience_txt div {
    font-size: 2.5rem;
    width: 400px;
    margin: 0 auto 0.5em;
    background-image: url("/img/2025/experience_ttl.webp");
    background-size: 400px 70px;
    background-repeat: no-repeat;
    line-height: 70px;
    height: 70px;
  }
  .experience_txt p {
    text-align: left;
    font-size: 2rem;
    margin: 1em auto 0;
  }
  .experience_txt p span {
    display: block;
    font-size: 1.5rem;
    margin: 1em auto 0;
  }
  .experience_img {
    width: 50%;
  }
  .experience_img p {
    display: none;
  }
  .experienc_sub {
    margin: 2em auto 1em;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: space-between;
    align-items: center;
  }
  .experienc_sub_img {
    width: 30%;
    margin: 0;
  }
  .experienc_sub_txt {
    width: 65%;
    text-align: left;
  }
  .experienc_sub_txt p {
    text-align: left;
  }
  .experienc_sub_txt p span {
    text-align: left;
    font-size: 2rem;
  }
  .experienc_sub_txt img {
    width: 250px;
    margin: 0 auto 1em;
  }
}