@charset "UTF-8";
html { scroll-behavior: smooth; }
body {
    font-family: "dnp-shuei-mincho-pr6n", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 16px;
    color: #555;
    width: 100%;
    height: 100vh;
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #f1e1dd;
}
.fadeIn {
  opacity: 0;
  transition: 2s;
  display: ;
  z-index: 10;
}
.fadeIn.is-show { opacity: 1; }
/*===========
inview
===========*/

.fadeIn_up {
  opacity: 0;
  transform: translate(0, 5%);
  transition: 2s;
}
.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

.fadeIn_up02 {
  opacity: 0;
  transform: translate(0, 5%);
  transition: 1s;
}
.fadeIn_up02.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

.fadeIn_up03 {
  opacity: 0;
  transform: translate(0, 20%);
  transition: 1s;
}
.fadeIn_up03.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

.fadeIn_up04 {
  opacity: 0;
  transform: translate(0, 30%);
  transition: 1.5s;
}
.fadeIn_up04.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

.fadeIn_up05 {
  opacity: 0;
  transform: translate(0, 40%);
  transition: 2s;
}
.fadeIn_up05.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

.fadeIn_up06 {
  opacity: 0;
  transform: translate(0, 50%);
  transition: 2.5s;
}
.fadeIn_up06.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*----------------------- PC -----------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/

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

/*----------------------   header   ----------------------*/

#pc_wrap {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 45vw;
  height: 100vh;
}
#pc_wrap02 {
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  width: 45vw;
  height: 100vh;
}
#pc_wrap .wrap_rogo {
  display: block;
  width: 250px;
  position: absolute;
  bottom: 45vh;
  left: 50%;
  transform: translateX(-50%);
}
#pc_wrap02 ul {
  display: block;
  width: 250px;
  position: absolute;
  bottom: 20vh;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  font-family: "Bodoni Moda", serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
  z-index: 10;
}
#pc_wrap02 ul li { padding: 20px 0; }
#pc_wrap02 ul li a span {
  color: #da978c;
  font-size: 28px;
}
#pc_wrap02 ul li a {
  color: #4f4c4e;
  font-size: 10px;
}
.main_content {
  position: relative;
  display: block;
  width: 400px;
  margin: 80px auto 0;
  background-color: white;
  box-shadow: 0px 0px 0px 0px rgba(40, 40, 40, 0.25);
}
.wrap_container_01 ,
.wrap_container_02 ,
.wrap_container_03 ,
.wrap_container_04 ,
.wrap_container_05 ,
.wrap_container_06 ,
.wrap_container_07 ,
.wrap_container_08 ,
.wrap_container_09 {
  position: relative;
  display: block;
  width: 400px;
  margin: 0 auto;
  background-color: white;
  box-shadow: 0px 5px 15px 0px rgba(201, 153, 145, 0.25);
}
/* 上下の影を消すカバー */
.main_content::after,
.wrap_container_01::before,
.wrap_container_01::after,
.wrap_container_02::before,
.wrap_container_02::after,
.wrap_container_03::before,
.wrap_container_03::after,
.wrap_container_04::before,
.wrap_container_04::after,
.wrap_container_05::before,
.wrap_container_05::after,
.wrap_container_06::before,
.wrap_container_06::after,
.wrap_container_07::before,
.wrap_container_07::after,
.wrap_container_08::before,
.wrap_container_08::after,
.wrap_container_09::before{
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 10px; /* 影を消す範囲 */
  background-color: white; /* 背景と同じ色で影を覆う */
  z-index: 1;
}
.main_content::before,
.wrap_container_01::before,
.wrap_container_02::before,
.wrap_container_03::before,
.wrap_container_04::before,
.wrap_container_05::before,
.wrap_container_06::before,
.wrap_container_07::before,
.wrap_container_08::before,
.wrap_container_09::before {
  top: 0;
}
.main_content::after,
.wrap_container_01::after,
.wrap_container_02::after,
.wrap_container_03::after,
.wrap_container_04::after,
.wrap_container_05::after,
.wrap_container_06::after,
.wrap_container_07::after,
.wrap_container_08::after,
.wrap_container_09::after {
  bottom: 0;
}
.wrap_container_01 video {
  position: absolute;
  top: 230px;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  display: block;
  width: 200px;
  margin: 0 auto;
}
.wrap_container_06 { height: 2100px; }
.wrap_button {
  position: relative;
  display: block;
  width: 400px;
  margin: 0 auto;
  box-shadow: 0px 0px 0px 0px rgba(40, 40, 40, 0.25);
}
.fixed-button {
  position: fixed;
  bottom: 20px;  /* 画面下からの距離 */
  width: 400px;   /* ボタンのサイズ */
  height: auto;  /* 縦横比を維持 */
  cursor: pointer; /* クリックしやすく */
  z-index: 1000; /* 他の要素より上に */
  transition: transform 0.3s ease, box-shadow 0.3s ease; /* なめらかに動かす */
  filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.2)); /* 通常時の影 */
}
.fixed-button:hover {
  transform: translateY(-5px); /* 5pxだけ上に浮く */
  filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.3)); /* ホバー時の影を強調 */
}
.wrap_container_02 .image_wrap {
  display: block;
  position: absolute;
  top: 50px;
  left: 50%;
  z-index: 100;
  overflow: hidden;
}
.wrap_container_02 .image_wrap::before {
  animation: displayImg 2.5s linear forwards;
  background: #f4ede8;
  content: '';
  pointer-events: none;
  position: absolute;
  inset: 0;
  z-index: 1;
}
@keyframes displayImg { 100% { transform: translateY(100%); } }
.wrap_container_02 .image_wrap img {
  display: block;
  width: 8px;
}
.wrap_container_02 .image_wrap02 img {
  display: block;
  position: absolute;
  top: 100px;
  z-index: 100;
  overflow: hidden;
}
.wrap_container_02 .image_wrap03 img ,
.wrap_container_02 .image_wrap04 img ,
.wrap_container_02 .image_wrap05 img ,
.wrap_container_02 .image_wrap06 img {
  display: block;
  position: absolute;
  top: 520px;
}
.wrap_container_02 .image_wrap07 img {
  display: block;
  position: absolute;
  top: 840px;
}
.wrap_container_02 .image_wrap08 img {
  display: block;
  position: absolute;
  top: 905px;
}
.wrap_container_02 .image_wrap09 img {
  display: block;
  position: absolute;
  bottom: 380px;
}
.wrap_container_03 {
  position: relative;
  display: block;
}
.wrap_container_03 .image_wrap01 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 55px;
  z-index: 100;
}
.wrap_container_03 .image_wrap02 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 180px;
  z-index: 0;
}
.wrap_container_03 .image_wrap02 img {
  display: block;
  z-index: 0;
}
.wrap_container_03 .video02 {
  position: absolute;
  top: 950px;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  width: 300px;
  margin: 0 auto;
  z-index: 100;
}
.wrap_container_03 .image_wrap03 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 650px;
  z-index: 10;
}
.wrap_container_03 .video03 {
  position: absolute;
  top: 1600px;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  width: 300px;
  margin: 0 auto;
  z-index: 100;
}
.wrap_container_03 .image_wrap04 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 1230px;
  z-index: 10;
}
.wrap_container_03 .image_wrap05 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 1785px;
  z-index: 10;
}
.wrap_container_04 .image_wrap01 {
  animation-name: fadein;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  bottom: 350px;
  z-index: 10;
}
.wrap_container_06 .image_wrap01 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity: 1;
  position: absolute;
  top: 125px;
  z-index: 10;
}
.wrap_container_06 .image_wrap02 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity: 1;
  position: absolute;
  top: 760px;
  z-index: 10;
}
.wrap_container_06 .image_wrap03 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity: 1;
  position: absolute;
  top: 1420px;
  z-index: 200;
}
@keyframes fade_bottom {
  from {
    opacity: 0;
    transform: translateY(80px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeInUp01 {
  display: block;
  width: 100%;
  margin: 0 auto;
  position: absolute;
  bottom: 55px;
  right: 0;
  left: 0;
  animation-name: fadein;
  animation-duration: 2s;
}
@keyframes fadein {
    from {
      opacity: 0;
      transform: translateY(40px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
.fadeInUp02 { animation: opacityFadeIn 1.7s ease 0s 1 normal; }
@keyframes opacityFadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}
.before_after_slider {
  display: block;
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  overflow: hidden;
  width: 300px;
  max-width: 100%;
}
.box_before {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 50%;
  height: 100%;
  border-right: 3px solid rgba(255, 255, 255, 0.7);
  box-shadow: 10px 0 15px -13px #000;
}
.box_before img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
}
.box_before::before {
  content: '◀︎ ▶︎';
  z-index: 1;
  position: absolute;
  top: 0;
  right: -20px;
  bottom: 0;
  width: 35px;
  height: 35px;
  color: white;
  font-size: 10px;
  margin: auto;
  border: 3px solid rgba(255, 255, 255, .7);
  border-radius: 50%;
  box-shadow: 10px 0 15px -13px #000;
  background-color: rgba(255, 255, 255, .7);
  text-align: center;
  line-height: 30px;
}
.slider_range {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  opacity: 0;
  cursor: col-resize;
}
.wrap_container_05 .carousel {
  display: flex;
  justify-content: center;
  position: absolute;
  top: 380px;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.wrap_container_05 .contains {
  width: 400px;
  height: 480px;
  overflow: hidden;
  position: relative;
  padding: 0;
  list-style: none;
}
.wrap_container_05 .slide_select { display: none; }
.wrap_container_05 .slide {
  width: 400px;
  height: 480px;
  position: absolute;
  opacity: 0;
  transition : all 0.5s;
}
.wrap_container_05 .slide img {
  display: block;
  margin: 0 auto;
  box-shadow: 0px 0px 20px -5px #b57f77;
}
.wrap_container_05 .scroll_button {
  position: absolute;
  display: block;
  height: 30px;
  width: 30px;
  top: 50%;
  margin-top: -20px;
  border-width: 1px 1px 0 0;
  border-style: solid;
  border-color: #333;
  cursor: pointer;
  opacity: 0.5;
  z-index: 3;
  transition : all 0.5s;
}
.wrap_container_05 .scroll_button:hover { opacity: 1; }
.wrap_container_05 .scroll_prev {
  left: 15px;
  transform: rotate(-135deg);
}
.wrap_container_05 .scroll_next {
  right: 15px;
  transform: rotate(45deg);
}
.wrap_container_05 .move_controler {
  position: absolute;
  bottom: 0px;
  width: 100%;
  text-align: center;
}
.wrap_container_05 .button_move {
  display: inline-block;
  height: 12px;
  width: 12px;
  margin: 0 2px;
  border-radius: 100%;
  cursor: pointer;
  opacity: 0.5;
  z-index: 2;
}
.wrap_container_05 .button_move:hover { opacity: 0.75; }
.wrap_container_05 .button_move { background-color: #C79E97 }
.slide_select:nth-of-type(1):checked ~ .slide:nth-of-type(1) { opacity: 1; }
.slide_select:nth-of-type(1):checked ~ .move_controler
.button_move:nth-of-type(1) { opacity: 1; }
.slide_select:nth-of-type(2):checked ~ .slide:nth-of-type(2) { opacity: 1; }
.slide_select:nth-of-type(2):checked ~ .move_controler
.button_move:nth-of-type(2) { opacity: 1; }
.slide_select:nth-of-type(3):checked ~ .slide:nth-of-type(3) { opacity: 1; }
.slide_select:nth-of-type(3):checked ~ .move_controler
.button_move:nth-of-type(3) { opacity: 1; }
.slide_select:nth-of-type(4):checked ~ .slide:nth-of-type(4) { opacity: 1; }
.slide_select:nth-of-type(4):checked ~ .move_controler
.button_move:nth-of-type(4) { opacity: 1; }
.slideshow {
  position: absolute;
  top: 100px;
  overflow: hidden;
  width: 100%;
}
input[name="slideshow"] { display: none; }
.slideContents {
  display: flex;
  position: relative;
  width: 500%;
  text-align: center;
  -webkit-user-select: none;
  user-select: none;
  transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.slideContents section { width: 100%; }
.slideContents section img {
  max-width: 100%;
  height: auto;
  padding: 50px;
  box-sizing: border-box;
  vertical-align: middle;
}
.arrow,
.arrow label,
.arrow .ico { position: absolute; }
.arrow {
  top: 0;
  margin: 0;
  transition: background .3s;
}
.prev { left: 0; }
.next { right: 0; }
.arrow:hover { background: rgba(255,255,255,.2); }
.arrow,
.arrow label {
  cursor: pointer;
  width: 50px;
  height: 100%;
}
.arrow label {
  top: 0;
  left: 0;
  z-index: 1;
}
.arrow .ico {
  top: calc(50% - 6px);
  width: 12px;
  height: 12px;
  border-top: 3px solid #e6b3a3;
  opacity: 0;
}
.prev .ico {
  left: 50%;
  border-left: 3px solid #e6b3a3;
  transform: rotate(-45deg);
  transition: left .3s cubic-bezier(0.215, 0.61, 0.355, 1), opacity .3s;
}
.next .ico {
  right: 50%;
  border-right: 3px solid #e6b3a3;
  transform: rotate(45deg);
  transition: right .3s cubic-bezier(0.215, 0.61, 0.355, 1), opacity .3s;
}
.arrow .ico { opacity: .6; }
.prev .ico { left: calc(50% - 6px); }
.next .ico { right: calc(50% - 6px); }
#switch1:checked ~ .slideContents { transform: translateX(0); }
#switch2:checked ~ .slideContents { transform: translateX(-20%); }
#switch3:checked ~ .slideContents { transform: translateX(-40%); }
#switch4:checked ~ .slideContents { transform: translateX(-60%); }
#switch5:checked ~ .slideContents { transform: translateX(-80%); }
.arrow label { pointer-events: none; }
#switch1:checked ~ .prev label[for="switch5"],
#switch2:checked ~ .prev label[for="switch1"],
#switch3:checked ~ .prev label[for="switch2"],
#switch4:checked ~ .prev label[for="switch3"],
#switch5:checked ~ .prev label[for="switch4"],
#switch1:checked ~ .next label[for="switch2"],
#switch2:checked ~ .next label[for="switch3"],
#switch3:checked ~ .next label[for="switch4"],
#switch4:checked ~ .next label[for="switch5"],
#switch5:checked ~ .next label[for="switch1"] { pointer-events: auto; }
.wrap_container_06 {
  font-family: "dnp-shuei-mincho-pr6n", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.accordion {
  margin: 1rem auto 0;
  max-width: 90%;
}
.toggle { display: none; }
.faq {
  position: relative;
  border-top: 1px solid #db978c; /* 2つ目以降のQには線を適用 */
}
.question,.anser {
  transform: translateZ(0);
  transition: all 0.3s;
  display: flex;
  flex-wrap: wrap;
  border-top: none; /* .faq で border-top をつけたので、ここでは不要 */
  cursor: pointer;
}
.question img {
  vertical-align: top;
  padding: 15px 5px 15px 10px;
  width: 45px;
  height: 100%;
}
.anser img {
  vertical-align: top;
  padding: 15px 5px 15px 10px;
  width: 45px;
  height: 100%;
}
.question p {
  color: #4d4d4d;
  font-size: 14px;
  padding: 15px;
  line-height: 1.5;
  width: 280px;
  text-align: justify;
  text-justify: inter-ideograph;
}
.anser p {
  color: #4d4d4d;
  font-size: 14px;
  padding: 15px 0 50px;
  line-height: 1.5;
  width: 300px;
  text-align: justify;
  text-justify: inter-ideograph;
  font-feature-settings: "palt";
}
.anser p span {
  font-size: 11px;
  line-height: 3;
}
.question:after,.question:before {
  content: "";
  position: absolute;
  right: 1.5rem;
  top: .5rem;
  bottom: 0;
  margin: auto;
  width: 2px;
  height: 1.5rem;
  background-color: #db978c;
  transition: all 0.3s;
}
.question:after { transform: rotate(90deg); }
.anser {
  border-top: solid 1px #db978c;
  max-height: 0;
  overflow: hidden;
}
.toggle:checked + .question + .anser {
  max-height: 500px;
  transition: all 1.5s;
}
.toggle:checked + .question:before {transform: rotate(90deg) !important; }
.wrap_container_09 .image_wrap01 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 310px;
  right: 30px;
  z-index: 100;
}
.wrap_container_09 .image_wrap02 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 345px;
  right: 125px;
  z-index: 100;
}
.wrap_container_09 .image_wrap03 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 395px;
  right: 40px;
  z-index: 100;
}
.wrap_container_09 .image_wrap04 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 400px;
  right: 160px;
  z-index: 100;
}
.wrap_container_09 .image_wrap05 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 365px;
  right: 220px;
  z-index: 100;
}
.wrap_container_09 .image_wrap06 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 450px;
  right: 220px;
  z-index: 100;
}
.wrap_container_09 .image_wrap07 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 410px;
  right: 305px;
  z-index: 100;
}
.wrap_container_09 .image_wrap01 img ,
.wrap_container_09 .image_wrap02 img ,
.wrap_container_09 .image_wrap03 img ,
.wrap_container_09 .image_wrap04 img ,
.wrap_container_09 .image_wrap05 img ,
.wrap_container_09 .image_wrap06 img ,
.wrap_container_09 .image_wrap07 img { width: 60px; }
.wrap_container_09 a { transition : all 0.5s; }
.wrap_container_09 a:hover {
  transition : all 0.5s;
  opacity: .5;
}

}

/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*----------------------- SP -----------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/

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

/*----------------------   header   ----------------------*/

#pc_wrap ,#pc_wrap02  { display: none; }

.main_content {
  position: relative;
  display: block;
  background-color: white;
}
.wrap_container_01 ,
.wrap_container_02 ,
.wrap_container_03 ,
.wrap_container_04 ,
.wrap_container_05 ,
.wrap_container_06 {
  position: relative;
  display: block;
  margin: 0 auto;
  background-color: white;
}
.wrap_container_07 {
  position: absolute;
  bottom: 0;
  display: block;
  padding: 230vw 0 0;
  margin: 0 auto;
  background-color: white;
}
.wrap_container_07 ,
.wrap_container_08 ,
.wrap_container_09 {
  position: relative;
  display: block;
  margin: 0 auto;
  background-color: white;
}
.wrap_container_01 {
  position: relative;
  width: 100%;
}
.wrap_container_01 video {
  position: absolute;
  top: 90px; /* ←上下は固定 */
  left: 50%;
  transform: translateX(-50%);
  width: 48%;
  margin: 0 auto;
}
.wrap_button {
  position: relative;
  display: block;
  width: 85vw;
  margin: 0 auto;
  box-shadow: 0px 0px 0px 0px rgba(40, 40, 40, 0.25);
}
.fixed-button {
  position: fixed;
  bottom: 3vh;  /* 画面下からの距離 */
  width: 85vw;   /* ボタンのサイズ */
  height: auto;  /* 縦横比を維持 */
  cursor: pointer; /* クリックしやすく */
  z-index: 1000; /* 他の要素より上に */
  transition: transform 0.3s ease, box-shadow 0.3s ease; /* なめらかに動かす */
  filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.2)); /* 通常時の影 */
}
.fixed-button:hover {
  transform: translateY(-5px); /* 5pxだけ上に浮く */
  filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.3)); /* ホバー時の影を強調 */
}
.wrap_container_02 .image_wrap {
  display: block;
  position: absolute;
  top: 50px;
  left: 50%;
  z-index: 100;
  overflow: hidden;
}
.wrap_container_02 .image_wrap::before {
  animation: displayImg 2.5s linear forwards;
  background: #f4ede8;
  content: '';
  pointer-events: none;
  position: absolute;
  inset: 0;
  z-index: 1;
}
@keyframes displayImg { 100% { transform: translateY(100%); } }
.wrap_container_02 .image_wrap img {
  display: block;
  width: 8px;
}
.wrap_container_02 .image_wrap02 img {
  display: block;
  position: absolute;
  top: 100px;
  z-index: 100;
  overflow: hidden;
}
.wrap_container_02 .image_wrap03 img ,
.wrap_container_02 .image_wrap04 img ,
.wrap_container_02 .image_wrap05 img ,
.wrap_container_02 .image_wrap06 img {
  display: block;
  position: absolute;
  top: 130vw;
}
.wrap_container_02 .image_wrap07 img {
  display: block;
  position: absolute;
  top: 211vw;
}
.wrap_container_02 .image_wrap08 img {
  display: block;
  position: absolute;
  top: 230vw;
}
.wrap_container_02 .image_wrap09 img {
  display: block;
  position: absolute;
  bottom: 97vw;
}
.wrap_container_03 .image_wrap01 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 15vw;
  z-index: 100;
}
.wrap_container_03 .image_wrap02 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 48vw;
  z-index: 0;
}
.wrap_container_03 .video02 {
  display: block;
  position: absolute;
  top: 216vw;
  left: 50%;
  transform: translateX(-50%);
  width: 70%;
  margin: 0 auto;
  z-index: 100;
}
.wrap_container_03 .image_wrap03 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 166vw;
  z-index: 10;
}
.wrap_container_03 .video03 {
  display: block;
  position: absolute;
  top: 378vw;
  left: 50%;
  transform: translateX(-50%);
  width: 70%;
  margin: 0 auto;
  z-index: 100;
}
.wrap_container_03 .image_wrap04 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 312vw;
  z-index: 10;
}
.wrap_container_03 .image_wrap05 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 452vw;
  z-index: 10;
}
.wrap_container_04 .image_wrap01 {
  animation-name: fadein;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  bottom: 87vw;
  z-index: 10;
}
.wrap_container_06 .image_wrap01 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity: 1;
  z-index: 10;
}
.wrap_container_06 .image_wrap02 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity: 1;
  position: absolute;
  top: 180vw;
  z-index: 10;
}
.wrap_container_06 .image_wrap03 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity: 1;
  position: absolute;
  top: 340vw;
  z-index: 20;
}
@keyframes fade_bottom {
  from {
    opacity: 0;
    transform: translateY(80px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeInUp01 {
  display: block;
  width: 100%;
  margin: 0 auto;
  position: absolute;
  bottom: 55px;
  right: 0;
  left: 0;
  animation-name: fadein;
  animation-duration: 2s;
}
@keyframes fadein {
    from {
      opacity: 0;
      transform: translateY(40px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

.fadeInUp02 { animation: opacityFadeIn 1.7s ease 0s 1 normal; }
@keyframes opacityFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.before_after_slider {
  display: block;
  position: absolute;
  bottom: -5vw;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  overflow: hidden;
  width: 75vw;
  max-width: 100%;
}
.box_before {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 50%;
  height: 100%;
  border-right: 3px solid rgba(255, 255, 255, 0.7);
  box-shadow: 10px 0 15px -13px #000;
}
.box_before img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
}
.box_before::before {
  content: '◀︎ ▶︎';
  z-index: 1;
  position: absolute;
  top: 0;
  right: -20px;
  bottom: 0;
  width: 35px;
  height: 35px;
  color: white;
  font-size: 10px;
  margin: auto;
  border: 3px solid rgba(255, 255, 255, .7);
  border-radius: 50%;
  box-shadow: 10px 0 15px -13px #000;
  background-color: rgba(255, 255, 255, .7);
  text-align: center;
  line-height: 30px;
}
.slider_range {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  opacity: 0;
  cursor: col-resize;
}
.wrap_container_05 .carousel {
  display: flex;
  justify-content: center;
  position: absolute;
  top: 96vw;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.wrap_container_05 .contains {
  width: 75vw;
  height: 480px;
  overflow: hidden;
  position: relative;
  padding: 0;
  list-style: none;
}
.wrap_container_05 .slide_select { display: none; }
.wrap_container_05 .slide {
  display: block;
  width: 75vw;
  height: 480px;
  position: absolute;
  opacity: 0;
  transition : all 0.5s;
}
.wrap_container_05 .slide img {
  display: block;
  margin: 0 auto;
  box-shadow: 0px 0px 20px -5px #b57f77;
}
.wrap_container_05 .scroll_button {
  position: absolute;
  display: block;
  height: 7vw;
  width: 7vw;
  top: 50%;
  margin-top: -20px;
  border-width: 1px 1px 0 0;
  border-style: solid;
  border-color: #333;
  cursor: pointer;
  opacity: 0.5;
  z-index: 3;
  transition : all 0.5s;
}
.wrap_container_05 .scroll_button:hover { opacity: 1; }
.wrap_container_05 .scroll_prev {
  left: 3vw;
  transform: rotate(-135deg);
}
.wrap_container_05 .scroll_next {
  right: 3vw;
  transform: rotate(45deg);
}
.wrap_container_05 .move_controler {
  position: absolute;
  bottom: 0px;
  width: 100%;
  text-align: center;
}
.wrap_container_05 .button_move {
  display: inline-block;
  height: 12px;
  width: 12px;
  margin: 0 2px;
  border-radius: 100%;
  cursor: pointer;
  opacity: 0.5;
  z-index: 2;
}
.wrap_container_05 .button_move:hover { opacity: 0.75; }
.wrap_container_05 .button_move { background-color: #C79E97 }
.slide_select:nth-of-type(1):checked ~ .slide:nth-of-type(1) { opacity: 1; }
.slide_select:nth-of-type(1):checked ~ .move_controler
.button_move:nth-of-type(1) { opacity: 1; }
.slide_select:nth-of-type(2):checked ~ .slide:nth-of-type(2) { opacity: 1; }
.slide_select:nth-of-type(2):checked ~ .move_controler
.button_move:nth-of-type(2) { opacity: 1; }
.slide_select:nth-of-type(3):checked ~ .slide:nth-of-type(3) { opacity: 1; }
.slide_select:nth-of-type(3):checked ~ .move_controler
.button_move:nth-of-type(3) { opacity: 1; }
.slide_select:nth-of-type(4):checked ~ .slide:nth-of-type(4) { opacity: 1; }
.slide_select:nth-of-type(4):checked ~ .move_controler
.button_move:nth-of-type(4) { opacity: 1; }
.slideshow {
  position: absolute;
  top: 260vw;
  overflow: hidden;
  width: 100%;
}
input[name="slideshow"] { display: none; }
.slideContents {
  display: flex;
  position: relative;
  width: 500%;
  text-align: center;
  -webkit-user-select: none;
  user-select: none;
  transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.slideContents section { width: 100%; }
.slideContents section img {
  max-width: 100%;
  height: auto;
  padding: 50px;
  box-sizing: border-box;
  vertical-align: middle;
}
.arrow,
.arrow label,
.arrow .ico { position: absolute; }
.arrow {
  top: 0;
  margin: 0;
  transition: background .3s;
}
.prev { left: 0; }
.next { right: 0; }
.arrow { background: rgba(255,255,255,.2); }
.arrow,
.arrow label {
  cursor: pointer;
  width: 50px;
  height: 100%;
}
.arrow label {
  top: 0;
  left: 0;
  z-index: 1;
}
.arrow .ico {
  top: calc(50% - 6px);
  width: 12px;
  height: 12px;
  border-top: 3px solid #e6b3a3;
  opacity: 0;
}
.prev .ico {
  left: 50%;
  border-left: 3px solid #e6b3a3;
  transform: rotate(-45deg);
  transition: left .3s cubic-bezier(0.215, 0.61, 0.355, 1), opacity .3s;
}
.next .ico {
  right: 50%;
  border-right: 3px solid #e6b3a3;
  transform: rotate(45deg);
  transition: right .3s cubic-bezier(0.215, 0.61, 0.355, 1), opacity .3s;
}
.arrow .ico { opacity: .6; }
.prev .ico { left: calc(50% - 6px); }
.next .ico { right: calc(50% - 6px); }
#switch1:checked ~ .slideContents { transform: translateX(0); }
#switch2:checked ~ .slideContents { transform: translateX(-20%); }
#switch3:checked ~ .slideContents { transform: translateX(-40%); }
#switch4:checked ~ .slideContents { transform: translateX(-60%); }
#switch5:checked ~ .slideContents { transform: translateX(-80%); }
.arrow label { pointer-events: none; }
#switch1:checked ~ .prev label[for="switch5"],
#switch2:checked ~ .prev label[for="switch1"],
#switch3:checked ~ .prev label[for="switch2"],
#switch4:checked ~ .prev label[for="switch3"],
#switch5:checked ~ .prev label[for="switch4"],
#switch1:checked ~ .next label[for="switch2"],
#switch2:checked ~ .next label[for="switch3"],
#switch3:checked ~ .next label[for="switch4"],
#switch4:checked ~ .next label[for="switch5"],
#switch5:checked ~ .next label[for="switch1"] { pointer-events: auto; }
.wrap_container_06 {
  font-family: "dnp-shuei-mincho-pr6n", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.accordion {
  margin: 1rem auto 0;
  max-width: 90%;
}
.toggle { display: none; }
.faq {
  position: relative;
  border-top: 1px solid #db978c; /* 2つ目以降のQには線を適用 */
}
.question,.anser {
  transform: translateZ(0);
  transition: all 0.3s;
  display: flex;
  flex-wrap: wrap;
  border-top: none; /* .faq で border-top をつけたので、ここでは不要 */
  cursor: pointer;
}
.question img {
  vertical-align: top;
  padding: 15px 5px 15px 10px;
  width: 45px;
  height: 100%;
}
.anser img {
  vertical-align: top;
  padding: 15px 5px 15px 10px;
  width: 45px;
  height: 100%;
}
.question p {
  color: #4d4d4d;
  font-size: 14px;
  padding: 15px;
  line-height: 1.5;
  width: 65vw;
  text-align: justify;
  text-justify: inter-ideograph;
}
.anser p {
  color: #4d4d4d;
  font-size: 14px;
  padding: 15px;
  line-height: 1.5;
  width: 70vw;
  text-align: justify;
  text-justify: inter-ideograph;
  font-feature-settings: "palt";
}
.anser p span { font-size: 11px; }
.question:after,.question:before {
  content: "";
  position: absolute;
  right: 1.5rem;
  top: .5rem;
  bottom: 0;
  margin: auto;
  width: 2px;
  height: 1.5rem;
  background-color: #db978c;
  transition: all 0.3s;
}
.question:after { transform: rotate(90deg); }
.anser {
  border-top: solid 1px #db978c;
  max-height: 0;
  overflow: hidden;
}
.toggle:checked + .question + .anser {
  max-height: 500px;
  transition: all 1.5s;
}
.toggle:checked + .question:before {transform: rotate(90deg) !important; }
.wrap_container_09 .image_wrap01 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 78vw;
  right: 30px;
  z-index: 100;
}
.wrap_container_09 .image_wrap02 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 85vw;
  right: 125px;
  z-index: 100;
}
.wrap_container_09 .image_wrap03 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 98vw;
  right: 40px;
  z-index: 100;
}
.wrap_container_09 .image_wrap04 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 100vw;
  right: 160px;
  z-index: 100;
}
.wrap_container_09 .image_wrap05 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 92vw;
  right: 54vw;
  z-index: 100;
}
.wrap_container_09 .image_wrap06 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 112vw;
  right: 54vw;
  z-index: 100;
}
.wrap_container_09 .image_wrap07 {
  animation-name: fade_bottom;
  animation-duration: .5s;
  opacity:1;
  position: absolute;
  top: 102vw;
  right: 75vw;
  z-index: 100;
}
.wrap_container_09 .image_wrap01 img ,
.wrap_container_09 .image_wrap02 img ,
.wrap_container_09 .image_wrap03 img ,
.wrap_container_09 .image_wrap04 img ,
.wrap_container_09 .image_wrap05 img ,
.wrap_container_09 .image_wrap06 img ,
.wrap_container_09 .image_wrap07 img { width: 16vw; }
.wrap_container_09 a { transition : all 0.5s; }
.wrap_container_09 a:hover {
  transition : all 0.5s;
  opacity: .5;
}

}