@charset "utf-8";
/* CSS Document */
/*body {
  position: relative;
  font-family: '游明朝', 'Yu Mincho', '游明朝体', 'YuMincho', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
  font-weight: 400;
  color: #333333;
  font-size: 1rem;
  text-align: justify;
  text-justify: inter-ideograph;
}*/

video {
  height: auto;
  max-width: 100%;
	filter: drop-shadow(0px 0px rgba(0,0,0,0));
  outline: none;
  border: none;
}
.top-movie-button.replay {
  display: none;
}
/*.top-movie-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}*/

.top-movie-wrapper video {
  width: 100%;
  height: auto;
  opacity: 1;
}
@-webkit-keyframes toFadein {
  0% {
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@keyframes toFadein {
  0% {
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@-webkit-keyframes toBottom {
  0% {
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  20% {
    background-position: 0 0;
  }
  70% {
    background-position: 0 100%;
  }
  90% {
    opacity: 1;
  }
  100% {
    background-position: 0 100%;
    opacity: 0;
  }
}

@keyframes toBottom {
  0% {
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  20% {
    background-position: 0 0;
  }
  70% {
    background-position: 0 100%;
  }
  90% {
    opacity: 1;
  }
  100% {
    background-position: 0 100%;
    opacity: 0;
  }
}

@-webkit-keyframes toFadein03 {
  0% {
    opacity: 0;
  }
  70% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}

@keyframes toFadein03 {
  0% {
    opacity: 0;
  }
  70% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}

@-webkit-keyframes toFadeinLast {
  0% {
    opacity: 0;
  }
  85% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}

@keyframes toFadeinLast {
  0% {
    opacity: 0;
  }
  85% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}

.visible.top-mv-fadein-01 {
  -webkit-animation-name: toFadein;
          animation-name: toFadein;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.visible.top-mv-bg-02 {
  -webkit-animation-name: toBottom;
          animation-name: toBottom;
  -webkit-animation-delay: .5s;
          animation-delay: .5s;
  -webkit-animation-duration: 5s;
          animation-duration: 5s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.visible.top-mv-fadein-03 {
  -webkit-animation-name: toFadein03;
          animation-name: toFadein03;
  -webkit-animation-delay: .5s;
          animation-delay: .5s;
  -webkit-animation-duration: 3s;
          animation-duration: 3s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.visible.top-mv-fadein-04 {
  -webkit-animation-name: toFadeinLast;
          animation-name: toFadeinLast;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes mv_show {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes mv_show {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@media screen and (min-width: 1025px) {
  #top .p-header {
    display: none;
  }
}

#photo.visible {
  -webkit-animation-name: mv_show;
          animation-name: mv_show;
  -webkit-animation-delay: .25s;
          animation-delay: .25s;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

#photo.visible .top-movie-photo-item {
  -webkit-animation-name: mv_show;
          animation-name: mv_show;
  -webkit-animation-delay: .5s;
          animation-delay: .5s;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.top-movie {
  position: relative;
  width: 100%;
  /*padding-top: 49.47%;*/
	padding-top: 56.2%;
  overflow: hidden;
  -webkit-transition: all .5s;
  transition: all .5s;
}

@media screen and (max-width: 767px) {
  .top-movie {
    /*padding-top: 100vw;*/
  }
}

.top-movie-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.top-movie-wrapper video {
  width: 100%;
  height: auto;
  opacity: 1;
}

.top-movie-photo {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  opacity: 0;
}

.top-movie-photo-item {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}

.top-movie-photo-item img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100% !important;
}

.top-movie-button {
  display: block;
  width: 80px;
  color: #000;
  font-size: 14px;
  text-align: center;
  text-decoration: none;
  padding: 10px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(0, 0, 0, 0.5);
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .top-movie-button {
    width: 60px;
    font-size: 12px;
    padding: 5px;
  }
}

.top-movie-button.replay {
  display: none;
}

.top-movie-button-wrapper {
  position: absolute;
  right: 15px;
  bottom: 25px;
}

@media screen and (max-width: 1330px) {
  .top-movie-button-wrapper {
    bottom: 15px;
  }
}

@media screen and (max-width: 1024px) {
  .top-movie-button-wrapper {
    right: 10px;
    bottom: 10px;
  }
}
.top-movie-button-wrapper {
  position: absolute;
  right: 15px;
  bottom: 25px;
}

@media screen and (max-width: 1330px) {
  .top-movie-button-wrapper {
    bottom: 15px;
  }
}

@media screen and (max-width: 1024px) {
  .top-movie-button-wrapper {
    right: 10px;
    bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  .u-hide-pc {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .u-hide-sp {
    display: none;
  }
}