@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
}

:root {
  --min-layout-width: 335;
  --max-layout-width: 1250;
  --min-ratio: calc(1 / var(--min-layout-width) * 100vw);
  --max-ratio: calc(1 / var(--max-layout-width) * 100vw);
}


body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #383231;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

a {
  text-decoration: none;
  color: #383231;
}

ul {
  list-style: none;
}

p, span, h2, h3 {
  letter-spacing: 0.2em;
}
@media screen and (max-width: 760px) {
  p, span, h2, h3 {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 760px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 760px) {
  .sp {
    display: block;
  }
}

.page-flex {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 760px) {
  .page-flex {
    display: block;
  }
}

.green {
  color: #56904F;
}



@media screen and (max-width: 760px) {
  header {
    position: relative;
    z-index: 50;
    display: flex;
    align-items: center;
  }
  header .nav-tit {
    position: absolute;
    width: 35.4667vw;
    margin-top: 7.2vw;
    margin-left: 6.9333vw;
  }
  header h1 {
    margin: 0;
  }
  header h1 img {
    width: 100%;
  }
  header .header-tit {
    width: 35.4667vw;
    margin-top: 7.2vw;
    margin-left: 6.9333vw;
  }
  .openbtn {
    display: block;
    position: fixed;
    top: 5.6vw;
    right: 6.1333vw;
    z-index: 999;
    cursor: pointer;
    width: 13.3333vw;
    height: 13.3333vw;
    background: transparent;
    transition-duration: 800ms;
    transition-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
    border: none;
    outline: none;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .openbtn .open {
    position: relative;
    margin-top: -1.3333vw;
    margin-top: -4.5vw;
  }
  .openbtn .open span {
    display: inline-block;
    transition: all 0.4s;
    position: absolute;
    right: 0vw;
    right: -4.5vw;
    height: 2px;
    border-radius: 5px;
    background: #383231;
    width: 8.5333vw;
  }
  .openbtn .open span:nth-of-type(1) {
    top: 0;
  }
  .openbtn .open span:nth-of-type(2) {
    top: 2.6667vw;
  }
  .openbtn .open span:nth-of-type(3) {
    top: 5.3333vw;
  }
  @keyframes fadeUp {
    from {
      opacity: 0;
      transform: translate(0, 10px);
    }
    to {
      opacity: 1;
      transform: translate(0, 0);
    }
  }
  .openbtn.active .open {
    margin-top: 2.6667vw;
  }
  .openbtn.active .open span:nth-of-type(1) {
    top: 14px;
    right: 6.4vw;
    right: -4.5vw;
    transform: translateY(-18px) rotate(-45deg);
    width: 8.5333vw;
  }
  .openbtn.active .open span:nth-of-type(2) {
    opacity: 0;
  }
  .openbtn.active .open span:nth-of-type(3) {
    top: 26px;
    right: 6.4vw;
    right: -4.5vw;
    transform: translateY(-30px) rotate(45deg);
    width: 8.5333vw;
  }
  .openbtn.active .text .menu {
    display: none;
  }
  .menu-box {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    transform: translateX(100%);
    background-color: #fff;
    transition: ease 0.4s;
  }
  .menu-box ul {
    width: 50.6667vw;
    margin: 0 auto 0 8vw;
    margin-top: 32vw;
  }
  .menu-box ul li {
    padding-bottom: 3.7333vw;
    border-bottom: 1px solid #918381;
  }
  .menu-box ul li + li {
    margin-top: 6.4000vw;
  }

  .menu-box ul li p {
    font-size: 2.9333vw;
    margin-top: 2.9333vw;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.8;
  }
  .menu-box ul li:first-child img {
    width: 25.0667vw;
  }
  .menu-box ul li:nth-child(2) img {
    width: 17.3333vw;
  }
  .menu-box ul li:nth-child(3) img {
    width: 18.6667vw;
  }
  .menu-box ul li:nth-child(4) img {
    width: 23.7333vw;
  }

  .menu-box.active {
    transform: translateX(0);
    display: block;
  }
}


/* --- header nav --- */
nav {
    position: fixed;
    background-color: rgba(253, 252, 248, 0.9);
    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    width: 250px;
    height: 100vh;
    box-sizing: border-box;
    z-index: 100;
    display: table;
}
nav .nav-tit a:hover {
    opacity: 0.7;
}
nav .nav-table {
  display: table-cell;
  vertical-align: middle;
}
@media screen and (min-height: 900px) {
  nav .nav-table {
    display: initial;
    vertical-align: initial;
  }
}
nav .nav-inner {
  width: 76.8%;
  max-width: 250px;
  margin: 0 auto;
}
  @media screen and (min-height: 900px) {
    nav .nav-inner {
      margin-top: 30px;
    }
  }

  nav .nav-tit h1 {
    width: 80.7292%;
    margin: 0;
  }
  nav .wrapper {
    margin-top: 13.8%;
    margin-top: 116px;
  }


  nav .wrapper ul li {
    border-bottom: #918381 solid 1px;
    overflow: hidden;
  }

  nav .wrapper ul li a {
    display: block;
    padding-top: 24px;
    padding-bottom: 15px;
  }
  nav .wrapper ul li a:hover {
    opacity: 0.7;
  }
  nav .wrapper ul li .nav-txt {
    letter-spacing: 0;
  }
  nav .wrapper ul li:nth-child(1) .nav-txt h2 {
    width: 94px;
  }
  nav .wrapper ul li:nth-child(2) .nav-txt h2 {
    width: 66px;
  }
  nav .wrapper ul li:nth-child(3) .nav-txt h2 {
    width: 71px;
  }
  nav .wrapper ul li:nth-child(4) .nav-txt h2 {
    width: 90px;
  }
  nav .wrapper ul li .nav-txt p {
    font-size: 11px;
    font-weight: 500;
    line-height: 1.6;
    margin-top: 10px;
  }




/* --- slider --- */
.slider {
  margin-top: 0;
  background: #C1CB82;
}
.slick-slide div {
  padding: 0 5px;
}



/* --- kv --- */
.kv {
  position: relative;
  height: calc(100vh - 2vh);
}
.kv .kv_inner {
  display: flex;
}
.kv .side_area {
  width: 250px;
}
.kv .kv_img_box {
  width: calc(100% - 250px);
  height: calc(100vh - 2vh);
  position: relative;

  background: url('../images/top/kv_pc.jpg');
  background-size: cover;
  background-position: center bottom;
}
.kv .kv_img_box .kv_tit {
  position: absolute;
  left: calc(100 * var(--max-ratio));
  bottom: 15vh;
}
.kv .kv_img_box .kv_tit ul {
  display: flex;
  flex-direction: row-reverse;
}
.kv .kv_img_box .kv_tit ul li {
  width: 46px;
  width: calc(46 * var(--max-ratio));
}
.kv .kv_img_box .kv_tit ul li:nth-child(2) {
  width: 76px;
  width: calc(76 * var(--max-ratio));
}
.kv .kv_img_box .kv_tit ul li:nth-child(3),
.kv .kv_img_box .kv_tit ul li:nth-child(4) {
  margin-right: 26px;
  margin-right: calc(26 * var(--max-ratio));
}
@media screen and (max-width: 760px) {
  .kv {
    height: auto;
  }
  .kv .side_area {
    display: none;
  }
  .kv .kv_img_box {
    width: 100vw;
    height: 188.8vw;
    background: url('../images/top/kv_sp.jpg');
    background-size: cover;
  }
  .kv .kv_img_box .kv_tit {
    left: 7.4667vw;
    bottom: auto;
    top: 86.9333vw;
  }
  .kv .kv_img_box .kv_tit ul li {
    width: 7.7333vw;
  }
  .kv .kv_img_box .kv_tit ul li:nth-child(2) {
    width: 12.2667vw;
  }
  .kv .kv_img_box .kv_tit ul li:nth-child(3),
  .kv .kv_img_box .kv_tit ul li:nth-child(4) {
    margin-right: 4.8vw;
  }
}


/* --- kv 山 --- */
.mountain_img {
  display: block;
  margin-top: calc(-100 * var(--max-ratio));
  position: relative;
  z-index: 1;
}
.mountain_img .scroll-box {
  width: calc(100% - 250px);
  position: absolute;
  left: 250px;
  top: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.mountain_img .scroll-box .scrolldown {
  width: 152px;
}
.float {
  animation: float 3s ease-in-out infinite;
}

@keyframes float{
  0%{ transform: translateY(0px); }
  50%{ transform: translateY(-30px); }
  100%{ transform: translateY(0px); }
}

@media screen and (max-width: 760px) {
  .mountain_img {
    margin-top: -41.3333vw;
  }
  .mountain_img .scroll-box {
    width: 29.3333vw;
    left: 35.4667vw;
    top: 12vw;
  }
  .mountain_img .scroll-box .scrolldown {
    width: 100%;
  }
}





  
/* --- section common --- */
.sec {
  padding-left: 250px;
  position: relative;
}
.sec .inner {
    width: 1000px;
    margin: 0 auto;
    position: relative;
    z-index: 10;
}
.cont_inner1250 {
  width: 1250px;
  margin: 0 auto;
  position: relative; 
  background-color: #918381;
}

.green_bg {
  background: #C1CB82;
}
.begie_bg {
  background: #E5DCA9;
}

@media screen and (max-width: 1250px) {
  .sec .inner {
    width: 100%;
  }
}
@media screen and (max-width: 760px) {
  .sec {
    padding-left: 0;
  }
  .sec .inner {
    width: 100%;
  }
}



/* --- tit --- */
.sec .sec_tit {
  text-align: center;
}
.sec .sec_tit .sec_tit_ja {
  display: block;
  margin-top: 15px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.sec .tit_box {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  position: relative;
}
.sec .tit_box .tit_img,
.sec .tit_box .tit_img img {
  width: 100%;
}
.sec .stit_list {
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.section01 .lead .about_tit {
  width: 437px;
}
.section01 .lead .stit_list {
  gap: 25px;
  top: -60px;
}
.section01 .lead .stit_list li {
  width: 51px;
}

.stay_tit {
  width: 306px;
}
.stay_tit ul {
  gap: 24px;
  top: -53px;
}
.stay_tit ul li {
  width: 52px;
}
.stay_tit ul li:nth-child(1) {
  margin-top: -10px;
}

.trail_tit {
  width: 329px;
}
.trail_tit ul {
  top: -35px;
}
.trail_tit ul li {
  width: 52px;
}
.trail_tit ul li:nth-child(2) {
  width: 87px;
  margin-left: 12px;
  margin-top: -40px;
}
@media screen and (max-width: 1250px) {


}
@media screen and (max-width: 760px) {
  .sec .sec_tit .sec_tit_ja {
    margin-top: 2.6667vw;
    font-size: 4vw;
  }

  .section01 .lead .about_tit {
    width: 74.4vw;
  }
  .section01 .lead .stit_list {
    gap: 5.3333vw;
    top: -9.3333vw;
  }
  .section01 .lead .stit_list li {
    width: 8.5333vw;
  }

  .stay_tit {
    width: 51.7333vw;
  }
  .stay_tit ul {
    gap: 4.2667vw;
    top: -8vw;
  }
  .stay_tit ul li {
    width: 8.5333vw;
  }
  .stay_tit ul li:nth-child(1) {
    margin-top: -1.3333vw;
  }

  .trail_tit {
    width: 55.4667vw;
  }
  .trail_tit ul {
    top: -4vw;
  }
  .trail_tit ul li {
    width: 8.5333vw;
  }
  .trail_tit ul li:nth-child(2) {
    width: 14.1333vw;
    margin-left: 2.4vw;
    margin-top: -8vw;
  }

  .area .sec_tit_img {
    width: 25.0667vw;
    margin: 0 auto;
  }
  .supervisor .sec_tit_img {
    width: 60.5333vw;
    margin: 0 auto;
  }
  #movie .sec_tit_img {
    width: 32.2667vw;
    margin: 0 auto;
  }
}




/* --- area / supervisor --- */
.section01 .area {
  padding-top: 260px;
  padding-bottom: 212px;
}
.section01 .area .lead_txt {
  width: 590px;
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.05em;
}
.section01 .area .area_img {
  display: block;
  width: 806px;
  margin-top: 57px;
  margin-left: auto;
  margin-right: auto;
}

.supervisor {
  padding-top: 188px;
  padding-bottom: 180px;
}
.supervisor ul {
  display: flex;
}
.supervisor ul.supervisor_list {
  margin-top: 90px;
  justify-content: center;
  gap: 7%;
}
.supervisor ul.supervisor_list > li {
  width: 214px;
}
.supervisor ul.supervisor_list span,
.supervisor ul.supervisor_list b {
  display: block;
  letter-spacing: 0.05em; 
}
.supervisor ul.supervisor_list span {
  margin-top: 30px;
  font-size: 16px;
  line-height: 1.5;
}
.supervisor ul.supervisor_list b {
  margin-bottom: 24px;
  font-size: 22px;
  line-height: 1.4545;
}
.supervisor ul.supervisor_list p {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.05em;
}

.supervisor ul.sns_list {
  margin-top: 20px;
  align-items: center;
  gap: 16px;
}
.supervisor ul.sns_list li a {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1250px) {
  .section01 .area {
    padding-top: 20.8vw;
    padding-bottom: 16.96vw;
  }
  .section01 .area .lead_txt {
    width: 47.2vw;
    margin-top: 20px;
  }
  .section01 .area .area_img {
    width: 64.4800vw;
    margin-top: 4.5600vw;
  }
  .supervisor {
    padding-top: 15.0400vw;
    padding-bottom: 18.2400vw;
  }
  .supervisor ul.supervisor_list > li {
    width: 24vw;
  }
}
@media screen and (max-width: 760px) {
  .section01 .area {
    padding-top: 44.5333vw;
    padding-bottom: 26.6667vw;
  }
  .section01 .area .lead_txt {
    width: 86.1333vw;
    margin-top: 4.8vw;
  }
  .section01 .area .area_img {
    width: 83.7333vw;
    margin-top: 12.8vw;
  }

  .supervisor {
    padding-top: 28.2667vw;
    padding-bottom: 35.4667vw;
  }
  .supervisor ul.supervisor_list {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .supervisor ul.supervisor_list {
    margin-top: 13.3333vw;
    gap: 13.3333vw;
  }
  .supervisor ul.supervisor_list > li {
    width: 52vw;
  }
  .supervisor ul.supervisor_list span {
    margin-top: 6.9333vw;
    font-size: 3.7333vw;
  }
  .supervisor ul.supervisor_list b {
    margin-bottom: 4.2667vw;
    font-size: 5.3333vw;
  }
  .supervisor ul.supervisor_list p {
    font-size: 3.4667vw;
  }

  .supervisor ul.sns_list {
    margin-top: 2.6667vw;
    gap: 4.2667vw;
  }
}









/* --- about / stay / trail --- */
.section02 {
  padding-top: 100px;
  padding-bottom: 180px;
}
.section03 {
  padding-top: 100px;
  padding-bottom: 180px;
}
.section01 .lead {
  padding-top: 230px;
}
.section01 .lead .lead_txt,
.section02 .lead_txt,
.section03 .lead_txt {
  font-size: 20px;
  font-weight: 500;
  line-height: 2.2;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 150px;
}
.section01 .lead .lead_txt {
  margin-top: 20px;
}
.section01 .lead .lead_txt span {
  display: inline-block;
  width: 40px;
  height: 0.1rem;
  background: #383231;
  position: relative;
  top: -7px;
}
@media screen and (max-width: 1250px) {
  .section02 {
    padding-top: 8vw;
    padding-bottom: 14.4000vw;
  }
  .section03 {
    padding-top: 8vw;
    padding-bottom: 14.4000vw;
  }
  .section01 .lead {
    padding-top: 18.4000vw;
  }
}
@media screen and (max-width: 760px) {
  .section02 {
    padding-top: 21.3333vw;
    padding-bottom: 29.3333vw;
  }
  .section03 {
    padding-top: 21.3333vw;
    padding-bottom: 29.3333vw;
  }
  .section01 .lead {
    padding-top: 25.8667vw;
  }
  .section01 .lead .lead_txt,
  .section02 .lead_txt,
  .section03 .lead_txt {
    font-size: 3.7333vw;
    margin-top: 22.6667vw;
    /* 85 */
  }
  .section01 .lead .lead_txt {
    margin-top: 20px;
  }  
  .section01 .lead .lead_txt span {
    width: 6.6667vw;
    height: 0.2667vw;
    top: -1.3333vw;
  }
}



/* --- item --- */
.about_item,
.stay_item,
.trail_item {
  position: absolute;
}

.about_item01 {
  width: 95px;
  top: -133px;
  right: -35px;
}
.about_item02 {
  width: 165px;
  top: 163px;
  right: 85px;
}
.about_item03 {
  width: 93px;
  top: 351px;
  left: 73px;
}
.about_item04 {
  width: 144px;
  top: 421px;
  right: 66px;
}
.about_item05 {
  width: 140px;
  bottom: -120px;
  left: 285px;
}

.stay_item01 {
  width: 229px;
  top: -228px;
  left: 57px;
}
.stay_item02 {
  width: 202px;
  top: calc(-187px + -174px);
  right: 104px;
}
.stay_item03 {
  width: 117px;
  top: -100px;
  right: 218px;
}
.stay_item04 {
  width: 116px;
  top: -13px;
  left: 172px;
}

.trail_item01 {
  width: 135px;
  top: -167px;
  top: calc(-167px + -93px);
  left: 82px;
}
.trail_item02 {
  width: 164px;
  top: -118px;
  left: 196px;
}
.trail_item03 {
  width: 270px;
  top: calc(-160px + -195px);
  right: 44px;
}
.trail_item04 {
  width: 179px;
  top: -94px;
  right: 159px;
}
.trail_item05 {
  width: 69px;
  top: 67px;
  right: 104px;
}



.photo_box {
  width: 100%;
  position: relative;
  margin-top: 65px;
}
.stay_img01 {
  width: 646px;
  margin: 0 0 0 auto;
}
.stay_img02 {
  width: 260px;
  position: absolute;
  left: 0;
  bottom: -68px;
}
.trail_img01 {
  width: 668px;
  margin-left: 0;
}
.trail_img02 {
  width: 258px;
  position: absolute;
  right: 0;
  bottom: -50px;
}
@media screen and (max-width: 1250px) {

  
}
@media screen and (min-width: 769px) and (max-width: 1100px) {

  .stay_img01 {
    width: 100%;
  }
  .stay_img02 {
    position: static;
    bottom: 0;
    margin-top: 60px;
  }
  .trail_img01 {
    width: 100%;
  }
  .trail_img02 {
    position: static;
    bottom: 0;
    margin: 60px 0 0 auto;
  }


}
@media screen and (min-width: 769px) and (max-width: 1000px) {
  .about_item,
  .stay_item,
  .trail_item {
    display: none;
  }
}
@media screen and (max-width: 760px) {

  .about_item01 {
    width: 15.4667vw;
    top: -21.6000vw;
    right: -5.3333vw;
  }
  .about_item02 {
    width: 26.6667vw;
    top: 46.1333vw;
    right: 4.5333vw;
  }
  .about_item03 {
    width: 13.3333vw;
    top: 64vw;
    left: 6.4000vw;
  }
  .about_item04 {
    width: 20.5333vw;
    top: 96.8000vw;
    right: 1.8667vw;
  }
  .about_item05 {
    width: 26.1333vw;
    bottom: -16vw;
    left: 35.2000vw;
  }

  .stay_item01 {
    width: 26.9333vw;
    top: -65.6vw;
    left: 0;
  }
  .stay_item02 {
    width: 34.4000vw;
    top: -50.6667vw;
    right: 5.3333vw;
  }
  .stay_item03 {
    width: 18.9333vw;
    top: -19.7333vw;
    right: 33.8667vw;
  }
  .stay_item04 {
    width: 18.9333vw;
    top: -36vw;
    left: 3.7333vw;
  }

  .trail_item01 {
    width: 20vw;
    top: -72vw;
    left: 2.6667vw;
  }
  .trail_item02 {
    width: 20.8000vw;
    top: -42.9333vw;
    left: 0;
  }
  .trail_item03 {
    width: 41.0667vw;
    top: -56vw;
    right: 4vw;
  }
  .trail_item04 {
    width: 30.9333vw;
    top: -22.4000vw;
    right: auto;
    left: 17.3333vw;
  }
  .trail_item05 {
    width: 14.666733vw;
    top: -24vw;
    right: 32.5333vw;
  }

  .photo_box {
    margin-top: 34.1333vw;
  }
  .stay_img01 {
    width: 93.0667vw;
  }
  .stay_img02 {
    position: static;
    width: 65.8667vw;
    bottom: 0;
    margin-top: 16vw;
  }
  .trail_img01 {
    width: 93.0667vw;
  }
  .trail_img02 {
    width: 65.8667vw;
    position: static;
    bottom: 0;
    margin: 16vw 0 0 auto;
  }
}








/* --- more ボタン --- */
.more-btn {
  width: 365px;
  height: 80px;
  margin: 60px auto 0;
  border-radius: 100vh;
  border: 1px solid #383231;
  overflow: hidden;
}
.slide_button.slide_to_up {
  position: relative;
}
.slide_button.slide_to_up::before {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 0;
  transition: 0.5s cubic-bezier(0.8, 0, 0.2, 1) 0s;
}
.slide_button.slide_to_up:hover::before {
  height: calc(100% + 1px);
}

.section02 .more-btn,
.section02 .slide_button.slide_to_up::before {
  background: #E5DCA9;
}
.section02 .slide_button.slide_to_up:hover::before {
  background: #CCBF75;
}
.section03 .more-btn,
.section03 .slide_button.slide_to_up::before {
  background: #C1CB82;
}
.section03 .slide_button.slide_to_up:hover::before {
  background: #A2AC65;
}

.sec .more-btn .btn_inner {
  position: relative;
  z-index: 3;
  padding: 28px 0;
  text-align: center;
  text-wrap: nowrap;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.15em;
}
.sec .more-btn .btn_inner img {
  position: absolute;
  right: 10.137%;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 760px) {
  .more-btn {
    width: 64.2667vw;
    height: 14.4000vw;
    margin: 12.8vw auto 0;
  }
  .sec .more-btn .btn_inner {
    padding: 4.5333vw 0;
    font-size: 3.7333vw;
  }
  .sec .more-btn .btn_inner img {
    right: 6.6667vw;
  }

  .section02 .slide_button.slide_to_up:hover::before {
    background: #E5DCA9;
  }
  .section03 .slide_button.slide_to_up:hover::before {
    background: #C1CB82;
  }

}


















/* --- movie(section04)  --- */
.section04 {
  padding-top: 100px;
  padding-bottom: 265px;
}
.section04 .inner {
  text-align: center;
}
.section04 ul.video_list {
  display: flex;
  justify-content: center;
  gap: 7.2%;
  margin-top: 89px;
  margin-bottom: 85px;
}
.section04 ul.video_list li {
  width: 332px;
  position: relative;
}
.section04 .thumb-wrapper {
  max-width: 100%;
  width: 100%;
  cursor: pointer;
}
.section04 .videoBox {
  display:none;
}
.section04 .videoBox video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 1250px) {
  .section04 ul.supervisor_list li {
    width: 20vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1000px) {
  .section04 ul.video_list {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
  }
}

@media screen and (max-width: 760px) {
  .section04 {
    padding-top: 21.3333vw;
    padding-bottom: 32vw;
  }
  .section04 ul.video_list {
    flex-direction: column;
    align-items: center;
    gap: 13.3333vw;
    margin-top: 13.3333vw;
    margin-bottom: 13.3333vw;
  }
  .section04 ul.video_list li {
    width: 86.4vw;
    margin: 0 auto;
  }
  .section04 .instagram_icon {
    width: 9.6000vw;
  }
}






/*--------------------------------
  scroll-to-top
--------------------------------*/
.top-btn {
  width: 80px;
  position: fixed;
  right: 60px;
  bottom: 20px;
  cursor: pointer;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}
.top-btn.is-visible {
  opacity: 1;
  visibility: visible;
}
@media screen and (max-width: 760px) {
  .top-btn {
    width: 13.3333vw;
    right: 6.1333vw;
    bottom: 4vw;
  }
}






/* --- footer --- */
#Footer {
	padding-left: 250px;
	padding-top: 40px;
	padding-bottom: 40px;
}

#Footer p {
  font-weight: bold;
	text-align: center;
}

.FooterTitle {
	margin-bottom: 30px;
}

.FooterAddress {
    display: inline-block;
	font-size: 75%;
    font-weight: 600;
    padding-top: 6px;
}
.FooterAddress a {
    color: #00784A;
}



.FooterContact {
	margin-top: 30px;
	border-radius: 4px;
	border: 1px solid #00784A;
	width: 240px;
	margin-left: auto;
	margin-right: auto;
}

.FooterContact a {
	display: block;
	padding-top: 15px;
	padding-bottom: 15px;
}

.FooterCopy {
	margin-top: 28px;
}
.FooterCopy small {
	font-size: 62%;
    font-weight: bold;
}
@media screen and (max-width: 760px) {
  #Footer {
    padding-left: 0;
    padding-top: 8vw;
    padding-bottom: 11.7333vw;
  }

  #Footer p {
    font-size: 3.2vw;

  }

  .FooterTitle {
    width: 76.8000vw;
    margin: 0 auto 8vw;
  }

  .FooterAddress {
	  font-size: 2.6667vw;
    padding-top: 2.4000vw;
    line-height: 2;
  }

  .FooterContact {
    margin-top: 4.8000vw;
    width: 58.6667vw;
  }
  
  .FooterContact a {
    padding-top: 4vw;
    padding-bottom: 4vw;
  }
  
  .FooterCopy {
    margin-top: 4.2667vw;
  }
  .FooterCopy small {
    font-size: 2.1333vw;
  }

}





/* cssアニメーション */
.wiggle {
  animation: wiggle 2s infinite;
}

.delay1{ animation-delay: 0s; }
.delay2{ animation-delay: 0.3s; }
.delay3{ animation-delay: 0.6s; }
.delay4{ animation-delay: 0.9s; }
.delay5{ animation-delay: 1.2s; }

@keyframes wiggle{
  0%{ transform: rotate(0deg); }
  25%{ transform: rotate(3deg); }
  50%{ transform: rotate(0deg); }
  75%{ transform: rotate(-3deg); }
  100%{ transform: rotate(0deg); }
}

/*左から右*/
.img-animation {
  overflow: hidden;
  position: relative;
}
.on.img-animation {
  animation: img-opacity 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.img-animation::before {
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}
.on.img-animation::before {
  animation: img-animation 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}


#stay .img-animation::before {
  background: #E5DCA9;
}
#trail .img-animation::before {
  background: #C1CB82;
}
@keyframes img-opacity {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes img-animation {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(100%);
  }

}


/*右から左*/
.img-wrap_right {
  opacity: 0;
}

.img-animation_right {
  animation: img-opacity_right 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  overflow: hidden;
  position: relative;
}

.img-animation_right::before {
  animation: img-animation_right 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

@keyframes img-opacity_right {
  100% {
    opacity: 1;
  }
}
@keyframes img-animation_right {
  100% {
    transform: translateX(-100%);
  }
}

.fadeIn,
.fadeIn-y,
.fadeIn--kv,
.fade01,
.fade02,
.fade03,
.fade04 {
  opacity: 0;
  animation-duration: 0.5s;
  animation-timing-function: linear;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}

.fadeIn-down {
  opacity: 1;
}

.fadeIn-left,
.fadeIn-right,
.fadeIn-down {
  animation-duration: 0.8s;
}

.fadeIn.on {
  animation-name: fadeIn;
}

.fadeIn-y.on,
.fade01.on,
.fade02.on,
.fade03.on,
.fade04.on {
  animation-name: fadeIn-y;
  animation-delay: 0.3s;
}
.fadeIn-y02.on {
  animation-name: fadeIn-y;
  animation-delay: 0.6s;
}



@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeIn-y {
  from {
    opacity: 0;
    transform: translate(0, 20px);
  }
  to {
    opacity: 1;
    transform: translate(0, 0);
  }
}
@keyframes fadeIn-down {
  from {
    transform: translate(0, 0);
  }
  to {
    transform: translate(0, 100%);
  }
}
.ef01,
.ef02,
.ef03,
.ef04,
.ef05 {
  -webkit-animation-duration: 0.5s;
  -webkit-animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  animation-iteration-count: 1;
  animation-timing-function: linear;
  opacity: 0;
}

.ef01.scrollin {
  -webkit-animation-name: fadeIn-y;
  animation-delay: 0.4s;
  animation-name: fadeIn-y;
}

.ef02.scrollin {
  -webkit-animation-name: effect02;
  animation-delay: 0.7s;
  animation-name: effect02;
}

.ef03.scrollin {
  -webkit-animation-name: effect02;
  animation-delay: 1s;
  animation-name: effect02;
}

.ef04.scrollin {
  -webkit-animation-name: effect02;
  animation-delay: 1.3s;
  animation-name: effect02;
}

.ef05.scrollin {
  -webkit-animation-name: effect02;
  animation-delay: 1.6s;
  animation-name: effect02;
}
@keyframes effect01 {
  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}
@keyframes effect02 {
  from {
    opacity: 0;
    transform: translate(20px,0);
  }
  to {
    opacity: 1;
    transform: translate(0, 0);
  }
}
@keyframes anima_fadein_5 {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }
  100% {
    opacity: 1;
    transform-origin: top;
    transform: scaleY(1);
  }
}
@keyframes anima_bg_5 {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }
  100% {
    opacity: 1;
    transform-origin: top;
    transform: scaleY(1);
  }
}



.fadeIn--kv {
  -webkit-animation-duration:.5s;
	-webkit-animation-timing-function:linear;
	-webkit-animation-iteration-count:1;
	-webkit-animation-fill-mode:forwards;
	animation-duration:.5s;
	animation-fill-mode:forwards;
	animation-iteration-count:1;
	animation-timing-function:linear;
	opacity:0;
	-webkit-animation-name:fadeIn;
	animation-name:fadeIn;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translate(20px,0);
  }
  to {
    opacity: 1;
    transform: translate(0, 0);
  }
}

.fadeIn--kv01
{ animation-delay: 0.3s; }
.fadeIn--kv02
{ animation-delay: 0.6s; }
.fadeIn--kv03
{ animation-delay: 0.9s; }
.fadeIn--kv04
{ animation-delay: 1.2s; }