.mainVisual {
  margin: 0 auto;
  position: relative;
}

@media print, screen and (min-width: 767px) {
  .mainVisual {
    padding-top: 18rem;
    width: 122rem;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual {
    padding-top: 15.6rem;
  }
}

.mainVisual__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media print, screen and (min-width: 767px) {
  .mainVisual__head {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual__head {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding: 0 2.8rem 0 4rem;
  }
}

@media print, screen and (min-width: 767px) {
  .mainVisual__head + .mainVisual__body {
    margin-top: 12.4rem;
  }
}

.mainVisual__body {
  overflow: hidden;
}

@media print, screen and (min-width: 767px) {
  .mainVisual__body {
    border-radius: 5rem 5rem 0 0;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual__body {
    border-radius: 3.2rem 3.2rem 0 0;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual__body .photo {
    height: 96rem;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual__body .photo__pic, .mainVisual__body .photo__image {
    height: 100%;
    max-width: initial;
    width: auto;
  }
}

.mainVisual__scroll {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  font-family: "Inter", sans-serif;
  letter-spacing: .08em;
  line-height: .7;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}

@media print, screen and (min-width: 767px) {
  .mainVisual__scroll {
    gap: 1rem;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual__scroll {
    gap: 0.8rem;
  }
}

@media print, screen and (min-width: 767px) {
  .mainVisual__scroll .inner {
    font-size: 1.4rem;
    padding-top: 2rem;
  }
}

@media screen and (max-width: 767px) {
  .mainVisual__scroll .inner {
    font-size: 2.4rem;
    padding: .8rem 0 2rem;
  }
}

.mainVisual__scroll .border {
  background-color: rgba(153, 153, 153, 0.4);
  height: 100%;
  position: relative;
  width: 1px;
}

.mainVisual__scroll .border .current {
  background-color: #7e7859;
  inset: 0;
  position: absolute;
  -webkit-animation: scrollGuide 3s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
          animation: scrollGuide 3s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.pageTtl {
  font-family: "Inter", sans-serif;
  font-weight: 100;
  letter-spacing: .12em;
  overflow: hidden;
}

@media print, screen and (min-width: 767px) {
  .pageTtl {
    font-size: 14rem;
    line-height: calc(160 / 140);
  }
}

@media screen and (max-width: 767px) {
  .pageTtl {
    font-size: 10.4rem;
    line-height: calc(160 / 104);
    padding-bottom: 9rem;
  }
}

.pageTtl .inner {
  display: inline-block;
  -webkit-transition: -webkit-transform .8s ease .4s;
  transition: -webkit-transform .8s ease .4s;
  transition: transform .8s ease .4s;
  transition: transform .8s ease .4s, -webkit-transform .8s ease .4s;
  -webkit-transform: translate(0, 100%);
          transform: translate(0, 100%);
}

body.is-load .pageTtl .inner {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}

.pageTtl .italic {
  font-style: italic;
}

.pageTtl .small {
  letter-spacing: .06em;
}

@media print, screen and (min-width: 767px) {
  .pageTtl .small {
    font-size: 12rem;
  }
}

@media screen and (max-width: 767px) {
  .pageTtl .small {
    font-size: 8.8rem;
  }
}

@media print, screen and (min-width: 767px) {
  .biographySect {
    display: -ms-grid;
    display: grid;
    gap: 4.8rem 6.4rem;
    -ms-grid-columns: 1fr .9fr;
        grid-template-columns: 1fr .9fr;
    padding-top: 12rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect {
    padding-top: 19rem;
  }
}

@media print, screen and (min-width: 767px) {
  .biographySect__visual {
    -ms-grid-column: 1;
    grid-column: 1 / 1;
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    grid-row: 1 / 3;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__visual {
    margin-top: 7.2rem;
  }
}

.biographySect__visual .photo {
  overflow: hidden;
}

@media print, screen and (min-width: 767px) {
  .biographySect__visual .photo {
    border-radius: 0 2.5rem 2.5rem 0;
    left: 0;
    margin-left: -12rem;
    position: -webkit-sticky;
    position: sticky;
    top: 12rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__visual .photo {
    border-radius: 0 2.5rem 2.5rem 0;
    margin-left: -8rem;
  }
}

@media print, screen and (min-width: 767px) {
  .biographySect__cont {
    -ms-grid-column: 2;
    grid-column: 2 / 2;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__cont {
    margin-top: 6.4rem;
  }
}

@media print, screen and (min-width: 767px) {
  .biographySect__name + .txt {
    margin-top: 5.6rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__name + .txt {
    margin-top: 4.8rem;
  }
}

.biographySect__name .ja {
  display: block;
  letter-spacing: 0;
  line-height: 1;
}

@media print, screen and (min-width: 767px) {
  .biographySect__name .ja {
    font-size: 4rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__name .ja {
    font-size: 4.8rem;
  }
}

.biographySect__name .en {
  display: block;
  font-family: "Public Sans", sans-serif;
  font-weight: 200;
  letter-spacing: .12em;
  line-height: .7;
}

@media print, screen and (min-width: 767px) {
  .biographySect__name .en {
    font-size: 2.4rem;
    margin-top: 2.4rem;
    padding-left: 1.2rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__name .en {
    font-size: 2.4rem;
    margin-top: 1.6rem;
    padding-left: .8rem;
  }
}

@media print, screen and (min-width: 767px) {
  .biographySect__list {
    margin-top: 4.8rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__list {
    margin-top: 8rem;
  }
}

.biographySect__list .ttl,
.biographySect__list .desc {
  line-height: 2;
  letter-spacing: .08em;
}

.biographySect__list .ttl:before,
.biographySect__list .desc:before {
  content: '';
  margin-top: calc((.75 - 2) * .5em);
}

.biographySect__list .ttl:after,
.biographySect__list .desc:after {
  margin-bottom: calc((.75 - 2) * .5em);
}

.biographySect__list .ttl:before, .biographySect__list .ttl:after,
.biographySect__list .desc:before,
.biographySect__list .desc:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

@media print, screen and (min-width: 767px) {
  .biographySect__list .ttl,
  .biographySect__list .desc {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__list .ttl,
  .biographySect__list .desc {
    font-size: 2.6rem;
  }
}

@media print, screen and (min-width: 767px) {
  .biographySect__list .ttl + .desc,
  .biographySect__list .desc + .desc {
    margin-top: .8rem;
  }
}

@media screen and (max-width: 767px) {
  .biographySect__list .ttl + .desc,
  .biographySect__list .desc + .desc {
    margin-top: .65rem;
  }
}

@media print, screen and (min-width: 767px) {
  .gallerySect {
    padding-top: 12rem;
  }
}

@media screen and (max-width: 767px) {
  .gallerySect {
    padding-top: 12rem;
  }
}

@media print, screen and (min-width: 767px) {
  .gallerySect__head + .gallerySect__cont {
    margin-top: 6.4rem;
  }
}

@media screen and (max-width: 767px) {
  .gallerySect__head + .gallerySect__cont {
    margin-top: 8rem;
  }
}

.gallerySect__cont {
  overflow: scroll;
}

@media print, screen and (min-width: 767px) {
  .gallerySect__cont {
    padding-bottom: 8rem;
  }
}

@media screen and (max-width: 767px) {
  .gallerySect__cont {
    margin-right: -8rem;
    padding-bottom: 8rem;
  }
}

.gallerySect__cont::-webkit-scrollbar {
  display: none;
}

.gallerySect__cont.is-disable + .gallerySect__scrollBar {
  display: none;
}

.gallerySect__body {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

@media print, screen and (min-width: 767px) {
  .gallerySect__body {
    padding-right: 12rem;
  }
}

.gallerySect__scrollBar {
  background-color: rgba(153, 153, 153, 0.2);
  height: 2px;
  overflow: hidden;
  position: relative;
}

.gallerySect__scrollBar .line {
  background-color: #7e7859;
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
}

@media print, screen and (min-width: 767px) {
  .discFeature .gallerySect .gallerySect__cont,
  .movieFeature .gallerySect .gallerySect__cont {
    margin-right: -12rem;
  }
}

@media print, screen and (min-width: 767px) {
  .discFeature .gallerySect .gallerySect__body,
  .movieFeature .gallerySect .gallerySect__body {
    gap: 6.4rem;
  }
}

@media screen and (max-width: 767px) {
  .movieFeature .gallerySect .gallerySect__body,
  .webFeature .gallerySect .gallerySect__body {
    gap: 3.2rem;
    padding-right: 12.7rem;
  }
}

@media screen and (max-width: 767px) {
  .discFeature .gallerySect .gallerySect__body {
    gap: 2.4rem;
    padding-right: 21.9rem;
  }
}

@media print, screen and (min-width: 767px) {
  .webFeature .gallerySect .sectTtl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 3.2rem;
  }
}

@media print, screen and (min-width: 767px) {
  .webFeature .gallerySect .gallerySect__head + .gallerySect__cont {
    margin-top: 3.2rem;
  }
}

@media print, screen and (min-width: 767px) {
  .webFeature .gallerySect .gallerySect__body {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 3rem;
    padding-right: 0;
  }
}

.galleryCard {
  display: inline-block;
  position: relative;
}

@media screen and (max-width: 767px) {
  .galleryCard.is-active .galleryCard__desc {
    opacity: 1;
  }
}

.galleryCard__body {
  background: none;
  border: 0;
  cursor: pointer;
  padding: 0;
}

@media print, screen and (min-width: 767px) {
  .galleryCard__body:hover .galleryCard__desc {
    opacity: 1;
  }
}

@media (hover: hover) and (pointer: fine) {
  .galleryCard__body:hover .galleryCard__desc {
    opacity: 1;
  }
}

.galleryCard--noLink .galleryCard__body {
  cursor: default;
}

.galleryCard__desc {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: rgba(0, 0, 0, 0.7);
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  inset: 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  letter-spacing: .08em;
  line-height: 2;
  opacity: 0;
  position: absolute;
  text-align: center;
  -webkit-transition: opacity .6s ease;
  transition: opacity .6s ease;
}

@media screen and (max-width: 767px) {
  .galleryCard__desc {
    -webkit-transition-duration: .3s;
            transition-duration: .3s;
  }
}

@media print, screen and (min-width: 767px) {
  .galleryCard__desc {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .galleryCard__desc {
    font-size: 2.4rem;
  }
}

@media print, screen and (min-width: 767px) {
  .discFeature .galleryCard {
    width: 32rem;
  }
}

@media screen and (max-width: 767px) {
  .discFeature .galleryCard {
    width: 48rem;
  }
}

@media print, screen and (min-width: 767px) {
  .movieFeature .galleryCard {
    width: 48rem;
  }
}

@media screen and (max-width: 767px) {
  .movieFeature .galleryCard {
    width: 56rem;
  }
}

@media print, screen and (min-width: 767px) {
  .webFeature .galleryCard {
    width: 38rem;
  }
}

@media screen and (max-width: 767px) {
  .webFeature .galleryCard {
    width: 56rem;
  }
}

.contactSect {
  position: relative;
}

@media print, screen and (min-width: 767px) {
  .contactSect {
    padding: 32rem 0;
  }
}

@media screen and (max-width: 767px) {
  .contactSect {
    padding-top: 24.8rem;
  }
}

.contactSect__body {
  background-color: rgba(255, 255, 255, 0.8);
  z-index: 1;
}

@media print, screen and (min-width: 767px) {
  .contactSect__body {
    border-radius: 2.5rem;
    left: 0;
    padding: 9.6rem 13.2rem 10.4rem 4.8rem;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    width: 72rem;
  }
}

@media screen and (max-width: 767px) {
  .contactSect__body {
    border-radius: 2.5rem;
    margin: -16rem -5rem 0;
    padding: 5.6rem 4.8rem 7.2rem;
    position: relative;
    width: 72rem;
  }
}

@media screen and (max-width: 767px) {
  .contactSect__body .sectTtl {
    bottom: calc(100% + 12.8rem);
    color: #ffffff;
    left: 0;
    position: absolute;
  }
}

@media print, screen and (min-width: 767px) {
  .contactSect__body .sectTtl + .txt {
    margin-top: 6.4rem;
  }
}

@media screen and (max-width: 767px) {
  .contactSect__body .txt {
    font-size: 2.4rem;
    letter-spacing: .02em;
  }
}

.contactSect__bg {
  width: calc(100vw - var(--scrollbar));
}

@media print, screen and (min-width: 767px) {
  .contactSect__bg {
    margin-left: calc(((100vw - var(--scrollbar)) - 120rem) / -2);
  }
}

@media screen and (max-width: 767px) {
  .contactSect__bg {
    margin-left: -8rem;
  }
}

@media print, screen and (min-width: 767px) {
  .contactArea {
    margin-top: 6.4rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea {
    margin-top: 3.2rem;
  }
}

.contactArea__body {
  overflow: hidden;
  position: relative;
}

.contactArea__body .ttl {
  line-height: 1;
}

@media print, screen and (min-width: 767px) {
  .contactArea__body .ttl + .area {
    margin-top: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea__body .ttl + .area {
    margin-top: 1.6rem;
  }
}

@media print, screen and (min-width: 767px) {
  .contactArea__body .area + .ttl {
    margin-top: 2.8rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea__body .area + .ttl {
    margin-top: 3.2rem;
  }
}

.contactArea__body .area input,
.contactArea__body .area textarea {
  background-color: #ffffff;
  border: 1px solid #999999;
  width: 100%;
}

@media print, screen and (min-width: 767px) {
  .contactArea__body .area input,
  .contactArea__body .area textarea {
    border-radius: .8rem;
    min-height: 3.2rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea__body .area input,
  .contactArea__body .area textarea {
    border-radius: .8rem;
    min-height: 3.2rem;
  }
}

@media print, screen and (min-width: 767px) {
  .contactArea__body .area textarea {
    max-height: 48rem;
    min-height: 32rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea__body .area textarea {
    min-height: 32rem;
  }
}

.contactArea__body .hp {
  left: -100%;
  opacity: 0;
  position: absolute;
}

.contactArea__send {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media print, screen and (min-width: 767px) {
  .contactArea__send {
    margin-top: 3.2rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea__send {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 2.4rem;
  }
}

.contactArea__btn {
  border: 1px solid #7e7859;
  background-color: #7e7859;
  color: #ffffff;
  cursor: pointer;
  font-family: YakuHanJP, "Zen Kaku Gothic New", sans-serif;
  font-weight: normal;
  line-height: 1;
  padding: 0;
  -webkit-transition: .4s ease;
  transition: .4s ease;
  -webkit-transition-property: background-color,color;
  transition-property: background-color,color;
}

@media print, screen and (min-width: 767px) {
  .contactArea__btn {
    border-radius: 2.5rem;
    height: 4rem;
    font-size: 1.6rem;
    width: 32rem;
  }
}

@media screen and (max-width: 767px) {
  .contactArea__btn {
    border-radius: 2.5rem;
    height: 6rem;
    font-size: 2.4rem;
    width: 40rem;
  }
}

@media print, screen and (min-width: 767px) {
  .contactArea__btn:hover {
    background-color: #ffffff;
    color: #7e7859;
  }
}

@media (hover: hover) and (pointer: fine) {
  .contactArea__btn:hover {
    background-color: #ffffff;
    color: #7e7859;
  }
}

@-webkit-keyframes scrollGuide {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  51% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
}

@keyframes scrollGuide {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  51% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
}
/*# sourceMappingURL=style.css.map */