@charset "utf-8";

html{
  scroll-behavior: smooth;
}


body {
    font-family: 'Zen Kaku Gothic New', sans-serif;
    font-weight: bold;
    background-color: #FAF3EA;
  }
  
  a {
    transition: all 0.3s ease;
  }

  h2{
    font-size: 3.4vw;
    margin: 0;
    letter-spacing: 1.14vw;
  }
h3{
  font-size: 1.43vw;
}

.top_visual {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  background-image: url("../images/gourmetfair-bacground.png");
  background-size: 150%;
}

.top_background{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  pointer-events: none;
}

.top_background picture img {
  width: 100%;
  height: auto;
  display: block;
}

.top_logo {
  top: 5%; 
  width: 36%;
  margin: 3.5vw auto 8vw;
}

.top_txt {
  top: 58%;
  width: 55%;
  margin: 0 auto 10vw;
}

.overlay{
  position: absolute;
  top: 1.4375rem;
  right: 7vw;
}

.multilanguage__select{
  display: flex;
  list-style: none;
  color:#D50052;
  font-size: 1.4vw;
}
.multilanguage__select p{
  margin: 0;
}
.multilanguage__select li:not(:first-child)::before {
  content: "|";
  margin: 0 0.5em;
  color: #D50052; /* 色はお好みで */
}
  a[data-stt-active] {
  text-decoration:none;
  font-weight:bold;
  }

a[data-stt-ignore]{
  text-decoration: none;
  color: #D50052;
  font-size: 1.4vw;
}

a[data-stt-ignore]:hover{
  color: #707070;
}

.top_visual img{
    width: 100%;
    height: auto; 
    display: block;
}

  /* 実施期間 */
  .event_duration{
    background-color: #D50052;
    text-align: center;
    padding-top: 5.3125rem;
    padding-bottom: 8.3125rem;
  }
  .event_duration h2{
    margin-bottom: 2vw;
  }

  .duration_title{
    margin-bottom: 2.75rem;
    display: flex ;
    flex-flow: column;
        color:#fff;
  }
  .duration_title img{
    margin: 0 auto;
  }

  .duration_content{
display: flex;
background-color: #fff;
margin: 0 14.28vw;
justify-content: space-between;
border: 3px solid #fff;
margin-bottom: 2rem;
align-items: center;
color: #3E3E3E;
  }


.pencil {
    width: 12.35vw;
    height: 5.5vw;
    background: #D50052;
    clip-path: polygon(
      0% 0%,       /* 左上 */
      90% 0%,      /* 先端直前の上 */
      100% 50%,    /* 先端 */
      90% 100%,    /* 先端直前の下 */
      0% 100%      /* 左下 */
      );
      position: relative; 
      display: flex;     
      align-items: center;
      justify-content: center;
      color: white;      
      font-size: 2.14vw;
  }

  .duration{
    font-size: 2.85vw;
    margin: 0;
    padding: 0.5rem;
    letter-spacing: 0.1em;
  }

  .duration span{
    font-size: 2.14vw;
  }

  .duration_shop {
    background-color: #D50052;
    padding: 1.142vw 2.14vw;
    margin: 0.4vw;
    border-radius: 5px;
    text-align: center;
  }

  .duration_shop.none{
    background-color: #fff;
    padding: 1.142vw 0;
    margin: 0.4vw;
    border-radius: 5px;
    text-align: center;
    width: 10vw;
  }
  .duration_shop.none:hover{
    background-color: #fff;
  }

  .duration_shop:hover{
    background-color: #a0003f;
  }

  /* リンクの見た目を<p>と同じように */
  .shop-link {
    display: block;
    color: #fff;
    font-size: 1.42vw;
    text-decoration: none;
    padding: 0.5rem 0;
  }
  .shop-link:hover {
    opacity: 0.85;
  }


  .original_menu{
    position: relative;
    color: #fff;
    border: 3px solid #fff;
    border-radius: 20px;
    margin: 5.7vw 22.2vw 5.14vw;
    padding:4.28vw 0;
    line-height: 4.5rem;
  }

  .original_menu_txt{
    font-size:  2.57vw;
  }

.original_menu .slash1,
.original_menu .slash2,
.original_menu .backslash1,
.original_menu .backslash2 {
  content: "";
  position: absolute;
  width: 20px;
  height: 5px;
  background-color: #fff;
  border-radius: 3px;
}

.original_menu .slash1 {
  top: -7%;
  right: -2%;
  transform: rotate(-62deg);
  width: 30px;
}
.original_menu .slash2 {
  top: -4%;
  right: -4%;
  transform: rotate(-45deg);
  width: 30px;
}

.original_menu .backslash1 {
  top: -7%;
  left: -2%;
  transform: rotate(62deg);
  width: 30px;
}

.original_menu .backslash2 {
  top: -4%;
  left: -4%;
  transform: rotate(45deg);
  width: 30px;
}

.present_content{
  display: flex;
  color: #fff;
  max-width: 1000px;
  margin: 0 auto;
  font-size: 1.71vw;
  align-items: center;
  padding: 0 2rem;
  gap: 1rem;
  justify-content: center;
}

.profile_img {
  width: auto;
  margin: 0;
  padding: 0;
  flex-shrink: 0;
}

.profile_img img {
  display: block;
  margin: 0;
  padding: 0;
}

.present_title{
  color: #fff;
}

.present_title img{
  margin: 0 auto;
}

.present_content p{
  letter-spacing: 0.1rem;
  line-height: 2.2rem;
  text-align: left;
  margin-left: 2rem;
}
.nowrap {
  white-space: nowrap;
}

.profile{
  font-size: 1.25rem;
  display: inline-block;
  margin: 1.5rem 0;
}

.profile a {
  position: relative;
  padding-left: 1.2em; 
  text-decoration: none;
  color: #fff;
  display: inline-block;
  white-space: nowrap;
}
.profile:hover{
  background-color: #a0003f;
}

.profile a::before {
  content: ">";
  position: absolute;
  left: 0;
  top: 40%;
  transform: translateY(-50%);
  color: #fff; 
  font-weight: bold;
  font-size: 	clamp(1rem, 0.9vw + 0.4rem, 1.5rem);
}

.present_note{
  font-size:	clamp(1rem, 0.8vw + 0.5rem, 1.375rem);
}

/* 動画 */
.event_movie {
  position: relative;
  display: flex;
  justify-content: center;
  padding-bottom: 13.5rem;
}

.thumbnail {
  position: relative;
  top: 5.875rem;
}

.yanai {
  position: absolute;
  bottom: -120px;
  right: -280px;
}

/* 参加店舗 */
.event_shop {
  background-image: url("../images/gourmetfair-bacground.png");
  background-size: cover;
  background-position: center;
  margin-top: 2vw;
}
.event_shop_container{
  width:85.71vw;
  margin: 0 auto;
}
.event_shop_title{
  background-color: #D50052;
  color: #fff;
  text-align: center;
  height: 6.5625rem;
    line-height: 6.5625rem;
}

.shop_wrapper{
  padding-bottom: 7.9375rem;
  list-style: none;
  margin-bottom: 0;
  padding-left: 0;
}

.event_shop_duration{
  display: flex;
  margin-bottom: 3.3125rem;
  margin-top: 6.25rem;
  align-items: baseline;
}

.shop_list{
  display: flex;
  gap: 1.21rem;
  padding: 0;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  position: relative;
}

.durationWrap{
  position: relative;
}

.durationWrap::after{
  content:"";
  display: inline-block;
  width: 40px;
  height: 40px;
  background-image: url(../images/arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top:0;
  right:0;
  /* background-color: tomato; */
   margin-top: 30%;
 /* transform: translateY(-50%);
  pointer-events: none; */
}

.durationWrap.active::after{
  opacity: 0; 
  pointer-events: none;
  animation: none !important;
}

/* .durationWrap.is-visible::after {
  animation: sway 1s ease-in-out 1;
}

@keyframes sway{
  0%   { transform: translateY(-50%) translateX(0); }
  50%  { transform: translateY(-50%) translateX(0); }
  75%  { transform: translateY(-50%) translateX(-10px); }
  100% { transform: translateY(-50%) translateX(0); }
} */


.shop_list_txt{
  background-color: #fff;
  width: 100%;
  scroll-snap-type: x mandatory;
  flex-wrap: nowrap;
}

.shop_list_container {
  width: calc(25% - 1.125rem); /* gapぶんを引いてちょうど4列 */
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  box-sizing: border-box;
  color:#707070;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  position: relative;
  padding-bottom: 5.71vw;
  flex: 0 0 calc((100% - 3rem) / 4);
}

.shop_list_img {
  width: 100%; 
  position: relative;
}

.shop_list_img img {
  width: 100%;
  height: auto;
  display: block;
}

.shop_name {
  word-break: break-word;
  overflow-wrap: break-word;
  padding: 0 1rem;
  text-align: left;
  font-size: 1.42vw;
}

.store-details{
  padding: 0 1rem;
  text-align: left;
  font-size: 1vw;
}

.shop_btn {
  display: block;
  text-align: center;
  background-color: #D50052;
  color:#fff;
  text-decoration: none;
  font-size: 1.42vw;
  padding:0.9vw 2.14vw;
  border-radius: 5px;
  border: none;
  position: absolute;
    left: 0;
    right: 0;
    width: 10vw;
    margin: 0 auto;
    bottom: 1.42vw;
}


.shop_btn:hover {
  background-color: #a0003f; 
}

.number-badge {
    position: absolute;
    top: 0.375rem;
    left: 0.375rem;
    width: 2.85vw;
    height: 2.85vw;
    background-color: #D50052;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.14vw;
    font-weight: bold;
    z-index: 10;
    user-select: none;
}

.number-badge .num {
  display: inline-block;
  position: relative;
  top: -2px; 
}

/* モーダル */
.modal-overlay {
  transition: opacity 0.2s ease;
  /* display: flex; */
  display: none;
  background-color: rgba(0, 0, 0, 0.5);
  justify-content: center;
  align-items: center;
  z-index: 9999;
   pointer-events: none; /* 初期状態ではクリックを無効化 */
  opacity: 0;
  overflow-y: auto;
  padding: 4rem 1rem;
  justify-content: center;
align-items: center;
}

.modal-overlay.active {
  pointer-events: all; /* クリックを有効化 */
  opacity: 1; /* 表示状態にする */
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.modal_wrapper {
  position: relative;
  display: inline-block;
  max-height: calc(100vh - 12rem);
}

.modal {
  background: white;
  border-radius: 8px;
  width: 85.7vw;
  text-align: center;
  padding: 6.0625rem 0;
  z-index: 10000;
  overflow-y: scroll;
  max-height: calc(100vh - 12rem);
  box-sizing:border-box;
}

.modal h2{
  color: #D50052;
  margin: 3.57vw 0;
}

.modal img{
  width: 31.25rem;
}

.close-btn {
  margin: 4.28vw;
  padding: 1.4375rem 6.5rem;
  background-color:#fff;
  border: 1px solid #707070;
  color: #707070;
  font-size: 1.71vw;
  border-radius: 4px;
  cursor: pointer;
}

.mordal_duration{
  font-size: 2.14rem;
  color: #fff;
  background-color: #D50052;
  text-align: center;
}

.mordal_duration p{
  padding: 1rem 0;
  margin: 0;
}


.shop-info-table {
  width: calc(100% - 17.125rem); 
  margin: 5.3125rem 8.5625rem;   
  border-collapse: collapse;
  font-size: 1.71vw;           
}

.shop-info-table th,
.shop-info-table td {
  padding: 0.625rem 0.875rem; 
  color:#707070;
  text-align: left;
  line-height: 2.5vw;
}


.shop-info-table th {
  width: 8rem; 
  white-space: nowrap; 
  vertical-align: top;
}

.shop-info-table td a{
  color: #707070;
}

.modal_menu_title{
  color:#D50052;
  border-top: 8px solid #D50052 ;
  margin: 0 4.6875rem;
}

.modal_menu_list{
  display: flex;
  gap: 3.125rem;
  flex-wrap: wrap;
  border-bottom: 8px solid #D50052 ;
  margin: 0 4.6875rem;
  justify-content: space-between;
}

.modal_menu_list_container{
  flex: 0 0 calc(50% - 1.5625rem); 
  box-sizing: border-box;
  color: #707070;
}

.modal_menu_list_container img{
  width: 100%;
}

.recipe_name{
  font-size: clamp(16px, 2.28vw, 32px);
}

.recipe_price{
  font-size: clamp(16px, 1.71vw, 24px);
  margin-bottom: 3.125rem;
}

.modal-close-icon {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 24px;
  height: 24px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 10001;
  display: flex;
      align-items: center;
      justify-content: center;
      padding: 1rem;
}
.modal-close-icon::before,
.modal-close-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 24px;
  height: 1px;       
  background-color: #707070;
  transform-origin: center;
}

.modal-close-icon::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.modal-close-icon::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.modal-close-icon:hover{
  background-color: rgba(0, 0, 0, 0.1); 
}

.modal_wrapper .number-badge  {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-50%,-50%);
  z-index: 10001;
  width: 5.7vw;
  height: 5.7vw;
}

.modal .number-badge{
  font-size: 3.57vw;
}

.recipe_txt{
  font-size: clamp(16px, 1.35vw, 24px);
  line-height: 2rem;
  text-align: left;
  padding: 0 1.5vw;
}

.close-btn:hover{
  background-color: #707070;
  color: #fff;
}


/* マップ */
.event_shopmap{
  background-color: #D50052;
  color:#fff;
  text-align: center;
  padding: 4rem 6.25rem;
}

.event_shopmap h1{
  margin-bottom: 3.3125rem;
}

.map-placeholder {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  margin-top: 3.25rem ;
  position: relative;
  padding-top: 56.25%;
}

.map-placeholder iframe {
  position: absolute;
  top:50%;
  left:50%;
  transform: translate(-50%, -50%);
  width: 85.7vw;
  height: 43.42vw;
  border: 0;
  display: block;
}

/* お問い合わせ */
.event_contact_wrapper{
  background-color: #fff;
  color: #707070;
  margin:4.0625rem auto;
  padding:1.6875rem 0 2.7rem;
  text-align: center;
  box-shadow: 4px 4px 6px -2px rgba(0, 0, 0, 0.3);
  width:57vw;
  border-radius: 0.7vw;
}

.event_contact_wrapper p{
  font-size: 	1.28vw;
  margin-top: 1.6875rem;
}

.mail_contact{
  color: #707070;
  font-size: 1.28vw;
}

.mail_contact:hover{
  background-color: rgba(0, 0, 0, 0.1); 
}

/* フッター */
footer {
  display: flex;
  background-color: #D50052;
  justify-content: center;
  gap: 0.8rem;
  padding: 5.875rem;
  flex-wrap: nowrap;
}

footer a {
  width: 38.125rem;
}

footer img {
  width: 100%;
  height: auto;
  display: block;
}

/* footer a:hover {
  filter: brightness(0.8);
} */

html, body {
  overflow-x: hidden;
}

.stt-lang-select.br{
  display: none;
}

/* ポップアップ*/
.popup {
  display: none; /* 初期は非表示 */
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0,0,0,0.6); /* 背景の暗転 */
  color:#707070;
  transition: opacity 0.2s ease;
  overflow-y: auto;
  opacity: 0;
  pointer-events: none;
  display: block; 
}

.popup-content {
  background-color: #fff;
  margin: 10% auto;
  padding: 2vw 1.4vw;
  border-radius: 8px;
  width: 85.7vw;
  max-width: 1200px;
  position: relative;
  box-shadow: 0 4px 8px rgba(0,0,0,0.2);
  overflow: scroll;
  max-height: calc(100vh - 8rem);
}

.popup.active{
  pointer-events: auto;
  opacity: 1;
}

.popup-content img{
  width: 21.4vw;
}

.popup-content p{
  text-align: center;
  font-size: 1.24vw;
}

.profile_name{
  font-weight: bold;
}

.close {
  color: #aaa;
  font-size: 28px;
  position: absolute;
  right: 16px;
  top: 8px;
  cursor: pointer;
}

.close:hover {
  color: #000;
}


/* sp表示 */
@media screen and (max-width: 768px) {
h2{
  font-size: 6.4vw;
}
h3{
  font-size: 5.3vw;
  margin: 0 0 2rem;
}

.top_logo{
  top: 5%;
    width: 56%;
    margin: 6.13vw auto 14.4vw;
}

.top_txt{
  top: 51%;
  width: 78.4vw;
}

.multilanguage__select{
  font-size: 5.3vw;
}
.multilanguage__select li:not(:first-child)::before{
  font-size: 4.8vw;
  vertical-align: middle;
}

.overlay{
  top:-0.5rem;
  right: 1rem;
}
a[data-stt-ignore]{
  font-size: 4.8vw;
  vertical-align: middle;
}
  .event_duration{
    padding: 1.625rem 8.06vw;
  }
  .duration_title {
    margin-bottom: 1.5rem;
}
 .duration_title_pc{
  display: none;
}
.duration_title_sp{
width: 84.5vw;
}
.duration_title img {
  height: auto;
  max-width: 100%;
}

.present_title img{
  height: auto;
  max-width: 100%;
}

.present_title_pc{
  display: none;
}

.present_title_sp{
 width: 88vw;
}

  .duration_content {
    flex-direction: column;
    margin: 0 0 1.25rem; 
    gap: 0.5rem;
    align-items: center; 
    padding: 0.6875rem 0.375rem 1.0625rem;
    box-shadow: 0 4px 6px -2px rgba(0, 0, 0, 0.3);
  }

  .pencil {
    width: 80vw;
        height: 8vw;
    clip-path: polygon(
      0% 0%,          /* 左上 */
      100% 0%,        /* 右上 */
      100% 80%,       /* 右下手前 */
      50% 100%,       /* 下の頂点（先端） */
      0% 80%          /* 左下手前 */
    );
  }

  .pencil-text{
    font-size: 6.4vw;
    line-height: 1.5rem;
    padding-bottom: 0.4rem;
  }

  .duration{
    font-size: 6.93vw;
    letter-spacing: 0.03rem;
    margin-top: 0.8rem;
  }
  .duration span {
    font-size: 4.5vw;
}

.duration_shop {
  padding:0.3125rem 2.125rem 0.5625rem;
}

.shop-link{
  font-size:4.8vw;
}

.original_menu {
  margin: 2.7rem 1rem;
  padding: 1.5rem 1rem;
  line-height: 2rem;
  font-size: 4.2vw;
}
.original_menu_txt {
  font-size: 4.2vw;
  line-height: 8vw;
}
.present_content {
  flex-direction: column;
  align-items: center;
  padding: 1.5rem 1rem;
  font-size: 4.26px;
  gap: 1.5rem;
}

.present_content p {
  margin-left: 0;
  text-align: center;
  line-height: 8vw;
  font-size: 4.26vw;
  font-feature-settings: "palt";
}

.present_note {
  font-size: 3.73vw;
  letter-spacing: -0.05em;
}

.profile_img img {
  width: 100%;
  max-width: 250px;
  height: auto;
}

.original_menu .slash1,
.original_menu .slash2,
.original_menu .backslash1,
.original_menu .backslash2 {
  width: 18px;
  height: 3px;
}

.present_content{
  padding: 1.5rem 0;
}

.profile {
  display: inline-block;
  border: 1px solid #fff; 
  padding: 4px 10px;      
  font-size: 3.73vw;
}

.profile a::before {
  top: 45%;
}

.event_movie{
  overflow-x: hidden; 
  overflow-y: auto;
}

  .yanai {
    bottom: -60px;     
    right: 0;          
    transform: scale(0.7);  
    bottom: -13rem;
    right: -10rem;
  }

  .thumbnail {
    top: 2rem;
    width: 90%;
    text-align: center;

  }

  .thumbnail img {
    max-width: 90%;
    height: auto;
  }

  .br_pc{
    display: none;
  }

  .event_shop {
    /* margin-top: -6rem; */
    position: relative;
    z-index: 2;
    background-image: none;
    overflow-x: hidden;
        overflow-y: auto;
  }

  .event_shop_container{
    width: 100%;
  }

  .event_shop_title{
    height: 3.75rem;
    line-height: 3.75rem;
  }

  .event_shop_duration{
  flex-direction: column;
  align-items: center;
  margin-top: 2.1875rem;
  margin-bottom: 1.75rem;
  }

  .shop_wrapper {
    margin: 0;
    padding-bottom: 15vw;
    padding-left: 0;
  }

  .shop_list_container{
    width: 90%;
    margin-bottom: 0.5rem;
    flex: 0 0 80%; 
    scroll-snap-align: start;
    padding-bottom: 12vw;
  }

  .store-details{
font-size: 4.26vw;
padding: 0 5.3vw;
  }

  .shop_name{
    font-size: 5.33vw;
    padding: 0 5.3vw;
  }

  .shop_btn{
    font-size: 5.33vw;
    width: 37.3vw;
        height: 10.6vw;
    bottom: 5vw;
  }

  .shop_list_txt{
    margin-top: 0;
  padding-bottom: 1.3125rem;
  }

  .event_shopmap{
    padding: 2.3125rem 1.875rem;
  }

  .map-placeholder{
    height: 508px;
  }

  .event_shopmap h1{
    margin-bottom: 1.875rem;
  }

  .event_contact_wrapper {
    border-radius: 10px;
    width: 84.5vw;
  }

  .event_contact_wrapper p{
    font-size: 3.73vw;
    margin: 0 0 1.125rem;
  }

  .mail_contact{
    font-size: 3.73vw;
  }

  footer{
    flex-direction: column;
    padding: 2.5625rem 30px 3.125rem;
  }

  footer a{
    width: 100%;
  }

  .shop_list {
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 1rem;
    margin-left: 30px;
    display: flex;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none;  /* IE/Edge */
  }

  .shop_list::-webkit-scrollbar {
    display: none;
  }
  .number-badge{
    width: 10.6vw;
    height: 10.6vw;
  }

  .number-badge .num{
    font-size: 8vw;
  }

  .modal {
    top: 4rem;
    width: 100%;
    padding: 3rem 0;
    max-height: 80vh;
    overflow-y: auto;
  }


  .modal img {
    width: 80%;
    height: auto;
  }

  .modal_menu_list {
    flex-direction: column;
    gap: 2rem;
    margin: 0;
  }

  .modal_menu_list_container {
    flex: 1 1 100%;
  }

  .shop-info-table {
    width: 88vw;
    margin:0 auto;
    font-size: 3.73vw;
  }

  .shop-info-table th {
    width: auto;
  }

  .modal_menu_title {
    margin: 3rem 1.5rem 1.5rem;
    font-size: 7.46vw;
  }

  .close-btn {
    font-size: 5.33vw;
    padding: 1rem 4rem;
    margin-top: 2rem;
  }

  .modal .number-badge {
    font-size: 5.3vw;
    width: 3rem;
    height: 3rem;
    top: 1rem;
    left: 1rem;
  }

  .mordal_duration {
    font-size: 4.8vw;
    padding: 0;
    margin-bottom: 1.2rem;
  }

  .modal-close-icon {
    top: 0.5rem;
    right: 0.5rem;
    width: 5.3vw;
    height: 5.3vw;
  }

  .modal-close-icon::before,
  .modal-close-icon::after {
    width: 20px;
  }

  .recipe_name {
    font-size: 6.4vw;
  }

  .recipe_price {
    font-size: 5.33vw;
    margin-bottom: 2rem;
  }

  .recipe_txt {
    font-size: 4.26vw;
    line-height: 1.6rem;
  }

  .modal-overlay .number-badge {
    width: 9vw;
    height: 9vw;
  }

  .shop-info-table th, .shop-info-table td{
    line-height: 1.5;
  }

  .shop-info-table td{
    white-space: normal;
    word-break: break-word;
  }

  .map-placeholder {
    padding-top: 0; 
    height: 135.4vw;  
    margin-top: 8vw;
  }

  .map-placeholder iframe {
    width: 84.5vw;
    height: 135.4vw;
  }

  .map_btn{
    display: inline-block; 
    margin-top: 30px;
    width: 84.53vw;
  }

  .map_btn img{
    width: 100%;
  }

  .top_text_pc{
    display: none !important;
  }

  .popup-content{
    padding: 4vw;
    width: 80vw;
  }

  .popup-content img{
    width: 80%;
  }

  .profile_text{
    text-align: left !important;
  }


.durationWrap::after{
  display: none;
}
}


@media screen and (min-width: 769px) {
.br_sp{
  display: none;
}

.swiper{
  display: none;
}

.pc-only-space {
  display: inline-block;
  width: 2em; 
}

.map_btn{
  display: none;
}

.top_text_sp{
display: none !important;
}

.duration_title_sp{
  display: none;
}

.duration_title_pc{
  width: 40.8vw;
  max-width: 408px;
}

.present_title_sp{
  display: none;
}

.present_title_pc{
  width: 56.28vw ;
  max-width: 788px;
}

}

html[lang="en"] {
  .present_content p {
        line-height: 1.5;
  }
  h2{
    letter-spacing: 0.2vw;
  }
}

@media screen and (max-width: 768px){
  html[lang="en"]  .present_content p {
    line-height: 6vw;
}
html[lang="en"] .present_note{
  letter-spacing: 0.5vw;
}
}