@charset "UTF-8";
:root {
  --maincolor: #a67e22;
  --subcolor: #fff;
  --textcolor: #0c0c0c;
  --container: 1200px;
}

/* ======== ↓ common ↓ ======== */
#contentsWrapper {
  position: relative;
  width: 100%;
  min-height: 50vh;
  font-size: 16px;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: normal;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--textcolor);
  background-color: #fff;
  z-index: 10;
}

@media screen and (max-width: 800px) {
  #contentsWrapper {
    font-size: max(3vw,12px);
  }
}

#contentsWrapper * {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

#contentsWrapper *::-webkit-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: var(--maincolor) #c1bfbf;
  width: 4px;
}

#contentsWrapper *::-webkit-scrollbar-thumb {
  background: var(--maincolor);
  border-radius: 4px;
}

#contentsWrapper a {
  opacity: 1;
  color: inherit;
  background-color: transparent;
  text-decoration: none !important;
  -webkit-transition: all 0.15s ease;
  transition: all 0.15s ease;
}

#contentsWrapper a.hover {
  color: var(--maincolor);
  background-color: transparent;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

#contentsWrapper img {
  max-width: 100%;
  height: auto;
  display: block;
}

#contentsWrapper .cover {
  width: 100%;
  max-width: none;
  height: auto;
}

#contentsWrapper .l-container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
}

@media screen and (max-width: 1220px) {
  #contentsWrapper .l-container {
    padding-left: 4%;
    padding-right: 4%;
  }
}

#contentsWrapper .flexBlock {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  list-style: none;
}

#contentsWrapper .flexBetween {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

#contentsWrapper .flexLeft {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

#contentsWrapper .flexAlignCenter {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#contentsWrapper .flexSplit > * {
  width: 50%;
}

#contentsWrapper .flexList2 > * {
  width: 45.37%;
}

#contentsWrapper .flexList2 > *:nth-child(even) {
  margin-left: 4.6%;
}

@media screen and (max-width: 800px) {
  #contentsWrapper .flexSplit > *,
  #contentsWrapper .flexList2 > * {
    width: 100%;
  }
  #contentsWrapper .flexList2 > *:nth-child(even) {
    margin-left: 0;
  }
}

#contentsWrapper .alignCenter {
  text-align: center;
}

#contentsWrapper .alignRight {
  text-align: right;
}

#contentsWrapper .alignLeft {
  text-align: left;
}

#contentsWrapper img.alignCenter {
  margin-left: auto;
  margin-right: auto;
}

#contentsWrapper img.alignLeft {
  margin-left: 0;
  margin-right: auto;
}

#contentsWrapper img.alignRight {
  margin-left: auto;
  margin-right: 0;
}

#contentsWrapper .mt-10 {
  margin-top: 1em !important;
}

#contentsWrapper .mt-15 {
  margin-top: 1.5em !important;
}

#contentsWrapper .mt-20 {
  margin-top: 2em !important;
}

#contentsWrapper .mt-25 {
  margin-top: 2.5em !important;
}

#contentsWrapper .mt-30 {
  margin-top: 3em !important;
}

#contentsWrapper .mt-35 {
  margin-top: 3.5em !important;
}

#contentsWrapper .mt-40 {
  margin-top: 4em !important;
}

#contentsWrapper .mt-45 {
  margin-top: 4.5em !important;
}

#contentsWrapper .mt-50 {
  margin-top: 5em !important;
}

#contentsWrapper .font-10 {
  font-size: 1rem !important;
  line-height: 2rem;
}

#contentsWrapper .font-12 {
  font-size: 1.2rem !important;
  line-height: 2.2rem;
}

#contentsWrapper .font-14 {
  font-size: 1.4rem !important;
  line-height: 2.4rem;
}

#contentsWrapper .font-16 {
  font-size: 1.6rem !important;
  line-height: 2.6rem;
}

#contentsWrapper .font-18 {
  font-size: 1.8rem !important;
  line-height: 2.8rem;
}

#contentsWrapper .font-20 {
  font-size: 2rem !important;
  line-height: 3rem;
}

#contentsWrapper .font-22 {
  font-size: 2.2rem !important;
  line-height: 3.2rem;
}

#contentsWrapper .font-24 {
  font-size: 2.4rem !important;
  line-height: 3.4rem;
}

#contentsWrapper .font-26 {
  font-size: 2.6rem !important;
  line-height: 3.6rem;
}

#contentsWrapper .font-28 {
  font-size: 2.8rem !important;
  line-height: 3.8rem;
}

#contentsWrapper .font-30 {
  font-size: 3rem !important;
  line-height: 4rem;
}

@media screen and (min-width: 801px) and (max-width: 1500px) {
  #contentsWrapper .font-10 {
    font-size: 0.83333vw !important;
  }
  #contentsWrapper .font-12 {
    font-size: 1vw !important;
  }
  #contentsWrapper .font-14 {
    font-size: 1.16667vw !important;
  }
  #contentsWrapper .font-16 {
    font-size: 1.33333vw !important;
  }
  #contentsWrapper .font-18 {
    font-size: 1.5vw !important;
  }
  #contentsWrapper .font-20 {
    font-size: 1.66667vw !important;
  }
  #contentsWrapper .font-22 {
    font-size: 1.83333vw !important;
  }
  #contentsWrapper .font-24 {
    font-size: 2vw !important;
  }
  #contentsWrapper .font-26 {
    font-size: 2.16667vw !important;
  }
  #contentsWrapper .font-28 {
    font-size: 2.33333vw !important;
  }
  #contentsWrapper .font-30 {
    font-size: 2.5vw !important;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .font-10 {
    font-size: 1.25vw !important;
  }
  #contentsWrapper .font-12 {
    font-size: 1.5vw !important;
  }
  #contentsWrapper .font-14 {
    font-size: 1.75vw !important;
  }
  #contentsWrapper .font-16 {
    font-size: 2vw !important;
  }
  #contentsWrapper .font-18 {
    font-size: 2.25vw !important;
  }
  #contentsWrapper .font-20 {
    font-size: 2.5vw !important;
  }
  #contentsWrapper .font-22 {
    font-size: 2.75vw !important;
  }
  #contentsWrapper .font-24 {
    font-size: 3vw !important;
  }
  #contentsWrapper .font-26 {
    font-size: 3.25vw !important;
  }
  #contentsWrapper .font-28 {
    font-size: 3.5vw !important;
  }
  #contentsWrapper .font-30 {
    font-size: 3.75vw !important;
  }
}

#contentsWrapper .font-reiminM {
  font-family: "黎ミン M", "Reimin Medium", serif;
  font-weight: 500;
}

#contentsWrapper .font-reiminB {
  font-family: "黎ミン B", "Reimin Bold", serif;
  font-weight: 600;
}

#contentsWrapper .font-reiminEB {
  font-family: "黎ミン EB", "Reimin ExtraBold", serif;
  font-weight: 700;
}

#contentsWrapper .u-link {
  color: #0091de;
  border-bottom: 1px solid currentColor;
  padding-bottom: 0.1em;
}

#contentsWrapper .u-link:hover {
  border-bottom: none;
}

@media screen and (max-width: 800px) {
  #contentsWrapper .u-link {
    padding-bottom: 0;
  }
}

#contentsWrapper .u-note {
  padding-left: 1em;
  text-indent: -1em;
  display: inline-block;
}

#contentsWrapper .u-marker {
  padding: 0 0.2em;
  margin: 0 0.2em;
  background: var(--maincolor);
  color: #fff;
}

#contentsWrapper .u-hidden {
  display: none;
  visibility: hidden;
}

#contentsWrapper .blockLink a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#contentsWrapper [data-ruby] {
  position: relative;
  display: inline-block;
  line-height: 1;
}

#contentsWrapper [data-ruby]:before {
  content: attr(data-ruby);
  position: absolute;
  top: -1.2em;
  left: 50%;
  font-size: max(0.3em,8px);
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  line-height: 1;
  text-align: center;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  white-space: nowrap;
}

#contentsWrapper .icon {
  width: 1em;
  height: 1em;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

#contentsWrapper .icon-x {
  background-image: url(../images/icon_x.svg);
}

@media screen and (min-width: 801px) {
  #contentsWrapper .sp {
    display: none !important;
  }
  #contentsWrapper a[href^="tel:"] {
    pointer-events: none;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .pc {
    display: none !important;
  }
}

#includeFooter {
  position: relative;
  z-index: 11;
}

/* ======== ↑ End common ↑ ======== */
/* ======== ↓ main ↓ ======== */
#includeHeader,
#specialHeader {
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}

.specialHeaderMargin {
  min-height: 100vh;
}

#contentsWrapper {
  position: relative;
  /* top */
  /* world */
  /* story */
  /* character */
  /* concept */
  /* items */
  /* gallery */
  /* build */
}

#contentsWrapper .js-loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #000;
  z-index: 9999;
  pointer-events: none;
  -webkit-transition: 1s ease 0.1s;
  transition: 1s ease 0.1s;
}

#contentsWrapper .js-loading .inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: 1s ease 0.1s;
  transition: 1s ease 0.1s;
}

#contentsWrapper .js-loading img {
  width: 400px;
  max-width: 80vw;
}

#contentsWrapper .js-loading .txt {
  font-size: 20px;
  text-align: center;
  color: #fff;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding-left: 2em;
  position: relative;
}

#contentsWrapper .js-loading .txt:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 1.5em;
  height: 1.5em;
  background: url(../images/heading_gear.svg) no-repeat center/contain;
  -webkit-animation: gearCW 2s linear 0s infinite normal forwards running;
          animation: gearCW 2s linear 0s infinite normal forwards running;
}

#contentsWrapper .js-loading.is-loading {
  opacity: 0;
}

#contentsWrapper .js-loading.is-loading .inner {
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

#contentsWrapper .js-transition {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #000;
  -webkit-mask-image: -webkit-gradient(linear, right top, left top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
  -webkit-mask-image: linear-gradient(-90deg, transparent 33.33%, #000 66.66%);
          mask-image: -webkit-gradient(linear, right top, left top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
          mask-image: linear-gradient(-90deg, transparent 33.33%, #000 66.66%);
  -webkit-mask-size: 300%;
          mask-size: 300%;
  -webkit-mask-position: 100%;
          mask-position: 100%;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  pointer-events: none;
  z-index: 9999;
}

#contentsWrapper .js-transition.is-transition {
  -webkit-mask-position: 0%;
          mask-position: 0%;
}

#contentsWrapper .c-parallax {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100vh;
  background: url(../images/body_bg.jpg) no-repeat center top/cover;
  z-index: -1;
}

#contentsWrapper h2.heading {
  font-size: 48px;
  font-weight: normal;
  text-align: center;
  line-height: 1.3;
  letter-spacing: 0.1em;
  text-indent: 0.1em;
  padding: 0 0.8em;
  margin: 0 auto;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

#contentsWrapper h2.heading:before, #contentsWrapper h2.heading:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 0.675em;
  height: 0.675em;
  background: url(../images/heading_gear.svg) no-repeat center/contain;
}

#contentsWrapper h2.heading:before {
  left: 0;
  -webkit-animation: gearCW 15s linear 0s infinite normal forwards running;
          animation: gearCW 15s linear 0s infinite normal forwards running;
}

#contentsWrapper h2.heading:after {
  right: 0;
  -webkit-animation: gearCCW 15s linear 0s infinite normal forwards running;
          animation: gearCCW 15s linear 0s infinite normal forwards running;
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper h2.heading {
    font-size: 4vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper h2.heading {
    font-size: 9.6vw;
  }
}

#contentsWrapper .c-btn a {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  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;
  width: 100%;
  max-width: 298px;
  aspect-ratio: 1 / 0.1476;
  color: #fff;
  background: url(../images/btn_bg.png) no-repeat center/100% 100%;
  padding: 0.25em 1em;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

#contentsWrapper .c-btn a:hover {
  background-image: url(../images/btn_bg_focus.png);
}

#contentsWrapper .c-btn a.left {
  margin-left: 0;
  margin-right: auto;
}

#contentsWrapper .c-btn a.right {
  margin-left: auto;
  margin-right: 0;
}

#contentsWrapper .c-btn a.center {
  margin-left: auto;
  margin-right: auto;
}

#contentsWrapper .c-btn a.orange:hover {
  background-image: url(../images/btn_bg_focus_orange.png);
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .c-btn a {
    font-size: 1.8vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .c-btn a {
    font-size: min(4vw,18px);
  }
}

#contentsWrapper .c-frame {
  background: rgba(235, 234, 234, 0.64);
  position: relative;
  margin-top: 0.834%;
  margin-bottom: 0.834%;
}

#contentsWrapper .c-frame:before, #contentsWrapper .c-frame:after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  aspect-ratio: 1 / 0.00834;
}

#contentsWrapper .c-frame:before {
  bottom: 100%;
  background: url(../images/concept_blockBg_top.png) no-repeat center bottom/contain;
}

#contentsWrapper .c-frame:after {
  top: 100%;
  background: url(../images/concept_blockBg_bottom.png) no-repeat center top/contain;
}

#contentsWrapper .c-frame.black {
  color: #fff;
  background: rgba(8, 8, 8, 0.64);
}

#contentsWrapper .c-frame.black:before {
  background-image: url(../images/frameBg_top_black.png);
}

#contentsWrapper .c-frame.black:after {
  background-image: url(../images/frameBg_bottom_black.png);
}

#contentsWrapper .c-countdown {
  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;
  font-size: 6vw;
  font-weight: bold;
  font-family: "Teko", sans-serif;
  line-height: 1;
  letter-spacing: 0.1em;
  text-align: justify;
  background: -webkit-gradient(linear, left top, left bottom, from(#bfaa5e), to(#e6d38f));
  background: linear-gradient(#bfaa5e, #e6d38f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
  z-index: 2;
}

#contentsWrapper .c-countdown > * {
  position: relative;
  width: 9.5vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: -webkit-gradient(linear, left top, left bottom, from(#bfaa5e), to(#e6d38f));
  background: linear-gradient(#bfaa5e, #e6d38f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

#contentsWrapper .c-countdown > *:after {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  margin: auto;
  font-size: 25%;
  text-align: center;
  letter-spacing: 0;
  -webkit-text-fill-color: #d4c079;
}

#contentsWrapper .c-countdown .day:after {
  content: 'Days';
}

#contentsWrapper .c-countdown .hour:after {
  content: 'Hours';
}

#contentsWrapper .c-countdown .min:after {
  content: 'Mins';
}

#contentsWrapper .c-countdown .sec:after {
  content: 'Secs';
}

@media screen and (max-width: 800px) {
  #contentsWrapper .c-countdown {
    font-size: 12vw;
  }
  #contentsWrapper .c-countdown > * {
    width: 17.5vw;
  }
}

#contentsWrapper #particle {
  position: fixed;
  top: 0;
  left: -100%;
  right: -100%;
  bottom: 0;
  margin: auto;
  z-index: 1;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 800px) {
  #contentsWrapper #particle {
    width: auto;
    height: 100%;
  }
}

#contentsWrapper .parallaxWrapper .layer1 {
  width: 100%;
  -webkit-transition: 4s cubic-bezier(0.25, 1, 0.25, 1);
  transition: 4s cubic-bezier(0.25, 1, 0.25, 1);
  position: relative;
  z-index: 1;
}

#contentsWrapper .parallaxWrapper .layer2 {
  width: 100%;
  -webkit-transition: 4s cubic-bezier(0.25, 1, 0.25, 1);
  transition: 4s cubic-bezier(0.25, 1, 0.25, 1);
  position: relative;
  z-index: 2;
}

#contentsWrapper .parallaxWrapper .layer3 {
  width: 100%;
  -webkit-transition: 4s cubic-bezier(0.25, 1, 0.25, 1);
  transition: 4s cubic-bezier(0.25, 1, 0.25, 1);
  position: relative;
  z-index: 3;
}

#contentsWrapper .js-mouseStalker {
  position: fixed;
  top: -10px;
  left: -10px;
  z-index: 1;
  -webkit-transition: 0.5s cubic-bezier(0, 0.66, 0.33, 1);
  transition: 0.5s cubic-bezier(0, 0.66, 0.33, 1);
}

#contentsWrapper .js-mouseStalker > * {
  width: 20px;
  height: 20px;
  background: var(--maincolor);
  -webkit-filter: blur(5px) drop-shadow(0 0 10px var(--maincolor));
          filter: blur(5px) drop-shadow(0 0 10px var(--maincolor));
  border-radius: 50%;
  -webkit-animation: blinkingStalker 1s ease 0s infinite normal forwards running;
          animation: blinkingStalker 1s ease 0s infinite normal forwards running;
}

@media screen and (max-width: 800px) {
  #contentsWrapper .js-mouseStalker {
    display: none !important;
  }
}

#contentsWrapper .bnr-slider img {
  margin: 0 auto;
  padding: 0 5px;
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}

#contentsWrapper .bnr-slider .slick-slide {
  -webkit-transition: 1s ease;
  transition: 1s ease;
}

#contentsWrapper .bnr-slider .slick-slide:hover img {
  -webkit-filter: brightness(110%);
          filter: brightness(110%);
}

#contentsWrapper .bnr-slider .slick-dots {
  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;
  margin-top: 20px;
}

#contentsWrapper .bnr-slider .slick-dots li {
  line-height: 0;
  margin: 0 10px;
}

#contentsWrapper .bnr-slider .slick-dots li.slick-active button {
  background: #f14400;
}

#contentsWrapper .bnr-slider .slick-dots button {
  font-size: 0;
  width: 16px;
  height: 16px;
  background: #616161;
  border: none;
  border-radius: 50%;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contentsWrapper .bnr-slider.off .slick-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: -webkit-fit-content !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
  -webkit-transform: none !important;
          transform: none !important;
  margin: 0 auto;
}

#contentsWrapper .bnr-slider.off .slick-track > * {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .bnr-slider.off .slick-slide {
    width: auto !important;
    max-width: 207px !important;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .bnr-slider {
    margin-left: -15px;
    margin-right: -15px;
  }
  #contentsWrapper .bnr-slider img {
    width: 100%;
  }
  #contentsWrapper .bnr-slider .slick-slide {
    margin: 0 15px;
  }
  #contentsWrapper .bnr-slider.off .slick-slide {
    margin: 0 7.5px;
  }
}

#contentsWrapper .c-tab_contentWrap {
  position: relative;
}

#contentsWrapper .c-tab_content:not(.active) {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
}

#contentsWrapper .c-tabTypeA .c-tab_navWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  padding-bottom: 5px;
  border-bottom: 2px solid var(--maincolor);
}

#contentsWrapper .c-tabTypeA .c-tab_nav {
  line-height: 1.3;
  text-align: center;
  color: #fff;
  background: url(../images/story_btn_bg.png) no-repeat center/100% 100%;
  width: 291px;
  aspect-ratio: 1 / 0.1856;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contentsWrapper .c-tabTypeA .c-tab_nav .chapter {
  font-size: 87.5%;
  display: block;
}

#contentsWrapper .c-tabTypeA .c-tab_nav.active {
  background-image: url(../images/story_btn_bg_active.png);
}

#contentsWrapper .c-tabTypeA .c-tab_contentWrap {
  margin-top: 50px;
}

#contentsWrapper .c-tabTypeA .c-tab_content .p-story1_bg {
  -webkit-transition: 1s ease 0.6s;
  transition: 1s ease 0.6s;
}

#contentsWrapper .c-tabTypeA .c-tab_content:not(.active) {
  opacity: 0;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
}

#contentsWrapper .c-tabTypeA .c-tab_content:not(.active) .p-story1_bg {
  opacity: 0;
}

#contentsWrapper .c-tabTypeA .c-tab_content.active {
  -webkit-transition: 0.6s ease 0.1s;
  transition: 0.6s ease 0.1s;
  opacity: 1;
  -webkit-filter: none;
          filter: none;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .c-tabTypeA .c-tab_content.active .p-story1_bg {
  opacity: 1;
}

#contentsWrapper .c-tabTypeA.js-scroll .c-tab {
  -webkit-transition: 1s ease 0.5s;
  transition: 1s ease 0.5s;
  opacity: 0;
  -webkit-filter: blur(5px);
          filter: blur(5px);
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}

#contentsWrapper .c-tabTypeA.is-scroll .c-tab {
  opacity: 1;
  -webkit-filter: none;
          filter: none;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .c-tabTypeA .c-tab_nav {
    max-width: calc(calc(100% - 20px) / 3);
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .c-tabTypeA .c-tab_navWrap {
    gap: 2vw 4%;
  }
  #contentsWrapper .c-tabTypeA .c-tab_nav {
    font-size: 2.5vw;
    width: 48%;
  }
  #contentsWrapper .c-tabTypeA .c-tab_contentWrap {
    margin-top: 10%;
  }
}

@media screen and (min-width: 801px) {
  #contentsWrapper #globalMenu {
    height: auto !important;
  }
  #contentsWrapper #globalMenu .parent {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #contentsWrapper #globalMenu .parent > li {
    position: relative;
  }
  #contentsWrapper #globalMenu .parent > li > a {
    font-size: 20px;
    font-weight: 500;
    text-align: center;
    color: #fff;
    display: block;
    -webkit-transition: 0.15s;
    transition: 0.15s;
    position: relative;
    z-index: 1;
  }
  #contentsWrapper #globalMenu .parent > li > a .paint {
    -webkit-mask-image: -webkit-gradient(linear, right top, left top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
    -webkit-mask-image: linear-gradient(-90deg, transparent 33.33%, #000 66.66%);
            mask-image: -webkit-gradient(linear, right top, left top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
            mask-image: linear-gradient(-90deg, transparent 33.33%, #000 66.66%);
    -webkit-mask-size: 300%;
            mask-size: 300%;
    -webkit-mask-position: 100%;
            mask-position: 100%;
    position: absolute;
    top: 0.25em;
    left: -300%;
    right: -300%;
    bottom: 0;
    margin: auto;
    width: 144px;
    aspect-ratio: 1 / 0.507;
    z-index: -1;
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  #contentsWrapper #globalMenu .parent > li > a .paint:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../images/gnav_focus.png) no-repeat center/contain;
  }
  #contentsWrapper #globalMenu .parent > li > a:not([href]) {
    opacity: 0.5;
    pointer-events: none;
  }
  #contentsWrapper #globalMenu .parent > li > a:hover .paint {
    -webkit-mask-position: 0%;
            mask-position: 0%;
  }
  #contentsWrapper #globalMenu .parent > li > a .icon {
    font-size: 120%;
  }
  #contentsWrapper #globalMenu .parent > li > a .icon:hover {
    opacity: 0.7;
  }
  #contentsWrapper #globalMenu .parent > li:not(:last-child) {
    margin-right: 3.8em;
  }
  #contentsWrapper #globalMenu .parent > li.current > a .paint {
    -webkit-mask-position: 0%;
            mask-position: 0%;
  }
  #contentsWrapper #globalMenu .parent > li.has-children:hover .child {
    opacity: 1;
    -webkit-mask-position: 0%;
            mask-position: 0%;
    pointer-events: auto;
    -webkit-transform: none;
            transform: none;
  }
  #contentsWrapper #globalMenu .child {
    position: absolute;
    top: 100%;
    left: 0;
    color: #fff;
    background: #000;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    z-index: 1;
    opacity: 0;
    -webkit-mask-image: -webkit-gradient(linear, left top, right top, color-stop(45%, #000), color-stop(55%, transparent));
    -webkit-mask-image: linear-gradient(to right, #000 45%, transparent 55%);
            mask-image: -webkit-gradient(linear, left top, right top, color-stop(45%, #000), color-stop(55%, transparent));
            mask-image: linear-gradient(to right, #000 45%, transparent 55%);
    -webkit-mask-size: 300%;
            mask-size: 300%;
    -webkit-mask-position: 100%;
            mask-position: 100%;
    pointer-events: none;
    -webkit-transform: translateY(-20px);
            transform: translateY(-20px);
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  #contentsWrapper #globalMenu .child a {
    display: block;
    padding: 0.5em 1em;
  }
  #contentsWrapper #globalMenu .child a:hover {
    background: rgba(255, 255, 255, 0.3);
  }
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper #globalMenu .parent > li > a .paint {
    width: 9.6vw;
  }
}

@media screen and (min-width: 801px) and (max-width: 1500px) {
  #contentsWrapper #globalMenu .parent > li > a {
    font-size: 1.33vw;
  }
  #contentsWrapper #globalMenu .parent > li:not(:last-child) {
    margin-right: 3.8vw;
  }
  #contentsWrapper #globalMenu .child > li > a {
    font-size: 1.33vw;
  }
}

@media screen and (min-width: 1501px) {
  #contentsWrapper #globalMenu .parent > li {
    letter-spacing: 0.2em;
  }
  #contentsWrapper #globalMenu .parent > li:not(:last-child) {
    margin-right: 4vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper #globalMenu {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.85);
    padding: 6vw;
    z-index: 102;
    overflow: scroll;
    opacity: 0;
    pointer-events: none;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  #contentsWrapper #globalMenu .parent {
    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-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
  }
  #contentsWrapper #globalMenu .parent > li:not(:first-child) {
    margin-top: 1em;
    padding-top: 1em;
    position: relative;
  }
  #contentsWrapper #globalMenu .parent > li:not(:first-child):before {
    content: '';
    position: absolute;
    top: 0;
    left: -50vw;
    right: -50vw;
    margin: auto;
    width: 92vw;
    height: 1px;
    background: var(--maincolor);
  }
  #contentsWrapper #globalMenu .parent > li > a {
    font-size: 6.4vw;
  }
  #contentsWrapper #globalMenu .parent > li > a:not([href]) {
    opacity: 0.5;
    pointer-events: none;
  }
  #contentsWrapper #globalMenu .child {
    text-align: center;
  }
  #contentsWrapper #globalMenu .child > li > a {
    font-size: 4vw;
    display: block;
    margin-top: 0.5em;
  }
  .is-menuOpen #contentsWrapper #globalMenu {
    opacity: 1;
    pointer-events: auto;
  }
}

#contentsWrapper .l-header {
  padding: 7px 3.5vw;
  background: url(../images/header_bg.jpg) no-repeat center right/cover;
  width: 100%;
  z-index: 101;
}

#contentsWrapper .l-header.fixed {
  position: fixed;
  top: 0;
  left: 0;
}

#contentsWrapper .l-header .logo {
  width: 220px;
  max-width: 20vw;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .l-header_inner {
    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: 800px) {
  #contentsWrapper .l-header {
    padding: 2vw 3.5vw;
    background-image: url(../images/header_bg_sp.jpg);
  }
  #contentsWrapper .l-header .logo {
    width: 575px;
    max-width: 57.5vw;
  }
}

#contentsWrapper .hamburger {
  position: absolute;
  top: 5.5vw;
  right: 3.5vw;
  width: 13vw;
  height: 7.7vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  z-index: 203;
  cursor: pointer;
}

#contentsWrapper .hamburger span {
  position: absolute;
  right: 0;
  margin: auto;
  width: 100%;
  height: 0.6vw;
  background: #fff;
  display: block;
  -webkit-transition: .5s;
  transition: .5s;
}

#contentsWrapper .hamburger span:nth-child(1) {
  top: 0;
  bottom: auto;
}

#contentsWrapper .hamburger span:nth-child(2) {
  top: 0;
  bottom: 0;
  width: 75%;
}

#contentsWrapper .hamburger span:nth-child(3) {
  top: auto;
  bottom: 0;
  width: 52%;
}

.is-menuOpen #contentsWrapper .hamburger span {
  width: 100%;
}

.is-menuOpen #contentsWrapper .hamburger span:nth-child(1) {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  bottom: 0;
}

.is-menuOpen #contentsWrapper .hamburger span:nth-child(2) {
  -webkit-transform: scaleY(0);
          transform: scaleY(0);
  opacity: 0;
}

.is-menuOpen #contentsWrapper .hamburger span:nth-child(3) {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  top: 0;
}

#contentsWrapper .p-countdown {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  background: #0b0b0b url(../images/countdown_bg02.png) no-repeat center top/cover;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#contentsWrapper .p-countdown .logo {
  margin-top: 1.5%;
  margin: 1.5% auto 0;
  width: 67.08%;
  position: relative;
  z-index: 2;
}

#contentsWrapper .p-countdown .logo img {
  width: 100%;
  max-width: none;
}

#contentsWrapper .p-countdown .bg1 {
  position: absolute;
  top: 2.8%;
  left: -50.5%;
  right: -50%;
  bottom: 0;
  margin: auto;
  width: 68.99%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  mix-blend-mode: lighten;
  z-index: 1;
}

#contentsWrapper .p-countdown .bg1 img {
  width: 100%;
  max-width: none;
  -webkit-animation: blinking 3s ease-in-out 0s infinite alternate forwards running;
          animation: blinking 3s ease-in-out 0s infinite alternate forwards running;
}

#contentsWrapper .p-countdown .c-countdown {
  margin-top: 1%;
}

#contentsWrapper .p-countdown.js-scroll .logo {
  opacity: 0;
  -webkit-transition: 1s ease 1.5s;
  transition: 1s ease 1.5s;
  -webkit-transform: translateY(5%);
          transform: translateY(5%);
  -webkit-filter: blur(5px);
          filter: blur(5px);
}

#contentsWrapper .p-countdown.js-scroll .bg1 {
  opacity: 0;
  -webkit-transition: 2s ease 1.0s;
  transition: 2s ease 1.0s;
  -webkit-filter: blur(5px);
          filter: blur(5px);
}

#contentsWrapper .p-countdown.js-scroll .c-countdown {
  opacity: 0;
  -webkit-transition: 0.8s ease 2s;
  transition: 0.8s ease 2s;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  -webkit-filter: blur(5px);
          filter: blur(5px);
}

#contentsWrapper .p-countdown.is-scroll .logo {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
  -webkit-filter: none;
          filter: none;
}

#contentsWrapper .p-countdown.is-scroll .bg1 {
  opacity: 1;
  -webkit-filter: none;
          filter: none;
}

#contentsWrapper .p-countdown.is-scroll .c-countdown {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
  -webkit-filter: none;
          filter: none;
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-countdown .logo {
    width: 92%;
  }
  #contentsWrapper .p-countdown .bg1 {
    width: 117%;
  }
}

#contentsWrapper .p-kv {
  padding-top: 46.933%;
  position: relative;
  z-index: 1;
}

#contentsWrapper .p-kv_img.switchImg {
  cursor: pointer;
}

#contentsWrapper .p-kv_img > *:not(.js-parallax) {
  position: absolute;
  margin: auto;
}

#contentsWrapper .p-kv_img .js-parallax > * {
  position: fixed;
}

#contentsWrapper .p-kv_img .js-parallax .gear1 {
  top: -8.6vw;
}

#contentsWrapper .p-kv_img .js-parallax .gear2 {
  top: 22.9vw;
}

#contentsWrapper .p-kv_img .js-parallax .gear3 {
  top: 28.4vw;
}

#contentsWrapper .p-kv_img .js-parallax .gear4 {
  top: 16.9vw;
}

#contentsWrapper .p-kv_img .js-parallax .gear5 {
  top: 31.9vw;
}

#contentsWrapper .p-kv_img .js-parallax .gear6 {
  top: 36.7vw;
}

#contentsWrapper .p-kv_img .js-parallax .paint {
  top: 5vw;
}

#contentsWrapper .p-kv_img .js-parallax .main {
  top: 14vw;
}

#contentsWrapper .p-kv_img .js-parallax .chara1 {
  top: 26.9vw;
}

#contentsWrapper .p-kv_img .js-parallax .chara2 {
  top: 20.6vw;
}

#contentsWrapper .p-kv_img .js-parallax .chara3 {
  top: 16.7vw;
}

#contentsWrapper .p-kv_img .js-parallax .chara4 {
  top: 8.8vw;
}

#contentsWrapper .p-kv_img .js-parallax .chara5 {
  top: 3vw;
}

#contentsWrapper .p-kv_img .js-parallax .catchL {
  top: 12.2vw;
}

#contentsWrapper .p-kv_img .js-parallax .catchR {
  top: 12.2vw;
}

#contentsWrapper .p-kv_img .js-parallax .bnr {
  top: 41vw;
}

#contentsWrapper .p-kv_img img {
  width: 100%;
  max-width: none;
  -webkit-transition: 2s cubic-bezier(0, 1, 0.5, 1);
  transition: 2s cubic-bezier(0, 1, 0.5, 1);
}

#contentsWrapper .p-kv_img .bg {
  position: fixed;
  top: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100vh;
  background: url(../images/kv_bg.jpg) no-repeat center/cover;
  z-index: -1;
}

#contentsWrapper .p-kv_img .gear1 {
  top: -37%;
  left: -20.6%;
  width: 36.53%;
}

#contentsWrapper .p-kv_img .gear1 img {
  -webkit-animation: gearCW 150s linear 0s infinite normal forwards running;
          animation: gearCW 150s linear 0s infinite normal forwards running;
}

#contentsWrapper .p-kv_img .gear2 {
  top: 30.1%;
  left: 8.7%;
  width: 7.93%;
}

#contentsWrapper .p-kv_img .gear2 img {
  -webkit-animation: gearCCW 30s linear 0s infinite normal forwards running;
          animation: gearCCW 30s linear 0s infinite normal forwards running;
}

#contentsWrapper .p-kv_img .gear3 {
  top: 41.8%;
  left: -6.6%;
  width: 19.7%;
}

#contentsWrapper .p-kv_img .gear3 img {
  -webkit-animation: gearCW 90s linear 0s infinite normal forwards running;
          animation: gearCW 90s linear 0s infinite normal forwards running;
}

#contentsWrapper .p-kv_img .gear4 {
  top: 17.4%;
  right: -8.6%;
  width: 19.34%;
}

#contentsWrapper .p-kv_img .gear4 img {
  -webkit-animation: gearCCW 90s linear 0s infinite normal forwards running;
          animation: gearCCW 90s linear 0s infinite normal forwards running;
}

#contentsWrapper .p-kv_img .gear5 {
  top: 49.4%;
  right: 7.6%;
  width: 8.1%;
}

#contentsWrapper .p-kv_img .gear5 img {
  -webkit-animation: gearCW 30s linear 0s infinite normal forwards running;
          animation: gearCW 30s linear 0s infinite normal forwards running;
}

#contentsWrapper .p-kv_img .gear6 {
  top: 59.7%;
  right: -12.1%;
  width: 26.68%;
}

#contentsWrapper .p-kv_img .gear6 img {
  -webkit-animation: gearCCW 120s linear 0s infinite normal forwards running;
          animation: gearCCW 120s linear 0s infinite normal forwards running;
}

#contentsWrapper .p-kv_img .glow {
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
}

#contentsWrapper .p-kv_img .paint {
  top: -7.3%;
  left: 11.6%;
  width: 77.31%;
}

#contentsWrapper .p-kv_img .catchL {
  top: 7.4%;
  left: 17%;
  width: 7.08%;
}

#contentsWrapper .p-kv_img .catchR {
  top: 7.5%;
  right: 16.9%;
  width: 6.84%;
}

#contentsWrapper .p-kv_img .main {
  top: 4.3%;
  left: 25.9%;
  width: 48.125%;
}

#contentsWrapper .p-kv_img .chara1 {
  top: 42%;
  left: 31.3%;
  width: 25.7%;
}

#contentsWrapper .p-kv_img .chara2 {
  top: 29.4%;
  left: 47.9%;
  width: 24.18%;
}

#contentsWrapper .p-kv_img .chara3 {
  top: 21.9%;
  left: 28%;
  width: 26.68%;
}

#contentsWrapper .p-kv_img .chara4 {
  top: 12.3%;
  left: 49.4%;
  width: 14.22%;
}

#contentsWrapper .p-kv_img .chara5 {
  top: 0%;
  left: 38.7%;
  width: 17.3%;
}

#contentsWrapper .p-kv_img .chara6 {
  top: 19.1%;
  left: 39.4%;
  width: 19.26%;
}

#contentsWrapper .p-kv_img .chara7 {
  top: 13%;
  left: 24.1%;
  width: 18.125%;
}

#contentsWrapper .p-kv_img .chara8 {
  top: 13%;
  left: 55.7%;
  width: 19.03%;
}

#contentsWrapper .p-kv_img .bnr {
  top: 74.6%;
  left: 30.4%;
  width: 39.2%;
}

#contentsWrapper .p-kv_img .is-sideC .chara1 {
  top: 8.5vw !important;
  left: 20.3%;
  width: 34.921875%;
}

#contentsWrapper .p-kv_img .is-sideC .chara2 {
  top: 13.9vw !important;
  left: 49.2%;
  width: 27.7734375%;
}

#contentsWrapper .p-kv_img .is-sideG .chara1 {
  top: 4vw !important;
  left: 24.7%;
  width: 30.9765625%;
}

#contentsWrapper .p-kv_img .is-sideG .chara2 {
  top: 13.9vw !important;
  left: 47.9%;
  width: 28.828125%;
}

#contentsWrapper .p-kv_scroll {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 12%;
  margin: auto;
  font-size: 1.6vw;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  text-align: center;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

#contentsWrapper .p-kv_scroll:before {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin: auto;
  width: 1px;
  height: 2em;
  background: currentColor;
}

#contentsWrapper .p-kv_scroll:after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin: auto;
  width: 0.5em;
  height: 0.5em;
  background: currentColor;
  border-radius: 50%;
  -webkit-animation: kvScroll 1.5s ease-in-out 0s infinite normal forwards running;
          animation: kvScroll 1.5s ease-in-out 0s infinite normal forwards running;
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .gear1, #contentsWrapper .p-kv.js-scroll .p-kv_img .gear2, #contentsWrapper .p-kv.js-scroll .p-kv_img .gear3, #contentsWrapper .p-kv.js-scroll .p-kv_img .gear4, #contentsWrapper .p-kv.js-scroll .p-kv_img .gear5, #contentsWrapper .p-kv.js-scroll .p-kv_img .gear6 {
  -webkit-transition: 1s ease 0.3s;
  transition: 1s ease 0.3s;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  -webkit-filter: blur(5px);
          filter: blur(5px);
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .glow {
  opacity: 0;
  -webkit-transition: 2s ease 1.5s;
  transition: 2s ease 1.5s;
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .paint {
  -webkit-mask-image: -webkit-gradient(linear, left top, right top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
  -webkit-mask-image: linear-gradient(90deg, transparent 33.33%, #000 66.66%);
          mask-image: -webkit-gradient(linear, left top, right top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
          mask-image: linear-gradient(90deg, transparent 33.33%, #000 66.66%);
  -webkit-mask-size: 300%;
          mask-size: 300%;
  -webkit-mask-position: 0%;
          mask-position: 0%;
  -webkit-transition: 1s ease 1s;
  transition: 1s ease 1s;
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .main, #contentsWrapper .p-kv.js-scroll .p-kv_img .chara1, #contentsWrapper .p-kv.js-scroll .p-kv_img .chara2, #contentsWrapper .p-kv.js-scroll .p-kv_img .chara3, #contentsWrapper .p-kv.js-scroll .p-kv_img .chara4, #contentsWrapper .p-kv.js-scroll .p-kv_img .chara5, #contentsWrapper .p-kv.js-scroll .p-kv_img .chara6 {
  -webkit-transition: 1.5s cubic-bezier(0.1, 1, 0.25, 1) 1.5s;
  transition: 1.5s cubic-bezier(0.1, 1, 0.25, 1) 1.5s;
  opacity: 0;
  -webkit-transform: translateY(10%);
          transform: translateY(10%);
  -webkit-filter: brightness(250%) blur(5px);
          filter: brightness(250%) blur(5px);
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .chara5 {
  -webkit-transition: 1.5s cubic-bezier(0.15, 0, 0.25, 1) 2s;
  transition: 1.5s cubic-bezier(0.15, 0, 0.25, 1) 2s;
  -webkit-filter: brightness(500%) blur(5px);
          filter: brightness(500%) blur(5px);
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .chara7 {
  -webkit-transition: 1.5s cubic-bezier(0.1, 1, 0.25, 1) 1.5s;
  transition: 1.5s cubic-bezier(0.1, 1, 0.25, 1) 1.5s;
  opacity: 0;
  -webkit-transform: translate(10%, 10%);
          transform: translate(10%, 10%);
  -webkit-filter: brightness(250%) blur(5px);
          filter: brightness(250%) blur(5px);
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .chara8 {
  -webkit-transition: 1.5s cubic-bezier(0.1, 1, 0.25, 1) 1.5s;
  transition: 1.5s cubic-bezier(0.1, 1, 0.25, 1) 1.5s;
  opacity: 0;
  -webkit-transform: translate(-10%, 10%);
          transform: translate(-10%, 10%);
  -webkit-filter: brightness(250%) blur(5px);
          filter: brightness(250%) blur(5px);
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .catchL, #contentsWrapper .p-kv.js-scroll .p-kv_img .catchR {
  -webkit-transition: 2s cubic-bezier(0.1, 1, 0.25, 1) 2s;
  transition: 2s cubic-bezier(0.1, 1, 0.25, 1) 2s;
  opacity: 0;
  -webkit-transform: translateY(-10%);
          transform: translateY(-10%);
  -webkit-filter: brightness(0%) blur(5px);
          filter: brightness(0%) blur(5px);
}

#contentsWrapper .p-kv.js-scroll .p-kv_img .bnr {
  opacity: 0;
  -webkit-transition: 0.8s ease 2.5s;
  transition: 0.8s ease 2.5s;
}

#contentsWrapper .p-kv.js-scroll .p-kv_scroll {
  opacity: 0;
  -webkit-transition: 0.6s ease 3s;
  transition: 0.6s ease 3s;
}

#contentsWrapper .p-kv.is-scroll .p-kv_img .gear1, #contentsWrapper .p-kv.is-scroll .p-kv_img .gear2, #contentsWrapper .p-kv.is-scroll .p-kv_img .gear3, #contentsWrapper .p-kv.is-scroll .p-kv_img .gear4, #contentsWrapper .p-kv.is-scroll .p-kv_img .gear5, #contentsWrapper .p-kv.is-scroll .p-kv_img .gear6 {
  -webkit-transform: none;
          transform: none;
  -webkit-filter: none;
          filter: none;
}

#contentsWrapper .p-kv.is-scroll .p-kv_img .glow {
  opacity: 1;
}

#contentsWrapper .p-kv.is-scroll .p-kv_img .paint {
  -webkit-mask-position: 100%;
          mask-position: 100%;
}

#contentsWrapper .p-kv.is-scroll .p-kv_img .main, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara1, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara2, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara3, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara4, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara5, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara6, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara7, #contentsWrapper .p-kv.is-scroll .p-kv_img .chara8 {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
  -webkit-filter: none;
          filter: none;
}

#contentsWrapper .p-kv.is-scroll .p-kv_img .catchL, #contentsWrapper .p-kv.is-scroll .p-kv_img .catchR {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
  -webkit-filter: none;
          filter: none;
}

#contentsWrapper .p-kv.is-scroll .p-kv_img .bnr {
  opacity: 1;
}

#contentsWrapper .p-kv.is-scroll .p-kv_scroll {
  opacity: 1;
}

@media screen and (min-width: 1221px) {
  #contentsWrapper .p-kv_img .js-parallax .paint {
    top: 4.2vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .main {
    top: 12vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara1 {
    top: 26.9vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara2 {
    top: 20.6vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara3 {
    top: 16.7vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara4 {
    top: 8.8vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara5 {
    top: 3vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara6 {
    top: 11.7vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara7 {
    top: 8.35vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara8 {
    top: 8.35vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .catchL {
    top: 10.2vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .catchR {
    top: 10.2vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .bnr {
    top: 39vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-kv {
    padding-top: 131.3%;
  }
  #contentsWrapper .p-kv_img .js-parallax {
    position: fixed;
  }
  #contentsWrapper .p-kv_img .js-parallax .gear1 {
    top: 19.5vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .gear4 {
    top: 117.6vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .glow {
    top: 50vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .paint {
    top: 52vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .main {
    top: 69vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara1 {
    top: 93.5vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara2 {
    top: 78.3vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara3 {
    top: 69vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara4 {
    top: 50vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .chara5 {
    top: 37.3vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .catchL {
    top: 64.5vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .catchR {
    top: 64.5vw;
  }
  #contentsWrapper .p-kv_img .js-parallax .bnr {
    top: 133.2vw;
  }
  #contentsWrapper .p-kv_img .bg {
    background-image: url(../images/kv_bg_sp.jpg);
  }
  #contentsWrapper .p-kv_img .gear1 {
    top: -20.3%;
    left: -31.5%;
    width: 62.6%;
  }
  #contentsWrapper .p-kv_img .gear2 {
    display: none;
  }
  #contentsWrapper .p-kv_img .gear3 {
    display: none;
  }
  #contentsWrapper .p-kv_img .gear4 {
    top: 54.1%;
    right: -19.6%;
    width: 45.5%;
  }
  #contentsWrapper .p-kv_img .gear5 {
    display: none;
  }
  #contentsWrapper .p-kv_img .gear6 {
    display: none;
  }
  #contentsWrapper .p-kv_img .paint {
    top: -7.3%;
    left: -19.4%;
    width: 140.1%;
  }
  #contentsWrapper .p-kv_img .catchL {
    left: 3%;
    width: 12.3%;
  }
  #contentsWrapper .p-kv_img .catchR {
    right: 3%;
    width: 11.9%;
  }
  #contentsWrapper .p-kv_img .main {
    left: 0%;
    width: 100%;
  }
  #contentsWrapper .p-kv_img .chara1 {
    left: 2%;
    width: 61.8%;
  }
  #contentsWrapper .p-kv_img .chara2 {
    left: 42%;
    width: 58.1%;
  }
  #contentsWrapper .p-kv_img .chara3 {
    left: -6.1%;
    width: 64.2%;
  }
  #contentsWrapper .p-kv_img .chara4 {
    left: 45.5%;
    width: 34%;
  }
  #contentsWrapper .p-kv_img .chara5 {
    left: 20%;
    width: 41.5%;
  }
  #contentsWrapper .p-kv_img .chara6 {
    top: 32.5%;
    left: 24.4%;
    width: 44.9%;
  }
  #contentsWrapper .p-kv_img .chara7 {
    top: 21.4%;
    left: 5%;
    width: 42.2%;
  }
  #contentsWrapper .p-kv_img .chara8 {
    top: 21.4%;
    left: 52%;
    width: 39.1%;
  }
  #contentsWrapper .p-kv_img .bnr {
    left: 5%;
    width: 90%;
  }
  #contentsWrapper .p-kv_img .is-sideC .chara1 {
    top: 49.7vw !important;
    left: -10.5%;
    width: 80.5%;
  }
  #contentsWrapper .p-kv_img .is-sideC .chara2 {
    top: 78.8vw !important;
    left: 45.5%;
    width: 64%;
  }
  #contentsWrapper .p-kv_img .is-sideG .chara1 {
    top: 39.2vw !important;
    left: -0.2%;
    width: 71.4%;
  }
  #contentsWrapper .p-kv_img .is-sideG .chara2 {
    top: 78.8vw !important;
    left: 42.6%;
    width: 66.4%;
  }
  #contentsWrapper .p-kv_scroll {
    font-size: 5vw;
    bottom: 15%;
  }
}

#contentsWrapper .p-topMenu {
  padding: 40px 0;
  background: url(../images/top_bg01.jpg) no-repeat center/cover;
  position: relative;
  z-index: 2;
}

#contentsWrapper .p-topMenu .block1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
}

#contentsWrapper .p-topMenu_btn {
  font-size: 30px;
  width: 100%;
  margin: 0 auto;
  background: #252527;
  border: 2px solid #977001;
  overflow: hidden;
  position: relative;
}

#contentsWrapper .p-topMenu_btn.blue {
  background: -webkit-gradient(linear, left top, right top, from(#252527), to(#01436a));
  background: linear-gradient(90deg, #252527, #01436a);
}

#contentsWrapper .p-topMenu_btn.red {
  background: -webkit-gradient(linear, left top, right top, from(#252527), to(#5e133d));
  background: linear-gradient(90deg, #252527, #5e133d);
}

#contentsWrapper .p-topMenu_btn > * {
  width: 100%;
  height: 100%;
  display: block;
  padding: 0.75em 1em;
}

#contentsWrapper .p-topMenu_btn a:hover .gear img {
  -webkit-animation-play-state: running;
          animation-play-state: running;
}

#contentsWrapper .p-topMenu_btn a:hover .txt {
  letter-spacing: 0.07em;
  text-shadow: 4px 4px 8px black;
}

#contentsWrapper .p-topMenu_btn a:hover .icon {
  -webkit-transform: scale(0.7);
          transform: scale(0.7);
  -webkit-filter: drop-shadow(0 0 4px white);
          filter: drop-shadow(0 0 4px white);
}

#contentsWrapper .p-topMenu_btn .txt {
  text-align: center;
  line-height: 1.2;
  letter-spacing: 0;
  color: #fff;
  height: 100%;
  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;
  -webkit-transition: 0.3s cubic-bezier(0, 0.33, 0.66, 1);
  transition: 0.3s cubic-bezier(0, 0.33, 0.66, 1);
  z-index: 5;
}

#contentsWrapper .p-topMenu_btn .icon {
  position: absolute;
  top: 0;
  right: 0.75em;
  bottom: 0;
  margin: auto;
  width: 1.466em;
  height: 1.466em;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contentsWrapper .p-topMenu_btn .icon img {
  width: 100%;
}

#contentsWrapper .p-topMenu_btn .gear {
  opacity: 0.5;
}

#contentsWrapper .p-topMenu_btn .gear img {
  position: absolute;
  z-index: 1;
}

#contentsWrapper .p-topMenu_btn .gear img:nth-child(1) {
  opacity: 0.8;
  top: -109%;
  left: -16.5%;
  width: 42.758%;
  -webkit-animation: gearCW 30s linear 0s infinite normal forwards paused;
          animation: gearCW 30s linear 0s infinite normal forwards paused;
}

#contentsWrapper .p-topMenu_btn .gear img:nth-child(2) {
  opacity: 0.7;
  top: 49%;
  left: 20.2%;
  width: 17.586%;
  -webkit-animation: gearCCW 30s linear 0s infinite normal forwards paused;
          animation: gearCCW 30s linear 0s infinite normal forwards paused;
}

#contentsWrapper .p-topMenu_btn .gear img:nth-child(3) {
  opacity: 0.6;
  top: -59%;
  left: 31.5%;
  width: 27.758%;
  -webkit-animation: gearCW 30s linear 0s infinite normal forwards paused;
          animation: gearCW 30s linear 0s infinite normal forwards paused;
}

#contentsWrapper .p-topMenu_btn .img {
  position: absolute;
  z-index: 4;
}

#contentsWrapper .p-topMenu_btn .img img {
  width: 100%;
  max-width: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contentsWrapper .p-topMenu_btn.js-scroll {
  -webkit-transition: 1s ease 0.3s;
  transition: 1s ease 0.3s;
  opacity: 0;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}

#contentsWrapper .p-topMenu_btn.is-scroll {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-topMenu_flex {
  margin-top: 35px;
}

#contentsWrapper .p-topMenu_menu {
  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;
}

#contentsWrapper .p-topMenu_menu li {
  width: 380px;
  max-width: 31.66%;
  aspect-ratio: 1 / 0.2474;
}

#contentsWrapper .p-topMenu_menu li:not(:first-child) {
  margin-left: 2.5%;
}

#contentsWrapper .p-topMenu_menu li > * {
  font-size: 32px;
  line-height: 1.3;
  text-align: center;
  color: #fff;
  display: block;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}

#contentsWrapper .p-topMenu_menu li > *:before {
  content: '';
  position: absolute;
  top: 0.4em;
  left: 1em;
  bottom: 0;
  margin: auto;
}

#contentsWrapper .p-topMenu_menu li > * .ja {
  font-size: 62.5%;
}

#contentsWrapper .p-topMenu_menu a:hover {
  -webkit-transform: rotate(-2deg) scale(0.95);
          transform: rotate(-2deg) scale(0.95);
  -webkit-filter: brightness(75%);
          filter: brightness(75%);
}

#contentsWrapper .p-topMenu_menu .sideC > * {
  background: url(../images/topMenu_menu_bg1.png) no-repeat center/contain;
}

#contentsWrapper .p-topMenu_menu .sideC > *:before {
  background: url(../images/icon_drop.svg) no-repeat center/contain;
  width: 1.78em;
  height: 1.53em;
}

#contentsWrapper .p-topMenu_menu .sideG > * {
  background: url(../images/topMenu_menu_bg2.png) no-repeat center/contain;
}

#contentsWrapper .p-topMenu_menu .sideG > *:before {
  background: url(../images/icon_capsule.svg) no-repeat center/contain;
  width: 1.125em;
  height: 1.125em;
}

#contentsWrapper .p-topMenu_menu .schedule > * {
  background: url(../images/topMenu_menu_bg3.png) no-repeat center/contain;
}

#contentsWrapper .p-topMenu_menu .schedule > *:before {
  background: url(../images/icon_calendar.svg) no-repeat center/contain;
  width: 1.25em;
  height: 1.218em;
}

#contentsWrapper .p-topMenu_news {
  background: url(../images/topMenu_news_bg.png) no-repeat center top/100% 100%;
  padding: 1.5% 3% 2%;
  position: relative;
}

#contentsWrapper .p-topMenu_news:before, #contentsWrapper .p-topMenu_news:after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  aspect-ratio: 1 / 0.00833;
}

#contentsWrapper .p-topMenu_news:before {
  bottom: 100%;
  background: url(../images/topMenu_news_bg_top.png) no-repeat center bottom/contain;
}

#contentsWrapper .p-topMenu_news:after {
  top: 100%;
  background: url(../images/topMenu_news_bg_bottom.png) no-repeat center top/contain;
}

#contentsWrapper .p-topMenu_news h2.heading {
  font-size: 32px;
  letter-spacing: 0.225em;
  text-indent: 0.225em;
  padding: 0.075em 1em 0;
}

#contentsWrapper .p-topMenu_news h2.heading:before, #contentsWrapper .p-topMenu_news h2.heading:after {
  width: 0.875em;
  height: 0.875em;
}

#contentsWrapper .p-topMenu_news ul {
  aspect-ratio: 1 / 0.35;
  overflow: auto;
}

#contentsWrapper .p-topMenu_news ul:not(:first-child) {
  margin-top: 1em;
}

#contentsWrapper .p-topMenu_news ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#contentsWrapper .p-topMenu_news ul li:not(:first-child) {
  margin-top: 1.2em;
}

#contentsWrapper .p-topMenu_news ul li .date {
  min-width: 7em;
  color: #d10c0c;
}

#contentsWrapper .p-topMenu_bnr .catch {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  padding: 0.3em 1em;
  color: #fff;
  background: url(../images/top_txt_bg1.png) no-repeat center/100% 100%;
  margin-top: 20px;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .p-topMenu .block1 > * {
    width: calc(calc(100% - 40px) / 2);
  }
  #contentsWrapper .p-topMenu_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  #contentsWrapper .p-topMenu_news {
    width: 45.34%;
  }
  #contentsWrapper .p-topMenu_bnr {
    width: 51.66%;
    margin-left: 3%;
  }
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .p-topMenu_btn {
    font-size: 2.5vw;
  }
  #contentsWrapper .p-topMenu_menu li > * {
    font-size: 2.6vw;
  }
  #contentsWrapper .p-topMenu_news h2.heading {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-topMenu {
    background-image: url(../images/top_bg01_sp.jpg);
  }
  #contentsWrapper .p-topMenu .block1 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 4vw;
  }
  #contentsWrapper .p-topMenu_btn {
    font-size: 5vw;
  }
  #contentsWrapper .p-topMenu_menu li {
    aspect-ratio: 1 / 0.8632;
  }
  #contentsWrapper .p-topMenu_menu li > * {
    font-size: 4.5vw;
    padding-top: 2.5em;
  }
  #contentsWrapper .p-topMenu_menu li > *:before {
    top: 1em;
    left: 0;
    right: 0;
    bottom: auto;
  }
  #contentsWrapper .p-topMenu_menu li > * .ja {
    font-size: 53.34%;
    letter-spacing: 0;
  }
  #contentsWrapper .p-topMenu_menu .sideC > * {
    background-image: url(../images/topMenu_menu_bg1_sp.png);
  }
  #contentsWrapper .p-topMenu_menu .sideC > *:before {
    top: 0.8em;
    width: 2.55em;
    height: 2.13em;
  }
  #contentsWrapper .p-topMenu_menu .sideG > * {
    background-image: url(../images/topMenu_menu_bg2_sp.png);
  }
  #contentsWrapper .p-topMenu_menu .sideG > *:before {
    width: 1.84em;
    height: 1.84em;
  }
  #contentsWrapper .p-topMenu_menu .schedule > * {
    background-image: url(../images/topMenu_menu_bg3_sp.png);
    letter-spacing: -0.05em;
  }
  #contentsWrapper .p-topMenu_menu .schedule > *:before {
    width: 1.93em;
    height: 1.86em;
  }
  #contentsWrapper .p-topMenu_flex {
    margin-top: 7%;
  }
  #contentsWrapper .p-topMenu_news {
    background-image: url(../images/topMenu_news_bg_sp.png);
  }
  #contentsWrapper .p-topMenu_news:before, #contentsWrapper .p-topMenu_news:after {
    aspect-ratio: 1 / 0.1521;
  }
  #contentsWrapper .p-topMenu_news:before {
    background-image: url(../images/topMenu_news_bg_top_sp.png);
  }
  #contentsWrapper .p-topMenu_news:after {
    background-image: url(../images/topMenu_news_bg_bottom_sp.png);
  }
  #contentsWrapper .p-topMenu_news h2.heading {
    font-size: 5.4vw;
  }
  #contentsWrapper .p-topMenu_news ul {
    width: 100%;
    max-height: 8.4em;
  }
  #contentsWrapper .p-topMenu_news ul li:not(:first-child) {
    margin-top: 0.7em;
  }
  #contentsWrapper .p-topMenu_bnr .catch {
    font-size: 4.5vw;
  }
  #contentsWrapper .p-topMenu .bnr-slider {
    margin-top: 8%;
  }
}

#contentsWrapper .p-world1 {
  position: relative;
  padding: 20px 0 40px;
}

#contentsWrapper .p-world1 .c-body {
  margin-top: 20px;
}

#contentsWrapper .p-world1_bg {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100vh;
  background: url(../images/world_bg.jpg) no-repeat center top/cover;
  z-index: -1;
}

#contentsWrapper .p-world1_block1 {
  color: #fff;
}

#contentsWrapper .p-world1_block1 h3 {
  font-size: 32px;
  line-height: 1.3;
  letter-spacing: 0;
  color: var(--textcolor);
  background: url(../images/world_text_bg.png) no-repeat center/100% 100%;
  -webkit-filter: drop-shadow(0 0 10px #000);
          filter: drop-shadow(0 0 10px #000);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 0.2em 0.5em;
}

#contentsWrapper .p-world1_block1 h3 + * {
  margin-top: 1.5em;
}

#contentsWrapper .p-world1_block1 p {
  font-size: 16px;
  font-weight: 500;
  line-height: 2.5;
}

#contentsWrapper .p-world1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-world1.js-scroll h3 {
  -webkit-transition: 1s ease 0.5s;
  transition: 1s ease 0.5s;
  opacity: 0;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

#contentsWrapper .p-world1.js-scroll p {
  -webkit-transition: 1s ease 0.7s;
  transition: 1s ease 0.7s;
  opacity: 0;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-transform: translateY(1em);
          transform: translateY(1em);
}

#contentsWrapper .p-world1.js-scroll p:nth-child(1) {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(2) {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(3) {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(4) {
  -webkit-transition-delay: 1.1s;
          transition-delay: 1.1s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(5) {
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(6) {
  -webkit-transition-delay: 1.3s;
          transition-delay: 1.3s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(7) {
  -webkit-transition-delay: 1.4s;
          transition-delay: 1.4s;
}

#contentsWrapper .p-world1.js-scroll p:nth-child(8) {
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

#contentsWrapper .p-world1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-world1.is-scroll h3 {
  opacity: 1;
  -webkit-filter: drop-shadow(0 0 20px rgba(0, 0, 0, 0.2)) blur(0);
          filter: drop-shadow(0 0 20px rgba(0, 0, 0, 0.2)) blur(0);
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-world1.is-scroll p {
  opacity: 1;
  -webkit-filter: none;
          filter: none;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 1500px) {
  #contentsWrapper .p-world1_block1 p {
    font-size: 18px;
    line-height: 3;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-world1 {
    padding: 3% 0 4%;
  }
  #contentsWrapper .p-world1 .c-body {
    margin-top: 4%;
  }
  #contentsWrapper .p-world1_bg {
    background-image: url(../images/world_bg_sp.jpg);
  }
  #contentsWrapper .p-world1_block1 h3 {
    font-size: 4.5vw;
  }
  #contentsWrapper .p-world1_block1 p {
    font-size: 3.4vw;
  }
}

#contentsWrapper .p-story1 {
  position: relative;
  padding: 20px 0 40px;
}

#contentsWrapper .p-story1 .c-body {
  margin-top: 20px;
}

#contentsWrapper .p-story1_bg {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100vh;
  background: url(../images/story_bg.jpg) no-repeat center top/cover;
  z-index: -1;
}

#contentsWrapper .p-story1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-story1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-story1 .c-tab_content > *:not(:first-child) {
  margin-top: 2em;
}

#contentsWrapper .p-story1 .c-tab_content h3 {
  font-size: 26px;
  text-align: center;
  line-height: 1.3;
  letter-spacing: 0.1em;
  background: url(../images/story_text_bg.png) no-repeat center/contain;
  padding: 0.3em 0;
}

#contentsWrapper .p-story1 .c-tab_content h3 .l {
  font-size: 126.7%;
  line-height: 1;
  letter-spacing: -0.05em;
  display: block;
}

#contentsWrapper .p-story1 .c-tab_content h3 + * {
  margin-top: 2em !important;
}

#contentsWrapper .p-story1 .c-tab_content p {
  font-size: 16px;
  text-align: center;
  line-height: 2;
  color: #fff;
}

#contentsWrapper .p-story1 .c-tab_content.prologue h3 {
  background: url(../images/story_text_bg01.png) no-repeat center/contain;
}

#contentsWrapper .p-story1 .c-tab_content.chapter1 h3 {
  background: url(../images/story_text_bg02.png) no-repeat center/contain;
}

#contentsWrapper .p-story1 .c-tab_content.chapter2 h3 {
  background: url(../images/story_text_bg02.png) no-repeat center/contain;
}

#contentsWrapper .p-story1 .c-tab_content.chapter2 .p-story1_bg {
  background-image: url(../images/story_bg_chapter2.jpg);
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-story1 {
    padding: 3% 0 12%;
  }
  #contentsWrapper .p-story1 .c-body {
    margin-top: 4%;
  }
  #contentsWrapper .p-story1_bg {
    background-image: url(../images/story_bg_sp.jpg);
  }
  #contentsWrapper .p-story1 .c-tab_content h3 {
    font-size: 4.2vw;
  }
  #contentsWrapper .p-story1 .c-tab_content p {
    font-size: 3.2vw;
    line-height: 2.5;
  }
  #contentsWrapper .p-story1 .c-tab_content.chapter2 .p-story1_bg {
    background-image: url(../images/story_bg_chapter2_sp.jpg);
  }
}

#contentsWrapper .p-character1 {
  padding: 20px 0 80px;
}

#contentsWrapper .p-character1 .c-body {
  margin-top: 20px;
}

#contentsWrapper .p-character1 h3 {
  font-size: 26px;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 17.23em;
  aspect-ratio: 1 / 0.09375;
  margin: 0 auto;
  padding: 0 0.5em;
  color: #fff;
  background: url(../images/character_title_bg.png) no-repeat center/contain;
  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;
}

#contentsWrapper .p-character1_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

#contentsWrapper .p-character1_list figure {
  position: relative;
  overflow: hidden;
  background: url(../images/character_thumbBg.png) no-repeat center/cover;
  border: 1px solid #bcbbba;
  width: 100%;
  aspect-ratio: 1 / 1;
  -webkit-transition: 0.1s;
  transition: 0.1s;
}

#contentsWrapper .p-character1_list figure img {
  position: absolute;
  top: 2%;
  left: -10%;
  margin: auto;
  width: 120%;
  max-width: none;
  -webkit-transition: 0.1s linear;
  transition: 0.1s linear;
  -webkit-transform-origin: center 30%;
          transform-origin: center 30%;
}

#contentsWrapper .p-character1_list .name {
  font-size: 15px;
  text-align: center;
  letter-spacing: 0;
  background: url(../images/character_name_bg.png) no-repeat center/100% 100%;
  margin-top: 0.5em;
  padding: 0.1em 0;
}

#contentsWrapper .p-character1_list a {
  display: block;
}

#contentsWrapper .p-character1_list a:hover {
  -webkit-animation: noise 0.1s linear 0s 1 normal forwards running;
          animation: noise 0.1s linear 0s 1 normal forwards running;
}

#contentsWrapper .p-character1_list a:hover figure {
  background-image: url(../images/character_thumbBg_focus.png);
  border-width: 4px;
}

#contentsWrapper .p-character1_list a:hover figure img {
  -webkit-transform: scale(1.12);
          transform: scale(1.12);
}

#contentsWrapper .p-character1_list .unknown figure img {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 26.92%;
}

#contentsWrapper .p-character1_list.js-scroll > li {
  -webkit-transition: 0.4s ease 0.6s;
  transition: 0.4s ease 0.6s;
  opacity: 0;
  -webkit-transform-origin: center 10%;
          transform-origin: center 10%;
  -webkit-transform: rotateZ(60deg);
          transform: rotateZ(60deg);
}

#contentsWrapper .p-character1_list.is-scroll > li {
  opacity: 1;
  -webkit-animation: pendulum 1s ease 0.6s 1 normal forwards running;
          animation: pendulum 1s ease 0.6s 1 normal forwards running;
}

#contentsWrapper .p-character1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-character1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .p-character1_list {
    gap: 30px 2%;
  }
  #contentsWrapper .p-character1_list > li {
    width: 180px;
    max-width: 15%;
  }
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .p-character1 h3 {
    font-size: 2.16vw;
  }
  #contentsWrapper .p-character1_list .name {
    font-size: 1.15vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-character1 {
    padding: 3% 0 12%;
  }
  #contentsWrapper .p-character1 .c-body {
    margin-top: 4%;
  }
  #contentsWrapper .p-character1 h3 {
    font-size: 4.5vw;
  }
  #contentsWrapper .p-character1_list {
    gap: 20px 3.33%;
  }
  #contentsWrapper .p-character1_list > li {
    width: 48.335%;
  }
  #contentsWrapper .p-character1_list .name {
    font-size: 3.6vw;
  }
}

#contentsWrapper .p-concept1 {
  padding: 20px 0 80px;
}

#contentsWrapper .p-concept1 .c-frame {
  padding: 30px 40px;
}

#contentsWrapper .p-concept1 h3 {
  font-size: 34px;
  text-align: center;
  max-width: 300px;
  margin: 0 auto;
  color: #fff;
  background: url(../images/concept_txtBg1.png) no-repeat center/100% 100%;
}

#contentsWrapper .p-concept1 h3 + p {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin-top: 1.25em;
}

#contentsWrapper .p-concept1_block1 {
  margin-top: 1em;
}

#contentsWrapper .p-concept1_block1 .build {
  position: relative;
  z-index: 1;
}

#contentsWrapper .p-concept1_block1 .build:before {
  content: '';
  position: absolute;
  top: 7%;
  left: -50%;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 725px;
  max-width: 156%;
  aspect-ratio: 1 / 0.629;
  background: url(../images/concept_bg01.png) no-repeat center/cover;
  z-index: -1;
}

#contentsWrapper .p-concept1_block1 .parts {
  position: relative;
  z-index: 2;
}

#contentsWrapper .p-concept1_block1 .parts:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 15%;
  width: 245px;
  max-width: 46.58%;
  aspect-ratio: 1 / 0.9265;
  background: url(../images/concept_bg02.png) no-repeat center/cover;
  z-index: -1;
}

#contentsWrapper .p-concept1_block1.reverse .build:before {
  top: -15%;
  left: -7%;
  right: 0;
  bottom: 0;
}

#contentsWrapper .p-concept1_block1 + .p-concept1_block1 {
  margin-top: 1em;
  padding-top: 1em;
  border-top: 2px solid var(--maincolor);
}

#contentsWrapper .p-concept1_block1.js-scroll .build img {
  -webkit-transition: 0.6s ease 1s;
  transition: 0.6s ease 1s;
  opacity: 0;
  -webkit-transform: translateY(5%);
          transform: translateY(5%);
}

#contentsWrapper .p-concept1_block1.js-scroll .build:before {
  -webkit-transition: 0.2s ease 0.7s;
  transition: 0.2s ease 0.7s;
  opacity: 0;
  -webkit-transform: translateX(2%);
          transform: translateX(2%);
}

#contentsWrapper .p-concept1_block1.js-scroll .parts img {
  -webkit-transition: 0.7s cubic-bezier(0, 0.75, 0.5, 1) 1s;
  transition: 0.7s cubic-bezier(0, 0.75, 0.5, 1) 1s;
  opacity: 0;
  -webkit-transform: translateX(7%);
          transform: translateX(7%);
}

#contentsWrapper .p-concept1_block1.js-scroll .parts:before {
  -webkit-transition: 0.05s linear 0.6s;
  transition: 0.05s linear 0.6s;
  opacity: 0;
  -webkit-transform: scale(0.7);
          transform: scale(0.7);
}

#contentsWrapper .p-concept1_block1.is-scroll .build img {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-concept1_block1.is-scroll .build:before {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-concept1_block1.is-scroll .parts img {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-concept1_block1.is-scroll .parts:before {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-concept1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-concept1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .p-concept1_block1 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 20px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #contentsWrapper .p-concept1_block1.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .p-concept1 h3 {
    font-size: 3.4vw;
  }
  #contentsWrapper .p-concept1 h3 + p {
    font-size: 1.8vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-concept1 {
    padding: 3% 0 12%;
  }
  #contentsWrapper .p-concept1 .c-frame {
    padding: 4% 6%;
  }
  #contentsWrapper .p-concept1 h3 {
    font-size: 5.5vw;
    max-width: 45vw;
  }
  #contentsWrapper .p-concept1 h3 + p {
    font-size: 3.5vw;
  }
  #contentsWrapper .p-concept1_block1 .build {
    margin-top: 1em;
  }
  #contentsWrapper .p-concept1_block1 .build img {
    max-width: 91.39%;
  }
  #contentsWrapper .p-concept1_block1 .build:before {
    max-width: 108%;
    left: -3%;
  }
  #contentsWrapper .p-concept1_block1:not(.reverse) .build img {
    margin-left: auto;
    margin-right: 0;
    max-width: 85.75%;
  }
  #contentsWrapper .p-concept1_block1:not(.reverse) .build:before {
    left: -5%;
  }
}

#contentsWrapper .p-items1 {
  padding: 20px 0 80px;
}

#contentsWrapper .p-items1 .c-body {
  margin-top: 20px;
}

#contentsWrapper .p-items1_bg {
  background: url(../images/items_blockBg.png) no-repeat center top/100% 100%;
  padding: 30px 70px;
  margin: 0 auto;
  width: 940px;
  max-width: 100%;
  position: relative;
}

#contentsWrapper .p-items1_bg:before, #contentsWrapper .p-items1_bg:after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  aspect-ratio: 1 / 0.1064;
}

#contentsWrapper .p-items1_bg:before {
  bottom: 100%;
  background: url(../images/items_blockBg_top.png) no-repeat center bottom/contain;
}

#contentsWrapper .p-items1_bg:after {
  top: 100%;
  background: url(../images/items_blockBg_bottom.png) no-repeat center top/contain;
}

#contentsWrapper .p-items1 h3 {
  font-size: 32px;
  line-height: 1.3;
  letter-spacing: 0;
  text-align: center;
  color: #fff;
  background: url(../images/items_textBg01.png) no-repeat center/100% 100%;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 0.2em 0.5em;
}

#contentsWrapper .p-items1 h3 + * {
  margin-top: 2em;
}

#contentsWrapper .p-items1 h4 {
  font-size: 30px;
  line-height: 1.3;
  letter-spacing: 0.175em;
  text-align: center;
  color: #fff;
  display: block;
  width: 380px;
  max-width: 100%;
  aspect-ratio: 1 / 0.1842;
  padding: 0.25em 0 0.1em;
  margin: 0 auto;
  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;
  position: relative;
}

#contentsWrapper .p-items1 h4:before {
  content: '';
  position: absolute;
  top: 0.1em;
  left: 1em;
  bottom: 0;
  margin: auto;
}

#contentsWrapper .p-items1 h4.sideC {
  background: url(../images/items_textBg02.png) no-repeat center/100% 100%;
}

#contentsWrapper .p-items1 h4.sideC:before {
  background: url(../images/icon_drop.svg) no-repeat center/contain;
  width: 1.78em;
  height: 1.53em;
}

#contentsWrapper .p-items1 h4.sideG {
  background: url(../images/items_textBg03.png) no-repeat center/100% 100%;
}

#contentsWrapper .p-items1 h4.sideG:before {
  background: url(../images/icon_capsule.svg) no-repeat center/contain;
  width: 1.125em;
  height: 1.125em;
}

#contentsWrapper .p-items1 p {
  font-size: 20px;
  line-height: 1.6;
  letter-spacing: -0.075em;
  text-align: center;
  margin-top: 0.7em;
}

#contentsWrapper .p-items1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-items1.js-scroll .p-items1_bg {
  -webkit-transition: 1s ease 0.3s;
  transition: 1s ease 0.3s;
  opacity: 0;
  -webkit-transform: scale(0.95);
          transform: scale(0.95);
}

#contentsWrapper .p-items1.js-scroll h3, #contentsWrapper .p-items1.js-scroll .p-items1_flex > * {
  -webkit-mask-image: -webkit-gradient(linear, right top, left top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
  -webkit-mask-image: linear-gradient(-90deg, transparent 33.33%, #000 66.66%);
          mask-image: -webkit-gradient(linear, right top, left top, color-stop(33.33%, transparent), color-stop(66.66%, #000));
          mask-image: linear-gradient(-90deg, transparent 33.33%, #000 66.66%);
  -webkit-mask-size: 300%;
          mask-size: 300%;
  -webkit-mask-position: 100%;
          mask-position: 100%;
  -webkit-transition: 0.8s ease 0.6s;
  transition: 0.8s ease 0.6s;
}

#contentsWrapper .p-items1.js-scroll .p-items1_flex > * {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}

#contentsWrapper .p-items1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-items1.is-scroll .p-items1_bg {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-items1.is-scroll h3, #contentsWrapper .p-items1.is-scroll .p-items1_flex > * {
  -webkit-mask-position: 0%;
          mask-position: 0%;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .p-items1_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #contentsWrapper .p-items1_flex > * {
    width: 49%;
  }
  #contentsWrapper .p-items1_flex > *:not(:first-child) {
    margin-left: 2%;
  }
}

@media screen and (max-width: 1020px) and (min-width: 801px) {
  #contentsWrapper .p-items1 h3 {
    font-size: 3.4vw;
  }
  #contentsWrapper .p-items1 h4 {
    font-size: 3.2vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-items1 {
    padding: 3% 0 12%;
  }
  #contentsWrapper .p-items1 .c-body {
    margin-top: 4%;
  }
  #contentsWrapper .p-items1_bg {
    padding: 4% 5%;
  }
  #contentsWrapper .p-items1_flex > *:not(:first-child) {
    margin-top: 2em;
  }
  #contentsWrapper .p-items1 h3 {
    font-size: 4.5vw;
  }
  #contentsWrapper .p-items1 h4 {
    font-size: 4.8vw;
    width: 11.0833em;
  }
  #contentsWrapper .p-items1 p {
    font-size: 3.4vw;
  }
}

#contentsWrapper .p-itemsSchedule {
  padding: 20px 0 80px;
}

#contentsWrapper .p-itemsSchedule .c-body {
  margin-top: 20px;
}

#contentsWrapper .p-itemsSchedule .c-frame {
  padding: 20px 0 40px;
}

#contentsWrapper .p-itemsSchedule .c-frame > .inner {
  padding: 0 70px;
}

#contentsWrapper .p-itemsSchedule h3 {
  font-size: 34px;
  line-height: 1.3;
  letter-spacing: -0.05em;
  text-align: center;
  color: #fff;
  background: url(../images/items_txtBg1.png) no-repeat center/100% 100%;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 0.17em 0.5em;
}

#contentsWrapper .p-itemsSchedule h3 + * {
  margin-top: 2em;
}

#contentsWrapper .p-itemsSchedule h3 .sub {
  font-size: 58.83%;
  display: block;
}

#contentsWrapper .p-itemsSchedule #itemSort {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#contentsWrapper .p-itemsSchedule #itemSort button {
  font-size: 30px;
  line-height: 1.3;
  letter-spacing: 0.175em;
  text-align: center;
  border: 0;
  color: #fff;
  display: block;
  width: 380px;
  max-width: 48%;
  aspect-ratio: 1 / 0.1842;
  padding: 0.25em 0 0.1em;
  margin: 0 auto;
  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;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
  position: relative;
}

#contentsWrapper .p-itemsSchedule #itemSort button:before {
  content: '';
  position: absolute;
  top: 0.1em;
  left: 1em;
  bottom: 0;
  margin: auto;
}

#contentsWrapper .p-itemsSchedule #itemSort button.sideC {
  background: url(../images/items_textBg02.png) no-repeat center/100% 100%;
}

#contentsWrapper .p-itemsSchedule #itemSort button.sideC:before {
  background: url(../images/icon_drop.svg) no-repeat center/contain;
  width: 1.78em;
  height: 1.53em;
}

#contentsWrapper .p-itemsSchedule #itemSort button.sideG {
  background: url(../images/items_textBg03.png) no-repeat center/100% 100%;
}

#contentsWrapper .p-itemsSchedule #itemSort button.sideG:before {
  background: url(../images/icon_capsule.svg) no-repeat center/contain;
  width: 1.125em;
  height: 1.125em;
}

#contentsWrapper .p-itemsSchedule #itemSort button:hover {
  -webkit-transform: rotate(-2deg) scale(0.95);
          transform: rotate(-2deg) scale(0.95);
  -webkit-filter: brightness(75%);
          filter: brightness(75%);
}

#contentsWrapper .p-itemsSchedule_table {
  margin-top: 20px;
  width: 100%;
  border-collapse: collapse;
  position: relative;
}

#contentsWrapper .p-itemsSchedule_table th, #contentsWrapper .p-itemsSchedule_table td {
  border: 2px solid var(--maincolor);
}

#contentsWrapper .p-itemsSchedule_table th.title {
  border-left: 0;
  width: 13.5%;
  padding: 2% 0;
  text-align: center;
  vertical-align: top;
}

#contentsWrapper .p-itemsSchedule_table th.title .inner {
  position: sticky;
  top: 10vw;
  left: 0;
}

#contentsWrapper .p-itemsSchedule_table th.title .chapter {
  font-size: 20px;
  white-space: nowrap;
}

#contentsWrapper .p-itemsSchedule_table th.title img {
  margin: 10px auto 0;
}

#contentsWrapper .p-itemsSchedule_table th.date {
  width: 10%;
  vertical-align: middle;
  font-size: 22px;
  line-height: 1.3;
  padding: 1% 0;
}

#contentsWrapper .p-itemsSchedule_table th.date .year {
  display: block;
}

#contentsWrapper .p-itemsSchedule_table th.date .month {
  font-size: 200%;
  display: block;
}

#contentsWrapper .p-itemsSchedule_table td {
  width: 76.5%;
  line-height: 1.3;
  letter-spacing: 0;
}

#contentsWrapper .p-itemsSchedule_table td .productList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

#contentsWrapper .p-itemsSchedule_table td .productList > li {
  padding: 10px 2% 25px;
}

#contentsWrapper .p-itemsSchedule_table td .productList .wrap {
  max-width: 300px;
  margin: 0 auto;
}

#contentsWrapper .p-itemsSchedule_table td .label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#contentsWrapper .p-itemsSchedule_table td .label li:first-child {
  min-width: 45%;
}

#contentsWrapper .p-itemsSchedule_table td .label li.shokugan img {
  width: 27%;
}

#contentsWrapper .p-itemsSchedule_table td .label li.candy {
  width: 15%;
}

#contentsWrapper .p-itemsSchedule_table td .label li.gashapon {
  width: 67%;
}

#contentsWrapper .p-itemsSchedule_table td .label li.gashaponOnline {
  width: 55%;
}

#contentsWrapper .p-itemsSchedule_table td .label li.premiumBandai {
  width: 67%;
}

#contentsWrapper .p-itemsSchedule_table td .img {
  margin-top: 0.5em;
}

#contentsWrapper .p-itemsSchedule_table td .name {
  font-size: 18px;
  font-weight: bold;
  margin-top: 0.2em;
}

#contentsWrapper .p-itemsSchedule_table td .detail {
  font-size: 14px;
  margin-top: 0.5em;
}

#contentsWrapper .p-itemsSchedule_table td .c-btn {
  margin-top: 0.5em;
}

#contentsWrapper .p-itemsSchedule_table td:last-child {
  border-right: 0;
}

#contentsWrapper .p-itemsSchedule.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-itemsSchedule.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .p-itemsSchedule_table td .productList > li {
    width: 50%;
  }
  #contentsWrapper .p-itemsSchedule_table td .productList > li:nth-child(2n+1) {
    border-right: 2px solid var(--maincolor);
  }
  #contentsWrapper .p-itemsSchedule_table td .productList > li[style="display: none;"] + li:nth-child(2n) {
    border-right: 2px solid var(--maincolor);
  }
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .p-itemsSchedule h3 {
    font-size: 3.4vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-itemsSchedule {
    padding: 3% 0 4%;
  }
  #contentsWrapper .p-itemsSchedule .c-body {
    margin-top: 4%;
  }
  #contentsWrapper .p-itemsSchedule .c-frame {
    padding: 4% 0 6%;
  }
  #contentsWrapper .p-itemsSchedule .c-frame > .inner {
    padding: 0 4%;
  }
  #contentsWrapper .p-itemsSchedule h3 {
    font-size: 4.5vw;
  }
  #contentsWrapper .p-itemsSchedule #itemSort button {
    font-size: 3.5vw;
  }
  #contentsWrapper .p-itemsSchedule_table th.title .inner {
    top: 50vw;
  }
  #contentsWrapper .p-itemsSchedule_table th.title .chapter {
    font-size: 3.5vw;
  }
  #contentsWrapper .p-itemsSchedule_table th.title img {
    max-width: 60%;
  }
  #contentsWrapper .p-itemsSchedule_table th.date {
    font-size: 3.2vw;
  }
  #contentsWrapper .p-itemsSchedule_table td .productList > li {
    width: 100%;
  }
  #contentsWrapper .p-itemsSchedule_table td .productList > li:not(:first-child) {
    border-top: 2px solid var(--maincolor);
  }
  #contentsWrapper .p-itemsSchedule_table td .productList > li:first-child[style="display: none;"] + li {
    border-top: none;
  }
  #contentsWrapper .p-itemsSchedule_table td .name {
    font-size: 4vw;
  }
  #contentsWrapper .p-itemsSchedule_table td .detail {
    font-size: 3.5vw;
  }
}

#contentsWrapper .p-specialItems_bg {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100vh;
  background: url(../images/specialItems_bg.jpg) no-repeat center top/cover;
  z-index: -1;
}

#contentsWrapper .p-specialItems .p-itemsSchedule h3 {
  letter-spacing: 0;
  color: #fff;
  background-image: url(../images/specialItems_titleBg.png);
  width: min(17.235em,100%);
}

#contentsWrapper .p-specialItems .p-itemsSchedule_table th, #contentsWrapper .p-specialItems .p-itemsSchedule_table td {
  border-color: #00ffae;
}

#contentsWrapper .p-specialItems .p-itemsSchedule_table td {
  border-left: 0;
}

#contentsWrapper .p-specialItems .p-itemsSchedule_table td .productList > li:nth-child(2n+1) {
  border-right-color: #00ffae;
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-specialItems h2.heading {
    font-size: 8vw;
  }
  #contentsWrapper .p-specialItems_bg {
    background-image: url(../images/specialItems_bg_sp.jpg);
  }
  #contentsWrapper .p-specialItems .p-itemsSchedule_table td .productList > li {
    width: 100%;
  }
  #contentsWrapper .p-specialItems .p-itemsSchedule_table td .productList > li:not(:first-child) {
    border-top-color: #00ffae;
  }
}

#contentsWrapper .p-gallery1 {
  padding: 20px 0 80px;
}

#contentsWrapper .p-gallery1 .c-body {
  margin-top: 30px;
}

#contentsWrapper .p-gallery1_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
}

#contentsWrapper .p-gallery1_list > li figure {
  width: 100%;
  aspect-ratio: 1 / 0.5569;
  overflow: hidden;
  position: relative;
}

#contentsWrapper .p-gallery1_list > li figure img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: 0.6s cubic-bezier(0.2, 0, 0.2, 1);
  transition: 0.6s cubic-bezier(0.2, 0, 0.2, 1);
}

#contentsWrapper .p-gallery1_list > li figure + * {
  margin-top: 0.5em;
}

#contentsWrapper .p-gallery1_list > li > a:hover figure img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}

#contentsWrapper .p-gallery1_list .title {
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}

#contentsWrapper .p-gallery1_list .name {
  font-size: 16px;
  font-weight: 500;
  text-align: center;
}

#contentsWrapper .p-gallery1_list.visualArt figure {
  aspect-ratio: 1 / 1;
}

#contentsWrapper .p-gallery1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-gallery1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 801px) {
  #contentsWrapper .p-gallery1_list > li {
    width: calc(calc(100% - 40px) / 3);
  }
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .p-gallery1_list .title {
    font-size: 1.8vw;
  }
  #contentsWrapper .p-gallery1_list .name {
    font-size: 1.6vw;
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-gallery1_list {
    gap: 2vw 4%;
  }
  #contentsWrapper .p-gallery1_list > li {
    width: 48%;
  }
  #contentsWrapper .p-gallery1_list .title {
    font-size: 3vw;
  }
  #contentsWrapper .p-gallery1_list .name {
    font-size: 2.5vw;
  }
}

#contentsWrapper .p-build1 {
  padding: 20px 0 80px;
}

#contentsWrapper .p-build1 .c-body {
  margin-top: 20px;
}

#contentsWrapper .p-build1_bnr {
  width: 100%;
  max-width: 940px;
  aspect-ratio: 1 / 0.1489;
  margin: 0 auto;
  background: #1d1d1d;
  overflow: hidden;
  position: relative;
}

#contentsWrapper .p-build1_bnr a {
  width: 100%;
  height: 100%;
  display: block;
}

#contentsWrapper .p-build1_bnr a:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(39%, rgba(14, 50, 45, 0)), to(#0e322d));
  background: linear-gradient(rgba(14, 50, 45, 0) 39%, #0e322d);
  z-index: 2;
  pointer-events: none;
  -webkit-transition: 0.6s;
  transition: 0.6s;
  opacity: 0;
}

#contentsWrapper .p-build1_bnr a:hover:after {
  opacity: 1;
}

#contentsWrapper .p-build1_bnr a:hover .txt {
  text-shadow: 4px 4px 4px black;
  -webkit-transform: translate(-4px, -4px);
          transform: translate(-4px, -4px);
}

#contentsWrapper .p-build1_bnr a:hover .gear img {
  -webkit-animation-play-state: running;
          animation-play-state: running;
}

#contentsWrapper .p-build1_bnr a:hover .img img {
  -webkit-filter: brightness(1.2);
          filter: brightness(1.2);
}

#contentsWrapper .p-build1_bnr .txt {
  position: absolute;
  top: 0.6em;
  left: 0.9em;
  font-size: 34px;
  line-height: 1.2;
  letter-spacing: 0;
  color: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  z-index: 5;
}

#contentsWrapper .p-build1_bnr .txt .l {
  font-size: 147%;
  letter-spacing: -0.1em;
}

#contentsWrapper .p-build1_bnr .txt .s {
  font-size: 70%;
}

#contentsWrapper .p-build1_bnr .gear {
  opacity: 0.5;
}

#contentsWrapper .p-build1_bnr .gear img {
  position: absolute;
  z-index: 1;
}

#contentsWrapper .p-build1_bnr .gear img:nth-child(1) {
  opacity: 0.8;
  top: -86%;
  left: 16.7%;
  width: 26.38%;
  -webkit-animation: gearCW 30s linear 0s infinite normal forwards paused;
          animation: gearCW 30s linear 0s infinite normal forwards paused;
}

#contentsWrapper .p-build1_bnr .gear img:nth-child(2) {
  opacity: 0.7;
  top: 47%;
  left: 39.5%;
  width: 10.85%;
  -webkit-animation: gearCCW 30s linear 0s infinite normal forwards paused;
          animation: gearCCW 30s linear 0s infinite normal forwards paused;
}

#contentsWrapper .p-build1_bnr .gear img:nth-child(3) {
  opacity: 0.6;
  top: -45%;
  left: 46.4%;
  width: 17.12%;
  -webkit-animation: gearCW 30s linear 0s infinite normal forwards paused;
          animation: gearCW 30s linear 0s infinite normal forwards paused;
}

#contentsWrapper .p-build1_bnr .paint {
  position: absolute;
  top: -48%;
  left: 57.3%;
  width: 46.06%;
  z-index: 3;
}

#contentsWrapper .p-build1_bnr .paint img {
  width: 100%;
  max-width: none;
}

#contentsWrapper .p-build1_bnr .img {
  position: absolute;
  z-index: 4;
}

#contentsWrapper .p-build1_bnr .img img {
  width: 100%;
  max-width: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contentsWrapper .p-build1_bnr.--human .img {
  top: -49%;
  left: 53%;
  width: 47.12%;
}

#contentsWrapper .p-build1_bnr.--marion a:after {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(39%, rgba(14, 50, 16, 0)), to(#0e3210));
  background: linear-gradient(rgba(14, 50, 16, 0) 39%, #0e3210);
}

#contentsWrapper .p-build1_bnr.--marion .img {
  top: -105%;
  left: 65.4%;
  width: 39.26%;
}

#contentsWrapper .p-build1_bnr.--sleipnir a:after {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(39%, rgba(50, 33, 14, 0)), to(#32210e));
  background: linear-gradient(rgba(50, 33, 14, 0) 39%, #32210e);
}

#contentsWrapper .p-build1_bnr.--sleipnir .img {
  top: -7%;
  left: 67%;
  width: 32.87%;
}

#contentsWrapper .p-build1_bnr.--resistanceleader .img {
  top: -29%;
  left: 71.5%;
  width: 19.26%;
}

#contentsWrapper .p-build1_bnr.js-scroll {
  -webkit-transition: 1s ease 0.3s;
  transition: 1s ease 0.3s;
  opacity: 0;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}

#contentsWrapper .p-build1_bnr.js-scroll .paint {
  -webkit-transition: 0.3s cubic-bezier(0, 0.9, 0.1, 1) 0.8s;
  transition: 0.3s cubic-bezier(0, 0.9, 0.1, 1) 0.8s;
  opacity: 0;
  -webkit-transform: translate(-30%, 10%);
          transform: translate(-30%, 10%);
}

#contentsWrapper .p-build1_bnr.js-scroll .img {
  -webkit-transition: 1.2s cubic-bezier(0.33, 0, 0, 1) 1s;
  transition: 1.2s cubic-bezier(0.33, 0, 0, 1) 1s;
  opacity: 0;
  -webkit-transform: translateX(-25%);
          transform: translateX(-25%);
}

#contentsWrapper .p-build1_bnr.is-scroll {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-build1_bnr.is-scroll .paint, #contentsWrapper .p-build1_bnr.is-scroll .img {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contentsWrapper .p-build1.js-scroll h2.heading {
  -webkit-transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  transition: 1s cubic-bezier(0.5, 0, 0, 0.9) 0s;
  opacity: 0;
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#contentsWrapper .p-build1.is-scroll h2.heading {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

@media screen and (min-width: 801px) and (max-width: 1220px) {
  #contentsWrapper .p-build1_bnr .txt {
    font-size: min(3.33vw,34px);
  }
}

@media screen and (max-width: 800px) {
  #contentsWrapper .p-build1_bnr {
    aspect-ratio: 1 / 0.3;
  }
  #contentsWrapper .p-build1_bnr a:after {
    opacity: 1;
  }
  #contentsWrapper .p-build1_bnr .txt {
    font-size: 4.2vw;
    letter-spacing: 0.1em;
    top: auto;
    left: 1em;
    bottom: 0.75em;
  }
  #contentsWrapper .p-build1_bnr .txt .l {
    letter-spacing: 0;
  }
  #contentsWrapper .p-build1_bnr .gear img {
    -webkit-animation-play-state: running !important;
            animation-play-state: running !important;
  }
  #contentsWrapper .p-build1_bnr .gear img:nth-child(1) {
    top: -30%;
    left: 10.7%;
  }
  #contentsWrapper .p-build1_bnr .gear img:nth-child(2) {
    left: 33.5%;
  }
  #contentsWrapper .p-build1_bnr .gear img:nth-child(3) {
    top: -5%;
    left: 40.4%;
  }
  #contentsWrapper .p-build1_bnr .paint {
    top: -11%;
    left: 50%;
    width: 54.125%;
  }
  #contentsWrapper .p-build1_bnr.--human .img {
    top: -1%;
    left: 46%;
    width: 55.375%;
  }
  #contentsWrapper .p-build1_bnr.--marion .img {
    top: -28%;
    left: 58%;
    width: 46.125%;
  }
  #contentsWrapper .p-build1_bnr.--sleipnir .img {
    top: 16%;
    left: 59%;
    width: 38.625%;
  }
  #contentsWrapper .p-build1_bnr.--resistanceleader .img {
    top: 3%;
    left: 69%;
    width: 22.625%;
  }
}

.c-iframeWrapper {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  position: relative;
}

.c-iframeWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mfp-content {
  -webkit-perspective: 2000px;
          perspective: 2000px;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
}

.c-modal {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  width: 900px;
  max-width: 90vw;
  max-height: 90vh;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
  position: relative;
}

.c-modal .mfp-close {
  top: 20px;
  right: 20px;
  font-size: 0;
  width: 30px;
  height: 30px;
  background: url(../images/modal_close.svg) no-repeat center/contain;
  opacity: 1;
}

.c-movieModal {
  overflow: visible;
  -webkit-animation: popup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
          animation: popup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
}

.c-movieModal .mfp-close {
  top: -40px;
  right: 0;
  -webkit-filter: contrast(0) brightness(2);
          filter: contrast(0) brightness(2);
}

.c-campaignModal {
  background: url(../images/character_modal_bg.jpg) no-repeat center/cover;
  padding: 40px;
  -webkit-animation: popup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
          animation: popup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
}

.c-campaignModal .inner {
  overflow-y: auto;
  height: 80vh;
}

.c-campaignModal .inner::-webkit-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: var(--maincolor) #c1bfbf;
  width: 4px;
}

.c-campaignModal .inner::-webkit-scrollbar-thumb {
  background: var(--maincolor);
  border-radius: 4px;
}

.c-campaignModal .img img {
  width: auto;
  max-width: 100%;
}

.c-campaignModal .detail {
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-top: 2em;
}

.c-campaignModal .detail > *:not(:first-child) {
  margin-top: 1em;
}

.c-campaignModal .detail a {
  text-decoration: none;
  color: #0091de;
  border-bottom: 1px solid currentColor;
  padding-bottom: 0.1em;
}

.c-campaignModal .detail a:hover {
  border-bottom: none;
}

@media screen and (max-width: 800px) {
  .c-campaignModal .detail a {
    padding-bottom: 0;
  }
}

.c-campaignModal .ul01 > li {
  padding-left: 1em;
  text-indent: -1em;
}

.c-campaignModal .ul01 > li:before {
  content: '・ ';
}

.c-campaignModal h3 {
  font-size: 18px;
  font-weight: bold;
  color: #977001;
  padding-left: 1.7em;
  position: relative;
}

.c-campaignModal h3:before {
  content: '';
  position: absolute;
  top: 0.15em;
  left: 0;
  width: 1.2em;
  height: 1.2em;
  background: url(../images/heading_gear.svg) no-repeat center/contain;
  -webkit-animation: gearCW 12s linear 0s infinite normal forwards running;
          animation: gearCW 12s linear 0s infinite normal forwards running;
}

.c-campaignModal h4 {
  font-size: 16px;
  font-weight: bold;
}

@media screen and (max-width: 800px) {
  .c-campaignModal {
    background-image: url(../images/character_modal_bg_sp.jpg);
    padding: 60px 4% 4%;
    font-size: max(3vw,12px);
  }
  .c-campaignModal h3 {
    font-size: 4vw;
  }
  .c-campaignModal h4 {
    font-size: 3.5vw;
  }
}

.c-charaModal {
  aspect-ratio: 9 / 7;
  letter-spacing: -0.025em;
  background: url(../images/character_modal_bg.jpg) no-repeat center/cover;
  padding: 20px 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-animation: characterPopup 0.5s cubic-bezier(0.5, 0.25, 0, 1) 0s 1 normal forwards running;
          animation: characterPopup 0.5s cubic-bezier(0.5, 0.25, 0, 1) 0s 1 normal forwards running;
}

.c-charaModal .visual {
  position: relative;
}

.c-charaModal .visual img {
  position: absolute;
  top: 0;
  left: -10%;
  right: 0;
  bottom: -10%;
  margin: auto;
  max-width: 100%;
  max-height: 74vh;
  z-index: 2;
}

.c-charaModal .visual:before {
  content: '';
  position: absolute;
  top: 0;
  left: -10%;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 457px;
  max-width: 47.5vw;
  aspect-ratio: 1 / 0.9431;
  background: url(../images/character_modal_paint.png) no-repeat center/contain;
  z-index: 1;
}

.c-charaModal .profile {
  position: relative;
  z-index: 3;
}

.c-charaModal .name {
  font-size: 30px;
  font-weight: 500;
  padding: 0.7em 0;
  border-top: 2px solid var(--maincolor);
  border-bottom: 2px solid var(--maincolor);
}

.c-charaModal .name + * {
  margin-top: 6%;
}

.c-charaModal .flavor {
  margin-right: -1em;
  overflow-y: auto;
  max-height: 70%;
}

.c-charaModal .flavor > *:not(:first-child) {
  margin-top: 1em;
}

.c-charaModal .flavor p {
  line-height: 2;
}

.c-charaModal .flavor::-webkit-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: var(--maincolor) #c1bfbf;
  width: 4px;
}

.c-charaModal .flavor::-webkit-scrollbar-thumb {
  background: var(--maincolor);
  border-radius: 4px;
}

@media screen and (min-width: 801px) {
  .c-charaModal {
    gap: 2%;
  }
  .c-charaModal .visual {
    width: 46%;
  }
  .c-charaModal .profile {
    width: 52%;
    margin-top: 15%;
  }
}

@media screen and (max-height: 770px) and (min-width: 801px) {
  .c-charaModal .profile {
    margin-top: 10vh;
  }
}

@media screen and (max-width: 800px) {
  .c-charaModal {
    aspect-ratio: 1 / 1.6854;
    background-image: url(../images/character_modal_bg_sp.jpg);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 4%;
  }
  .c-charaModal .visual {
    height: 66%;
  }
  .c-charaModal .visual img {
    left: -2%;
    bottom: 5%;
    max-height: 90%;
  }
  .c-charaModal .visual:before {
    left: 12%;
    max-width: 71.6vw;
  }
  .c-charaModal .profile {
    height: 34%;
  }
  .c-charaModal .name {
    font-size: 4.5vw;
    text-align: center;
  }
  .c-charaModal .name + * {
    margin-top: 5%;
  }
  .c-charaModal .flavor {
    font-size: 3vw;
    text-align: center;
    max-height: 60%;
  }
}

.c-galleryModal {
  padding: 100px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background: #000;
  -webkit-animation: galleryPopup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
          animation: galleryPopup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
}

.c-galleryModal img {
  max-width: 100%;
  max-height: calc(90vh - 200px);
  margin: 0 auto;
  display: block;
}

.c-galleryModal figcaption {
  position: absolute;
  left: 1.75em;
  bottom: 1.25em;
  font-size: 16px;
  font-weight: normal;
  line-height: 1.5;
  color: #fff;
}

.c-galleryModal figcaption > * {
  display: block;
}

.c-galleryModal figcaption .title {
  font-size: 150%;
}

.c-galleryModal .mfp-close {
  -webkit-filter: contrast(0) brightness(2);
          filter: contrast(0) brightness(2);
}

@media screen and (max-width: 800px) {
  .c-galleryModal {
    padding: 16vw 0;
  }
  .c-galleryModal figcaption {
    font-size: 2.5vw;
  }
}

.c-buildModal {
  -webkit-animation: BuildPopup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
          animation: BuildPopup 0.8s cubic-bezier(0.5, 0.33, 0.33, 1) 0s 1 normal forwards running;
}

.c-buildModal ul {
  overflow-y: auto;
  height: 90vh;
}

.c-buildModal ul::-webkit-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: var(--maincolor) #c1bfbf;
  width: 4px;
}

.c-buildModal ul::-webkit-scrollbar-thumb {
  background: var(--maincolor);
  border-radius: 4px;
}

.c-buildModal ul li:not(:first-child) {
  margin-top: 2vw;
}

.c-buildModal img {
  width: 100%;
}

.c-buildModal .mfp-close {
  position: fixed;
  right: calc(50% - 430px);
}

@media screen and (max-width: 1000px) {
  .c-buildModal .mfp-close {
    top: 2%;
    right: 2%;
  }
}

.mfp-arrow {
  opacity: 1;
}

.mfp-arrow:before, .mfp-arrow:after {
  content: none;
}

.mfp-arrow-left {
  left: auto;
  right: calc(50% + 450px);
  background: url(../images/modal_prev.svg) no-repeat center !important;
}

.mfp-arrow-right {
  left: calc(50% + 450px);
  right: auto;
  background: url(../images/modal_next.svg) no-repeat center !important;
}

@media screen and (max-width: 1220px) {
  .mfp-arrow-left {
    left: 0;
    right: auto;
  }
  .mfp-arrow-right {
    left: auto;
    right: 0;
  }
}

@media screen and (max-width: 800px) {
  .mfp-arrow-left {
    top: auto;
    bottom: 0%;
    left: 2%;
  }
  .mfp-arrow-right {
    top: auto;
    bottom: 0%;
    right: 2%;
  }
}

.js-scroll.fadeInUp {
  opacity: 0;
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}

.js-scroll.fadeInFlip {
  opacity: 0;
  -webkit-transition: 1s ease 0.3s;
  transition: 1s ease 0.3s;
  -webkit-transform: rotateY(90deg);
          transform: rotateY(90deg);
}

.js-scroll.fadeInZoom {
  opacity: 0;
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
}

.js-scroll.fadeInMask {
  -webkit-transition: 1s ease 0.3s;
  transition: 1s ease 0.3s;
  -webkit-mask-image: -webkit-gradient(linear, right top, left top, color-stop(40%, transparent), color-stop(60%, #000));
  -webkit-mask-image: linear-gradient(-90deg, transparent 40%, #000 60%);
          mask-image: -webkit-gradient(linear, right top, left top, color-stop(40%, transparent), color-stop(60%, #000));
          mask-image: linear-gradient(-90deg, transparent 40%, #000 60%);
  -webkit-mask-size: 300%;
          mask-size: 300%;
  -webkit-mask-position: 100%;
          mask-position: 100%;
}

.js-scroll.is-scroll.fadeInUp, .js-scroll.is-scroll.fadeInFlip, .js-scroll.is-scroll.fadeInZoom {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

.js-scroll.is-scroll.fadeInMask {
  -webkit-mask-position: 0%;
          mask-position: 0%;
}

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

@keyframes blinking {
  0% {
    opacity: 0.33;
  }
  100% {
    opacity: 1;
  }
}

@-webkit-keyframes blinkingStalker {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  10% {
    opacity: 0.8;
  }
  20% {
    opacity: 1;
  }
  40% {
    opacity: 0.7;
  }
  60% {
    opacity: 0.9;
  }
  80% {
    opacity: 0.5;
  }
  100% {
    opacity: 1;
  }
}

@keyframes blinkingStalker {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  10% {
    opacity: 0.8;
  }
  20% {
    opacity: 1;
  }
  40% {
    opacity: 0.7;
  }
  60% {
    opacity: 0.9;
  }
  80% {
    opacity: 0.5;
  }
  100% {
    opacity: 1;
  }
}

@-webkit-keyframes kvScroll {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-0.25em);
            transform: translateY(-0.25em);
  }
  20% {
    opacity: 1;
    -webkit-transform: translateY(-0.25em);
            transform: translateY(-0.25em);
  }
  80% {
    opacity: 1;
    -webkit-transform: translateY(1.75em);
            transform: translateY(1.75em);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(1.75em);
            transform: translateY(1.75em);
  }
}

@keyframes kvScroll {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-0.25em);
            transform: translateY(-0.25em);
  }
  20% {
    opacity: 1;
    -webkit-transform: translateY(-0.25em);
            transform: translateY(-0.25em);
  }
  80% {
    opacity: 1;
    -webkit-transform: translateY(1.75em);
            transform: translateY(1.75em);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(1.75em);
            transform: translateY(1.75em);
  }
}

@-webkit-keyframes paint {
  0% {
    -webkit-mask-position: 0%;
            mask-position: 0%;
  }
  100% {
    -webkit-mask-position: 100%;
            mask-position: 100%;
  }
}

@keyframes paint {
  0% {
    -webkit-mask-position: 0%;
            mask-position: 0%;
  }
  100% {
    -webkit-mask-position: 100%;
            mask-position: 100%;
  }
}

@-webkit-keyframes popup {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-filter: none;
            filter: none;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes popup {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-filter: none;
            filter: none;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@-webkit-keyframes characterPopup {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.9) rotate3d(-1, -1, -0.5, 90deg);
            transform: scale(0.9) rotate3d(-1, -1, -0.5, 90deg);
  }
  100% {
    opacity: 1;
    -webkit-filter: none;
            filter: none;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes characterPopup {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.9) rotate3d(-1, -1, -0.5, 90deg);
            transform: scale(0.9) rotate3d(-1, -1, -0.5, 90deg);
  }
  100% {
    opacity: 1;
    -webkit-filter: none;
            filter: none;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@-webkit-keyframes galleryPopup {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-filter: none;
            filter: none;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes galleryPopup {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-filter: none;
            filter: none;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@-webkit-keyframes BuildPopup {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-20%);
            transform: translateY(-20%);
  }
  100% {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}

@keyframes BuildPopup {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-20%);
            transform: translateY(-20%);
  }
  100% {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}

@-webkit-keyframes noise {
  0%, 100% {
    -webkit-transform: skewX(0deg);
            transform: skewX(0deg);
  }
  10%, 30%, 50%, 70%, 90% {
    -webkit-filter: hue-rotate(180deg) blur(2px);
            filter: hue-rotate(180deg) blur(2px);
    -webkit-transform: skewX(2deg);
            transform: skewX(2deg);
  }
  20%, 40%, 60%, 80% {
    -webkit-transform: skewX(-2deg);
            transform: skewX(-2deg);
  }
}

@keyframes noise {
  0%, 100% {
    -webkit-transform: skewX(0deg);
            transform: skewX(0deg);
  }
  10%, 30%, 50%, 70%, 90% {
    -webkit-filter: hue-rotate(180deg) blur(2px);
            filter: hue-rotate(180deg) blur(2px);
    -webkit-transform: skewX(2deg);
            transform: skewX(2deg);
  }
  20%, 40%, 60%, 80% {
    -webkit-transform: skewX(-2deg);
            transform: skewX(-2deg);
  }
}

@-webkit-keyframes pendulum {
  0% {
    -webkit-transform: rotateZ(30deg);
            transform: rotateZ(30deg);
  }
  25% {
    -webkit-transform: rotateZ(-10deg);
            transform: rotateZ(-10deg);
  }
  50% {
    -webkit-transform: rotateZ(4deg);
            transform: rotateZ(4deg);
  }
  75% {
    -webkit-transform: rotateZ(-1deg);
            transform: rotateZ(-1deg);
  }
  100% {
    -webkit-transform: rotateZ(0deg);
            transform: rotateZ(0deg);
  }
}

@keyframes pendulum {
  0% {
    -webkit-transform: rotateZ(30deg);
            transform: rotateZ(30deg);
  }
  25% {
    -webkit-transform: rotateZ(-10deg);
            transform: rotateZ(-10deg);
  }
  50% {
    -webkit-transform: rotateZ(4deg);
            transform: rotateZ(4deg);
  }
  75% {
    -webkit-transform: rotateZ(-1deg);
            transform: rotateZ(-1deg);
  }
  100% {
    -webkit-transform: rotateZ(0deg);
            transform: rotateZ(0deg);
  }
}

#logo > * {
  transform-box: fill-box;
  -webkit-transform-origin: center;
          transform-origin: center;
}

#logo #gear1, #logo #gear3, #logo #gear5, #logo #gear7 {
  -webkit-animation: gearCW 36s linear 0s infinite normal forwards running;
          animation: gearCW 36s linear 0s infinite normal forwards running;
}

#logo #gear2, #logo #gear4, #logo #gear6, #logo #gear8 {
  -webkit-animation: gearCCW 36s linear 0s infinite normal forwards running;
          animation: gearCCW 36s linear 0s infinite normal forwards running;
}

#logo .cls-1 {
  fill: url(#gradatient6-54);
}

#logo .cls-2 {
  fill: url(#gradatient6-53);
}

#logo .cls-3 {
  fill: url(#gradatient6-228);
}

#logo .cls-4 {
  fill: url(#gradatient3-2);
}

#logo .cls-5 {
  fill: url(#gradatient6-108);
}

#logo .cls-6 {
  fill: #f1efee;
}

#logo .cls-7 {
  fill: url(#gradatient6-209);
}

#logo .cls-8 {
  fill: url(#gradatient6-58);
}

#logo .cls-9 {
  fill: url(#gradatient6-186);
}

#logo .cls-10 {
  fill: url(#gradatient6-74);
}

#logo .cls-11 {
  fill: #965424;
}

#logo .cls-11, #logo .cls-12, #logo .cls-13, #logo .cls-14, #logo .cls-15, #logo .cls-16, #logo .cls-17 {
  mix-blend-mode: multiply;
}

#logo .cls-18 {
  fill: url(#gradatient6-21);
}

#logo .cls-19 {
  fill: url(#gradatient6-181);
}

#logo .cls-20 {
  fill: url(#gradatient152-7);
}

#logo .cls-21 {
  fill: #918982;
}

#logo .cls-22 {
  fill: url(#gradatient6-229);
}

#logo .cls-23 {
  fill: url(#gradatient_swatch3-4);
}

#logo .cls-24 {
  fill: url(#gradatient6-86);
}

#logo .cls-25 {
  fill: url(#gradatient60);
}

#logo .cls-26 {
  fill: url(#gradatient_swatch3-2);
}

#logo .cls-27 {
  fill: url(#gradatient152);
}

#logo .cls-12, #logo .cls-28 {
  fill: url(#gradatient3);
}

#logo .cls-29 {
  fill: url(#gradatient6-38);
}

#logo .cls-30 {
  fill: url(#gradatient6-91);
}

#logo .cls-31 {
  fill: url(#gradatient2-3);
}

#logo .cls-32 {
  -webkit-mask: url(#mask-5);
          mask: url(#mask-5);
}

#logo .cls-33 {
  fill: url(#gradatient6-215);
}

#logo .cls-34 {
  fill: url(#gradatient6-56);
}

#logo .cls-35 {
  fill: url(#gradatient_swatch3);
}

#logo .cls-36 {
  fill: url(#gradatient152-8);
}

#logo .cls-37 {
  fill: url(#gradatient6-6);
}

#logo .cls-38 {
  fill: url(#gradatient6-127);
}

#logo .cls-39 {
  fill: url(#linear-gradient-2);
}

#logo .cls-40 {
  fill: url(#gradatient6-83);
}

#logo .cls-41 {
  fill: url(#gradatient6-87);
}

#logo .cls-42 {
  fill: url(#gradatient6-59);
}

#logo .cls-43 {
  fill: url(#gradatient6-208);
}

#logo .cls-44 {
  fill: url(#gradatient6-194);
}

#logo .cls-45 {
  fill: url(#gradatient6-94);
}

#logo .cls-46 {
  fill: url(#gradatient6-187);
}

#logo .cls-47 {
  fill: url(#gradatient6-66);
}

#logo .cls-48 {
  fill: url(#gradatient6-156);
}

#logo .cls-49 {
  -webkit-mask: url(#mask-1);
          mask: url(#mask-1);
}

#logo .cls-50 {
  fill: url(#gradatient6-225);
}

#logo .cls-51 {
  fill: #8a837b;
}

#logo .cls-52 {
  fill: url(#gradatient6-163);
}

#logo .cls-53 {
  fill: #5c5952;
}

#logo .cls-54 {
  fill: url(#gradatient6-171);
}

#logo .cls-55 {
  fill: url(#gradatient6-96);
}

#logo .cls-56 {
  fill: url(#gradatient6-137);
}

#logo .cls-57 {
  fill: url(#gradatient2-4);
}

#logo .cls-58 {
  fill: url(#gradatient6-126);
}

#logo .cls-59 {
  fill: url(#gradatient6-130);
}

#logo .cls-60 {
  fill: url(#gradatient_swatch3-7);
}

#logo .cls-61 {
  fill: url(#gradatient_swatch3-13);
}

#logo .cls-62 {
  fill: url(#gradatient6-213);
}

#logo .cls-63 {
  fill: url(#gradatient6-158);
}

#logo .cls-64 {
  fill: url(#gradatient6-197);
}

#logo .cls-65 {
  fill: #52514b;
}

#logo .cls-66 {
  fill: url(#gradatient6-166);
}

#logo .cls-67 {
  fill: url(#gradatient6-231);
}

#logo .cls-68 {
  fill: url(#gradatient6-57);
}

#logo .cls-69 {
  fill: #4c4c47;
}

#logo .cls-70 {
  fill: url(#gradatient6-12);
}

#logo .cls-71 {
  fill: url(#gradatient6-43);
}

#logo .cls-72 {
  fill: url(#gradatient6-152);
}

#logo .cls-73 {
  fill: url(#gradatient60-5);
}

#logo .cls-74 {
  fill: url(#gradatient6-64);
}

#logo .cls-13 {
  fill: url(#radial-gradient-3);
}

#logo .cls-75 {
  fill: url(#gradatient6-218);
}

#logo .cls-76 {
  fill: url(#gradatient6-27);
}

#logo .cls-77 {
  fill: url(#gradatient6-20);
}

#logo .cls-78 {
  fill: url(#gradatient6);
}

#logo .cls-79 {
  fill: url(#gradatient6-201);
}

#logo .cls-80 {
  fill: url(#gradatient6-205);
}

#logo .cls-81 {
  fill: url(#gradatient6-204);
}

#logo .cls-82 {
  fill: url(#gradatient6-33);
}

#logo .cls-14 {
  fill: url(#radial-gradient);
}

#logo .cls-83 {
  fill: url(#gradatient60-12);
}

#logo .cls-84 {
  fill: url(#gradatient6-180);
}

#logo .cls-85 {
  fill: url(#gradatient6-157);
}

#logo .cls-86 {
  fill: url(#gradatient6-55);
}

#logo .cls-87 {
  fill: url(#gradatient60-10);
}

#logo .cls-88 {
  fill: url(#gradatient6-9);
}

#logo .cls-89 {
  fill: url(#gradatient6-160);
}

#logo .cls-90 {
  -webkit-filter: url(#luminosity-noclip-5);
          filter: url(#luminosity-noclip-5);
}

#logo .cls-91 {
  fill: url(#gradatient3-3);
}

#logo .cls-92 {
  fill: url(#gradatient6-155);
}

#logo .cls-93 {
  fill: url(#gradatient60-13);
}

#logo .cls-94 {
  fill: #fff;
}

#logo .cls-95 {
  -webkit-mask: url(#mask);
          mask: url(#mask);
}

#logo .cls-96 {
  fill: url(#gradatient60-2);
}

#logo .cls-97 {
  fill: url(#gradatient6-139);
}

#logo .cls-98 {
  fill: url(#gradatient6-178);
}

#logo .cls-99 {
  fill: url(#gradatient6-104);
}

#logo .cls-100 {
  fill: url(#gradatient6-106);
}

#logo .cls-101 {
  fill: url(#gradatient6-61);
}

#logo .cls-102 {
  fill: url(#gradatient2);
}

#logo .cls-103 {
  fill: #9c948d;
}

#logo .cls-104 {
  fill: url(#gradatient6-124);
}

#logo .cls-105 {
  fill: #595650;
}

#logo .cls-106 {
  fill: url(#gradatient6-223);
}

#logo .cls-107 {
  fill: url(#gradatient6-164);
}

#logo .cls-108 {
  fill: #b4aea9;
}

#logo .cls-109 {
  fill: url(#gradatient6-77);
}

#logo .cls-110 {
  fill: url(#gradatient8-4);
}

#logo .cls-111 {
  fill: #736c65;
}

#logo .cls-112 {
  fill: url(#gradatient152-6);
}

#logo .cls-113 {
  fill: url(#gradatient6-48);
}

#logo .cls-114 {
  fill: url(#gradatient6-227);
}

#logo .cls-115 {
  fill: url(#gradatient6-151);
}

#logo .cls-116 {
  fill: url(#gradatient6-32);
}

#logo .cls-117 {
  fill: url(#gradatient6-101);
}

#logo .cls-118 {
  fill: url(#gradatient2-6);
}

#logo .cls-119 {
  fill: #877f78;
}

#logo .cls-120 {
  fill: url(#gradatient6-235);
}

#logo .cls-121 {
  fill: url(#gradatient_swatch3-9);
}

#logo .cls-122 {
  fill: url(#gradatient6-236);
}

#logo .cls-123 {
  fill: #d2ceca;
}

#logo .cls-124 {
  fill: url(#gradatient6-45);
}

#logo .cls-125 {
  fill: url(#gradatient152-5);
}

#logo .cls-126 {
  fill: url(#gradatient110);
}

#logo .cls-127 {
  fill: url(#gradatient6-212);
}

#logo .cls-128 {
  fill: url(#gradatient6-93);
}

#logo .cls-129 {
  fill: url(#gradatient152-11);
}

#logo .cls-130 {
  fill: url(#gradatient_swatch3-17);
}

#logo .cls-131 {
  fill: url(#gradatient6-37);
}

#logo .cls-132 {
  fill: url(#gradatient6-140);
}

#logo .cls-133 {
  fill: url(#gradatient60-8);
}

#logo .cls-134 {
  fill: none;
}

#logo .cls-135 {
  fill: url(#gradatient6-172);
}

#logo .cls-136 {
  fill: #a69f99;
}

#logo .cls-137 {
  fill: url(#gradatient6-159);
}

#logo .cls-138 {
  fill: url(#gradatient_swatch3-5);
}

#logo .cls-139 {
  fill: url(#gradatient6-131);
}

#logo .cls-140 {
  fill: #bcb6b1;
}

#logo .cls-141 {
  fill: url(#gradatient6-150);
}

#logo .cls-142 {
  fill: url(#gradatient6-119);
}

#logo .cls-143 {
  fill: #e1dedc;
}

#logo .cls-144 {
  fill: url(#gradatient6-22);
}

#logo .cls-145 {
  fill: url(#gradatient6-88);
}

#logo .cls-146 {
  fill: #cec9c6;
}

#logo .cls-147 {
  -webkit-mask: url(#mask-2);
          mask: url(#mask-2);
}

#logo .cls-148 {
  fill: #5f5b55;
}

#logo .cls-149 {
  fill: url(#gradatient6-182);
}

#logo .cls-150 {
  fill: url(#gradatient6-98);
}

#logo .cls-151 {
  fill: url(#gradatient_swatch3-18);
}

#logo .cls-152 {
  -webkit-filter: url(#luminosity-noclip-3);
          filter: url(#luminosity-noclip-3);
}

#logo .cls-153 {
  fill: url(#gradatient2-7);
}

#logo .cls-154 {
  fill: url(#gradatient6-35);
}

#logo .cls-155 {
  fill: #aaa39d;
}

#logo .cls-156 {
  fill: url(#gradatient6-177);
}

#logo .cls-157 {
  fill: url(#gradatient6-133);
}

#logo .cls-158 {
  fill: url(#gradatient6-102);
}

#logo .cls-159 {
  fill: #79726b;
}

#logo .cls-160 {
  fill: #a39b95;
}

#logo .cls-161 {
  fill: url(#gradatient6-8);
}

#logo .cls-162 {
  fill: url(#gradatient_swatch3-16);
}

#logo .cls-163 {
  fill: #c7c1bd;
}

#logo .cls-164 {
  fill: url(#linear-gradient-3);
}

#logo .cls-165 {
  fill: url(#gradatient6-143);
}

#logo .cls-166 {
  fill: url(#gradatient6-18);
}

#logo .cls-167 {
  fill: #dddad7;
}

#logo .cls-168 {
  fill: url(#gradatient6-173);
}

#logo .cls-169 {
  fill: #c3bdb9;
}

#logo .cls-170 {
  fill: url(#gradatient6-92);
}

#logo .cls-171 {
  fill: url(#gradatient6-84);
}

#logo .cls-172 {
  fill: url(#gradatient6-167);
}

#logo .cls-173 {
  fill: url(#gradatient6-79);
}

#logo .cls-174 {
  fill: url(#gradatient60-3);
}

#logo .cls-175 {
  fill: url(#gradatient6-123);
}

#logo .cls-176 {
  fill: url(#gradatient60-4);
}

#logo .cls-177 {
  fill: url(#gradatient_swatch3-3);
}

#logo .cls-178 {
  fill: url(#gradatient6-169);
}

#logo .cls-179 {
  fill: #7d766e;
}

#logo .cls-180 {
  fill: url(#gradatient6-111);
}

#logo .cls-181 {
  fill: url(#gradatient6-72);
}

#logo .cls-182 {
  fill: url(#gradatient6-97);
}

#logo .cls-183 {
  fill: url(#gradatient6-115);
}

#logo .cls-184 {
  fill: url(#gradatient6-174);
}

#logo .cls-185 {
  fill: url(#gradatient6-7);
}

#logo .cls-186 {
  fill: url(#gradatient6-226);
}

#logo .cls-187 {
  isolation: isolate;
}

#logo .cls-188 {
  fill: url(#gradatient6-100);
}

#logo .cls-189 {
  fill: url(#gradatient6-175);
}

#logo .cls-190 {
  fill: url(#gradatient6-78);
}

#logo .cls-191 {
  fill: url(#gradatient6-184);
}

#logo .cls-192 {
  fill: url(#gradatient3-5);
}

#logo .cls-193 {
  fill: url(#gradatient6-125);
}

#logo .cls-194 {
  fill: url(#gradatient6-34);
}

#logo .cls-195 {
  fill: url(#gradatient6-138);
}

#logo .cls-196 {
  fill: url(#gradatient8);
}

#logo .cls-197 {
  fill: #cac5c1;
}

#logo .cls-198 {
  fill: url(#gradatient6-10);
}

#logo .cls-199 {
  fill: url(#gradatient6-189);
}

#logo .cls-200 {
  fill: #d6d2ce;
}

#logo .cls-201 {
  fill: url(#gradatient6-233);
}

#logo .cls-202 {
  fill: url(#gradatient6-191);
}

#logo .cls-203 {
  fill: url(#gradatient60-9);
}

#logo .cls-204 {
  fill: url(#gradatient6-80);
}

#logo .cls-205 {
  fill: url(#gradatient6-85);
}

#logo .cls-206 {
  fill: url(#gradatient6-76);
}

#logo .cls-207 {
  fill: url(#gradatient6-214);
}

#logo .cls-208 {
  fill: url(#gradatient2-5);
}

#logo .cls-209 {
  fill: #e9e7e5;
}

#logo .cls-210 {
  fill: url(#gradatient6-68);
}

#logo .cls-211 {
  fill: url(#gradatient6-99);
}

#logo .cls-212 {
  fill: #766f68;
}

#logo .cls-213 {
  fill: url(#gradatient173);
}

#logo .cls-214 {
  fill: url(#gradatient_swatch3-15);
}

#logo .cls-215 {
  fill: url(#gradatient6-13);
}

#logo .cls-216 {
  fill: url(#gradatient6-103);
}

#logo .cls-217 {
  fill: url(#gradatient6-190);
}

#logo .cls-218 {
  fill: url(#gradatient6-36);
}

#logo .cls-219 {
  fill: url(#gradatient6-196);
}

#logo .cls-220 {
  fill: url(#gradatient6-211);
}

#logo .cls-221 {
  fill: url(#gradatient6-25);
}

#logo .cls-222 {
  fill: url(#gradatient8-3);
}

#logo .cls-223 {
  fill: url(#gradatient6-4);
}

#logo .cls-224 {
  fill: url(#gradatient6-23);
}

#logo .cls-225 {
  fill: url(#gradatient6-26);
}

#logo .cls-226 {
  fill: url(#gradatient173-2);
}

#logo .cls-227 {
  fill: url(#gradatient6-135);
}

#logo .cls-228 {
  fill: url(#gradatient6-149);
}

#logo .cls-229 {
  fill: url(#gradatient6-51);
}

#logo .cls-230 {
  fill: url(#gradatient6-116);
}

#logo .cls-231 {
  fill: url(#gradatient6-17);
}

#logo .cls-232 {
  fill: #d9d6d3;
}

#logo .cls-233 {
  fill: url(#gradatient6-145);
}

#logo .cls-234 {
  fill: #f5f4f3;
}

#logo .cls-235 {
  fill: url(#gradatient6-176);
}

#logo .cls-236 {
  fill: url(#gradatient6-60);
}

#logo .cls-237 {
  fill: url(#gradatient6-220);
}

#logo .cls-238 {
  fill: url(#gradatient6-3);
}

#logo .cls-239 {
  fill: url(#gradatient_swatch3-14);
}

#logo .cls-240 {
  fill: url(#gradatient6-2);
}

#logo .cls-241 {
  fill: url(#gradatient6-24);
}

#logo .cls-242 {
  fill: url(#gradatient6-44);
}

#logo .cls-243 {
  fill: url(#gradatient152-9);
}

#logo .cls-244 {
  fill: url(#gradatient6-141);
}

#logo .cls-245 {
  fill: url(#gradatient6-221);
}

#logo .cls-246 {
  fill: url(#gradatient152-2);
}

#logo .cls-247 {
  fill: url(#gradatient6-132);
}

#logo .cls-248 {
  fill: url(#gradatient6-232);
}

#logo .cls-249 {
  fill: url(#gradatient6-224);
}

#logo .cls-250 {
  fill: url(#gradatient6-107);
}

#logo .cls-251 {
  fill: #69635d;
}

#logo .cls-252 {
  fill: url(#gradatient6-42);
}

#logo .cls-253 {
  fill: #edebea;
}

#logo .cls-254 {
  fill: #421f0c;
}

#logo .cls-255 {
  fill: url(#gradatient6-95);
}

#logo .cls-256 {
  fill: url(#gradatient179);
}

#logo .cls-257 {
  fill: url(#gradatient60-7);
}

#logo .cls-258 {
  fill: url(#gradatient152-10);
}

#logo .cls-259 {
  fill: #9f9891;
}

#logo .cls-260 {
  fill: url(#gradatient6-148);
}

#logo .cls-261 {
  fill: url(#gradatient6-200);
}

#logo .cls-262 {
  fill: url(#gradatient6-210);
}

#logo .cls-263 {
  fill: url(#gradatient6-153);
}

#logo .cls-264 {
  fill: url(#gradatient6-234);
}

#logo .cls-265 {
  fill: url(#gradatient60-11);
}

#logo .cls-266 {
  fill: url(#gradatient_swatch3-12);
}

#logo .cls-267 {
  fill: url(#gradatient6-41);
}

#logo .cls-268 {
  fill: #f9f8f8;
}

#logo .cls-269 {
  fill: url(#gradatient6-195);
}

#logo .cls-270 {
  fill: url(#gradatient_swatch3-8);
}

#logo .cls-271 {
  fill: url(#gradatient3-4);
}

#logo .cls-272 {
  fill: url(#gradatient6-216);
}

#logo .cls-273 {
  fill: #e5e3e0;
}

#logo .cls-274 {
  fill: url(#gradatient6-165);
}

#logo .cls-275 {
  fill: url(#gradatient6-16);
}

#logo .cls-276 {
  fill: url(#gradatient6-122);
}

#logo .cls-277 {
  fill: url(#gradatient6-30);
}

#logo .cls-278 {
  fill: #98918a;
}

#logo .cls-279 {
  fill: #66615a;
}

#logo .cls-280 {
  fill: url(#gradatient6-65);
}

#logo .cls-281 {
  fill: url(#gradatient6-142);
}

#logo .cls-282 {
  fill: url(#gradatient60-6);
}

#logo .cls-283 {
  fill: url(#gradatient6-188);
}

#logo .cls-284 {
  fill: url(#gradatient6-52);
}

#logo .cls-285 {
  fill: url(#gradatient6-222);
}

#logo .cls-286 {
  fill: url(#gradatient6-40);
}

#logo .cls-16 {
  fill: url(#radial-gradient-2);
}

#logo .cls-287 {
  fill: url(#gradatient6-62);
}

#logo .cls-288 {
  fill: url(#gradatient6-202);
}

#logo .cls-289 {
  fill: url(#gradatient6-29);
}

#logo .cls-290 {
  fill: url(#gradatient6-219);
}

#logo .cls-291 {
  fill: #8e867f;
}

#logo .cls-292 {
  fill: url(#gradatient6-154);
}

#logo .cls-293 {
  fill: url(#gradatient6-144);
}

#logo .cls-294 {
  fill: url(#gradatient6-168);
}

#logo .cls-295 {
  fill: url(#gradatient6-193);
}

#logo .cls-296 {
  fill: url(#gradatient6-117);
}

#logo .cls-297 {
  fill: url(#gradatient6-71);
}

#logo .cls-298 {
  fill: url(#gradatient6-31);
}

#logo .cls-299 {
  fill: url(#gradatient6-67);
}

#logo .cls-300 {
  fill: url(#gradatient6-47);
}

#logo .cls-301 {
  fill: url(#gradatient8-2);
}

#logo .cls-302 {
  fill: url(#gradatient6-183);
}

#logo .cls-303 {
  fill: url(#gradatient6-161);
}

#logo .cls-304 {
  fill: url(#gradatient6-15);
}

#logo .cls-305 {
  fill: url(#gradatient6-162);
}

#logo .cls-306 {
  fill: url(#gradatient6-192);
}

#logo .cls-307 {
  fill: #807972;
}

#logo .cls-308 {
  fill: url(#gradatient6-113);
}

#logo .cls-309 {
  fill: url(#gradatient6-207);
}

#logo .cls-310 {
  fill: #fcfcfc;
}

#logo .cls-311 {
  -webkit-mask: url(#mask-4);
          mask: url(#mask-4);
}

#logo .cls-312 {
  fill: url(#gradatient6-81);
}

#logo .cls-313 {
  fill: url(#gradatient6-50);
}

#logo .cls-314 {
  fill: url(#gradatient6-14);
}

#logo .cls-315 {
  fill: url(#gradatient6-19);
}

#logo .cls-316 {
  fill: url(#gradatient6-90);
}

#logo .cls-317 {
  fill: url(#gradatient_swatch3-11);
}

#logo .cls-318 {
  fill: url(#gradatient6-121);
}

#logo .cls-319 {
  fill: url(#gradatient6-128);
}

#logo .cls-320 {
  fill: url(#gradatient6-217);
}

#logo .cls-321 {
  fill: #0c0205;
}

#logo .cls-322 {
  fill: url(#gradatient_swatch3-6);
}

#logo .cls-323 {
  fill: url(#gradatient6-112);
}

#logo .cls-324 {
  fill: url(#gradatient6-39);
}

#logo .cls-325 {
  fill: url(#gradatient6-118);
}

#logo .cls-326 {
  fill: #6f6962;
}

#logo .cls-327 {
  fill: url(#gradatient6-5);
}

#logo .cls-328 {
  fill: url(#gradatient6-28);
}

#logo .cls-329 {
  fill: url(#gradatient6-230);
}

#logo .cls-330 {
  fill: url(#gradatient6-46);
}

#logo .cls-331 {
  fill: url(#gradatient6-120);
}

#logo .cls-332 {
  fill: url(#gradatient6-198);
}

#logo .cls-333 {
  fill: url(#gradatient6-114);
}

#logo .cls-334 {
  fill: #4f4e49;
}

#logo .cls-335 {
  fill: url(#gradatient6-11);
}

#logo .cls-336 {
  fill: #6c665f;
}

#logo .cls-337 {
  fill: url(#gradatient6-146);
}

#logo .cls-338 {
  fill: url(#gradatient6-206);
}

#logo .cls-17 {
  fill: url(#radial-gradient-4);
}

#logo .cls-339 {
  fill: #ada6a1;
}

#logo .cls-340 {
  fill: url(#gradatient_swatch3-10);
}

#logo .cls-341 {
  fill: url(#gradatient152-3);
}

#logo .cls-342 {
  fill: url(#gradatient3-6);
}

#logo .cls-343 {
  fill: url(#gradatient6-63);
}

#logo .cls-344 {
  fill: url(#gradatient6-75);
}

#logo .cls-345 {
  fill: url(#gradatient6-185);
}

#logo .cls-346 {
  fill: url(#gradatient6-82);
}

#logo .cls-347 {
  fill: #56534e;
}

#logo .cls-348 {
  fill: url(#linear-gradient);
}

#logo .cls-349 {
  fill: url(#gradatient6-105);
}

#logo .cls-350 {
  fill: url(#gradatient6-129);
}

#logo .cls-351 {
  fill: url(#gradatient6-203);
}

#logo .cls-352 {
  fill: url(#gradatient_swatch3-20);
}

#logo .cls-353 {
  fill: #bfb9b5;
}

#logo .cls-354 {
  fill: #b8b2ad;
}

#logo .cls-355 {
  fill: url(#gradatient6-89);
}

#logo .cls-356 {
  fill: url(#gradatient6-110);
}

#logo .cls-357 {
  fill: url(#gradatient6-147);
}

#logo .cls-358 {
  fill: url(#gradatient6-49);
}

#logo .cls-359 {
  fill: #b1aaa5;
}

#logo .cls-360 {
  fill: url(#gradatient6-179);
}

#logo .cls-361 {
  fill: url(#gradatient6-69);
}

#logo .cls-362 {
  fill: url(#gradatient6-199);
}

#logo .cls-363 {
  fill: url(#gradatient193);
}

#logo .cls-364 {
  fill: #635e57;
}

#logo .cls-365 {
  fill: url(#gradatient6-109);
}

#logo .cls-366 {
  fill: #958d86;
}

#logo .cls-367 {
  fill: url(#gradatient_swatch3-19);
}

#logo .cls-368 {
  fill: #837c75;
}

#logo .cls-369 {
  -webkit-mask: url(#mask-3);
          mask: url(#mask-3);
}

#logo .cls-370 {
  fill: url(#gradatient6-70);
}

#logo .cls-371 {
  fill: url(#gradatient6-136);
}

#logo .cls-372 {
  -webkit-filter: url(#luminosity-noclip);
          filter: url(#luminosity-noclip);
}

#logo .cls-373 {
  fill: url(#gradatient2-2);
}

#logo .cls-374 {
  fill: url(#gradatient6-170);
}

#logo .cls-375 {
  fill: url(#gradatient152-4);
}

#logo .cls-376 {
  fill: url(#gradatient6-73);
}

#logo .cls-377 {
  fill: url(#gradatient6-134);
}

@-webkit-keyframes gearCW {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes gearCW {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@-webkit-keyframes gearCCW {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(-360deg);
            transform: rotate(-360deg);
  }
}

@keyframes gearCCW {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(-360deg);
            transform: rotate(-360deg);
  }
}

/* ======== ↑ End main ↑ ======== */
