.home .hero {
  width: 100%;
  height: calc(100svh - 4.5em);
  line-height: 0;
  display: flex;
  flex-wrap: wrap;
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.home .hero .hero_inner {
  width: 100%;
  height: calc(50svh - 2.25em);
}
@media (min-width: 768px) {
  .home .hero .hero_inner {
    width: 50%;
    height: auto;
  }
}
.home .hero .hero_inner img {
  height: 50svh;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .home .hero .hero_inner img {
    height: 100svh;
  }
}
.home .post_content {
  position: relative;
}
.home .container .h2 {
  line-height: 1.2;
}
.home .container .text {
  line-height: 3;
}
.home .container p.title {
  font-size: clamp(2rem, 0.909rem + 5.45vw, 5rem);
  line-height: 2;
}
.home #sec01 {
  position: relative;
  z-index: 0;
}
.home #sec01::before {
  content: "";
  width: 100%;
  height: 100%;
  background-image: url(../../images/common/bg_mosaic_01.webp);
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.home #sec01 .container .notice {
  background-color: #fff;
  padding: 2em 5%;
}
.home #sec01 .container .sec01_inner {
  display: flex;
  flex-wrap: wrap;
  gap: 2em 6%;
  position: relative;
}
@media (min-width: 768px) {
  .home #sec01 .container .sec01_inner {
    flex-wrap: nowrap;
  }
}
.home #sec01 .container .sec01_inner .text {
  padding-block-start: 5%;
}
@media (width >= 1400px) {
  .home #sec01 .container .sec01_inner .text .h2 br {
    display: none;
  }
}
.home #sec01 .container .sec01_inner .picture {
  width: 70%;
  margin-inline-start: auto;
}
@media (min-width: 768px) {
  .home #sec01 .container .sec01_inner .picture {
    width: 22%;
    margin-inline-start: 0;
  }
}
.home #sec01 .container .sec01_inner .picture:last-child {
  position: absolute;
  right: -5svw;
  bottom: 0;
  z-index: -1;
}
@media (width >= 1666px) {
  .home #sec01 .container .sec01_inner .picture:last-child {
    right: calc(750px - 50svw);
  }
}
.home #sec01 .container:nth-of-type(3) {
  position: relative;
  z-index: 0;
}
.home #sec01 .container:nth-of-type(3)::before {
  content: "";
  width: 200svw;
  height: calc(50% + 6em);
  background-color: #fff;
  position: absolute;
  left: -50%;
  bottom: -6em;
  z-index: -1;
}
.home #sec02 .container picture,
.home #sec03 .container picture {
  line-height: 0;
  display: block;
}
.home #sec02 .container picture img,
.home #sec03 .container picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.home #sec02 .container:nth-of-type(1),
.home #sec03 .container:nth-of-type(1) {
  display: flex;
  flex-wrap: wrap;
  gap: 2em 6%;
}
.home #sec02 .container:nth-of-type(1) .text,
.home #sec03 .container:nth-of-type(1) .text {
  width: 100%;
  display: grid;
}
@media (min-width: 768px) {
  .home #sec02 .container:nth-of-type(1) .text,
  .home #sec03 .container:nth-of-type(1) .text {
    width: 47%;
  }
}
.home #sec02 .container:nth-of-type(1) .picture,
.home #sec03 .container:nth-of-type(1) .picture {
  width: 47%;
  min-height: 100%;
}
.home #sec02 .container:nth-of-type(2) .swiper .swiper-pagination,
.home #sec03 .container:nth-of-type(2) .swiper .swiper-pagination {
  position: relative;
  bottom: 0;
}
.home #sec02 .container:nth-of-type(2) .swiper .swiper-pagination .swiper-pagination-bullet,
.home #sec03 .container:nth-of-type(2) .swiper .swiper-pagination .swiper-pagination-bullet {
  width: 3em;
  height: 0.5em;
  border-radius: 0;
}
.home #sec02 .container:nth-of-type(2) .swiper .swiper-pagination .swiper-pagination-bullet-active,
.home #sec03 .container:nth-of-type(2) .swiper .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #222;
}
.home #sec02 .container:nth-of-type(1) .text img {
  aspect-ratio: 1/1;
}
@media (min-width: 768px) {
  .home #sec02 .container:nth-of-type(1) .text img {
    aspect-ratio: inherit;
  }
}
.home #sec03 .container:nth-of-type(1) {
  flex-direction: row-reverse;
}
.home #sec03 .container:nth-of-type(1) .text img {
  width: 70%;
}
@media (min-width: 768px) {
  .home #sec03 .container:nth-of-type(1) .text img {
    width: inherit;
  }
}
@media (min-width: 480px) {
  .home #sec04 .container:nth-of-type(1) .text {
    text-align: center;
  }
}
@media (min-width: 480px) {
  .home #sec04 .container:nth-of-type(1) .text .h2 + .h2 {
    font-size: 3.2rem;
  }
}
.home #sec04 .container:nth-of-type(1) .text p span {
  display: inline-block;
}
.home #sec04 .container:nth-of-type(2) {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2em;
}
.home #sec05 .container .sec05_inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  row-gap: 5em;
  margin-inline: -3.5%;
}
.home #sec05 .container .sec05_inner .page_link {
  grid-column: span 3;
  padding-inline: 10%;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: 0;
}
@media (min-width: 768px) {
  .home #sec05 .container .sec05_inner .page_link {
    grid-column: span 1;
  }
}
@media (min-width: 768px) {
  .home #sec05 .container .sec05_inner .page_link:nth-of-type(2) {
    border-right: #222 solid 1px;
    border-left: #222 solid 1px;
  }
}
.home #sec05 .container .sec05_inner .page_link .h2 {
  line-height: 1;
}
.home #sec05 .container .sec05_inner .page_link .picture {
  line-height: 0;
  display: block;
}
.home #news {
  position: relative;
  z-index: 0;
}
.home #news .container .title .button {
  text-align: right;
}
.home #news .container .button {
  margin-block-start: 0.5em;
}
@media (min-width: 768px) {
  .home #news .container .button {
    margin-block-start: -3em;
  }
}
.home #news .container .news_inner {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 3em 4em;
}
@media (min-width: 480px) {
  .home #news .container .news_inner {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 980px) {
  .home #news .container .news_inner {
    grid-template-columns: repeat(3, 1fr);
  }
}
.home #news .container .news_inner .article > a {
  padding-block-end: 0.5em;
  display: block;
  position: relative;
  z-index: 0;
}
.home #news .container .news_inner .article > a::before {
  content: "";
  width: 0%;
  height: 1px;
  border-bottom: #222 solid 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: all 0.4s;
}
.home #news .container .news_inner .article > a:hover::before {
  width: 100%;
}
.home #news .container .news_inner .article .thumbnail {
  line-height: 0;
}
.home #news .container .news_inner .article .thumbnail img {
  width: 100%;
  height: 100%;
  background-color: #fff;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
.home #news .container .news_inner .article .entry_meta {
  display: flex;
  gap: 0.5em;
}
.home #news .container .news_inner .article .entry_meta .entry_tag {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  letter-spacing: 0.1em;
  text-transform: capitalize;
}
.home #news .container .news_inner .article .entry_title .eng {
  line-height: 1.2;
  letter-spacing: 0.1em;
}

.swiper-slide-active .swiper-img,
.swiper-slide-duplicate-active .swiper-img,
.swiper-slide-prev .swiper-img {
  animation: zoomUp 7s linear 0s normal both;
}

.effect.fade_in {
  opacity: 0;
  filter: blur(2em);
  transition: all 1500ms;
}
.effect.fade_in.is_show {
  opacity: 1;
  filter: blur(0);
}
.effect.fade_up {
  opacity: 0;
  transform: translate(0, 30px);
  transition: all 2000ms;
}
.effect:not(.opening).fade_down {
  opacity: 0;
  transform: translate(0, -30px);
  transition: all 2000ms;
}
.effect.slide_left {
  opacity: 0;
  transform: translate(30px, 0);
  transition: all 2000ms;
}
.effect.slide_right {
  opacity: 0;
  transform: translate(-30px, 0);
  transition: all 2000ms;
}
.effect.is_show:not(.fade_in) {
  opacity: 1;
  transform: translate(0, 0);
}

/* delay */
/* opening */
.effect.opening.fade_in {
  opacity: 0;
  transition: opacity 3s;
}
.effect.opening.fade_in.start {
  opacity: 1;
}
.effect.opening.fade_down {
  opacity: 0;
  transform: translateY(-50%);
}
.effect.opening.fade_down.start {
  animation: opening 1s 1 forwards 1s;
}

@keyframes opening {
  100% {
    opacity: 1;
    transform: translateY(0%);
  }
}
@keyframes zoomUp {
  0% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}/*# sourceMappingURL=home.css.map */