@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600&display=swap");

/*-----------------------------------------------------------------
 * 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 {
  font-size: 62.5%;
  height: 100%;
}

body {
  width: 100%;
  -webkit-text-size-adjust: 100%;
  background-color: #FFF;
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
}

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

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

.pc {
  display: block;
}

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

.sp {
  display: none;
}

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

.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%;
}

@media screen and (max-width: 768px) {
  .header {
    height: 6rem;
    position: fixed;
    top: 0;
    bottom: auto;
    z-index: 9999;
  }
}

@media screen and (min-width: 769px) {
  .header__inner {
    width: 100%;
    height: 100%;
    padding: min(2.6666666667vw, 32px) min(3.3333333333vw, 40px);
  }
}

@media screen and (max-width: 768px) {
  .header__inner {
    -webkit-overflow-scrolling: touch;
    width: 100%;
    height: 100%;
    min-height: 100dvh;
    overflow: auto;
    position: fixed;
    top: 0;
    left: 0;
    padding: 80px 0;
    pointer-events: none;
    z-index: 1;
    -webkit-transition: opacity 0.5s ease-in-out;
    transition: opacity 0.5s ease-in-out;
  }

  .is-active .header__inner {
    pointer-events: auto;
    overscroll-behavior-y: contain;
    overflow-y: auto;
  }
}

@media screen and (max-width: 768px) {
  .header__naviWrap {
    width: 100%;
    min-height: 100dvh;
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
  }
}

.header__logo {
  width: 175px;
  position: relative;
}

@media screen and (min-width: 769px) {
  .header__logo {
    -webkit-transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.25s ease-in-out;
    transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1), -webkit-transform 0.25s ease-in-out;
    transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1), transform 0.25s ease-in-out;
    transition: opacity 0.5s cubic-bezier(0.5, 1, 0.89, 1), transform 0.25s ease-in-out, -webkit-transform 0.25s ease-in-out;
  }

  .header__logo:hover {
    opacity: 0.7;
    -webkit-transform: translateY(-4px);
    transform: translateY(-4px);
  }
}

@media screen and (max-width: 768px) {
  .header__logo {
    height: 6rem;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
    background: #FFF;
    z-index: 999;
  }
}

.header__logo::before {
  padding-top: 18.286%;
  background: url("../img/common//logo/logo.svg") no-repeat center center/contain;
}

@media screen and (max-width: 768px) {
  .header__logo::before {
    width: 33.0666666667vw;
    margin: 0 auto;
    padding-top: 6.555%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}

.header__logo a {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
}

.header__navi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

@media screen and (max-width: 768px) {
  .header__navi {
    width: 100%;
    min-height: 100dvh;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0 max(6.4vw, 32px);
    position: relative;
    opacity: 0;
    -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
    transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  }

  .is-active .header__navi {
    opacity: 1;
    z-index: 99;
  }
}

.header__navi--link {
  position: relative;
  overflow: hidden;
}

.header__navi--link::after {
  content: "";
  display: block;
  width: 100%;
  height: min(1.5vw, 18px);
  background-color: #000;
  position: absolute;
  top: 0;
  z-index: 1;
  -webkit-transform: translateX(-101%);
  transform: translateX(-101%);
  -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) {
  .header__navi--link::after {
    content: none;
  }
}

.header__navi--link>span {
  display: inline-block;
  line-height: 1;
  -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 (min-width: 769px) {
  .header__navi--link>span {
    position: relative;
    top: -2px;
    z-index: 2;
    color: #000;
  }
}

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

  .header__navi--link:hover::after,
  .header__navi--link.is-current::after {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
  }

  .header__navi--link:hover>span,
  .header__navi--link.is-current>span {
    color: #fff;
  }
}

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

  .header__navi--link:hover::before,
  .header__navi--link.is-current::before {
    color: #009dbd;
  }
}

.header__navi--list {
  height: 100%;
  gap: min(3.3333333333vw, 40px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (min-width: 769px) {
  .header__navi--list {
    margin-right: auto;
  }
}

@media screen and (max-width: 768px) {
  .header__navi--list {
    padding-top: max(28.8vw, 144px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: 2.25rem;
    margin-bottom: 3.2rem;
    z-index: 99;
  }
}

.header__navi--item {
  position: relative;
}

.header__navi--item>a {
  width: 100%;
  height: 100%;
  display: block;
  font-size: min(1.6666666667vw, 20px);
  font-weight: 400;
  color: #000;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .header__navi--item>a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: max(2.1333333333vw, 10.6666666667px);
    font-size: max(9.6vw, 48px);
    line-height: 1;
    font-weight: 500;
    color: #000;
  }
}

@media screen and (max-width: 768px) {
  .header__navi--item>a::before {
    content: attr(data-menu);
    display: inline-block;
    font-family: "futura-pt", sans-serif;
    font-size: min(1vw, 12px);
    position: relative;
    top: 5px;
    width: max(4.2666666667vw, 21.3333333333px);
    font-size: max(3.2vw, 16px);
    text-align: center;
    color: #000;
  }
}

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

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

.header__navi--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;
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 769px) {
  .header__navi--sns {
    gap: min(1.3333333333vw, 16px);
    top: -5px;
    margin-right: min(2.6666666667vw, 32px);
  }
}

@media screen and (max-width: 768px) {
  .header__navi--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);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    z-index: 99;
  }

  .is-active .header__navi--sns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    opacity: 1;
  }
}

.header__navi--sns--title {
  color: #000;
  font-size: min(1.3333333333vw, 16px);
  -webkit-transition: color 0.5s cubic-bezier(0.5, 1, 0.89, 1);
  transition: color 0.5s cubic-bezier(0.5, 1, 0.89, 1);
}

@media screen and (max-width: 768px) {
  .header__navi--sns--title {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    margin: 0 auto;
    font-size: max(3.2vw, 16px);
  }
}

.header__navi--sns--list {
  margin-top: min(0.3333333333vw, 4px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(1.6666666667vw, 20px);
}

@media screen and (max-width: 768px) {
  .header__navi--sns--list {
    margin-top: max(6.4vw, 32px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: max(6.4vw, 32px);
  }
}

.header__navi--sns--item {
  width: min(1.6666666667vw, 20px);
  height: min(1.6666666667vw, 20px);
}

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

.header__navi--sns--item>a {
  width: 100%;
  height: 100%;
  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;
}

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

.header__navi--sns--item>a.icon-tw::before {
  -webkit-mask-image: url("../img/common/icon/icon_tw.svg");
  mask-image: url("../img/common/icon/icon_tw.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__navi--sns--item>a.icon-tw:hover::before {
  background-color: #009dbd;
}

.header__navi--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__navi--sns--item>a.icon-tik:hover::before {
  background-color: #009dbd;
}

@media screen and (max-width: 768px) {
  .header__navi--text {
    position: relative;
    background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, white), color-stop(0%, #000));
    background-image: linear-gradient(0deg, white 0 0%, #000 0%);
    -webkit-background-clip: text;
    color: transparent;
    -webkit-transition: background-image 0.3s cubic-bezier(0.5, 1, 0.89, 1);
    transition: background-image 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  }

  .is-current .header__navi--text {
    background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, white), color-stop(30%, #000));
    background-image: linear-gradient(0deg, white 0 50%, #000 30%);
  }

  .header__navi--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, #000), color-stop(30%, rgba(255, 255, 255, 0)));
    background: linear-gradient(0deg, #000 0 50%, rgba(255, 255, 255, 0) 30%);
    -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
    transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
    opacity: 0;
  }

  .is-current .header__navi--text::before {
    opacity: 1;
  }
}

.header__link {
  margin-bottom: min(3.3333333333vw, 40px);
  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, 16px) min(0.8333333333vw, 10px);
  margin: 0 auto;
  border: 1px solid #000;
  background-color: #000;
  font-size: min(1.3333333333vw, 16px);
  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__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, 16px);
  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: 9px;
  -webkit-transform: rotate(20deg);
  transform: rotate(20deg);
}

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

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

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

@media screen and (min-width: 769px) {
  .header__triangle {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .header__triangle {
    width: 150%;
    height: 250%;
    top: calc(50% + 100px);
    left: 50%;
    -webkit-transform: translateX(-50%) translateY(-50%) rotate(-45deg);
    transform: translateX(-50%) translateY(-50%) rotate(-45deg);
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
    background-color: rgba(255, 255, 255, 0.8);
    z-index: 9;
  }
}

.header__shareDl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: min(1.3333333333vw, 16px);
}

@media screen and (max-width: 768px) {
  .header__shareDl {
    gap: max(4.2666666667vw, 21.3333333333px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}

.header__shareDl--dt {
  color: #000;
  font-size: min(1.3333333333vw, 16px);
  text-align: center;
}

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

.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(1.6666666667vw, 20px);
  height: min(1.6666666667vw, 20px);
  /* 各SNS */
}

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

@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: contain;
  mask-size: contain;
  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.6666666667vw, 33.3333333333px);
    height: max(6.6666666667vw, 33.3333333333px);
  }
}

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

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

.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);
}

@media screen and (max-width: 768px) {
  .header__share {
    position: absolute;
    right: max(6.4vw, 32px);
    bottom: max(6.6666666667vw, 33.3333333333px);
    z-index: 99;
  }
}

.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 {
    height: 100dvh;
  }
}

.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;
  background-repeat: no-repeat;
}

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

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

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

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

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

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

.header__slide--item:nth-child(7) {
  background-image: url("../img/common/nav/visual_7.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;
}

/**
* navBtn
*/
@media screen and (max-width: 767px) {
  .header__navBtnWrap {
    width: min(8.33333vw, 100px);
    pointer-events: auto;
  }
}

@media screen and (max-width: 767px) and (max-width: 768px) {
  .header__navBtnWrap {
    width: max(12.8vw, 64px);
    height: max(12.8vw, 64px);
    position: absolute;
    top: 8px;
    right: 8px;
    pointer-events: auto;
    -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);
  }
}

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

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

@-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 {
  position: relative;
}

@media screen and (min-width: 769px) {
  .footer {
    margin-top: min(13.3333333333vw, 160px);
  }
}

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

.footer__in {
  margin-bottom: min(6.6666666667vw, 80px);
}

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

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

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

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

@media screen and (max-width: 768px) {
  .footer__bnr--item {
    width: calc(50% - 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: 168px;
  }
}

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

.footer__bnr--bottom {
  margin: min(6.6666666667vw, 80px) 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, 40px);
}

.footer__caution--text {
  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, 20px);
  right: min(1.6666666667vw, 20px);
  -webkit-transform: translateY(calc(100% + min(1.6666666667vw, 20px)));
  transform: translateY(calc(100% + min(1.6666666667vw, 20px)));
  -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: 9998;
  mix-blend-mode: difference;
}

.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, 10px);
}

.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(6.6666666667vw, 80px);
  height: min(3.3333333333vw, 40px);
  -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: min(1.3333333333vw, 16px);
  margin-top: 6px;
  text-align: center;
}

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

/* ===============================================
# animation
=============================================== */
/**
 * test
 */
@-webkit-keyframes test {}

@keyframes test {}

/* ===============================================
# 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: absolute;
  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: 120px;
  height: 120px;
  pointer-events: auto;
  position: absolute;
  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;
    right: -5px;
  }
}

@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 {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  border: none;
}

/*-----------------------------------------------
* 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-bg-blue {
  display: inline-block;
  background-color: #009dbd;
  color: #fff;
  line-height: 1;
}

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

.u-marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(10%, transparent), color-stop(10%, #009dbd));
  background: linear-gradient(transparent 10%, #009dbd 10%);
  color: #FFF;
  line-height: 1;
}

/* ===============================================
# top
=============================================== */
.cmn__triangle--item {
  width: min(50vw, 600px);
  height: min(50vw, 600px);
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
  clip-path: polygon(0 0, 100% 100%, 100% 0);
  position: absolute;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .cmn__triangle--item {
    width: max(49.3333333333vw, 246.6666666667px);
    height: max(49.3333333333vw, 246.6666666667px);
  }
}

.cmn__triangle--item.-blue {
  background-color: #009dbd;
}

.cmn__triangle--item.-gray {
  background-color: #eee;
}

.cmn__triangle--item.-black {
  background-color: #000;
}

.cmn__triangle--item.-top {
  top: 0;
  left: 0;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
  -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 .cmn__triangle--item.-top {
  -webkit-transform: translateX(0%) scale(-1, 1);
  transform: translateX(0%) scale(-1, 1);
}

.cmn__triangle--item.-bottom {
  bottom: 0;
  right: 0;
  -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 .cmn__triangle--item.-bottom {
  -webkit-transform: translateX(0%) scale(1, -1);
  transform: translateX(0%) scale(1, -1);
}

.cmn__link {
  position: relative;
  margin-top: min(6.6666666667vw, 80px);
}

.cmn__link>a {
  width: 100%;
  display: block;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(2vw, 24px);
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: #009dbd;
  color: #FFF;
}

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

.cmn__link>a:hover {
  opacity: 0.8;
}

.cmn__link>a::before,
.cmn__link>a::after {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  background-color: #FFF;
  -webkit-clip-path: polygon(100% 0, 0 0, 0 100%);
  clip-path: polygon(100% 0, 0 0, 0 100%);
  position: absolute;
}

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

  .cmn__link>a::before,
  .cmn__link>a::after {
    width: max(5.3333333333vw, 26.6666666667px);
    height: max(5.3333333333vw, 26.6666666667px);
  }
}

.cmn__link>a::before {
  top: -1px;
  left: -1px;
}

.cmn__link>a::after {
  bottom: -1px;
  right: -1px;
  -webkit-transform: scale(-1, -1);
  transform: scale(-1, -1);
}

.cmn__link--text {
  display: block;
  padding: min(2.6666666667vw, 32px) 0;
  font-size: min(1.6666666667vw, 20px);
  text-align: center;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .cmn__link--text {
    padding: max(3.2vw, 16px) 0;
    font-size: max(3.2vw, 16px);
  }
}

.update,
.theater,
.about {
  max-width: 1920px;
  margin: 0 auto;
}

.update__inner,
.theater__inner,
.about__inner {
  max-width: 1920px;
  margin: 0 auto;
  padding: 0 min(13.3333333333vw, 160px);
}

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

  .update__inner,
  .theater__inner,
  .about__inner {
    padding: 0 max(6.6666666667vw, 33.3333333333px);
  }
}

/**
 * firstv
 */
@media screen and (max-width: 768px) {
  .firstv {
    overflow: hidden;
  }
}

.firstv__heading--in {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 min(9.1666666667vw, 110px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: min(2vw, 24px);
}

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

.firstv__heading--logo.-logo-seed {
  width: min(26.3333333333vw, 316px);
  background: url("../img/common/logo/logo_seed.png") no-repeat center center/contain;
}

@media screen and (max-width: 768px) {
  .firstv__heading--logo.-logo-seed {
    width: max(45.2vw, 226px);
    padding-top: 22.758112%;
    margin: 0 auto;
  }
}

.firstv__heading--logo.-logo-destiny {
  width: min(28.8333333333vw, 346px);
  background: url("../img/common/logo/logo_destiny.png") no-repeat center center/contain;
}

@media screen and (max-width: 768px) {
  .firstv__heading--logo.-logo-destiny {
    width: max(48.6666666667vw, 243.3333333333px);
    padding-top: 23.520548%;
    margin: 0 auto;
  }
}

.firstv__heading--text {
  background: url("../img/common/logo/logo_set2.png") no-repeat center center/contain;
  width: min(82vw, 680px);
  padding-top: 24%;
  margin-top: 24px;
}

@media screen and (max-width: 768px) {
  .firstv__heading--text {
    margin-top: 0;
    padding-top: 41.5%;
  }
}

@media screen and (min-width: 769px) {
  .firstv__slider {
    margin-top: min(-2.6666666667vw, -32px);
  }
}

@media screen and (max-width: 768px) {
  .firstv__slider {
    margin: max(-4vw, -20px) 0 max(-13.3333333333vw, -66.6666666667px);
  }
}

.firstv__slider--in {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  height: auto !important;
  padding: min(8.3333333333vw, 100px) 0;
}

@media screen and (max-width: 768px) {
  .firstv__slider--in {
    padding: max(13.3333333333vw, 66.6666666667px) 0;
  }
}

.firstv__slider--pagination {
  position: relative !important;
  bottom: max(3.2vw, 16px) !important;
}

@media screen and (max-width: 768px) {
  .firstv__slider--pagination {
    bottom: max(-4.2666666667vw, -21.3333333333px) !important;
  }
}

.firstv__slider--item>img {
  -webkit-box-shadow: 0 0 80px rgba(0, 0, 0, 0.16);
  box-shadow: 0 0 80px rgba(0, 0, 0, 0.16);
}

.firstv__bnrWrap {
  position: relative;
  width: min(66.6666666667vw, 800px);
  overflow: hidden;
  margin: 0 auto;
  padding-bottom: 30px;
  -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);
  opacity: 0;
  -webkit-transform: translateY(-20px);
  transform: translateY(-20px);
  -webkit-transition-delay: 0.25s;
  transition-delay: 0.25s;
}

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

.-loaded .firstv__bnrWrap {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

@media screen and (max-width: 768px) {
  .firstv__bnrWrap {
    margin-top: max(12.9333333333vw, 64.6666666667px);
  }
}

.firstv__bnr {
  margin-top: min(4.1666666667vw, 50px);
}

@media screen and (max-width: 1023px) {
  .firstv__bnr {
    margin-top: min(1.6666666667vw, 20px);
  }
}

.firstv__bnr--in {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  height: auto !important;
}

.firstv__bnr--item {
  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;
  gap: 40px;
}

@media screen and (max-width: 768px) {
  .firstv__bnr--item {
    gap: 20px;
  }
}

.firstv__bnr--item a {
  display: block;
  -webkit-transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.firstv__bnr--item a:hover {
  opacity: 0.7;
}

.firstv__bnr--item img {
  width: 100%;
}

.firstv__bnr--pagination {
  position: relative !important;
  text-align: center;
  bottom: min(-1.3333333333vw, -16px) !important;
}

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

.about__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;
  position: relative;
  z-index: 2;
}

@media screen and (min-width: 769px) {
  .about__titleWrap {
    gap: min(3.3333333333vw, 40px);
    margin-left: min(3.3333333333vw, 40px);
  }
}

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

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

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

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

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

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

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

@media screen and (max-width: 768px) {
  .about__title--sub {
    gap: max(1.6vw, 8px);
  }
}

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

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

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

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

.about__box {
  position: relative;
  top: -40px;
  background-color: #FFF;
  padding: min(6.6666666667vw, 80px);
  z-index: 1;
  border: 1px solid #ccc;
}

@media screen and (max-width: 768px) {
  .about__box {
    top: -12px;
    padding: max(6.4vw, 32px);
  }
}

.about__box>p {
  font-size: min(1.6666666667vw, 20px);
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .about__box>p {
    font-size: max(3.2vw, 16px);
  }
}

.about__box>p+p {
  margin-top: min(1.6666666667vw, 20px);
}

@media screen and (max-width: 768px) {
  .about__box>p+p {
    margin-top: max(2.6666666667vw, 13.3333333333px);
  }
}

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

.theater__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;
  position: relative;
  z-index: 2;
}

@media screen and (min-width: 769px) {
  .theater__titleWrap {
    gap: min(3.3333333333vw, 40px);
    margin-left: min(3.3333333333vw, 40px);
  }
}

@media screen and (max-width: 1023px) {
  .theater__titleWrap {
    gap: max(2.6666666667vw, 13.3333333333px);
    margin-left: max(3.2vw, 16px);
  }
}

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

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

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

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

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

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

@media screen and (max-width: 768px) {
  .theater__title--sub {
    gap: max(1.6vw, 8px);
  }
}

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

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

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

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

.theater__box {
  position: relative;
  top: -40px;
  background-color: #FFF;
  padding: min(6.6666666667vw, 80px) 0;
  z-index: 1;
  border: 1px solid #ccc;
}

@media screen and (max-width: 768px) {
  .theater__box {
    top: -12px;
    padding: max(6.4vw, 32px) 0;
  }
}

.theater__box>p {
  font-size: min(1.6666666667vw, 20px);
  line-height: 2;
}

.theater__box>p+p {
  margin-top: min(1.6666666667vw, 20px);
}

.theater__boxIn {
  padding: 0 min(6.6666666667vw, 80px);
}

.theater__heading {
  display: inline-block;
  background-color: #000;
}

@media screen and (min-width: 769px) {
  .theater__heading {
    margin-bottom: min(2.6666666667vw, 32px);
    padding-left: min(6.6666666667vw, 80px);
  }
}

@media screen and (max-width: 768px) {
  .theater__heading {
    padding-left: max(6.4vw, 24px);
    padding-bottom: 2px;
    margin-bottom: max(4.2666666667vw, 21.3333333333px);
  }
}

.theater__heading>span {
  color: #FFF;
  line-height: 1;
  display: block;
  font-weight: 600;
}

@media screen and (min-width: 769px) {
  .theater__heading>span {
    font-size: min(1.6666666667vw, 20px);
    margin-top: -1px;
  }
}

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

.theater__heading.heading-ticket {
  margin-top: min(6.6666666667vw, 80px);
}

@media screen and (max-width: 768px) {
  .theater__heading.heading-ticket {
    margin-top: max(7.4666666667vw, 37.3333333333px);
  }
}

.theater__subheading {
  font-size: min(1.6666666667vw, 20px);
  font-weight: 500;
  color: #009dbd;
  margin-bottom: min(2vw, 24px);
}

@media screen and (max-width: 768px) {
  .theater__subheading {
    margin-bottom: max(3.2vw, 16px);
    font-size: max(3.2vw, 16px);
  }
}

.theater__shedule+.theater__shedule {
  margin-top: min(6.6666666667vw, 80px);
}

.theater__shedule--logo {
  width: min(25vw, 300px);
  margin: 0 auto min(3.3333333333vw, 40px);
}

@media screen and (max-width: 768px) {
  .theater__shedule--logo {
    width: max(40vw, 200px);
    margin: 0 auto max(5.3333333333vw, 26.6666666667px);
  }
}

.theater__shedule--item {
  margin-bottom: min(2vw, 24px);
  text-align: center;
}

@media screen and (max-width: 768px) {
  .theater__shedule--item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: max(1.0666666667vw, 5.3333333333px);
    margin-bottom: max(4.2666666667vw, 21.3333333333px);
  }
}

.theater__shedule--link {
  width: min(46.6666666667vw, 560px);
  margin: min(5vw, 60px) auto 0;
}

@media screen and (max-width: 768px) {
  .theater__shedule--link {
    width: 100%;
    margin: max(8vw, 40px) auto 0;
  }
}

.theater__ticket--in+.theater__ticket--in {
  margin-top: min(3.3333333333vw, 40px);
}

@media screen and (max-width: 768px) {
  .theater__ticket--in+.theater__ticket--in {
    margin-top: max(7.4666666667vw, 37.3333333333px);
  }
}

.theater__ticket--item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(1.3333333333vw, 16px);
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin-bottom: min(0.8333333333vw, 10px);
}
.theater__ticket--item.-wrap{
  flex-wrap: wrap;
}

@media screen and (max-width: 768px) {
  .theater__ticket--item {
    width: 100%;
    gap: unset;
    margin-bottom: max(3.2vw, 16px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.theater__ticket--item dt {
  position: relative;
  font-size: min(1.3333333333vw, 16px);
  color: #009dbd;
}

@media screen and (max-width: 768px) {
  .theater__ticket--item dt {
    width: max(16vw, 80px);
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
}

.theater__ticket--item dt>span {
  display: block;
  text-align: right;
}

@media screen and (min-width: 769px) {
  .theater__ticket--item dt>span {
    width: min(13.3333333333vw, 160px);
    font-size: min(1.3333333333vw, 16px);
  }
}

@media screen and (max-width: 768px) {
  .theater__ticket--item dt>span {
    width: max(24vw, 120px);
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
}

.theater__ticket--item dd {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (min-width: 769px) {
  .theater__ticket--item dd {
    padding-left: min(1.3333333333vw, 16px);
    gap: 16px;
    font-size: min(1.3333333333vw, 16px);
  }
}

@media screen and (max-width: 768px) {
  .theater__ticket--item dd {
    width: 100%;
    font-size: max(2.9333333333vw, 14.6666666667px);
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

.theater__ticket--item dd>span {
  display: block;
  margin-top: -4px;
  font-size: min(1.6666666667vw, 20px);
}

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

@media screen and (min-width: 769px) {
  .theater__ticket--item dd::before {
    content: "";
    display: block;
    width: 1px;
    height: calc(100% - 8px);
    position: absolute;
    top: 4px;
    left: 0;
    background-color: #000;
  }
}

.theater__ticket--item dd>a {
  color: #009dbd;
  text-decoration: underline;
}

.theater__ticket--item dd>a:hover {
  opacity: 0.8;
  text-decoration: none;
}

.theater__ticket--caution {
  margin-bottom: 16px;
}
dd.theater__ticket--caution{
  width: 100%;
  padding: 0;
  gap: 0;
  display: block;
}
dd.theater__ticket--caution:before{
  content: unset;
}

@media screen and (max-width: 768px) {
  .theater__ticket--caution {
    margin-bottom: 8px;
  }
}

@media screen and (max-width: 768px) {
  .theater__ticket--caution.sp-space {
    margin-bottom: max(3.2vw, 16px);
  }
}

.theater__ticket--text {
  font-size: min(1.3333333333vw, 16px);
}

.theater__ticket--text.text-caution {
  font-size: min(1vw, 12px);
  margin-bottom: min(0.3333333333vw, 4px);
}

@media screen and (max-width: 768px) {
  .theater__ticket--text.text-caution {
    font-size: max(2.4vw, 12px);
  }
}

.theater__ticket--text.text-caution::before {
  content: "※";
}

.theater .oneTokuten {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 40px 0 20px;
  gap: 120px;
}

@media screen and (max-width: 768px) {
  .theater .oneTokuten {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: 20px 0;
  }
}

.theater .oneTokuten__item {
  position: relative;
}

.theater .oneTokuten__item:not(:last-child)::before,
.theater .oneTokuten__item:not(:last-child)::after {
  content: "";
  display: block;
  width: 4px;
  background: #009dbd;
}

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

  .theater .oneTokuten__item:not(:last-child)::before,
  .theater .oneTokuten__item:not(:last-child)::after {
    height: min(4.1666666667vw, 50px);
    position: absolute;
    top: calc(50% - min(4.1666666667vw, 50px));
    right: max(-12.6666666667vw, -63.3333333333px);
    -webkit-transform: translate(0%, -50%);
    transform: translate(0%, -50%);
  }
}

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

  .theater .oneTokuten__item:not(:last-child)::before,
  .theater .oneTokuten__item:not(:last-child)::after {
    height: 60px;
    position: absolute;
    bottom: -80px;
    left: 50%;
    -webkit-transform: translate(-50%, 0%);
    transform: translate(-50%, 0%);
  }
}

@media screen and (max-width: 768px) {
  .theater .oneTokuten__item:not(:last-child)::before {
    -webkit-transform: translate(calc(-50% + 1px), 0%);
    transform: translate(calc(-50% + 1px), 0%);
  }
}

.theater .oneTokuten__item:not(:last-child)::after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

@media screen and (min-width: 769px) {
  .theater .oneTokuten__item:not(:last-child)::after {
    top: calc(50% - min(6.25vw, 75px));
  }
}

.theater .oneTokuten__img {
  margin-bottom: 16px;
}

.theater .oneTokuten__img>img {
  width: auto;
  max-height: 350px;
}

@media screen and (max-width: 768px) {
  .theater .oneTokuten__img>img {
    margin: 0 auto;
  }
}

.theater .oneTokuten__text--name {
  font-size: 16px;
  font-weight: 600;
  color: #009dbd;
  margin-bottom: 8px;
}

@media screen and (max-width: 768px) {
  .theater .oneTokuten__text--name {
    font-size: 16px;
  }
}

.theater .oneTokuten__text--caution {
  font-size: 18px;
  line-height: 1.75;
}

@media screen and (max-width: 768px) {
  .theater .oneTokuten__text--caution {
    font-size: 12px;
  }
}

/**
 * update
 */
.update {
  position: relative;
  margin-top: min(13.3333333333vw, 160px);
}

@media screen and (max-width: 768px) {
  .update {
    margin-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, 40px);
    margin-left: min(3.3333333333vw, 40px);
  }
}

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

.update__title>span {
  display: block;
  font-size: min(15vw, 180px);
  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, 15px);
}

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

.update__title--sub>span {
  font-size: min(1vw, 12px);
  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(1.3333333333vw, 16px);
  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, 48px);
  }

  .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, 16px);
  margin: 0 auto;
  border: 1px solid #000;
  background-color: #000;
  font-size: min(1.3333333333vw, 16px);
  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, 76px);
  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(6.4vw, 32px);
  }
}

.update__box {
  width: calc(50% - min(3.3333333333vw, 40px));
  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 (min-width: 769px) {
  .update__box {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}

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

.update__news--list {
  background-color: rgba(255, 255, 255, 0.7);
}

.update__news--item {
  border-top: 1px solid #ccc;
}

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

.update__news--link {
  padding: min(2vw, 24px) min(1.3333333333vw, 16px);
  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--link {
    gap: max(2.1333333333vw, 10.6666666667px);
    padding: max(4vw, 20px) 0;
  }
}

.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__movie {
  position: relative;
  overflow: hidden;
}

.update__movie--inner {
  margin-bottom: auto;
}

.update__movie--item {
  position: relative;
}

.update__movie--item::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 56.25%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.4);
  pointer-events: none;
  z-index: 10;
}

@media screen and (max-width: 768px) {
  .update__movie--item::before {
    content: none;
  }
  .update__movie--item a{
    position: relative;
  }
  .update__movie--item a::before {
    content: "";
    display: block;
    width: 100%;
    padding-top: 56.25%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.4);
    pointer-events: none;
    z-index: 10;
  }
}

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

.update__movie--play--link {
  display: block;
  height: 100%;
  padding-top: 56.25%;
  overflow: hidden;
}

.update__movie--play--link img{
  min-width: 75%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0%);
}

.update__movie--play--img{
  overflow: hidden;
}

.update__movie--play--link span {
  color: #fff;
  font-size: min(1.3333333333vw, 16px);
  z-index: 11;
}

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

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

.update__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);
}

.update__movie--play--link .icon-arrow-large::after {
  content: "";
  display: block;
  width: min(10vw, 120px);
  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) {
  .update__movie--play--link .icon-arrow-large::after {
    width: max(20vw, 100px);
  }
}

.update__movie--play--btn {
  width: min(13.3333333333vw, 160px);
  position: absolute;
  top: calc(50% - 24px);
  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) {
  .update__movie--play--btn {
    width: max(30vw, 150px);
    top: 50%;
  }
}

.update__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, 16px);
  margin: 0 auto;
  border: 1px solid #FFF;
  background-color: #000;
  font-size: min(1.3333333333vw, 16px);
  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__movie--link>a {
    font-size: max(3.2vw, 16px);
    padding: 8px max(3.2vw, 16px);
  }
}

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

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

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

.update__movie--title {
  margin-top: min(2vw, 24px);
}

.update__movie--title>p {
  color: #000;
  font-size: min(1.3333333333vw, 16px);
  letter-spacing: 0.025em;
}

@media screen and (max-width: 768px) {
  .update__movie--title>p {
    font-size: max(3.2vw, 16px);
  }
}

.update__movie--pagination {
  margin-top: min(3.3333333333vw, 40px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative !important;
}

@media screen and (max-width: 768px) {
  .update__movie--pagination {
    margin-top: max(7.4666666667vw, 37.3333333333px);
  }
}

.swiper-pagination-bullet {
  width: 16px;
  height: 16px;
  background: url("../img/common/icon/icon_slidenav.svg") no-repeat center center/contain;
  position: relative;
  opacity: 1;
}

.swiper-pagination-bullet::before {
  width: 8px;
  height: 8px;
  content: "";
  display: inline-block;
  -webkit-mask-image: url("../img/common/icon/icon_slidenav_on.svg");
  mask-image: url("../img/common/icon/icon_slidenav_on.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: #009dbd;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) scale(0);
  transform: translate(-50%, -50%) scale(0);
  -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);
}

.swiper-pagination-bullet-active::before {
  -webkit-transform: translate(-50%, -50%) scale(1);
  transform: translate(-50%, -50%) scale(1);
}

/*-----------------------------------------------
* 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;
  }
}

/*-----------------------------------------------
* 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;
  background-color: #FFF;
}

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

/* logo */
.loading__logo {
  width: 60vw;
  max-width: 800px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
}

@media screen and (max-width: 768px) {
  .loading__logo {
    gap: 20px;
  }
}

.loading__logo img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .loading__logo {
    width: 80vw;
    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;
}

/*-----------------------------------------------
* 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(40px);
  transform: translateY(40px);
  opacity: 0;
}

.ani-fadeup.-inview,
.-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);
  -webkit-transform: translateX(40px);
  transform: translateX(40px);
  opacity: 0;
}

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

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

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

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

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

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

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

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

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

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

.ani-faderight.-inview.ani-delay:nth-child(10),
.-inview .ani-faderight.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;
}

/* ===============================================
# sub
=============================================== */
#fullWrap {
  overflow: hidden;
}

.sub__in {
  width: calc(100% - min(6.6666666667vw, 80px));
  padding-left: min(3.3333333333vw, 40px);
  max-width: 1400px;
}

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

.sub__container {
  margin-top: min(6.6666666667vw, 80px);
}

@media screen and (max-width: 768px) {
  .sub__container {
    margin: max(21.3333333333vw, 106.6666666667px) 0 max(12.8vw, 64px);
  }
}

.sub__headline--inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: min(3.3333333333vw, 40px);
}

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

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

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

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

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

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

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

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

@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, 12px);
  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: 32px;
  background-color: #000;
}

.sub__tab {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 99;
  margin-left: min(-0.8333333333vw, -10px);
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}

@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::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-right: 1px solid #000;
  background: transparent;
  -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:hover::before {
  background-color: rgba(255, 255, 255, 0.4);
}

.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, 10px) 0;
  color: #000;
  font-size: min(1.6666666667vw, 20px);
  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, 18.6666666667px);
  }
}

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

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

.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, 80px));
  margin-top: min(6.6666666667vw, 80px);
}

@media screen and (max-width: 768px) {
  .sub__contents {
    width: 100%;
    margin-top: max(12.8vw, 64px);
  }
}

.sub__heading {
  width: calc(100% - min(6.6666666667vw, 80px));
  background-color: #000;
  position: relative;
  left: 0;
}

.sub__heading--main>span {
  display: block;
  font-size: min(5vw, 60px);
  font-weight: 300;
  text-transform: uppercase;
  line-height: 0.7;
  color: #FFF;
  text-align: right;
}

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

/**
 * fixbg
 */
.fixbg {
  width: 100%;
  height: 100vh;
  min-height: 720px;
  position: fixed;
  top: 0;
  z-index: -1;
  pointer-events: none;
}

@media screen and (max-width: 768px) {
  .fixbg {
    overflow: hidden;
  }
}

/**
 * fade
 */
body::after {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: opacity 0.8s ease;
  transition: opacity 0.8s ease;
}

body.-fadeout::after {
  opacity: 1;
}

.news__contents {
  width: 100%;
  margin-top: min(6.6666666667vw, 80px);
  padding: 0 min(13.3333333333vw, 160px);
}

@media screen and (max-width: 768px) {
  .news__contents {
    margin-top: max(6.4vw, 32px);
    padding: 0 max(6.4vw, 32px);
  }
}

.-loaded .news__contents {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.news__itemList {
  background-color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  border-bottom: 1px solid #ccc;
  max-width: 1400px;
  margin: 0 auto;
}

.news__item {
  width: 50%;
  padding: min(3.3333333333vw, 40px);
  border-color: #ccc;
  border-style: solid;
  border-width: 1px;
  border-bottom: none;
}

@media screen and (max-width: 768px) {
  .news__item {
    width: 100%;
    padding: max(5.3333333333vw, 26.6666666667px);
  }
}

@media screen and (min-width: 769px) {
  .news__item:nth-child(odd) {
    border-right: none;
  }
}

.news__item--link {
  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, 24px);
}

@media screen and (max-width: 768px) {
  .news__item--link {
    gap: max(3.2vw, 16px);
  }
}

@media screen and (min-width: 769px) {
  .news__item--link:hover::before {
    width: 100%;
    left: 0;
    right: auto;
  }

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

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

.news__item--thumb {
  position: relative;
  overflow: hidden;
  padding-top: 56.25%;
  z-index: 1;
}

.news__item--thumb>img {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.news__item--title {
  color: #000;
  font-size: min(1.3333333333vw, 16px);
  -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) {
  .news__item--title {
    font-size: max(3.2vw, 16px);
  }
}

.news__item--date {
  color: #009dbd;
  font-size: min(1.3333333333vw, 16px);
  font-family: "futura-pt", sans-serif;
  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) {
  .news__item--date {
    font-size: max(3.2vw, 16px);
  }
}

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

.news__pager {
  margin-top: min(6.6666666667vw, 80px);
  position: relative;
}

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

@media screen and (min-width: 769px) {
  .news__pager--bottom {
    margin-top: -40px;
  }
}

@media screen and (max-width: 768px) {
  .news__pager--bottom {
    margin-top: 24px;
  }
}

.news__pager--btn {
  width: min(8vw, 96px);
}

@media screen and (max-width: 768px) {
  .news__pager--btn {
    width: max(20vw, 100px);
  }
}

.news__pager--btn>a {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  gap: 8px;
  padding: 8px 0;
  background-color: #000;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.news__pager--btn>a:hover {
  background-color: #009dbd;
}

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

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

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

.news__pager--numbtn {
  width: min(2.6666666667vw, 32px);
}

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

.news__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) {
  .news__pager--numbtn>a {
    padding: max(2.9333333333vw, 14.6666666667px) 0;
  }
}

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

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

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

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

.news__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);
}

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

.news__pager--list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: min(2vw, 24px);
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.news__detail {
  background-color: #FFF;
  border: 1px solid #ccc;
  padding: min(6.6666666667vw, 80px);
}

.-loaded .news__detail {
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}

.news__desc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: min(3.3333333333vw, 40px);
  padding-bottom: min(3.3333333333vw, 40px);
  border-bottom: 1px solid #ccc;
}

@media screen and (max-width: 768px) {
  .news__desc {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: max(3.2vw, 16px);
    padding-bottom: max(5.3333333333vw, 26.6666666667px);
  }
}

.news__desc--title {
  color: #000;
  font-size: min(1.3333333333vw, 16px);
  -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) {
  .news__desc--title {
    font-size: max(3.7333333333vw, 18.6666666667px);
  }
}

.news__desc--date {
  font-size: min(1.3333333333vw, 16px);
  color: #009dbd;
  font-family: "futura-pt", sans-serif;
  text-align: center;
}

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

@media screen and (max-width: 768px) {
  .news__desc--date>time {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.news__artcle--in+.news__artcle--in {
  margin-top: 40px;
}

.news__artcle--in {
  padding: min(3.3333333333vw, 40px) 0;
  border-bottom: 1px solid #ccc;
}

@media screen and (max-width: 768px) {
  .news__artcle--in {
    padding: max(6.6666666667vw, 33.3333333333px) 0;
  }
}

.news__artcle--in p {
  font-size: min(1.3333333333vw, 16px);
}

@media screen and (max-width: 768px) {
  .news__artcle--in p {
    font-size: max(2.9333333333vw, 14.6666666667px);
    line-height: 2;
  }

  .news__artcle--in iframe{
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 9;
  }
}

.news__artcle p,
.news__artcle img {
  margin-bottom: 40px;
}

.news__artcle a {
  word-wrap: break-word;
  color: #009dbd;
}

.news__artcle img {
  margin: 40px auto;
  display: block;
}

.news__link--item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  font-size: min(1.3333333333vw, 16px);
  font-weight: 500;
}

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

.news__link--item::before {
  content: "";
  display: block;
  width: 16px;
  height: 8px;
  position: relative;
  top: 4px;
  -webkit-mask-image: url("../img/common/icon/icon_arrow_type2.svg");
  mask-image: url("../img/common/icon/icon_arrow_type2.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;
}

@media screen and (max-width: 768px) {
  .news__link--item::before {
    top: 6px;
  }
}

.news__link--item>a {
  width: calc(100% - 32px);
  display: inline-block;
  color: #009dbd;
  font-size: min(1.3333333333vw, 16px);
}

@media screen and (max-width: 768px) {
  .news__link--item>a {
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
}

.news__link--item+.news__link--item {
  margin-top: min(2.6666666667vw, 32px);
}

.news__share {
  margin-top: min(3.3333333333vw, 40px);
}

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

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

@media screen and (max-width: 768px) {
  .news__shareDl {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

.news__shareDl--dt {
  color: #000;
  font-size: var(--fontsize-14);
  text-align: center;
}

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

.news__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) {
  .news__shareLists {
    gap: max(6.4vw, 32px);
  }
}

.news__shareLists--item {
  width: min(2.08333vw, 25px);
  height: min(2.08333vw, 25px);
  /* 各SNS */
}

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

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

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

.news__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%;
}

.news__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: contain;
  mask-size: contain;
  width: min(2.08333vw, 25px);
  height: min(2.08333vw, 25px);
  -webkit-transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}
.theater__shedule--dt{
    background: #009dbd;
    color: #fff;
    line-height: 1.2;
    font-size:min(1.6666666667vw, 20px);
}
.theater__shedule--dd{
  margin: 8px 0 0 0;
  font-size:min(1.6666666667vw, 20px);
}
.present__ttl{
  text-align: left;
  margin: 16px 0 0 0;
  color: #009dbd;
  font-weight: bold;
}
.present__cap{
  text-align: left;
  margin: 8px 0 16px 0;
}
.present__mb{
  margin: 0 0 40px 0;
}

@media screen and (max-width: 768px) {
  .news__shareLists--item>a:before {
    width: max(6.6666666667vw, 33.3333333333px);
    height: max(6.6666666667vw, 33.3333333333px);
  }
  .theater__shedule--dt{
      font-size:max(3.2vw, 16px);
  }
  .theater__shedule--dd{
    font-size:max(3.2vw, 16px);
  }
  .present__ttl{
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
  .present__cap{
    margin: 8px 0 16px 0;
    font-size: max(2.9333333333vw, 14.6666666667px);
  }
  .present__mb{
    margin: 0 0 32px 0;
  }
}

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

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

.news__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);
}

.news__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);
}
.atTxt{
  color: #bd0000 !important;
}