@charset "UTF-8";
/* コンテンツ最大幅 */
/* color */
/* ============================================ */
/* font */
/* ============================================ */
/* top */
/* ============================================ */
main {
  padding-top: 95px;
}
@media all and (max-width: 896px) {
  main {
    padding-top: 50px;
  }
}

.mv {
  position: relative;
  padding-bottom: 40px;
  font-size: 1.67vw;
}
@media all and (max-width: 896px) {
  .mv {
    font-size: 4.62vw;
  }
}
.mv figure img {
  width: 100%;
}
.mv .rotate {
  position: absolute;
  top: 2vw;
  left: 15.42vw;
  transform: rotate(-4deg);
}
@media all and (max-width: 896px) {
  .mv .rotate {
    top: 2.56vw;
    left: 2.56vw;
  }
}
.mv h1 {
  margin-bottom: 1.46vw;
  color: #009be9;
  font-family: "Archivo", sans-serif;
  font-size: 4.95vw;
  font-weight: 900;
  line-height: 1;
}
@media all and (max-width: 896px) {
  .mv h1 {
    margin-bottom: 3.85vw;
    font-size: 13.59vw;
  }
}
.mv .link-bnr {
  position: absolute;
  bottom: 10px;
  left: 50%;
  width: calc(100% - 30px);
  max-width: 1200px;
  text-align: center;
  transform: translateX(-50%);
}
@media all and (max-width: 896px) {
  .mv .link-bnr {
    max-width: initial;
    left: 15px;
    transform: translateX(0);
  }
}
.mv .link-bnr dt {
  display: inline-flex;
  position: relative;
  margin-bottom: 20px;
  padding-inline: 40px;
  color: #00ae91;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 1px;
  -webkit-text-stroke: 5px #fff;
  paint-order: stroke;
}
@media all and (max-width: 896px) {
  .mv .link-bnr dt {
    margin-bottom: 10px;
    padding-inline: 25px;
    font-size: 2.4rem;
  }
}
.mv .link-bnr dt::before, .mv .link-bnr dt::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 2px;
  height: 80px;
  outline: 2px solid #fff;
  background: #00ae91;
}
@media all and (max-width: 896px) {
  .mv .link-bnr dt::before, .mv .link-bnr dt::after {
    height: 60px;
  }
}
.mv .link-bnr dt::before {
  left: 0;
  transform: rotate(-24deg);
}
.mv .link-bnr dt::after {
  right: 0;
  transform: rotate(24deg);
}
.mv .link-bnr ul {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px;
  background: #fff;
  box-shadow: 4px 4px 20px 0 rgba(0, 0, 0, 0.25);
}
.mv .link-bnr ul li {
  position: relative;
  display: flex;
  justify-content: center;
  width: 50%;
}
@media all and (max-width: 896px) {
  .mv .link-bnr ul li {
    display: block;
  }
}
.mv .link-bnr ul li:not(:first-child)::before {
  content: "";
  position: absolute;
  top: 15px;
  left: 0;
  width: 1px;
  height: calc(100% - 30px);
  background: #cddbe0;
}
.mv .link-bnr ul li a {
  display: flex;
  flex-direction: column;
  padding: 15px;
  font-size: 1.8rem;
}
@media all and (max-width: 896px) {
  .mv .link-bnr ul li a {
    font-size: 1.3rem;
  }
}
.mv .link-bnr ul li a img {
  max-width: 300px;
  margin: 5px auto 0;
}
@media all and (max-width: 896px) {
  .mv .link-bnr ul li a img {
    max-width: 100%;
  }
}

html[lang=zh-cmn-Hant] .mv .rotate {
  top: 5vw;
}
@media all and (max-width: 896px) {
  html[lang=zh-cmn-Hant] .mv .rotate {
    top: 13vw;
  }
}

html[lang=th] .mv .rotate {
  top: 5vw;
}
@media all and (max-width: 896px) {
  html[lang=th] .mv .rotate {
    top: 2.56vw;
  }
}

.access {
  position: relative;
  margin-top: -40px;
  padding-block: 88px 40px;
  overflow: hidden;
}
.access::before, .access::after {
  content: "";
  position: absolute;
  z-index: -1;
  background: url(../images/common/ico_snowflake.svg) no-repeat center/cover;
  animation: rotation 15s linear infinite;
}
.access::before {
  top: 0;
  right: -70px;
  width: 227px;
  height: 254px;
}
@media all and (max-width: 896px) {
  .access::before {
    z-index: 0;
  }
}
.access::after {
  bottom: -44px;
  left: -36px;
  width: 110px;
  height: 126px;
}
.access .inner {
  display: flex;
  align-items: center;
  gap: 30px;
}
@media all and (max-width: 896px) {
  .access .inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}
.access .exp {
  width: calc((100% - 30px) / 2);
}
@media all and (max-width: 896px) {
  .access .exp {
    display: contents;
    width: auto;
  }
}
.access .exp h3 {
  margin-block: 15px;
  color: #0a1927;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: 1px;
}
@media all and (max-width: 896px) {
  .access .exp h3 {
    margin-block: 0 10px;
  }
}
.access .exp h3 strong {
  color: #00ae91;
}
.access .exp nav {
  margin-top: 40px;
}
@media all and (max-width: 896px) {
  .access .exp nav {
    order: 1;
    width: 306px;
    margin: 0 auto;
  }
}
.access .exp nav ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px;
}
.access .exp nav ul li {
  width: calc((100% - 16px) / 3);
}
.access .exp nav ul li a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding-block: 14px;
  border-radius: 4px;
  border: 2px solid #076abc;
  background: #fff;
  color: #076abc;
  text-align: center;
  font-weight: 600;
  line-height: 1.8;
}
.access .exp nav ul li a span {
  font-size: 1.4rem;
  line-height: 1.35;
}
@media all and (max-width: 896px) {
  .access .exp nav ul li a span {
    font-size: 1.2rem;
  }
}
.access .exp nav ul li:first-child {
  width: 100%;
}
.access .exp nav ul li:first-child a {
  background: #076abc;
  color: #fff;
  letter-spacing: 1px;
}
.access figure {
  width: calc((100% - 30px) / 2);
  text-align: center;
}
@media all and (max-width: 896px) {
  .access figure {
    order: 0;
    width: 100%;
    margin: 14px auto 0;
  }
}
.access figure img {
  width: 80%;
}
@media all and (max-width: 896px) {
  .access figure img {
    width: 100%;
  }
}

.movie {
  position: relative;
  margin-top: 35px;
  padding-block: 30px 50px;
  background: linear-gradient(90deg, rgb(224, 250, 253) 0%, rgb(223, 249, 253) 100%);
}
.movie::before, .movie::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 47px;
  background: url(../images/common/bg_wave.webp) no-repeat center/100% 47px;
}
.movie::before {
  top: -47px;
  transform: scale(-1);
}
.movie::after {
  bottom: -47px;
}
.movie iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
  border-radius: 4px;
  margin-top: 24px;
}
.movie .anime {
  position: absolute;
  top: -90px;
  left: 0;
  width: 100%;
  height: 200px;
  overflow: hidden;
}
.movie .anime .tree {
  position: absolute;
  top: 35px;
  right: 150px;
  width: 70px;
}
@media all and (max-width: 896px) {
  .movie .anime .tree {
    right: 100px;
    width: 38px;
  }
}
.movie .anime .skier {
  position: absolute;
  top: -50px;
  right: -120px;
  width: 120px;
}
@media all and (max-width: 896px) {
  .movie .anime .skier {
    right: -87px;
    width: 87px;
  }
}
.movie .anime .skier.is-visible {
  animation: skier03 0.75s cubic-bezier(0.22, 1, 0.36, 1) 1s forwards;
}

.charm {
  position: relative;
  margin-top: -15px;
  padding-block: 88px 40px;
  overflow: hidden;
}
.charm::before {
  content: "";
  position: absolute;
  top: 0;
  right: -70px;
  z-index: -1;
  width: 227px;
  height: 254px;
  background: url(../images/common/ico_snowflake.svg) no-repeat center/cover;
  animation: rotation 15s linear infinite;
}
.charm section {
  padding-block: 40px;
}
.charm section h3 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  color: #0a1927;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.8;
}
.charm section h3 span {
  display: flex;
  position: relative;
  height: 32px;
  padding: 1px 17px 2px 36px;
  justify-content: center;
  align-items: center;
  border-radius: 100px;
  border: 2px solid #009be9;
  background: #fff;
  color: #009be9;
  font-size: 1.6rem;
}
.charm section h3 span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 16px;
  width: 13px;
  height: 15px;
  background: url(../images/common/ico_map_blue.svg) no-repeat center/cover;
  transform: translateY(-50%);
}
.charm section .swiper {
  width: calc(100% - 30px);
  max-width: 1280px;
  margin-inline: auto;
}
@media all and (max-width: 896px) {
  .charm section .swiper {
    width: auto;
    max-width: initial;
    padding-bottom: 50px;
  }
}
.charm section .swiper-wrapper {
  flex-wrap: wrap;
  gap: 30px;
}
@media all and (max-width: 896px) {
  .charm section .swiper-wrapper {
    flex-wrap: nowrap;
    gap: normal;
  }
}
.charm section .swiper-slide {
  width: calc((100% - 30px) / 2);
}
@media all and (max-width: 896px) {
  .charm section .swiper-slide {
    padding-inline: 15px;
  }
}
.charm section .swiper-slide a {
  display: block;
}
.charm section .swiper-slide img {
  border-radius: 4px 4px 0 0;
}
.charm section .swiper-content {
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  padding: 15px 20px 20px;
  border-radius: 0 0 4px 4px;
  background: #e9fcff;
  line-height: 1.8;
}
.charm section .swiper-content::before {
  content: "";
  position: absolute;
  top: -28px;
  left: 50%;
  width: 70px;
  height: 30px;
  background: #e9fcff;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: translateX(-50%);
}
.charm section .swiper-content i {
  position: absolute;
  top: -12px;
  left: 50%;
  color: #009be9;
  font-family: "Archivo", sans-serif;
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  transform: translateX(-50%);
}
.charm section .swiper-content h4 {
  color: #009be9;
  text-align: center;
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: 1px;
}
.charm section .swiper-button-prev, .charm section .swiper-button-next {
  display: none;
}
@media all and (max-width: 896px) {
  .charm section .swiper-button-prev, .charm section .swiper-button-next {
    display: flex;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #009be9;
    filter: drop-shadow(-2px 2px 8px rgba(0, 0, 0, 0.25));
  }
}
.charm section .swiper-button-prev::after, .charm section .swiper-button-next::after {
  content: "";
  width: 9px;
  height: 9px;
  margin-right: 23px;
  background: url(../images/common/ico_arrow.svg) no-repeat center/cover;
  filter: brightness(0) invert(1);
}
.charm section .swiper-button-prev {
  left: -30px;
  transform: scaleX(-1);
}
.charm section .swiper-button-next {
  right: -30px;
}
.charm section .swiper-pagination-bullet {
  width: 13px;
  height: 13px;
  margin-inline: 8px !important;
  border: 1px solid #009be9;
  background: #fff;
}
.charm section .swiper-pagination-bullet-active {
  background: #009be9;
}
.charm section .relation {
  display: flex;
  gap: 30px;
  margin-top: 30px;
}
@media all and (max-width: 896px) {
  .charm section .relation {
    flex-direction: column;
    gap: 8px;
    margin-top: 20px;
  }
}
.charm section .relation li {
  width: 50%;
}
@media all and (max-width: 896px) {
  .charm section .relation li {
    width: auto;
  }
}
.charm section .relation a {
  display: flex;
  flex-direction: column;
  position: relative;
  height: 100%;
  margin-inline: auto;
  padding: 14px 40px;
  justify-content: center;
  align-items: center;
  border-radius: 4px;
  background: #076abc;
  color: #fff;
  text-align: center;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 1px;
}
@media all and (max-width: 896px) {
  .charm section .relation a {
    max-width: 320px;
  }
}
.charm section .relation a.book {
  background: #00ae91;
}
.charm section .relation a::after {
  content: "";
  position: absolute;
  right: 20px;
  width: 16px;
  height: 16px;
  background: url(../images/common/ico_arrow.svg) no-repeat center/cover;
  filter: brightness(0) invert(1);
}
@media all and (max-width: 896px) {
  .charm section .relation a::after {
    width: 9px;
    height: 9px;
  }
}
.charm section.tambara {
  position: relative;
}
.charm section.tambara::before, .charm section.tambara::after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 110px;
  height: 126px;
  background: url(../images/common/ico_snowflake.svg) no-repeat center/cover;
  animation: rotation 15s linear infinite;
}
.charm section.tambara::before {
  top: -60px;
  left: -20px;
}
.charm section.tambara::after {
  bottom: -40px;
  right: -10px;
}

.faq {
  position: relative;
  padding-block: 30px 40px;
  background: #def8fd;
}
.faq::before, .faq::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 47px;
  background: url(../images/common/bg_wave.webp) no-repeat center/100% 47px;
}
.faq::before {
  top: -47px;
  transform: scaleY(-1);
}
.faq::after {
  bottom: -47px;
}
.faq ul {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 24px;
  line-height: 1.8;
}
.faq ul li {
  padding: 20px 20px 10px;
  border-radius: 4px;
  background: #fff;
}
.faq .acd-label {
  display: block;
  position: relative;
  padding: 0 26px;
  cursor: pointer;
}
.faq .acd-label::before {
  content: "Q";
  position: absolute;
  top: -3px;
  left: 0;
  color: #009be9;
  font-family: "Inter", sans-serif;
  font-size: 2rem;
  font-weight: 800;
}
.faq .acd-label::after {
  content: "";
  position: absolute;
  top: calc(50% - 2px);
  right: 3px;
  width: 10px;
  height: 10px;
  border-top: 2px solid #009be9;
  border-right: 2px solid #009be9;
  border-top-right-radius: 2px;
  transform: rotate(135deg);
  transition: 0.3s;
}
.faq .acd-content {
  position: relative;
  height: 0;
  margin-top: 10px;
  padding-left: 26px;
  border-top: 1px solid #cddbe0;
  opacity: 0;
  transition: 0.3s;
  visibility: hidden;
}
.faq .acd-content::before {
  content: "A";
  position: absolute;
  top: 8px;
  left: 0;
  color: #ea0029;
  font-family: "Inter", sans-serif;
  font-size: 2rem;
  font-weight: 800;
  opacity: 0;
  transition: 0.5s;
}
.faq .acd-content img {
  margin-top: 16px;
}
.faq .acd-check {
  display: none;
}
.faq .acd-check:checked + .acd-label::after {
  top: calc(50% - 6px);
  transform: rotate(-45deg);
}
.faq .acd-check:checked + .acd-label + .acd-content {
  height: auto;
  opacity: 1;
  padding-block: 10px;
  visibility: visible;
}
.faq .acd-check:checked + .acd-label + .acd-content::before {
  opacity: 1;
}
.faq .anime {
  position: absolute;
  top: -85px;
  left: 0;
  width: 100%;
  height: 200px;
  overflow: hidden;
}
.faq .anime .tree {
  position: absolute;
  top: 30px;
  left: 140px;
  width: 70px;
}
@media all and (max-width: 896px) {
  .faq .anime .tree {
    left: 95px;
    width: 38px;
  }
}
.faq .anime .skier {
  position: absolute;
  top: 0;
  left: -110px;
  width: 110px;
}
@media all and (max-width: 896px) {
  .faq .anime .skier {
    width: 80px;
  }
}
.faq .anime .skier.is-visible {
  animation: skier04 0.65s cubic-bezier(0.22, 1, 0.36, 1) 1s forwards;
}

html[lang=zh-cmn-Hant] .faq .acd-label::before {
  content: "問";
}
html[lang=zh-cmn-Hant] .faq .acd-content::before {
  content: "答";
}

/*# sourceMappingURL=top.css.map */
