#contents div {
  text-align: center;
}
#contents img {
  vertical-align: top;
}
/*//////*/
#contents .fade {
  opacity: 0;
  -webkit-animation: fadeIn 1s ease .3s 1 forwards;
  animation: fadeIn 1s ease .3s 1 forwards;
}
.fade2 {
  opacity: 0;
  -webkit-animation: fadeIn 2s ease .3s 1 forwards;
  animation: fadeIn 2s ease .3s 1 forwards;
}
#contents .fadeDown {
  -webkit-animation: fadeDown 2.5s ease .3s 1 forwards;
  animation: fadeDown 2.5s ease .3s 1 forwards;
}
#contents .fadeUp {
  opacity: 0;
  -webkit-animation: fadeUp 2s ease .8s 1 forwards;
  animation: fadeUp 2s ease .8s 1 forwards;
}
#contents .fadeUp2 {
  opacity: 0;
  -webkit-animation: fadeUp 2s ease 1s 1 forwards;
  animation: fadeUp 2s ease 1s 1 forwards;
}
#contents .fadeUp3 {
  opacity: 0;
  -webkit-animation: fadeUp 2s ease 1.2s 1 forwards;
  animation: fadeUp 2s ease 1.2s 1 forwards;
}
#contents .fadeUp__bright {
  opacity: 0;
  -webkit-animation: fadeUp__bright 2s ease .8s 1 forwards;
  animation: fadeUp__bright 2s ease .8s 1 forwards;
}
#contents .fadeUp__bright2 {
  opacity: 0;
  -webkit-animation: fadeUp__bright 2s ease 1s 1 forwards;
  animation: fadeUp__bright 2s ease 1s 1 forwards;
}
#contents .fadeUp__bright3 {
  opacity: 0;
  -webkit-animation: fadeUp__bright 2s ease 1.2s 1 forwards;
  animation: fadeUp__bright 2s ease 1.2s 1 forwards;
}
#contents .fadeIn-scaleUp {
  opacity: 0;
  -webkit-animation: fadeIn-scaleUp 2.5s ease .3s 1 forwards;
  animation: fadeIn-scaleUp 2.5s ease .3s 1 forwards;
}
#contents .fadeIn-scaleDown {
  opacity: 0;
  -webkit-animation: fadeIn-scaleDown 2.5s ease .3s 1 forwards;
  animation: fadeIn-scaleDown 2.5s ease .3s 1 forwards;
}
#contents .fadeIn-bright-scaleUp {
  opacity: 0;
  -webkit-animation: fadeIn-bright-scaleUp 2.5s ease .3s 1 forwards;
  animation: fadeIn-bright-scaleUp 2.5s ease .3s 1 forwards;
}
#contents .fadeIn-bright-scaleDown {
  opacity: 0;
  -webkit-animation: fadeIn-bright-scaleDown 2.5s ease .3s 1 forwards;
  animation: fadeIn-bright-scaleDown 2.5s ease .3s 1 forwards;
}
#contents .line_x {
  opacity: 0;
  height: 10px;
  width: 100%;
  mix-blend-mode: multiply;
  -webkit-animation: lineX 1.8s ease 1.6s 1 forwards;
  animation: lineX 1.8s ease 1.6s 1 forwards;
}
#contents .brightIn {
  opacity: 0;
  -webkit-animation: brightIn 2s ease .5s 1 forwards;
  animation: brightIn 2s ease .5s 1 forwards;
}
#contents .brightIn2 {
  opacity: 0;
  -webkit-animation: brightIn2 2s ease .5s 1 forwards;
  animation: brightIn2 2s ease .5s 1 forwards;
}
#contents .brightUp-up {
  opacity: 0;
  -webkit-animation: brightIn 1.5s ease .4s 1 forwards;
  animation: brightIn 1.5s ease .4s 1 forwards;
}
/*//////*/
@keyframes lineX {
  0% {
    opacity: 0;
    transform: scale(0, 1);
    transform-origin: left top;
  }
  100% {
    opacity: 1;
    transform: scale(1, 1);
    transform-origin: left top;
  }
}
/*//////*/
@keyframes fadeIn {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}
/*//////*/
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}
/*//////*/
@keyframes fadeIn-scaleUp {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
@-webkit-keyframes fadeIn-scaleUp {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
/*//////*/
@keyframes fadeIn-scaleDown {
  0% {
    opacity: 0;
    transform: scale(1.05);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
@-webkit-keyframes fadeIn-scaleDown {
  0% {
    opacity: 0;
    transform: scale(1.05);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
/*//////*/
@keyframes fadeIn-bright-scaleUp {
  0% {
    filter: brightness(2);
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    filter: brightness(1);
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
@-webkit-keyframes fadeIn-bright-scaleUp {
  0% {
    filter: brightness(2);
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    filter: brightness(1);
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
/*//////*/
@keyframes fadeIn-bright-scaleDown {
  0% {
    filter: brightness(2);
    opacity: 0;
    transform: scale(1.07);
  }
  100% {
    filter: brightness(1);
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
@-webkit-keyframes fadeIn-bright-scaleDown {
  0% {
    filter: brightness(2);
    opacity: 0;
    transform: scale(1.07);
  }
  100% {
    filter: brightness(1);
    opacity: 1;
    transform: scale(1);
  }
}
/*//////*/
@keyframes fadeDown {
  0% {
    opacity: 1;
    transform: translateY(0px);
  }
  100% {
    opacity: 1;
    transform: translateY(40px);
  }
}
@-webkit-keyframes fadeDown {
  0% {
    opacity: 1;
    transform: translateY(0px);
  }
  100% {
    opacity: 1;
    transform: translateY(40px);
  }
}
/*//////*/
@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@-webkit-keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
/*//////*/
@keyframes fadeUp__bright {
  0% {
    opacity: 0;
    transform: translateY(10px);
    filter: brightness(2);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
    filter: brightness(1);
  }
}
@-webkit-keyframes fadeUp__bright {
  0% {
    opacity: 0;
    transform: translateY(10px);
    filter: brightness(2);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
    filter: brightness(1);
  }
}
/*//////*/
@keyframes brightIn2 {
  0% {
    opacity: 0;
    filter: brightness(1.5);
  }
  100% {
    opacity: 1;
    filter: brightness(1);
  }
}
@-webkit-keyframes brightIn2 {
  0% {
    opacity: 0;
    filter: brightness(1.5);
  }
  100% {
    opacity: 1;
    filter: brightness(1);
  }
}
/*//////*/
/*//////*/
@keyframes brightIn {
  0% {
    opacity: 0;
    filter: brightness(2);
  }
  100% {
    opacity: 1;
    filter: brightness(1);
  }
}
@-webkit-keyframes brightIn {
  0% {
    opacity: 0;
    filter: brightness(2);
  }
  100% {
    opacity: 1;
    filter: brightness(1);
  }
}
/*//////*/
@keyframes brightUp {
  0% {
    opacity: 0;
    transform: scale(1.1);
    filter: brightness(2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: brightness(1);
  }
}
@-webkit-keyframes brightUp {
  0% {
    opacity: 0;
    transform: scale(1.1);
    filter: brightness(2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: brightness(1);
  }
}
/*//////*/
#contents .movie_set {
  display: block;
  width: 950px;
  height: 328px;
  transform: translateZ(0);
  transition: height .5s ease-in-out, transform 0.5s;
}
#contents .movie_set.js-open {
  will-change: height;
  height: 534px;
}
#contents .movie_set .video {
  width: 950px !important;
  height: 534px !important;
  display: none;
  outline: none;
  background-color: #FFFFFF;
}
#contents .m_set .close {
  background-image: url(../img/close.png);
  background-size: 90%;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  top: -25px;
  right: 10px;
  margin: auto;
  z-index: 10000;
  height: 50px;
  width: 50px;
  cursor: pointer;
  display: none;
}
#contents .movie_section {
  position: relative;
}
#contents .movie_section > img {
  position: absolute;
  top: 0;
}
#contents .movie_area img {
  position: absolute;
}
/*#contents .img_bt {
  margin-left: auto;
  margin-right: auto
}*/
#contents .img_bt img {
  object-fit: cover;
}
#contents .BB {
  border: solid 2px #000;
}
/**/
#contents .my_text-center {
  text-align: center !important
}
#contents .my_d-flex {
  display: -ms-flexbox !important;
  display: flex !important
}
#contents .my_align-items-center {
  -ms-flex-align: center !important;
  align-items: center !important
}
#contents .my_justify-content-center {
  -ms-flex-pack: center !important;
  justify-content: center !important
}
#contents .my_justify-content-between {
  -ms-flex-pack: justify !important;
  justify-content: space-between !important
}
#contents .my_position-absolute {
  position: absolute !important;
}
#contents .my_position-relative {
  position: relative;
}
#contents .my_o-hidden {
  overflow: hidden !important;
}
#contents .my_top0 {
  top: 0 !important
}
#contents .my_left0 {
  left: 0 !important
}
#contents .my_right0 {
  right: 0 !important
}
#contents .my_bottom0 {
  bottom: 0 !important
}
#contents .my_ms-auto, #contents .my_mx-auto {
  margin-left: auto !important
}
#contents .my_me-auto, #contents .my_mx-auto {
  margin-right: auto !important
}
#contents .my_m-auto {
  margin: auto !important
}
#contents .my_z-index1 {
  z-index: 1 !important;
}
#contents .my_z-index2 {
  z-index: 2 !important;
}
#contents .my_z-index3 {
  z-index: 3 !important;
}
#contents .my_z-index10 {
  z-index: 10 !important;
}
#contents .my_z-index20 {
  z-index: 20 !important;
}
#contents .my_z-index3 {
  z-index: 30 !important;
}
#contents .shadow {
  box-shadow: 0 20px 30px -35px rgba(0, 0, 0, 1);
  transition: .3s;
}
#contents .shadow:hover {
  box-shadow: 0 60px 30px -35px rgba(0, 0, 0, .15), 0 -10px 5px -10px rgba(0, 0, 0, .1);
  transform: translateY(-3px);
}
/******mouse over*****/
#contents .movies {
  cursor: pointer;
}
#contents .play_movie {
  background: #3A3948;
  overflow: hidden;
  position: relative;
}
#contents .play_movie {
  z-index: 1;
  border-top-left-radius: 20px !important;
  border-top-right-radius: 20px !important;
  border-bottom-right-radius: 20px !important;
  border-bottom-left-radius: 20px !important;
}
#contents .movies .play_movie .play_movie_img {
  transition-duration: 0.6s;
}
#contents .movies:hover .play_movie .play_movie_img {
  transform: scale(1.06);
  opacity: 0.8;
}
#contents .movies .movie-pointer {
  display: inline-block;
  transition-duration: 0.4s;
  width: 63px;
  height: 106px;
}
#contents .movies:hover .movie-pointer {
  opacity: 1;
  height: 90px;
}
#contents .movies:hover .play_bt {
  opacity: 1;
}
#contents .movies .play_movie_title {
  transition-duration: 0.6s;
  opacity: 1;
}
#contents .movies:hover .play_movie_title {
  opacity: 0.5;
}
/****scale_bt*****/
#contents .scale_bt {
  height: auto;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}
#contents .scale_bt::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background-color: #fff;
  opacity: 0;
  transform: scale(1);
  transition: all 0.5s ease;
}
#contents .scale_bt-img {
  transition: all 0.5s ease;
  opacity: 1;
  display: block;
}
#contents .scale_bt:hover .scale_bt-img {
  transform: scale(1.04);
  opacity: 1;
}
#contents .scale_bt:hover::after {
  transform: scale(0.92, 0.78);
  opacity: 0.9;
}
#contents .bt_cover {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  box-sizing: border-box;
  z-index: 1;
  background-color: rgba(57, 116, 117, 0.7);
  mix-blend-mode: multiply;
  transition: all 0.5s ease;
}
#contents .scale_bt:hover .bt_cover {
  opacity: 0;
}
#contents .bt_tx {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  box-sizing: border-box;
  z-index: 2;
}
#contents .bt_tx::after {
  content: "";
  position: absolute;
  width: 0px;
  height: 2px;
  top: 140px;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #F70004;
  transition: all 0.5s ease;
  z-index: 3;
}
#contents .scale_bt:hover .bt_tx::after {
  width: 110px;
  background-color: #F70004;
}
/*********/
/*****IE****/
#contents .my_ie {
  display: block;
}
#contents .my_modan {
  display: none !important;
}
#contents .my_modan_flex {
  display: none !important;
}
/* chrome safari opera */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  #contents .my_ie {
    display: none;
  }
  #contents .my_modan {
    display: block !important;
  }
  #contents .my_modan_flex {
    display: flex !important;
  }
}
/*Edgeのみ（EdgeHTML）*/
_:-ms-lang(x)::backdrop, #contents .my_ie {
  display: none !important;
}
_:-ms-lang(x)::backdrop, #contents .my_modan {
  display: block !important;
}
_:-ms-lang(x)::backdrop, #contents .my_modan_flex {
  display: flex !important;
}
/*Edgeのみ（Chromium）*/
_:lang(x)::-ms-, #contents .my_ie {
  display: none !important;
}
_:lang(x)::-ms-, #contents .my_modan {
  display: block !important;
}
_:lang(x)::-ms-, #contents .my_modan_flex {
  display: flex !important;
}
/*Firefoxのみ*/
_:lang(x)::-moz-placeholder, #contents .my_ie {
  display: none !important;
}
_:lang(x)::-moz-placeholder, #contents .my_modan {
  display: block !important;
}
_:lang(x)::-moz-placeholder, #contents .my_modan_flex {
  display: flex !important;
}
/*********/
/*********/
#contents .bt_effect {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  opacity: 0;
  cursor: pointer;
  z-index: -1;
}
#contents .bt_effect.green, #contents .bt_effect.orange, #contents .bt_effect.blue {
  width: 34px !important;
  height: 34px !important;
}
#contents .bt_effect::before, .bt_effect::after {
  content: "";
  opacity: 0;
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background-color: #49AEEC;
  border-radius: 50%;
  box-sizing: border-box;
  pointer-events: none;
  animation: pulsate 2.6s linear infinite;
}
#contents .bt_effect::after {
  animation-delay: 1.3s;
}
/**************/
#contents .maps .modal__open:hover {
  z-index: 2 !important;
}
/**************/
#contents .bt_effect.green::before, .bt_effect.green::after {
  background-color: #207D49 !important;
}
#contents .bt_effect.orange::before, .bt_effect.orange::after {
  background-color: #C99701 !important;
}
#contents .bt_effect.blue::before, .bt_effect.blue::after {
  background-color: #8090F4 !important;
}
#contents .bt_effect.green::before, .bt_effect.green::after, #contents .bt_effect.orange::before, .bt_effect.orange::after, #contents .bt_effect.blue::before, .bt_effect.blue::after {
  animation: pulsate2 1.2s linear infinite !important;
}
#contents .bt_effect.green::after, #contents .bt_effect.orange::after, #contents .bt_effect.blue::after {
  animation-delay: .6s !important;
}
#contents .hover_effect .bt_effect {
  opacity: 0;
  display: none !important;
}
#contents .hover_effect:hover .bt_effect, #contents .hover_effect:hover .green_on, #contents .hover_effect:hover .orange_on {
  opacity: 1;
  display: block !important;
}
/*********/
/*********/
#contents .pulse-btn {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  opacity: 0;
  cursor: pointer;
  z-index: -1;
}
#contents .pulse-btn.green, #contents .pulse-btn.orange {
  width: 34px !important;
  height: 34px !important;
}
#contents .pulse-btn::before, .pulse-btn::after {
  content: "";
  opacity: 0;
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  /*  border: 1px solid #1da1f2;*/
  background-color: #49AEEC;
  border-radius: 50%;
  box-sizing: border-box;
  pointer-events: none;
  animation: pulsate 2.6s linear infinite;
}
#contents .pulse-btn::after {
  animation-delay: 1.3s;
}
/**************/
#contents .maps .modal__open:hover {
  z-index: 2 !important;
}
/**************/
#contents .pulse-btn.green::before, .pulse-btn.green::after {
  background-color: #207D49 !important;
}
#contents .pulse-btn.orange::before, .pulse-btn.orange::after {
  background-color: #C99701 !important;
}
#contents .pulse-btn.green::before, .pulse-btn.green::after, #contents .pulse-btn.orange::before, .pulse-btn.orange::after {
  animation: pulsate2 1.2s linear infinite !important;
}
#contents .pulse-btn.green::after, #contents .pulse-btn.orange::after {
  animation-delay: .6s !important;
}
#contents .img_bt .pulse-btn {
  opacity: 0;
  display: none !important;
}
#contents .green_on, #contents .orange_on {
  width: 34px !important;
  height: 34px !important;
  background-size: cover;
  display: none;
}
#contents .green_on {
  background-image: url("../img/pc/2x/green_on@2x.png");
}
#contents .orange_on {
  background-image: url("../img/pc/2x/orange_on@2x.png");
}
#contents .img_bt:hover .pulse-btn, #contents .img_bt:hover .green_on, #contents .img_bt:hover .orange_on {
  opacity: 1;
  display: block !important;
}
@keyframes pulsate {
  0% {
    transform: scale(1);
    opacity: 0;
    z-index: -1;
  }
  15% {
    opacity: .6;
  }
  100% {
    transform: scale(2.4);
    opacity: 0;
  }
}
@keyframes pulsate2 {
  0% {
    transform: scale(1);
    opacity: 0;
    z-index: -1;
  }
  15% {
    opacity: .9;
  }
  75% {
    opacity: .4;
  }
  100% {
    transform: scale(2.6);
    opacity: 0;
  }
}
/************************/
.fuwa, .fuwa2 {
  display: inline-block;
  /*transition: 1.5s ease-in-out;*/
  transition: 1.5s ease-out;
}
.fuwa {
  animation: fuwa 5s ease-in-out infinite alternate;
}
.fuwa2 {
  animation: fuwa2 5s ease-in-out infinite alternate;
}
@keyframes fuwa {
  0% {
    transform: translate(0, 0) rotate(-3deg);
  }
  50% {
    transform: translate(0, -5px) rotate(0deg);
  }
  100% {
    transform: translate(0, 0) rotate(3deg);
  }
}
@keyframes fuwa2 {
  0% {
    transform: translate(0, 0) rotate(3deg);
  }
  50% {
    transform: translate(0, -5px) rotate(0deg);
  }
  100% {
    transform: translate(0, 0) rotate(-3deg);
  }
}
.fadeup2 {
  animation-name: fadeUpAnime;
  animation-duration: 2s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(10px) scale(1.06);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.delay-time02 {
  animation-delay: 0.2s !important;
}
.delay-time04 {
  animation-delay: 0.4s !important;
}
.delay-time06 {
  animation-delay: 0.6s !important;
}
.delay-time08 {
  animation-delay: 0.8s !important;
}
.delay-time010 {
  animation-delay: 1s !important;
}
.delay-time012 {
  animation-delay: 1.2s !important;
}
.delay-time014 {
  animation-delay: 1.4s !important;
}
.delay-time016 {
  animation-delay: 1.6s !important;
}
.delay-time018 {
  animation-delay: 1.8s !important;
}
.anim-box.kiran {
  opacity: 1;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}
.anim-box.kiran::before {
  background-color: #fff;
  content: "";
  display: block;
  position: absolute;
  top: -100px;
  left: 0;
  width: 30px;
  height: 100%;
  opacity: 0;
  transition: cubic-bezier(0.32, 0, 0.67, 0);
}
.anim-box.kiran:hover::before {
  animation: kiran 0.5s linear;
}
@keyframes kiran {
  0% {
    transform: scale(2) rotate(55deg);
    opacity: 0;
  }
  30% {
    transform: scale(20) rotate(55deg);
    opacity: 0.5;
  }
  40% {
    transform: scale(30) rotate(55deg);
    opacity: 0.3;
  }
  70% {
    transform: scale(45) rotate(55deg);
    opacity: 0.1;
  }
  100% {
    transform: scale(50) rotate(55deg);
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
#contents .fadeIn {
  opacity: 0; /* 最初は非表示 */
  animation: fadeIn 1.3s ease-in-out;
  animation-delay: 0.3s; /* 1秒の遅延 */
  animation-fill-mode: forwards; /* アニメーション後もスタイルを保持 */
}

