﻿.inquiry_ButtonWrapper {
  position: fixed;
  z-index: 2;
  bottom: 9em;
  right: 2rem;
  max-width: 125px;
  max-height: 65px;
}

.inquiry_ButtonWrapper {
  position: fixed;
  z-index: 2;
  bottom: 9em;
  right: 2rem;
  max-width: 125px;
  max-height: 65px;
}

.inquiry_ButtonWrapper {
  position: fixed;
  z-index: 2;
  bottom: 9em;
  right: 2rem;
  max-width: 125px;
  max-height: 65px;
}

.inquiry_ButtonWrapper {
  position: fixed;
  z-index: 2;
  bottom: 9em;
  right: 2rem;
  max-width: 125px;
  max-height: 65px;
}

/* CSS Document */
.shop_text h3 {
  font-size: 2.5rem;
  line-height: 1;
  margin-bottom: 0rem;
}

.exNoticeContainer_02 {
  padding: 2rem 0;
  margin: 4rem 0 6rem;
}

@media screen and (max-width: 599px) {
  .exNoticeContainer_02 {
    padding: 1rem 0;
    margin: 1rem 0 2rem;
  }
}

.shop_column_01 {
  padding: 0 0 2rem 0;
}

.shop_column_01 .exReserveContentWrapper {
  padding: 2rem 3rem;
}

.shop_column_01 .exReserveContentWrapper {
  width: 100%;
}

.shop_column_01 .exReserveContentContainer {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 20px;
}

.exReserveContentWrapper.exReserveContentWrapper_rikomon {
  background-color: #fdfcd3;
}

.exReserveContentWrapper.exReserveContentWrapper_toriatsukai {
  background-color: #f2f2f2;
}

.exReserveContentWrapper.exReserveContentWrapper_popup {
  background-color: #f5ecd9;
}

.exReserveContentWrapper.exReserveContentWrapper_godoro {
  background-color: #e3f2fd;
}

.exReserveContentListWrapper {
  font-size: 1.4rem;
  color: #000000;
  font-weight: 400;
}

.exReserveContentListText {
  font-size: 1.4rem;
}

.exFlowImage2Col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  margin-top: 2rem;
}

.exFlowImage2Col_item img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0.8rem;
}

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

  .exReserveContentListWrapper,
  .exReserveContentListText {
    font-size: 1.4rem;
  }

  .exFlowImage2Col {
    grid-template-columns: 1fr;
  }

  .exAboutContainer--rikomonPlace .exFlowImage2Col {
    grid-template-columns: 1fr !important;
  }
}

.exAboutContainer--rikomonPlace .exFlowTitleWrapper h3 {
  flex-basis: 100%;
}

.exAboutContainer--rikomonPlace .exFlowTitleLogoWrapper {
  margin: 1.2rem auto 2rem;
  text-align: center;
}

.exAboutContainer--rikomonPlace .exFlowTitleLogoWrapper img {
  width: 40%;
  max-width: 16rem;
  height: auto;
  display: inline-block;
}

.exAboutContainer--rikomonPlace .exFlowTitleLogoWrapper img[src*="2026logo2line.jpg"] {
  width: 60%;
  max-width: 24rem;
}

.exAboutContainer.exAboutContainer--rikomonPlace {
  border-radius: 8rem 0 0 8rem !important;
}

.exAboutContainer--rikomonPlace .exFlowContentText {
  margin-top: 0;
}

.exAboutContainer--rikomonPlace .exFlowContentContainer:nth-child(3) {
  margin-bottom: 1.2rem;
}

.exAboutContainer--rikomonPlace>.exAboutWrapper>h2 {
  margin-bottom: 12px;
}

.exAboutContainer--rikomonPlace .exAboutWrapper--godoroFlow>h3 {
  display: inline-block;
  position: relative;
  z-index: 0;
  line-height: 1;
  font-size: 2.8rem;
  padding: 4rem 0;
  margin-bottom: 18px;
}

.exAboutContainer--rikomonPlace .exFlowContentContainer--godoroFlow .exFlowTitleWrapper h3 {
  font-size: 2.8rem;
}

.exAboutContainer--rikomonPlace .exAboutWrapper--godoroFlow {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.exAboutContainer--rikomonPlace .exAboutWrapper--godoroFlow>h3::before {
  content: "";
  background-color: #f2f2f2;
  border-radius: 4rem;
  height: 1rem;
  position: absolute;
  bottom: 50%;
  width: calc(100% + 2rem);
  left: 50%;
  transform: translate(-50%, 100%);
  z-index: -1;
}

@media screen and (max-width: 765px) {
  .exAboutContainer--rikomonPlace .exAboutWrapper--godoroFlow>h3 {
    font-size: 1.8rem;
    padding: 0;
  }

  .exAboutContainer--rikomonPlace .exFlowContentContainer--godoroFlow .exFlowTitleWrapper h3 {
    font-size: 1.8rem;
  }
}

.exAboutContainer--rikomonPlace .rikomon-title-tab-wrap {
  justify-content: center;
  width: fit-content;
  margin: 0 auto 10px;
  padding: 2rem 3rem;
  background-color: #fdfcd3;
  border-radius: 10px;
  gap: 0;
}

.exAboutContainer--rikomonPlace .rikomon-title-tab-wrap--godoro {
  background-color: #e3f2fd;
}

.exAboutContainer--rikomonPlace .rikomon-title-tab-wrap--toriatsukai {
  background-color: #f2f2f2;
  color: #444;
}

.exAboutContainer--rikomonPlace .rikomon-title-tab-wrap--toriatsukai .tab_id_11 {
  background: #444;
}

.exAboutContainer--rikomonPlace .rikomon-title-tab-wrap--popup {
  background-color: #f5ecd9;
}


.exAboutContainer--rikomonPlace .exFlowImage2Col_item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.exAboutContainer--rikomonPlace .exFlowImage2Col--singleTile {
  grid-template-columns: 1fr;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.exAboutContainer--rikomonPlace .exFlowImage2Col--full {
  grid-template-columns: 1fr;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.exAboutContainer--rikomonPlace .exFlowImage2Col--singleTile .exFlowImage2Col_item img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  border-radius: 0.8rem;
}

.exAboutContainer--rikomonPlace .exFlowContentContainer--godoroFlow {
  background-color: #f2f2f2;
  border-radius: 1.2rem;
  padding: 2.4rem;
}

.exAboutContainer--rikomonPlace .exFlowContentContainer--godoroFlow .exFlowTitleWrapper {
  padding: 0 0 0.8rem;
}

.exAboutContainer--rikomonPlace .exFlowContentContainer--godoroFlow .exFlowContentWrapper:first-of-type {
  padding-top: 0.8rem;
  padding-bottom: 1.6rem;
  margin-bottom: 1.6rem;
  border-bottom: 2px solid #555;
}

@media screen and (min-width: 600px) {

  .exAboutContainer--rikomonPlace .exFlowImage2Col_item img[src*="logoNew_sideBlack.png"],
  .exAboutContainer--rikomonPlace .exFlowImage2Col_item img[src*="2026logo2line.jpg"] {
    width: 80%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 599px) {
  .exAboutContainer--rikomonPlace .exFlowImage2Col.exFlowImage2Col--singleTile {
    grid-template-columns: 1fr;
  }

  .exAboutContainer--rikomonPlace .exFlowImage2Col--singleTile {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

/* スマホ以外では改行させない */
.sp-br {
  display: none;
}

@media screen and (max-width: 599px) {
  .exAboutContainer.exAboutContainer--rikomonPlace {
    border-radius: 2rem 0 0 2rem !important;
  }

  .exAboutContainer--rikomonPlace .exFlowTitleWrapper h3 {
    width: 100%;
    max-width: 100%;
    padding: 0 1.2rem;
    box-sizing: border-box;
  }

  /* スマホで Rikomon の後で改行して2行に */
  .sp-br {
    display: block;
  }

  /* Rikomon 見出しだけ exFlowTitleLine を短くして文字を2行で表示しやすく */
  .exAboutContainer--rikomonPlace .exFlowContentContainer:nth-child(3) .exFlowTitleWrapper .exFlowTitleLine {
    width: 15%;
    min-width: 1.5rem;
    flex: 0 0 auto;
  }

  /* Rikomon 見出しは2行表示・線は短く */
  .exAboutContainer--rikomonPlace .exFlowContentContainer:nth-child(3) .exFlowTitleWrapper h3 {
    flex: 1 1 auto;
    min-width: 0;
    font-size: clamp(1.5rem, 4.2vw, 1.85rem);
    line-height: 1.5;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  /* 合同・取扱店・ポップアップは1行で整える（フォントで収める） */
  .exAboutContainer--rikomonPlace .exFlowContentContainer:nth-child(n+4) .exFlowTitleWrapper h3 {
    font-size: 1.5rem;
    line-height: 1.2;
    white-space: nowrap;
  }
}

@media (min-width: 768px) {
  .shop_column_01 .exReserveContentContainer {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media screen and (max-width: 765px) {
  .shop_column_01 {
    padding: 0;
  }

  .shop_column_01 .exReserveContentWrapper {
    width: 100%;
    padding: 3rem 2rem;
    margin: 1rem 0;
  }

  .shop_column_01 .exReserveContentWrapper {
    max-width: 100%;
  }
}

.exReserveContentButton_04 {
  font-size: 2.1rem;
  background-color: #c9c9c9;
  color: #fff;
  padding: 1rem 2rem;
  padding: 1.6rem;
  display: block;
  border-radius: 1rem;
  box-shadow: 0 0 2rem 1rem rgb(51 51 51 / 10%);
}

.area_name_tab {
  width: 100%;
  background: #f2f2f2;
  border-radius: 1rem;
  /* margin-bottom: 2rem; */
  font-size: clamp(18px, 2.9vw, 20px);
  font-weight: 600;
  padding: 2rem 0;
}

.area_name_tab h3 {
  padding: 1.5rem;
  color: #333;
  position: relative;
}

/*.area_name_tab h3::before{
   content: "";
    position: absolute;
    top: 50%;
    right: 10%;
    border: 1rem solid transparent;
    border-top: 1.2rem solid #333;
}*/
.area_name_01 {
  text-align: left;
  margin-top: 2rem;
}

.mg-bot_01 {
  margin-bottom: 5rem;
}

@media screen and (min-width: 600px) {
  .area_name_01 {
    margin-bottom: 5rem;
  }
}

.area_name_01 h3 {
  border-bottom: solid 3px #ff9c90;
  border-image: linear-gradient(to right, #ff9c90 0%, #ffe0dc 100%);
  border-image-slice: 1;
}

.event_date_01 {
  font-weight: 600;
  background-color: #fff;
  padding: 1rem;
  border-radius: 0.8rem;
  width: auto;
  display: inline-block;
  text-align: center;
}

.event_date_02 {
  width: auto;
  font-size: clamp(17px, 18.5vw, 20px);
  font-weight: 600;
}

.event_date_wrapper {
  font-size: 1.4rem;
  text-align: left;
  padding: 0 0 2rem 0;
}

.event_date_wrapper li {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.event_date_wrapper li.event_date_pair_center {
  justify-content: center;
}

.event_date_wrapper li.event_date_pair_center .event_date_01_group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  text-align: center;
}


.area_link_01 {
  display: flex;
  flex-wrap: wrap;
  gap: 5rem;
  justify-content: space-between;
  padding: 2rem 0 5rem;
  /*background: url("../img/map.png");*/
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: rgba(255, 255, 255, 0.7);
  background-blend-mode: lighten;
}

.area_link_02 {
  width: calc(100% / 2 - 2.5rem);
}

.area_link_02 h3 {
  text-align: left;
  padding-bottom: 1rem;
}

.area_link_03 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.area_link_03 a {
  width: calc(100% / 3 - 0.7rem);
}

.area_link_03::after {
  content: "";
  display: block;
  width: calc(100% / 3 - 0.7rem);
}

@media screen and (max-width: 765px) {
  .event_date_wrapper li {
    flex-direction: column;
  }

  .area_link_01 {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    flex-direction: column;
  }

  .area_link_02 {
    width: calc(100% / 1);
    margin: 0 auto;
  }
}

.tab_id_wrapper {
  width: 100%;
  display: flex;
  gap: 1rem;
  padding-bottom: 2rem;
}

.exReserveContentWrapper>.tab_id_wrapper {
  justify-content: center;
}

.tab_id_wrapper div {
  padding: 0.5rem;
  color: #ffffff;
  border-radius: 0.4rem;
}

.tab_id_01 {
  background: #4a6fb3 !important;
  font-weight: 500;
  font-size: 1.4rem;
}

.tab_id_02 {
  background: #f0cc73;
}

.exReserveContentWrapper.exReserveContentWrapper_toriatsukai .tab_id_11 {
  background: #444;
}

.exReserveContentWrapper.exReserveContentWrapper_toriatsukai .tab_id_wrapper .tab_id_06 {
  background: #b08a5a !important;
}

.tab_id_03 {
  background: #80d7a6;
}

.tab_id_04 {
  background: #a9a9a9;
}

/*エリアボタン*/
.area_button_01 {
  position: fixed;
  z-index: 2;
  bottom: 3em;
  right: 2rem;
  height: clamp(50px, 5rem, 65px);
  width: clamp(117px, 15vw, 125px);
}

.area_button_02 {
  padding: 1rem 0.3rem;
  text-align: center;
  display: flex;
  background-color: #c8161d;
  border-radius: 1rem;
  box-shadow: 0 0 0.8rem 0.4rem rgb(200 200 200 / 10%);
  transition: all 0.2s;
  justify-content: center;
  font-size: clamp(16px, 2.4vw, 17px);
  font-weight: 600;
  color: #fff;
}

.reserve_content .event_date_02 {
  display: block;
  text-align: center;
}

.reserve_content .exFlowContentText {
  text-align: center;
}

.reserve_button {
  width: 90%;
  max-width: 400px;
  text-align: center;
  font-size: 2rem;
  background-color: #c8161d;
  color: #fff;
  margin: 2rem auto;
  padding: 1.6vmin;
  display: block;
  border-radius: 1rem;
  box-shadow: 0 0 2rem 1rem rgb(51 51 51 / 10%);
}

.shop_column_01 .shop_text h3 {
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.3;
}

/*ローディング*/
.loading {
  position: fixed;
  z-index: 1000;
  width: 100%;
  height: 100vh;
  background-color: #000000;
  display: flex;
  justify-content: center;
  background-color: #f2f2f2;
}

.loading.hide {
  opacity: 0;
  pointer-events: none;
  transition: opacity 500ms;
}

.loading-wrap {
  position: abolute;
  left: 0;
  right: 0;
  margin: auto;
  height: 20px;
}

.end_wrapper_01 {
  position: relative;
}

.end_wrapper_01::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #00000096;
  border-radius: 2rem;
  z-index: 998;
}

.end_wrapper_01::after {
  position: absolute;
  content: "終了しました";
  width: 100%;
  height: auto;
  border-radius: 2rem;
  z-index: 999;
  color: #fff;
  top: 50%;
  left: 0%;
  font-size: 2.5rem;
  font-weight: 500;
}

.logo_icon_box {
  padding: 1rem;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}

.logo_icon_box img {
  width: 100%;
}

.after-content,
.after-content_02 {
  display: none;
}

.kitte_marunouchi_highlight {
  margin-bottom: 1rem;
  padding: 1.2rem;
  border-radius: 1.2rem;
  background: #f5ecd9;
}

.kitte_marunouchi_highlight .event_date_01 {
  display: inline-block;
  margin-bottom: 0.8rem;
  font-size: 1.4rem;
  font-weight: 600;
}

.kitte_marunouchi_highlight_head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  margin-bottom: 0.4rem;
  flex-wrap: wrap;
}

.kitte_marunouchi_highlight_head .event_date_01 {
  margin-bottom: 0;
}

.kitte_marunouchi_highlight_head .tab_id_13 {
  padding: 0.5rem;
  color: #ffffff;
  border-radius: 0.4rem;
}

.kitte_marunouchi_highlight_text {
  margin: 0 0 0.8rem;
  font-weight: 700;
}

.kitte_marunouchi_highlight_head .kitte_marunouchi_highlight_text {
  margin: 0;
  padding: 0;
  background: transparent;
}

.kitte_marunouchi_highlight .tab_id_wrapper_02 {
  padding-bottom: 0;
}

.kitte_osaka_highlight {
  margin-bottom: 1rem;
  padding: 1.2rem;
  border-radius: 1.2rem;
  background: #f5ecd9;
}

.kitte_osaka_highlight .event_date_01 {
  display: inline-block;
  margin-bottom: 0.8rem;
  font-size: 1.4rem;
}

.kitte_osaka_highlight_head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  margin-bottom: 0.8rem;
  flex-wrap: nowrap;
}

.kitte_osaka_highlight_head_labels {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}

.kitte_osaka_highlight_head .tab_id_13 {
  padding: 0.5rem;
  color: #ffffff;
  border-radius: 0.4rem;
}

.kitte_osaka_highlight_head .tab_id_13.tab_id_13_festival {
  background: #444;
}

.kitte_osaka_highlight_head .tab_id_13.tab_id_13_festival::before {
  content: none;
}

.kitte_osaka_highlight_text {
  margin: 0 0 0.8rem;
  font-weight: 700;
}

.kitte_osaka_highlight_head .kitte_osaka_highlight_text {
  margin: 0;
  padding: 0;
  background: transparent;
}

.kitte_osaka_highlight .tab_id_wrapper_02 {
  padding-bottom: 0;
}

.kobe_hankyu_highlight {
  margin-bottom: 1rem;
  padding: 1.2rem;
  border-radius: 1.2rem;
  background: #f5ecd9;
}

.kobe_hankyu_highlight_dates {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-bottom: 0.8rem;
}

.kobe_hankyu_highlight_head {
  margin-bottom: 0.4rem;
}

.kobe_hankyu_highlight_head .tab_id_13 {
  padding: 0.5rem;
  color: #ffffff;
  border-radius: 0.4rem;
}

.kobe_hankyu_highlight .event_date_01 {
  display: inline-block;
  font-size: 1.4rem;
}

.kobe_hankyu_highlight_text {
  margin: 0 0 0.8rem;
  font-weight: 700;
}

.kobe_hankyu_highlight_head .kobe_hankyu_highlight_text {
  margin: 0;
  padding: 0;
  background: transparent;
}

.kobe_hankyu_highlight .tab_id_wrapper_02 {
  padding-bottom: 0;
}

.hankyu_umeda_highlight {
  margin-bottom: 1rem;
  padding: 1.2rem;
  border-radius: 1.2rem;
  background: #f5ecd9;
}

.hankyu_umeda_highlight .event_date_01 {
  display: inline-block;
  margin-bottom: 0.8rem;
  font-size: 1.4rem;
}

.hankyu_umeda_highlight_head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-bottom: 0.8rem;
}

.hankyu_umeda_highlight_head .event_date_01 {
  margin-bottom: 0;
}

.hankyu_umeda_highlight_head .tab_id_13 {
  padding: 0.5rem;
  color: #ffffff;
  border-radius: 0.4rem;
}

.hankyu_umeda_highlight_text {
  margin: 0 0 0.8rem;
  font-weight: 700;
}

.hankyu_umeda_highlight_head .hankyu_umeda_highlight_text {
  margin: 0;
  padding: 0;
  background: transparent;
}

.hankyu_umeda_highlight .tab_id_wrapper_02 {
  padding-bottom: 0;
}

.area_button_01 {
  z-index: 1000;
}

.exAboutContainer--rikomonPlace>.exAboutWrapper>h2 {
  margin-bottom: 12px;
}