@charset "UTF-8";
/* ==========================================================================//
//
// Movieページ
//
// ========================================================================== */
#pageMovie .page_body {
  margin-top: 0;
}

main {
  position: relative;
}
main::before {
  position: absolute;
  content: "";
  background-image: url(../../images/gallery/gallery_bg.svg);
  background-repeat: no-repeat;
  background-size: contain;
  top: 5%;
  right: 0;
  width: min(117px, 31.2%);
  height: 141px;
  z-index: -1;
}
@media all and (min-width: 751px) {
  main::before {
    top: 4.4%;
    width: min(365px, 26.75%);
    height: 440px;
  }
}

.page_head .page_ttl .en .small {
  text-transform: none;
}
.page_head .lead {
  margin-top: 30px;
  line-height: 2;
}
@media all and (min-width: 751px) {
  .page_head .lead {
    margin-top: 40px;
    font-size: 17px;
  }
}

@media all and (min-width: 751px) {
  .page_body {
    margin-top: 110px;
  }
}

/* ギャラリー
---------------------------------------------------------- */
.post_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media all and (min-width: 751px) {
  .post_list {
    gap: 40px 1.25%;
  }
}
@media all and (max-width: 750px) {
  .post_list {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 25px 3px;
  }
}
.post_list .post_item {
  margin-bottom: 15px;
  display: inline-block;
  cursor: pointer;
  margin-bottom: 0;
}
@media all and (min-width: 751px) {
  .post_list .post_item {
    width: 32.5%;
  }
}
@media all and (max-width: 750px) {
  .post_list .post_item {
    width: calc(50% - 3px);
  }
}
.post_list .post_item a {
  display: block;
}
.post_list .post_item a .thumbnail {
  overflow: hidden;
}
.post_list .post_item a .thumbnail img {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 16/9;
  -webkit-transition: -webkit-transform 0.5s ease;
  transition: -webkit-transform 0.5s ease;
  transition: transform 0.5s ease;
  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
}
@media (hover: hover) {
  .post_list .post_item a:hover img {
    -webkit-transform: scale(1.07);
            transform: scale(1.07);
  }
}
.post_list .post_item p {
  margin-top: 5px;
}
@media all and (min-width: 751px) {
  .post_list .post_item p {
    font-size: 15px;
    margin-top: 15px;
  }
}

/* VIEW MOREボタン */
.more_btn_back {
  margin: 50px 0 0;
  text-align: center;
}
@media all and (min-width: 751px) {
  .more_btn_back {
    margin: 80px 0 0;
  }
}
.more_btn_back .more_btn {
  margin: 0 auto;
  cursor: pointer;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.more_btn_back .more_btn span {
  padding-right: 46px;
  position: relative;
  font-family: "Lato", sans-serif;
  letter-spacing: 0.025em;
  font-size: 12px;
  letter-spacing: 0.075em;
}
@media all and (min-width: 751px) {
  .more_btn_back .more_btn span {
    padding-right: 55px;
    font-size: 15px;
  }
}
.more_btn_back .more_btn span::before, .more_btn_back .more_btn span::after {
  position: absolute;
  content: "";
  background-color: #505050;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 7px;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
@media all and (min-width: 751px) {
  .more_btn_back .more_btn span::before, .more_btn_back .more_btn span::after {
    right: 0;
  }
}
.more_btn_back .more_btn span::before {
  width: 23px;
  height: 1px;
}
@media all and (min-width: 751px) {
  .more_btn_back .more_btn span::before {
    width: 32px;
  }
}
.more_btn_back .more_btn span::after {
  width: 1px;
  height: 23px;
  right: 18px;
}
@media all and (min-width: 751px) {
  .more_btn_back .more_btn span::after {
    height: 32px;
    right: 15px;
  }
}
@media (hover: hover) {
  .more_btn_back .more_btn:hover span::before, .more_btn_back .more_btn:hover span::after {
    -webkit-transform: translateY(-50%) rotate(-180deg);
            transform: translateY(-50%) rotate(-180deg);
  }
}

/* モーダル */
.lity {
  background: rgba(0, 0, 0, 0.8) !important;
}
.lity .lity-container {
  padding: 0 20px;
  width: 100%;
}
@media all and (min-width: 751px) {
  .lity .lity-container {
    padding: 0;
    width: 54.87%;
  }
}
.lity .lity-container .lity-close {
  top: 20px;
  right: 20px;
}
@media all and (min-width: 751px) {
  .lity .lity-container .lity-close {
    width: 50px;
    height: 50px;
    font-weight: 300;
    font-size: 50px;
  }
}
.lity .lity-content {
  aspect-ratio: 16/9;
  width: 100%;
  height: 100%;
}
.lity .lity-content iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: 100%;
}
.lity body:has(.lity-opened) {
  overflow: hidden;
}
.lity .lity-wrap .lity-close {
  font-size: 0;
  top: 20px;
  right: 22px;
}
@media all and (min-width: 751px) {
  .lity .lity-wrap .lity-close {
    top: 24px;
    right: 24px;
  }
}
.lity .lity-wrap .lity-close::before, .lity .lity-wrap .lity-close::after {
  position: absolute;
  content: "";
  background-color: #fff;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.lity .lity-wrap .lity-close::before {
  width: 25px;
  height: 1px;
  left: 7px;
}
@media all and (min-width: 751px) {
  .lity .lity-wrap .lity-close::before {
    width: 32px;
    left: 7px;
  }
}
.lity .lity-wrap .lity-close::after {
  width: 1px;
  height: 25px;
  right: 16px;
}
@media all and (min-width: 751px) {
  .lity .lity-wrap .lity-close::after {
    height: 32px;
    right: 26.5px;
  }
}
@media (hover: hover) {
  .lity .lity-wrap .lity-close:hover::before, .lity .lity-wrap .lity-close:hover::after {
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
  }
}