@charset "UTF-8";
/*-----------------------------------------------------------------
 * reset
-----------------------------------------------------------------*/
blockquote,body,code,dd,div,dl,dt,fieldset,figcaption,figure,form,h1,h2,h3,h4,h5,h6,input,legend,li,ol,p,pre,td,textarea,th,ul{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:400}li{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:400}q:after,q:before{content:""}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,select,textarea{font-family:inherit;font-size:inherit;font-weight:inherit;font-size:100%}legend{color:#fff}hr{display:none}img{vertical-align:bottom}button,input,select,textarea{font-size:99%}table{font-size:inherit;font:100%;border-collapse:collapse;border-spacing:0}code,kbd,pre,samp,tt{font-family:monospace;*font-size:108%;line-height:100%}.hd{display:block;width:0;height:0;overflow:hidden}.cf:after,.cf:before{content:"";display:table}.cf:after{clear:both}.cf{*zoom:1}article,aside,details,figcaption,figure,footer,header,hgroup,hr,main,menu,nav,section{display:block}*{margin:0;padding:0;-webkit-box-sizing:border-box;box-sizing:border-box;max-height:999999px}*,:focus{outline:0}button{background-color:transparent;border:0;cursor:pointer;outline:0;padding:0}

/*-----------------------------------------------------------------
 * base
-----------------------------------------------------------------*/
html {
  background: url(../img/common/bg.jpg) no-repeat;
  background-size: cover;
  background-attachment: fixed;
  font-size: 62.5%;
  height: 100%;
}

body {
  width: 100%;
  -webkit-text-size-adjust: 100%;
  color: #000;
  font-size: 1.6rem;
}

iframe {
  border: none;
}

img,
video,
object {
  max-width: 100%;
  height: auto;
  border: none;
  display: block;
}

a {
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

a:hover img {
  text-decoration: none;
  opacity: 0.8;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}

@media screen and (max-width: 1200px) {
  .pcbr{display: none;}
  .spbr{display: block;}
}
@media screen and (min-width: 1520px) {
  .pcbr{display: block;}
  .spbr{display: none;}
}
@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
  .pcbr{display: none;}
  .spbr{display: none;}
}

.ah {
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.ah:hover {
  opacity: 0.8;
}

/**
* scroll bar
*/
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: #fff;
}

::-webkit-scrollbar-thumb {
  background: #000;
  margin: 2px;
  -webkit-box-shadow: none;
  box-shadow: none;
}

/*-----------------------------------------------
* header
-------------------------------------------------*/
.header {
  width: 100%;
  height: min(8.33333vw, 100px);
  position: fixed;
  top: 0;
  z-index: 999;
}

.header.is-active:before {
  opacity: 1;
}

.header__logo {
  position: absolute;
  z-index: 1000;
}

.header__logo.is-active {
  z-index: 999;
}

@media screen and (min-width: 769px) {
  .header__logo {
    width: min(20vw, 300px);
    pointer-events: auto;
    top: min(1.6666666666666667vw, 25px);
    left: min(3.3333333333vw, 50px);
  }
}

@media screen and (max-width: 768px) {
  .header__logo {
    top: max(2.1333333333vw, 10.6666666667px);
    left: max(3.2vw, 16px);
    width: max(32vw, 160px);
  }
}

.header__logo>img {
  width: 100%;
}

.header__inner {
  -webkit-overflow-scrolling: touch;
  width: calc(100% - min(6.6666666667vw, 100px));
  height: 100%;
  overflow-y: auto;
  -ms-scroll-chaining: none;
  overscroll-behavior: contain;
  position: fixed;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
  overflow: hidden;
  /* background: url("../img/common/nav/bg_img_2.jpg") no-repeat center center/cover; */
}

@media screen and (min-width: 769px) {
  .header__inner {
    min-height: 640px;
    z-index: 1;
  }
}

@media screen and (max-width: 768px) {
  .header__inner {
    width: 100%;
    overflow-x: hidden;
    background-image: unset;
  }
}

.is-active .header__inner {
  opacity: 1;
  pointer-events: auto;
}

@media screen and (max-width: 768px) {
  .is-active .header__inner {
    overscroll-behavior-y: contain;
    overflow-y: auto;
  }
}

.header__openInner {
  width: min(6.6666666667vw, 100px);
  /* height: 100vh; */
  position: fixed;
  top: 0;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .header__openInner {
    pointer-events: none;
  }

  .is-active .header__openInner {
    pointer-events: auto;
  }
}

@media screen and (min-width: 769px) {
  .is-active .header__openInner::before {
    opacity: 1;
  }
}

@media screen and (max-width: 768px) {
  .header__openInner {
    width: max(12.8vw, 64px);
    right: max(3.2vw, 16px);
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}

.header__navBtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  height: 100%;
  position: relative;
  text-decoration: none;
  z-index: 10;
}

@media screen and (min-width: 769px) {
  .header__navBtn {
    margin-top: 24px;
  }
}

@media screen and (max-width: 768px) {
  .header__navBtn {
    background-color: #000;
    padding-top: max(3.2vw, 16px);
  }
}

.header__navBtn:before {
  content: "";
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  position: absolute;
  inset: 0;
  margin: auto;
}

.header__navBtn:after {
  content: "Menu";
  color: #fff;
  font-size: min(1.3333333333vw, 20px);
  letter-spacing: 0;
  line-height: 1;
  margin-top: 18px;
  text-align: center;
  font-family: "futura-pt", sans-serif;
  text-transform: uppercase;
}

@media screen and (max-width: 768px) {
  .header__navBtn:after {
    font-size: max(2.6666666667vw, 13.3333333333px);
    margin-top: max(2.1333333333vw, 10.6666666667px);
  }
}

.header__navBtn.is-active:after {
  content: "Close";
}

.header__navBtn__lineWrap {
  width: 32px;
  height: 16px;
  position: relative;
}

@media screen and (max-width: 768px) {
  .header__navBtn__lineWrap {
    width: max(6.6666666667vw, 33.3333333333px);
    height: max(2.6666666667vw, 13.3333333333px);
  }
}

.header__navBtn--line {
  background-color: #fff;
  width: 100%;
  height: 1px;
  margin: auto;
  position: absolute;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.header__navBtn--line:nth-child(1) {
  top: 0;
}

.header__navBtn--line:nth-child(2) {
  bottom: 0;
}

.header__navBtn.is-active .header__navBtn--line:nth-child(1) {
  top: 8px;
  -webkit-transform: rotate(20deg);
  transform: rotate(20deg);
}

.header__navBtn.is-active .header__navBtn--line:nth-child(2) {
  bottom: 7px;
  -webkit-transform: rotate(-20deg);
  transform: rotate(-20deg);
}

@media screen and (max-width: 768px) {
  .header__navBtn.is-active .header__navBtn--line:nth-child(1) {
    top: 9px;
  }
  .header__navBtn.is-active .header__navBtn--line:nth-child(2) {
    bottom: 4px;
  }
}

.header__sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: relative;
  z-index: 1;
  filter: invert(1) drop-shadow(0 0 1px #009dbd) drop-shadow(0 0 1px #009dbd) drop-shadow(0 0 1px #009dbd) drop-shadow(0 0 1px #009dbd) drop-shadow(0 0 1px #009dbd);
}

@media screen and (max-width: 768px) {
  .header__sns {
    display: none;
    opacity: 0;
    -webkit-transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1);
    transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1);
    margin-top: max(12.8vw, 64px);
    filter: none;
  }

  .is-active .header__sns {
    display: block;
    opacity: 1;
  }
}

.header__sns--title {
  color: #000;
  font-size: min(1.3333333333vw, 20px);
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .header__sns--title {
    margin: 0 auto;
    font-size: max(3.2vw, 16px);
  }
}

.header__sns--list {
  margin-top: min(2vw, 30px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: min(2vw, 30px);
}

@media screen and (max-width: 768px) {
  .header__sns--list {
    margin-top: max(6.4vw, 32px);
    gap: max(6.4vw, 32px);
  }
}

.header__sns--item {
  width: min(1.6666666667vw, 25px);
  height: min(1.6666666667vw, 25px);
}

@media screen and (max-width: 768px) {
  .header__sns--item {
    width: max(6.6666666667vw, 33.3333333333px);
    height: max(6.6666666667vw, 33.3333333333px);
  }
}

.header__sns--item>a::before {
  width: 100%;
  height: 100%;
  content: "";
  display: inline-block;
  -webkit-transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.header__sns--item>a.icon-tw::before {
  -webkit-mask-image: url("../img/common/icon/icon_tw.svg?v2");
  mask-image: url("../img/common/icon/icon_tw.svg?v2");
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: #FFF;
  background-color: #000;
}

.header__sns--item>a.icon-tw:hover::before {
  background-color: #FFF;
}

.header__sns--item>a.icon-tik::before {
  -webkit-mask-image: url("../img/common/icon/icon_tik.svg");
  mask-image: url("../img/common/icon/icon_tik.svg");
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: #FFF;
  background-color: #000;
}

.header__sns--item>a.icon-tik:hover::before {
  background-color: #FFF;
}

.header__link {
  margin-bottom: min(1.6666666667vw, 25px);
  position: relative;
  z-index: 1;
}

.header__link--item>a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 14px;
  padding: min(1.3333333333vw, 20px) min(0.8333333333vw, 12.5px);
  margin: 0 auto;
  border: 1px solid #000;
  background-color: #000;
  font-size: min(1.3333333333vw, 20px);
  color: #fff;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

.header__link--item>a:hover {
  color: #000;
  background-color: #FFF;
}

.header__link--item>a:hover .icon-arrow {
  -webkit-animation: arrow 0.5s;
  animation: arrow 0.5s;
}

.header__link--item>span {
  line-height: 1;
}

.header__triangle {
  z-index: -1;
  pointer-events: none;
  position: absolute;
}

@media screen and (min-width: 769px) {
  .header__triangle {
    width: 0;
    height: 150%;
    top: 0;
    right: 0;
    background-color: rgba(255, 255, 255, 0.8);
    -webkit-transition: width 0.5s cubic-bezier(0.5, 1, 0.89, 1);
    transition: width 0.5s cubic-bezier(0.5, 1, 0.89, 1);
  }

  .is-active .header__triangle {
    width: min(25vw, 375px);
  }
}

@media screen and (max-width: 768px) {
  .header__triangle {
    height: 200%;
    top: max(20%,390px);
    left: 50%;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
    -webkit-transform: translateX(0%) translateY(-50%) rotate(-85deg);
    transform: translateX(0%) translateY(-50%) rotate(-85deg);
    background-color: #fff;
    z-index: 2;
    width: 0%;
    -webkit-transition: width 0.5s ease;
    transition: width 0.5s ease;
  }

  .is-active .header__triangle {
    width: 130%;
    max-width: 700px;
  }
}

.header__shareDl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 24px;
}

@media screen and (max-width: 768px) {
  .header__shareDl {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}

.header__shareDl--dt {
  display: none;
}

@media screen and (max-width: 768px) {
  .header__shareDl--dt {
  }
}

.header__shareLists {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .header__shareLists {
    gap: max(6.4vw, 32px);
  }
}

.header__shareLists--item {
  width: min(2.08333vw, 25px);
  height: min(2.08333vw, 25px);
}

.header__shareLists--item:first-child a{
  padding: 2px;
}

.header__shareLists--item:not(:first-child) {
  margin-left: min(2.5vw, 30px);
}

@media screen and (max-width: 768px) {
  .header__shareLists--item:not(:first-child) {
    margin-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .header__shareLists--item {
    width: max(6.4vw, 32px);
    height: max(6.4vw, 32px);
  }
}

.header__shareLists--item>a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.header__shareLists--item>a:before {
  content: "";
  background-color: #000;
  display: block;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  width: min(2.08333vw, 25px);
  height: min(2.08333vw, 25px);
  -webkit-transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .header__shareLists--item>a:before {
    width: max(6.4vw, 32px);
    height: max(6.4vw, 32px);
  }
}

.header__shareLists--item>a:hover::before {
  background-color: #009dbd;
}

.header__shareLists--item.is-weibo>a:before {
  -webkit-mask-image: url(../img/common/icon/icon_wb.svg);
  mask-image: url(../img/common/icon/icon_wb.svg);
}

.header__shareLists--item.is-twitter>a:before {
  -webkit-mask-image: url(../img/common/icon/icon_tw.svg?v2);
  mask-image: url(../img/common/icon/icon_tw.svg?v2);
}

.header__shareLists--item.is-facebook>a:before {
  -webkit-mask-image: url(../img/common/icon/icon_fb.svg);
  mask-image: url(../img/common/icon/icon_fb.svg);
}

.header__shareLists--item.is-line>a:before {
  -webkit-mask-image: url(../img/common/icon/icon_line.svg);
  mask-image: url(../img/common/icon/icon_line.svg);
}

.header__slide {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: #FFF;
}

@media screen and (max-width: 768px) {
  .header__slide {
    background-color: #009dbd;
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
    -webkit-transform-origin: bottom;
    transform-origin: bottom;
  }
}

.header__slide--list {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.header__slide--item {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-size: cover;
  background-position: center bottom;
  background-repeat: no-repeat;
}

@media screen and (max-width: 768px) {
  .header__slide--item {
    background-size: contain;
  }
}

.header__slide--item:nth-child(1) {
  background-image: url("../img/common/nav/bg_img_1.jpg");
}

.header__slide--item:nth-child(2) {
  /* background-image: url("../img/common/nav/bg_img_2.jpg"); */
}

.header__slide--item:nth-child(3) {
  background-image: url("../img/common/nav/bg_img_3.jpg");
}

.header__slide--item.is-show {
  -webkit-animation: zoom 11s forwards linear;
  animation: zoom 11s forwards linear;
}

.header__slide--item .fade-img {
  width: 1px;
  height: 1px;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  margin: -1px;
  padding: 0;
  overflow: hidden;
  position: absolute;
}

.header__onbg {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

@media screen and (max-width: 768px) {
  .header__onbg {
    background-color: #009dbd;
  }
}

@media screen and (max-width: 768px) {
  .header__onbg:before {
    content: "";
    display: block;
    width: 100%;
    padding-top: 56.25%;
    position: absolute;
    bottom: 0;
    /* background: url("../img/common/nav/bg_img_2.jpg") no-repeat center center/contain; */
    -webkit-transform: scale(1.8);
    transform: scale(1.8);
    z-index: 1;
  }
}

.headerNavWrap {
  height: calc(100% - min(10vw, 150px));
}

@media screen and (max-width: 768px) {
  .headerNavWrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    z-index: 3;
  }
}

.headerNavWrap__in {
  padding: 0 min(5vw, 75px) 0 0;
  min-height: 100%;
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 769px) {
  .headerNavWrap__in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin: min(3.3333333333vw, 50px) auto;
  }
}

@media screen and (max-width: 768px) {
  .headerNavWrap__in {
    padding: max(3.2vw, 16px);
    padding-left: max(7.6vw, 38px);
  }
}

.headerNav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  margin-top: min(3.3333333333vw, 50px);
  gap: min(3.3333333333vw, 50px);
}

@media screen and (min-width: 769px) {
  .headerNav {
    width: min(16.6666666667vw, 250px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    height: calc(100vh - 150px);
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}

@media screen and (max-width: 768px) {
  .headerNav {
    display: block;
    width: 100%;
  }
}

.headerNav__wrapper {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

.headerNav__logo {
  opacity: 0;
  -webkit-transform: translateY(-20px);
  transform: translateY(-20px);
  -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (min-width: 769px) {
  .headerNav__logo {
    width: min(20.8333333333vw, 312.5px);
    z-index: 99;
  }
}

@media screen and (max-width: 768px) {
  .headerNav__logo {
    width: max(32vw, 160px);
    margin: max(4.2666666667vw, 21.3333333333px) auto;
    position: relative;
    z-index: 3;
  }
}

.is-active .headerNav__logo {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.is-close .headerNav__logo {
  opacity: 0;
  -webkit-transform: translateY(10px);
  transform: translateY(10px);
}

.headerNav__logo>a {
  display: block;
  width: 100%;
  max-width: 272px;
}

@media screen and (max-width: 768px) {
  .headerNav__logo>a {
    max-width: 100%;
  }
}

.headerNav__logo img {
  width: 100%;
}

/**
 * headerNavLists
 */
.headerNavLists {
  -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (min-width: 769px) {
  .headerNavLists {
    width: 66.6666666667%;
    display: grid;
    gap: min(2vw, 30px) 0;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}

@media screen and (max-width: 768px) {
  .headerNavLists {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: max(3.2vw, 16px) 0;
  }
}

.headerNavLists__item {
  opacity: 0;
  -webkit-transform: translateY(-20px);
  transform: translateY(-20px);
  -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.headerNavLists__item.is-ani {
  opacity: 1;
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
}

.headerNavLists__item.is-leave {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
}

.headerNavLists__link {
  color: #000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: min(1.3333333333vw, 20px);
}

@media screen and (max-width: 768px) {
  .headerNavLists__link {
    gap: max(1.0666666667vw, 5.3333333333px);
  }
}

.headerNavLists__link.is-current::before {
  color: #000;
}

@media screen and (min-width: 769px) {
  .headerNavLists__link:hover .headerNavLists__text::before {
    -webkit-transform: scaleX(100%);
    transform: scaleX(100%);
    -webkit-transform-origin: left;
    transform-origin: left;
  }
}

.headerNavLists__text {
  position: relative;
  font-size: min(3vw, 45px);
  line-height: 1;
  white-space: nowrap;
}

@media screen and (max-width: 768px) {
  .headerNavLists__text {
    font-size: max(7.2vw, 36px);
    text-shadow: 
    2px 2px 4px #FFF, 
    -2px -2px 4px #FFF, 
    2px -2px 4px #FFF, 
    -2px 2px 4px #FFF;
  }
  .is-current .headerNavLists__text {
    text-shadow: none  
  }
}

.headerNavLists__text:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  background: -webkit-gradient(linear, left bottom, left top, color-stop(0, #009dbd), color-stop(30%, rgba(255, 255, 255, 0)));
  background: linear-gradient(0deg, #009dbd 0 50%, rgba(255, 255, 255, 0) 30%);
  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  -webkit-transform: scaleX(0%);
  transform: scaleX(0%);
  -webkit-transform-origin: right;
  transform-origin: right;
}

.is-current .headerNavLists__text::before {
  -webkit-transform: scaleX(100%);
  transform: scaleX(100%);
  -webkit-transform-origin: left;
  transform-origin: left;
}

/**
 * navBtn
 */
.header__navBtnWrap {
  width: min(8.33333vw, 100px);
  pointer-events: auto;
}

@media screen and (max-width: 768px) {
  .header__navBtnWrap {
    width: max(12.8vw, 64px);
    height: max(12.8vw, 64px);
    margin: max(3.2vw, 16px);
    -webkit-transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1);
    transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1);
    pointer-events: auto;
  }
}

@media screen and (max-width: 768px) {
  #top .header__navBtnWrap {
    opacity: 0;
  }
}

@media screen and (max-width: 768px) {
  #top .is-show .header__navBtnWrap {
    opacity: 1;
  }
  #top .is-active .header__navBtnWrap {
    opacity: 1;
  }
}

.headerShare {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .headerShare {
    margin-top: max(8vw, 32px);
    filter: drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff);
  }
}

.is-active .headerShare {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.is-close .headerShare {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
}

@-webkit-keyframes zoom {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  100% {
    -webkit-transform: scale(1.03);
    transform: scale(1.03);
  }
}

@keyframes zoom {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  100% {
    -webkit-transform: scale(1.03);
    transform: scale(1.03);
  }
}


/*-----------------------------------------------
* footer
-------------------------------------------------*/
.footer__fixbg {
  background: url(../img/common/bg_pagebottom.png) no-repeat bottom right;
  background-size: 100%;
  display: block;
  width: 100%;
  padding-top: max(7.8vw);
}

@media screen and (max-width: 1920px) {
  .footer__fixbg{
  }
}

.footer {
  overflow: hidden;
  position: relative;
  background: #FFF;
}

@media screen and (max-width: 768px) {
  .footer {
    /* padding-top: max(21.3333333333vw, 106.6666666667px); */
  }
}

.footer__in {
  /* padding-bottom: min(6.6666666667vw, 100px); */
}

.footer__bnr--list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (min-width: 769px) {
  .footer__bnr--list {
    width: min(80.4166666667vw, 1206.25px);
    margin: max(6.25vw, 93.75px) auto max(6.25vw, 93.75px) auto;
  }
}

@media screen and (max-width: 768px) {
  .footer__bnr--list {
    width: 100%;
    padding: 0 min(6vw, 90px);
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: max(6.4vw, 32px);
    margin: max(12.8vw, 64px) auto;
  }
}

.footer__bnr--item {
  width: 35%;
}

@media screen and (max-width: 768px) {
  .footer__bnr--item {
    width: calc(45% - max(6.4vw, 32px));
  }
}

.footer__bnr--item img {
  margin: 0 auto;
}

@media screen and (min-width: 769px) {
  .footer__bnr--item.bnr-1 img {
    max-width: 190px;
  }
}

@media screen and (min-width: 769px) {
  .footer__bnr--item.bnr-2 img {
    max-width: 172px;
  }
}

@media screen and (min-width: 769px) {
  .footer__bnr--item.bnr-3 img {
    max-width: 144px;
  }
}

@media screen and (min-width: 769px) {
  .footer__bnr--item.bnr-4 img {
    max-width: 64px;
  }
}

@media screen and (max-width: 768px) {
  .footer__bnr--item.bnr-4 img {
    max-width: 48px;
  }
}

.footer__bnr--bottom {
  margin: min(6.6666666667vw, 100px) auto 0;
}

@media screen and (max-width: 768px) {
  .footer__bnr--bottom {
    margin: max(12.8vw, 64px) auto;
  }
}

.footer__bnr--bottom img {
  margin: 0 auto;
}

@media screen and (min-width: 769px) {
  .footer__bnr--bottom img {
    max-width: 168px;
  }
}

@media screen and (max-width: 768px) {
  .footer__bnr--bottom img {
    max-width: 126px;
  }
}

.footer__caution {
  background-color: #000;
  padding: 45px min(3.3333333333vw, 50px);
}

.footer__caution--text,.footer__caution--text a {
  color: #FFF;
  text-align: center;
  font-size: 12px;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .footer__caution--text {
    font-size: max(2.6666666667vw, 13.3333333333px);
    line-height: 2;
  }
}

.footer__caution--bottom {
  position: relative;
  margin-top: 32px;
}

@media screen and (max-width: 768px) {
  .footer__caution--bottom {
    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;
  }
}

.footer__caution--copy {
  color: #aaa;
}

@media screen and (min-width: 769px) {
  .footer__caution--copy {
    margin-right: auto;
    font-size: 12px;
  }
}

@media screen and (max-width: 768px) {
  .footer__caution--copy {
    font-size: max(2.6666666667vw, 13.3333333333px);
    text-align: center;
  }
}

.footer__caution--link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}

@media screen and (min-width: 769px) {
  .footer__caution--link {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}

@media screen and (max-width: 768px) {
  .footer__caution--link {
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-bottom: max(6.6666666667vw, 33.3333333333px);
  }
}

.footer__caution--link>li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.footer__caution--link>li a {
  font-size: 12px;
  line-height: 1.5;
  color: #009dbd;
  -webkit-transition: -webkit-text-decoration 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-text-decoration 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: text-decoration 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: text-decoration 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-text-decoration 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .footer__caution--link>li a {
    font-size: max(2.6666666667vw, 13.3333333333px);
    line-height: 2;
  }
}

.footer__caution--link>li a:hover {
  text-decoration: underline;
}

.footer__caution--link>li:not(:first-child) {
  gap: 16px;
}

.footer__caution--link>li:not(:first-child)::before {
  content: "";
  display: block;
  width: 1px;
  height: 12px;
  background-color: #fff;
  margin-top: 2px;
}


/*-----------------------------------------------
* pagetop
-------------------------------------------------*/
.pagetop {
  position: fixed;
  bottom: min(1.6666666667vw, 25px);
  right: min(5.8333333333vw, 87.5px);
  -webkit-transform: translateY(calc(100% + min(1.6666666667vw, 25px)));
  transform: translateY(calc(100% + min(1.6666666667vw, 25px)));
  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  z-index: 2;
  mix-blend-mode: difference;
}

@media screen and (max-width: 768px) {
  .pagetop {
    bottom: max(2.6666666667vw, 13.3333333333px);
    right: max(2.6666666667vw, 13.3333333333px);
    -webkit-transform: translateY(calc(100% + 16px));
    transform: translateY(calc(100% + 16px));
  }
}

.pagetop.-active {
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
}

.pagetop>a {
  color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  text-decoration: none;
  gap: min(0.8333333333vw, 12.5px);
}

.pagetop>a::before {
  content: "";
  background-color: #FFF;
  display: block;
  -webkit-mask: url(../img/common/icon/icon_pagetop.svg) no-repeat 0 0/100%;
  mask: url(../img/common/icon/icon_pagetop.svg) no-repeat 0 0/100%;
  width: min(5vw, 75px);
  height: min(1.6666666667vw, 25px);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

@media screen and (max-width: 768px) {
  .pagetop>a::before {
    width: max(12.8vw, 64px);
    height: max(6.4vw, 32px);
  }
}

.pagetop>a:hover::before {
  -webkit-transform: translateY(-20%);
  transform: translateY(-20%);
}

.pagetop__text {
  font-size: 14px;
  margin-top: 6px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .pagetop__text {
    font-size: max(2.6666666667vw, 13.3333333333px);
  }
}


/*-----------------------------------------------
* modal
-------------------------------------------------*/
/**
 * modalBox
 * 基盤のモーダル
 */
.modalBox {
  -webkit-overflow-scrolling: touch;
  display: none;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
}

.modalBox::before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.75);
}

.oneModal {
  display: none;
  width: 100%;
  height: 100%;
  position: relative;
}

/* oneModalIn */
.oneModalIn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: auto;
  width: 100%;
  min-height: 100%;
  margin: 0 auto;
  position: relative;
}

@media screen and (max-width: 768px) {
  .oneModalIn {
    min-width: 100%;
  }
}

.oneModalIn__cont {
  padding: 50px 0;
}

@media screen and (max-width: 768px) {
  .oneModalIn__cont {
    padding: 30px 0;
  }
}

/* closeBtn */
.closeBtn {
  display: block;
  width: 90px;
  height: 120px;
  pointer-events: auto;
  position: fixed;
  top: 0;
  right: 0;
  -webkit-transition: background 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  z-index: 99;
}

@media screen and (max-width: 768px) {
  .closeBtn {
    width: max(12.8vw, 64px);
    height: 75px;
    position: fixed;
    right: 0;
  }
}

@media screen and (min-width: 769px) {

  .closeBtn:hover::before,
  .closeBtn:hover::after {
    background: #009dbd;
  }
}

.closeBtn>a {
  display: block;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  color: #fff;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .closeBtn>a {
    font-size: max(2.6666666667vw, 13.3333333333px);
  }
}

@media screen and (min-width: 769px) {
  .closeBtn>a:hover {
    color: #009dbd;
  }
}

.closeBtn::before,
.closeBtn::after {
  content: "";
  position: absolute;
  top: calc(50% - 16px);
  left: 50%;
  width: 1px;
  height: 100%;
  background: #FFF;
  -webkit-transition: background 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {

  .closeBtn::before,
  .closeBtn::after {
    width: 1px;
    height: 100%;
    top: calc(50% - 10px);
  }
}

.closeBtn::before {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
  transform: translate(-50%, -50%) rotate(45deg);
}

.closeBtn::after {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg);
}

.closeBtn__txt {
  text-align: center;
  font-family: "futura-pt", sans-serif;
}

.closeBtn.hd {
  opacity: 0;
}

/**
* iframe
*/
/* common */
.commonIframe {
  width: 100%;
  height: 100%;
  display: block;
}

/* youtube */
.youtubeIframeWrap {
  width: 70%;
  max-width: 159.993vh;
  position: relative;
}

@media screen and (max-width: 768px) {
  .youtubeIframeWrap {
    width: 100%;
    max-width: 100%;
  }
}

.youtubeIframeWrap::before {
  content: "";
  display: block;
  padding-top: 56.25%;
  z-index: 0;
}

.youtubeIframeWrap>.youtubeIframe,.youtubeIframeWrap>.bilibiliIframe {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

/* img */
.imgModalScaleWrap {
  width: 90%;
  margin: 2% auto auto;
  max-width: 159.993vh;
  position: relative;
  text-align: center;
}
.imgModalScaleWrap img{
  display: inline-block;
}
@media screen and (max-width: 1000px) {
  .imgModalScaleWrap {
    margin-top: 10%;
  }
}
@media screen and (max-width: 768px) {
  .imgModalScaleWrap {
    margin-top: 20%;
  }
}
#imgModal.oneModal .oneModalIn{
  min-height:unset;
}

/*-----------------------------------------------
* icon
-------------------------------------------------*/
a .icon-arrow::before {
  width: 16px;
  height: 6px;
  content: "";
  display: inline-block;
  -webkit-mask-image: url("../img/common/icon/icon_arrow.svg");
  mask-image: url("../img/common/icon/icon_arrow.svg");
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: #FFF;
  background-color: #FFF;
  -webkit-transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

a:hover .icon-arrow::before {
  background-color: #000;
}

a .icon-blank::before {
  width: 16px;
  height: 12px;
  content: "";
  display: inline-block;
  -webkit-mask-image: url("../img/common/icon/icon_blank.svg");
  mask-image: url("../img/common/icon/icon_blank.svg");
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: #FFF;
  background-color: #FFF;
  -webkit-transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}


/*-----------------------------------------------
* utility
-------------------------------------------------*/
.u-color-blue {
  color: #009dbd;
}

.u-font-futura {
  font-family: "futura-pt", sans-serif;
}

.u-ytWrap {
  position: relative;
  max-width: 1080px;
  margin: auto;
}

.u-ytWrap::before {
  content: "";
  display: block;
  padding-top: 56.25%;
}

.u-ytWrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .u-ytWrap iframe {
    padding: 0;
  }
}

.u-bg-white {
  background-color: #FFF;
}

.u-indentfront {
  text-indent: 1em;
  padding-left: 1em;
}

.u-indentback {
  text-indent: -1em;
  padding-left: 2em;
}

.u-text-right{
  text-align: right;
}

.u-text-underline{
  text-decoration: underline;
}


/**
 * movie
 */
.movie {
  position: relative;  
  overflow: hidden;
}

@media screen and (min-width: 769px) {
  .movie {
    /* padding-top: min(8.3333333333vw, 125px); */
  }
}

@media screen and (max-width: 768px) {
  .movie {
    overflow: hidden;
    /* margin-top: max(6.4vw, 32px); */
    opacity: 0;
    -webkit-transition: all 0.3s cubic-bezier(0.5, 1, 0.89, 1);
    transition: all 0.3s cubic-bezier(0.5, 1, 0.89, 1);
    -webkit-transform: translateY(-20px);
    transform: translateY(-20px);
    -webkit-transition-delay: 0.25s;
    transition-delay: 0.25s;
  }
  .movie.-inview {
    opacity: 1;
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }
}

.movie__titleWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: min(3.3333333333vw, 50px);
  position: absolute;
  z-index: 2;
  top: min(-0.33333333333333337vw, -5px);
  margin-left: min(-0.33333333333333337vw, -5px);
}

@media screen and (min-width: 769px) {
  .movie__titleWrap {
    left: min(-1vw, -15px);
  }
}

@media screen and (max-width: 768px) {
  .movie__titleWrap {
    top: min(-0.13333333333333333vw, -2px);
  }
}

.movie__title>span {
  display: block;
  font-size: min(15vw, 225px);
  font-weight: 300;
  text-transform: uppercase;
  line-height: 1;
  color: #FFF;
}

.movie__title>span::before,
.movie__title>span::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}

.movie__title>span::before {
  margin-top: calc((1 - 1.3) * 0.5em);
}

.movie__title>span::after {
  margin-bottom: calc((1 - 1.3) * 0.5em);
}

@media screen and (max-width: 768px) {
  .movie__title>span {
    font-size: max(16vw, 80px);
  }
}

.movie__title--sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(1.25vw, 18.75px);
}

@media screen and (max-width: 768px) {
  .movie__title--sub {
    gap: max(3.0666666667vw, 15.3333333333px);
  }
}

.movie__title--sub>span {
  font-size: min(1vw, 15px);
  line-height: 1.333;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .movie__title--sub>span {
    font-size: max(2.4vw, 12px);
    font-size: 10px;
    -webkit-transform: translateX(-12%) translateY(-12%) scale(0.8);
    transform: translateX(-12%) translateY(-12%) scale(0.8);
    white-space: nowrap;
  }
}

.movie__title--sub::before {
  content: "";
  display: block;
  width: 1px;
  min-height: 40px;
  background-color: #FFF;
}

@media screen and (max-width: 768px) {
  .movie__title--sub::before {
    height: 32px;
    min-height: auto;
  }
}

.movie__inner {
  padding-top: 53.333%;
  overflow: hidden;
  position: relative;
  z-index: 1;
  background: #000;
}

@media screen and (max-width: 768px) {
  .movie__inner {
    padding-top: 85.333%;
  }
}

.movie__inner::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 53.333%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 157, 189, 0.4);
}

@media screen and (max-width: 768px) {
  .movie__inner::before {
    padding-top: 85.333%;
  }
}

.movie__bg {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: -1;
}

.movie__bg>iframe {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1;
  -webkit-transform: translate(-50%, 0%) scale(1.75);
  transform: translate(-50%, 0%) scale(1.75);
  -webkit-transform-origin: center;
  transform-origin: center;
}

@media screen and (max-width: 768px) {
  .movie__bg>iframe {
    -webkit-transform: translate(-50%, 0%) scale(1.5);
    transform: translate(-50%, 0%) scale(1.5);
  }
}

.movie__desc {
  width: calc(100% - min(13.3333333333vw, 200px));
  position: absolute;
  left: min(6.6666666667vw, 100px);
  bottom: min(6.6666666667vw, 100px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  z-index: 10;
}

@media screen and (max-width: 768px) {
  .movie__desc {
    width: calc(100% - max(10.6666666667vw, 53.3333333333px));
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    left: max(5.3333333333vw, 26.6666666667px);
    bottom: max(5.3333333333vw, 26.6666666667px);
  }
}

.movie__desc>h3 {
  font-size: min(4vw, 60px);
  color: #FFF;
  line-height: 0.7;
}

@media screen and (max-width: 768px) {
  .movie__desc>h3 {
    font-size: max(8.5333333333vw, 42.6666666667px);
    line-height: 1;
    font-weight: 500;
  }
}

.movie__play {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 9;
}

.movie__play--link {
  display: block;
  height: 100%;
}

.movie__play--link span {
  color: #fff;
  font-size: min(1.3333333333vw, 20px);
}

@media screen and (max-width: 768px) {
  .movie__play--link span {
    font-size: max(3.2vw, 16px);
  }
}

.movie__play--link:hover .icon-arrow-large {
  -webkit-transform: translateX(10px);
  transform: translateX(10px);
}

.movie__play--link .icon-arrow-large {
  position: relative;
  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.movie__play--link .icon-arrow-large::after {
  content: "";
  display: block;
  width: min(10vw, 150px);
  padding-top: 53.333%;
  -webkit-mask-image: url("../img/common/icon/icon_arrow_large.svg");
  mask-image: url("../img/common/icon/icon_arrow_large.svg");
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: #FFF;
  background-color: #FFF;
}

@media screen and (max-width: 768px) {
  .movie__play--link .icon-arrow-large::after {
    width: max(30vw, 150px);
  }
}

.movie__play--btn {
  width: min(13.3333333333vw, 200px);
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .movie__play--btn {
    width: max(30vw, 150px);
  }
}

.movie__link>a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  padding: 10px min(1.3333333333vw, 20px);
  margin: 0 auto;
  border: 1px solid #FFF;
  background-color: #000;
  font-size: min(1.3333333333vw, 20px);
  color: #fff;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1), background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1), background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .movie__link>a {
    font-size: max(3.2vw, 16px);
    padding: 8px max(3.2vw, 16px);
  }
}

.movie__link>a:hover {
  color: #000;
  background-color: #FFF;
}

.movie__link>a:hover .icon-arrow {
  -webkit-animation: arrow 0.5s;
  animation: arrow 0.5s;
}

.movie__link>a>span {
  line-height: 1;
}

.movie__triangle--item {
  width: min(50vw, 750px);
  height: min(50vw, 750px);
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
  clip-path: polygon(0 0, 100% 100%, 100% 0);
  position: absolute;
  mix-blend-mode: multiply;
  z-index: 8;
}

.movie__triangle--item.-right {
  bottom: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.6);
  -webkit-transform: translateX(100%) scale(1, -1);
  transform: translateX(100%) scale(1, -1);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-transform 0.4s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.4s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.4s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.4s cubic-bezier(0.5, 1, 0.89, 1);
}

.-inview .movie__triangle--item.-right {
  -webkit-transform: translateX(0%) scale(1, -1);
  transform: translateX(0%) scale(1, -1);
}

.movie__triangle--item.-left {
  top: 0;
  left: 0;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
  background-color: rgba(0, 0, 0, 0.6);
  background-color: rgba(0, 0, 0, 0.6);
  -webkit-transform: translateX(-100%) scale(-1, 1);
  transform: translateX(-100%) scale(-1, 1);
  -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: transform 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
}

.-inview .movie__triangle--item.-left {
  -webkit-transform: translateX(0%) scale(-1, 1);
  transform: translateX(0%) scale(-1, 1);
}

/**
 * update
 */
.update {
  position: relative;
  padding-top: min(6.6666666667vw, 100px);
  /* padding-bottom: min(13.3333333333vw, 200px); */
}

@media screen and (max-width: 768px) {
  .update {
    padding-top: max(13.3333333333vw, 66.6666666667px);
    padding-bottom: max(13.3333333333vw, 66.6666666667px);
    overflow: hidden;
  }
}

.update__titleWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  mix-blend-mode: multiply;
}

@media screen and (min-width: 769px) {
  .update__titleWrap {
    gap: min(3.3333333333vw, 50px);
    left: min(-6.6666666667vw, -100px);
    margin-left: min(3.3333333333vw, 50px);
  }
}

@media screen and (max-width: 1023px) {
  .update__titleWrap {
    left: max(-3.2vw, -16px);
    gap: max(5.3333333333vw, 26.6666666667px);
  }
}

.update__title>span {
  display: block;
  font-size: min(15vw, 225px);
  font-weight: 300;
  text-transform: uppercase;
  line-height: 1;
}

.update__title>span::before,
.update__title>span::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}

.update__title>span::before {
  margin-top: calc((1 - 1.3) * 0.5em);
}

.update__title>span::after {
  margin-bottom: calc((1 - 1.3) * 0.5em);
}

@media screen and (max-width: 768px) {
  .update__title>span {
    font-size: max(16vw, 80px);
  }
}

.update__title--sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(1.25vw, 18.75px);
}

@media screen and (max-width: 768px) {
  .update__title--sub {
    gap: max(3.0666666667vw, 15.3333333333px);
  }
}

.update__title--sub>span {
  font-size: min(1vw, 15px);
  line-height: 1.333;
  color: #000;
}

@media screen and (max-width: 768px) {
  .update__title--sub>span {
    font-size: max(2.4vw, 12px);
    font-size: 10px;
    -webkit-transform: translateX(-12%) translateY(-12%) scale(0.8);
    transform: translateX(-12%) translateY(-12%) scale(0.8);
    white-space: nowrap;
  }
}

.update__title--sub::before {
  content: "";
  display: block;
  width: 1px;
  min-height: 40px;
  background-color: #000;
}

@media screen and (max-width: 768px) {
  .update__title--sub::before {
    height: 50px;
    min-height: auto;
  }
}

.update__subtitle {
  margin-top: min(3.3333333333vw, 50px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .update__subtitle {
    margin-top: max(6.6666666667vw, 33.3333333333px);
  }
}

.update__subtitle--heading>span {
  text-transform: uppercase;
}

@media screen and (min-width: 769px) {
  .update__subtitle--heading>span {
    font-size: min(4vw, 60px);
  }

  .update__subtitle--heading>span::before,
  .update__subtitle--heading>span::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }

  .update__subtitle--heading>span::before {
    margin-top: calc((1 - 0.3) * 0.5em);
  }

  .update__subtitle--heading>span::after {
    margin-bottom: calc((1 - 0.3) * 0.5em);
  }
}

@media screen and (max-width: 768px) {
  .update__subtitle--heading>span {
    font-size: max(9.6vw, 48px);
  }
}

.update__subtitle--link>a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  padding: 10px min(1.3333333333vw, 20px);
  margin: 0 auto;
  border: 1px solid #000;
  background-color: #000;
  font-size: min(1.3333333333vw, 20px);
  color: #fff;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1), background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1), background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .update__subtitle--link>a {
    padding: max(2vw, 10px) max(3.2vw, 16px);
  }
}

.update__subtitle--link>a:hover {
  color: #000;
  background-color: #FFF;
}

.update__subtitle--link>a:hover .icon-arrow {
  -webkit-animation: arrow 0.5s;
  animation: arrow 0.5s;
}

@media screen and (max-width: 768px) {
  .update__subtitle--link>a span {
    font-size: max(3.2vw, 16px);
  }
}

.update__subtitle--link>span {
  line-height: 1;
}

.update__contents {
  margin-top: min(6.3333333333vw, 95px);
  width: 100%;
  /* display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; */
}

@media screen and (max-width: 768px) {
  .update__contents {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: max(12.8vw, 64px);
    margin-top: max(12.8vw, 64px);
  }
}

.update__box {
  /* width: calc(50% - min(3.3333333333vw, 50px));
  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; */
}

@media screen and (max-width: 768px) {
  .update__box {
    width: 100%;
  }
}

.update__news--list {
  /* min-height: 520px; */
}

.update__news--item {
  border-top: 1px solid #ccc;
  background-color: rgba(255, 255, 255, 0.7);
}

.update__news--item:last-child {
  border-bottom: 1px solid #ccc;
}

.update__news--link {
  padding: min(2vw, 30px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px 0;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: relative;
}

@media screen and (max-width: 768px) {
  .update__news--list {
    min-height: unset;
  }  
  .update__news--link {
    gap: max(2.1333333333vw, 10.6666666667px);
    padding: max(4vw, 20px);
  }
}

.update__news--link::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  height: 1px;
  background-color: #009dbd;
  width: 0;
  -webkit-transition-duration: 0.25s;
  transition-duration: 0.25s;
  -webkit-transition-property: width;
  transition-property: width;
  right: 0;
  z-index: 1;
}

.update__news--link:hover::before {
  width: 100%;
  left: 0;
  right: auto;
}

.update__news--link:hover .update__news--title {
  color: #009dbd;
}

.update__news--link:hover .update__news--arrow::before {
  -webkit-animation: arrow 0.4s;
  animation: arrow 0.4s;
  -webkit-animation-delay: 0.05s;
  animation-delay: 0.05s;
  background-color: #009dbd !important;
}

.update__news--title {
  color: #000;
  line-height: 2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-transition: color 0.25s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.25s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .update__news--title {
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
}

.update__news--date {
  color: #009dbd;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 768px) {
  .update__news--date {
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
}

.update__news--arrow::before {
  width: 16px;
  height: 8px;
  background-color: #000 !important;
}

.update__twi {
  position: relative;
}

.update__twi--inner {
  width: 100%;
  overflow-y: scroll;
}

@media screen and (min-width: 769px) {
  .update__twi--inner {
    height: calc(100% - min(11.25vw, 168.75px));
    position: absolute;
    top: 0;
  }
}

@media screen and (max-width: 768px) {
  .update__twi--inner {
    width: 100%;
    margin: 0 auto;
    height: 240px;
    overflow-y: scroll;
    background-color: #fff;
    border: 1px solid #eee;
  }
}

/*-----------------------------------------------
* keyframes
-------------------------------------------------*/
@-webkit-keyframes arrow {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }

  40% {
    opacity: 0;
  }

  49.9% {
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
    opacity: 0;
  }

  50% {
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes arrow {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }

  40% {
    opacity: 0;
  }

  49.9% {
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
    opacity: 0;
  }

  50% {
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
}

/*-----------------------------------------------
* fadein
-------------------------------------------------*/
.ani-fade {
  -webkit-transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  opacity: 0;
}

.ani-fade.-inview {
  opacity: 1;
}

.ani-fadeup {
  -webkit-transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  opacity: 0;
}

.-inview .ani-fadeup {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.-inview.ani-fadeup {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.ani-fadedown {
  -webkit-transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  -webkit-transform: translateY(-40px);
  transform: translateY(-40px);
  opacity: 0;
}

.ani-fadedown.-inview,
.-inview .ani-fadedown {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.ani-fadedown.ani-delay-all {
  -webkit-transition-delay: 0.7s;
  transition-delay: 0.7s;
}

.ani-faderight {
  -webkit-transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  opacity: 0;
}

@media screen and (min-width: 769px) {
  .ani-faderight {
    -webkit-transform: translateX(40px);
    transform: translateX(40px);
  }
}

@media screen and (max-width: 768px) {
  .ani-faderight {
      -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
      transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
      transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1);
      transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1), transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
    -webkit-transform: translateY(10px);
    transform: translateY(10px);
  }
}

.ani-faderight.-inview {
  opacity: 1;
}

@media screen and (min-width: 769px) {
  .ani-faderight.-inview {
    -webkit-transform: translateX(0px);
    transform: translateX(0px);
  }
}

@media screen and (max-width: 768px) {
  .ani-faderight.-inview {
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }
}

.ani-faderight.-inview.ani-delay:nth-child(1) {
  -webkit-transition-delay: 0.05s;
  transition-delay: 0.05s;
}

.ani-faderight.-inview.ani-delay:nth-child(2) {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.ani-faderight.-inview.ani-delay:nth-child(3) {
  -webkit-transition-delay: 0.15s;
  transition-delay: 0.15s;
}

.ani-faderight.-inview.ani-delay:nth-child(4) {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.ani-faderight.-inview.ani-delay:nth-child(5) {
  -webkit-transition-delay: 0.25s;
  transition-delay: 0.25s;
}

.ani-faderight.-inview.ani-delay:nth-child(6) {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.ani-faderight.-inview.ani-delay:nth-child(7) {
  -webkit-transition-delay: 0.35s;
  transition-delay: 0.35s;
}

.ani-faderight.-inview.ani-delay:nth-child(8) {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

.ani-faderight.-inview.ani-delay:nth-child(9) {
  -webkit-transition-delay: 0.45s;
  transition-delay: 0.45s;
}

.ani-faderight.-inview.ani-delay:nth-child(10) {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}

.ani-fadeleft {
  -webkit-transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.6s cubic-bezier(0.5, 1, 0.89, 1), transform 0.6s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  -webkit-transform: translateX(-40px);
  transform: translateX(-40px);
  opacity: 0;
}

.-inview .ani-fadeleft,
.ani-fadeleft.-inview {
  opacity: 1;
  -webkit-transform: translateX(0px);
  transform: translateX(0px);
}

.-inview .ani-fadeleft.ani-delay:nth-child(1),
.ani-fadeleft.-inview.ani-delay:nth-child(1) {
  -webkit-transition-delay: 0.05s;
  transition-delay: 0.05s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(2),
.ani-fadeleft.-inview.ani-delay:nth-child(2) {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(3),
.ani-fadeleft.-inview.ani-delay:nth-child(3) {
  -webkit-transition-delay: 0.15s;
  transition-delay: 0.15s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(4),
.ani-fadeleft.-inview.ani-delay:nth-child(4) {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(5),
.ani-fadeleft.-inview.ani-delay:nth-child(5) {
  -webkit-transition-delay: 0.25s;
  transition-delay: 0.25s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(6),
.ani-fadeleft.-inview.ani-delay:nth-child(6) {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(7),
.ani-fadeleft.-inview.ani-delay:nth-child(7) {
  -webkit-transition-delay: 0.35s;
  transition-delay: 0.35s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(8),
.ani-fadeleft.-inview.ani-delay:nth-child(8) {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(9),
.ani-fadeleft.-inview.ani-delay:nth-child(9) {
  -webkit-transition-delay: 0.45s;
  transition-delay: 0.45s;
}

.-inview .ani-fadeleft.ani-delay:nth-child(10),
.ani-fadeleft.-inview.ani-delay:nth-child(10) {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}

/*-----------------------------------------------
* loading
-------------------------------------------------*/
.loading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
}

@media screen and (max-width: 767px) {
  .loading {
    background-attachment: inherit;
  }
}

/* logo */
.loading__logo {
  width: 30vw;
  max-width: 400px;
}

.loading__logo img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .loading__logo {
    width: 60vw;
    max-width: 100%;
  }
}

/* animation */
.loading__logo {
  -webkit-filter: blur(0);
  -moz-filter: blur(0);
  filter: blur(0);
  opacity: 1;
  -webkit-transition: all 0.8s ease-in-out;
  transition: all 0.8s ease-in-out;
}

.loading.is-load .loading__logo {
  -webkit-filter: blur(15px);
  -moz-filter: blur(15px);
  filter: blur(15px);
  opacity: 0;
}

/* ===============================================
# sub
=============================================== */
#sub #fullWrap{
  background: url(../img/common/bg_head.png) no-repeat 0 0;
  background-size: contain;
}
@media screen and (min-width: 1400px) {
  #sub{
    background: url(../img/common/bg_head_re.png) repeat-x 0 0;
  }
  #sub #fullWrap{
    background-size: unset;
  }
}
@media screen and (max-width: 768px) {
  #sub{
    background: none;
  }
  #sub #fullWrap{
    background: url(../img/common/bg_header_sp.png) no-repeat 0 0;
    background-size: contain;
  }
}
/* .sub__in {
  width: calc(100% - min(6.6666666667vw, 100px));
  padding-left: min(3.3333333333vw, 50px);
  max-width: 1400px;
} */

/* @media screen and (min-width: 1400px) {
  .sub__in {
    margin: 0 auto;
    padding-left: 0;
  }
} */

.sub__container {
  /* margin-top: min(13.3333333333vw, 200px); */
}

@media screen and (max-width: 768px) {
  .sub__container {
    /* margin: max(26.1333333333vw, 130.6666666667px) 0 max(12.8vw, 64px); */
  }
}

.sub__headline--inner {
  text-align: right;
}
@media screen and (max-width: 768px) {
  .sub__headline--inner {
    text-align: left;
  }
}
.sub__headline--main{
  width: 100%;
  padding-top: min(1.2vw, 18px);
  padding-right: min(8vw, 120px);
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .sub__headline--main {
    padding-top: min(20vw, 300px);
    padding-left: min(4vw, 20px);
    padding-right: 0;
  }
}

.sub__headline--main>span {
  display: block;
  font-size: min(10vw, 150px);
  font-weight: 300;
  text-transform: uppercase;
  color: #fff;
}

@media screen and (min-width: 769px) {
  .sub__headline--main>span {
    line-height: 1;
  }
}

@media screen and (max-width: 768px) {
  .sub__headline--main>span {
    font-size: max(12vw, 60px);
    line-height: 0.667;
  }
}

@media screen and (max-width: 768px) {
  #theater .sub__headline--main>span {
    font-size: max(13.3333333333vw, 66.6666666667px);
  }
}

.sub__headline--sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(1.25vw, 18.75px);
}

@media screen and (max-width: 768px) {
  .sub__headline--sub {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: max(3.2vw, 16px);
    white-space: nowrap;
  }
}

.sub__headline--sub>span {
  text-transform: uppercase;
  font-size: min(1vw, 15px);
  line-height: 1.333;
  color: #000;
}

@media screen and (max-width: 768px) {
  .sub__headline--sub>span {
    font-size: 10px;
    -webkit-transform: translateX(-12%) translateY(-12%) scale(0.8);
    transform: translateX(-12%) translateY(-12%) scale(0.8);
  }
}

.sub__headline--sub::before {
  content: "";
  display: block;
  width: 1px;
  min-height: 40px;
  background-color: #000;
}

.sub__tab {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 99;
  border: 1px solid #000;
  background: #fff;
  /* margin-left: min(-0.8333333333vw, -12.5px);
  margin-right: -1%; */
  /* margin-left: min(-2.6666666667vw, -40px);
  margin-right: min(-2.6666666667vw, -40px); */
  margin: 0 0 2em 0;
}

/* .sub__tab::before {
  content: "";
  display: inline-block;
  height: 1px;
  width: calc(100% - min(1.5833333333vw, 23.75px));
  background-color: #000;
  position: absolute;
  bottom: 0;
} */

@media screen and (max-width: 768px) {
  /* .sub__tab {
    margin-left: max(-4.2666666667vw, -21.3333333333px);
    margin-right: max(-4.2666666667vw, -21.3333333333px);
  } */
}

.sub__tab--item {
  width: 50%;
  position: relative;
}

/* .sub__tab--item:not(:last-child) {
  margin-left: 1px;
} */

.sub__tab--item:last-child {
  width: calc(50% - min(0.9166666667vw, 13.75px));
}

/* .sub__tab--item::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-right: 1px solid #000;
  background: #fff;
  -webkit-transform: skew(-25deg);
  transform: skew(-25deg);
  z-index: -1;
  -webkit-transition: all 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: all 0.3s cubic-bezier(0.5, 1, 0.89, 1);
} */

.sub__tab--item>button {
  width: 100%;
  display: block;
  margin: 0 auto;
  -webkit-transition: all 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: all 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.sub__tab--item>button span {
  display: block;
  padding: min(0.8333333333vw, 12.5px) 0;
  color: #000;
  font-size: min(1.6666666667vw, 25px);
  line-height: 1;
  text-transform: uppercase;
  text-align: center;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .sub__tab--item>button span {
    padding: max(3.2vw, 16px) 0;
    font-size: max(3.7333333333vw, 15.5666666667px);
  }
}

@media screen and (min-width: 769px) {
  .sub__tab--item>button:hover span {
    color: #009dbd;
  }
}

.sub__tab--item.is-active {
  pointer-events: none;
  background: #000;
}

.sub__tab--item.is-active::before {
  background: #000;
}

.sub__tab--item.is-active>button>span {
  color: #FFF;
}

.sub__contents {
  width: calc(100% - min(6.6666666667vw, 100px));
  margin-top: min(13.333333333333334vw, 200px);
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 768px) {
  .sub__contents {
    width: 100%;
    margin-top: max(15vw, 75px);
  }
}
@media screen and (min-width: 769px) {
  .sub__contents {
    max-width: 1500px;
  }
}
.sub__heading {
  /* width: calc(100% - min(6.6666666667vw, 100px)); */
  background-color: #000;
  position: relative;
  opacity: 0;
  margin: auto;
  -webkit-transition: all 0.6s cubic-bezier(0.5, 1, 0.89, 1);
  transition: all 0.6s cubic-bezier(0.5, 1, 0.89, 1);
}

.sub__heading.-inview {
  opacity: 1;
}

.sub__heading--main>span {
  display: block;
  font-size: min(5vw, 75px);
  font-weight: 300;
  text-transform: uppercase;
  color: #FFF;
  text-align: center;
  line-height: 1;
  padding:0.1em;
}
.sub__heading--main>span.asiafont{
  padding:0.1em 0 0 0;
}

@media screen and (max-width: 768px) {
  .sub__heading--main>span {
    line-height: 1;
    padding:0.1em 0 0 0;
    /* font-size: max(9.6vw, 48px); */
    font-size: max(7.000000000000001vw, 35px);
  }
}


/* commentModal */
.commentModalCont{
  display: flex;
  flex-direction: column;
  max-width: 1000px;
  background-color: #FFF;
  padding: 80px;
}

.commentModalCont__in{
  display: flex;
  gap: 40px;
}

.commentModalCont__img{
  width: 35%;
}

.commentModalCont__texts{
  width: 65%;
}

.commentModalCont__name{
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid #000;
}

.commentModalCont__name>p{
  position: relative;
  font-size: 3.2rem;
  letter-spacing: 0.28rem;
}

.commentModalCont__name>p span{
  display: block;
  color: #009dbd;
  font-size: 16px;
}

.commentModal__text+.commentModal__text{
  margin-top: 24px;
}

.commentModal__text{
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .oneModalIn__cont{
    padding: 0;
  }
  .commentModalCont{
    padding: 80px 40px;
    min-height: 100svh;
    overflow-y: scroll;
  }
  .commentModalCont__in{
    display: flex;
    flex-direction: column;
  }
  
  .commentModalCont__img,  
  .commentModalCont__texts{
    width: 100%;
  }
  .commentModalCont__name{
    margin-bottom: 20px;
    padding-bottom: 16px;
  }

  .commentModalCont__name>p{
    font-size: 2.8rem;
  }

  .commentModalCont__name>p span{
    font-size: 12px;
  }

  .closeBtn::before, .closeBtn::after{
    background: #009dbd;
  }
  .closeBtn__txt{
    color: #009dbd;
  }
}


/* 区切り点線 */
.deco-dotline{
  border-bottom: 2px dotted #000;
  margin-top: 30px;
}

/* ===============================================
# pager
=============================================== */
.pager{
  margin: 0 auto min(6.25vw, 93.75px) auto;
}
.pager--btn>a:hover {
  background-color: #009dbd;
}

.pager--btn>a:hover .icon-arrow::before {
  background-color: #FFF;
}

.pager--btn.-prev a .icon-arrow {
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
}

.pager--btn.-disable {
  pointer-events: none;
  opacity: 0.5;
}

.pager--numbtn {
  width: min(2.6666666667vw, 40px);
}

@media screen and (max-width: 768px) {
  .pager--numbtn {
    width: max(9.6vw, 48px);
  }
}

.pager--numbtn>a {
  display: block;
  padding: 8px 0;
  background-color: #000;
  color: #fff;
  text-align: center;
  -webkit-transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .pager--numbtn>a {
    padding: max(2.9333333333vw, 14.6666666667px) 0;
  }
}

.pager--numbtn>a:hover {
  background-color: #009dbd;
}

.pager--numbtn.is-current>a {
  background-color: #009dbd;
}

.pager--back {
  width: min(13.9166666667vw, 208.75px);
  margin: 0 auto;
  z-index: 9;
  position: relative;
}

@media screen and (max-width: 768px) {
  .pager--back {
    width: 100%;
    padding: 0 max(12.8vw, 64px);
  }
}

.pager--back>a {
  display: block;
  padding: 8px 0;
  background-color: #000;
  color: #fff;
  text-align: center;
  -webkit-transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: background-color 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.pager--back>a:hover {
  background-color: #009dbd;
}

/* ===============================================
 cms
=============================================== */
/*------------------------------------------------------------
 conpornent
------------------------------------------------------------*/
.detail__content div[data-type="component-videourl"], .detail__content div[data-type="component-videourl2"], .detail__content div[data-type="component-photoGallery"], .detail__content div[data-type="component-photo"], .detail__content .row {
  margin: 1.3em 0;
}
.detail__content .c-video {
  width: 70%;
  margin: 0 auto;
}
.detail__content .c-video__main {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.detail__content .c-video__main iframe, .detail__content .c-video__main [data-video-provider="youku"]>* {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.detail__content .content--text {
  display:block;
  width: 100%;
}
.content--text .content--text__inner{
margin: 0 50px;
padding: 35px 0;
word-wrap: break-word;
overflow-wrap: break-word;
}
@media screen and (max-width: 768px) {
  .content--text__inner img{
    width: 100%;
    height: inherit;
  }
}

.c-video {
  position: relative;
  width:100%;
  height:0;
  padding-top: 56.25%;
}
.c-video iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}