.c-black {
  color: #000;
}

.c-white {
  color: #fff;
}

.wow {
  visibility: hidden;
}

body::-webkit-scrollbar {
  display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
body {
  -ms-overflow-style: none;
  /* IE and Edge */
  scrollbar-width: none;
  overflow-x: unset;
}

html.is-scroll-locked,
body.is-scroll-locked {
  position: fixed;
  width: 100%;
  left: 0;
  right: 0;
}

html.is-kv-locked,
body.is-kv-locked {
  height: 100%;
  overflow: hidden;
}
html.is-kv-locked .bt-to-top,
body.is-kv-locked .bt-to-top {
  opacity: 0;
  -webkit-transition: 0.3s 0s ease;
  transition: 0.3s 0s ease;
  pointer-events: none;
}

.l-body {
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
  font-style: normal;
  font-weight: 400;
  width: 100%;
  padding: 0;
  position: relative;
}
.l-body::before {
  content: "";
  position: fixed;
  display: block;
  z-index: -1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(#DCE0F4 1px, transparent 1px), linear-gradient(90deg, #DCE0F4 1px, #F8F8F8 1px);
  background-size: 90px 90px;
}
.l-body .l-body-main {
  width: 100% !important;
  position: relative;
  min-height: 100vh;
  color: #1432AA;
}

.font-instrument {
  font-family: "Instrument Serif", serif;
}

.font-dnp-shuei-mincho {
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
}

.font-hiragino {
  font-family: "Hiragino Sans", Meiryo, sans-serif;
}

.l-content {
  max-width: 1340px;
  position: relative;
  padding: 0 20px;
  display: block;
  margin: 0 auto;
}

@media screen and (min-width: 768px) {
  .u-sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .u-pc {
    display: none !important;
  }
  .l-all {
    overflow: visible;
  }
  .section-group > .l-content {
    overflow-x: hidden;
  }
  .l-body-main {
    padding: 0;
  }
  #section-kv .video-right-wrapper {
    display: none;
  }
}
.body-150th .l-head {
  background-color: #fff;
}
.body-150th .l-head .l-inner {
  z-index: 2000;
}
.page-top .header-tags-container {
  display: block;
  opacity: 1;
  visibility: visible;
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease;
}

video {
  will-change: transform;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

.bt-concept {
  position: fixed;
  cursor: pointer;
  bottom: 0;
  right: 5.1rem;
  z-index: 10;
  width: 18rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.6rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 5rem;
  background-color: #1432AA;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  opacity: 0;
  pointer-events: none;
}
.bt-concept span {
  display: inline-block;
  color: #fff;
  font-size: 1.8rem;
  text-transform: uppercase;
  font-family: "Instrument Serif", serif;
  line-height: 1;
}
.bt-concept .icon-play {
  display: inline-block;
  width: 3rem;
  height: 3rem;
  position: relative;
}
.bt-concept.show {
  opacity: 1;
  pointer-events: auto;
}
.bt-concept.hide {
  display: none;
}
.bt-concept:hover {
  opacity: 0.8;
}

.ele-hover-move {
  overflow: hidden;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  will-change: transform;
}
.ele-hover-move img {
  width: 100%;
  display: block;
  pointer-events: none;
}

.slider-container {
  width: 100%;
  max-width: 1310px;
  margin: 0 auto;
  padding-bottom: 8rem;
  position: relative;
  display: block;
}
.slider-container .slider {
  position: relative;
  width: 100%;
  height: 55.9rem;
}
.slider-container .slider .slide {
  position: absolute;
  width: 25.2rem;
  height: auto;
  -webkit-transition: all 1.2s cubic-bezier(0.25, 0.8, 0.25, 1);
  transition: all 1.2s cubic-bezier(0.25, 0.8, 0.25, 1);
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  will-change: transform;
}
.slider-container .slider .slide .info {
  position: absolute;
  top: 0;
  left: 0;
  display: none;
  overflow: hidden;
}
.slider-container .slider .slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.slider-container .slider-info {
  position: absolute;
  z-index: 10;
  width: 41rem;
  height: 55.9rem;
  overflow: visible;
  left: calc(50% - 44px);
  top: 3rem;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
.slider-container .slider-info .info {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
}
.slider-container .slider-info .info .info-left {
  position: absolute;
  bottom: 0;
  left: -2rem;
  -webkit-transform: translate(0, 30px);
      -ms-transform: translate(0, 30px);
          transform: translate(0, 30px);
}
.slider-container .slider-info .info .info-left .hero-title {
  margin-bottom: 0.4rem;
}
.slider-container .slider-info .info .info-right {
  position: absolute;
  right: 0;
  bottom: 3.5rem;
  -webkit-transform: translate(70%, 0);
      -ms-transform: translate(70%, 0);
          transform: translate(70%, 0);
}
.slider-container .slider-info .info .info-right .hero-title {
  font-size: 2rem;
  margin-bottom: 2.3rem;
}
.slider-container .nav-btn {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: none;
  font-size: 16px;
  font-weight: bold;
  z-index: 10;
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: center;
}
.slider-container .nav-btn:hover {
  opacity: 0.8;
}
.slider-container .nav-btn.prev {
  left: 20px;
  background-image: url("../image/shared/icon_prev.webp");
}
.slider-container .nav-btn.next {
  right: 20px;
  background-image: url("../image/shared/icon_next.webp");
}
.slider-container .group-nav {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 100;
  bottom: -7rem;
  width: 100%;
  text-align: center;
}
.slider-container .dots {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  text-align: center;
  gap: 0.8rem;
}
.slider-container .dots .dot {
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background: #C7C7C7;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.slider-container .dots .dot:hover {
  opacity: 0.8;
}
.slider-container .dots .dot.active {
  background: #1432AA;
}

.modal-open .bg-blue-fix-wrapper {
  display: none;
}

.bg-blue-fix-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  mix-blend-mode: multiply;
  z-index: -1;
}
.bg-blue-fix-wrapper .bg-blue-fix {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  background-color: #1432AA;
  -webkit-transition: opacity 2s 0s ease;
  transition: opacity 2s 0s ease;
}
.bg-blue-fix-wrapper .bg-blue-fix.hide {
  opacity: 0;
}

.section-bg {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.section-bg.ball-fixed {
  position: fixed;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -webkit-transition: -webkit-transform 1.5s 0.2s ease;
  transition: -webkit-transform 1.5s 0.2s ease;
  transition: transform 1.5s 0.2s ease;
  transition: transform 1.5s 0.2s ease, -webkit-transform 1.5s 0.2s ease;
  will-change: transform;
}
.section-bg.ball-fixed .ball-wrapper {
  position: relative;
  pointer-events: none;
  opacity: 0.3;
  -webkit-transition: opacity 1s ease, -webkit-transform 2s ease;
  transition: opacity 1s ease, -webkit-transform 2s ease;
  transition: opacity 1s ease, transform 2s ease;
  transition: opacity 1s ease, transform 2s ease, -webkit-transform 2s ease;
  -webkit-animation: none;
          animation: none;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  will-change: transform;
}
.section-bg.ball-fixed .ball-wrapper.move-left {
  -webkit-transform: translate(-30vw, 0);
      -ms-transform: translate(-30vw, 0);
          transform: translate(-30vw, 0);
  -webkit-transition: opacity 1s ease, -webkit-transform 3s ease;
  transition: opacity 1s ease, -webkit-transform 3s ease;
  transition: opacity 1s ease, transform 3s ease;
  transition: opacity 1s ease, transform 3s ease, -webkit-transform 3s ease;
}
.section-bg.ball-fixed .ball-wrapper.move-right {
  -webkit-transform: translate(30vw, 0);
      -ms-transform: translate(30vw, 0);
          transform: translate(30vw, 0);
  -webkit-transition: opacity 1s ease, -webkit-transform 3s ease;
  transition: opacity 1s ease, -webkit-transform 3s ease;
  transition: opacity 1s ease, transform 3s ease;
  transition: opacity 1s ease, transform 3s ease, -webkit-transform 3s ease;
}
.section-bg.ball-fixed .ball-wrapper .ball {
  pointer-events: none;
  width: 100vw;
  max-width: 132.4rem;
}

.body-150th .img-zoom {
  -webkit-transform: scale(1) translate(0, 0);
      -ms-transform: scale(1) translate(0, 0);
          transform: scale(1) translate(0, 0);
  will-change: transform;
  -webkit-transition: -webkit-transform 3s ease-out;
  transition: -webkit-transform 3s ease-out;
  transition: transform 3s ease-out;
  transition: transform 3s ease-out, -webkit-transform 3s ease-out;
}
.body-150th.is-zooming .img-zoom {
  -webkit-transform: scale(1.04) translate(4px, 5px);
      -ms-transform: scale(1.04) translate(4px, 5px);
          transform: scale(1.04) translate(4px, 5px);
}
#section-kv {
  padding: 0;
  padding-bottom: 5rem;
  margin-bottom: 12.5rem;
  z-index: 99;
  min-height: 0;
  -webkit-perspective: 1200px;
          perspective: 1200px;
}
#section-kv .ele-hover-move {
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  will-change: transform;
}
#section-kv svg {
  position: absolute;
  width: 0;
  height: 0;
}
#section-kv .kv-hero__slide-item {
  will-change: transform;
}
#section-kv .kv-hero__slide-item img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  will-change: transform;
}
#section-kv .kv-hero__slider-track--left .kv-hero__slide--edge-left {
  clip-path: url(#silk-clip1);
  will-change: transform;
}
#section-kv .kv-hero__slider-track--left .kv-hero__slide--main-left {
  clip-path: url(#silk-clip4);
  will-change: transform;
}
#section-kv .kv-hero__slider-track--right .kv-hero__slide--edge-right {
  clip-path: url(#silk-clip6);
  will-change: transform;
}
#section-kv .kv-hero__slider-track--right .kv-hero__slide--main-right {
  clip-path: url(#silk-clip5);
  will-change: transform;
}
#section-kv.is-kv-split-sticky .kv-hero__slider {
  position: sticky;
  top: 31px;
  z-index: 20;
}
#section-kv.kv-fixed .kv-hero__logo {
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#section-kv.kv-fixed .kv-hero__content {
  -webkit-transform: translate(6.03vw, 0);
      -ms-transform: translate(6.03vw, 0);
          transform: translate(6.03vw, 0);
}
#section-kv.has-bg .kv-hero__scroll {
  opacity: 1;
}
#section-kv.has-bg .kv-hero__logo-img {
  background: url(/150th/image/shared/logo_150th_anniversary.svg) no-repeat;
  background-size: 100% auto;
  background-position: center;
  width: 7.778vw;
  height: 2.292vw;
}
#section-kv.has-bg .kv-hero__logo .text {
  color: #fff;
}
#section-kv.has-bg .kv-hero__title {
  color: #fff;
}
#section-kv .slider-kv .slider-kv-inner img {
  width: auto;
  height: calc(100vh - 80px);
}
#section-kv .hero-content .hero-title {
  font-size: 4.5rem;
  margin-bottom: 5rem;
}
#section-kv .hero-content .hero-title .reveal-text {
  padding-right: 0;
}
#section-kv .hero-content .hero-body .reveal {
  margin-bottom: 0.5rem;
}
#section-kv .hero-content .hero-body .reveal:last-child {
  margin-bottom: 0;
}
#section-kv .info {
  height: 100vh;
  width: 100%;
  margin-top: 188px;
}
#section-kv .info .hero-body {
  color: #1432AA;
  text-align: center;
}
#section-kv .kv-hero {
  width: 100%;
  height: 160vh;
}
#section-kv .kv-hero__slider {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 10.069vw;
  width: 100%;
  -webkit-transition: 1.5s ease-out;
  transition: 1.5s ease-out;
  height: max(648px, 100vh - 260px);
  min-height: 500px;
}
#section-kv .kv-hero__slider.is-scroll {
  top: 30vh;
  position: sticky;
}
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--left {
  -webkit-transform: translateX(-64.5%) scale(1.122);
      -ms-transform: translateX(-64.5%) scale(1.122);
          transform: translateX(-64.5%) scale(1.122);
  -webkit-transition: all 0.8s ease-out;
  transition: all 0.8s ease-out;
}
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--left .slick-slide img {
  -webkit-transform: translate(0, -20%);
      -ms-transform: translate(0, -20%);
          transform: translate(0, -20%);
  opacity: 0;
  -webkit-transition: 0.8s all ease-out;
  transition: 0.8s all ease-out;
}
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--left .slick-slide.slick-active img,
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--left .slick-slide.slick-current img {
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  opacity: 1;
  -webkit-transition: 0.8s all ease-out;
  transition: 0.8s all ease-out;
}
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--right {
  -webkit-transition: all 0.8s ease-out;
  transition: all 0.8s ease-out;
  -webkit-transform: translateX(38.4%) scale(1.122);
      -ms-transform: translateX(38.4%) scale(1.122);
          transform: translateX(38.4%) scale(1.122);
}
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--right .slick-slide img {
  -webkit-transform: translate(0, 20%);
      -ms-transform: translate(0, 20%);
          transform: translate(0, 20%);
  opacity: 0;
  -webkit-transition: 0.8s all ease-out;
  transition: 0.8s all ease-out;
}
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--right .slick-slide.slick-active img,
#section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--right .slick-slide.slick-current img {
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  opacity: 1;
  -webkit-transition: 0.8s all ease-out;
  transition: 0.8s all ease-out;
}
#section-kv .kv-hero__content {
  position: absolute;
  width: 1px;
  height: 79vh;
  top: 38px;
  left: 0;
  z-index: 99;
  -webkit-transform: translate(13.73vw, 0);
      -ms-transform: translate(13.73vw, 0);
          transform: translate(13.73vw, 0);
  -webkit-transition: -webkit-transform 1s ease;
  transition: -webkit-transform 1s ease;
  transition: transform 1s ease;
  transition: transform 1s ease, -webkit-transform 1s ease;
}
#section-kv .kv-hero__content .section-heading {
  top: 78px;
}
#section-kv .kv-hero__title {
  font-size: 48px;
  color: #1432AA;
  line-height: 1.2;
  position: sticky;
}
#section-kv .kv-hero__logo {
  position: absolute;
  height: 80vh;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 300px);
      -ms-transform: translate(-50%, 300px);
          transform: translate(-50%, 300px);
  z-index: 99;
  -webkit-transition: 1s ease;
  transition: 1s ease;
}
#section-kv .kv-hero__logo-img {
  position: sticky;
  top: 130px;
  background: url(/150th/image/shared/logo_150th_anniversary_blue.svg) no-repeat;
  background-size: 100% auto;
  background-position: center;
  width: 7.778vw;
  height: 2.292vw;
}
#section-kv .kv-hero__logo .text {
  position: absolute;
  pointer-events: none;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  white-space: nowrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1.4rem;
  color: #1432AA;
}
#section-kv .kv-hero__scroll {
  font-size: 14px;
  line-height: 1;
  font-family: "Instrument Serif", serif;
  color: #fff;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding-bottom: 21px;
  padding-top: 12px;
  opacity: 0;
}
#section-kv .kv-hero__scroll::after {
  position: absolute;
  height: 15px;
  width: 1px;
  content: "";
  bottom: 1px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #fff;
}
#section-kv .kv-hero__slider-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 10.069vw;
  width: calc(50% - 5.347vw);
  min-width: 0;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transform: translateX(0) scale(1);
      -ms-transform: translateX(0) scale(1);
          transform: translateX(0) scale(1);
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
#section-kv .kv-hero__slider-track--left {
  -webkit-transform: translateX(-25%) scale(1);
      -ms-transform: translateX(-25%) scale(1);
          transform: translateX(-25%) scale(1);
  -webkit-transition: all 0.8s ease-out;
  transition: all 0.8s ease-out;
}
#section-kv .kv-hero__slider-track--right {
  -webkit-transition: all 0.8s ease-out;
  transition: all 0.8s ease-out;
}
#section-kv .kv-hero__slide {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0px;
          flex: 1 1 0;
  min-width: 22.731vw;
  overflow: hidden;
}
#section-kv .kv-hero__slide-item {
  width: 100%;
}
#section-kv .kv-hero__slide-item img {
  display: block;
  width: 100%;
  height: auto;
}
#section-kv .kv-hero__scroll {
  margin-top: -60px;
}
#section-kv .l-content {
  position: absolute;
  z-index: 2;
  width: 100%;
  height: 100%;
  left: 50%;
  top: 0;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#section-kv .video-right-wrapper {
  position: absolute;
  z-index: 10;
  right: 0;
  top: 0;
}
#section-kv .video-right-wrapper.fixed {
  z-index: 0;
}
#section-kv .video-right-wrapper.fixed .video-right {
  position: fixed;
  top: 5.1rem;
  z-index: 1;
}
#section-kv .video-right {
  position: relative;
  top: 0;
  right: 0;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30.2rem;
  height: 17rem;
  background: url("../image/top/video_menu.webp") no-repeat;
  background-size: cover;
  cursor: pointer;
}
#section-kv .video-right .icon-play .play-ring {
  width: 50px;
  aspect-ratio: 1/1;
  display: block;
}
#section-kv .video-right .video-text {
  position: absolute;
  width: 100%;
  text-align: center;
  bottom: 0;
  left: 0;
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
  font-size: 2.6rem;
  line-height: 4.7rem;
  color: #fff;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
#section-kv .video-right::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 1;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  background-color: rgba(0, 0, 0, 0.5);
}
#section-kv .video-right:hover .video-text {
  color: #1432AA;
}
#section-kv .video-right:hover::before {
  opacity: 0;
}
#section-kv .video-right:hover .ring-progress {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}

#section-message {
  padding-top: 0;
}
#section-message .ball-wrapper {
  left: -28vw;
  top: -20vw;
}
#section-message .ball-wrapper .ball {
  max-width: 180rem;
}
#section-message .l-content {
  padding-top: 7rem;
  padding-bottom: 15.4rem;
}
#section-message .c-group-image-text {
  gap: 3.8rem;
}
#section-message .hero-content {
  left: 0;
  position: relative;
  top: 0;
}
#section-message .hero-content .hero-body {
  max-width: 58rem;
}
#section-message .hero-content .hero-title {
  margin-bottom: 0;
}
#section-message .hero-content .hero-body2 {
  margin-top: 3.6rem;
  margin-bottom: 1.3rem;
}

.text-anim.animated .reveal::before {
  -webkit-animation: panel-sweep 0.5s 0.5s ease-in-out forwards;
          animation: panel-sweep 0.5s 0.5s ease-in-out forwards;
}
.text-anim.animated .reveal-text {
  -webkit-animation: text-rise 0.6s 1s ease forwards;
          animation: text-rise 0.6s 1s ease forwards;
}

.hero {
  padding: 44px 48px 56px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: -webkit-gradient(linear, left top, right top, from(rgba(8, 32, 99, 0.35)), color-stop(60%, rgba(8, 32, 99, 0)));
  background: linear-gradient(90deg, rgba(8, 32, 99, 0.35), rgba(8, 32, 99, 0) 60%);
  pointer-events: none;
}
.hero-content {
  position: absolute;
  top: 12.5rem;
  left: 10rem;
  max-width: 900px;
  z-index: 1;
}
.hero-title {
  font-size: 3rem;
  margin-bottom: 3rem;
}
.hero-title.title-small {
  font-size: 1.6rem;
  margin-bottom: 1.1rem;
}
.hero-title.title-small .reveal::before {
  background-color: #1432AA;
}
.hero-title.title-small .reveal .reveal-text {
  background-color: #1432AA;
  color: #fff;
  padding: 0.95rem 1rem;
}
.hero-title .reveal {
  margin-bottom: 0.9rem;
}
.hero-title .reveal:last-child {
  margin-bottom: 0;
}
.hero-title .reveal::before {
  -webkit-animation-duration: 0.75s;
          animation-duration: 0.75s;
}
.hero-title .reveal-text {
  -webkit-animation-delay: 0.9s;
          animation-delay: 0.9s;
  line-height: 1;
  white-space: nowrap;
  font-weight: 500;
  padding: 0.35rem 1rem;
}
.hero-body {
  font-size: 1.6rem;
  display: block;
}
.hero-body .reveal {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  margin-bottom: 1.1rem;
}
.hero-body .reveal:last-child {
  margin-bottom: 0;
}
.hero-body .reveal::before {
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
}
.hero-body .reveal-text {
  -webkit-animation-delay: 0.75s;
          animation-delay: 0.75s;
  line-height: 1;
  white-space: nowrap;
  font-weight: 500;
  padding: 0.25rem 0.5rem;
}

.reveal {
  display: inline-block;
  position: relative;
  overflow: hidden;
  vertical-align: bottom;
}
.reveal::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff;
  -webkit-transform-origin: left center;
      -ms-transform-origin: left center;
          transform-origin: left center;
  -webkit-transform: scaleX(0);
      -ms-transform: scaleX(0);
          transform: scaleX(0);
  z-index: 0;
}

.reveal-text {
  position: relative;
  display: inline-block;
  color: #1432AA;
  z-index: 1;
  -webkit-transform: translateY(110%);
      -ms-transform: translateY(110%);
          transform: translateY(110%);
}

.slider-kv {
  display: grid;
  width: 100%;
  overflow: hidden;
  position: relative;
}
.slider-kv .slider-kv-inner {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-animation: scroll-to-left 30s infinite linear forwards;
          animation: scroll-to-left 30s infinite linear forwards;
  will-change: transform;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
.slider-kv .slider-kv-inner img {
  width: 503px;
  display: block;
  will-change: transform;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

.ball-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-animation: floatMove 40s 1s ease-in-out infinite;
          animation: floatMove 40s 1s ease-in-out infinite;
  will-change: transform;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.ball {
  position: relative;
  width: 100vw;
  -webkit-animation: softBounce 20s ease-in-out infinite;
          animation: softBounce 20s ease-in-out infinite;
  will-change: transform;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.text-anim-clip-path {
  clip-path: inset(0px 100% 0px 0px);
}
.text-anim-clip-path.animated {
  -webkit-transition: all 1.5s 1s ease;
  transition: all 1.5s 1s ease;
  clip-path: inset(0px -5% 0px 0px);
}

@-webkit-keyframes scroll-to-left {
  from {
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
  to {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@keyframes scroll-to-left {
  from {
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
  to {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
@-webkit-keyframes scroll-to-right {
  from {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  to {
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
@keyframes scroll-to-right {
  from {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  to {
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
@-webkit-keyframes softBounce {
  0% {
    -webkit-transform: scale(1, 1) rotate(0deg);
            transform: scale(1, 1) rotate(0deg);
  }
  22% {
    -webkit-transform: scale(1, 1.05) rotate(0.4deg);
            transform: scale(1, 1.05) rotate(0.4deg);
  }
  48% {
    -webkit-transform: scale(0.95, 1) rotate(-0.3deg);
            transform: scale(0.95, 1) rotate(-0.3deg);
  }
  73% {
    -webkit-transform: scale(1, 1.03) rotate(0.2deg);
            transform: scale(1, 1.03) rotate(0.2deg);
  }
  100% {
    -webkit-transform: scale(1, 1) rotate(0deg);
            transform: scale(1, 1) rotate(0deg);
  }
}
@keyframes softBounce {
  0% {
    -webkit-transform: scale(1, 1) rotate(0deg);
            transform: scale(1, 1) rotate(0deg);
  }
  22% {
    -webkit-transform: scale(1, 1.05) rotate(0.4deg);
            transform: scale(1, 1.05) rotate(0.4deg);
  }
  48% {
    -webkit-transform: scale(0.95, 1) rotate(-0.3deg);
            transform: scale(0.95, 1) rotate(-0.3deg);
  }
  73% {
    -webkit-transform: scale(1, 1.03) rotate(0.2deg);
            transform: scale(1, 1.03) rotate(0.2deg);
  }
  100% {
    -webkit-transform: scale(1, 1) rotate(0deg);
            transform: scale(1, 1) rotate(0deg);
  }
}
@-webkit-keyframes panel-sweep {
  to {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}
@keyframes panel-sweep {
  to {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}
@-webkit-keyframes text-rise {
  from {
    -webkit-transform: translateY(105%);
            transform: translateY(105%);
  }
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes text-rise {
  from {
    -webkit-transform: translateY(105%);
            transform: translateY(105%);
  }
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.section-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  min-height: 100vh;
  position: relative;
}
.section-group > .l-content {
  width: 100%;
  padding: 100px 0;
}
.section-group .l-heading {
  position: absolute;
  z-index: 99;
  left: 5rem;
  display: block;
  width: 1px;
  height: calc(100% - 10rem);
  top: 0;
  pointer-events: none;
}
.section-group .l-heading .section-heading {
  pointer-events: auto;
}
.section-group .section-heading {
  position: sticky;
  top: 0.1rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  white-space: nowrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.section-group .section-heading .section-heading-big {
  font-family: "Instrument Serif", serif;
  font-size: 45px;
  padding: 0.25rem 0.8rem;
  line-height: 1;
  font-weight: 400;
  background-color: #fff;
}
.section-group .section-heading .section-heading-small {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 0.45rem 0.8rem;
  font-size: 16px;
  font-weight: 500;
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
  background-color: #fff;
}
.is-windows .section-group .section-heading .section-heading-small {
  padding: 0.3rem 0.8rem 0.6rem;
}
.section-group .section-heading.section-heading--blue .section-heading-big {
  background-color: #1432AA;
  color: #fff;
}
.section-group .section-heading.section-heading--blue .section-heading-small {
  background-color: #1432AA;
  color: #fff;
}

.c-group-image-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 3rem;
}
.c-group-image-text .c-text {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 10px;
}
.c-group-image-text .c-text .c-bg-white {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 1.6rem;
  line-height: 1;
  padding: 0.5rem;
  background-color: #fff;
}
.c-group-image-text .c-image {
  display: block;
}

.video-contain {
  background-color: #000;
  width: 100%;
  max-width: 90rem;
  height: 0;
  padding-bottom: 56.25%;
  display: block;
  position: relative;
}
.video-contain video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.video-contain iframe {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: scale(1.02);
      -ms-transform: scale(1.02);
          transform: scale(1.02);
  width: 100%;
  height: 100%;
}

.full-movie .video-contain {
  background-color: transparent;
  overflow: hidden;
}
.full-movie .video-contain iframe {
  opacity: 0;
}
.full-movie .video-contain iframe.show {
  opacity: 1;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

#splash-intro {
  pointer-events: none;
  background-color: #fff;
  overflow: hidden;
}
#splash-intro .modal-container {
  z-index: 100;
}
#splash-intro .close-btn {
  pointer-events: auto;
  z-index: 100;
}
#splash-intro .video-contain {
  z-index: 100;
  background-color: #fff;
  opacity: 0;
  pointer-events: auto;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}
#splash-intro .video-contain.active {
  opacity: 1;
}
#splash-intro .video-contain.video-contain1 {
  position: absolute;
  width: 9rem;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
#splash-intro .video-contain .video-title {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-transform: translate(0, -56px);
      -ms-transform: translate(0, -56px);
          transform: translate(0, -56px);
  text-align: center;
}
#splash-intro .video-contain .video-title img {
  display: inline-block;
  width: 5.3rem;
}
#splash-intro .video-contain .video-title .video-text {
  font-size: 2rem;
  color: #1432AA;
  display: block;
  margin-top: 0.5rem;
}
#splash-intro .video-contain .bt-skip {
  position: absolute;
  z-index: 100;
  cursor: pointer;
  bottom: 0;
  left: 0;
  width: 100%;
  -webkit-transform: translate(0, 42px);
      -ms-transform: translate(0, 42px);
          transform: translate(0, 42px);
  display: block;
  text-align: center;
  font-family: "Instrument Serif", serif;
  color: #1432AA;
  font-size: 1.8rem;
}

#section-movie {
  height: 100vh;
  display: block;
}
#section-movie .l-content {
  height: 100%;
}
#section-movie .group-movie-title-wrapper {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50vh;
  overflow: hidden;
  pointer-events: none;
}
#section-movie .group-movie-title {
  position: absolute;
  z-index: 10;
  bottom: -6vw;
  left: 0;
  mix-blend-mode: exclusion;
}
#section-movie .group-movie-title .movie-title {
  font-family: "Instrument Serif", serif;
  font-size: 12.5vw;
  line-height: 1;
  color: #FF6A6A;
}
#section-movie .group-movie-title .movie-title.title2 {
  -webkit-transform: translate(49.6%, -30%);
      -ms-transform: translate(49.6%, -30%);
          transform: translate(49.6%, -30%);
  position: relative;
  z-index: 1;
}

.bg-full-movie {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.bg-full-movie:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background-color: #1432AA;
  mix-blend-mode: overlay;
}
.bg-full-movie video {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  -o-object-fit: cover;
     object-fit: cover;
}
.bg-full-movie .icon-play {
  position: absolute;
  z-index: 50;
  cursor: pointer;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.bg-full-movie .icon-play svg {
  width: 9.2rem;
}
.bg-full-movie .icon-text {
  position: absolute;
  left: 0;
  bottom: 15px;
  width: 100%;
  height: 21px;
  font-size: 16px;
  line-height: 21px;
  color: #fff;
  font-family: "Instrument Serif", serif;
  text-align: center;
}
.bg-full-movie .play-ring {
  width: 80px;
  aspect-ratio: 1/1;
  display: block;
}

.ring-base {
  fill: none;
  stroke: #fff;
  stroke-width: 2;
}

.ring-progress {
  fill: none;
  stroke: #1432AA;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 220;
  stroke-dashoffset: 180;
  -webkit-transform-origin: 50% 50%;
      -ms-transform-origin: 50% 50%;
          transform-origin: 50% 50%;
  -webkit-animation: spin-ring 3s linear infinite;
          animation: spin-ring 3s linear infinite;
}

.play-ring:hover .ring-progress {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}

.play-icon {
  fill: #fff;
}

#section-history .group-bt {
  display: block;
  z-index: 12;
  width: 100%;
  padding: 3rem 0;
  padding-bottom: 15rem;
  text-align: center;
}
#section-history .l-content {
  position: absolute;
  height: auto;
  padding: 0;
  z-index: 10;
  width: 100%;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  top: 12.6rem;
}
#section-history .slider-kv {
  padding-top: 12.6rem;
}
#section-history .slider-kv .slider-kv-inner {
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  -webkit-animation: scroll-to-right 60s infinite linear forwards;
          animation: scroll-to-right 60s infinite linear forwards;
  gap: 2rem;
  will-change: transform;
}
#section-history .slider-kv .slider-kv-inner img {
  width: 294.6rem;
}
#section-history .hero-content {
  left: 5rem;
  position: relative;
  top: 0;
}
#section-history .hero-content .hero-body.hero-body2 {
  margin-top: 4.4rem;
}
#section-history .ball-wrapper {
  left: auto;
  right: -21vw;
  top: -30vw;
}
#section-history .ball-wrapper .ball {
  width: 115vw;
  max-width: 192rem;
}

#section-vision {
  position: relative;
  height: 100%;
}
#section-vision .section-vision-wapper {
  padding-inline: 50px;
  padding-bottom: 8.5vh;
  padding-top: 24vh;
  min-height: 100vh;
  background: #1432AA;
  width: 100%;
  text-align: center;
  position: relative;
}
#section-vision::after, #section-vision::before {
  position: absolute;
  content: "";
  width: 1px;
  height: 100%;
  background: #fff;
  top: 0;
  z-index: 999;
}
#section-vision::after {
  left: 49px;
}
#section-vision::before {
  right: 49px;
}
#section-vision .slider-kv-inner .vision-slider-text {
  color: #1432AA;
  background: #fff;
}
#section-vision .slider-kv-inner + .slider-kv-inner {
  margin-top: 10px;
}
#section-vision .bt-view-more {
  margin: 44px auto 0;
  z-index: 1000;
}

.vision-line {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  pointer-events: none;
}

.line--horizontal::after {
  display: block;
  content: "";
  width: 100%;
  height: 1px;
  background: #fff;
  left: 0;
  top: 51px;
  position: sticky;
  margin-top: 50px;
}

.container-scroller {
  width: 100%;
  display: block;
  overflow: auto;
  /* native scroll */
  overflow-x: auto;
  overflow-y: hidden;
  /* Firefox */
  scrollbar-width: none;
  /* IE / Edge legacy */
  -ms-overflow-style: none;
}
.container-scroller.is-drag {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
.container-scroller .scroller {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  padding-left: 13rem;
}
.container-scroller .scroller .item {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  white-space: nowrap;
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.container-scroller .scroller .item .img-contain {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  position: relative;
  cursor: pointer;
}
.container-scroller .scroller .item .img-contain img {
  width: 41rem;
  max-width: none;
  pointer-events: none;
}

@media screen and (min-width: 768px) {
  #section-challenge {
    min-height: 95rem;
  }
}
#section-challenge .slider-container {
  overflow: hidden;
  padding-top: 3rem;
  padding-bottom: 14.5rem;
  -ms-touch-action: pan-y;
      touch-action: pan-y;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
#section-challenge .slider-container .slide {
  clip-path: url(#silk-clip3);
}
#section-challenge .slider-container .slider-info {
  pointer-events: none;
}
#section-challenge .slider-container img {
  pointer-events: none;
  aspect-ratio: 0.7334525939;
}
#section-challenge .ball-wrapper .ball {
  max-width: 180rem;
}
#section-challenge .btn-open-wrapper::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: rgba(20, 50, 170, 0.6);
  opacity: 0;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
#section-challenge .btn-open-wrapper:hover::before {
  opacity: 1;
}
#section-challenge .btn-open-wrapper:hover .btn-open {
  background-color: #fff;
  z-index: 2;
}
#section-challenge .btn-open-wrapper:hover .btn-open::before, #section-challenge .btn-open-wrapper:hover .btn-open::after {
  background-color: #1432AA;
}
#section-challenge .btn-open {
  width: 8rem;
  height: 5rem;
  border-radius: 2.5rem;
  background-color: #1432AA;
  left: 50%;
  bottom: 0;
  -webkit-transform: translate(-50%, 50%);
      -ms-transform: translate(-50%, 50%);
          transform: translate(-50%, 50%);
  position: absolute;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
#section-challenge .btn-open::before {
  content: "";
  position: absolute;
  width: 1.5rem;
  height: 0.1rem;
  background-color: #fff;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
#section-challenge .btn-open::after {
  content: "";
  position: absolute;
  width: 1.5rem;
  height: 0.1rem;
  background-color: #fff;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
      -ms-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
#section-challenge .section-bg {
  overflow: visible;
}
#section-challenge .ball-wrapper {
  left: -28vw;
  top: -20vw;
}
#section-challenge .hero-content {
  left: 0;
  position: relative;
  top: 0;
}
#section-challenge .l-content {
  position: absolute;
  pointer-events: none;
  z-index: 10;
  width: 100%;
  height: 55.9rem;
  padding: 0;
  left: 50%;
  top: 42%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
#section-challenge .l-content .hero-content {
  left: 5rem;
}
#section-challenge .container-scroller {
  padding: 17.2rem 0;
}

#section-anniversary .section-bg {
  left: 50%;
  max-width: 145.8rem;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  bottom: 0;
  top: auto;
  z-index: 0;
}
#section-anniversary .ball-wrapper {
  top: 10rem;
}
#section-anniversary .ball-wrapper .ball {
  -webkit-transform-origin: center bottom;
      -ms-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
}
#section-anniversary .section-heading {
  margin-bottom: 4.5rem;
}
#section-anniversary .hero-content {
  left: 5rem;
  position: relative;
  top: 0;
}
#section-anniversary .group-text {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
#section-anniversary .group-text .anniversary_logo {
  width: 30rem;
  height: 30rem;
  margin-bottom: 3.2rem;
}
.bt-view-more {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 0 2.6rem;
  min-width: 15rem;
  height: 8rem;
  border-radius: 4rem;
  border: 1px solid #1432AA;
  background-color: #1432AA;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  overflow: hidden;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.bt-view-more span {
  position: relative;
  z-index: 2;
  font-family: "Instrument Serif", serif;
  font-size: 1.4rem;
  line-height: 1;
  color: #fff;
}
.bt-view-more.bt-white {
  background: #fff;
}
.bt-view-more.bt-white span {
  color: #1432AA;
}
.bt-view-more::before {
  content: "";
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  opacity: 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-transform-origin: left bottom;
      -ms-transform-origin: left bottom;
          transform-origin: left bottom;
}
.bt-view-more:hover {
  background-color: #fff;
}
.bt-view-more:hover span {
  color: #1432AA;
}

@media screen and (max-width: 767px) {
  .bg-blue-fix-wrapper .bg-blue-fix {
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
    -webkit-transition: all 1s 0.1s ease;
    transition: all 1s 0.1s ease;
  }
  .bg-blue-fix-wrapper .bg-blue-fix.hide {
    -webkit-transform: translate(0, -110%);
        -ms-transform: translate(0, -110%);
            transform: translate(0, -110%);
    -webkit-transition: all 1s 0.1s ease;
    transition: all 1s 0.1s ease;
    opacity: 1;
  }
  .slider-container .slider {
    height: 33.6rem;
  }
  .slider-container .slider .slide {
    width: 10.1rem;
    clip-path: url(#silk-clip4);
  }
  .slider-container .slider-info {
    width: 24.6rem;
    height: 33.6rem;
  }
  .slider-container .slider-info .info .info-left {
    top: 100%;
    left: -4rem;
    -webkit-transform: translate(0, 43px);
        -ms-transform: translate(0, 43px);
            transform: translate(0, 43px);
  }
  .slider-container .slider-info .info .info-left .hero-title {
    margin-bottom: 0;
  }
  .slider-container .slider-info .info .info-right {
    right: 0;
    top: 0;
    width: 100%;
    height: 100%;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  .slider-container .slider-info .info .info-right .hero-title {
    position: absolute;
    top: 0;
    left: 0;
    font-size: 1.8rem;
    -webkit-transform: translate(-45px, -16px);
        -ms-transform: translate(-45px, -16px);
            transform: translate(-45px, -16px);
  }
  .slider-container .slider-info .info .info-right .hero-body {
    position: absolute;
    right: 0;
    text-align: right;
    font-size: 1.4rem;
    -webkit-transform: translate(45px, 0);
        -ms-transform: translate(45px, 0);
            transform: translate(45px, 0);
  }
  .slider-container .slider-info .info .info-right .hero-body .reveal {
    margin-bottom: 0.9rem;
  }
  .slider-container .nav-btn {
    width: 1.1rem;
    height: 1.1rem;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    background: none;
    font-size: 16px;
    font-weight: bold;
    z-index: 10;
    background-repeat: no-repeat;
    background-size: auto 100%;
    background-position: center;
  }
  .slider-container .nav-btn:hover {
    opacity: 0.8;
  }
  .slider-container .nav-btn.prev {
    left: 20px;
    background-image: url("../image/shared/icon_prev.webp");
  }
  .slider-container .nav-btn.next {
    right: 20px;
    background-image: url("../image/shared/icon_next.webp");
  }
  .section-bg.ball-fixed .ball-wrapper .ball {
    width: 160vw;
  }
  .hero-title {
    font-size: 2.4rem;
  }
  .hero-title .reveal {
    margin-bottom: 0.5rem;
  }
  .hero-title .reveal-text {
    padding: 0.35rem 0.6rem;
  }
  .hero-body {
    font-size: 1.4rem;
  }
  .ball {
    max-width: none;
  }
  .section-group .l-heading {
    left: 0;
  }
  .section-group .l-heading .section-heading {
    top: 0;
  }
  .section-group .l-heading .section-heading::after {
    width: 0;
    -webkit-transition: 0.3s ease-in;
    transition: 0.3s ease-in;
  }
  .section-group .l-heading .section-heading.is-top::after, .section-group .l-heading .section-heading.is-top::before {
    position: absolute;
    content: "";
    top: 50px;
    left: 0;
    width: 100vw;
    height: 1px;
    background: #1432AA;
    z-index: 1005;
    -webkit-transition: 0.3s ease-in;
    transition: 0.3s ease-in;
  }
  .section-group .l-heading .section-heading.is-top::before {
    top: 0;
  }
  .section-group .l-heading .section-heading.is-top::after {
    top: 50px;
  }
  .section-group .l-heading .section-heading-big {
    padding: 0.25rem 0.6rem;
  }
  .section-group .l-heading .section-heading-small {
    padding: 0.25rem 0.6rem;
  }
  .section-group .l-content {
    padding: 10rem 2rem;
  }
  .slider-kv .slider-kv-inner img {
    width: 43rem;
  }
  #section-kv {
    padding-bottom: 0;
  }
  #section-kv .kv-hero__slider-track--left .kv-hero__slide--edge-left {
    clip-path: url(#silk-clip4);
    will-change: transform;
  }
  #section-kv .kv-hero__slider-track--left .kv-hero__slide--main-left {
    clip-path: url(#silk-clip4);
    will-change: transform;
  }
  #section-kv .kv-hero__slider-track--right .kv-hero__slide--edge-right {
    clip-path: url(#silk-clip4);
    will-change: transform;
  }
  #section-kv .kv-hero__slider-track--right .kv-hero__slide--main-right {
    clip-path: url(#silk-clip4);
    will-change: transform;
  }
  #section-kv.has-bg .kv-hero__content {
    left: 1.6rem;
    top: 3rem;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  #section-kv.has-bg .kv-hero__logo-img {
    width: 9.4rem;
    height: 2.8rem;
  }
  #section-kv.has-bg .kv-hero__logo-img .text {
    color: #fff;
  }
  #section-kv .hero-content {
    left: 2.5rem;
  }
  #section-kv .hero-content .hero-title {
    font-size: 3.2rem;
  }
  #section-kv .hero-content .hero-body {
    text-align: right;
    padding-right: 2rem;
  }
  #section-kv .info {
    z-index: 999;
    max-width: 90vw;
    margin: 15rem auto 0;
    position: relative;
  }
  #section-kv.kv-fixed .kv-hero__content {
    height: 102vh;
  }
  #section-kv.kv-fixed .kv-hero__title {
    top: 10.2rem;
    -webkit-transform: translate(0, -50%) scale(1);
        -ms-transform: translate(0, -50%) scale(1);
            transform: translate(0, -50%) scale(1);
  }
  #section-kv.kv-fixed .kv-hero__logo {
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  #section-kv.kv-fixed .kv-hero__logo .kv-hero__logo-img {
    -webkit-transform: translate(0, 0) scale(1);
        -ms-transform: translate(0, 0) scale(1);
            transform: translate(0, 0) scale(1);
  }
  #section-kv .kv-hero {
    padding-bottom: 0;
    height: 170svh;
  }
  #section-kv .kv-hero__slider {
    gap: 0;
    padding-top: 0;
    overflow: hidden;
    height: calc(100svh - 208px);
    margin-top: -20px;
    min-height: 0;
  }
  #section-kv .kv-hero__slider.is-scroll {
    top: 0;
    position: sticky;
    left: 0;
    width: 100%;
    z-index: 20;
    padding-top: 0;
    height: calc(100vh - 100px);
  }
  #section-kv .kv-hero__slider.is-scroll .kv-hero__slide--edge-left {
    opacity: 0;
    -webkit-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  #section-kv .kv-hero__slider.is-scroll .kv-hero__slide--edge-right {
    opacity: 0;
    -webkit-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  #section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--left {
    -webkit-transform: translate(-18%, 6svh) scale(1);
        -ms-transform: translate(-18%, 6svh) scale(1);
            transform: translate(-18%, 6svh) scale(1);
  }
  #section-kv .kv-hero__slider.is-scroll .kv-hero__slider-track--right {
    -webkit-transform: translate(7.2%, 0%) scale(1);
        -ms-transform: translate(7.2%, 0%) scale(1);
            transform: translate(7.2%, 0%) scale(1);
  }
  #section-kv .kv-hero__content {
    height: calc(100svh - 208px);
  }
  #section-kv .kv-hero__content .section-heading {
    top: 0;
    height: 100%;
  }
  #section-kv .kv-hero__title {
    font-size: 1.8rem;
    -webkit-transform: translate(8vw, -50%) scale(1.666);
        -ms-transform: translate(8vw, -50%) scale(1.666);
            transform: translate(8vw, -50%) scale(1.666);
    top: 48%;
    -webkit-transform-origin: left top;
        -ms-transform-origin: left top;
            transform-origin: left top;
    -webkit-transition: 0.8s ease-out;
    transition: 0.8s ease-out;
  }
  #section-kv .kv-hero__logo {
    position: sticky;
    height: auto;
    left: calc(100vw - 60px);
    top: calc(100svh - 140px);
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
    width: 49px;
    height: 25px;
  }
  #section-kv .kv-hero__logo-img {
    position: absolute;
    top: auto;
    left: auto;
    right: 0;
    bottom: 0;
    width: 11.2rem;
    height: 3.3rem;
    -webkit-transform: translate(-20vw, -15svh) scale(1.2);
        -ms-transform: translate(-20vw, -15svh) scale(1.2);
            transform: translate(-20vw, -15svh) scale(1.2);
    -webkit-transform-origin: right bottom;
        -ms-transform-origin: right bottom;
            transform-origin: right bottom;
    -webkit-transition: 0.8s ease-out;
    transition: 0.8s ease-out;
  }
  #section-kv .kv-hero__slider-track {
    width: 44svh;
    gap: 0 0;
    height: 100%;
    -webkit-box-align: normal;
        -ms-flex-align: normal;
            align-items: normal;
    padding-block: 5px 15px;
  }
  #section-kv .kv-hero__slider-track--left {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-transform: translateX(0) scale(1);
        -ms-transform: translateX(0) scale(1);
            transform: translateX(0) scale(1);
  }
  #section-kv .kv-hero__slider-track--left .kv-hero__slide-item.slick-active {
    z-index: 99;
    position: relative;
  }
  #section-kv .kv-hero__slider-track--right {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-transform: translateX(0) scale(1);
        -ms-transform: translateX(0) scale(1);
            transform: translateX(0) scale(1);
  }
  #section-kv .kv-hero__slider-track--right .kv-hero__slide-item.slick-active {
    -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    z-index: -1;
    position: relative;
  }
  #section-kv .kv-hero__slide {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  #section-kv .kv-hero__slide--main-left {
    margin-top: -6svh;
  }
  #section-kv .kv-hero__slide--edge-left {
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  #section-kv .kv-hero__slide--edge-right {
    -webkit-transform: translateX(50%);
        -ms-transform: translateX(50%);
            transform: translateX(50%);
    margin-top: -6svh;
  }
  #section-kv .kv-hero__slide-item img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #section-kv .kv-hero__scroll {
    display: none;
  }
  .slick-list {
    width: 25.616svh;
    height: 100%;
  }
  .slick-track {
    height: 100%;
  }
  #section-message .l-content {
    padding-top: 140px;
    padding-bottom: 108px;
  }
  #section-message .section-bg .ball-wrapper {
    -webkit-animation-name: floatMove-message-sp;
            animation-name: floatMove-message-sp;
    top: 30%;
    left: -55%;
  }
  #section-message .section-bg .ball-wrapper .ball {
    width: 178vw;
  }
  #section-message .c-group-image-text {
    padding: 0 2rem;
    gap: 3.5rem;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  #section-message .c-group-image-text .hero-body {
    max-width: calc(100vw - 60px);
  }
  #section-message .c-group-image-text .c-image {
    width: auto;
  }
  #section-movie {
    min-height: 81.2rem;
  }
  #section-movie .group-movie-title-wrapper {
    height: 100%;
  }
  #section-movie .group-movie-title {
    bottom: 0;
    width: 100%;
    height: 100%;
  }
  #section-movie .group-movie-title .movie-title {
    position: relative;
    white-space: nowrap;
  }
  #section-movie .group-movie-title .movie-title.title1 {
    top: -4rem;
    left: -1.8rem;
    font-size: 12rem;
    -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
            transform: rotate(90deg);
    -webkit-transform-origin: 0 100%;
        -ms-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  #section-movie .group-movie-title .movie-title.title2 {
    top: 10rem;
    right: 10.2rem;
    font-size: 12rem;
    -webkit-transform: rotate(-90deg);
        -ms-transform: rotate(-90deg);
            transform: rotate(-90deg);
    -webkit-transform-origin: 100% 0;
        -ms-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
  #section-history .section-bg .ball-wrapper {
    top: 30%;
    left: -55%;
  }
  #section-history .section-bg .ball-wrapper .ball {
    width: 178vw;
  }
  #section-history .hero-content {
    left: 2rem;
  }
  #section-history .slider-kv {
    padding: 0;
    padding-top: 14rem;
  }
  #section-history .slider-kv .slider-kv-inner {
    gap: 1rem;
  }
  #section-history .slider-kv .slider-kv-inner img {
    width: auto;
    height: 65.4rem;
  }
  #section-history .group-bt {
    padding-bottom: 10rem;
  }
  #section-challenge {
    padding-bottom: 11.5rem;
  }
  #section-challenge .l-content {
    position: relative;
    height: auto;
    padding-top: 13.4rem;
    top: 0;
    left: 0;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  #section-challenge .l-content .hero-content {
    left: 2.4rem;
  }
  #section-challenge .slider-container {
    padding-top: 9rem;
    top: 0;
  }
  #section-challenge .slider-container .slider-info {
    top: 9rem;
    left: 50%;
  }
  #section-challenge .slider-container .slider-info .info-left .hero-content {
    top: 10px;
  }
  #section-challenge .slider-container .slider-info .info-right .hero-title {
    -webkit-transform: translate(-42px, -9px);
        -ms-transform: translate(-42px, -9px);
            transform: translate(-42px, -9px);
  }
  #section-challenge .slider-container .slider-info .info-right .hero-content {
    height: 100%;
    bottom: 0;
    top: auto;
  }
  #section-challenge .slider-container .slider-info .info-right .hero-body {
    bottom: -4rem;
    -webkit-transform: translate(45px, 0);
        -ms-transform: translate(45px, 0);
            transform: translate(45px, 0);
  }
  #section-challenge .slider-container .group-nav {
    bottom: -14.5rem;
  }
  #section-anniversary {
    min-height: 0;
  }
  #section-anniversary .l-content {
    padding-bottom: 6.4rem;
    padding-top: 110px;
  }
  #section-anniversary .hero-content {
    left: 0;
    margin-bottom: 4.5rem;
  }
  #section-anniversary .group-text .anniversary_logo {
    width: 20rem;
    height: 20rem;
  }
  .body-150th .img-zoom {
    height: 100%;
  }
}
@media screen and (max-height: 667px) {
  #section-kv .kv-hero__slider {
    padding-top: 0;
  }
}
@media screen and (min-width: 2000px) {
  #section-kv .kv-hero__slide {
    min-width: 500px;
  }
  #section-kv .kv-hero__slider-track,
  #section-kv .kv-hero__slider {
    gap: 0 15.069vw;
  }
}
@media screen and (max-width: 374px) {
  #section-kv .kv-hero__logo-img {
    -webkit-transform: translate(-25vw, -6svh) scale(1.2);
        -ms-transform: translate(-25vw, -6svh) scale(1.2);
            transform: translate(-25vw, -6svh) scale(1.2);
  }
}
@media screen and (min-width: 768px) {
  .l-page-history .l-footer-150th-wrapper {
    display: none;
  }
  .l-page-history .l-footer-150th-wrapper.active {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(2rem);
  -webkit-backdrop-filter: blur(2rem);
  display: none;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 9999;
  padding: 2rem;
}
.modal-overlay.active {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.modal-overlay .modal-container {
  width: 100%;
  max-width: 84.7rem;
  position: relative;
  margin: auto;
}
.modal-overlay .layout-split {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5.3rem;
}
@media (max-width: 768px) {
  .modal-overlay .layout-split {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.modal-overlay .content-left {
  -webkit-box-flex: 1.3;
      -ms-flex: 1.3;
          flex: 1.3;
}
.modal-overlay .content-right {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.modal-overlay .content-left .caption {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.2rem;
}
.modal-overlay .content-left .caption span {
  color: #1432AA;
  background-color: #FFFFFF;
  font-size: 1.4rem;
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  padding: 0.2rem 0.8rem 0.3rem;
}
.modal-overlay .content-left img {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 1.1rem;
}
.modal-overlay .content-right .c-title {
  top: 0;
  padding-left: 0;
  margin-top: 4rem;
}
.modal-overlay .content-right .c-title-desc {
  font-size: 2.4rem;
  padding-right: 3rem;
}
.modal-overlay .content-right-desc {
  background-color: #FFFFFF;
  color: #1432AA;
  font-size: 1.6rem;
  width: 100%;
  padding: 0.8rem 1rem;
  line-height: normal;
}
.modal-overlay .close-btn {
  position: absolute;
  top: 0;
  right: 0;
  background: #1432AA;
  color: #fff;
  border: none;
  width: 5rem;
  height: 5rem;
  cursor: pointer;
}
.modal-overlay .close-btn .close-icon::before {
  content: "";
  position: absolute;
  width: 2.5rem;
  height: 0.1rem;
  background-color: #FFFFFF;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(135deg);
      -ms-transform: translate(-50%, -50%) rotate(135deg);
          transform: translate(-50%, -50%) rotate(135deg);
}
.modal-overlay .close-btn .close-icon::after {
  content: "";
  position: absolute;
  width: 2.5rem;
  height: 0.1rem;
  background-color: #FFFFFF;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
      -ms-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}

.l-history {
  margin-top: -5rem;
}
@media screen and (max-width: 767px) {
  .l-history {
    margin-top: 0;
  }
}
.l-history #section-history {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100vh;
  min-height: 800px;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .l-history #section-history {
    margin-bottom: 9rem;
    min-height: 0;
    height: auto;
  }
}
.l-history #section-history .l-content {
  max-width: 100%;
  z-index: 1;
  top: 18rem;
}
@media screen and (max-width: 767px) {
  .l-history #section-history .l-content {
    top: 12rem;
    left: 50%;
  }
}
.l-history #section-history .hero-content {
  left: 17.7rem;
}
@media screen and (max-width: 767px) {
  .l-history #section-history .hero-content {
    left: 2rem;
  }
}
.l-history #section-history .slider-kv {
  padding-top: 7.4rem;
}
@media screen and (max-width: 767px) {
  .l-history #section-history .slider-kv {
    padding-top: 9.2rem;
  }
}
.l-history .c-title {
  top: 0.1rem;
  padding-left: 5rem;
  z-index: 99;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  -webkit-transition: -webkit-transform 1s ease;
  transition: -webkit-transform 1s ease;
  transition: transform 1s ease;
  transition: transform 1s ease, -webkit-transform 1s ease;
  display: block;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.8s ease;
  transition: all 0.8s ease;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}
.l-history .c-title:not(:first-child) {
  position: absolute;
}
.l-history .c-title.show {
  visibility: visible;
  opacity: 1;
}
.l-history .c-title.move {
  -webkit-transform: translate(-110%, 0);
      -ms-transform: translate(-110%, 0);
          transform: translate(-110%, 0);
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .l-history .c-title {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
.l-history .c-title-period {
  font-size: 3.2rem;
  color: #1432AA;
  background-color: #FFFFFF;
  line-height: 1.3;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 0.5rem 0.8rem;
}
.l-history .c-title-year {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
.l-history .c-title-year .c-title-year--block {
  height: 5.1rem;
  background-color: #1432AA;
  padding: 0 0.8rem;
}
.l-history .c-title-year .c-title-sub--block {
  height: 2.4rem;
  background-color: #1432AA;
  padding: 0 0.4rem;
}
.l-history .c-title-year .year {
  color: #FFFFFF;
  font-size: 4.5rem;
  font-weight: 500;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1;
  font-weight: 400;
}
.is-windows .l-history .c-title-year .year {
  line-height: 0.9;
}
.is-mac .l-history .c-title-year .year {
  line-height: 1.1;
}
@media screen and (max-width: 767px) {
  .l-history .c-title-year .year {
    font-size: 4rem;
  }
}
.l-history .c-title-year .sub {
  font-size: 1.6rem;
  font-weight: 500;
  color: #FFFFFF;
  line-height: 1;
}
.is-windows .l-history .c-title-year .sub {
  line-height: 0.9;
}
.is-mac .l-history .c-title-year .sub {
  line-height: 1.6;
}
.l-history .c-title-desc {
  font-size: 1.6rem;
  color: #1432AA;
  background-color: #FFFFFF;
  font-weight: 500;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.3rem 0.8rem 0.6rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}
.l-history .l-history-wrapper-outer {
  position: relative;
  width: 100%;
  height: 200vh;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-wrapper-outer {
    height: auto;
  }
}
.l-history .l-history-year {
  width: 100%;
  height: 100vh;
  position: sticky;
  top: 0;
  left: 0;
  overflow: hidden;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year {
    height: auto;
    overflow: visible;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
}
.l-history .l-history-year .main-header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 99;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .main-header {
    position: sticky;
    top: 0;
  }
  .l-history .l-history-year .main-header .c-title {
    padding-left: 0;
  }
}
.l-history .l-history-year .timeline-container {
  margin: 11rem 36rem 0;
  position: relative;
  z-index: 99;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .timeline-container {
    position: sticky;
    bottom: 5rem;
    left: 0;
    width: 100%;
    background: #F8F8F8;
    padding: 4rem 1.5rem;
    margin: 0;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-top: auto;
  }
}
.l-history .l-history-year .timeline-container .track {
  height: 0.1rem;
  background: #1432AA;
  position: relative;
  cursor: pointer;
  max-width: 86.2rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .timeline-container .track {
    max-width: 85%;
    -ms-touch-action: pan-x;
        touch-action: pan-x;
    margin-left: 16px;
  }
}
.l-history .l-history-year .timeline-container .progress {
  position: absolute;
  height: 100%;
  background: #1432AA;
  width: 0%;
  pointer-events: none;
}
.l-history .l-history-year .timeline-container .handle {
  width: 1.4rem;
  height: 1.4rem;
  background: #1432AA;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: -webkit-transform 0.2s ease;
  transition: -webkit-transform 0.2s ease;
  transition: transform 0.2s ease;
  transition: transform 0.2s ease, -webkit-transform 0.2s ease;
  z-index: 5;
  cursor: -webkit-grab;
  cursor: grab;
}
.l-history .l-history-year .timeline-container .handle:hover {
  -webkit-transform: translate(-50%, -50%) scale(1.2);
      -ms-transform: translate(-50%, -50%) scale(1.2);
          transform: translate(-50%, -50%) scale(1.2);
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .timeline-container .handle {
    -ms-touch-action: none;
        touch-action: none;
    width: 0.8rem;
    height: 0.8rem;
  }
}
.l-history .l-history-year .timeline-container .milestone {
  position: absolute;
  top: 0;
}
.l-history .l-history-year .timeline-container .milestone::after {
  position: absolute;
  content: "";
  width: 0.1rem;
  height: 1rem;
  top: -0.4rem;
  background-color: #1432AA;
}
.l-history .l-history-year .timeline-container .milestone.milestone-1876 {
  left: 0%;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .timeline-container .milestone.milestone-1876 .txt {
    top: -2.2rem;
  }
}
.l-history .l-history-year .timeline-container .milestone.milestone-1951 {
  left: 40%;
}
.l-history .l-history-year .timeline-container .milestone.milestone-2015 {
  left: 85%;
}
.l-history .l-history-year .timeline-container .milestone.milestone-150th {
  width: 5.4rem;
  top: -1rem;
  left: 102%;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .timeline-container .milestone.milestone-150th {
    width: 3rem;
  }
}
.l-history .l-history-year .timeline-container .milestone.milestone-150th::after {
  display: none;
}
.l-history .l-history-year .timeline-container .milestone .txt {
  display: block;
  color: #808080;
  position: absolute;
  top: -3.5rem;
  left: 0;
  white-space: nowrap;
  cursor: pointer;
  font-size: 1.4rem;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .timeline-container .milestone .txt {
    font-size: 1rem;
    top: -2.8rem;
  }
}
.l-history .l-history-year .timeline-container .milestone .yr {
  display: block;
  position: absolute;
  top: 1.5rem;
  left: -1.3rem;
  font-size: 1.2rem;
  color: #1432AA;
}
.l-history .l-history-year .timeline-container .milestone.active .txt {
  color: #1432AA;
  font-weight: bold;
}
.l-history .l-history-year .history-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100vh;
  margin-top: 9.4rem;
  overflow: hidden;
  cursor: -webkit-grab;
  cursor: grab;
  -ms-touch-action: pan-y;
      touch-action: pan-y;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content {
    display: block;
    overflow: visible;
    margin: 0;
    padding: 0 2rem;
    height: auto;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .l-history .l-history-year .history-content .c-title.u-sp {
    padding-left: 0;
    margin-left: -2rem;
    margin-bottom: 5rem;
  }
  .l-history .l-history-year .history-content .c-title.u-sp .c-title-year .year {
    line-height: 1;
  }
  .is-windows .l-history .l-history-year .history-content .c-title.u-sp .c-title-year .year {
    line-height: 1;
  }
  .is-mac .l-history .l-history-year .history-content .c-title.u-sp .c-title-year .year {
    line-height: 1.3;
  }
  .is-windows .l-history .l-history-year .history-content .c-title.u-sp .c-title-year .sub {
    line-height: 0.9;
  }
  .is-mac .l-history .l-history-year .history-content .c-title.u-sp .c-title-year .sub {
    line-height: 1.6;
  }
}
.l-history .l-history-year .history-content.is-dragging {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
.l-history .l-history-year .history-content .item {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0 15.6rem;
  gap: 8rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item {
    display: block;
    width: 100%;
    padding: 5rem 0;
    padding-top: 0;
    min-height: 80vh;
  }
}
.l-history .l-history-year .history-content .item .inner {
  width: 85.9rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner {
    width: 100%;
    margin-bottom: 9.5rem;
  }
}
.l-history .l-history-year .history-content .item .inner--large {
  width: 100rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner--large {
    width: 100%;
  }
}
.l-history .l-history-year .history-content .item .inner:nth-child(odd) {
  -ms-flex-item-align: end;
      align-self: flex-end;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner:nth-child(odd) {
    -ms-flex-item-align: auto;
        align-self: auto;
    margin-bottom: 9.5rem;
  }
}
.l-history .l-history-year .history-content .item .inner:nth-child(odd) .content-left .image::after {
  background: -webkit-gradient(linear, left top, left bottom, from(#FF9AC8), to(#1432AA));
  background: linear-gradient(to bottom, #FF9AC8, #1432AA);
}
.l-history .l-history-year .history-content .item .inner .inner-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .inner-container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2rem;
  }
}
.l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block {
  height: 3.6rem;
}
.is-windows .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .year {
  line-height: 0.9;
}
.is-mac .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .year {
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block {
    height: 2.8rem;
  }
  .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .year {
    line-height: 1;
  }
  .is-windows .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .year {
    line-height: 1;
  }
  .is-mac .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .year {
    line-height: 1.4;
  }
  .is-windows .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .sub {
    line-height: 1.2;
  }
  .is-mac .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-year--block .sub {
    line-height: 1.6;
  }
}
.l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-sub--block {
  height: 2.6rem;
}
.is-windows .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-sub--block .sub {
  line-height: 1.2;
}
.is-mac .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-sub--block .sub {
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-sub--block {
    height: 2.2rem;
  }
}
.l-history .l-history-year .history-content .item .inner .inner-container .c-title-year .c-title-sub--block .sub {
  line-height: 1.2;
}
.l-history .l-history-year .history-content .item .inner .content-left {
  -webkit-box-flex: 1.5;
      -ms-flex: 1.5;
          flex: 1.5;
  max-width: 50rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .content-left {
    max-width: 100%;
  }
}
.l-history .l-history-year .history-content .item .inner .content-left .image {
  position: relative;
  isolation: isolate;
  pointer-events: none;
}
.l-history .l-history-year .history-content .item .inner .content-left .image img {
  width: 100%;
  height: auto;
  display: block;
}
.l-history .l-history-year .history-content .item .inner .content-left .caption {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.2rem;
}
.l-history .l-history-year .history-content .item .inner .content-left .caption span {
  color: #1432AA;
  background-color: #FFFFFF;
  font-size: 1.4rem;
  text-align: right;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  padding: 0.5rem 0.5rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .content-left .caption span {
    font-size: 1.2rem;
  }
}
.l-history .l-history-year .history-content .item .inner .content-right {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.l-history .l-history-year .history-content .item .inner .content-right-desc {
  background-color: #FFFFFF;
  color: #1432AA;
  font-size: 1.6rem;
  width: 100%;
  padding: 0.8rem 2.5rem 0.8rem 1rem;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .content-right-desc {
    padding: 1rem 1rem 3rem 1rem;
  }
}
.l-history .l-history-year .history-content .item .inner .c-title {
  margin-top: 4rem;
  margin-bottom: 1rem;
  padding-left: 0;
  opacity: 1;
  visibility: visible;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .c-title {
    margin: 0;
  }
}
.l-history .l-history-year .history-content .item .inner .c-title-desc {
  font-size: 3.2rem;
  color: #1432AA;
  font-weight: bold;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .c-title-desc {
    font-size: 2.4rem;
  }
}
.l-history .l-history-year .history-content .item .inner .c-title-year {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-bottom: 1.2rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .c-title-year {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-bottom: 0;
  }
}
.l-history .l-history-year .history-content .item .inner .c-title-year .year {
  font-size: 3rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .c-title-year .year {
    font-size: 2.2rem;
  }
}
.l-history .l-history-year .history-content .item .inner .c-title-year .sub {
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item .inner .c-title-year .sub {
    font-size: 1.4rem;
  }
}
.l-history .l-history-year .history-content .item.item-slogan {
  width: 100vw;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .item.item-slogan {
    width: 100%;
    height: auto;
    height: 80vh;
    min-height: 54rem;
    padding: 10rem 0;
    padding-top: 0;
  }
}
.l-history .l-history-year .history-content .l-history-slogan {
  position: relative;
}
.l-history .l-history-year .history-content .l-history-slogan .hero-body {
  font-size: clamp(32px, 2.4vw, 45px);
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .l-history-slogan .hero-body {
    font-size: 2.4rem;
  }
}
.l-history .l-history-year .history-content .l-history-slogan--bg {
  margin-top: -5rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .l-history-slogan--bg {
    margin-top: 0;
    min-height: auto;
  }
}
.l-history .l-history-year .history-content .l-history-slogan--bg .ball-wrapper {
  position: relative;
}
.l-history .l-history-year .history-content .l-history-slogan--bg .ball-wrapper .ball {
  width: 83.4rem;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .l-history-slogan--bg .ball-wrapper .ball {
    width: 100%;
  }
}
.l-history .l-history-year .history-content .l-history-slogan .group-text {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.l-history .l-history-year .history-content .l-history-slogan .group-text .hero-content {
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 90rem;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .l-history-slogan .group-text .hero-content {
    width: 100%;
  }
}
.l-history .l-history-year .history-content .l-history-slogan .back-btn {
  position: absolute;
  bottom: 5rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .l-history .l-history-year .history-content .l-history-slogan .back-btn {
    bottom: -13rem;
  }
}

body.modal-open {
  position: fixed;
  width: 100%;
  overflow: hidden;
}

@-webkit-keyframes scroll-auto2 {
  from {
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
  }
  to {
    -webkit-transform: translate(-120vw, -50%);
            transform: translate(-120vw, -50%);
  }
}

@keyframes scroll-auto2 {
  from {
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
  }
  to {
    -webkit-transform: translate(-120vw, -50%);
            transform: translate(-120vw, -50%);
  }
}
.bg-header {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 5rem;
  z-index: 100;
  background-image: linear-gradient(#DCE0F4 1px, transparent 1px), linear-gradient(90deg, #DCE0F4 1px, #F8F8F8 1px);
  background-size: 90px 90px;
}

.l-header-150th-wrapper {
  height: 9rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
}
.l-header-150th-wrapper.hide-tag::before {
  height: 100%;
  top: 0;
}
.l-header-150th-wrapper.hide-tag .header-tags-container {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.l-header-150th-wrapper .l-header-150th .header-content .header-content--text {
  -webkit-transition: 0.4s ease;
  transition: 0.4s ease;
}
.l-header-150th-wrapper .l-header-150th .header-content .header-menu {
  -webkit-transition: 0.4s ease;
  transition: 0.4s ease;
}
.l-header-150th-wrapper .l-header-150th.blue-line::before {
  opacity: 1;
  -webkit-transition: opacity 0s;
  transition: opacity 0s;
}
.l-header-150th-wrapper .l-header-150th.blue-line:after {
  opacity: 1;
  -webkit-transition: opacity 0s;
  transition: opacity 0s;
}
.l-header-150th-wrapper .l-header-150th.blue-line .header-content {
  opacity: 0;
  -webkit-transition: opacity 0.2s 0s ease-in-out;
  transition: opacity 0.2s 0s ease-in-out;
}
.l-header-150th-wrapper .l-header-150th::before {
  content: "";
  height: 100vh;
  width: 0.1rem;
  background: #fff;
  top: 9rem;
  left: 8.9rem;
  position: absolute;
  z-index: 999;
  opacity: 1;
  -webkit-transition: 0s ease-in-out;
  transition: 0s ease-in-out;
}
.l-header-150th-wrapper .l-header-150th::after {
  content: "";
  height: 100vh;
  width: 0.1rem;
  background: #fff;
  top: 0;
  right: 8.9rem;
  position: absolute;
  z-index: 999;
  opacity: 1;
  -webkit-transition: 0s ease-in-out;
  transition: 0s ease-in-out;
}
.l-header-150th-wrapper.is-small {
  position: sticky;
  top: 0;
  z-index: 1001;
  height: 5rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  background: transparent;
  -webkit-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  margin-bottom: 0.1rem;
}
.l-header-150th-wrapper.is-small .l-header-150th::before {
  background: #1432AA;
  top: 5rem;
  left: 4.9rem;
  -webkit-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 1;
}
.l-header-150th-wrapper.is-small .l-header-150th::after {
  background: #1432AA;
  right: 4.9rem;
  -webkit-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 1;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-line {
  display: none;
  width: 0.1rem;
  height: 100vh;
  background-color: #1432AA;
  position: fixed;
  top: 0;
  z-index: 999;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-line--left {
  left: 5rem;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-line--left {
  right: 5rem;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-inner {
  border-block: 0.1rem solid #1432AA;
  z-index: 9999;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-logo {
  width: 5rem;
  height: 5rem;
  border-right: 1px solid #1432AA;
  -webkit-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-logo video {
  width: 100%;
  height: 100%;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-tags-container {
  background: transparent;
  width: calc(100% - 23rem);
}
.l-header-150th-wrapper.is-small .l-header-150th .header-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 1;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0;
  padding-left: 0.9rem;
  gap: 0 1rem;
  border-left: 0.1rem solid #1432AA;
  -webkit-transition: opacity 0.4s 0.6s ease-in-out;
  transition: opacity 0.4s 0.6s ease-in-out;
  opacity: 1;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-content--logo {
  max-width: 4.1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: url(/150th/image/shared/logo_dnp_blue.webp) no-repeat;
  background-size: 100% auto;
  background-position: center;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-content--text {
  font-size: 1.5rem;
  line-height: 2rem;
  max-width: 17.7rem;
  display: block;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-menu {
  margin-left: 0.5rem;
  width: 5rem;
  height: 5rem;
  background: #1432AA;
  display: block;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-btn {
  width: 100%;
  height: 100%;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.6rem 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-btn--line {
  width: 2.5rem;
  height: 0.1rem;
  background: #fff;
  -webkit-transition: 0.15s;
  transition: 0.15s;
}
.l-header-150th-wrapper.is-small .l-header-150th .header-btn:hover .header-btn--line:first-child {
  -webkit-transition: 0.15s;
  transition: 0.15s;
  -webkit-transform: translateY(0.4rem);
      -ms-transform: translateY(0.4rem);
          transform: translateY(0.4rem);
}
.l-header-150th-wrapper.is-small .l-header-150th .header-btn:hover .header-btn--line:last-child {
  -webkit-transition: 0.15s;
  transition: 0.15s;
  -webkit-transform: translateY(-0.3rem);
      -ms-transform: translateY(-0.3rem);
          transform: translateY(-0.3rem);
}

.global-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 18.2rem;
  overflow: hidden;
  background-color: lightgray;
  color: #fff;
  font-size: 3rem;
  font-weight: 600;
}

.header-inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  background: transparent;
  border-block: 0.1rem solid #fff;
}
.header-submenu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  -webkit-transition: opacity 0.25s ease-out, visibility 0s linear 0.25s;
  transition: opacity 0.25s ease-out, visibility 0s linear 0.25s;
}
.header-submenu.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  -webkit-transition: opacity 0.25s ease-out;
  transition: opacity 0.25s ease-out;
}
.header-submenu.is-open.is-hover .text-animation,
.header-submenu.is-open.is-hover .submenu-link--big::after,
.header-submenu.is-open.is-hover .submenu-link--sub::after {
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.header-line {
  display: none;
}
.header-logo {
  width: 9rem;
  height: 9rem;
  position: relative;
  z-index: 9;
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
}
.header-logo video {
  width: 100%;
  height: 100%;
}
.header-tags-container {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  overflow: hidden;
  width: calc(100% - 9rem);
  display: none;
}
.header-tags {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  left: calc(100vw - 20rem);
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
  position: absolute;
  z-index: 0;
  top: 50%;
  -webkit-animation: scroll-auto2 20s infinite linear;
          animation: scroll-auto2 20s infinite linear;
  white-space: nowrap;
}
.header-tags:hover {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}
.header-tags:hover .header-tags--tag {
  background-color: #fff;
  color: #1432AA;
}
.header-tags:hover .header-tags--tag.active {
  background-color: #1432AA;
  color: #fff;
}
.header-tags--tag {
  font-size: 1.4rem;
  padding: 0 1rem;
  height: 2rem;
  border-radius: 999.9rem;
  position: relative;
  z-index: 2;
  color: #fff;
  background-color: #1432AA;
  line-height: 1.8rem;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border: 1px solid #fff;
}
.header-tags--tag:hover {
  background-color: #fff;
  border-color: #fff;
  color: #1432AA;
}
.header-tags--tag.active {
  background-color: #fff;
  color: #1432AA;
}
.header-tags--tag + .header-tags--tag {
  margin-left: -0.5rem;
  z-index: 0;
  position: relative;
}
.header-tags--tag:nth-child(even) {
  z-index: 1;
  position: relative;
}
.header-tags--tag:last-child {
  font-size: 1.3rem;
}
.is-windows .header-tags--tag:last-child {
  line-height: 1.3rem;
  padding: 0.1rem 1rem 0.4rem;
}
.header-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 1;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1.7rem 1.7rem 1.4rem;
  gap: 0 2.1rem;
  border-left: 0.1rem solid #fff;
}
.header-content--logo {
  width: 55px;
  height: 16px;
  background: url(/150th/image/shared/logo_dnp.webp) no-repeat;
  background-size: 100% auto;
  background-position: center;
}
.header-content--text {
  font-size: 2.1rem;
  line-height: 2.4rem;
  color: #1432AA;
  max-width: 14.7rem;
  display: none;
}
.header-menu {
  display: none;
}

.header-submenu::after {
  width: 5rem;
  height: 5rem;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  content: "";
  top: 0;
  left: 0;
  position: absolute;
  background: url(/150th/image/shared/logo_150th.webp) no-repeat;
  background-size: 100% 100%;
  z-index: 19;
  opacity: 0;
}

.header-submenu.is-open:not(.is-closing) .submenu-head--close .close-line:last-child {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
      -ms-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
.header-submenu.is-open:not(.is-closing) .submenu-head--close .close-line:first-child {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
      -ms-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
.header-submenu.is-open:not(.is-closing) .submenu-head--close:hover .close-line:last-child {
  -webkit-transform: translate(-50%, -50%) rotate(-25deg);
      -ms-transform: translate(-50%, -50%) rotate(-25deg);
          transform: translate(-50%, -50%) rotate(-25deg);
}
.header-submenu.is-open:not(.is-closing) .submenu-head--close:hover .close-line:first-child {
  -webkit-transform: translate(-50%, -50%) rotate(25deg);
      -ms-transform: translate(-50%, -50%) rotate(25deg);
          transform: translate(-50%, -50%) rotate(25deg);
}

.submenu-sidebar {
  max-width: 21.5rem;
  padding: 3.5rem 3rem 3.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  background: transparent;
  opacity: 0;
  z-index: 9;
}
.submenu-sidebar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background: #fff;
  z-index: -1;
}
.submenu-sidebar--logo150th {
  width: 16rem;
  height: 16rem;
}
.submenu-sidebar--logo150th video {
  opacity: 0;
  width: 100%;
  height: 100%;
}
.submenu-sidebar--logodnp, .submenu-sidebar--content {
  opacity: 0;
  -webkit-transform: translateX(-30%);
      -ms-transform: translateX(-30%);
          transform: translateX(-30%);
}
.submenu-sidebar--text {
  color: #1432AA;
}
.submenu-sidebar--sns {
  margin-top: 2.1rem;
}
.submenu-sidebar--link {
  font-size: 1.4rem;
  text-decoration: none;
  color: #1432AA;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
  padding-top: 5px;
}
.submenu-sidebar--link .icn {
  background: url(/150th/image/shared/link_icon_blank_blue.svg) no-repeat;
  background-size: 1rem auto;
  background-position: center right;
  width: 1rem;
  height: 1rem;
  margin-top: 0.2rem;
}
.submenu-sidebar--snslist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 2rem;
  padding-top: 1rem;
}
.submenu-main {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
}
.submenu-main::before {
  position: absolute;
  content: "";
  right: 5rem;
  top: 0;
  width: 0;
  height: 100%;
  background: #1432AA;
  opacity: 0;
  z-index: 8;
}
.submenu-main::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 5rem;
  height: 100%;
  background: #1432AA;
  z-index: 8;
  opacity: 0;
}
.submenu-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: relative;
  z-index: 9;
  border-bottom: 1px solid #fff;
}
.submenu-head--content {
  border-left: 0.1rem solid #fff;
  color: #fff;
  font-size: 1.5rem;
  padding: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
}
.submenu-head--logodnp {
  max-width: 4.1rem;
}
.submenu-head--close {
  width: 5rem;
  height: 5rem;
  background: #fff;
  position: relative;
  cursor: pointer;
}
.submenu-head--close .close-line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2.5rem;
  height: 0.1rem;
  background: #1432AA;
  display: block;
  -webkit-transform-origin: center;
      -ms-transform-origin: center;
          transform-origin: center;
  -webkit-transition: -webkit-transform 0.2s ease-out;
  transition: -webkit-transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out, -webkit-transform 0.2s ease-out;
}
.submenu-head--close .close-line:last-child {
  -webkit-transform: translate(-50%, calc(-50% + 0.4rem)) rotate(0deg);
      -ms-transform: translate(-50%, calc(-50% + 0.4rem)) rotate(0deg);
          transform: translate(-50%, calc(-50% + 0.4rem)) rotate(0deg);
}
.submenu-head--close .close-line:first-child {
  -webkit-transform: translate(-50%, calc(-50% - 0.4rem)) rotate(0deg);
      -ms-transform: translate(-50%, calc(-50% - 0.4rem)) rotate(0deg);
          transform: translate(-50%, calc(-50% - 0.4rem)) rotate(0deg);
}
.submenu-content {
  margin-right: 4.9rem;
  height: calc(100% - 4.6rem);
  padding: 3.5rem 6rem 3.5rem 3.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 10;
  overflow: hidden;
  border-right: 1px solid #fff;
}
.submenu-content--inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
}
.submenu-content--inner .submenu-content--logo150th {
  position: relative;
}
.submenu-content--inner .submenu-content--logo150th .text {
  position: absolute;
  padding-left: 2rem;
  pointer-events: none;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  white-space: nowrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 2.1rem;
  color: #fff;
}
.submenu-content::before {
  content: "";
  position: absolute;
  background: url(/150th/image/shared/bg_menu.webp) no-repeat;
  background-position: center;
  background-size: cover;
  -webkit-transform-origin: top left;
      -ms-transform-origin: top left;
          transform-origin: top left;
  z-index: 0;
  width: 155.2rem;
  opacity: 0;
  height: 124.1rem;
  right: 6rem;
  top: -25rem;
}
.submenu-content > * {
  position: relative;
  z-index: 1;
}
.submenu-content--logo150th {
  padding-left: 2rem;
  opacity: 0;
  -webkit-transform: translateY(50%);
      -ms-transform: translateY(50%);
          transform: translateY(50%);
}
.submenu-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem 6.8rem;
}
.submenu-item {
  text-align: right;
  position: relative;
  overflow: hidden;
  color: #1432AA;
}
.submenu-item .text-animation {
  display: block;
  -webkit-transform: translateY(50%);
      -ms-transform: translateY(50%);
          transform: translateY(50%);
  opacity: 0;
  position: relative;
  z-index: 9;
}
.submenu-link {
  font-size: 3rem;
  text-decoration: none;
  font-family: "Instrument Serif", serif;
  color: #1432AA;
  z-index: 1;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
}
.submenu-link--big {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
  margin-left: auto;
  margin-right: 0;
  padding: 0.2rem 0.5rem;
  position: relative;
}
.submenu-link--big::after {
  content: "";
  width: 0;
  height: 100%;
  position: absolute;
  background-color: #fff;
  top: 0;
  left: 0;
}
.submenu-link--sub {
  display: block;
  padding: 0.2rem 0.5rem 0.5rem 1.5rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-right: 0;
  margin-left: auto;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  font-size: 1.4rem;
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
  position: relative;
  z-index: 1;
}
.submenu-link--sub::after {
  content: "";
  width: 0;
  height: 100%;
  position: absolute;
  background-color: #fff;
  top: 0;
  left: 0;
}
.submenu-footer {
  position: absolute;
  bottom: 3.5rem;
  left: 3.5rem;
}
.submenu-footer--links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 3rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.submenu-footer--link {
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.8rem;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
}
.submenu-footer--link .icn {
  background: url(/150th/image/shared/link_icon_blank.svg) no-repeat;
  background-size: 1rem auto;
  background-position: center right;
  width: 1rem;
  height: 1rem;
  margin-top: 0.3rem;
  display: block;
}

.icn {
  font-size: 0;
}

.sns-item a {
  font-size: 0;
  display: block;
  height: 2rem;
}
.sns-item.facebook a {
  width: 2rem;
  background: url(/150th/image/shared/btn_fb.webp) no-repeat center/2rem auto;
}
.sns-item.linkedin a {
  width: 2.4rem;
  background: url(/150th/image/shared/btn_linkedin.webp) no-repeat center/2.4rem auto;
}
.sns-item.youtube a {
  width: 2.9rem;
  background: url(/150th/image/shared/btn_youtube.webp) no-repeat center/2.4rem auto;
}
.copyright {
  color: #fff;
  font-size: 1.2rem;
  padding-top: 1rem;
}

@media screen and (max-width: 767px) {
  .global-header {
    height: 10.8rem;
  }
  @-webkit-keyframes scroll-auto2 {
    from {
      -webkit-transform: translate(0, -50%);
              transform: translate(0, -50%);
    }
    to {
      -webkit-transform: translate(-200vw, -50%);
              transform: translate(-200vw, -50%);
    }
  }
  @keyframes scroll-auto2 {
    from {
      -webkit-transform: translate(0, -50%);
              transform: translate(0, -50%);
    }
    to {
      -webkit-transform: translate(-200vw, -50%);
              transform: translate(-200vw, -50%);
    }
  }
  .l-header-150th-wrapper {
    position: relative;
  }
  .l-header-150th-wrapper::before {
    content: "";
    position: absolute;
    display: block;
    z-index: 100;
    left: 0;
    top: -50px;
    width: 100%;
    height: calc(100% + 50px);
    background-image: linear-gradient(#DCE0F4 1px, transparent 1px), linear-gradient(90deg, #DCE0F4 1px, #F8F8F8 1px);
    background-size: 90px 90px;
  }
  .l-header-150th-wrapper {
    width: 100%;
    z-index: 1000;
  }
  .l-header-150th-wrapper.hide-tag .header-menu::before {
    position: absolute;
    z-index: -2;
    content: "";
    width: 100vw;
    height: 100%;
    right: 0;
    top: 0;
    pointer-events: none;
    background-color: #F8F8F8;
  }
  .l-header-150th-wrapper.hide-tag .header-menu::after {
    position: absolute;
    z-index: -1;
    content: "";
    width: 100vw;
    height: 100%;
    right: 0;
    top: 0;
    pointer-events: none;
    background-image: linear-gradient(#DCE0F4 1px, transparent 1px), linear-gradient(90deg, #DCE0F4 1px, #F8F8F8 1px);
    background-size: 90px 90px;
  }
  .l-header-150th-wrapper.is-small {
    position: fixed;
    bottom: -1px;
    top: auto;
    z-index: 1005;
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-content {
    border: none;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 0;
    padding-right: 5rem;
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-content .header-menu {
    position: absolute;
    right: 0;
    bottom: 0;
    margin-left: 0;
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-tags-container {
    width: 100%;
    border-top: 1px solid #1432AA;
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-inner {
    border-top: 1px solid #1432AA;
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-logo video {
    width: 50px;
    border-right: 1px solid #1432AA;
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-btn:hover .header-btn--line:first-child {
    -webkit-transition: 0.15s;
    transition: 0.15s;
    -webkit-transform: translateY(0rem);
        -ms-transform: translateY(0rem);
            transform: translateY(0rem);
  }
  .l-header-150th-wrapper.is-small .l-header-150th .header-btn:hover .header-btn--line:last-child {
    -webkit-transition: 0.15s;
    transition: 0.15s;
    -webkit-transform: translateY(0rem);
        -ms-transform: translateY(0rem);
            transform: translateY(0rem);
  }
  .l-header-150th-wrapper {
    height: 5rem;
  }
  .l-header-150th-wrapper .header-inner {
    z-index: 105;
  }
  .l-header-150th-wrapper.is-small .header-inner,
  .l-header-150th-wrapper.is-small .header-tags-container {
    -webkit-transition: 0.3s ease-out;
    transition: 0.3s ease-out;
  }
  .l-header-150th-wrapper.is-small.is-top .l-header-150th .header-content--logo {
    background: url(/150th/image/shared/logo_dnp.webp) no-repeat;
    background-size: 100% auto;
    background-position: center;
  }
  .l-header-150th-wrapper.is-small.is-top .header-content--text {
    color: #fff;
  }
  .l-header-150th-wrapper.is-small.is-top .l-header-150th .header-tags-container, .l-header-150th-wrapper.is-small.is-top .header-logo, .l-header-150th-wrapper.is-small.is-top .header-inner, .l-header-150th-wrapper.is-small.is-top .header-tags--tag {
    border-color: #fff;
  }
  .l-header-150th-wrapper.is-small.is-top .l-header-150th .header-menu .header-btn {
    border-left: 1px solid #fff;
  }
  .l-header-150th-wrapper.is-small.is-top .header-inner,
  .l-header-150th-wrapper.is-small.is-top .header-tags-container {
    background: #1432AA;
    -webkit-transition: 0.3s ease-out;
    transition: 0.3s ease-out;
  }
  .l-header-150th-wrapper.is-small.is-top .header-tags--tag {
    border: 1px solid;
  }
  .header-submenu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .header-submenu::after {
    width: 5rem;
    height: 5rem;
    -webkit-transform: translate(0, -100%);
        -ms-transform: translate(0, -100%);
            transform: translate(0, -100%);
    content: "";
    top: 100%;
    left: 0;
    position: absolute;
    background: url(/150th/image/shared/logo_150th.webp) no-repeat;
    background-size: 100% 100%;
    z-index: 19;
  }
  .header-submenu.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    -webkit-transition: opacity 0.25s ease-out;
    transition: opacity 0.25s ease-out;
  }
  .header-submenu.is-open .submenu-sidebar--logo150th img {
    width: 80px;
    height: 80px;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
    -webkit-transition: 0.3s ease-out 0.5s;
    transition: 0.3s ease-out 0.5s;
    opacity: 1;
  }
  .header-submenu.is-open.is-hover .text-animation,
  .header-submenu.is-open.is-hover .submenu-link--big::after,
  .header-submenu.is-open.is-hover .submenu-link--sub::after {
    -webkit-transition-delay: 0s;
            transition-delay: 0s;
  }
  .submenu-sidebar {
    content: none;
    position: absolute;
    width: 100%;
    height: 80px;
    bottom: 50px;
    left: 0;
    max-width: 100%;
    padding: 0;
    gap: 0 3.941vh;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .submenu-sidebar--logo150th {
    width: 80px;
    height: 80px;
  }
  .submenu-sidebar--logo150th img {
    -webkit-transform: translate(0px, 81px);
        -ms-transform: translate(0px, 81px);
            transform: translate(0px, 81px);
    width: 50px;
    height: 50px;
    -webkit-transition: 0.3s ease-out;
    transition: 0.3s ease-out;
  }
  .submenu-sidebar--logodnp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 80px;
  }
  .submenu-sidebar--content {
    padding-top: 1.601vh;
  }
  .submenu-sidebar--text-small {
    font-size: 10px;
  }
  .submenu-sidebar--sns {
    margin-top: 13px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0 12px;
  }
  .submenu-sidebar--link {
    font-size: 13px;
  }
  .submenu-sidebar--snslist {
    gap: 0 10px;
    padding-top: 0;
  }
  .submenu-main {
    height: 100vh;
  }
  .submenu-main::before {
    content: none;
  }
  .submenu-main::after {
    width: 100%;
    bottom: 0;
    left: 0;
    right: 0;
    height: 100%;
    -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
            transform: translateY(100%);
    -webkit-transition: 0.2s ease-out;
    transition: 0.2s ease-out;
    opacity: 1;
  }
  .submenu-head {
    padding-left: 50px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: 50px;
    border-bottom: none;
    border-top: 1px solid #1432AA;
  }
  .submenu-head--content {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding: 1rem 1.5rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .submenu-head--logodnp {
    max-width: 41px;
  }
  .submenu-head--text {
    font-size: 15px;
  }
  .submenu-content {
    height: calc(100% - 130px);
    margin-right: 0;
    padding: 3.818vh 25px 3.818vh;
    display: block;
    border-right: none;
  }
  .submenu-content--inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    height: 100%;
    padding-bottom: 100px;
  }
  .submenu-content--inner .submenu-content--logo150th .text {
    padding-left: 0;
    font-size: 1.6rem;
  }
  .submenu-content--logo150th {
    padding-left: 0;
    text-align: center;
    width: 44.267vw;
  }
  .submenu-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2.96vh 0;
  }
  .submenu-list .submenu-item {
    text-align: left;
  }
  .submenu-link {
    margin-left: 0;
  }
  .submenu-link--big {
    font-size: 30px;
    margin-left: 0;
    text-align: left;
  }
  .submenu-link--sub {
    margin-left: 0;
    text-align: left;
    font-size: 12px;
    padding: 0.2rem 0.5rem 0.5rem 0.3rem;
  }
  .submenu-footer {
    left: 6.333vw;
    bottom: 4.333vw;
  }
  .header-tags-container {
    top: calc(-100% - 1px);
    width: 100%;
  }
  .header-tags-container .header-tags {
    left: 100vw;
  }
  .l-body.nolnav + .l-foot .wrap-page-top .page-top.pageTopFixed {
    bottom: 6rem;
  }
  .header-tags--tag {
    border: 1px solid #1432AA;
  }
  .copyright {
    padding-top: 12px;
  }
  .sns-item a {
    font-size: 0;
    display: block;
    height: 1.5rem;
  }
  .sns-item.facebook a {
    width: 1.4rem;
    background: url(/150th/image/shared/btn_fb.webp) no-repeat center/1.4rem auto;
  }
  .sns-item.linkedin a {
    width: 1.7rem;
    background: url(/150th/image/shared/btn_linkedin.webp) no-repeat center/1.7rem auto;
  }
  .sns-item.youtube a {
    width: 2.1rem;
    background: url(/150th/image/shared/btn_youtube.webp) no-repeat center/2.1rem auto;
  }
}
@media (max-width: 375px) and (min-aspect-ratio: 375/700) {
  .submenu-main {
    height: 100svh;
  }
  .submenu-main .submenu-content {
    height: calc(100svh - 130px);
    overflow-y: scroll;
  }
  .submenu-main .submenu-content .submenu-content--inner {
    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: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding-bottom: 0;
    height: auto;
    margin-bottom: 5rem;
  }
  .submenu-main .submenu-content .submenu-content--inner .submenu-content--logo150th {
    margin-bottom: 5rem;
  }
  .submenu-main .submenu-content .submenu-footer {
    position: relative;
    left: 0;
    bottom: 0;
    margin-right: -2.5rem;
    margin-bottom: 4rem;
  }
  .submenu-main .submenu-content .submenu-footer .submenu-footer--links {
    gap: 0 2rem;
  }
}
@media screen and (max-width: 320px) {
  .section-group .l-heading .section-heading-big {
    font-size: 40px;
  }
  .section-group .l-heading .section-heading.is-top:after {
    top: 4.4rem;
  }
  #section-kv .info .hero-body {
    font-size: 12px;
  }
  #section-kv .kv-hero__title {
    font-size: 16px;
  }
  .submenu-sidebar {
    gap: 0 13px;
  }
  .submenu-sidebar--content {
    padding-top: 9px;
  }
  .submenu-content {
    padding: 20px 32px 20px;
  }
  .submenu-sidebar--link {
    font-size: 11px;
  }
  .submenu-list {
    gap: 10px 50px;
  }
  .submenu-link--big {
    font-size: 18px;
  }
  .submenu-link--sub {
    font-size: 10px;
  }
  .submenu-footer {
    left: 24px;
    bottom: 24px;
  }
  .submenu-footer--link {
    font-size: 12px;
  }
  .copyright {
    padding-top: 7px;
    font-size: 10px;
  }
}
.l-footer-150th-wrapper {
  position: relative;
  min-height: 38vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 0;
  background-color: #1432AA;
}
@media screen and (max-width: 767px) {
  .l-footer-150th-wrapper {
    min-height: 50vh;
  }
}
.l-footer-150th-wrapper .bt-to-top {
  position: fixed;
  z-index: 100;
  bottom: 0;
  right: 0;
  width: 5rem;
  height: 5rem;
  cursor: pointer;
  -webkit-transition: 0.3s 1s ease;
  transition: 0.3s 1s ease;
  background: url("../image/shared/btn_to_top.webp") no-repeat;
  background-size: 100% 100%;
}
.l-footer-150th-wrapper .bt-to-top:hover {
  opacity: 0.8;
}

.l-footer-150th {
  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-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  z-index: 1;
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .l-footer-150th {
    padding-bottom: 100px;
    justify-items: flex-start;
    padding-top: 90px;
  }
}
.l-footer-150th--logo {
  margin-bottom: 2.6rem;
}
@media screen and (max-width: 767px) {
  .l-footer-150th--logo {
    margin-bottom: 4.8rem;
  }
}
.l-footer-150th--nav-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 3rem;
  margin-bottom: 2.6rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .l-footer-150th--nav-link {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2.1rem;
  }
}
.l-footer-150th--nav-link .txt-link {
  font-weight: 400;
  font-size: 1.4rem;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.l-footer-150th--nav-link .txt-link:hover {
  opacity: 0.8;
}
.l-footer-150th--nav-link .txt-link:after {
  content: "";
  position: relative;
  display: inline-block;
  margin-left: 0.5rem;
  width: 1rem;
  height: 1rem;
  background: url("../image/shared/icon_blank.webp") no-repeat;
  background-size: 100% 100%;
}
.l-footer-150th--copyright {
  font-size: 1.2rem;
  color: #FFFFFF;
  font-family: "Hiragino Sans", Meiryo, sans-serif;
}
@media screen and (max-width: 767px) {
  .l-footer-150th--copyright {
    line-height: 1.4;
    text-align: center;
    margin-top: 30px;
  }
}

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

@keyframes opacity-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes opacity-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes opacity-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.header-submenu.is-open .submenu-main::after {
  opacity: 1;
  -webkit-transition: 0.3s ease-in 0.45s;
  transition: 0.3s ease-in 0.45s;
}
.header-submenu.is-open .submenu-main::before {
  width: calc(100% - 5rem);
  -webkit-transition: 0.5s ease-in;
  transition: 0.5s ease-in;
  opacity: 1;
}
.header-submenu.is-open::after {
  opacity: 1;
  width: 14.8rem;
  height: 14.8rem;
  -webkit-transform: translate(3.5rem, 4.1rem);
      -ms-transform: translate(3.5rem, 4.1rem);
          transform: translate(3.5rem, 4.1rem);
  -webkit-transition: 0.4s ease-in 0.2s;
  transition: 0.4s ease-in 0.2s;
  -webkit-animation: opacity-out 0.2s ease 0.6s forwards;
          animation: opacity-out 0.2s ease 0.6s forwards;
}
.header-submenu.is-open .submenu-sidebar--logo150th video {
  -webkit-animation: opacity-in 0.2s ease 0.55s forwards;
          animation: opacity-in 0.2s ease 0.55s forwards;
}
.header-submenu.is-open .submenu-content::before {
  opacity: 1;
  right: 6rem;
  top: -25rem;
  -webkit-transition: 0.5s ease-in 0.45s;
  transition: 0.5s ease-in 0.45s;
}
.header-submenu.is-open .submenu-sidebar {
  opacity: 1;
  -webkit-transition: 0.5s ease-in;
  transition: 0.5s ease-in;
}
.header-submenu.is-open .submenu-sidebar::after {
  width: 100%;
  -webkit-transition: 0.5s ease-in;
  transition: 0.5s ease-in;
}
.header-submenu.is-open .submenu-sidebar--logodnp,
.header-submenu.is-open .submenu-sidebar--content {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
  opacity: 1;
  -webkit-transition: 0.3s ease-in 0.3s;
  transition: 0.3s ease-in 0.3s;
}
.header-submenu.is-open .submenu-content--logo150th {
  -webkit-animation: submenu-rise-in 0.3s ease-in 0.7s forwards;
          animation: submenu-rise-in 0.3s ease-in 0.7s forwards;
}
.header-submenu.is-open .submenu-link--big::after,
.header-submenu.is-open .submenu-link--sub::after {
  width: 100%;
  -webkit-transition: 0.3s ease-in 0.7s;
  transition: 0.3s ease-in 0.7s;
}
.header-submenu.is-open .text-animation {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: 0.3s ease-in 0.8s;
  transition: 0.3s ease-in 0.8s;
}
.header-submenu.is-open .submenu-link:hover {
  color: #fff;
}
.header-submenu.is-open .submenu-link:hover .submenu-link--big::after,
.header-submenu.is-open .submenu-link:hover .submenu-link--sub::after {
  background-color: #1432AA;
}

.header-submenu.is-closing {
  opacity: 1;
  visibility: visible;
  pointer-events: none;
}
.header-submenu.is-closing .submenu-main::after {
  opacity: 0;
  -webkit-transition: 0.5s ease-out 0.65s;
  transition: 0.5s ease-out 0.65s;
}
.header-submenu.is-closing .submenu-main::before {
  width: 0;
  -webkit-transition: 0.5s ease-out 0.75s;
  transition: 0.5s ease-out 0.75s;
  opacity: 0;
}
.header-submenu.is-closing::after {
  -webkit-animation: none;
          animation: none;
  opacity: 1;
  width: 5rem;
  height: 5rem;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  -webkit-transition: 0.4s ease-out 0.5s;
  transition: 0.4s ease-out 0.5s;
}
.header-submenu.is-closing .submenu-sidebar--logo150th video {
  opacity: 0;
  -webkit-animation: none;
          animation: none;
}
.header-submenu.is-closing .submenu-content::before {
  z-index: 9;
  opacity: 0;
  right: 30%;
  top: -30rem;
  -webkit-transition: 0.5s ease-in-out 0.45s;
  transition: 0.5s ease-in-out 0.45s;
}
.header-submenu.is-closing .submenu-sidebar {
  opacity: 0;
  z-index: 0;
  -webkit-transition: 0.5s ease-out 0.75s;
  transition: 0.5s ease-out 0.75s;
}
.header-submenu.is-closing .submenu-sidebar::after {
  width: 0;
  -webkit-transition: 0.5s ease-out 0.75s;
  transition: 0.5s ease-out 0.75s;
}
.header-submenu.is-closing .submenu-sidebar--logodnp,
.header-submenu.is-closing .submenu-sidebar--content {
  -webkit-transform: translateX(-30%);
      -ms-transform: translateX(-30%);
          transform: translateX(-30%);
  opacity: 0;
  -webkit-transition: 0.3s ease-out 0.75s;
  transition: 0.3s ease-out 0.75s;
}
.header-submenu.is-closing .submenu-content--logo150th {
  opacity: 0;
  -webkit-transform: translateY(50%);
      -ms-transform: translateY(50%);
          transform: translateY(50%);
  -webkit-animation: submenu-rise-out 0.3s ease-in forwards;
          animation: submenu-rise-out 0.3s ease-in forwards;
}
.header-submenu.is-closing .submenu-link--big::after,
.header-submenu.is-closing .submenu-link--sub::after {
  width: 0;
  -webkit-transition: 0.3s ease-in 0.2s;
  transition: 0.3s ease-in 0.2s;
}
.header-submenu.is-closing .text-animation {
  opacity: 0;
  -webkit-transform: translateY(50%);
      -ms-transform: translateY(50%);
          transform: translateY(50%);
  -webkit-transition: 0.3s ease-in;
  transition: 0.3s ease-in;
}

@media screen and (max-width: 767px) {
  .header-submenu.is-open .submenu-main::after {
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: 0.3s ease-in;
    transition: 0.3s ease-in;
  }
  .header-submenu.is-open .submenu-main::before {
    width: calc(100% - 5rem);
    -webkit-transition: 0.5s ease-in;
    transition: 0.5s ease-in;
    opacity: 1;
  }
  .header-submenu.is-open::after {
    -webkit-animation: none;
            animation: none;
    opacity: 1;
    width: 73px;
    height: 73px;
    -webkit-transform: translate(4px, -126px);
        -ms-transform: translate(4px, -126px);
            transform: translate(4px, -126px);
    -webkit-transition: 0.4s ease-in 0.2s;
    transition: 0.4s ease-in 0.2s;
  }
  .header-submenu.is-open .submenu-sidebar--logo150th video {
    opacity: 0;
    -webkit-animation: none;
            animation: none;
  }
  .header-submenu.is-open .submenu-content::before {
    opacity: 1;
    right: -10rem;
    top: 0rem;
    width: 100%;
    height: 100%;
    -webkit-transition: 0.5s ease-in 0.25s;
    transition: 0.5s ease-in 0.25s;
  }
  .header-submenu.is-open .submenu-sidebar {
    opacity: 1;
    -webkit-transition: 0.5s ease-in;
    transition: 0.5s ease-in;
  }
  .header-submenu.is-open .submenu-sidebar::after {
    width: 100%;
    -webkit-transition: 0.5s ease-in;
    transition: 0.5s ease-in;
  }
  .header-submenu.is-open .submenu-sidebar--logodnp,
  .header-submenu.is-open .submenu-sidebar--content {
    -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
    -webkit-transition: 0.3s ease-in 0.3s;
    transition: 0.3s ease-in 0.3s;
  }
  .header-submenu.is-open .submenu-content--logo150th {
    -webkit-animation: submenu-rise-in 0.3s ease-in 0.7s forwards;
            animation: submenu-rise-in 0.3s ease-in 0.7s forwards;
  }
  .header-submenu.is-open .submenu-link--big::after,
  .header-submenu.is-open .submenu-link--sub::after {
    width: 100%;
    -webkit-transition: 0.3s ease-in 0.7s;
    transition: 0.3s ease-in 0.7s;
  }
  .header-submenu.is-open .text-animation {
    opacity: 1;
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: 0.3s ease-in 0.8s;
    transition: 0.3s ease-in 0.8s;
  }
  .header-submenu.is-open .submenu-link:hover {
    color: #fff;
  }
  .header-submenu.is-open .submenu-link:hover .submenu-link--big::after,
  .header-submenu.is-open .submenu-link:hover .submenu-link--sub::after {
    background-color: #1432AA;
  }
  .header-submenu.is-closing {
    opacity: 1;
    visibility: visible;
    pointer-events: none;
  }
  .header-submenu.is-closing .submenu-main::after {
    opacity: 0;
    -webkit-transition: 0.5s ease-out 0.65s;
    transition: 0.5s ease-out 0.65s;
  }
  .header-submenu.is-closing .submenu-main::before {
    width: 0;
    -webkit-transition: 0.5s ease-out 0.75s;
    transition: 0.5s ease-out 0.75s;
    opacity: 0;
  }
  .header-submenu.is-closing::after {
    opacity: 0;
    width: 5rem;
    height: 5rem;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
    -webkit-transition: 0.4s ease-out 0.5s;
    transition: 0.4s ease-out 0.5s;
  }
  .header-submenu.is-closing .submenu-content::before {
    z-index: 9;
    opacity: 0;
    right: 30%;
    top: -30rem;
    -webkit-transition: 0.5s ease-in-out 0.45s;
    transition: 0.5s ease-in-out 0.45s;
  }
  .header-submenu.is-closing .submenu-sidebar {
    opacity: 0;
    z-index: 0;
    -webkit-transition: 0.5s ease-out 0.75s;
    transition: 0.5s ease-out 0.75s;
  }
  .header-submenu.is-closing .submenu-sidebar::after {
    width: 0;
    -webkit-transition: 0.5s ease-out 0.75s;
    transition: 0.5s ease-out 0.75s;
  }
  .header-submenu.is-closing .submenu-sidebar--logodnp,
  .header-submenu.is-closing .submenu-sidebar--content {
    -webkit-transform: translateX(-30%);
        -ms-transform: translateX(-30%);
            transform: translateX(-30%);
    opacity: 0;
    -webkit-transition: 0.3s ease-out 0.75s;
    transition: 0.3s ease-out 0.75s;
  }
  .header-submenu.is-closing .submenu-content--logo150th {
    opacity: 0;
    -webkit-transform: translateY(50%);
        -ms-transform: translateY(50%);
            transform: translateY(50%);
    -webkit-animation: submenu-rise-out 0.3s ease-in forwards;
            animation: submenu-rise-out 0.3s ease-in forwards;
  }
  .header-submenu.is-closing .submenu-link--big::after,
  .header-submenu.is-closing .submenu-link--sub::after {
    width: 0;
    -webkit-transition: 0.3s ease-in 0.2s;
    transition: 0.3s ease-in 0.2s;
  }
  .header-submenu.is-closing .text-animation {
    opacity: 0;
    -webkit-transform: translateY(50%);
        -ms-transform: translateY(50%);
            transform: translateY(50%);
    -webkit-transition: 0.3s ease-in;
    transition: 0.3s ease-in;
  }
}
.p-vision .l-content-small {
  max-width: 1168px;
  margin: 0 auto;
}
.p-vision .section-group .section-heading {
  z-index: 999;
}
.p-vision .l-content {
  max-width: 100%;
  padding: 0 4.9rem 0 4.9rem;
  top: -8rem;
  min-height: calc(100vh - 5rem);
}
.p-vision .slider-kv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 10px 0;
  z-index: 6;
  position: relative;
}

.slider-kv-inner.right-to-left {
  -webkit-animation: scroll-to-right 30s infinite linear forwards;
          animation: scroll-to-right 30s infinite linear forwards;
}

.vision-slider-text {
  font-size: 100px;
  line-height: 1.2;
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
  background: #1432AA;
  color: #fff;
  padding-bottom: 13px;
}

.future-info {
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
}
.future-info--title {
  font-size: 30px;
  line-height: 1.2;
}
.future-info--title .reveal {
  padding: 2px 0 7px 5px;
}
.future-info--desc {
  font-size: 16px;
  line-height: 1.2;
  margin-top: 20px;
}
.future-info--desc .reveal {
  padding: 0 0 3px 5px;
  margin-top: 10px;
}
.future-wapper {
  margin-block: 100px;
}
.future-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 55px;
}
.future-content-block {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.future-content {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-areas: "top-left top-center top-right" ". mid-center ." "bottom-left bottom-center bottom-right";
}
.future-content .top-left {
  grid-area: top-left;
}
.future-content .top-center {
  grid-area: top-center;
}
.future-content .top-right {
  grid-area: top-right;
}
.future-content .mid-center {
  grid-area: mid-center;
  min-height: 73px;
  padding: 4px 10px;
  background: #1432AA;
  color: #fff;
}
.future-content .bottom-left {
  grid-area: bottom-left;
}
.future-content .bottom-center {
  grid-area: bottom-center;
}
.future-content .bottom-right {
  grid-area: bottom-right;
}
.future-content--white {
  margin-top: 54px;
}
.future-content--white .future-item {
  min-height: 94px;
}
.future-content--white .future-item:nth-child(odd) {
  background: #fff;
  color: #1432AA;
  text-align: center;
}
.future-content--white .mid-center {
  grid-area: mid-center;
  min-height: 94px;
  padding: 10px;
  background: #fff;
  color: #1432AA;
}
.future-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-inline: 30px;
  position: relative;
  min-height: 208px;
}
.future-item:nth-child(odd) {
  background: #1432AA;
  color: #fff;
}
.future-item:nth-child(even) {
  text-align: center;
}
.future-label {
  position: absolute;
  top: 0;
  left: 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #1432AA;
  line-height: 1.3;
  font-size: 18px;
}
.future-label .reveal {
  padding: 4px 12px;
}
.future-text {
  font-size: 16px;
  line-height: 1.3;
}
.future-text--small {
  font-size: 14px;
  line-height: 1.3;
}
.future-text--medium {
  font-size: 20px;
  line-height: 1.3;
}
.future-text--big {
  font-size: 30px;
  line-height: 1.3;
  font-family: dnp-shuei-mincho-pr6n, sans-serif;
}

.society-wapper {
  padding-block: 120px 96px;
}
.society-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 133px;
}
.society-img {
  max-width: 536px;
  margin-top: -35px;
}

.horizontal-line {
  position: relative;
}
.horizontal-line::after {
  content: "";
  position: absolute;
  width: 100%;
  left: 0;
  top: 0;
  height: 1px;
  background-color: #1432AA;
}

.btn-full {
  padding-block: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 50px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  text-decoration: none;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  color: #1432AA;
}
.btn-full--icon {
  font-size: 0;
  width: 32px;
  height: 20px;
  background: url(/150th/image/shared/btn-full-blue.webp) no-repeat;
  background-size: 100% auto;
  background-position: center;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.btn-full:hover {
  color: #fff;
  background: #1432AA;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.btn-full:hover .btn-full--icon {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  background: url(/150th/image/shared/btn-full-white.webp) no-repeat;
  background-size: 100% auto;
  background-position: center;
}

.back-to-top {
  padding-block: 50px 0;
  text-align: center;
}

@-webkit-keyframes submenu-rise-in {
  from {
    opacity: 0;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes submenu-rise-in {
  from {
    opacity: 0;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes submenu-rise-out {
  from {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    opacity: 0;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
  }
}
@keyframes submenu-rise-out {
  from {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    opacity: 0;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
  }
}
@-webkit-keyframes spin-ring {
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes spin-ring {
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes scroll-to-left {
  from {
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
  to {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
@keyframes scroll-to-right {
  from {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  to {
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
@-webkit-keyframes floatMove {
  0% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
  18% {
    -webkit-transform: translate(2%, -2.5%);
            transform: translate(2%, -2.5%);
  }
  41% {
    -webkit-transform: translate(-1.8%, 2.8%);
            transform: translate(-1.8%, 2.8%);
  }
  67% {
    -webkit-transform: translate(-0.8%, -1.5%);
            transform: translate(-0.8%, -1.5%);
  }
  86% {
    -webkit-transform: translate(1.6%, 1.2%);
            transform: translate(1.6%, 1.2%);
  }
  100% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
}
@keyframes floatMove {
  0% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
  18% {
    -webkit-transform: translate(2%, -2.5%);
            transform: translate(2%, -2.5%);
  }
  41% {
    -webkit-transform: translate(-1.8%, 2.8%);
            transform: translate(-1.8%, 2.8%);
  }
  67% {
    -webkit-transform: translate(-0.8%, -1.5%);
            transform: translate(-0.8%, -1.5%);
  }
  86% {
    -webkit-transform: translate(1.6%, 1.2%);
            transform: translate(1.6%, 1.2%);
  }
  100% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
}
@-webkit-keyframes floatMove2 {
  0% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
  18% {
    -webkit-transform: translate(5%, -3.5%);
            transform: translate(5%, -3.5%);
  }
  41% {
    -webkit-transform: translate(-6.8%, 2.8%);
            transform: translate(-6.8%, 2.8%);
  }
  67% {
    -webkit-transform: translate(-4.2%, -4.5%);
            transform: translate(-4.2%, -4.5%);
  }
  86% {
    -webkit-transform: translate(3.6%, 2.2%);
            transform: translate(3.6%, 2.2%);
  }
  100% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
}
@keyframes floatMove2 {
  0% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
  18% {
    -webkit-transform: translate(5%, -3.5%);
            transform: translate(5%, -3.5%);
  }
  41% {
    -webkit-transform: translate(-6.8%, 2.8%);
            transform: translate(-6.8%, 2.8%);
  }
  67% {
    -webkit-transform: translate(-4.2%, -4.5%);
            transform: translate(-4.2%, -4.5%);
  }
  86% {
    -webkit-transform: translate(3.6%, 2.2%);
            transform: translate(3.6%, 2.2%);
  }
  100% {
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
}
@-webkit-keyframes floatMove-message-sp {
  0% {
    -webkit-transform: translate(0%, 0%) rotate(-16deg);
            transform: translate(0%, 0%) rotate(-16deg);
  }
  18% {
    -webkit-transform: translate(2%, -2.5%) rotate(-16deg);
            transform: translate(2%, -2.5%) rotate(-16deg);
  }
  41% {
    -webkit-transform: translate(-1.8%, 2.8%) rotate(-16deg);
            transform: translate(-1.8%, 2.8%) rotate(-16deg);
  }
  67% {
    -webkit-transform: translate(-0.8%, -1.5%) rotate(-16deg);
            transform: translate(-0.8%, -1.5%) rotate(-16deg);
  }
  86% {
    -webkit-transform: translate(1.6%, 1.2%) rotate(-16deg);
            transform: translate(1.6%, 1.2%) rotate(-16deg);
  }
  100% {
    -webkit-transform: translate(0%, 0%) rotate(-16deg);
            transform: translate(0%, 0%) rotate(-16deg);
  }
}
@keyframes floatMove-message-sp {
  0% {
    -webkit-transform: translate(0%, 0%) rotate(-16deg);
            transform: translate(0%, 0%) rotate(-16deg);
  }
  18% {
    -webkit-transform: translate(2%, -2.5%) rotate(-16deg);
            transform: translate(2%, -2.5%) rotate(-16deg);
  }
  41% {
    -webkit-transform: translate(-1.8%, 2.8%) rotate(-16deg);
            transform: translate(-1.8%, 2.8%) rotate(-16deg);
  }
  67% {
    -webkit-transform: translate(-0.8%, -1.5%) rotate(-16deg);
            transform: translate(-0.8%, -1.5%) rotate(-16deg);
  }
  86% {
    -webkit-transform: translate(1.6%, 1.2%) rotate(-16deg);
            transform: translate(1.6%, 1.2%) rotate(-16deg);
  }
  100% {
    -webkit-transform: translate(0%, 0%) rotate(-16deg);
            transform: translate(0%, 0%) rotate(-16deg);
  }
}
@keyframes softBounce {
  0% {
    -webkit-transform: scale(1, 1) rotate(0deg);
            transform: scale(1, 1) rotate(0deg);
  }
  22% {
    -webkit-transform: scale(1, 1.05) rotate(0.4deg);
            transform: scale(1, 1.05) rotate(0.4deg);
  }
  48% {
    -webkit-transform: scale(0.95, 1) rotate(-0.3deg);
            transform: scale(0.95, 1) rotate(-0.3deg);
  }
  73% {
    -webkit-transform: scale(1, 1.03) rotate(0.2deg);
            transform: scale(1, 1.03) rotate(0.2deg);
  }
  100% {
    -webkit-transform: scale(1, 1) rotate(0deg);
            transform: scale(1, 1) rotate(0deg);
  }
}
@-webkit-keyframes wave-top-bottom {
  0% {
    clip-path: path("M0 20 Q70 0 140 20 Q218 40 296 20 Q366 0 436 20 L436 560 Q366 580 296 560 Q218 540 140 560 Q70 580 0 560 L0 20 Z");
  }
  100% {
    clip-path: path("M0 20 Q70 40 140 20 Q218 0 296 20 Q366 40 436 20 L436 560 Q366 540 296 560 Q218 580 140 560 Q70 540 0 560 L0 20 Z");
  }
}
@keyframes wave-top-bottom {
  0% {
    clip-path: path("M0 20 Q70 0 140 20 Q218 40 296 20 Q366 0 436 20 L436 560 Q366 580 296 560 Q218 540 140 560 Q70 580 0 560 L0 20 Z");
  }
  100% {
    clip-path: path("M0 20 Q70 40 140 20 Q218 0 296 20 Q366 40 436 20 L436 560 Q366 540 296 560 Q218 580 140 560 Q70 540 0 560 L0 20 Z");
  }
}
@-webkit-keyframes wave-top-bottom2 {
  0% {
    clip-path: path("M0 20 Q35 0 70 20 Q105 40 140 20 Q179 0 218 20 Q257 40 296 20 Q331 0 366 20 Q401 40 436 20 L436 560 Q401 580 366 560 Q331 540 296 560 Q257 580 218 560 Q179 540 140 560 Q105 580 70 560 Q35 540 0 560 Z");
  }
  100% {
    clip-path: path("M0 20 Q35 40 70 20 Q105 0 140 20 Q179 40 218 20 Q257 0 296 20 Q331 40 366 20 Q401 0 436 20 L436 560 Q401 540 366 560 Q331 580 296 560 Q257 540 218 560 Q179 580 140 560 Q105 540 70 560 Q35 580 0 560 Z");
  }
}
@keyframes wave-top-bottom2 {
  0% {
    clip-path: path("M0 20 Q35 0 70 20 Q105 40 140 20 Q179 0 218 20 Q257 40 296 20 Q331 0 366 20 Q401 40 436 20 L436 560 Q401 580 366 560 Q331 540 296 560 Q257 580 218 560 Q179 540 140 560 Q105 580 70 560 Q35 540 0 560 Z");
  }
  100% {
    clip-path: path("M0 20 Q35 40 70 20 Q105 0 140 20 Q179 40 218 20 Q257 0 296 20 Q331 40 366 20 Q401 0 436 20 L436 560 Q401 540 366 560 Q331 580 296 560 Q257 540 218 560 Q179 580 140 560 Q105 540 70 560 Q35 580 0 560 Z");
  }
}
@-webkit-keyframes wave-side {
  0% {
    clip-path: path("M20 0 L416 0 Q436 72 416 145 Q396 218 416 290 Q436 362 416 435 Q396 508 416 580 L20 580 Q0 508 20 435 Q40 362 20 290 Q0 218 20 145 Q40 72 20 0 Z");
  }
  100% {
    clip-path: path("M20 0 L416 0 Q396 72 416 145 Q436 218 416 290 Q396 362 416 435 Q436 508 416 580 L20 580 Q40 508 20 435 Q0 362 20 290 Q40 218 20 145 Q0 72 20 0 Z");
  }
}
@keyframes wave-side {
  0% {
    clip-path: path("M20 0 L416 0 Q436 72 416 145 Q396 218 416 290 Q436 362 416 435 Q396 508 416 580 L20 580 Q0 508 20 435 Q40 362 20 290 Q0 218 20 145 Q40 72 20 0 Z");
  }
  100% {
    clip-path: path("M20 0 L416 0 Q396 72 416 145 Q436 218 416 290 Q396 362 416 435 Q436 508 416 580 L20 580 Q40 508 20 435 Q0 362 20 290 Q40 218 20 145 Q0 72 20 0 Z");
  }
}
@media screen and (max-width: 1600px) {
  @-webkit-keyframes wave-side {
    0% {
      clip-path: path("M15.05 0 L312.95 0 Q328 60.83 312.95 122.5 Q297.91 184.17 312.95 245 Q328 305.83 312.95 367.5 Q297.91 429.17 312.95 490 L15.05 490 Q0 429.17 15.05 367.5 Q30.09 305.83 15.05 245 Q0 184.17 15.05 122.5 Q30.09 60.83 15.05 0 Z");
    }
    100% {
      clip-path: path("M15.05 0 L312.95 0 Q297.91 60.83 312.95 122.5 Q328 184.17 312.95 245 Q297.91 305.83 312.95 367.5 Q328 429.17 312.95 490 L15.05 490 Q30.09 429.17 15.05 367.5 Q0 305.83 15.05 245 Q30.09 184.17 15.05 122.5 Q0 60.83 15.05 0 Z");
    }
  }
  @keyframes wave-side {
    0% {
      clip-path: path("M15.05 0 L312.95 0 Q328 60.83 312.95 122.5 Q297.91 184.17 312.95 245 Q328 305.83 312.95 367.5 Q297.91 429.17 312.95 490 L15.05 490 Q0 429.17 15.05 367.5 Q30.09 305.83 15.05 245 Q0 184.17 15.05 122.5 Q30.09 60.83 15.05 0 Z");
    }
    100% {
      clip-path: path("M15.05 0 L312.95 0 Q297.91 60.83 312.95 122.5 Q328 184.17 312.95 245 Q297.91 305.83 312.95 367.5 Q328 429.17 312.95 490 L15.05 490 Q30.09 429.17 15.05 367.5 Q0 305.83 15.05 245 Q30.09 184.17 15.05 122.5 Q0 60.83 15.05 0 Z");
    }
  }
}
@keyframes panel-sweep {
  to {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}
@keyframes text-rise {
  from {
    -webkit-transform: translateY(105%);
            transform: translateY(105%);
  }
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@media screen and (min-width: 768px) {
  #section-anniversary .l-heading {
    top: -5rem;
  }
}
#section-anniversary .back-btn {
  margin: 64px auto;
}

.anniversary-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: calc(100% - 100px);
  margin: 0 auto;
  border-bottom: 1px solid #1432AA;
}
.anniversary-left {
  position: sticky;
  top: 0;
  height: 100vh;
  width: 50%;
  border-right: 1px solid #1432AA;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  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;
  background: #fff;
}
.anniversary_logo {
  width: 26.528vw;
  height: 26.528vw;
  overflow: hidden;
}
.anniversary_logo video {
  width: 100%;
  height: 100%;
}
.anniversary-right {
  width: 50%;
}
.anniversary-right-img {
  padding-top: 35px;
}
.anniversary-right-caption {
  padding-top: 15px;
  font-size: 12px;
  color: #000;
}
.anniversary-right__content {
  width: 100%;
  height: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-left: 66px;
}
.anniversary-right__content .hero-body {
  font-size: 20px;
}
.anniversary-right__section {
  position: relative;
  padding: 104px 54px 57px 64px;
  border-top: 1px solid #1432AA;
}
.anniversary-right__section-1 {
  padding: 152px 54px 95px 64px;
}
.anniversary-right_label {
  font-size: 24px;
  background: #1432AA;
  position: absolute;
  top: 0;
  left: 0;
  padding: 1px 4px;
  font-family: "Instrument Serif", serif;
  text-transform: uppercase;
  color: #fff;
}
.anniversary-heading {
  margin-bottom: 15px;
}
.anniversary-heading .hero-body {
  font-size: 24px;
  line-height: 1.3;
  font-weight: bold;
}
.anniversary-text {
  font-size: 16px;
  line-height: 2;
  color: #000;
}
.anniversary-body {
  width: calc(100% - 100px);
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid #1432AA;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.anniversary-body_right {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.anniversary-body_left {
  border-right: 1px solid #1432AA;
  width: 100%;
}
.anniversary-body_left_content {
  padding-top: 90px;
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.logo-journey {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  position: relative;
  border-bottom: 1px solid #1432AA;
}
.logo-journey__timeline {
  width: 100%;
  position: relative;
  padding-top: 93px;
  border-top: 1px solid #1432AA;
}
.logo-journey__timeline-1 {
  padding-top: 60px;
}
.logo-journey__year-group {
  padding-right: 110px;
  position: relative;
}
.logo-journey__year {
  position: absolute;
  left: -32px;
  top: -4px;
  -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
          transform: translateX(-100%);
  font-size: 24px;
  line-height: 1.5;
}
.logo-journey__text {
  position: absolute;
  left: -32px;
  top: 2px;
  -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
          transform: translateX(-100%);
  font-size: 16px;
  line-height: 1.5;
}
.logo-journey__event {
  padding-left: 34px;
  position: relative;
  padding-bottom: 55px;
}
.logo-journey__event-group {
  padding-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 12px;
}
.logo-journey__event-img img {
  background-color: #fff;
}
.logo-journey__event-caption {
  padding-top: 10px;
  font-size: 12px;
  line-height: 2;
  color: #000;
}
.logo-journey__event-marker {
  position: absolute;
  left: 0;
  top: 2px;
  width: 16px;
  height: 16px;
  background: #1432AA;
  border-radius: 999px;
  -webkit-transform: translate(-50%, 4px);
      -ms-transform: translate(-50%, 4px);
          transform: translate(-50%, 4px);
}
.logo-journey__event-marker-2 {
  width: 10px;
  height: 10px;
  top: 5px;
}
.logo-journey__event-title {
  line-height: 1.3;
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 18px;
}
.logo-journey__event-description {
  line-height: 2;
  color: #000;
}
@media screen and (max-width: 767px) {
  #section-anniversary .l-heading {
    z-index: 1001;
  }
  .anniversary-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    margin: 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .anniversary-left {
    position: relative;
    top: 0;
    height: auto;
    width: 100%;
    border-right: none;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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;
    background: #fff;
    padding-top: 70px;
    z-index: 1000;
    border-bottom: 1px solid #1432AA;
  }
  .anniversary_logo {
    width: 53.333vw;
    height: 53.333vw;
    overflow: hidden;
  }
  .anniversary_logo video {
    width: 100%;
    height: 100%;
  }
  .anniversary-right {
    width: 100%;
  }
  .anniversary-right-img {
    padding-top: 30px;
  }
  .anniversary-right-caption {
    padding-top: 10px;
    font-size: 10px;
  }
  .anniversary-right__content {
    height: auto;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 64px 25px 69px 34px;
  }
  .anniversary-right__content .hero-body {
    font-size: 16px;
  }
  .anniversary-right__section {
    position: relative;
    padding: 55px 32px 115px;
  }
  .anniversary-right__section::after {
    width: 100%;
    height: 1px;
  }
  .anniversary-right__section-1 {
    padding: 59px 32px 68px;
  }
  .anniversary-right_label {
    font-size: 20px;
  }
  .anniversary-heading {
    margin-bottom: 15px;
  }
  .anniversary-heading .hero-body {
    font-size: 20px;
    line-height: 1.3;
    font-weight: bold;
  }
  .anniversary-text {
    font-size: 14px;
    line-height: 2;
    color: #000;
  }
  .anniversary-body {
    width: 100%;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border-top: 1px solid #1432AA;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .anniversary-body_right {
    width: 32px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .anniversary-body_left {
    border-left: 1px solid #1432AA;
    border-right: none;
    width: 100%;
  }
  .anniversary-body_left_content {
    padding: 37px 32px;
    margin: 0 auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  .logo-journey {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    position: relative;
    border-bottom: 1px solid #1432AA;
  }
  .logo-journey__timeline {
    width: 100%;
    position: relative;
    padding-top: 40px;
  }
  .logo-journey__year-group {
    padding-bottom: 0;
    padding-inline: 56px 32px;
    position: relative;
  }
  .logo-journey__year {
    position: relative;
    left: 0;
    top: -1px;
    -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    font-size: 18px;
    padding-bottom: 8px;
  }
  .logo-journey__text {
    position: relative;
    left: 0;
    top: 3px;
    margin-bottom: 5px;
    -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    font-size: 14px;
  }
  .logo-journey__event {
    position: relative;
    padding-bottom: 40px;
    padding-left: 0;
  }
  .logo-journey__event-group {
    padding-top: 20px;
    gap: 12px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .logo-journey__event-group.col2-sp .logo-journey__event-img {
    width: calc(50% - 6px);
  }
  .logo-journey__event-caption {
    padding-top: 10px;
    font-size: 12px;
    line-height: 2;
    color: #000;
  }
  .logo-journey__event-marker {
    display: none;
  }
  .logo-journey__event-marker-2 {
    width: 8px;
    height: 8px;
    top: 5px;
  }
  .logo-journey__event-title {
    line-height: 1.3;
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 17px;
  }
  .logo-journey__event-description {
    line-height: 2;
    color: #000;
    font-size: 14px;
  }
}
@media screen and (max-width: 767px) {
  .l-information {
    padding-bottom: 6.4rem;
  }
}
.l-information .l-heading {
  top: -5rem;
}
@media screen and (max-width: 767px) {
  .l-information .l-heading {
    top: 0;
  }
}
.l-information .section-group {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.l-information #section-information {
  padding-inline: 49px;
}
@media screen and (max-width: 767px) {
  .l-information #section-information {
    padding-inline: 0;
  }
}
.l-information .c-information {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-bottom: 6.3rem;
  width: 100%;
  border-block: 1px solid #1432AA;
}
@media screen and (max-width: 767px) {
  .l-information .c-information {
    grid-template-columns: 1fr;
    padding: 0;
    border-bottom: none;
    margin-top: 50px;
  }
}
.l-information .c-information--item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 0 2.4rem;
  border-right: 0.1rem solid #1432AA;
  position: relative;
  cursor: pointer;
  -webkit-transition: 0.2s all;
  transition: 0.2s all;
  aspect-ratio: 1/1;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .l-information .c-information--item {
    border-bottom: 0.1rem solid #1432AA;
    border-top: none;
    border-right: none;
    border-left: none;
    aspect-ratio: auto;
    min-height: 251px;
  }
}
.l-information .c-information--item:hover .modal-btn {
  background-color: #ffffff;
}
.l-information .c-information--item:hover .modal-btn .icon-plus::after {
  background-color: #1432AA;
}
.l-information .c-information--item:hover .modal-btn .icon-plus::before {
  background-color: #1432AA;
}
.l-information .c-information--item .date {
  margin-bottom: 1.7rem;
  font-size: 1.8rem;
  font-family: "Instrument Serif", serif;
}
.l-information .c-information--item .image {
  border-radius: 99.9rem;
  overflow: hidden;
  padding: 7px 27px;
  margin-bottom: 1.4rem;
  background: #fff;
}
.l-information .c-information--item .image img {
  width: 66px;
  height: 66px;
}
.l-information .c-information--item .desc {
  font-size: 1.6rem;
  line-height: 1.5;
}
.l-information .c-information--item .modal-btn {
  width: 3.5rem;
  height: 3.5rem;
  position: absolute;
  bottom: 0;
  right: 0;
  background-color: #1432AA;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-top: 0.1rem solid #1432AA;
  border-left: 0.1rem solid #1432AA;
  -webkit-transition: 0.2s all;
  transition: 0.2s all;
}
.l-information .c-information--item .modal-btn .icon-plus {
  position: relative;
  display: block;
  width: 1rem;
  height: 1rem;
  margin: auto;
}
.l-information .c-information--item .modal-btn .icon-plus::after {
  content: "";
  position: absolute;
  width: 1rem;
  height: 0.1rem;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-color: #ffffff;
}
.l-information .c-information--item .modal-btn .icon-plus::before {
  content: "";
  position: absolute;
  width: 1rem;
  height: 0.1rem;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
      -ms-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
  background-color: #ffffff;
}
@media screen and (max-width: 767px) {
  .l-information .modal-information--header {
    width: 100%;
    position: fixed;
    z-index: 10000;
    bottom: 0;
  }
}
.l-information .modal-information--header .header {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  border-bottom: 0.1rem solid #1432AA;
  height: 5rem;
  padding-right: 7.8rem;
}
@media screen and (max-width: 767px) {
  .l-information .modal-information--header .header {
    bottom: 0;
    top: auto;
    border-top: 0.1rem solid #1432AA;
    border-bottom: none;
    background-color: #ffffff;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-right: 0;
  }
}
.l-information .modal-information--header .header .logo {
  max-width: 4rem;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
.l-information .modal-information--header .header .logo::before {
  position: absolute;
  content: "";
  top: 0;
  left: -2.6rem;
  height: 5rem;
  width: 0.1rem;
  background-color: #1432AA;
}
@media screen and (max-width: 767px) {
  .l-information .modal-information--header .header .logo::before {
    display: none;
  }
}
.l-information .modal-information--header .header .font-instrument {
  font-size: 1.5rem;
}
.l-information .modal-information--header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 5rem;
  width: 0.1rem;
  height: 100%;
  background-color: #1432AA;
}
@media screen and (max-width: 767px) {
  .l-information .modal-information--header::before {
    display: none;
  }
}
.l-information .modal-information--header::after {
  content: "";
  position: absolute;
  top: 0;
  right: 5rem;
  width: 0.1rem;
  height: 100%;
  background-color: #1432AA;
}
@media screen and (max-width: 767px) {
  .l-information .modal-information--header::after {
    display: none;
  }
}
.l-information .modal-overlay {
  padding: 5rem 5.1rem 0 5.1rem;
}
@media screen and (max-width: 767px) {
  .l-information .modal-overlay {
    padding: 5rem 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .l-information .modal-overlay .close-btn {
    top: auto;
    bottom: 0;
    z-index: 10000;
  }
}
.l-information .modal-container {
  max-width: 100%;
  display: grid;
  grid-template-columns: 1.4fr 2fr;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .l-information .modal-container {
    display: block;
    height: auto;
    margin: 0;
    max-height: 87.5vh;
    overflow-y: scroll;
  }
}
.l-information .modal-container .modal-information--left {
  border-right: 0.1rem solid #1432AA;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .l-information .modal-container .modal-information--left {
    border-block: 0.1rem solid #1432AA;
  }
}
.l-information .modal-container .modal-information--left .modal-information--img {
  width: 100%;
  height: auto;
  background: #fff;
}
.l-information .modal-container .modal-information--right {
  padding: 12rem;
  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;
}
@media screen and (max-width: 767px) {
  .l-information .modal-container .modal-information--right {
    padding: 3.6rem 3.2rem 12rem 3.2rem;
  }
}
.l-information .modal-container .modal-information--right .date {
  font-size: 1.8rem;
  margin-bottom: 1.2rem;
  color: #333333;
  font-family: "Instrument Serif", serif;
}
.l-information .modal-container .modal-information--right .ttl {
  font-size: 1.6rem;
  font-weight: 500;
  margin-bottom: 1.6rem;
}
@media screen and (max-width: 767px) {
  .l-information .modal-container .modal-information--right .ttl {
    margin-bottom: 2.4rem;
  }
}
.l-information .modal-container .modal-information--right .desc {
  font-size: 1.4rem;
  color: #333333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.6rem;
  line-height: 1.75;
}
.l-information .modal-container .modal-information--right .desc a {
  color: #1432AA;
  text-decoration: none;
}
.l-information .modal-container .modal-information--right .desc .image {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-information .modal-container .modal-information--right .desc .image img {
  max-width: 30rem;
  margin: 0 auto;
}
.l-information .back-btn {
  margin: 0 auto;
}