@charset "utf-8";

/*----------------------------------------------------------------------------------------------
	top
----------------------------------------------------------------------------------------------*/
#movie_base {
  z-index: 0;
}

.video-container {
  width: 100%;
  min-height: 100vh;
  height: clamp(100vh, 100vh, 54.5vw);
  /* aspect-ratio: 240 / 143; */
  overflow: hidden;
  margin: 0 auto;
  text-align: center;
  position: relative;
}

.video-container::after {
  position: absolute;
  content: "";
  display: block;
  width: .5px;
  height: 100%;
  top: 0;
  right: 135px;
  background: #ffffff77;
}

.mv_set {
  background: #fff;
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}

.mv_bg01 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  background: url(../img/mv01.jpg) no-repeat center top;
  background-size: cover;
}

.mv_bg02,
.mv_bg03,
.mv_bg04,
.mv_bg05,
.mv_bg06,
.mv_bg07,
.mv_bg08 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.mv_bg02 {
  background: url(../img/mv02.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_bg03 {
  background: url(../img/mv03.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_bg04 {
  background: url(../img/mv04.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_bg05 {
  background: url(../img/mv05.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_bg06 {
  background: url(../img/mv06.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_bg07 {
  background: url(../img/mv07.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_bg08 {
  background: url(../img/mv07.jpg) no-repeat center top;
  background-size: cover;
  opacity: 0;
}

.mv_t01 {
  position: absolute;
  left: 0;
  top: 40%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_t_sub {
  position: absolute;
  left: 0;
  top: 53%;
  width: 100%;
  text-align: center;
  opacity: 0;
}

.mv_t02 {
  position: absolute;
  left: 0;
  top: 46%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_t03 {
  position: absolute;
  left: 0;
  top: 46%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_t04 {
  position: absolute;
  left: 0;
  top: 46%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_t05 {
  position: absolute;
  left: 0;
  top: 46%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_t06 {
  position: absolute;
  left: 0;
  top: 46%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_t07 {
  position: absolute;
  left: 0;
  top: 46%;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
}

.mv_cta_btn01 {
  position: absolute;
  left: 0;
  top: 58%;
  width: 100%;
  text-align: center;
  opacity: 0;
}

.mv_cta_btn01 a:hover {
  filter: brightness(1.2);
}

.mv_cta_btn01 img {
  height: clamp(20px, 4vw, 70px);
  width: auto;
}

.mv_en_reservation {
  position: absolute;
  left: 2%;
  bottom: 2%;
  width: 84%;
  opacity: 0;
}

.mv_t01 img {
  height: clamp(60px, 8.7vw, 130px);
  width: auto;
}

.mv_t05 img,
.mv_t06 img,
.mv_t07 img {
  height: 3.3vw;
  width: auto;
}

.mv_t02 img,
.mv_t03 img,
.mv_t04 img {
  height: 7.7vw;
  width: auto;
}

.mv_t_sub img {
  height: 1.8vw;
  width: auto;
}


@media (max-width: 800px) {
  .video-container {
    width: 100%;
    min-height: initial;
    height: initial;
    aspect-ratio: 1 / .82;
    overflow: hidden;
    margin: 0 auto;
    text-align: center;
    position: relative;
  }

  .video-container::after {
    display: none;
  }

  .mv_bg01 {
    background: url(../img/mv01_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg02 {
    background: url(../img/mv02_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg03 {
    background: url(../img/mv04_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg04 {
    background: url(../img/mv04_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg05 {
    background: url(../img/mv05_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg06 {
    background: url(../img/mv06_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg07 {
    background: url(../img/mv07_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_bg08 {
    background: url(../img/mv07_sp.jpg) no-repeat center top;
    background-size: cover;
    opacity: 0;
  }

  .mv_t01 {
    position: absolute;
    left: 8%;
    top: 55.8%;
    width: 85%;
    opacity: 0;
  }

  .mv_t01 {
    position: absolute;
    left: 0;
    top: 38%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t_sub {
    position: absolute;
    left: 0;
    top: 52%;
    width: 100%;
    text-align: center;
    opacity: 0;
  }

  .mv_t02 {
    position: absolute;
    left: 0;
    top: 46%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t03 {
    position: absolute;
    left: 0;
    top: 46%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t04 {
    position: absolute;
    left: 0;
    top: 46%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t05 {
    position: absolute;
    left: 0;
    top: 46%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t06 {
    position: absolute;
    left: 0;
    top: 46%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t07 {
    position: absolute;
    left: 0;
    top: 46%;
    width: 100%;
    text-align: center;
    opacity: 0;
    filter: drop-shadow(0px 0px 5px rgba(33, 33, 33, 0.9)) drop-shadow(0px 0px 8px rgba(33, 33, 33, 0.9));
  }

  .mv_t01 img {
    height: 15.7vw;
    width: auto;
  }

  .mv_t05 img,
  .mv_t06 img,
  .mv_t07 img {
    height: 5.7vw;
    width: auto;
  }

  .mv_t02 img,
  .mv_t03 img,
  .mv_t04 img {
    height: 10.7vw;
    width: auto;
  }

  .mv_t_sub img {
    height: 3.5vw;
    width: auto;
  }

  .mv_cta_btn01 {
    position: absolute;
    left: 0;
    top: 62%;
    width: 100%;
    text-align: center;
    opacity: 0;
  }

  .mv_cta_btn01 a:hover {
    filter: brightness(1.2);
  }

  .mv_cta_btn01 img {
    height: 9vw;
    width: auto;
    /* display: none; */
  }

  .mv_en_reservation {
    position: absolute;
    left: 2%;
    bottom: 2%;
    width: 90%;
    opacity: 0;
  }
}

/* section01 */
.section01_mv {
  position: absolute;
  background: url(../img/mv08.jpg) no-repeat center top;
  background-size: cover;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.section01 {
  position: relative;
  background: url(../img/mv08.jpg) no-repeat center top;
  background-size: cover;
  aspect-ratio: 240 / 143;
}

.sec01_wrap {
  width: clamp(300px, 80%, 1200px);
  margin-inline: auto;
  display: flex;
  color: #fff;
  padding-top: 10vw;
}

.sec01_txt {
  width: 52%;
  text-align: justify;
}

.sec01_banner {
  width: 40%;
  margin-top: 5em;
  z-index: 1;
}

.sec01_txt_ttl01 {
  font-size: 2.0vw;
}

.sec01_txt_txt01 {
  font-size: 1.2vw;
  line-height: 2;
  margin-top: 1.5em;
}

.sec01_cta_btn01 {
  margin-top: 3em;
}

.sec01_cta_btn01 a:hover {
  filter: brightness(1.2);
}

.sec01_cta_btn01 img {
  height: 4vw;
  width: auto;
}

.sec01_en_reservation {
  position: absolute;
  left: 2%;
  bottom: 2%;
  width: 84%;
  filter: invert(39%) sepia(22%) saturate(458%) hue-rotate(356deg) brightness(94%) contrast(89%);
}

/* section02 */
.section02 {
  position: relative;
  padding: 0 0;
}

.sec02_img01 {
  width: 70%;
  margin-inline: auto;
}

.sec02_txt01 {
  position: absolute;
  width: 2932px;
  left: 30%;
  top: 17%;
}

.sec02_overlay {
  position: relative;
  background: #1A1311;
  padding: 100px 0;
  /* margin-top: 140px; */
  background: url(../img/sec01.jpg) no-repeat center top;
  background-size: cover;
}

.sec02_overlay::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #2a1f1fc7;
  backdrop-filter: blur(15px);
}

.sec02_overlay_in {
  position: relative;
  width: clamp(300px, 80%, 1200px);
  margin-inline: auto;
  display: flex;
  gap: 14.2%;
  z-index: 2;
}

.sec02_overlay_txt01 {
  width: 54.4%;
  color: #fff;
}

.sec02_overlay_ttl01 {
  font-size: 1.5vw;
  line-height: 2;
}

.sec02_overlay_map {
  margin-top: 2em;
  text-align: center;
  position: relative;
}

.sec02_overlay_links {
  width: 31.4%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.sec02_overlay_link_list {
  background: #fff;
  padding: 2em;
  font-size: 20px;
}

.sec02_overlay_link_list li {
  padding: .7em 0;
  border-bottom: 1px solid #000;
}

.sec02_overlay_link_list li:last-child {
  border: none;
}

.sec02_overlay_link_list li a {
  display: flex;
  gap: 10px;
  align-items: center;
}

.sec02_overlay_link_list li a::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: .4em .3em 0 .3em;
  border-color: #BCBDBD transparent transparent transparent;
  margin-top: .2em;
}

.sec02_overlay_link_list li a:hover {
  color: #999;
  transform: translateY(3px);
}

.sec02_overlay_map a {
  display: inline-block;
  font-size: 11px;
  color: #ffffff;
  background: #d65a1b;
  line-height: 1.2;
  padding: .4em .5em;
}

.sec02_overlay_map a:hover {
  background: #C8A52C;
  color: #1A1311;
}

.area_map_link01 {
  position: absolute;
  top: 46.5%;
  left: 40%;
}

.area_map_link02 {
  position: absolute;
  top: 36.0%;
  left: 56%;
}

.area_map_link03 {
  position: absolute;
  top: 28%;
  left: 49%;
}

.area_map_link04 {
  position: absolute;
  top: 31%;
  left: 61%;
}

.area_map_link05 {
  position: absolute;
  top: 30.5%;
  left: 32.5%;
}

.area_map_link06 {
  position: absolute;
  top: 36.5%;
  left: 40%;
}

.area_map_link07 {
  position: absolute;
  top: 52%;
  left: 56.0%;
}

.area_map_link08 {
  position: absolute;
  top: 85.5%;
  left: 51%;
}

.area_map_link09 {
  position: absolute;
  top: 42.5%;
  left: 60.5%;
}


/* section03 */
.section03 {
  position: relative;
  display: flex;
}

.section03-in01 {
  width: 375px;
  flex: 1;
  border-right: .5px solid #000;
  padding: 100px 5% 20px;
}

.exhibition_ttl01 {
  text-align: center;
}

.exhibition_ttl01 img {
  width: 6.5vw;
  height: auto;
  padding-left: 10%;
}

.exhibition_txt01 {
  line-height: 2;
  margin-top: 40px;
}

.icon_set {
  margin-top: 40px;
}

.section03-in02 {
  width: calc(100% - 375px);
  padding: 100px 0 50px;
}


.exhibition_list_contents {
  width: clamp(150px, 75%, 1000px);
  margin-left: 10%;
}

.exhibition_list_ttl01 {
  color: #999;
  font-size: clamp(30px, 2.5vw, 57px);
  line-height: 1;
  display: flex;
  gap: 5px;
  align-items: center;
  margin-bottom: .8em;
  padding-top: 30px;
  margin-top: -30px;
}

.exhibition_list_ttl01 .jp {
  font-size: .4em;
  padding-top: .5em;
}

.exhibition_list {
  display: flex;
  flex-wrap: wrap;
  gap: 80px 10%;
}

.exhibition_list_item {
  width: calc((100% - 10%) / 2);
}

.exhibition_list_item_img {
  position: relative;
  aspect-ratio: 1 / 1;
  cursor: pointer;
}

.item_img01,
.item_img02 {
  position: relative;
  /* top: 0;
  left: 0; */
  width: 100%;
  height: 100%;
}

.exhibition_list_item_img:hover .item_img02 {
  opacity: 0;
  transition: all .5s ease;
}

.exhibition_list_item_ttl01 {
  text-align: center;
  font-size: clamp(17px, 1.25vw, 28px);
  padding: 1em 0;
  border-bottom: .5px solid #000;
  margin-bottom: 1em;
}

.exhibition_list_item_txt01 {
  font-size: clamp(14px, 1.1vw, 22px);
}

.exhibition_list_item_txt02 {
  margin-top: 1em;
}

.exhibition_list_item_map {
  margin-top: 5px;
}

.exhibition_list_item_map a:hover {
  filter: brightness(.5);
}

.u-small {
  font-size: 0.8em;
}

.exhibition_list_item_cta {
  display: flex;
  margin-top: 0;
  align-items: flex-end;
}

.exhibition_list_item_icons {
  display: flex;
  gap: 10px;
  align-items: flex-end;
  margin-top: 15px;
}

.exhibition_list_item_btn {
  margin-left: auto;
  /* display: none; */
  width: 38%;
}

.exhibition_list_item_btn a:hover {
  filter: brightness(2);
}

/* section04 merit */
.section04 {
  position: relative;
  padding: 100px 0 100px;
}

.merit_ttl01 {
  width: clamp(250px, 80%, 1200px);
  margin-inline: auto;
  margin-bottom: 4em;
}

.l-container-lx {
  width: clamp(250px, 80%, 920px);
  margin-inline: auto;
  vertical-align: baseline !important;
}

.section04_ttl01 {
  font-size: 30px;
  line-height: 1.6;
  vertical-align: baseline !important;
  letter-spacing: .1em;
}

[data-ruby] {
  position: relative;
  /* margin-top: -.5em; */
  display: inline-block;
  transform: translateY(-.20em);
}

[data-ruby]::before {
  content: attr(data-ruby);
  position: absolute;
  top: -.2em;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 0.35em;
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
}

/* 以下追加 */
rt {
  display: none;
}

.section04_txt01 {
  font-size: 16px;
  line-height: 2;
  margin-top: 1em;
}

.merit-contents {
  display: flex;
  gap: 1px;
  margin-top: 70px;
}

.merit-contents_item {
  color: #fff;
  width: calc((100% - 3px) / 4);
  height: 608px;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  cursor: pointer;
}

.merit-contents .merit-contents_item:nth-child(1) {
  background: url(../img/cont_bg01_sp.jpg) no-repeat center top;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(2) {
  background: url(../img/cont_bg02_sp.jpg) no-repeat center top;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(3) {
  background: url(../img/cont_bg03_sp.jpg) no-repeat center top;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(4) {
  background: url(../img/cont_bg04_sp.jpg) no-repeat center top;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(1).is_active {
  background: url(../img/cont_bg01_sp.jpg) no-repeat center center;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(2).is_active {
  background: url(../img/cont_bg02_sp.jpg) no-repeat center center;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(3).is_active {
  background: url(../img/cont_bg03_sp.jpg) no-repeat center center;
  background-size: cover;
}

.merit-contents .merit-contents_item:nth-child(4).is_active {
  background: url(../img/cont_bg04_sp.jpg) no-repeat center center;
  background-size: cover;
}

.merit-contents_item_ttl01 {
  font-size: 1.6vw;
  text-align: center;
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.merit-contents_item_in {
  display: none;
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.merit-contents_item:hover {
  width: 37%;
}

.merit-contents_item.is_active {
  width: 100%;
}

.merit-contents_item.is_active .merit-contents_item_ttl01 {
  opacity: 0;
  display: none;
}

.merit-contents_item.is_active .merit-contents_item_in {
  display: flex;
  flex-direction: column;
  width: clamp(300px, 90%, 1400px);
  height: 100%;
  margin-inline: auto;
  justify-content: center;
}

.merit-contents_item_ttl02 {
  font-size: 30px;
}

.merit-contents_item_txt {
  width: clamp(250px, 90%, 500px);
  background: #1A1311;
  padding: 1.5em;
  font-size: 16px;
  line-height: 1.8;
  margin-top: 2em;
  text-align: justify;
}

.merit-contents_item.is_close {
  width: 0;
}

.merit-contents_item.is_close .merit-contents_item_ttl01 {
  opacity: 0;
  transition: none
}

.merit-more {
  display: flex;
  justify-content: center;
  margin-top: 100px;
  gap: 45px;
}

.merit-more li {
  width: 450px;
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  line-height: 1.6;
  text-align: center;
  border: .5px solid #000;
  padding: 1.5em;
}

.merit-more li:nth-child(2) {
  padding: 0;
}

.merit-more li a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 1.5em;
}

.merit-more li a:hover {
  background: #e4e1de;
}

.merit-more li::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/icon_triangle.svg) no-repeat left top;
  background-size: contain;
  width: 3em;
  height: 3em;
}

.section05 {
  position: relative;
  padding: 290px 0 390px;
  background: #F5F1ED;
  color: #42362F;
  display: none;
}

.section05_img01 {
  position: absolute;
  top: 37px;
  left: 24%;
  width: 19.4%;
}

.section05_img02 {
  position: absolute;
  top: 16%;
  right: 3.8%;
  width: 12.4%;
}

.section05_img03 {
  position: absolute;
  top: 59.3%;
  left: 52.2%;
  width: 30.2%;
}

.scroll-txt {
  width: 100%;
  display: flex;
  overflow: hidden;
  gap: 5em;
}

.section05_ttl01 {
  font-size: clamp(20px, 4.0vw, 52px);
  line-height: 1;
  letter-spacing: -.1em;
  flex-shrink: 0;
  width: auto;
  height: auto;
  display: inline-block;
  text-wrap: nowrap;
  white-space: nowrap;
  /* animation: anim--first 30s infinite linear 0.1s both; */
}

@keyframes anim--first {
  0% {
    transform: translateX(30%);
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  100% {
    transform: translateX(-110%);
  }
}

.section06_ttl01 {
  font-size: clamp(20px, 2.9vw, 52px);
  line-height: 1;
  letter-spacing: -.1em;
  margin-top: 2em;
}

.u-big01 {
  font-size: 1.5em;
  margin: 0 -.5em 0 -.6em;
}

.u-big01.u-tsume01 {
  margin: 0 -.5em 0 -.8em;
}

.section05_txt01 {
  font-size: clamp(16px, 1.25vw, 23px);
  margin-top: 2em;
}

.section06 {
  position: relative;
  padding: 140px 0 350px;
  background: #BD9A83;
  color: #fff;
  display: none;
}

.section06_img01 {
  width: 61%;
}

.section06_in {
  position: relative;
  border-top: .5px solid #fff;
  margin-top: 110px;
}

.en-light {
  position: absolute;
  width: 35.6%;
  top: 23vw;
  right: 1%;
}

.section06_img02 {
  width: 23.5%;
}

.section06_img03 {
  position: absolute;
  width: 12%;
  top: 6vw;
  left: 75.6%;
}

.section06_img04 {
  position: absolute;
  width: 19.7%;
  top: 106%;
  left: 40%;
}

.section06_txt01 {
  font-size: clamp(16px, 1.25vw, 23px);
  margin-top: 1.5em;
  line-height: 2;
}


.section07 {
  position: relative;
  padding: 140px 0 350px;
  background: #95AEBB;
  margin-top: 100px;
  color: #fff;
  display: none;
}

.section07_img01 {
  width: 61%;
}

.section07_in {
  position: relative;
  border-top: .5px solid #fff;
  margin-top: 110px;
}

.en-air {
  position: absolute;
  width: 21.6%;
  top: 23vw;
  right: 11%;
}

.section07_img02 {
  width: 42.9%;
  margin-left: 51.5%;
}

.section07_img03 {
  position: absolute;
  width: 17.6%;
  top: 109%;
  left: 12.1%;
}

.section08 {
  position: relative;
  padding: 140px 0 350px;
  background: #75715E;
  margin-top: 100px;
  color: #fff;
  display: none;
}

.section08_img01 {
  width: 61%;
}

.section08_in {
  position: relative;
  border-top: .5px solid #fff;
  margin-top: 110px;
}

.en-design {
  position: absolute;
  width: 46.6%;
  top: 23vw;
  right: 1%;
}

.section08_img02 {
  width: 24.8%;
  margin-left: 59.4%;
}

.section08_img03 {
  position: absolute;
  width: 19.7%;
  top: 107%;
  left: 5.7%;
}

.section08_img04 {
  position: absolute;
  width: 26%;
  bottom: 0;
  right: 0;
}

.section09 {
  margin-top: 100px;
}

.section09_links {
  width: clamp(300px, 90%, 1400px);
  display: flex;
  margin-inline: auto;
}

.section09_links_item {
  width: 50%;
}

.section09_links_item:nth-child(1) {
  border-right: .5px solid #000;
  padding: 0 6% 0 0;
}

.section09_links_item:nth-child(2) {
  padding: 0 0 0 6%;
}

.section09_links_item a {
  display: flex;
  gap: 6%;
}

.section09_links_item:nth-child(1) a {
  flex-direction: row-reverse;
  text-align: right;
}

.section09_links_item_img {
  width: 37.1%;
}

.section09_links_item_txt {
  flex: 1;
}

.section09_links_item_ttl01 {
  font-size: 1.4vw;
  margin-top: -.2em;
}

.section09_links_item_txt02 {
  font-size: 13px;
  margin-top: 1.2em;
}

.section09_links_item_txt03 {
  position: relative;
  font-size: 16px;
  margin-top: 1.4em;
  display: flex;
  gap: 10px;
  -webkit-transition: .4s;
  transition: .4s;
}

.section09_links_item:nth-child(1) .section09_links_item_txt03 {
  justify-content: flex-end;
}

.section09_links_item_txt03 span {
  display: inline-block;
  border-bottom: 1px solid #000;
  padding-bottom: 2px;
}

.section09_links_item_txt03::after {
  content: "";
  background: url(../img/flow_maru01.svg) no-repeat center center;
  width: 28px;
  height: 28px;
}

.section09_links_item a:hover .section09_links_item_txt03 {
  transform: translateX(10px);
}

.section10 {
  background: url(../img/img06_01.jpg) no-repeat center top;
  background-size: cover;
  padding: 120px 0;
  margin-top: 100px;
}

.banner01,
.banner02 {
  width: clamp(300px, 90%, 920px);
  margin-inline: auto;
}

.section11 {
  margin-top: 140px;
}

.section12 {
  margin-top: 140px;
  text-align: center;
}

.section12_ttl01 {
  font-size: 35px;
}

.section12_ttl02 {
  font-size: 25px;
  position: relative;
  padding: 0 .5em;
  margin-top: 1em;
}

.section12_ttl02 span {
  padding: 0 .5em .5em;
  border-bottom: .5px solid #000;
}

.flow {
  background: url(../img/flow_bg.jpg) no-repeat center top;
  background-size: cover;
  margin-top: 70px;
}

.flow_item {
  width: clamp(300px, 90%, 500px);
  background-size: cover;
  margin-inline: auto;
  background: #fff;
  padding: 50px 0;
}

.flow_item_ttl01 {
  font-size: 26px;
  line-height: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

.flow_item_ttl01 .flow_number {
  font-size: 1.2em;
  margin-left: .2em;
}

.flow_item_txt01 {
  font-size: 17px;
  margin-top: .5em;
}

.flow_item_arrow {
  padding: 25px 0;
}

.section13 {
  margin-top: 100px;
  text-align: center;
}

.section13_ttl01 {
  font-size: 28px;
}

.section13_txt01 {
  font-size: 18px;
  margin-top: 1.0em;
}

.section14 {
  margin-top: 100px;
}

.faq_ttl01 {
  font-size: 30px;
  line-height: 1;
  text-align: center;
  color: #fff;
  background: #866E48;
  padding: .5em 0;
}

/* faq_area */
#faq_area .inner {
  margin-top: 40px;
}

#faq_area .inner .acc_box .toggle {
  display: none;
}

.acc_box {
  font-size: 20px;
  line-height: 1.7;
}

#faq_area .inner .acc_box .Label {
  padding: 25px 60px 30px 100px;
  display: block;
  color: #000;
  border-bottom: .5px solid #000;
  position: relative;
}

#faq_area .inner .acc_box .Label:hover {
  cursor: pointer;
}

#faq_area .inner .acc_box .Label::before {
  content: "Q.";
  font-style: normal;
  font-size: 48px;
  letter-spacing: 0.15em;
  position: absolute;
  top: 42%;
  left: 30px;
  transform: translate(0, -50%);
}

#faq_area .inner .acc_box .acc_ans::before {
  content: "A.";
  font-style: normal;
  font-size: 48px;
  letter-spacing: 0.15em;
  position: absolute;
  top: 49px;
  left: 30px;
  transform: translate(0, 0);
}

#faq_area .inner .acc_box .Label::after {
  content: "";
  width: 24px;
  height: 24px;
  background: url("../img/faq_icon01.svg") no-repeat;
  background-size: 24px 24px;
  position: absolute;
  top: 50%;
  right: 2%;
  transform: translate(0, -50%);
}

#faq_area .inner .acc_box .Label,
#faq_area .inner .acc_box .acc_ans {
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}

.acc_ans {
  background: rgba(255, 255, 255, 1);
  height: 0;
  margin-bottom: 10px;
  padding: 0 65px 0 100px;
  overflow: hidden;
  font-size: 18px;
  color: #000;
  line-height: 1.7;
  letter-spacing: 0.05em;
}

.toggle:checked+.Label+.acc_ans {
  height: auto;
  padding: 69px 65px 80px 100px;
  background: #F1F1F2;
  transition: all .3s;
}

.acc_ans p {
  line-height: 1.8;
}

.toggle:checked+.Label::after {
  background: url("../img/faq_icon02.svg") no-repeat !important;
  background-size: 24px 24px !important;
}

@media only screen and (max-width: 800px) {
  #faq_area .inner {
    margin-top: 0;
  }

  .faqsec_titBox {
    margin: 0px auto 0px;
    text-align: center;
    padding: 0px 0 20px;
  }

  #faq_area .inner .acc_box {
    margin: 10px 0 0 0;
    font-size: 4.0vw;
  }

  #faq_area .inner .acc_box .Label {
    padding: 20px 45px 20px 70px;
    line-height: 1.5;
    border-bottom: .5px solid #979797;
  }

  #faq_area .inner .acc_box .Label::before {
    font-size: 2.8rem;
    left: 6%;
    top: 41%;
  }

  #faq_area .inner .acc_box .acc_ans::before {
    font-size: 2.8rem;
    left: 6%;
    top: 6%;
  }

  #faq_area .inner .acc_box .Label::after {
    content: "";
    width: 20px;
    height: 20px;
    background: url("../img/faq_icon01.svg") no-repeat;
    background-size: 20px 20px;
    position: absolute;
    top: 50%;
    right: 5%;
    transform: translate(0, -50%);
  }

  .toggle:checked+.Label+.acc_ans {
    padding: 25px 5% 25px 65px;
  }

  .acc_ans p {
    line-height: 1.8;
    font-size: 3.5vw;
  }

  .toggle:checked+.Label::after {
    background: url("../img/faq_icon02.svg") no-repeat !important;
    background-size: 20px 20px !important;
  }
}


.cp_box {
  margin-top: 140px;
}

.cp_box .section12_ttl02 {
  text-align: center;
}

.cp_notes {
  font-size: 16px;
  line-height: 1.8;
  margin-top: 2em;
}

.banner03 {
  width: clamp(250px, 90%, 920px);
  margin-inline: auto;
  margin-top: 30px;
}

@media (max-width: 800px) {
  .cp_box {
    margin-top: 40px;
    width: 85%;
    margin-inline: auto;
  }

  .cp_box .section12_ttl02 {
    text-align: center;
  }

  .cp_notes {
    font-size: 2.7vw;
    line-height: 1.8;
    margin-top: 3em;
  }

  .banner03 {
    width: clamp(250px, 85%, 750px);
    margin-inline: auto;
    margin-top: 30px;
  }

  .banner03__btn {
    width: clamp(250px, 85%, 750px);
    margin-inline: auto;
    margin-top: 20px;
  }
}

/* SP
------------------------------------------------------ */
@media (max-width: 800px) {


  /* section01 */
  .section01 {
    position: relative;
    background: url(../img/mv08.jpg) no-repeat center top;
    background-size: cover;
    aspect-ratio: 240 / 143;
  }

  .sec01_wrap {
    width: clamp(300px, 80%, 1400px);
    margin-inline: auto;
    display: flex;
    color: #fff;
    padding-top: 9vw;
    padding-bottom: 9vw;
    flex-direction: column;
  }

  .sec01_txt {
    width: 100%;
  }

  .sec01_banner {
    width: 100%;
    margin-top: 1em;
  }

  .sec01_txt_ttl01 {
    font-size: 4vw;
  }

  .sec01_txt_txt01 {
    font-size: 2.95vw;
    line-height: 1.8;
    margin-top: 1em;
  }

  .sec01_cta_btn01 {
    margin-top: 1em;
  }

  .sec01_cta_btn01 a:hover {
    filter: brightness(1.2);
  }

  .sec01_cta_btn01 img {
    height: auto;
    width: auto;
  }

  .sec01_en_reservation {
    position: absolute;
    left: 2%;
    bottom: 2%;
    width: 84%;
    filter: invert(39%) sepia(22%) saturate(458%) hue-rotate(356deg) brightness(94%) contrast(89%);
  }

  /* section02 */
  .top-section02 {
    position: relative;
    text-align: center;
    padding: 70px 5% 40px;
  }

  .sec02_img01 {
    width: 70%;
    margin-inline: auto;
  }

  .sec02_txt01 {
    position: absolute;
    width: 2932px;
    left: 30%;
    top: 17%;
  }

  .sec02_overlay {
    position: relative;
    background: #1A1311;
    padding: 40px 0;
    /* margin-top: 140px; */
    background: url(../img/sec01.jpg) no-repeat center top;
    background-size: cover;
  }

  .sec02_overlay::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #2a1f1fc7;
    backdrop-filter: blur(15px);
  }

  .sec02_overlay_in {
    position: relative;
    width: clamp(300px, 85%, 1400px);
    margin-inline: auto;
    display: flex;
    gap: 40px;
    z-index: 2;
    flex-direction: column;
  }

  .sec02_overlay_txt01 {
    width: 100%;
    /* color: #fff; */
  }

  .sec02_overlay_ttl01 {
    font-size: 4.5vw;
    line-height: 1.8;
  }

  .sec02_overlay_map {
    margin-top: 2em;
    text-align: center;
    margin-left: -8%;
    margin-right: 0;
  }

  .sec02_overlay_links {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .sec02_overlay_link_list {
    background: #fff;
    padding: .5em .8em 1em;
    font-size: 15px;
    display: flex;
    flex-wrap: wrap;
    gap: 2%;
  }

  .sec02_overlay_link_list li {
    padding: .7em 0;
    border-bottom: 1px solid #000;
    width: calc((100% - 4%) / 3);
  }

  .sec02_overlay_link_list li:last-child {
    border: none;
    border-bottom: 1px solid #000;
  }

  .sec02_overlay_link_list li a {
    display: flex;
    gap: 10px;
    align-items: center;
  }

  .sec02_overlay_link_list li a::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: .4em .3em 0 .3em;
    border-color: #BCBDBD transparent transparent transparent;
    margin-top: .2em;
  }

  .sec02_overlay_link_list li a:hover {
    color: #999;
    transform: translateY(3px);
  }

  .sec02_overlay_map a {
    display: inline-block;
    font-size: 2.5vw;
    /* color: #C8A52C; */
    /* background: #1A1311; */
    line-height: 1.2;
    padding: .3em .5em;
  }

  .sec02_overlay_map a:hover {
    background: #C8A52C;
    color: #1A1311;
  }

  .area_map_link01 {
    position: absolute;
    top: 45.0%;
    left: 22.5%;
  }

  .area_map_link02 {
    position: absolute;
    top: 23%;
    left: 39.5%;
  }

  .area_map_link03 {
    position: absolute;
    top: 33.5%;
    left: 52.5%;
  }

  .area_map_link04 {
    position: absolute;
    top: 26%;
    left: 57.5%;
  }

  .area_map_link05 {
    position: absolute;
    top: 28%;
    left: 24%;
  }

  .area_map_link06 {
    position: absolute;
    top: 35%;
    left: 29.5%;
  }

  .area_map_link07 {
    position: absolute;
    top: 50%;
    left: 53.5%;
  }

  .area_map_link08 {
    position: absolute;
    top: 83.5%;
    left: 47%;
  }

  .area_map_link09 {
    position: absolute;
    top: 41.5%;
    left: 57%;
  }

  /* section03 */
  .section03 {
    position: relative;
    display: flex;
    flex-direction: column;
  }

  .section03-in01 {
    width: 100%;
    flex: 1;
    border-right: none;
    padding: 70px 7.5% 30px;
  }

  .exhibition_ttl01 {
    text-align: center;
  }

  .exhibition_ttl01 img {
    width: 48.5vw;
    height: auto;
    padding-left: 0;
  }

  .exhibition_txt01 {
    font-size: 3.6vw;
    line-height: 2;
    margin-top: 10px;
  }

  .icon_set {
    margin-top: 20px;
  }

  .icon_set img {
    width: 95%;
    height: auto;
  }

  .section03-in02 {
    width: 100%;
    padding: 40px 0 40px;
  }


  .exhibition_list_contents {
    width: clamp(150px, 85%, 1183px);
    margin-left: 7.5%;
  }

  .exhibition_list_ttl01 {
    color: #999;
    font-size: clamp(33px, 2.9vw, 57px);
    line-height: 1;
    display: flex;
    gap: 5px;
    align-items: center;
    margin-bottom: .8em;
    padding-top: 30px;
    margin-top: -30px;
  }

  .exhibition_list_ttl01 .jp {
    font-size: .4em;
    padding-top: .5em;
  }

  .exhibition_list {
    display: flex;
    flex-wrap: wrap;
    gap: 70px 12%;
  }

  .exhibition_list_item {
    width: 100%;
  }

  .exhibition_list_item_img {
    position: relative;
    aspect-ratio: 1 / 1;
    cursor: pointer;
  }

  .item_img01,
  .item_img02 {
    position: relative;
    top: initial;
    left: initial;
    width: 100%;
    height: auto;
  }

  .exhibition_list_item_img:hover .item_img02 {
    opacity: 0;
    transition: all .5s ease;
  }

  .exhibition_list_item_ttl01 {
    text-align: center;
    font-size: clamp(18px, 1.35vw, 30px);
    padding: 0 0 1em;
    border-bottom: .5px solid #000;
    margin-bottom: 1em;
  }

  .exhibition_list_item_txt01 {
    font-size: clamp(15px, 1.1vw, 22px);
  }

  .exhibition_list_item_txt02 {
    font-size: 3.1vw;
    margin-top: 1em;
  }

  .u-small {
    font-size: 0.8em;
  }

  .exhibition_list_item_cta {
    display: flex;
    margin-top: 0;
  }

  .exhibition_list_item_icons {
    display: flex;
    gap: 5px;
    align-items: flex-end;
    margin-top: 10px;
  }

  .exhibition_list_item_icons li {
    width: 30px;
  }

  .exhibition_list_item_btn {
    margin-left: auto;
    /* display: none; */
  }

  .exhibition_list_item_btn a:hover {
    filter: brightness(2);
  }

  /* section04 merit */
  .section04 {
    position: relative;
    padding: 60px 0 40px;
  }

  .merit_ttl01 {
    width: clamp(250px, 85%, 1200px);
    margin-inline: auto;
    margin-bottom: 2em;
  }

  .merit_ttl01 img {
    width: 67.5vw;
    height: auto;
    padding-left: 0;
  }

  .l-container-lx {
    width: clamp(20px, 85%, 1400px);
    margin-inline: auto;
    vertical-align: baseline !important;
  }

  .section04_ttl01 {
    font-size: 5.5vw;
    line-height: 1.6;
    vertical-align: baseline !important;
    letter-spacing: .1em;
  }

  [data-ruby] {
    position: relative;
    /* margin-top: -.5em; */
    display: inline-block;
    transform: translateY(-.20em);
  }

  [data-ruby]::before {
    content: attr(data-ruby);
    position: absolute;
    top: -.2em;
    left: 0;
    right: 0;
    margin: auto;
    font-size: 0.35em;
    line-height: 1;
    letter-spacing: 0;
    text-align: center;
  }

  /* 以下追加 */
  rt {
    display: none;
  }

  .section04_txt01 {
    font-size: 3.8vw;
    line-height: 2;
    margin-top: 1em;
  }

  .merit-contents {
    display: flex;
    gap: 1px;
    margin-top: 40px;
    flex-direction: column;
  }

  .merit-contents_item {
    color: #fff;
    width: 100%;
    height: 45vw;
    display: flex;
    align-items: center;
    justify-content: center;
    -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    cursor: pointer;
  }

  .merit-contents .merit-contents_item:nth-child(1) {
    background: url(../img/cont_bg01_sp.jpg) no-repeat center 29%;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(2) {
    background: url(../img/cont_bg02_sp.jpg) no-repeat center top;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(3) {
    background: url(../img/cont_bg03_sp.jpg) no-repeat center 45%;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(4) {
    background: url(../img/cont_bg04_sp.jpg) no-repeat center top;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(1).is_active {
    background: url(../img/cont_bg01_sp.jpg) no-repeat center center;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(2).is_active {
    background: url(../img/cont_bg02_sp.jpg) no-repeat center center;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(3).is_active {
    background: url(../img/cont_bg03_sp.jpg) no-repeat center center;
    background-size: cover;
  }

  .merit-contents .merit-contents_item:nth-child(4).is_active {
    background: url(../img/cont_bg04_sp.jpg) no-repeat center center;
    background-size: cover;
  }

  .merit-contents_item_ttl01 {
    font-size: 5.6vw;
    text-align: center;
    -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  }

  .merit-contents_item_in {
    display: none;
    -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  }

  .merit-contents_item:hover {
    width: 100%;
  }

  .merit-contents_item.is_active {
    width: 100%;
    height: 85vh;
  }

  .merit-contents_item.is_active .merit-contents_item_ttl01 {
    opacity: 0;
    display: none;
  }

  .merit-contents_item.is_active .merit-contents_item_in {
    display: flex;
    flex-direction: column;
    width: clamp(300px, 90%, 1400px);
    height: 100%;
    margin-inline: auto;
    justify-content: center;
  }

  .merit-contents_item_ttl02 {
    font-size: 7vw;
    text-align: center;
  }

  .merit-contents_item_txt {
    width: 100%;
    background: #1A1311;
    padding: 1.5em;
    font-size: 16px;
    line-height: 1.8;
    margin-top: 2em;
    text-align: justify;
  }

  .merit-contents_item.is_close {
    height: 0;
    width: 100%;
  }

  .merit-contents_item.is_close .merit-contents_item_ttl01 {
    opacity: 0;
    transition: none
  }

  .merit-more {
    width: 85%;
    margin-inline: auto;
    display: flex;
    justify-content: center;
    margin-top: 40px;
    gap: 20px;
    flex-direction: column;
  }

  .merit-more li {
    width: 100%;
    height: 24vw;
    display: flex;
    position: relative;
    justify-content: center;
    align-items: center;
    font-size: 16px;
    line-height: 1.5;
    text-align: center;
    border: .5px solid #000;
    padding: 1.5em;
  }

  .merit-more li a {
    display: block;
    width: 100%;
    height: 100%;
    padding: .6em 1.5em;
  }

  .merit-more li::before {
    content: "";
    position: absolute;
    width: 2em;
    height: 2em;
  }

  .section05 {
    position: relative;
    padding: 49vw 0 71vw;
    background: #F5F1ED;
    color: #42362F;
  }

  .section05_img01 {
    position: absolute;
    top: 30px;
    left: 50%;
    width: 43.4%;
  }

  .section05_img02 {
    position: absolute;
    top: 77%;
    right: 9.8%;
    width: 29.4%;
  }

  .section05_img03 {
    position: absolute;
    top: 70.3%;
    left: 10%;
    width: 42.2%;
  }

  .scroll-txt {
    width: 100%;
    display: flex;
    overflow: hidden;
    gap: 5em;
  }

  .section05_ttl01 {
    font-size: 9.0vw;
    padding-left: 4%;
    line-height: 1.3;
    letter-spacing: -.1em;
    flex-shrink: 0;
    width: auto;
    height: auto;
    display: inline-block;
    text-wrap: nowrap;
    white-space: nowrap;
    /* animation: anim--first 15s infinite linear 0.1s both; */
  }

  @keyframes anim--first {
    0% {
      transform: translateX(30%);
      opacity: 0;
    }

    10% {
      opacity: 1;
    }

    100% {
      transform: translateX(-110%);
    }
  }

  .section06_ttl01 {
    font-size: 6vw;
    line-height: 1.5;
    letter-spacing: -.1em;
    margin-top: 3em;
    text-align: center;
  }

  .u-big01 {
    font-size: 1.5em;
    margin: 0 -.5em 0 -.6em;
  }

  .u-big01.u-tsume01 {
    margin: 0 -.5em 0 -.6em;
  }

  .u-sage-sp {
    padding-left: .5em;
  }

  .section05_txt01 {
    font-size: clamp(15px, 1.6vw, 30px);
    margin-top: 1em;
    line-height: 2;
    padding-left: 1em;
  }

  .section06 {
    position: relative;
    padding: 0 0 63vw;
    background: #BD9A83;
    color: #fff;
  }

  .section06_img01 {
    width: 100%;
  }

  .section06_in {
    position: relative;
    border-top: none;
    margin-top: 35vw;
  }

  .en-light {
    position: absolute;
    width: 100%;
    top: 126vw;
    left: -36.5vw;
  }

  .en-light img {
    transform: rotate(90deg);
    height: 27vw;
  }

  .section06_img02 {
    width: 60%;
  }

  .section06_img03 {
    position: absolute;
    width: 30.7%;
    top: 116%;
    left: 62%;
  }

  .section06_img04 {
    position: absolute;
    width: 54%;
    top: 116%;
    left: 8%;
  }

  .section06_txt01 {
    font-size: 3.2vw;
    margin-top: 1.5em;
    line-height: 2;
    text-align: center;
  }


  .section07 {
    position: relative;
    padding: 0 0 53vw;
    background: #95AEBB;
    margin-top: 0;
    color: #fff;
  }

  .section07_img01 {
    width: 100%;
  }

  .section07_in {
    position: relative;
    border-top: none;
    margin-top: 110px;
  }

  .en-air {
    position: absolute;
    width: 100%;
    top: 129vw;
    left: -32.5vw;
  }

  .en-air img {
    transform: rotate(90deg);
    height: 22vw;
  }

  .section07_img02 {
    width: 100%;
    margin-left: 0;
  }

  .section07_img03 {
    position: absolute;
    width: 46.4%;
    top: 109%;
    left: 27.1%;
  }

  .section08 {
    position: relative;
    padding: 0 0 50vw;
    background: #75715E;
    margin-top: 0;
    color: #fff;
  }

  .section08_img01 {
    width: 100%;
  }

  .section08_in {
    position: relative;
    border-top: none;
    margin-top: 35vw;
  }

  .en-design {
    position: absolute;
    width: 100%;
    top: 114vw;
    left: -36.5vw;
  }

  .en-design img {
    transform: rotate(90deg);
    height: 27vw;
  }

  .section08_img02 {
    width: 61.8%;
    margin-left: 38.2%;
  }

  .section08_img03 {
    position: absolute;
    width: 32.8%;
    top: 107%;
    left: 60%;
  }

  .section08_img04 {
    position: absolute;
    width: 47.5%;
    bottom: 0;
    right: initial;
    left: 0;
  }

  .section09 {
    margin-top: 50px;
  }

  .section09_links {
    width: clamp(300px, 85%, 1400px);
    display: flex;
    margin-inline: auto;
    flex-direction: column;
    gap: 30px;
  }

  .section09_links_item {
    width: 100%;
  }

  .section09_links_item:nth-child(1) {
    border-right: none;
    padding: 0 0 0 0;
  }

  .section09_links_item:nth-child(2) {
    padding: 0 0 0 0;
  }

  .section09_links_item a {
    display: flex;
    gap: 4%;
  }

  .section09_links_item:nth-child(1) a {
    flex-direction: row;
    text-align: justify;
  }

  .section09_links_item_img {
    width: 51.1%;
  }

  .section09_links_item_txt {
    flex: 1;
  }

  .section09_links_item_ttl01 {
    font-size: 3.4vw;
    margin-top: -.2em;
  }

  .section09_links_item_txt02 {
    font-size: 2.9vw;
    margin-top: 1.2em;
  }

  .section09_links_item_txt03 {
    position: relative;
    font-size: 16px;
    margin-top: 1.2em;
    display: flex;
    gap: 10px;
    -webkit-transition: .4s;
    transition: .4s;
  }

  .section09_links_item:nth-child(1) .section09_links_item_txt03 {
    justify-content: flex-start;
  }

  .section09_links_item_txt03 span {
    display: inline-block;
    border-bottom: 1px solid #000;
    padding-bottom: 2px;
  }

  .section09_links_item_txt03::after {
    content: "";
    background: url(../img/flow_maru01.svg) no-repeat center center;
    background-size: contain;
    width: 26px;
    height: 26px;
  }

  .section09_links_item a:hover .section09_links_item_txt03 {
    transform: translateX(10px);
  }

  .section10 {
    background: url(../img/img06_01_sp.jpg) no-repeat center top;
    background-size: cover;
    padding: 40px 5%;
    margin-top: 60px;
    display: flex;
    gap: 5%;
  }

  .banner01,
  .banner02 {
    width: clamp(300px, 85%, 1020px);
    margin-inline: auto;
  }

  .section11 {
    margin-top: 40px;
  }

  .section12 {
    margin-top: 40px;
    text-align: center;
  }

  .section12_ttl01 {
    font-size: 5.0vw;
  }

  .section12_ttl02 {
    font-size: 4.5vw;
    position: relative;
    padding: 0 .5em;
    margin-top: 1em;
  }

  .section12_ttl02 span {
    padding: 0 .5em .5em;
    border-bottom: .5px solid #000;
  }

  .flow {
    background: url(../img/flow_bg_sp.jpg) no-repeat center top;
    background-size: cover;
    margin-top: 40px;
  }

  .flow_item {
    width: clamp(300px, 85%, 710px);
    background-size: cover;
    margin-inline: auto;
    background: none;
    padding: 40px 0;
  }

  .flow_item_ttl01 {
    font-size: 5.5vw;
    line-height: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
  }

  .flow_item_ttl01 .flow_number {
    font-size: 1.2em;
    margin-left: .2em;
  }

  .flow_item_txt01 {
    font-size: 3.8vw;
    margin-top: 1em;
  }

  .flow_item_arrow {
    padding: 15px 0 20px;
  }

  .flow_item_arrow img {
    height: 3vw;
    width: auto;
  }

  .section13 {
    margin-top: 40px;
    text-align: center;
  }

  .section13_ttl01 {
    font-size: 5.0vw;
  }

  .section13_txt01 {
    font-size: 3.8vw;
    margin-top: 1.5em;
  }

  .section14 {
    margin-top: 40px;
  }

  .section14 .l-container-lx {
    width: 100%;
    ;
  }

  .faq_ttl01 {
    font-size: 5.0vw;
    line-height: 1;
    text-align: center;
    color: #fff;
    background: #866E48;
    padding: .5em 0;
    margin: 0 5%;
  }

}


/* 20250515 */
.section05_v02 .l-container-lx {
    width: clamp(250px, 80%, 945px);
    margin-inline: auto;
}

.section05_v02_ttl01 {
  font-size: 30px;
  line-height: 1.6;
  vertical-align: baseline !important;
  letter-spacing: .1em;
  text-indent: -.5em;
}

.section05_v02_txt01 {
  font-size: 16px;
  line-height: 2;
  margin-top: 1em;
}

.section05_v02_list {
  display: flex;
  margin-top: 40px;
}

.section05_v02_list_item {
  width: calc(100% / 3);
  color: #fff;
  text-align: justify;
}

.section05_v02_list_item:nth-child(1) {
  background: #BD9A83;
}
.section05_v02_list_item:nth-child(2) {
  background: #95AEBB;
}
.section05_v02_list_item:nth-child(3) {
  background: #75715E;
}

.section05_v02_img01 {
  position: relative;
}

.section05_v02_list_item_inner {
  position: relative;
  padding: 5em 16% 4em;
}

.en_v02 {
  position: absolute;
  width: 100%;
  bottom: -3.5vw;
  left: 16%;
}
.en_v02 img {
  height: 5.5vw;
  width: auto;
}

.section05_v02_list_item_ttl01 {
  font-size: clamp(20px, 2vw, 43px);
  line-height: 1.2;
  margin-top: 0;
  margin-left: -.5em;
  font-weight: 600;
}

.section05_v02_list_item_ttl02 {
  font-size: clamp(15px, 1vw, 22px);
  line-height: 1.2;
  margin-top: 1em;
  font-weight: 600;
}

.section05_v02_list_item_txt01 {
  font-size: clamp(14px, .8vw, 17px);
  line-height: 1.6;
  margin-top: 1em;
}

@media (max-width: 800px) {
  .section05_v02 .l-container-lx {
    width: clamp(250px, 80%, 945px);
    margin-inline: auto;
  }

  .section05_v02_ttl01 {
    font-size: 5.5vw;
    line-height: 1.6;
  }

  .section05_v02_txt01 {
    font-size: 3.8vw;
    line-height: 2;
    margin-top: 1em;
  }

  .section05_v02_list {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
  }

  .section05_v02_list_item {
    width: 100%;
    display: flex;
  }

  .section05_v02_img01 {
    width: 40%;
  }

  .section05_v02_list_item_inner {
    position: relative;
    padding: 1em 6%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
  }

  .en_v02 {
    position: absolute;
    width: 100%;
    bottom: initial;
    top: 10px;
    left: -5.5%;
  }
  .en_v02 img {
    height: auto;
    width: 11vw;
  }

  .section05_v02_list_item_ttl01 {
    font-size: clamp(20px, 2vw, 43px);
    line-height: 1.2;
    margin-top: 0;
    margin-left: -.5em;
    font-weight: 600;
  }

  .section05_v02_list_item_ttl02 {
    font-size: clamp(15px, 1vw, 22px);
    line-height: 1.2;
    margin-top: 1em;
    font-weight: 600;
    display: none;
  }

  .section05_v02_list_item_txt01 {
    font-size: clamp(13px, .8vw, 17px);
    line-height: 1.5;
    margin-top: .8em;
  }
}