@charset "utf-8";
html.noscroll {
  overflow: hidden;
}

main {
  overflow: clip;
}

/* ↓↓↓ fv ↓↓↓ */
.fv {
  position: relative;
}
.fv .bg_wrap {
  position: relative;
  width: 100%;
  background-color: #fff;
  padding: 143px 0 0;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .fv .bg_wrap {
    padding: 132px 0 0;
  }
}
.fv .inner {
  position: relative;
  max-width: 1032px;
  container-type: inline-size;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .fv .inner {
    padding-bottom: 40px;
  }
}
.fv .inner .creature01 {
  position: absolute;
  width: min(17.734375vw, 227px);
  opacity: 0;
  translate: 10% 10%;
  bottom: -260px;
  right: clamp(-70px, calc((1032px - 100vw) * 0.37903 + 24px), 24px);
}
@media screen and (max-width: 768px) {
  .fv .inner .creature01 {
    width: 114px;
    bottom: -93px;
    right: -20px;
  }
}
.fv .page_ttl {
  position: relative;
  width: fit-content;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto;
}
.fv .page_ttl::before {
  content: '';
  position: absolute;
  width: 42.5387596899cqw;
  height: auto;
  aspect-ratio: 439/105;
  background-image: url(../img/story/pagettl_deco.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  top: -2.9069767441860463cqw;
  right: -6.104651162790697cqw;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .fv .page_ttl::before {
    width: 248px;
    aspect-ratio: 248/52;
    background-image: url(../img/story/pagettl_deco_sp.svg);
    top: -15px;
    right: 10px;
  }
}
.fv .page_ttl::after {
  content: '';
  position: absolute;
  width: 2.5193798449612403cqw;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url(../img/recycle/pagettl_deco2.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  translate: -50% 100%;
  bottom: -0.29069767441860467cqw;
  left: 50%;
}
@media screen and (max-width: 768px) {
  .fv .page_ttl::after {
    width: 16px;
    bottom: -4px;
  }
}
.fv .page_ttl .en {
  position: relative;
  width: fit-content;
  font-size: 9.689922480620156cqw;
  font-family: var(--Livvic);
  font-weight: 900;
  line-height: 1;   
  letter-spacing: 0.05em;
  color: var(--story_color);
  display: block;
  -webkit-text-stroke: 2px #000;
}
@media screen and (max-width: 768px) {
  .fv .page_ttl .en {
    font-size: 5.6rem;
    -webkit-text-stroke: 1px #000;
  }
}
.fv .page_ttl .ja {
  position: relative;
  width: fit-content;
  font-size: clamp(1.4rem,1.744186046511628cqw,1.8rem);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #fff;
  background-color: #000;
  display: block;
  padding: 0.3875968992248062cqw 1.550387596899225cqw;
  margin: 1.937984496124031cqw auto 0;
}
@media screen and (max-width: 768px) {
.fv .page_ttl .ja {
    font-size: 1.6rem;
    padding: 4px 16px;
    margin: 16px auto 0;
  }
}
.fv .bg_bottom {
  position: absolute;
  width: 100%;
  display: flex;
  justify-content: center;
  overflow: clip;
  translate: -50% 100%;
  bottom: min(0.625vw, 8px);
  left: 50%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .fv .bg_bottom {
    bottom: 2px;
  }
}
.fv .bg_bottom .bg_parts {
  width: max(100%,1920px);
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .fv .bg_bottom .bg_parts {
    width: 100%;
  }
}
/* ↑↑↑ fv ↑↑↑ */
.lead_img {
  width: 100%;
  height: max(62.5vw,800px);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .lead_img {
    height: auto;
  }
}
.lead_img img {
  width: max(100%,1280px);
}
@media screen and (max-width: 768px) { 
  .lead_img img {
    width: min(190.66666666666669vw,800px);
  }
}
/* ↓↓↓ lead_block ↓↓↓ */
.lead_block {
  position: relative;
  padding: 0 30px;
}
@media screen and (max-width: 768px) {
  .lead_block {
    padding: 40px 25px 0;
  }
}
.lead_block .bg_top {
  position: absolute;
  width: 100%;
  display: flex;
  justify-content: center;
  translate: -50% -100%;
  top: 1px;
  left: 50%;
}
.lead_block .bg_top .bg_parts {
  width: max(100%, 1920px);
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .lead_block .bg_top .bg_parts {
    width: 100%;
  }
}
.lead_block .bg_top .creature02 {
  position: absolute;
  width: min(13.4375vw, 172px);
  opacity: 0;
  translate: -10% -10%;
  top: max(-2.34375vw,-30px);
  left: max(calc((440 - 40) * ((100vw - 1280px) / (2560 - 1280)) + 40px),40px);
}
@media screen and (max-width: 768px) {
  .lead_block .bg_top .creature02 {
    width: 86px;
    top: -46px;
    left: 42px;
  }
}
.lead_block .inner {
  max-width: 1032px;
  container-type: inline-size;
  margin: 0 auto;
}
.lead_block .inner .lead_txt {
  font-size: clamp(1.4rem,1.550387596899225cqw,1.6rem);
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.05em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .lead_block .inner .lead_txt {
    font-size: 1.6rem;
  }
}
/* ↑↑↑ lead_block ↑↑↑ */

/* ↓↓↓ flow ↓↓↓ */
.flow {
  position: relative;
  padding: 0 24px;
  margin-top: min(11.875vw, 152px);
}
@media screen and (max-width: 768px) {
  .flow {
    padding: 0;
    margin-top: 0;
  }
}
.flow .inner {
  max-width: 1176px;
  margin: 0 auto;
  container-type: inline-size;
}
@media screen and (max-width: 768px) {
  .flow .inner {
    max-width: 100%;
  }
}
.flow .inner .img_wrap {
  width: 100%;
  position: relative;
  margin-left: 1.19047619047cqw;
}
@media screen and (max-width: 768px) {
  .flow .inner .img_wrap {
    width: 100%;
    height: 1046px;
    padding: 80px 0 64px;
    margin-left: 0;
    overflow-x: scroll !important;
    overflow-y: hidden !important;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .flow .inner .img_wrap::-webkit-scrollbar{
    display: none;
  }
}
.flow .inner .img_wrap .deco {
  position: absolute;
  top: -9.098639455cqw;
  right: 11.0544217687cqw;
  width: 8.7585034013cqw;
  height: auto;
  aspect-ratio: 103 / 87;
}
.flow .inner .img_wrap .flow_img {
  display: block;
  width: 97.9591836734cqw;
  height: auto;
  aspect-ratio: 1152 / 960;
}
@media screen and (max-width: 768px) {
  .flow .inner .img_wrap .flow_img {
    display: block;
    width: 1046px;
    aspect-ratio: 1046 / 844;
    margin-top: 60px;
  }
}
.flow .inner .img_wrap .btn01 {
  position: absolute;
  top: -5.95238095238cqw;
  left: 28.48639455cqw;
  width: 8.16326530612cqw;
  height: auto;
  aspect-ratio: 96 / 108;
  cursor: pointer;
  background-color: unset;
  border: unset;
}
@media screen and (max-width: 768px) {
  .flow .inner .img_wrap .btn01 {
    position: absolute;
    top: 80px;
    left: 322px;
    width: 84px;
    height: auto;
    aspect-ratio: 84 / 92;
  }
}
.flow .inner .img_wrap .btn02 {
  position: absolute;
  top: 5.952380952380952cqw;
  left: 93.02721088435374cqw;
  width: 8.16326530612cqw;
  height: auto;
  aspect-ratio: 96 / 101;
  cursor: pointer;
  background-color: unset;
  border: unset;
}
@media screen and (max-width: 768px) {
  .flow .inner .img_wrap .btn02 {
    position: absolute;
    top: 200px;
    left: 954px;
    width: 84px;
    height: auto;
    aspect-ratio: 84 / 89;
  }
}
.flow .inner .img_wrap .btn03 {
  position: absolute;
  bottom: -3.99659863945cqw;
  left: 27.04081632653cqw;
  width: 8.16326530612cqw;
  height: auto;
  aspect-ratio: 96 / 108;
  cursor: pointer;
  background-color: unset;
  border: unset;
}
@media screen and (max-width: 768px) {
  .flow .inner .img_wrap .btn03 {
    position: absolute;
    bottom: 64px;
    left: 305px;
    width: 84px;
    height: auto;
    aspect-ratio: 84 / 92;
  }
}
.btn01 img, 
.btn02 img {
  transition: scale .5s;
  animation: float01 1s linear infinite;
}
.btn03 img {
  transition: scale .5s;
  animation: float02 1s linear infinite;
}
@media screen and (min-width: 769px) {
  :is(.btn01:hover,.btn02:hover,.btn03:hover) img {
    scale: 1.18;
    animation-play-state: paused;
  }
}
.flow .inner .detail {
  position: relative;
  width: clamp(255px, 27.8911564625cqw, 328px);
  height: auto;
  aspect-ratio: 328 / 64;
  display: grid;
  justify-items: center;
  align-items: center;
  border: 2px solid #000;
  border-radius: 32px;
  margin: 10.2040816326cqw auto 8px;
  background-color: #fff;
  box-shadow: 0 8px 0 #FEF589;
  transition: translate ease .3s, box-shadow ease .3s;
}
@media screen and (min-width: 769px) {
  .flow .inner .detail:hover {
    translate: 0 8px !important;
    box-shadow: 0 0 0 #FEF589;
  } 
}
@media screen and (max-width: 768px) {
  .flow .inner .detail {
    width: 280px;
    height: auto;
    aspect-ratio: 280 / 56;
    border: 1px solid #000;
    border-radius: 32px;
    margin: 0 auto 8px;
    background-color: #fff;
  } 
}
.flow .inner .detail::after {
  content: '';
  position: absolute;
  translate: 0 -50%;
  top: 50%;
  right: clamp(19px, 2.04081632653cqw, 24px);
  width: clamp(19px, 2.04081632653cqw, 24px);
  height: clamp(19px, 2.04081632653cqw, 24px);
  background: url(../img/story/external-link-link.svg) no-repeat;
  background-size: contain;
}
@media screen and (max-width: 768px) {
  .flow .inner .detail::after {
    content: '';
    position: absolute;
    translate: 0 -50%;
    top: 50%;
    right: 16px;
    width: 20px;
    height: 20px;
  }
}
.flow .inner .detail .text {
  font-family: var(--Zen_Kaku_New);
  font-size: clamp(1.4rem, 1.53061224489cqw, 1.8rem);
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .flow .inner .detail .text {
    font-size: 16px;
  }
}
/* ↑↑↑ flow ↑↑↑ */

/* ↓↓↓ modal ↓↓↓ */
.js-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  z-index: 30;
}
.modal__bg {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  background: rgba(248, 255, 235, 0.9);
  position: absolute;
}
.modal__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(856px, 100% - 100px);
  max-height: 80dvh;
  height: min(430px, 41.66666666666667cqw);
  border: 2px solid #000;
  border-radius: 32px;
  background: #fff;
  container-type: inline-size;
}
@media screen and (max-width: 768px) {
  .modal__content {
    width: 86.4%;
    max-width: 500px;
    height: min(calc((450 - 571) * ((100vw - 375px) / (768 - 375)) + 571px),80dvh);
    aspect-ratio: unset;
    border: 1px solid #000;
    border-radius: 32px;
    padding: 56px 24px;
  }
  #modal03 .modal__content {
    padding: 56px 24px 96px 24px;
  }
}
.modal__content .text_wrap {
  display: flex;
  height: calc(100% - 9.389671361502347cqw - 5.633802816901409cqw);
  flex-direction: column;
  margin: 9.389671361502347cqw 11.03286384976526cqw 0 9.624413145539906cqw;
}
@media screen and (max-width: 768px) {
  .modal__content .text_wrap {
    height: 100%;
    margin: 0;
  }
}
.modal__content .text_wrap .title {
  position: relative;
  width: max-content;
  font-family: var(--Zen_Maru);
  font-size: 3.7558685446cqw;
  font-weight: 700;
  margin-left: 7.5117370892cqw;
  padding: 0.234741784037cqw 0.93896713615cqw 0.46948356807cqw;
  color: #FFF;
  background-color: #000;
}
@media screen and (max-width: 768px) {
  .modal__content .text_wrap .title {
    font-size: 2.4rem;
    margin-left: 50px;
    padding: 2px 8px 4px;
  }
}
.modal__content .text_wrap .title::after {
  content: '';
  position: absolute;
  translate: 0 -50%;
  top: 50%;
  left: -7.5117370892cqw;
  width: 5.6338028169cqw;
  height: 6.338028169cqw;
  background: url(../img/story/modal-ttl-deco01.svg) no-repeat;
  background-size: contain;
}
#modal02 .modal__content .text_wrap .title::after {
  background: url(../img/story/modal-ttl-deco02.svg) no-repeat;
  background-size: contain;
}
#modal03 .modal__content .text_wrap .title::after {
  background: url(../img/story/modal-ttl-deco03.png) no-repeat;
  background-size: contain;
}
@media screen and (max-width: 768px) {
  .modal__content .text_wrap .title::after {
    left: -50px;
    width: 38px;
    height: 43px;
  }
}
.modal__content .text_wrap .text {
  font-family: var(--Zen_Kaku_New);
  font-size: 1.8779342723cqw;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  text-align: justify;
  word-break: break-all;
  height: 100%;
  overflow: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
  margin-top: 3.7558685446cqw;
  padding-right: 2.8169014084507045cqw;
  margin-right: -2.8169014084507045cqw;
}
.modal__content .text_wrap .text::-webkit-scrollbar{
  display: none;
}
@media screen and (max-width: 768px) {
  .modal__content .text_wrap .text {
    font-size: 1.6rem;
    padding-right: 12px;
    margin-right: -12px;
    margin-top: 32px;
  }
}
@media screen and (max-width: 768px) {
.modal__content .simplebar-track.simplebar-vertical {
    right: 0px !important;
  }
}
.modal__content .text_wrap::-webkit-scrollbar {
  display: none;
}
.modal__content .simplebar-scrollbar {
  z-index: 10;
  pointer-events: auto !important;
}
.modal__content .simplebar-scrollbar::before {
  background: var(--story_color);
  border-radius: 2px;
  width: 4px;
  margin-left: -2px;
  margin-top: -1px;
}
.modal__content .simplebar-scrollbar.simplebar-visible::before {
  opacity: 1;
}
.modal__content .simplebar-track {
  background: #E7E5E1;
  width: 4px !important;
  border-radius: 2px;
}
.modal__content .deco {
  position: absolute;
  top: 0;
  left: 58.450704225cqw;
  width: 19.718309859cqw;
  height: auto;
  aspect-ratio: 168 / 108;
}
@media screen and (max-width: 768px) {
  .modal__content .deco {
    position: absolute;
    top: 0;
    left: unset;
    right: 0;
    width: 125px;
    aspect-ratio: 125 / 85;
  }
}
#modal02 .modal__content .deco {
  position: absolute;
  top: 0;
  left: 61.2676056338cqw;
  width: 17.84037558685cqw;
  height: auto;
  aspect-ratio: 152 / 120;
}
@media screen and (max-width: 768px) {
  #modal02 .modal__content .deco {
    position: absolute;
    top: 0;
    left: unset;
    right: 4px;
    width: 125px;
    aspect-ratio: 125 / 99;
  }
}
#modal03 .modal__content .deco {
  position: absolute;
  top: 3.7558685446cqw;
  left: 53.873239436cqw;
  width: 42.8403755868cqw;
  height: auto;
  aspect-ratio: 365 / 106;
}
@media screen and (max-width: 768px) {
  #modal03 .modal__content .deco {
    translate: -50% 0;
    top: unset;
    bottom: 0;
    left: 50%;
    width: 276px;
    aspect-ratio: 276 / 80;
    margin: 16px auto 0;

  }
}
.modal__content .modal-close-btn {
  position: absolute;
  top: -4.6948356807cqw;
  right: -4.6948356807cqw;
  width: 9.3896713615cqw;
  height: 9.3896713615cqw;
  background-color: #000;
  border: 2px solid #000;
  transition: background-color .3s ease;
  border-radius: 50%;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .modal__content .modal-close-btn:hover {
    background-color: #FEF589;
  }
}
@media screen and (max-width: 768px) {
  .modal__content .modal-close-btn {
    position: absolute;
    top: -24px;
    right: -14px;
    width: 64px;
    height: 64px;
    background-color: #000;
    transition: background-color .3s ease;
    border-radius: 50%;
  }
}
.modal__content .modal-close-btn::after {
  content: '';
  position: absolute;
  translate: -50% -50%;
  top: 50%;
  left: 50%;
  width: 3.051643192488cqw;
  height: 3.051643192488cqw;
  mask-image: url(../img/story/close-icon.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  background-color: #fff;
  transition: background-color ease .3s;
}
@media screen and (min-width: 769px) {
  .modal__content .modal-close-btn:hover::after {
    background-color: #000;
  }
}
@media screen and (max-width: 768px) {
  .modal__content .modal-close-btn::after {
    width: 17px;
    height: 17px;
  }
}
/* ↑↑↑ modal ↑↑↑ */
/* ↓↓↓ scroll-hint ↓↓↓ */
.scroll-hint-icon {
  translate: -50% 0;
  top: 128px;
  left: 50%;
  background-color: rgba(0, 0, 0, .5);
  border-radius: 16px;        
  width: 156px;
  height: 120px;
}
.scroll-hint-icon:before {
  width: 24px;
  height: 39px;
  background-image: url(../img/story/scroll-hint-hand.svg);
}
.scroll-hint-icon::after {
  background-image: url(../img/story/scroll-hint-arrow.svg);
}
.scroll-hint-icon-white:before {
  background-image: url(../img/story/scroll-hint-hand.svg);
}
.scroll-hint-icon-white:after {
  background-image: url(../img/story/scroll-hint-arrow.svg);
}
.scroll-hint-text {
  display: block;
  font-family: var(--Zen_Kaku_New);
  font-size: 1.4rem;
  font-weight: 500;
  text-align: center;
  line-height: 1.4;
  color: #fff;
}
/* ↑↑↑ scroll-hint ↑↑↑ */
