.p-top {
  position: relative;
}
@media not all and (max-width: 900px) {
  .p-top {
    width: 100%;
    height: 100vh;
    overflow: hidden;
  }
}
.p-top::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/common/bg.jpg) top center no-repeat;
  background-size: 100% auto;
}
.p-top__container {
  position: relative;
  width: 100%;
  height: 100%;
}
@media not all and (max-width: 900px) {
  .p-top__container {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .p-top__container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding-top: 30px;
    z-index: 1;
    background: linear-gradient(to bottom, #acfbff, rgba(172, 251, 255, 0));
    pointer-events: none;
  }
}
.p-top__edge {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}
[data-hover] .p-top__edge {
  opacity: 1;
}
.p-top__edge-filter {
  position: absolute;
  top: 0;
  width: 0;
  height: 100%;
  background: var(--color-white);
  opacity: 0.4;
}
.p-top__edge-filter:first-child {
  left: 0;
}
.p-top__edge-filter:last-child {
  right: 0;
}
.p-top__base {
  position: relative;
  margin: 0 auto;
}
@media not all and (max-width: 900px) {
  .p-top__base {
    width: 100vh;
    height: 100vh;
  }
  @media screen and (orientation: portrait) {
    .p-top__base {
      width: 100vw;
      height: 100vw;
    }
  }
}
@media screen and (max-width: 900px) {
  .p-top__base {
    width: 100%;
    padding-top: 208.5333333333%;
    overflow: hidden;
  }
}
@media not all and (max-width: 900px) {
  .p-top__base-inner {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 180.1538461538%;
    max-width: 2342px;
    height: auto;
    transform: translate(-50%, -50.5%);
  }
}
@media screen and (max-width: 900px) {
  .p-top__base-inner {
    position: absolute;
    top: 0;
    left: 50%;
    width: 238.6666666667%;
    height: auto;
    transform: translateX(-50%);
  }
}
.p-top__base-inner img {
  margin: 0 auto;
}
.p-top__contents {
  position: absolute;
}
@media not all and (max-width: 900px) {
  .p-top__contents {
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100vh;
    transform: translate(-50%, -50%);
    pointer-events: none;
  }
}
@media screen and (max-width: 900px) {
  .p-top__contents {
    top: 8%;
    left: 0%;
    width: 100%;
  }
}
.p-top__ttl {
  transform: translateY(50px);
  opacity: 0;
  transition: transform 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.7s, opacity 0.5s cubic-bezier(0.25, 1, 0.5, 1) 0.7s;
}
@media not all and (max-width: 900px) {
  .p-top__ttl {
    position: absolute;
    top: 38px;
    left: 38px;
    z-index: 1;
    width: 273px;
  }
}
@media screen and (max-width: 900px) {
  .p-top__ttl {
    width: 85%;
    max-width: 560px;
    margin: 0 auto;
    transform: translateY(30px);
  }
}
.is-load .p-top__ttl {
  transform: translateY(0px);
  opacity: 1;
}
.p-top__copy {
  position: absolute;
  font-family: YakuHanJPs, "Jersey 15", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  color: var(--color-main);
  font-size: 13px;
}
@media not all and (max-width: 900px) {
  .p-top__copy {
    bottom: 26px;
    left: 40px;
  }
}
@media screen and (max-width: 900px) {
  .p-top__copy {
    bottom: 26px;
    width: 100%;
    text-align: center;
    font-size: 12px;
  }
}

@media not all and (max-width: 900px) {
  .p-nav {
    position: absolute;
    top: 0;
    right: 48px;
    width: 240px;
    height: 100vh;
    pointer-events: auto;
    transform: translateX(40px);
    opacity: 0;
    transition: transform 0.8s cubic-bezier(0.25, 1, 0.5, 1) 2.8s, opacity 0.6s cubic-bezier(0.25, 1, 0.5, 1) 2.8s;
  }
  .is-load .p-nav {
    transform: translateX(0);
    opacity: 1;
  }
  .p-nav::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: -10px;
    right: -10px;
    padding-top: 50%;
    background: linear-gradient(to top, #fff, rgba(255, 255, 255, 0));
    pointer-events: none;
  }
}
.p-nav__list {
  position: relative;
}
@media not all and (max-width: 900px) {
  .p-nav__list {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition-property: transform;
    box-sizing: content-box;
  }
}
.p-nav__list-group {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media not all and (max-width: 900px) {
  .p-nav__list-item {
    width: 120px;
    height: 120px !important;
  }
  .p-nav__list-item:nth-child(2) {
    transform: translateY(calc(50% + 5px));
  }
}

@media not all and (max-width: 900px) {
  .p-nav_data__txt {
    font-size: 14px;
  }
  .p-nav_data__txt-cap {
    padding: 4px 15px 5px;
    font-size: 10px;
  }
  .p-nav_data.is-current .p-nav_data__base {
    transform: rotate(180deg);
  }
  .p-nav_data.is-current .p-nav_data__base::after {
    opacity: 1;
  }
  .p-nav_data__badge {
    bottom: -1px;
    right: 8px;
    width: 27px;
    height: 27px;
  }
}

.p-clickable {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.is-op-end .p-clickable {
  pointer-events: auto;
}
.p-clickable__item {
  position: absolute;
  pointer-events: none;
}
.p-clickable__item:nth-child(1) {
  top: 21.9%;
  left: 43.5%;
  width: 9.7%;
}
.p-clickable__item:nth-child(2) {
  top: 28.1%;
  left: 35.8%;
  width: 13%;
}
.p-clickable__item:nth-child(3) {
  top: 37.6%;
  left: 46.5%;
  width: 13.6%;
}
.p-clickable__item:nth-child(4) {
  top: 37%;
  left: 37.5%;
  width: 3%;
}
.p-clickable__item:nth-child(5) {
  top: 47%;
  left: 42.2%;
  width: 10.6%;
}
.p-clickable__item:nth-child(6) {
  top: 44.9%;
  left: 52.5%;
  width: 13.7%;
}
.p-clickable__item:nth-child(7) {
  top: 54.6%;
  left: 41.3%;
  width: 9.6%;
}
.p-clickable__item:nth-child(8) {
  top: 52.4%;
  left: 50.5%;
  width: 17.5%;
}
.p-clickable__item:nth-child(9) {
  top: 61.8%;
  left: 45.6%;
  width: 11%;
}
.p-clickable__item:nth-child(10) {
  top: 66.2%;
  left: 41.7%;
  width: 10.6%;
}
.p-clickable__item:nth-child(11) {
  top: 30.5%;
  left: 49%;
  width: 10.6%;
}
.p-clickable__item-inner {
  display: block;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
}
.p-clickable__item-inner svg {
  fill: transparent;
}
.p-clickable__item-inner svg a {
  pointer-events: auto;
  cursor: pointer;
}
.p-clickable__link {
  display: block;
  position: absolute;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  transform: translateY(15px);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) 0.4s, opacity 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}
[data-hover] .p-clickable__link {
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}
.p-clickable__item:nth-child(1) .p-clickable__link {
  top: 0%;
  right: -64%;
  width: 77%;
}
[data-hover=president] .p-clickable__item:nth-child(1) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(1) .p-clickable__link {
    right: -86%;
    width: 96%;
    padding-top: 0;
  }
  .p-clickable__item:nth-child(1) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(2) .p-clickable__link {
  top: -46%;
  left: 26%;
  width: 53%;
}
[data-hover=movie] .p-clickable__item:nth-child(2) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(2) .p-clickable__link {
    top: -60%;
    width: 68%;
    padding-top: 60%;
  }
  .p-clickable__item:nth-child(2) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(3) .p-clickable__link {
  top: -46%;
  left: 13%;
  width: 50%;
}
[data-hover=shooting] .p-clickable__item:nth-child(3) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(3) .p-clickable__link {
    top: -64%;
    width: 60%;
    padding-top: 60%;
  }
  .p-clickable__item:nth-child(3) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(4) .p-clickable__link {
  top: 17%;
  left: 96%;
  width: 255%;
  padding-left: 25%;
}
[data-hover=requirements] .p-clickable__item:nth-child(4) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(4) .p-clickable__link {
    top: 0;
    left: 85%;
    width: 330%;
  }
  .p-clickable__item:nth-child(4) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(5) .p-clickable__link {
  top: -52.5%;
  left: 16.2%;
  width: 67%;
  padding-top: 60%;
}
[data-hover=finishing] .p-clickable__item:nth-child(5) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(5) .p-clickable__link {
    top: -72%;
    width: 90%;
    padding-top: 65%;
  }
  .p-clickable__item:nth-child(5) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(6) .p-clickable__link {
  top: -33.5%;
  left: 16.2%;
  width: 69%;
}
[data-hover=cg] .p-clickable__item:nth-child(6) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media not all and (max-width: 900px) {
  .p-clickable__item:nth-child(6) .p-clickable__link {
    min-width: 160px;
  }
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(6) .p-clickable__link {
    top: -40%;
    left: 2.2%;
    width: 91%;
    padding-top: 67%;
  }
  .p-clickable__item:nth-child(6) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(7) .p-clickable__link {
  top: -52.5%;
  left: 16.2%;
  width: 61%;
  padding-top: 80%;
}
[data-hover=art] .p-clickable__item:nth-child(7) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(7) .p-clickable__link {
    top: -77%;
    width: 90%;
    padding-top: 60%;
  }
  .p-clickable__item:nth-child(7) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(8) .p-clickable__link {
  top: 12%;
  left: 0;
  width: 109%;
  padding-top: 80%;
  transform: translate(20%, calc(-43% + 20px));
}
@media not all and (max-width: 900px) {
  [data-hover=drawing] .p-clickable__item:nth-child(8) .p-clickable__link {
    opacity: 1;
    transform: translate(20%, -43%);
    pointer-events: auto;
  }
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(8) .p-clickable__link {
    top: 0;
    width: 90%;
    padding-top: 0;
    bottom: auto;
    transform: translate(20%, calc(-89% + 20px));
  }
  .p-clickable__item:nth-child(8) .p-clickable__link.is-current {
    opacity: 1;
    transform: translate(20%, -89%);
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(9) .p-clickable__link {
  top: -98%;
  left: 9%;
  width: 83%;
  padding-top: 80%;
}
[data-hover=pm] .p-clickable__item:nth-child(9) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media not all and (max-width: 900px) {
  .p-clickable__item:nth-child(9) .p-clickable__link {
    min-width: 160px;
  }
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(9) .p-clickable__link {
    top: -122%;
    width: 122%;
  }
  .p-clickable__item:nth-child(9) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(10) .p-clickable__link {
  top: -38%;
  left: 57%;
  width: 77%;
}
[data-hover=qa] .p-clickable__item:nth-child(10) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media not all and (max-width: 900px) {
  .p-clickable__item:nth-child(10) .p-clickable__link {
    padding-top: 60%;
    min-width: 160px;
  }
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(10) .p-clickable__link {
    top: -62%;
    left: 25%;
    width: 125%;
  }
  .p-clickable__item:nth-child(10) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
.p-clickable__item:nth-child(11) .p-clickable__link {
  top: -101%;
  left: 0%;
  width: 77%;
  padding-top: 77%;
}
@media not all and (max-width: 900px) {
  .p-clickable__item:nth-child(11) .p-clickable__link {
    min-width: 150px;
  }
}
[data-hover=interview] .p-clickable__item:nth-child(11) .p-clickable__link {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(11) .p-clickable__link {
    top: -105%;
    left: -17%;
    width: 114%;
    padding-top: 77%;
    bottom: auto;
  }
  .p-clickable__item:nth-child(11) .p-clickable__link.is-current {
    opacity: 1;
    pointer-events: auto;
  }
}
@media not all and (max-width: 900px) {
  .p-clickable__item:nth-child(8) .p-clickable__link-inner {
    position: absolute;
    top: 0;
    right: 0;
    width: 66.5%;
    margin-left: auto;
  }
}
.p-clickable__item:nth-child(7) .p-clickable__link-inner, .p-clickable__item:nth-child(5) .p-clickable__link-inner, .p-clickable__item:nth-child(9) .p-clickable__link-inner, .p-clickable__item:nth-child(11) .p-clickable__link-inner {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
}
.p-clickable__item:nth-child(10) .p-clickable__link-inner {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(2) .p-clickable__link-inner, .p-clickable__item:nth-child(3) .p-clickable__link-inner, .p-clickable__item:nth-child(6) .p-clickable__link-inner {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
  }
}
.p-clickable__link-base {
  display: block;
}
.p-clickable__item:nth-child(6) .p-clickable__link-base {
  transform-origin: top center;
  transform: scaleY(70%);
}
.p-clickable__item:nth-child(9) .p-clickable__link-base {
  transform-origin: top center;
  transform: scaleY(80%);
}
.p-clickable__item:nth-child(10) .p-clickable__link-base {
  transform-origin: top center;
  transform: scaleY(80%);
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(11) .p-clickable__link-base {
    transform-origin: top center;
    transform: scaleY(70%);
  }
}
.p-clickable__link-list {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 92%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 14%;
}
.p-clickable__item:nth-child(1) .p-clickable__link-list {
  height: 100%;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(1) .p-clickable__link-list {
    height: 96%;
  }
}
.p-clickable__item:nth-child(4) .p-clickable__link-list {
  height: 96%;
  padding-left: 24%;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(4) .p-clickable__link-list {
    padding-left: 20%;
  }
}
.p-clickable__item:nth-child(6) .p-clickable__link-list {
  height: 68%;
  padding-left: 11%;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(6) .p-clickable__link-list {
    height: 65%;
    padding-left: 7%;
  }
}
.p-clickable__item:nth-child(9) .p-clickable__link-list {
  height: 72%;
  padding-left: 8%;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(8) .p-clickable__link-list {
    padding-left: 8%;
  }
}
.p-clickable__item:nth-child(10) .p-clickable__link-list {
  padding-left: 10%;
  height: 74%;
}
@media screen and (max-width: 900px) {
  .p-clickable__item:nth-child(11) .p-clickable__link-list {
    padding-left: 11%;
    height: 64%;
  }
}
.p-clickable__link-item + .p-clickable__link-item {
  margin-top: 8px;
}
@media screen and (max-width: 900px) {
  .p-clickable__link-item + .p-clickable__link-item {
    margin-top: 4px;
  }
}
.p-clickable__link-item .p-in-link {
  position: relative;
  display: block;
  padding-left: 18px;
  text-align: left;
  font-family: YakuHanJPs, "DotGothic16", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  color: var(--color-main);
  font-size: 15px;
}
@media not all and (max-width: 900px) {
  .p-clickable__link-item .p-in-link {
    padding-left: clamp(10px, 1.1428571429vw, 22px);
    font-size: clamp(10px, 1.0714285714vw, 16px);
  }
}
@media screen and (max-width: 900px) {
  .p-clickable__link-item .p-in-link {
    padding-left: 12px;
    font-size: 12px;
    padding-left: 3.2vw;
    font-size: min(3.2vw, 20px);
  }
}
.p-clickable__link-item .p-in-link.is-current::before {
  background-color: var(--color-main2);
}
.p-clickable__link-item .p-in-link::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 14px;
  height: 100%;
  -webkit-mask: url(../img/common/i_arrow.svg) left center no-repeat;
  mask: url(../img/common/i_arrow.svg) left center no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  background: var(--color-sub);
  transition: background-color 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
@media not all and (max-width: 900px) {
  .p-clickable__link-item .p-in-link::before {
    width: clamp(10px, 1vw, 19px);
  }
}
@media screen and (max-width: 900px) {
  .p-clickable__link-item .p-in-link::before {
    width: 12px;
    width: min(3.2vw, 18px);
  }
}

.p-chara {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.p-chara__aone {
  position: absolute;
  bottom: 22.2%;
  left: 35.7%;
  width: 4.2%;
  transform: scale(0.8, 1.4) translate(0%, -100%);
  transition: opacity 0.2s cubic-bezier(0.25, 1, 0.5, 1) 0.2s;
}
[data-hover] .p-chara__aone {
  transition: opacity 0.2s cubic-bezier(0.25, 1, 0.5, 1) 0s;
  opacity: 0;
}
.is-load .p-chara__aone {
  animation: poyon 1.2s linear 0.7s forwards;
}
.p-chara__aone-inner {
  width: 100%;
  padding-top: 137.7551020408%;
  background: url(../img/top/c_aone.png) left center no-repeat;
  background-size: 400% auto;
  animation: chara_move 1s steps(4, jump-none) 1.6s infinite;
}
.p-chara__president {
  position: absolute;
  top: 21.5%;
  left: 44.3%;
  width: 7.6%;
}
.p-chara__president-out {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 2.5s;
  transform-origin: 60% 30%;
}
.is-load .p-chara__president-out {
  transform: translateY(0) scale(1);
}
[data-hover=president] .p-chara__president-out {
  opacity: 0;
}
.p-chara__president-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_president_in.png);
}
[data-hover=president] .p-chara__president-in {
  opacity: 1;
}
.p-chara__movie {
  position: absolute;
  top: 28.9%;
  left: 37.1%;
  width: 9.8%;
}
[data-hover=movie] .p-chara__movie-out {
  opacity: 0;
}
.p-chara__movie-out img {
  transform: translateY(10px);
  opacity: 0;
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) 2.4s, opacity 0.3s cubic-bezier(0.25, 1, 0.5, 1) 2.4s;
}
.is-load .p-chara__movie-out img {
  transform: translateY(0);
  opacity: 1;
}
.p-chara__movie-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_movie_in.png);
}
[data-hover=movie] .p-chara__movie-in {
  opacity: 1;
}
.p-chara__pm {
  position: absolute;
  bottom: 31.3%;
  left: 46.6%;
  width: 9%;
}
[data-hover=pm] .p-chara__pm-out {
  opacity: 0;
}
.p-chara__pm-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 1.7s;
  transform-origin: 50% 80%;
}
.is-load .p-chara__pm-out img {
  transform: translateY(0) scale(1);
}
.p-chara__pm-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_production_in.png);
}
[data-hover=pm] .p-chara__pm-in {
  opacity: 1;
}
.p-chara__cg {
  position: absolute;
  top: 45.5%;
  left: 52.9%;
  width: 11.1%;
}
[data-hover=cg] .p-chara__cg-out {
  opacity: 0;
}
.p-chara__cg-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 2.1s;
  transform-origin: 80% 90%;
}
.is-load .p-chara__cg-out img {
  transform: translateY(0) scale(1.01);
}
.p-chara__cg-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_cg_in.png);
}
[data-hover=cg] .p-chara__cg-in {
  opacity: 1;
}
.p-chara__shooting {
  position: absolute;
  top: 37.5%;
  left: 47.2%;
  width: 9.8%;
}
[data-hover=shooting] .p-chara__shooting-out {
  opacity: 0;
}
.p-chara__shooting-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 2.2s;
  transform-origin: 30% 50%;
}
.is-load .p-chara__shooting-out img {
  transform: translateY(0) scale(1);
}
.p-chara__shooting-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_photography_in.png);
}
[data-hover=shooting] .p-chara__shooting-in {
  opacity: 1;
}
.p-chara__finishing {
  position: absolute;
  top: 46.2%;
  left: 43.2%;
  width: 9.1%;
}
[data-hover=finishing] .p-chara__finishing-out {
  opacity: 0;
}
.p-chara__finishing-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 2s;
}
.is-load .p-chara__finishing-out img {
  transform: translateY(0) scale(1.01);
}
.p-chara__finishing-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_finishing_in.png);
}
[data-hover=finishing] .p-chara__finishing-in {
  opacity: 1;
}
.p-chara__art {
  position: absolute;
  top: 54.8%;
  left: 42.3%;
  width: 7.5%;
}
[data-hover=art] .p-chara__art-out {
  opacity: 0;
}
.p-chara__art-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 1.8s;
  transform-origin: 70% 80%;
}
.is-load .p-chara__art-out img {
  transform: translateY(0) scale(1.01);
}
.p-chara__art-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_art_in.png);
}
[data-hover=art] .p-chara__art-in {
  opacity: 1;
}
.p-chara__drawing {
  position: absolute;
  top: 53.3%;
  left: 51%;
  width: 17.5%;
}
[data-hover=drawing] .p-chara__drawing-out, [data-hover=drawing-movie] .p-chara__drawing-out, [data-hover=drawing-fukuoka] .p-chara__drawing-out {
  opacity: 0;
}
.p-chara__drawing-out img {
  transform: translateY(20px);
  opacity: 0;
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 1.9s, opacity 0.3s cubic-bezier(0.25, 1, 0.5, 1) 1.9s;
  transform-origin: 20% 50%;
}
.is-load .p-chara__drawing-out img {
  transform: translateY(0);
  opacity: 1;
}
.p-chara__drawing-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_drawing_in.png);
}
[data-hover=drawing] .p-chara__drawing-in, [data-hover=drawing-movie] .p-chara__drawing-in, [data-hover=drawing-fukuoka] .p-chara__drawing-in {
  opacity: 1;
}
.p-chara__interview {
  position: absolute;
  top: 28.8%;
  left: 48.9%;
  width: 8.2%;
}
[data-hover=interview] .p-chara__interview-out {
  opacity: 0;
}
.p-chara__interview-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 2.3s;
}
.is-load .p-chara__interview-out img {
  transform: translateY(0) scale(1);
}
.p-chara__interview-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_interview_in.png);
}
[data-hover=interview] .p-chara__interview-in {
  opacity: 1;
}
.p-chara__qa {
  position: absolute;
  top: 67.8%;
  left: 49.5%;
  width: 4.4%;
}
[data-hover=qa] .p-chara__qa-out {
  opacity: 0;
}
.p-chara__qa-out img {
  transform: translateY(20px) scale(0);
  transition: transform 0.6s cubic-bezier(0.37, 1.43, 0.64, 1) 1.5s;
  transform-origin: 30% 80%;
}
.is-load .p-chara__qa-out img {
  transform: translateY(0) scale(1.01);
}
.p-chara__qa-in {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-position: left center;
  background-size: 200% auto;
  animation: chara_move 1s steps(2, jump-none) infinite;
  opacity: 0;
  background-image: url(../img/top/c_qa_in.png);
}
[data-hover=qa] .p-chara__qa-in {
  opacity: 1;
}
.p-chara__bird {
  position: absolute;
  top: 44.7%;
  left: 41.4%;
  width: 2.8%;
}
.p-chara__flower {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-chara__flower-item {
  position: absolute;
  width: 2.4%;
}
.p-chara__flower-item:nth-child(1) {
  bottom: 33%;
  left: 31%;
}
.p-chara__flower-item:nth-child(2) {
  bottom: 25%;
  left: 39%;
}
.p-chara__flower-item:nth-child(3) {
  bottom: 37.5%;
  left: 33%;
}
.p-chara__flower-item:nth-child(3) img {
  transform: scaleX(-1);
}
.p-chara__flower-item:nth-child(4) {
  bottom: 32%;
  left: 25%;
}
.p-chara__flower-item:nth-child(5) {
  bottom: 32.5%;
  right: 29%;
}
.p-chara__flower-item:nth-child(5) img {
  transform: scaleX(-1);
}
.p-chara__flower-item:nth-child(6) {
  bottom: 30.5%;
  left: 35%;
}
.p-chara__flower-item:nth-child(6) img {
  transform: scaleX(-1);
}

@keyframes chara_move {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}
.p-filter {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.p-filter__item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}
[data-hover=president] .p-filter__item.--president {
  opacity: 1;
}
[data-hover=movie] .p-filter__item.--movie {
  opacity: 1;
}
[data-hover=requirements] .p-filter__item.--requirements {
  opacity: 1;
}
[data-hover=pm] .p-filter__item.--pm {
  opacity: 1;
}
[data-hover=cg] .p-filter__item.--cg {
  opacity: 1;
}
[data-hover=shooting] .p-filter__item.--shooting {
  opacity: 1;
}
[data-hover=finishing] .p-filter__item.--finishing {
  opacity: 1;
}
[data-hover=art] .p-filter__item.--art {
  opacity: 1;
}
[data-hover=drawing] .p-filter__item.--drawing {
  opacity: 1;
}
[data-hover=drawing-movie] .p-filter__item.--drawing {
  opacity: 1;
}
[data-hover=drawing-fukuoka] .p-filter__item.--drawing {
  opacity: 1;
}
[data-hover=interview] .p-filter__item.--interview {
  opacity: 1;
}
[data-hover=qa] .p-filter__item.--qa {
  opacity: 1;
}

.m-president {
  display: none;
}
.m-president__content {
  position: relative;
  min-height: 100vh;
  color: var(--color-main);
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
.m-president__content::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  padding-top: 100%;
  transform: translate(-50%, -50%) scale(0);
  background: var(--color-white);
  border-radius: 50%;
}
@media screen and (max-width: 900px) {
  .m-president__content::before {
    left: 50%;
    width: 90vh;
    padding-top: 90vh;
  }
}
.is-modal-open .m-president__content::before {
  animation: modal_circle 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.m-president__inner {
  position: relative;
}
@media screen and (max-width: 900px) {
  .m-president__inner {
    width: 90%;
    margin: 0 auto;
  }
}
.m-president__ttl {
  margin-bottom: 45px;
  text-align: center;
}
@media screen and (max-width: 900px) {
  .m-president__ttl {
    margin-bottom: 20px;
  }
}
.m-president__ttl-main {
  display: block;
  font-weight: 700;
  font-size: 45px;
  letter-spacing: 0.08rem;
  transform: translateY(20px);
  opacity: 0;
}
@media screen and (max-width: 900px) {
  .m-president__ttl-main {
    font-size: 30px;
  }
}
.is-modal-open .m-president__ttl-main {
  animation: modal_elem_y 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.1s forwards, modal_elem_alpha 0.6s cubic-bezier(0.25, 1, 0.5, 1) 0.1s forwards;
}
.m-president__ttl-sub {
  display: block;
  margin-top: 1px;
  font-size: 24px;
  color: var(--color-sub);
  font-family: YakuHanJPs, "Jersey 15", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  letter-spacing: 0.02rem;
  transform: translateY(20px);
  opacity: 0;
}
@media screen and (max-width: 900px) {
  .m-president__ttl-sub {
    font-size: 16px;
  }
}
.is-modal-open .m-president__ttl-sub {
  animation: modal_elem_y 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.2s forwards, modal_elem_alpha 0.6s cubic-bezier(0.25, 1, 0.5, 1) 0.2s forwards;
}
.m-president__desc {
  line-height: 1.58;
  transform: translateY(20px);
  opacity: 0;
}
.is-modal-open .m-president__desc {
  animation: modal_elem_y 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.35s forwards, modal_elem_alpha 0.6s cubic-bezier(0.25, 1, 0.5, 1) 0.35s forwards;
}
@media screen and (max-width: 900px) {
  .m-president__desc {
    text-align: left;
    line-height: 1.65;
  }
}
@media screen and (max-width: 900px) {
  .m-president__desc .p-in-name {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
  }
}

.m-movie {
  display: none;
}
@media screen and (max-width: 900px) {
  .m-movie__container {
    width: 90%;
    margin: 0 auto;
  }
}
.m-movie__play {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.m-movie__play iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.p-loading {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  font-family: YakuHanJPs, "DotGothic16", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  color: var(--color-main);
  display: flex;
  justify-content: center;
  align-items: center;
  background: url(../img/common/bg_menu.jpg) top center no-repeat;
  background-size: cover;
}
.is-load .p-loading {
  transition: opacity 0.5s cubic-bezier(0.25, 1, 0.5, 1) 0.7s;
  opacity: 0;
  pointer-events: none;
}
.p-loading__txt {
  display: flex;
  text-align: center;
  letter-spacing: 0.06rem;
}
.p-loading__txt span {
  display: block;
}
.p-loading__txt span:nth-last-child(3) {
  animation: hover_flash 0.5s cubic-bezier(0.5, 1, 0.89, 1) alternate infinite;
}
.p-loading__txt span:nth-last-child(2) {
  animation: hover_flash 0.5s cubic-bezier(0.5, 1, 0.89, 1) 0.25s alternate infinite;
}
.p-loading__txt span:nth-last-child(1) {
  animation: hover_flash 0.5s cubic-bezier(0.5, 1, 0.89, 1) 0.5s alternate infinite;
}
.p-loading__chara {
  width: 100%;
}
.p-loading__chara-inner {
  width: 100%;
  padding-top: 137.7551020408%;
  background: url(../img/top/c_aone.png) left center no-repeat;
  background-size: 400% auto;
  animation: chara_move 1s steps(4, jump-none) infinite;
}