.w-layout-blockcontainer {
  /* max-width: 940px; */
  margin-left: auto;

  margin-right: auto;
  display: block;
}
.g2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.lower-map {
  margin-top: 20%;
  margin-bottom: 10%;
  margin-left: 10%;
  margin-right: 10%;
  width: 80%;
  height: 80%;
  object-fit: cover;
}

.award-loading {
  font-size: .5rem;
  color: #ededed;
  text-align: center;
}

@media screen and (max-width: 991px) {
  .w-layout-blockcontainer {
    max-width: 728px;
  }
  
  .vineyerd-block-moblie {
    display: block !important;
    background-image: url('../images/greenback-tile.webp');
    background-position: 0 0;
    background-size: auto;
    padding-top: 40px;
    padding-bottom: 80px;
  }
  
  .footer-company-info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    padding: 0;
    width: fit-content;
  }
  
  .company-blk, .hour-blk {
    width: 100%;
    margin-bottom: 20px;
  }
  
  .top-helo {
    margin-top: 90px; /* タブレットサイズでのグローバルメニューの高さに合わせて調整 */
  }
  
  .tour-info-section {
    padding: 40px 0;
  }
  
  .tour-info-container {
    padding: 0 15px;
  }
  
  .tour-info-item {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  

  
  .tour-info-content {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .w-layout-blockcontainer {
    max-width: none;
  }
  
  .top-helo {
    margin-top: 80px; /* モバイルサイズでのグローバルメニューの高さに合わせて調整 */
    height: 560px; /* モバイルでは高さも調整 */
  }
  
  .logos {
    width: 140px; /* スマホでは少し小さくする */
  }
  
  .award-row {
    margin-left: 0;
    margin-right: 0;
    padding-top: 8px;
    padding-bottom: 8px;
  }
  
  .award-title, .award-detail {
    font-size: 0.8rem; /* 文字サイズを小さく */
    line-height: 1.5rem; /* 行間も調整 */
  }
  
  .award-title {
    font-weight: 700; /* 太字に */
  }
  
  .award-detail {
    padding-left: 0;
    padding-right: 0;
  }

  /* --- 会社概要テーブル スマホ表示調整 --- */


  .c-table-title {
    flex: 0 0 30%; /* タイトルの幅を30%に固定 (必要なら調整) */
    width: 30%; /* フォールバック/互換性のため */
    max-width: 30%;
    padding-right: 10px; /* タイトルと内容の間に少し余白 */
    box-sizing: border-box;
  }

  .c-table-content {
    flex: 1 1 70%; /* 内容の幅を残り70%で可変に */
    width: 70%; /* フォールバック/互換性のため */
    max-width: 70%;
    box-sizing: border-box;
  }

  /* 文字が小さすぎる場合は調整 */
  /* .small-font-lite { */
    /* 必要であればフォントサイズを調整 */
    /* font-size: 0.8rem; */
  /* } */

  /* .w-container,
  .winary-container {
    padding-left: 5% !important;
    padding-right: 5% !important;
  } */

  
  /* ... 他のスマホ用スタイル ... */

  /* --- winary-helo スマホ表示調整 --- */
  /* ... winary-helo styles ... */

  /* ... winary-catch, wine-intro-text-font padding reset ... */

  /* 会社概要テーブルのスマホ調整はこの下に追加される想定 */
  /* ... c-table-row styles ... */

  /* 受賞歴テーブルのスマホ調整はこの下に追加される想定 */
  /* ... award-title/detail styles ... */

  .map-wrapper {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    margin-bottom: 20px;
  }
  
  .tour-info-section {
    padding: 40px 0;
  }
  
  .tour-info-item {
    padding: 15px;
  }

  .tour-info-number {
    font-size: 18px;
    margin-bottom: 10px;
  }
  
  .tour-info-text {
    font-size: 14px;
    line-height: 1.5;
  }
  
  /* 受賞年号を小さく */
  .award-year-font {
    font-size: 1rem;
    line-height: 1.6rem;
  }
  
  /* ステータスアイコンをさらに小さく */
  .award-table-status {
    width: 16px;
    margin-left: 5px;
    margin-right: 5px;
  }
  
  .award-table-status img {
    width: 14px;
  }
  
  /* ヘッダーのパディングを調整 */
  .award-open-header,
  .award-close-header {
    padding: 6px 10px;
  }
}



.winary_section {
  grid-column-gap: 20px;
  grid-row-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: none;
  height: auto;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.title_blk {
  grid-column-gap: 10px;
  flex: 0 auto;
  justify-content: center;
  align-items: center;
  height: 272px;
  padding: 60px 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.line {
  grid-column-gap: 10px;
  outline-offset: 0px;
  border: 1px solid #eddfdf;
  outline: 3px #333;
  flex: 0 auto;
  justify-content: flex-end;
  align-items: center;
  height: 152px;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.text_wrapper {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  height: 152px;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.upper {
  grid-column-gap: 10px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 61px;
  padding: 8px 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.text {
  color: #9f9696;
  letter-spacing: .1em;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 100%;
  text-decoration: none;
}

.lower {
  grid-column-gap: 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 61px;
  padding: 6px 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.photo_blk {
  grid-column-gap: 10px;
  object-fit: cover;
  justify-content: flex-start;
  align-items: center;
  width: 70%;
  height: auto;
  padding: 0 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.body {
  color: #9f9696;
  background: none; 
  font-weight: 600;
}

.zenkoji_section {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding: 80px 10px;
  font-size: 1.5rem;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.winary_section-2 {
  grid-column-gap: 20px;
  flex: 1;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 470px;
  display: flex;
  overflow: hidden;
}

.title_blk-2 {
  grid-column-gap: 10px;
  flex-flow: row;
  flex: 0 auto;
  justify-content: flex-start;
  align-items: flex-start;
  height: 272px;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.line-2 {
  grid-column-gap: 10px;
  flex: 0 auto;
  justify-content: flex-end;
  align-items: center;
  height: 152px;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.lower-2 {
  grid-column-gap: 10px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 61px;
  padding: 6px 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.text-5 {
  text-align: left;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
}

.photo_blk-2 {
  grid-column-gap: 10px;
  object-fit: cover;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 470px;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.winary_content {
  grid-column-gap: 10px;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding: 10px;
  font-family: 'Zen Old Mincho', serif;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.space-wrapper {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 120px;
  height: 890px;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.about-contents {
  grid-column-gap: 10px;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding-top: 10px;
  padding-bottom: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.content_wrapper {
  grid-row-gap: 60px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 894px;
  padding: 10px 20px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.text_blk {
  grid-row-gap: 10px;
  border: 0 solid #fff8ef;
  border-left-width: 1px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding: 10px 40px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.table-style {
  border: 1px solid #949494;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  font-size: 1.2rem;
  text-decoration: none;
  display: flex;
}

.table-row {
  overflow: hidden;
}

.title-style {
  background-color: #efe5db;
  border: 0 solid #230303;
  border-bottom-width: 1px;
  justify-content: center;
  align-items: center;
  width: 140px;
  padding-top: 10px;
  padding-bottom: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.value {
  border: 0 solid #efe5db80;
  border-bottom-width: 1px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 1042px;
  padding: 10px 20px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.wine {
  grid-row-gap: 20px;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  width: 300px;
  height: auto;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.photo_wrapper {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.wine_photo {
  object-fit: cover;
}

.wine_intoro {
  grid-row-gap: 20px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.button_rite {
  grid-column-gap: 10px;
  border: 1px solid #7e7e7e;
  justify-content: flex-start;
  align-items: center;
  padding: 16px 20px;
  text-decoration: none;
  display: flex;
  position: relative;
}

.button_txt {
  color: #efe5db;
  letter-spacing: .1em;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1rem;
  font-weight: 500;
  line-height: 35px;
  text-decoration: none;
}

.arrow {
  border-style: solid;
  border-width: undefinedpx;
  object-fit: cover;
  border-color: #efe5db;
  position: absolute;
  top: 22px;
  left: 180px;
}

.wine-catch {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: center;
  width: auto;
  height: 300px;
  padding-left: 0;
  padding-right: 0;
  line-height: 350px;
  display: flex;
}

.chatch {
  flex: 0 auto;
  order: 1;
  width: auto;
  padding-left: 20px;
  padding-right: 20px;
  display: block;
}

.catch_photo {
  background-image: url('../images/start2.webp');
  background-position: 50%;
  background-size: cover;
  flex: 0 auto;
  height: 300px;
  display: block;
  overflow: visible;
  transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform: scale(1.1);
  will-change: transform;
}

.catch_photo.akino {
  background-image: url('../images/photo_blk.webp');
}

.catch_photo.tokoji {
  background-image: url('../images/tokoji.webp');
}

.image {
  width: 100%;
  height: 300px;
}

.catch-text-blk {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: row;
  flex: 0 auto;
  justify-content: flex-start;
  align-self: stretch;
  align-items: center;
  display: flex;
}

.catch-text-blk.r {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: flex-end;
  align-items: center;
}

.catch-text {
  color: #9f9696;
  flex: 0 auto;
  padding-left: 0;
  font-family: 'Zen Old Mincho', serif;
  font-size: 2rem;
  font-weight: 400;
  line-height: 60px;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(15px);
  transition: opacity 0.6s ease-out, filter 0.8s ease-out, transform 0.6s ease-out;
  will-change: opacity, filter, transform;
}

.catch-text.delay-1 { transition-delay: 0.1s; }
.catch-text.delay-2 { transition-delay: 0.2s; }
.catch-text.delay-3 { transition-delay: 0.3s; }

.catch-blk-space {
  width: 20%;
}

.catch-blk-space.under0line {
  border-bottom: 1px solid #757575;
  flex-flow: column;
  width: 20%;
  height: auto;
  display: flex;
}

.t-white {
  color: #fff;
}

.t-red {
  color: #d34444;
}

.image-2 {
  width: auto;
  height: 300px;
}

.wine-intoroduce {
  justify-content: flex-start;
  align-items: stretch;
  margin-top: 40px;
  margin-bottom: 40px;
  display: flex;
}

.wine-intoro-r {
  text-align: center;
  flex-flow: column;
  justify-content: flex-end;
  align-items: center;
  width: 30%;
  display: flex;
}

.wine-intoro-l {
  width: 70%;
  display: flex;
}

.wine-intoro-table-wrapper {
  /* border: 1px solid #474747; を削除 */
  border: 1px solid #5c5c5c; /* テーブル全体に境界線を追加 */
  flex-flow: column;
  align-items: stretch;
  width: 100%;
  margin-top: 20px;
  margin-bottom: 20px;
  display: flex;
}

._w-space {
  width: 10%;
}

.div-block-2, .wine-intoro-contents-wrapper {
  flex: 1;
}

.wine-intro-text-font {
  border-left: 1px solid #616161;
  color: #9f9696;
  margin-top: auto;
  padding-bottom: 20px;
  padding-left: 20px;
  padding-right: 20px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.nomal-font {
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.5rem;
  line-height: 1.8rem;
}

.small-font {
  color: #000;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.6rem;
}

.small-font.bold {
  font-weight: 700;
}

.small-font.white {
  color: #fff;
}

.col-title {
  color: #66180f;
  text-align: center;
  background-color: #efe5db;
  border-bottom: 1px solid #3f3636;
  flex-flow: row;
  justify-content: center;
  align-items: stretch;
  height: auto;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
}

.col-content {
  border-bottom: 1px solid #4e4e4e;
  flex: 0 auto;
  padding-top: 10px;
  padding-bottom: 10px;
}

.wine-name-wrapper, .online-shop-button-wrapper {
  margin-top: 20px;
  margin-bottom: 20px;
}

.columns {
  display: flex;
}

.wine-photo {
  height: 300px;
  width: auto;
  max-height: 300px;
  object-fit: contain;
}

.ss-font {
  font-family: 'Zen Old Mincho', serif;
  font-size: .8rem;
  line-height: 1.1rem;
}

.ss-font.winary {
  color: #9f9696;
}

.ss-font.white {
  color: #cdcdcd;
}


.button {
  background-color: #464646;
  border: 1px solid #616161;
}

.wine-catch-2 {
  flex-flow: row;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.t-green {
  color: #7ed109;
}

.helo-back {
  background-image: url('../images/awards.webp');
  background-position: 50% 0;
  background-size: cover;
  width: 100%;
  height: 720px;
  margin-bottom: 40px;
}

.helo-back.about {
  background-image: url('../images/Helo＿Section.webp');
  background-position: center center;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  -webkit-perspective: 1000;
}

.helo-back.history {
  background-image: url('../images/rekishi.webp');
  background-position: center center;
  background-size: cover;
  width: auto;
  height: 350px;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  -webkit-perspective: 1000;
}

.helo-back.company {
  background-image: url('../images/campany-helo.webp');
  background-position: center center;
  background-size: cover;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  -webkit-perspective: 1000;
}

.container {
  max-width: 1200px;
}

.t-blue {
  color: #7ba7ff;
}

.helo {
  max-width: 1440px;
}

.menu {
  grid-column-gap: 64px;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 1440px;
  padding: 33px 20px;
  text-decoration: none;
  display: flex;
  margin: 0 auto;
}

.logos {
  object-fit: contain; /* coverからcontainに変更 */
  justify-content: center;
  align-items: center;
  height: auto; /* 固定高さから自動調整に変更 */
  width: 161px; /* 幅を明示的に指定 */
  text-decoration: none;
  display: flex;
}

.menu-2 {
  grid-column-gap: 12px;
  justify-content: flex-end;
  padding-right: 20px;
  align-items: center;
  width: 100%;
  max-width: 979px;
  text-decoration: none;
  display: flex;
}

.menuitem {
  color: #fff8ef;
  letter-spacing: .1em;
  margin-top: 0;
  margin-bottom: 0;
  font-family: 'Zen Old Mincho', serif;
  font-size: .8rem;
  font-weight: 400;
  line-height: 1rem;
  text-decoration: none;
}

.h-menu {
  cursor: pointer;
  position: relative;
  z-index: 1001;
  display: flex;
  flex-direction: column; /* 縦並びに変更 */
  align-items: center;
  justify-content: center;
}

.hamburger-icon {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 24px;
  height: 18px;
  margin-bottom: 8px; /* 下側のマージンを増やす */
  margin-right: 0; /* 横のマージンを削除 */
}

.hamburger-line {
  width: 100%;
  height: 2px;
  background-color: #fff8ef;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.h-menu.open .hamburger-line:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}

.h-menu.open .hamburger-line:nth-child(2) {
  opacity: 0;
}

.h-menu.open .hamburger-line:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.95);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 999;
  transform: translateX(100%);
  transition: transform 0.3s ease;
}

.mobile-menu.open {
  transform: translateX(0);
  z-index: 999;
}

.mobile-menu-item {
  margin: 15px 0;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.0rem;
  color: #fff8ef;
}

.text-9 {
  color: #fff8ef;
  letter-spacing: .1em;
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Montserrat, sans-serif;
  font-size: 12px;
  font-weight: 400;
  line-height: 100%;
  text-decoration: none;
}

.column {
  flex-flow: column;
  align-self: center;
  padding-left: 0;
  padding-right: 0;
  display: flex;
}

.wine-helo {
  flex-flow: row;
  margin-left: 0;
  margin-right: 0;
  display: flex;
}

.column-2 {
  align-self: center;
  padding-top: 40px;
  display: block;
}

.wine-helo2 {
  display: flex;
}

.global-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: rgba(0, 0, 0, 0.3);
  width: 100vw;
  max-width: 100vw;
  padding: 0;
  margin: 0;
  transition: transform 0.6s ease-in-out; /* アニメーション速度を調整 (0.3s -> 0.6s) */
}

/* ヘッダーを非表示にするためのクラス */
.header--hidden {
  transform: translateY(-100%);
}

/* Webフォント読み込み中はメニューを非表示 (スムーズな表示のためopacityを使用) */
html.wf-loading .global-menu {
  opacity: 0;
  /* opacityの変化にもtransitionを適用 */
  transition: opacity 0.2s ease-in-out, transform 0.6s ease-in-out; 
}

/* 読み込み完了時 or 失敗時に表示 */
html.wf-active .global-menu,
html.wf-inactive .global-menu {
  opacity: 1;
}

.global-menu.w-layout-blockcontainer {
  max-width: 100%;
  width: 100%;
}

.fotter {
  flex-flow: row;
  display: flex;
}

.campany-info-blk {
  flex-flow: column;
  display: flex;
}

.footer {
  flex-flow: column;
  margin-bottom: 140px;
  margin-left: 100px;
  margin-right: 100px;
  display: flex;
}

.campany-info {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: column;
  display: flex;
}



.company-info-header {
  color: #a1a1a1;
  margin-top: 20px;
  margin-bottom: 20px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.5rem;
  line-height: 2rem;
}

.hour-header {
  color: #a1a1a1;
  margin-bottom: auto;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.adress {
  grid-row-gap: 4px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding: 10px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.instagram {
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 20px;
  height: 20px;
  text-decoration: none;
  display: flex;
}

.footer-menu-wrapper {
  display: flex;
  flex-direction: column;
  align-self: center;
  width: fit-content; /* 幅を内容に合わせる */
}

.title-compornent {
  flex-flow: column;
  margin-top: 20px;
  margin-bottom: 20px;
  display: flex;
}

.title-en-wrapper, .title-jp-wrapper {
  display: flex;
  
}

.space {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 10%;
  display: flex;
  /* 線が飛び出さないように調整 */
  overflow: hidden;
}

/* ツアー情報ページの見出し用のspace要素のスタイル調整 */
.tour-info-section .space img,
.tour-details-section .space img {
  max-width: 100%;
  height: auto;
}

.english-text {
  color: #fff1e0;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 2.4rem;
  line-height: 3rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: flex;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
}

.japanese-text {
  color: #dbdbdb;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.5rem;
  line-height: 2.5rem;
  display: flex;
}

.company-info-tbl {
  margin-top: 40px;
  margin-bottom: 40px;
  padding-left: 140px;
  padding-right: 140px;
}

.c-table-row {
  color: #cacaca;
  border-bottom: 1px solid #707070;
}

.c-table-title, .c-table-content {
  padding-top: 20px;
  padding-bottom: 20px;
}

.content-body {
  flex-flow: column;
  padding: 20px 10%;
  display: flex;
}

.content-body.pic {
  padding-top: 10px;
  padding-bottom: 0;
}

.content-body.fasility {
  flex-flow: column;
}

.content-text {
  padding-left: 0%;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.6rem;
}

.text-block-2 {
  font-family: 'Zen Old Mincho', serif;
}

.section {
  margin-bottom: auto;
  color: #9f9696;
}

.section-2 {
  margin-bottom: 100px;
}

.button-wrapper {
  justify-content: flex-end;
  align-items: center;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 20px;
  display: flex;
}

.button-large {
  display: flex;
}

.button-body {
  border: 1px solid #2c2c2c;
  padding: 10px 40px;
  align-items: center;
  position: relative;
  transition: all 0.3s ease;
  display: flex;
}

.button-body-lite {
  display: flex;
  padding: 12px 30px;
  justify-content: center;
  align-items: center;
  gap: 24px;
  align-self: stretch;
  flex-wrap: nowrap;
  transition: all 0.3s ease;
}

.button-body.white {
  border-color: #fff;
}

.image-arrow {
  position: absolute;
  top: 50%;
  right: -20px;
  transform: translateY(-50%);
  height: 1em;
  width: auto;
  transition: transform 0.3s ease;
}

.award-table {
  border: 1px solid #8e8e8e;
  margin: 40px 10%;
  padding-left: 0%;
  padding-right: 0%;
  width: 80%; /* 左右マージンと合わせて100%になるよう設定 */
  box-sizing: border-box; /* ボーダーとパディングを幅に含める */
}

.award-table-row-open {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
  width: 100%; /* 横幅を100%に設定 */
}

.award-table-status {
  width: 20px; /* 30pxから20pxに変更 */
  margin-left: 10px; /* 20pxから10pxに変更 */
  margin-right: 10px; /* 20pxから10pxに変更 */
}

.award-year-font {
  color: #9f9696;
  margin-top: 10px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.2rem;
  line-height: 2rem;
}

.award-open-header {
  border-bottom: 1px solid #797979;
  flex: 1;
  justify-content: space-between;
  align-self: stretch;
  align-items: center;
  padding: 8px 15px; /* 10px 20pxから8px 15pxに変更 */
  display: flex;
  width: 100%;
  box-sizing: border-box;
  cursor: pointer;
}

.award-open-body {
  overflow: hidden;
  transition: max-height 0.8s ease-out, padding 0.5s ease-out, margin 0.5s ease-out;
  max-height: 3000px; /* より大きな値に設定して、ほぼすべての内容を表示できるようにする */
  padding-top: 15px;
  padding-bottom: 15px;
  margin-top: 10px;
  margin-bottom: 10px;
}

.award-row {
  border-bottom: 1px solid #4b4b4b;
  margin-left: 0;
  margin-right: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 5%; /* 左右に10%のパディングを追加 */
  padding-right: 5%; /* 左右に10%のパディングを追加 */
  width: 100%;
  box-sizing: border-box; /* パディングを幅に含める */
}

.award-title {
  color: #9f9696;
  padding-left: 0%;
  padding-right: 0%;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
  width: 100%;
  margin-bottom: 5px;
}

.award-detail {
  color: #9f9696;
  padding-left: 0%;
  padding-right: 0%;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
  width: 100%;
}

.award-close-header {
  border-bottom: 1px solid #7d7d7d;
  justify-content: space-between;
  align-items: center;
  padding: 8px 15px; /* 左右のパディングを調整 */
  display: flex;
  width: 100%;
  box-sizing: border-box;
  cursor: pointer;
}

.section-3 {
  margin-bottom: 40px;
}

.wine-info-table-row {
  border: none; /* 元のボーダーを削除 */
  border-bottom: 1px solid #5c5c5c; /* 下部のボーダーのみ適用 */
  display: flex;
}

/* 最後の行の下部ボーダーを削除 */
.wine-info-table-row:last-child {
  border-bottom: none;
}

/* 既存のスタイルを維持 */
.wine-info-key {
  background-color: #efe5db;
  justify-content: center;
  align-items: flex-start;
  width: 20%;
  padding: 10px;
  display: flex;
  border-right: 1px solid #5c5c5c; /* 右側のボーダーを追加 */
}

.wine-info-value {
  width: 80%;
  padding: 10px;
}

.font-table-key {
  color: #693131;
  text-align: right;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.font-talbe-value {
  color: #9f9696;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.text-span, .text-span-2, .text-span-3, .text-span-4, .text-span-5 {
  font-size: 1.3rem;
}

.text-component-wrapper {
  flex-flow: row;
  display: flex;
}

.lite-text {
  border-left: 1px solid #616161;
  margin-top: auto;
  padding: 0 20px 20px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.8rem;
}

.lite-text.large {
  font-size: 1.2rem;
  line-height: 2rem;
}

.wine-history-wrapper {
  flex: 1;
}

.wine-history-text-wrapper {
  flex: 1;
  margin-right: 10%;
  padding-left: 20px;
  padding-right: 20px;
  padding-bottom: 40px;
  color: #9f9696;
}

.history-table-wrapper {
  background-color: #000000b0;
  margin-top: 20px;
  margin-bottom: 20px;
  padding-top: 40px;
  padding-bottom: 40px;
}

.history-table {
  margin-left: 10%;
  margin-right: 10%;
  display: flex;
  align-items: center; /* 縦方向の中央揃えを追加（横並び時） */
}

.history-table-photo-wrapper {
  flex: 1; /* 横並び時の幅を柔軟に */
  height: 400px; /* 高さを300pxに固定 */
  padding-right: 20px; /* 写真とテーブルの間に余白 */
  box-sizing: border-box;
  overflow: hidden; /* はみ出した画像を隠す */
  display: flex; /* 中の画像を中央揃えするために追加 */
  align-items: center; /* 垂直中央揃え */
  justify-content: center; /* 水平中央揃え */
}

.history-table-photo-wrapper img {
  width: 100%; /* 幅をコンテナに合わせる */
  height: 100%; /* 高さをコンテナに合わせる */
  /* max-width: none; を削除 */
  /* max-height: none; を削除 */
  display: block;
  object-fit: cover; /* アスペクト比を維持しつつコンテナを覆う */
}

.history-table-table-wrapper {
  flex: 1; /* 横並び時の幅を柔軟に */
  align-self: stretch; /* 横並び時に高さを揃える */
  padding-bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: center; /* 縦方向の中央揃え */
}

.history-table-row {
  padding: 4px 20px;
  display: flex;
}

.start-of-photo-wrapper {
  display: flex;
}

.photo-wrapper {
  flex: 1;
}

.photo {
  width: 100%;
  height: 100%;
  display: block;
}

.footer-company-info {
  display: flex;
  flex-direction: column;
  width: fit-content; /* 幅を内容に合わせる */
  align-self: flex-start; /* 親要素がflexの場合に左寄せ */
  margin: 0; /* マージンをリセット */
  margin-right: 40px; /* 右マージンを40pxに設定 */
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

.footer-wrapper {
  color: #a1a1a1;
  margin-top: 20px;
  margin-bottom: 0;
  font-family: 'Zen Old Mincho', serif;
  display: flex;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 10%;
  padding-right: 10%;
  width: 100%;
  box-sizing: border-box;
}

.copyright-wrapper {
  text-align: center;
  font-family: 'Zen Old Mincho', serif;
  margin-bottom: 60px; /* ショートカットメニューの高さ分マージンを追加 */
}

.sns-blk {
  padding-top: 10px;
  padding-bottom: 10px;
}

.company-info-font {
  color: #a1a1a1;
  font-family: 'Zen Old Mincho', serif;
  font-size: .8rem;
  line-height: 1.6rem;
}

.company-info-font.atention {
  margin-top: 20px;
}

/* .company-info-font-ss {
  padding-bottom: 10px;
  font-family: Noto Serif JP, sans-serif;
  font-size: .8rem;
  line-height: 1.6rem;
} */

.footer-menu-font {
  font-family: 'Zen Old Mincho', serif;
  font-size: .8rem;
  line-height: 1.6rem;
}

.text-block-3 {
  color: #a1a1a1;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: .8rem;
  line-height: 1rem;
}

.line-wrapper {
  text-align: center;
  padding-top: 20px;
  padding-bottom: 20px;
}

.then-wrapper {
  margin-bottom: 20px;
}

.then{
  padding-top: 30px;

}
.section-4 {
  margin-bottom: 100px;
}

.history-section {
  background-image: url('../images/background.webp');
  background-position: 0 0;
  background-size: auto;

}

.start-section {
  background-repeat: repeat-y;
  background-size: contain;
  background-attachment: scroll;
  padding-top: 40px;
}


.real-d-or-section {
  padding-top: 40px;
  padding-bottom: 40px;
}

.winary-helo-1 {
  display: flex;
}

.winary-catch {
  flex: 0 auto;
  justify-content: flex-start;
  align-items: stretch;
  padding-left: 40px;
  padding-right: 40px;
  display: flex;
}

.winary-catch-photo {
  flex: 1;
  overflow: hidden;
}

.catch-space {
  display: flex;
  align-items: center;
  filter: brightness(0.5);
}

.catch-body {
  text-align: left;
  flex-flow: column;
  flex: 0 auto;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.winary-helo-2 {
  display: flex;
}

.top-helo {
  position: relative;
  max-width: 1440px;
  margin: 0 auto;
  height: 720px;
  overflow: hidden;
  margin-top: 117px; /* グローバルメニューの実際の高さに合わせて調整（33px上部パディング + 51px高さ + 33px下部パディング） */
}

.slideshow-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0; /* Start hidden */
  transform-origin: center;
  filter: blur(10px);
  animation-duration: 35s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

/* Assign animation names to each slide */
.slide:nth-child(1) {
  animation-name: slideShow1;
}

.slide:nth-child(2) {
  animation-name: slideShow2;
}

.slide:nth-child(3) {
  animation-name: slideShow3;
}

.slide:nth-child(4) {
  animation-name: slideShow4;
}

.slide:nth-child(5) {
  animation-name: slideShow5;
}

.footer-menu{
  /* display: flex; */
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: 30px;
  padding: 20px 0;
  width: fit-content; /* 幅を内容に合わせる */
  align-self: flex-start; /* 親要素(.footer-wrapper)内で左寄せ */
  align-items: flex-start; /* 子要素(.footer-menu-wrapper)を左寄せ */
}

.winary-container {
  display: flex;
  flex-direction: column;
  padding-left: 10%;
  padding-right: 10%;
}

/* Define new keyframes for each slide over the 35s cycle with adjusted zoom */
@keyframes slideShow1 {
  /* Start blurred and zoomed in slightly more */
  0%      { opacity: 0; filter: blur(10px); transform: scale(1.1); }
  /* Fade in, focus, and zoom out slightly over 2s */
  5.7%    { opacity: 1; filter: blur(0);    transform: scale(1.05); }  /* 2s */
  /* Continue zooming out slowly to normal size over 5s */
  20%     { opacity: 1; filter: blur(0);    transform: scale(1); }    /* 7s */
  /* Fade out and blur over 2s, maintaining normal size */
  25.7%   { opacity: 0; filter: blur(10px); transform: scale(1); }    /* 9s */
  /* Stay hidden */
  100%    { opacity: 0; }
}

@keyframes slideShow2 {
  0%      { opacity: 0; }
  /* Start at 7s: blurred and zoomed in slightly more */
  20%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }  /* 7s */
  /* Fade in, focus, zoom out slightly over 2s */
  25.7%   { opacity: 1; filter: blur(0);    transform: scale(1.05); }  /* 9s */
  /* Continue zooming out slowly to normal size over 5s */
  40%     { opacity: 1; filter: blur(0);    transform: scale(1); }    /* 14s */
  /* Fade out and blur over 2s, maintaining normal size */
  45.7%   { opacity: 0; filter: blur(10px); transform: scale(1); }    /* 16s */
  100%    { opacity: 0; }
}

@keyframes slideShow3 {
  0%      { opacity: 0; }
  /* Start at 14s */
  40%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }  /* 14s */
  /* Fade in, focus, zoom out slightly over 2s */
  45.7%   { opacity: 1; filter: blur(0);    transform: scale(1.05); }  /* 16s */
  /* Continue zooming out slowly to normal size over 5s */
  60%     { opacity: 1; filter: blur(0);    transform: scale(1); }    /* 21s */
  /* Fade out and blur over 2s, maintaining normal size */
  65.7%   { opacity: 0; filter: blur(10px); transform: scale(1); }    /* 23s */
  100%    { opacity: 0; }
}

@keyframes slideShow4 {
  0%      { opacity: 0; }
  /* Start at 21s */
  60%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }  /* 21s */
  /* Fade in, focus, zoom out slightly over 2s */
  65.7%   { opacity: 1; filter: blur(0);    transform: scale(1.05); }  /* 23s */
  /* Continue zooming out slowly to normal size over 5s */
  80%     { opacity: 1; filter: blur(0);    transform: scale(1); }    /* 28s */
  /* Fade out and blur over 2s, maintaining normal size */
  85.7%   { opacity: 0; filter: blur(10px); transform: scale(1); }    /* 30s */
  100%    { opacity: 0; }
}

@keyframes slideShow5 {
  0%      { opacity: 0; }
  /* Start at 28s */
  80%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }  /* 28s */
  /* Fade in, focus, zoom out slightly over 2s */
  85.7%   { opacity: 1; filter: blur(0);    transform: scale(1.05); }  /* 30s */
  /* Continue zooming out slowly to normal size until end of cycle (35s) */
  99.99%  { opacity: 1; filter: blur(0);    transform: scale(1); }    /* Hold at normal size until just before loop ends */
  /* End blurred and zoomed in to match slide 1 start */
  100%    { opacity: 0; filter: blur(10px); transform: scale(1.1); } /* Match start state for smooth loop */
}

/* Keep logos on top and center them */
.logo-1, .logo-2 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10; /* Ensure logos are above the slideshow */
  animation-duration: 8s; /* Changed from 6s to 8s */
  animation-timing-function: ease-in-out; /* Use ease-in-out for smoother feel */
  animation-iteration-count: 1;
  animation-fill-mode: forwards; /* Keep final state */
}

.logo-1 {
  opacity: 1; /* Start visible */
  width: 200px; /* Keep specific width if needed */
  animation-name: logoFadeOutProfessional;
}

.logo-2 {
  opacity: 0; /* Start hidden */
  width: 200px; /* Keep specific width if needed */
  animation-name: logoFadeInProfessional;
}

/* Rename and redefine keyframes for 8s duration with blur/zoom */
@keyframes logoFadeOutProfessional {
  0%      { opacity: 1; filter: blur(0px); transform: translate(-50%, -50%) scale(1); }
  75%     { opacity: 1; filter: blur(0px); transform: translate(-50%, -50%) scale(1); } /* 6s: Start fade */
  100%    { opacity: 0; filter: blur(4px); transform: translate(-50%, -50%) scale(1.03); } /* 8s: Faded out, slightly blurred and zoomed */
}

@keyframes logoFadeInProfessional {
  0%      { opacity: 0; filter: blur(4px); transform: translate(-50%, -50%) scale(1.03); } /* Start matching end state of logo-1 */
  75%     { opacity: 0; filter: blur(4px); transform: translate(-50%, -50%) scale(1.03); } /* 6s: Start fade */
  100%    { opacity: 1; filter: blur(0px); transform: translate(-50%, -50%) scale(1); } /* 8s: Faded in, sharp, normal size */
}

/* Remove old logo keyframes */
/*
@keyframes logoFadeOut {
  0%      { opacity: 1; }
  83.33%  { opacity: 1; } 
  100%    { opacity: 0; }
}

@keyframes logoFadeIn {
  0%      { opacity: 0; }
  83.33%  { opacity: 0; } 
  100%    { opacity: 1; }
}
*/

.message-top {
  flex-flow: row;
  justify-content: center;
  align-items: center;
  margin-top: 40px;
  margin-bottom: 40px;
  display: flex;
}

.message-1 {
  margin-left: 5%;
  margin-right: 25%;
}

.text-block-4 {
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.message-section {
  margin-top: 100px;
  margin-bottom: 100px;
}

.slider {
  margin-bottom: 60px;
  display: flex;
  overflow: hidden;
  width: 100%; /* 変更: 幅を100%に */
  position: relative; /* 追加: 位置基準 */
}

.slider-photo-wrapper {
  flex: 0 0 auto;
  display: flex;
  width: calc(100% / 4); /* 変更: PCでは4枚表示 */
  padding: 0 5px; /* 追加: 画像間の余白 */
  box-sizing: border-box; /* 追加: ボックスモデル */
}

.silder-photo {
  width: 100%; /* 追加: 幅100% */
  height: auto; /* 追加: 高さ自動 */
  object-fit: cover; /* 追加: 画像サイズ調整 */
}

.slider-container {
  overflow: hidden; /* 追加: はみ出した部分を隠す */
  position: relative; /* 追加: 位置基準 */
  width: 100%; /* 追加: 幅100% */
  margin-bottom: 60px; /* 移動: スライダーのマージン */
}

.slider-track {
  display: flex; /* 追加: 横並び */
  width: max-content; /* 追加: 内容に合わせて幅を確保 */
  animation: none; /* 初期値: JavaScriptで制御 */
}

@keyframes slideScroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%); /* 半分移動 */
  }
}

/* スマホ表示時のスライダー調整 */
@media screen and (max-width: 767px) {
  .slider-container {
    margin-bottom: 40px;
  }
  
  .slider-photo-wrapper {
    width: calc(100% / 2); /* スマホでは2枚表示 */
  }
}

/* タブレット表示時の調整 */
@media screen and (min-width: 768px) and (max-width: 991px) {
  .slider-photo-wrapper {
    width: calc(100% / 3); /* タブレットでは3枚表示 */
  }
}

.section-helo {
  background-image: url('../images/vineyard.webp');
  background-position: 50%;
  background-size: cover;
  height: 350px;
  display: flex;
}

/* フェードイン アニメーション用のクラス */
.fade-element {
  opacity: 0;
  transform: translateY(30px); /* 少し下にずらす量を増やす */
  transition: opacity 0.7s ease-out, transform 0.7s ease-out; /* ease-outで表示をスムーズに */
}

.fade-element.visible {
  opacity: 1;
  transform: translateY(0);
}

/* フェードイン処理のディレイ設定 */
.fade-delay-1 {
  transition-delay: 0.2s;
}

.fade-delay-2 {
  transition-delay: 0.4s;
}

.fade-delay-3 {
  transition-delay: 0.6s;
}

/* アンカーリンク対象要素のスクロールマージン設定 */
section[id], div[id] {
  scroll-margin-top: 80px; /* グローバルメニューの高さに合わせて調整 */
}

/* モバイル用の調整 */
@media screen and (max-width: 767px) {
  section[id], div[id] {
    scroll-margin-top: 70px; /* モバイル用メニューの高さに合わせて調整 */
  }
}

.about-section {
  background-image: url('../images/parchment.webp');
  background-position: 50%;
  background-repeat: repeat-x;
  background-size: cover;
  background-attachment: scroll;
  padding-bottom: 60px;
}

.button-wrapper-about {
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 20px;
}

.section-helo.access {
  background-image: url('../images/access_top.webp');
  background-size: cover;
  height: 350px; /* 高さを固定 */
  margin-bottom: 60px;
}

.vineyard-blok-pc {
  background-image: url('../images/greenback-tile.webp');
  background-position: 0 0;
  background-size: auto;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: auto;
  padding-top: 0;
  display: flex;
  position: relative;

}

.english-text--dark {
  color: #7b6666;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 2.4rem;
  line-height: 3rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: flex;
}

.japanese-text--dark {
  color: #4e4e4e;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.5rem;
  line-height: 2.5rem;
  display: flex;
}

.history-text-dark {
  color: #4e4e4e;
  border-left: 1px solid #616161;
  margin-top: auto;
  padding: 0 20px 20px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.8rem;
}

.history-text-dark.large {
  color: #0d0d0d;
  font-size: 1.1rem;
  line-height: 2rem;
}

.button-large-dark {
  color: #000;
  margin-top: 10px;
  display: flex;
}

._w-space2 {
  width: 10%;
}

.button-wrapper-vineyerd {
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* ボタンを左揃え */
  gap: 10px; /* ボタン間のスペース */
}

.intoro-part {
  flex-flow: row;
}

.bottom-map {
  margin-left: 10%;
  margin-right: 10%;
  position: relative;
}

.upper-map {
  position: absolute;
}

.fix-part {
  z-index: 2;
  flex-flow: column;
  align-self: stretch;
  padding-top: 20px;
  display: flex;
  position: absolute;
  inset: 0% 0% auto;
}

.container-2 {
  position: relative;
}

/* Safariに対応するためのスタイル追加 */
@media not all and (min-resolution:.001dpcm) { 
  @supports (-webkit-appearance:none) {
    .helo-back--tour,
    .helo-back--tour.about,
    .helo-back--tour.history,
    .helo-back--tour.company {
      background-attachment: scroll !important; /* Safariでは固定背景を使わない */
      background-position: center center !important;
      -webkit-transform: translateZ(0) !important;
      -webkit-backface-visibility: hidden !important;
      -webkit-perspective: 1000 !important;
    }
  }
}

.helo-back--tour {
  position: relative; /* 疑似要素の基準 */
  overflow: hidden; /* グラデーションがはみ出ないように */
  opacity: 1;
  background-image: url('../images/cellar.webp');
  background-position: center center;
  background-size: cover;
  background-attachment: fixed; /* パララックス効果（Safari以外） */
  width: 100%;
  margin-top: auto;
  margin-bottom: auto;
  padding-top: 60px;
  padding-bottom: 60px;
}


.helo-back--tour.about {
  background-image: url('../images/Helo＿Section.webp');
  background-position: center center;
  background-size: cover;
  image-rendering: -webkit-optimize-contrast; /* Safari画像品質向上 */
}

.helo-back--tour.history {
  background-image: url('../images/rekishi.webp');
  background-position: center center;
  background-size: cover;
  width: auto;
  height: 350px;
  image-rendering: -webkit-optimize-contrast; /* Safari画像品質向上 */
}

.helo-back--tour.company {
  background-image: url('../images/campany-helo.webp');
  background-position: center center;
  background-size: cover;
  image-rendering: -webkit-optimize-contrast; /* Safari画像品質向上 */
}

.lite-text--whitte {
  color: #fffcf8;
  border: 1px #fff;
  margin-top: auto;
  padding: 0 20px 20px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.8rem;
}

.lite-text--whitte.tour {
  color: #b9b9b9;
}

.lite-text--whitte.large {
  font-size: 1.2rem;
  line-height: 2rem;
}

.button-large-lite {
  display: flex;
}

.tour-blk {
  border-left: 1px solid #fff;
  padding-left: 20px;
}

.news-content-body {
  margin-left: 10%;
  margin-right: 10%;
}

.news-wrapper {
  border-bottom: 1px solid #898989;
  margin-bottom: 10px;
}

.news-day-font {
  color: #a3a3a3;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.2rem;
  line-height: 2rem;
}

.news-content-text {
  color: #dadada;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.sns-wrappter {
  grid-column-gap: 7px;
  grid-row-gap: 7px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.news-section {
  margin-top: 60px;
  margin-bottom: 60px;
}

.access-section {
  margin-bottom: 40px;
}

.map-wrapper {
  flex: 1;
}

.map-info-wrapper {
  flex: 1;
  padding-left: 20px;
  padding-right: 20px;
}

.facility-blk {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex: 1;
  margin-bottom: 20px;
  display: flex;
}

.facility-photo-blk {
  flex: 1;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.facility-info-blk {
  flex: 1;
}

.font-title {
  color: #1c1c1c;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.2rem;
  line-height: 1.8rem;
}

.font-title.white {
  color: #ededed;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 2rem;
}

.font-nomal {
  color: #202020;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 2rem;
}

.font-nomal.white {
  color: #d7d7d7;
  padding-bottom: 20px;
  font-size: .8rem;
  line-height: 1.6rem;
}

.messege-top {
  font-family: 'Zen Old Mincho', serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 3rem;
}

.messege-top.white {
  color: #a1a1a1;
}

.message-1-text {
  margin-top: 60px;
  margin-bottom: 60px;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.message-1-text.white {
  color: #a1a1a1;
}

.message-2-text {
  margin: 40px 5% 40px 25%;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.message-2-text.white {
  color: #a1a1a1;
}

.body-2 {
  background-color: #0e0101;
  background-image: none;
  margin-bottom: 10px;
  margin-right: 10px;
}

.silder-photo {
  flex: 1;
}

.bunner {
  flex: 1;
  order: 1;
  align-self: auto;
  width: auto;
  max-width: none;
  display: block;
}

.vineyerd-block-moblie {
  display: none;
}

.container-3 {
  position: absolute;
  inset: 0% 0% auto;
}

.small-font-lite {
  color: #a9a9a9;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.6rem;
}

.small-font-lite.bold {
  font-weight: 700;
}

.small-font-lite.white {
  color: #fff;
}

.small-font-co {
  color: #000;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 1.6rem;
}

.small-font-co.bold {
  font-weight: 700;
}

.small-font-co.white {
  color: #fff;
}

.button-body-lite {
  border: 1px solid #b7b7b7;
  padding: 10px 40px;
  display: flex;
  position: relative;
}

.button-body-lite.white {
  border-color: #fff;
}

.content-body-access {
  padding-left: 10%;
  padding-right: 10%;
  display: flex;
  gap: 40px;
}

.brillant-section {
  padding-top: 40px;
  margin-bottom: 60px;
}

.shortcut-menu {
  grid-column-gap: 1px;
  grid-row-gap: 4px;
  flex-flow: row;
  justify-content: flex-end;
  align-items: center;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-right: 10px;
  display: flex;
  position: fixed; /* stickyからfixedに変更 */
  bottom: 0;
  right: 0;
  width: 100%;
  z-index: 1000; /* 高いz-indexで他の要素の上に表示 */
}

.s-menu {
  background-color: #566a2d80;
  width: 200px;
  margin-left: 0;
  margin-right: 0;
  padding: 10px 20px;
}

.s-menu-text {
  color: #f1f1f1;
  text-align: center;
  font-family: 'Zen Old Mincho', serif;
  font-size: 1rem;
  line-height: 2rem;
}

.logo-1, .logo-2 {
  position: absolute;
}

@media screen and (max-width: 991px) {
  .button-wrapper-tour {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .map-info-wrapper {
    flex: 1;
    padding-left: 0px;
    padding-right: 0px;
  }


  .winary-container {
    display: flex;
    flex-direction: column;
    /* padding-left: 10%; */
    /* padding-right: 10%; */
  }
  .tour-blk {
    border-left: 0px solid #d321210a;
    padding-left: 20px;
  }
  .facility-info-blk {
    flex: 1;
    padding-left: 20px;
    padding-right: 20px;
  }
  .table-row {
    justify-content: flex-start;
    align-items: stretch;
    display: flex;
  }

  .catch-text-blk {
    padding-top: 10px;
    padding-bottom: 10px;
    display: block;
  }

  .catch-text {
    padding-left: 0;
    font-size: 2rem;
    line-height: 3rem;
  }

  .catch-blk-space {
    width: 20%;
  }

  .catch-blk-space.under0line {
    width: 20%;
    height: auto;
  }

  .wine-intoroduce {
    flex-flow: column;
  }

  .wine-intoro-r {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    flex-flow: row;
    justify-content: center;
    align-self: center;
    align-items: flex-end;
    width: auto;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .wine-intoro-l, .wine-intoro-text-wrapper {
    width: 100%;
  }

  ._w-space {
    width: 0%;
  }

  .wine-intoro-contents-wrapper {
    padding-left: 5%;
    padding-right: 5%;
  }

  .wine-intro-text-font {
    color: #9f9696;
    font-size: 1rem;
  }

  .small-font {
    font-size: .8rem;
    line-height: 1.6rem;
  }

  .small-font.bold {
    text-align: left;
  }

  .col-title {
    justify-content: center;
    align-items: center;
    display: flex;
  }



  .columns-2 {
    display: flex;
  }

  .t-green {
    display: inline;
  }

  .helo-back {
    background-position: 50%;
    height: 400px;
  }

  .helo-back.about {
    background-position: 50%;
    background-size: cover;
    width: auto;
    height: 400px;
  }

  .menu {
    justify-content: space-between;
    align-items: center;
  }

  .menu-2 {
    font-family: 'Zen Old Mincho', serif;
    display: none;
  }

  .column {
    flex-flow: column;
    align-self: center;
    display: flex;
  }

  .column-2 {
    align-self: center;
    padding-top: 0;
  }

  .wine-helo2 {
    flex-flow: row;
    display: flex;
  }

  .global-menu {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .english-text {
    font-family: 'Montserrat', sans-serif;
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 0.05em;
  }

  .japanese-text {
    font-size: 1.2rem;
    line-height: 1.8rem;
  }

  .company-info-tbl {
    padding-left: 20px;
    padding-right: 20px;
  }

  .content-body {
    padding-left: 5%;
    padding-right: 5%;
  }

  .award-table {
    margin-left: 5%;
    margin-right: 5%;
    width: 90%;
    box-sizing: border-box;
  }

  .wine-info-key {
    justify-content: center;
    align-items: center;
  }

  .font-table-key {
    text-align: right;
    font-size: .8rem;
    display: flex;
  }

  .font-talbe-value {
    font-size: .8rem;
    color: #9f9696;
  }

  .text-component-wrapper {
    flex-flow: row;
  }

  .lite-text {
    font-size: 1rem;
  }

  .wine-history-wrapper {
    padding-left: 5%;
    padding-right: 5%;
  }

  .wine-history-text-wrapper {
    margin-right: auto;
  }

  .history-table {
    margin-left: 5%;
    margin-right: 5%;
  }

  .start-of-photo-wrapper {
    flex-flow: column;
  }

  .footer-wrapper {

    flex-direction: column; /* 縦並びにする */
  }

  .section-4 {
    margin-bottom: auto;
  }

  .image-4 {
    flex: 0 auto;
    display: none;
  }

  .image-5 {
    display: none;
  }

  .image-6 {
    order: 1;
    display: none;
  }

  .slider {
    width: auto;
    height: auto;
  }

  .section-helo.access {
    height: 200px; /* 高さを固定 */
  }

  .vineyard-blok-pc {
    display: none;
  }

  .english-text--dark {
    font-family: 'Montserrat', sans-serif;
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 0.05em;
  }

  .japanese-text--dark {
    font-size: 1.2rem;
    line-height: 1.8rem;
  }

  .history-text-dark {
    font-size: 1rem;
  }

  .button-large-dark.mobile {
    margin-right: 60px;
  }

  ._w-space2 {
    width: 0%;
  }

  .bottom-map {
    margin-top: 100px;
  }

  .helo-back--tour {
    background-position: center center;
    background-attachment: scroll; /* モバイルでは固定背景を使わない */
    height: auto;
  }

  .helo-back--tour.about {
    background-position: center center;
    background-size: cover;
    width: auto;
    height: 400px;
  }

  .lite-text--whitte {
    font-size: 1rem;
  }

  .facility-blk {
    flex-flow: column;
  }


  .button-wrapper-vineyerd-mb {
    justify-content: flex-start;
    align-items: center;
    display: flex;
  }


  .image-7 {
    flex: 1;
    display: block;
  }

  .image-8, .image-9, .image-10 {
    flex: 1;
  }

  .small-font-lite {
    font-size: .8rem;
    line-height: 1.6rem;
  }

  .small-font-lite.bold {
    text-align: left;
  }

  .small-font-co {
    font-size: .8rem;
    line-height: 1.6rem;
  }

  .small-font-co.bold {
    text-align: left;
  }

  .content-body-access {
    flex-flow: column;
  }

  .image-11 {
    display: block;
  }

  .fasi-photo {
    flex: 1;
    display: block;
  }

  .shortcut-menu {
    background-color: rgba(0, 0, 0, 0.3); /* モバイルでは背景を少し濃くする */
    padding-right: 0;
    justify-content: center;
    padding-bottom: 15px; /* モバイルでは余白を増やす */
  }

  .s-menu {
    width: 45%; /* 幅を調整して2つのボタンを均等に配置 */
    max-width: 180px;
    margin: 0 5px;
  }
  .s-menu-text {
    font-size: .7rem !important; /* !importantを追加して優先適用 */
    line-height: 1.4rem !important; /* !importantを追加して優先適用 */
  }

  .footer-menu {
    /* display: flex; */
    flex-direction: column;
    /* align-items: center; を削除、基本スタイルのalign-items: flex-start を継承 */
    margin-top: 20px;
    padding-top: 0;
    /* width: fit-content; は継承される */
    /* align-self: flex-start; も継承される */
    align-items: center; /* やはり中央寄せのままにする場合はこちらを有効に */
  }
  
  .footer-company-info {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    padding: 0;
  }
  
  .company-blk, .hour-blk {
    width: 100%;
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 480px) {
  .section-helo.access {
    height: 150px; /* 高さを固定 */
  }

  .news-content-body {
    margin-left: 5%;
    margin-right: 5%;
  }

  /* 横幅が足りないときはボタンを縦並びにする */
  .button-wrapper-vineyerd-mb {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    display: flex;
    gap: 10px; /* ボタン間のスペース */
    margin-bottom: 20px;
  }
  .wine-intoro-contents-wrapper {
    padding-left: 0%;
    padding-right: 0%;
  }

  .helo-back {
    background-position: 50%;
    height: 300px;
  }

  .footer-menu {
    /* display: flex; */
    flex-direction: column;
    align-items: center;
    margin-bottom: 20px;
    padding-left: 0;
    padding-right: 0;
    /* width: fit-content; は継承される */
    /* align-self: flex-start; も継承される */
  }

  .space {
    width: 3%;
  }

  .english-text {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.05em;
  }

  .japanese-text {
    font-size: 1.2rem;
    line-height: 2.2rem;
  }

  .company-info-tbl {
    padding-left: 20px;
    padding-right: 20px;
  }

  /* .content-body {
    padding-left: 0%;
    padding-right: 0%;
  } */
  .content-body .campany{
    padding-left: 20px;
    padding-right: 20px;
  }

  .button-wrapper {
    justify-content: center;
    align-items: center;
  }

  .award-table {
    margin-left: 0%;
    margin-right: 0%;
    width: 100%;
    box-sizing: border-box;
  }

  .wine-history-wrapper {
    padding-left: 0%;
    padding-right: 0%;
  }

  .footer-wrapper {
    flex-flow: column;
  }

  .text-block-3 {
    font-size: .6rem;
  }

  .english-text--dark {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.05em;
  }

  .japanese-text--dark {
    font-size: 1.2rem;
    line-height: 2.2rem;
  }

  .helo-back--tour {
    background-position: 50%;
    height: auto;
  }

  .messege-top.white {
    font-size: 1.5rem;
  }

  .message-1-text.white, .message-2-text.white {
    font-size: 1rem;
    line-height: 1.6rem;
  }

  .s-menu {
    width: 45%; /* スマホサイズでも幅を確保 */
    padding: 8px 10px;
  }

  .s-menu-text {
    font-size: .7rem !important; /* !importantを追加して優先適用 */
    line-height: 1.4rem !important; /* !importantを追加して優先適用 */
  }

  .footer-wrapper {
    padding-left: 5%;
    padding-right: 5%;
  }
  
  .top-helo {
    margin-top: 112px; /* モバイルサイズでのグローバルメニューの高さに合わせて調整 */
    height: 560px; /* モバイルでは高さも調整 */
  }
  
  .logos {
    width: 140px; /* スマホでは少し小さくする */
  }

  /* .container {
    padding-left: 5%;
    padding-right: 5%;
  } */
}

/* メニューホバーエフェクト */
.menuitem a, .footer-menu-font a {
  position: relative;
  text-decoration: none;
}

.menuitem a::after, .footer-menu-font a::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 1px;
  background-color: #efe5db;
  transition: width 0.3s ease;
}

.menuitem a:hover::after, .footer-menu-font a:hover::after {
  width: 100%;
}

/* フッターメニューホバーエフェクト調整 */
.footer-menu-font {
  position: relative;
  margin-bottom: 8px;
}

.footer-menu-font a::after {
  bottom: -2px;
}

/* ショートカットメニューホバーエフェクト */
.s-menu a {
  position: relative;
  text-decoration: none;
  /* 下線表示を完全に削除 */
}

/* 下線アニメーションスタイルを削除 */
/* .s-menu a::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 1px;
  background-color: #efe5db;
  transition: width 0.3s ease;
}

.s-menu a:hover::after {
  width: 100%;
} */

@media screen and (min-width: 992px) {
  .h-menu {
    display: none;
  }
  
  .mobile-menu {
    display: none;
  }
}

/* ページ全体のグラデーション背景 */
.page-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to bottom, #201212, #401E1A 50%, #201212);
  z-index: -1; /* コンテンツの下に配置 */
}

/* カード画像の調整 */
.card-image img {
  width: 100%; /* 横幅をコンテナに合わせる */
  height: auto; /* 高さは自動調整してアスペクト比を維持 */
  display: block; /* 余分なスペースを防ぐ */
}

/* 施設紹介セクションの画像の調整 */
.facility-photo-blk img {
  width: 100%; /* 画像の幅をコンテナの100%にする */
  height: auto; /* 高さは自動調整してアスペクト比を維持 */
  display: block; /* 余分な下スペースを防ぐ */
}

/* ======================================== */
/*           ボタンインタラクション          */
/* ======================================== */

/* --- 共通スタイル --- */
.button-large-dark,
.button-large-lite,
.button-body-lite { /* .button-body-lite を共通セレクタに追加 */
  display: inline-flex;
  transition: transform 0.1s ease;
  cursor: pointer;
}
.s-menu {
  transition: transform 0.1s ease;
  cursor: pointer;
}

/* ボタン内部要素のトランジション (セレクタ調整) */
.button-body,
.button-body-lite { /* .button-body-lite を追加 */
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

/* 矢印のトランジション (変更なし) */
.image-arrow {
  /* ... */
}

/* ボタン内リンクのクリック範囲確保 */
.button-large-dark a,
.button-large-lite a,
.online-shop-button-wrapper a, /* online-shop-button-wrapper 内の a も対象に */
.s-menu a {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* --- ダークボタン (.button-large-dark) --- */
/* (変更なし) */


/* --- ライトボタン (.button-body-lite) のインタラクション --- */
/* ホバー */
.button-body-lite:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

.button-body-lite:hover .image-arrow {
  transform: translateY(-50%) translateX(5px);
}

.button-body-lite:active {
  background-color: rgba(255, 255, 255, 0.2);
}

/* --- 追加：ダークボタン (.button-body) のインタラクション --- */
.button-body:hover {
  background-color: rgba(0, 0, 0, 0.05);
}

.button-body:hover .image-arrow {
  transform: translateY(-50%) translateX(5px);
}

.button-body:active {
  background-color: rgba(0, 0, 0, 0.1);
}

/* --- ショートカットメニュー (.s-menu) --- */
.s-menu:hover {
  background-color: rgba(86, 106, 45, 0.7);
  border-color: #f0f0f0;
}
.s-menu:hover .s-menu-text {
  color: #ffffff;
  /* 下線アニメーションを削除 */
}
.s-menu:active {
  transform: translateY(1px);
  background-color: rgba(86, 106, 45, 0.8);
}

/* === ↓↓↓ 削除されたスタイルを再追加 ↓↓↓ === */

/* ワイナリーキャッチ演出 */
.winary-catch-photo {
  overflow: hidden; /* 拡大時に画像がはみ出ないように */
}
/* 画像の初期スタイル */
.catch_photo {
  transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform: scale(1.1);
  will-change: transform;
}
/* 画面内表示時の画像スタイル */
.winary-helo-1.is-visible .catch_photo,
.winary-helo-2.is-visible .catch_photo {
  transform: scale(1.0);
}
/* テキストの初期スタイル */
.catch-text {
  opacity: 0;
  filter: blur(8px);
  transform: translateY(15px);
  transition: opacity 0.6s ease-out, filter 0.8s ease-out, transform 0.6s ease-out;
  will-change: opacity, filter, transform;
}
/* 画面内表示時のテキストスタイル */
.winary-helo-1.is-visible .catch-text,
.winary-helo-2.is-visible .catch-text {
  opacity: 1;
  filter: blur(0px);
  transform: translateY(0);
}
/* テキスト表示の遅延 */
.catch-text.delay-1 { transition-delay: 0.1s; }
.catch-text.delay-2 { transition-delay: 0.2s; }
.catch-text.delay-3 { transition-delay: 0.3s; }

/* 受賞歴アコーディオン */
.award-open-body {
  overflow: hidden;
  transition: max-height 0.8s ease-out, padding 0.5s ease-out, margin 0.5s ease-out;
  max-height: 3000px; /* より大きな値に設定して、ほぼすべての内容を表示できるようにする */
  padding-top: 15px;
  padding-bottom: 15px;
  margin-top: 10px;
  margin-bottom: 10px;
}
.award-table-row-close .award-open-body {
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0;
  border-width: 0;
}
.award-open-header,
.award-close-header {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%; /* 横幅いっぱいに表示するために追加 */
  box-sizing: border-box; /* パディングを幅に含めるために追加 */
}
.award-table-status img {
  transition: transform 0.5s ease;
  width: 18px; /* 画像サイズを指定 */
  height: auto; /* 縦横比を維持 */
}
.award-table-row-close .award-table-status img {
  transform: rotate(0deg);
}
.award-table-row-open .award-table-status img {
  transform: rotate(180deg);
}

/* 基本スタイルに .wine-name を追加 */
.wine-name {
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
  color: #9f9696;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.8rem;
  margin-top: 10px;
  margin-bottom: 10px;
  text-align: center;
}

/* === ↑↑↑ 削除されたスタイルを再追加 ↑↑↑ === */

/* メディアクエリ内の .wine-name 定義は削除されていることを確認 */
@media screen and (max-width: 767px) {
  /* ... */
  /* .wine-name { ... } はここには無い */
  /* ... */
}

/* === ↓↓↓ スクロールインアニメーション追加 ↓↓↓ === */

/* スクロールインのベース設定 */
.scroll-in {
  opacity: 0;
  transition: opacity 0.8s ease, transform 1s ease, filter 1s ease;
}

/* 左からのアニメーション（wine-intro-text-font、wine-intoro-table-wrapper、fix-part用） */
.scroll-in-left {
  transform: translateX(-50px);
}
.scroll-in-left.visible {
  opacity: 1;
  transform: translateX(0);
}

/* 右からのアニメーション（wine-intoro-r、bottom-map用） */
.scroll-in-right {
  transform: translateX(50px);
}
.scroll-in-right.visible {
  opacity: 1;
  transform: translateX(0);
}

/* 右からぼかし強めのアニメーション（bottom-map用） */
.scroll-in-right-blur {
  transform: translateX(50px);
  filter: blur(10px);
}
.scroll-in-right-blur.visible {
  opacity: 1;
  transform: translateX(0);
  filter: blur(0);
}

/* ディレイ設定 */
.scroll-delay-1 { transition-delay: 0.1s; }
.scroll-delay-2 { transition-delay: 0.2s; }

/* === ↑↑↑ スクロールインアニメーション追加 ↑↑↑ === */

/* === ↓↓↓ 横スクロール問題の修正 ↓↓↓ === */
/* タブレット表示時の横スクロール防止 */
html, body {
  overflow-x: hidden; /* 横スクロールを隠す */
  width: 100%; /* 幅を制限 */
  max-width: 100%; /* 最大幅を制限 */
  position: relative; /* 絶対位置要素の基準 */
}

/* コンテナの幅を制限して横スクロールを防止 */
.w-layout-blockcontainer {
  max-width: 100% !important; /* 重要: 最大幅を確実に制限 */
  box-sizing: border-box; /* パディングを幅に含める */
  overflow-x: hidden; /* 内部の横スクロールも防止 */
}

/* ワイナリー紹介セクションの調整 */
.wine-intoroduce {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

.wine-photo-wrapper {
  height: auto;
  max-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wine-photo-wrapper img {
  max-width: 100%;
  max-height: 300px;
  width: auto;
}

@media screen and (max-width: 991px) {
  /* タブレットサイズでのグローバルメニュー調整 */
  .global-menu {
    width: 100%;
    max-width: 100%;
    padding: 0;
    box-sizing: border-box;
  }
  
  /* アニメーション要素がはみ出さないように */
  .scroll-in-left, .scroll-in-right {
    max-width: 100%;
  }
  
  /* ワイン紹介テキストのレスポンシブ対応 */
  .wine-intro-text-font,
  .wine-intoro-table-wrapper,
  .wine-intoro-r {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    /* padding-left: 5%;
    padding-right: 5%; */
  }
}
/* === ↑↑↑ 横スクロール問題の修正 ↑↑↑ === */

/* === スクロールインアニメーション追加 === */

/* 右からぼかし強めのアニメーション（bottom-map用） */
.scroll-in-right-blur {
  transform: translateX(50px);
  filter: blur(10px);
}
.scroll-in-right-blur.visible {
  opacity: 1;
  transform: translateX(0);
  filter: blur(0);
}

/* 施設画像用の特殊スクロールエフェクト */
.scroll-fade-scale {
  opacity: 0;
  transform: scale(0.92);
  filter: brightness(0.8) saturate(0.7);
  transition: opacity 1s ease, transform 1.2s ease, filter 1.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.scroll-fade-scale.visible {
  opacity: 1;
  transform: scale(1);
  filter: brightness(1) saturate(1);
}

/* 施設画像の遅延表示 (複数画像を順番に表示) */
.scroll-delay-3 { transition-delay: 0.3s; }
.scroll-delay-4 { transition-delay: 0.4s; }
.scroll-delay-5 { transition-delay: 0.5s; }
.scroll-delay-6 { transition-delay: 0.6s; }

/* ディレイ設定 */
.scroll-delay-1 { transition-delay: 0.1s; }
.scroll-delay-2 { transition-delay: 0.2s; }

/* === ↑↑↑ スクロールインアニメーション追加 ↑↑↑ === */

/* === ↓↓↓ 施設紹介画像のホバー・クリックエフェクト ↓↓↓ === */
/* 施設画像のコンテナスタイル */
.facility-photo-blk {
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* 施設画像のリンク */
.facility-photo-link {
  display: block;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

/* 施設画像の基本スタイル */
.facility-photo-blk img {
  transition: transform 0.5s cubic-bezier(0.33, 1, 0.68, 1), 
              filter 0.5s cubic-bezier(0.33, 1, 0.68, 1);
  width: 100%;
  will-change: transform, filter;
}

/* ホバーエフェクト - コンテナ */
.facility-photo-blk:hover {
  transform: none;
  box-shadow: none;
}

/* ホバーエフェクト - 画像 */
.facility-photo-blk:hover img {
  transform: none;
  filter: brightness(0.85); /* 軽く暗くなる効果のみ */
  transition: filter 0.3s ease;
}

/* アクティブ（クリック）エフェクト */
.facility-photo-blk:active {
  transform: none;
  box-shadow: none;
}

/* 施設画像オーバーレイ (訪問情報) */
.facility-photo-overlay {
  display: none; /* オーバーレイを非表示 */
}

/* ホバー時にオーバーレイを表示 */
.facility-photo-blk:hover .facility-photo-overlay {
  display: none; /* ホバー時も非表示 */
}

/* 訪問ボタン */
.facility-visit-button {
  display: none; /* ボタンを非表示 */
}

.facility-photo-blk:hover .facility-visit-button {
  display: none; /* ホバー時も非表示 */
}

.facility-visit-button:hover {
  display: none; /* ボタンのホバー効果も無効化 */
}

.facility-visit-button:active {
  display: none; /* ボタンのアクティブ効果も無効化 */
}

/* 訪問ボタンのホバー */
.facility-visit-button:hover {
  display: none; /* ボタンホバー効果も無効化 */
}

/* 施設画像のホバー・クリックエフェクト（2つ目の定義） */
.facility-photo-blk:hover {
  transform: none;
  box-shadow: none;
}

.facility-photo-blk:hover img {
  transform: none;
  filter: brightness(0.85); /* 軽く暗くなる効果のみ */
}

.facility-photo-blk:active {
  transform: none;
  box-shadow: none;
}

/* オーバーレイ効果（情報表示用） */
.facility-photo-overlay {
  display: none; /* オーバーレイを非表示 */
}

.facility-photo-blk:hover .facility-photo-overlay {
  display: none; /* ホバー時も非表示 */
}

.facility-overlay-title {
  display: none; /* タイトルを非表示 */
}

.facility-overlay-text {
  display: none; /* テキストを非表示 */
}

.facility-photo-blk:hover .facility-overlay-title,
.facility-photo-blk:hover .facility-overlay-text {
  display: none; /* ホバー時も非表示 */
}

/* 別の場所にある同様の定義 */
.facility-photo-blk:hover .fasi-photo {
  filter: brightness(0.85); /* 軽く暗くなる効果のみ */
  transform: none;
}

.facility-photo-blk:hover .facility-photo-overlay {
  display: none; /* ホバー時も非表示 */
}

/* --- タブレット以下の表示調整 --- */
@media screen and (max-width: 991px) {
  .history-table {
    flex-direction: column; /* 縦並びにする */
    margin-left: 5%; /* マージン調整 */
    margin-right: 5%;
    align-items: stretch; /* 要素の幅を親に合わせる */
  }

  .history-table-photo-wrapper {
    height: 300px; /* タブレット以下でも高さを300pxに固定 */
    padding-right: 0; /* 右の余白を削除 */
    margin-bottom: 20px; /* テーブルとの間にマージンを追加 */
  }

  .history-table-table-wrapper {
    width: 100%; /* 幅を100%に */
  }
}

/* --- 受賞歴テーブル スマホ表示調整 --- */
@media screen and (max-width: 767px) {
  .award-title,
  .award-detail {
    font-size: 0.8rem; /* 文字サイズを小さく */
    line-height: 1.5rem; /* 行間も調整 */
  }

  .award-title {
    font-weight: 700; /* 太字に */
  }
}

/* --- winary-helo スマホ表示調整 --- */
@media screen and (max-width: 767px) {
  .wine-intoro-r {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    flex-flow: column;
    justify-content: center;
    align-self: center;
    align-items: center;
    width: auto;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .wine-name-wrapper {
    text-align: center; /* テキストを中央揃えにする */
    display: flex;
    flex-direction: column;
    align-items: center; /* 子要素を中央に配置 */
    justify-content: center; /* 縦方向も中央揃え */
    width: 100%; /* 幅を100%に設定 */
    padding-left: 20px;
    padding-right: 20px;
  }

  .winary-helo-1 {
    flex-direction: column-reverse; /* 画像が上、テキストが下になるように逆順で縦並び */
  }

  .winary-helo-2 {
    flex-direction: column; /* 画像が上、テキストが下になるように縦並び */
  }

  /* 縦並び時の共通スタイル */
  .winary-helo-1 .winary-catch-photo,
  .winary-helo-1 .winary-catch,
  .winary-helo-2 .winary-catch-photo,
  .winary-helo-2 .winary-catch {
    width: 100%; /* 幅を100%にする */
    flex: none; /* flexの伸縮をリセット */
    max-width: none; /* 最大幅の制限を解除 */
    width: 100vw; /* ビューポート幅いっぱいに設定 */
    margin-left: calc(-50vw + 50%); /* 左右中央揃えのためのネガティブマージン */
    margin-right: calc(-50vw + 50%); /* 左右中央揃えのためのネガティブマージン */
    
  }

  .winary-helo-1 .winary-catch-photo,
  .winary-helo-2 .winary-catch-photo {
    margin-bottom: 20px; /* 画像の下に余白を追加 */
    height: 300px; /* 画像の高さを適度に設定 (必要なら調整) */
  }

  .winary-helo-1 .winary-catch,
  .winary-helo-2 .winary-catch {
    padding-left: 40px; /* 左右パディングを削除 */
    padding-right: 40px;
  }

  /* winary-helo-2 の右側の縦線は不要になるので非表示 */
  .winary-helo-2 .image-5 {
      display: none;
  }
}

/* 電話番号・メールアドレスのリンクスタイル */
.phone-link, .email-link {
  text-decoration: none;
  color: inherit !important;
  -webkit-text-fill-color: inherit !important;
  text-decoration: underline;
}

/* @media screen and (max-width: 479px) {
  .container {
    padding-left: 5%;
    padding-right: 5%;
  }
} */

/* TOUR_INFO */
.lang-item {
  margin-left: auto;
  margin-right: 40px;
}

.lang-link {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

/* 言語切り替えリンクの下線を非表示 */
.menuitem.lang-item a::after {
  display: none;
}

.lang-logo {
  width: 28px;
  height: 28px;
  transition: transform 0.3s ease;
}

.lang-link:hover .lang-logo {
  transform: scale(1.1);
  opacity: 0.8;
}

.lang-link:active .lang-logo {
  transform: scale(0.95);
  opacity: 1;
}

/* モバイル版言語切り替えリンクのスタイル */
.lang-mobile-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  padding-bottom: 15px;
  margin-bottom: 15px;
}

.lang-mobile-link {
  display: flex;
  align-items: center;
}

.lang-arrow {
  width: 16px;
  height: 16px;
  margin-left: 8px;
}

.lang-logo-mobile {
  width: 24px;
  height: 24px;
  margin-right: 10px;
}

@media screen and (max-width: 991px) {
  .lang-item {
    display: none; /* タブレット・モバイル表示ではPC版の言語切り替えを非表示 */
  }
}



.tour-info-section {
  padding: 40px 0;
  background-color: #fff;
}

.tour-info-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.tour-info-grid {
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-top: 40px;
}

.tour-info-item {
  margin-bottom: 20px;
  padding: 20px;
  background-color: transparent;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 40px;
}

.tour-info-image {
  width: 50%;
  height: auto;
  border-radius: 0;
  object-fit: cover;
  flex-shrink: 0;
}

.tour-info-content {
  flex: 1;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
  text-align: left;
}

.tour-info-number {
  font-size: 22px;
  font-weight: bold;
  color: #333;
  margin-bottom: 15px;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
}

.tour-info-text {
  font-size: 16px;
  line-height: 1.6;
  color: #555;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
}

.tour-details-section {
  padding: 60px 20px;
  background-color: #f7f0dc;
  color: #333;
}

.tour-details-container {
  max-width: 1000px;
  margin: 0 auto;
}

.tour-details-block {
  margin-bottom: 30px;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
}

.tour-details-title {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 15px;
  color: #333;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
  border-bottom: 1px solid #ccc;
  padding-bottom: 5px;
}

.tour-details-content {
  font-size: 16px;
  line-height: 1.6;
  color: #555;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
}

.hero-image-container {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  /* 高さを固定値から計算値に変更 */
  height: auto;
  /* グローバルメニューの下に潜り込むように */
  margin-top: 0;
}

.hero-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.3); /* 明るさを0.3に設定 */
  animation: darkenImage 5s ease-out forwards; /* 5秒かけて徐々に暗くなるアニメーション */
}

@keyframes darkenImage {
  0% { filter: brightness(1); }
  100% { filter: brightness(0.3); }
}

.title-content-overlay {
  position: relative;
  z-index: 1;
  width: 100%;
  /* paddingの調整 */
  padding-top: 180px; /* グローバルメニューの高さ + 40px */
  padding-bottom: 100px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.title-compornent {
  margin-bottom: 30px;
}



@media screen and (max-width: 767px) {
  .hero-image-container {
    height: auto;
    margin-top: 0;
  }
  
  .title-content-overlay {
    padding-top: 120px;
    padding-bottom: 40px;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.menu-link {
  text-decoration: none;
  color: inherit;
}

.instagram-link {
  display: inline-block;
  line-height: 0;
}

@media screen and (max-width: 767px) {
  .hero-image-container {
    min-height: auto;
  }
  
  .title-content-overlay {
    padding-top: 100px;
    padding-bottom: 30px;
    padding-left: 15px;
    padding-right: 15px;
  }
}
.content-text.company {
  color: #9f9696;
}

/* タブレットサイズ以下のレスポンシブ対応 */
@media screen and (max-width: 991px) {
  .tour-info-item {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  
  .tour-info-image {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    max-width: none;
    margin-bottom: 20px;
  }
  
  .tour-info-content {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .tour-info-item {
    padding: 15px;
  }
  

  
  .tour-info-number {
    font-size: 18px;
    margin-bottom: 10px;
  }
  
  .tour-info-text {
    font-size: 14px;
    line-height: 1.5;
  }
}

.reserve-button-wrapper {
  margin-top: 40px;
  text-align: center;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
}

.small-font.white {
  color: #fff;
  font-family: 'Zen Old Mincho', serif; /* Noto Serif JP から変更 */
}

.top-reserve-button-wrapper {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-top: 30px;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .top-reserve-button-wrapper {
    justify-content: center;
    margin-top: 20px;
    margin-bottom: 15px;
  }
}

/* ワイナリーツアー全幅画像スタイル */
.tour-fullwidth-image-section {
  width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.tour-fullwidth-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* ヒーローセクションのスライドショー調整 */
.hero-image-container {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  margin-top: 0; /* グローバルメニューの下に潜り込むようにmargin-top削除 */
}

.hero-image-container .slideshow-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.hero-image-container .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0; /* Start hidden */
  transform-origin: center;
  filter: blur(10px);
  animation-duration: 32s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

/* Assign animation names to each slide */
.hero-image-container .slide:nth-child(1) {
  animation-name: heroSlideShow1;
}

.hero-image-container .slide:nth-child(2) {
  animation-name: heroSlideShow2;
}

.hero-image-container .slide:nth-child(3) {
  animation-name: heroSlideShow3;
}

.hero-image-container .slide:nth-child(4) {
  animation-name: heroSlideShow4;
}

/* Define new keyframes for each slide over the 32s cycle with adjusted zoom */
@keyframes heroSlideShow1 {
  0%      { opacity: 0; filter: blur(10px); transform: scale(1.1); }
  3%      { opacity: 1; filter: blur(0);    transform: scale(1.05); }
  22%     { opacity: 1; filter: blur(0);    transform: scale(1); }
  25%     { opacity: 0; filter: blur(10px); transform: scale(1); }
  100%    { opacity: 0; }
}

@keyframes heroSlideShow2 {
  0%      { opacity: 0; }
  25%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }
  28%     { opacity: 1; filter: blur(0);    transform: scale(1.05); }
  47%     { opacity: 1; filter: blur(0);    transform: scale(1); }
  50%     { opacity: 0; filter: blur(10px); transform: scale(1); }
  100%    { opacity: 0; }
}

@keyframes heroSlideShow3 {
  0%      { opacity: 0; }
  50%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }
  53%     { opacity: 1; filter: blur(0);    transform: scale(1.05); }
  72%     { opacity: 1; filter: blur(0);    transform: scale(1); }
  75%     { opacity: 0; filter: blur(10px); transform: scale(1); }
  100%    { opacity: 0; }
}

@keyframes heroSlideShow4 {
  0%      { opacity: 0; }
  75%     { opacity: 0; filter: blur(10px); transform: scale(1.1); }
  78%     { opacity: 1; filter: blur(0);    transform: scale(1.05); }
  97%     { opacity: 1; filter: blur(0);    transform: scale(1); }
  100%    { opacity: 0; filter: blur(10px); transform: scale(1.1); }
}

@media screen and (max-width: 767px) {
  .hero-image-container {
    height: 560px;
    padding-top: 100px;
  }
  
  .title-content-overlay {
    padding: 0 20px;
  }
}

@media screen and (max-width: 480px) {
  .hero-image-container {
    height: 700px;
    padding-top: 100px;
  }
  .tour-blk {
    border-left: 0px solid #d321210a;
    padding-left: 0px;
  }

 
  .title-content-overlay {
    padding: 0;
  }
}

/* 受賞歴アコーディオン */
.award-open-body {
  overflow: hidden;
  transition: max-height 0.8s ease-out, padding 0.5s ease-out, margin 0.5s ease-out;
  max-height: 3000px; /* より大きな値に設定して、ほぼすべての内容を表示できるようにする */
  padding-top: 15px;
  padding-bottom: 15px;
  margin-top: 10px;
  margin-bottom: 10px;
}
.award-table-row-close .award-open-body {
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0;
  border-width: 0;
}
/* 最初のアコーディオンは常に開く */
.award-table > .award-table-row-open:first-child .award-open-body {
  max-height: 3000px;
  padding-top: 15px;
  padding-bottom: 15px;
  margin-top: 10px;
  margin-bottom: 10px;
  border-width: 1px;
  display: block !important;
}

.vineyerd-map-mobile {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  width: 90%;
}

.vineyerd-map-mobile img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.image-7 {
  flex: 1;
  display: block;
}

/* Safari/iOSでの画像品質向上のための追加スタイル */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  .helo-back--tour,
  .helo-back--tour.about,
  .helo-back--tour.history,
  .helo-back--tour.company {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transform: translateZ(0);
    image-rendering: -webkit-optimize-contrast;
    will-change: transform;
  }
}

/* Map Additional Info Styles */
.map-additional-info {
  margin-top: 20px;
  margin-bottom: 20px;
}

.map-additional-info .address-map-container {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: left;
  flex-wrap: wrap;
  margin-bottom: 15px;
}

.map-additional-info .address-text {
  font-weight: 400;
  text-align: left;
  margin-top: 0; /* pタグのデフォルトマージンをリセット */
  margin-bottom: 0; /* pタグのデフォルトマージンをリセット */
  font-family: 'Zen Old Mincho', serif;
}

.map-additional-info .google-map-button-wrapper {
  margin: 20px 0px;
  border: 1px solid #777;
  border-radius: 5px;
  padding: 8px 12px;
  display: inline-block; /* インライン要素として表示し、横幅いっぱいにならないようにする */
  max-width: fit-content; /* コンテンツに合わせた最大幅に制限 */
}

.map-additional-info .google-map-button {
  text-decoration: none;
  color: #333;
  display: inline-flex;
  align-items: center; /* 垂直中央揃えを維持 */
  font-size: 0.8rem;
  font-weight: 400;
  font-family: 'Zen Old Mincho', serif;
  /* line-height: 1; */ /* 必要に応じて行の高さを調整 */
}

.map-additional-info .google-map-icon {
  margin-right: 5px; /* アイコンとテキストの間にスペースを確保 */
  width: 12px;
  height: auto;
  /* vertical-align: middle; */ /* 必要に応じて垂直位置を微調整 */
}

.map-additional-info .access-info-text {
  margin-top: 10px;
  margin-bottom: 10px;
  text-align: left;
  font-weight: 400;
  font-family: 'Zen Old Mincho', serif;
}