/* arguments inittial */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
/* site style */
/* [ writing-mode ]
-------------------------------------------------*/
/* [ easy breakpoint ]
-------------------------------------------------*/
#top {
  color: #fff;
}

#top .bg {
  width: 100%;
  height: 100vh;
  height: 100lvh;
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
  overflow: hidden;
}

#top .bg .bg_slide {
  position: relative;
  overflow: hidden;
}

#top .bg .bg_slide figure {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

#top .bg .bg_slide figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@keyframes zoomOut {
  0% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}

#top .bg .swiper-slide-active .slide-img,
#top .bg .swiper-slide-duplicate-active .slide-img,
#top .bg .swiper-slide-prev .slide-img {
  animation: zoomOut 10s linear 0s 1 normal both;
}

#top .mv {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (max-width: 767px) {
  #top .mv {
    padding: 0 30px 0 60px;
  }
}

#top .mv .mv_ttl {
  width: 80%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
}

#top .mv .mv_ttl img {
  display: block;
  max-width: 425px;
}

@media (max-width: 767px) {
  #top .mv .mv_ttl img {
    max-width: 267px;
  }
}

#top .concept {
  padding-top: 60px;
  margin-top: 260px;
}

@media (max-width: 767px) {
  #top .concept {
    margin-top: 90px;
  }
}

#top .concept .concept_title img {
  width: 242px;
}

@media (max-width: 767px) {
  #top .concept .concept_title img {
    width: 162px;
  }
}

#top .concept .concept_subtitle {
  font-size: 35px;
  font-size: 3.5rem;
  line-height: 1em;
  letter-spacing: 0.2em;
  font-weight: 500;
  margin-top: 130px;
}

@media only screen and (max-width: 1100px) {
  #top .concept .concept_subtitle {
    font-size: 28px;
    font-size: 2.8rem;
  }
}

@media (max-width: 767px) {
  #top .concept .concept_subtitle {
    font-size: 22px;
    font-size: 2.2rem;
    line-height: 1.4545em;
    letter-spacing: 0.15em;
    margin-top: 44px;
  }
}

#top .concept .concept_content {
  font-size: 20px;
  font-size: 2rem;
  line-height: 2em;
  letter-spacing: 0.2em;
  font-weight: 700;
  margin-top: 70px;
}

@media only screen and (max-width: 1100px) {
  #top .concept .concept_content {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media (max-width: 767px) {
  #top .concept .concept_content {
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8666em;
    letter-spacing: 0.15em;
    margin-top: 40px;
  }
}

#top .concept .concept_inner {
  width: calc(100% - 60px);
  margin: 0 auto;
  max-width: 737px;
}

@media only screen and (max-width: 1100px) {
  #top .concept .concept_inner {
    width: 100%;
    padding: 0 40px 0 100px;
  }
}

@media (max-width: 767px) {
  #top .concept .concept_inner {
    padding: 0 16px 0 60px;
  }
}

#top .materiality {
  padding-top: 60px;
  margin-top: 148px;
}

@media (max-width: 767px) {
  #top .materiality {
    margin-top: 44px;
  }
}

#top .materiality .materiality_title ._en {
  padding-bottom: 5px;
}

#top .materiality .materiality_title ._en img {
  width: 337px;
}

@media (max-width: 767px) {
  #top .materiality .materiality_title ._en img {
    width: 225px;
  }
}

#top .materiality .materiality_inner {
  width: calc(100% - 60px);
  margin: 0 auto;
  max-width: 1050px;
}

@media only screen and (max-width: 1100px) {
  #top .materiality .materiality_inner {
    width: 100%;
    padding: 0 40px 0 100px;
  }
}

@media (max-width: 767px) {
  #top .materiality .materiality_inner {
    padding: 0;
  }
}

#top .materiality .materiality_scroll {
  width: 100%;
  overflow: hidden;
}

@media (max-width: 767px) {
  #top .materiality .materiality_scroll {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
}

@media (max-width: 767px) {
  #top .materiality .materiality_scroll .materiality_img {
    display: inline-block;
  }
}

#top .materiality .simplebar-track.simplebar-horizontal {
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.25);
  width: calc(100% - 90px);
  left: 60px;
  right: auto;
  position: absolute;
}

#top .materiality .simplebar-scrollbar::before {
  background: #fff;
  border-radius: 2px;
  height: 4px;
  bottom: 1px;
  top: auto;
}

#top .materiality .simplebar-scrollbar.simplebar-visible:before {
  opacity: 1;
}

@media (max-width: 767px) {
  #top .materiality .materiality_scroll {
    scrollbar-width: thin;
    scrollbar-color: #9aa0a6 #eee;
  }
  #top .materiality .materiality_scroll::-webkit-scrollbar {
    height: 8px;
  }
  #top .materiality .materiality_scroll::-webkit-scrollbar-track {
    background: #eee;
    border-radius: 999px;
  }
  #top .materiality .materiality_scroll::-webkit-scrollbar-thumb {
    background: #9aa0a6;
    border-radius: 999px;
  }
}

#top .materiality .materiality_img {
  margin-top: 112px;
}

@media (max-width: 767px) {
  #top .materiality .materiality_img {
    width: 1013px;
    padding: 0 30px 14px 60px;
    margin-top: 47px;
  }
}

#top .materiality .materiality_content {
  font-size: 20px;
  font-size: 2rem;
  line-height: 2em;
  letter-spacing: 0.2em;
  font-weight: 700;
  margin-top: 82px;
  text-align: center;
}

@media only screen and (max-width: 1100px) {
  #top .materiality .materiality_content {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media (max-width: 767px) {
  #top .materiality .materiality_content {
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8666em;
    letter-spacing: 0.15em;
    margin-top: 54px;
    padding: 0 30px 0 60px;
  }
}

#top .story {
  margin: 196px 0 222px;
}

@media (max-width: 767px) {
  #top .story {
    margin: 133px 0 88px;
  }
}

#top .story .story_link {
  background: #0055A2;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  color: #fff;
  padding: 125px 0 105px;
  transform: skewY(-10.7deg);
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

@media (max-width: 767px) {
  #top .story .story_link {
    padding: 85px 0 54px;
  }
}

#top .story .story_link .story_link_bg {
  position: absolute;
  width: 100%;
  height: 100vh;
  display: block;
  top: 50%;
  left: 0;
  opacity: 0.7;
  mix-blend-mode: multiply;
  transition: 0.3s;
  background-image: url("/enterpri/co-creation/assets/img/top/img_story.jpg");
  background-size: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  transform: skewY(10.7deg) translateY(-50%);
}

@media (max-width: 767px) {
  #top .story .story_link .story_link_bg {
    background-image: url("/enterpri/co-creation/assets/img/top/img_story_sp.jpg");
  }
}

@media (any-hover: hover) {
  #top .story .story_link:hover {
    opacity: 1;
  }
  #top .story .story_link:hover .story_link_bg {
    background-size: 110%;
  }
}

#top .story .story_title {
  transform: skewY(10.7deg);
  position: relative;
  z-index: 2;
}

#top .story .story_title ._en {
  width: 413px;
  padding-bottom: 26px;
}

@media (max-width: 767px) {
  #top .story .story_title ._en {
    width: 225px;
    padding-bottom: 18px;
  }
}

#top .story .story_title ._en img {
  width: 183px;
}

@media (max-width: 767px) {
  #top .story .story_title ._en img {
    width: 124px;
  }
}

#top .c_footer {
  margin-bottom: 194px;
}

@media (max-width: 767px) {
  #top .c_footer {
    margin-bottom: 222px;
  }
}
