/* -----------------------------------------------
  Variables
--------------------------------------------------*/
:root {
  --color-text: #000;
  --color-bg: #fff;
  --color-base: #0091d7;
  --color-link: #176ca9;
  --color-hover: rgb(36.5, 183.8604651163, 255);
  --color-visited: #176ca9;
  --color-error: #dd0000;
  --swiper-theme-color: #0091d7;
}

/* -----------------------------------------------
  Mixins
--------------------------------------------------*/
*,
*::before,
*::after {
  box-sizing: border-box;
  overflow-wrap: anywhere;
}

.header__logo {
  display: none;
}

.header__text {
  color: #fff;
}

.header {
  z-index: 7;
}

.local-navigation {
  z-index: 6;
}

.keyvisual {
  z-index: 5;
}

.precious {
  z-index: 4;
}

.wellness {
  z-index: 3;
}

.stays {
  z-index: 2;
}

.activity {
  z-index: 1;
}

.fadeInCamp {
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.fadeInCamp.visible {
  opacity: 1;
}

.keyvisual {
  position: relative;
  background: url("../../images/new/bg_header.webp");
  background-size: cover;
  background-position: top center;
  height: 56.8148148148vw;
}
.keyvisual__logo {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  row-gap: min(0.5rem, 0.3703703704vw);
  width: min(21.7rem, 16.0740740741vw);
  position: absolute;
  top: 30vw;
  left: calc(50% + 18.5185185185vw);
}
.keyvisual__logo .title {
  color: #fff;
  font-size: min(1.24rem, 0.9185185185vw);
  margin-top: -1.75em;
  margin-left: min(4.2rem, 3.1111111111vw);
}
.keyvisual__catch {
  color: #fff;
  font-size: min(1.8rem, 1.3333333333vw);
  font-weight: 600;
  position: absolute;
  top: 34.8148148148vw;
  right: calc(50% + 18.5185185185vw);
}
.keyvisual__text {
  position: absolute;
}
.keyvisual__text.--left {
  width: min(23.75rem, 17.5925925926vw);
  height: min(14.3rem, 10.5925925926vw);
  top: min(20.9rem, 15.4814814815vw);
  right: 50%;
}
.keyvisual__text.--right {
  width: min(28.05rem, 20.7777777778vw);
  height: min(14.25rem, 10.5555555556vw);
  top: min(28.55rem, 21.1481481481vw);
  left: 50%;
}
.keyvisual__text .text-en {
  position: absolute;
}
.keyvisual__text .text-en.--normal {
  opacity: 0.68;
}
.keyvisual__text .text-en.--overlay {
  mix-blend-mode: overlay;
  opacity: 0.65;
}
.keyvisual__text .text-en.--color-burn {
  mix-blend-mode: color-burn;
  opacity: 0.64;
}
.keyvisual__text .text-en.--multiply {
  mix-blend-mode: multiply;
  opacity: 0.84;
}
.keyvisual__text .text-en.--lighten {
  mix-blend-mode: lighten;
  opacity: 0.64;
}
.keyvisual__text .text-en.--heart {
  width: min(23.75rem, 17.5925925926vw);
  top: 0;
  left: 0;
}
.keyvisual__text .text-en.--beat {
  width: min(19.25rem, 14.2592592593vw);
  bottom: 0;
  right: 0;
}
.keyvisual__text .text-en.--resort {
  width: min(28.05rem, 20.7777777778vw);
  top: 0;
  left: 0;
}
.keyvisual__text .text-en.--drive {
  width: min(21.55rem, 15.962962963vw);
  bottom: 0;
  left: 0;
}

.local-navigation {
  position: absolute;
  right: min(1rem, 0.7407407407vw);
  top: min(45.5rem, 33.7037037037vw);
  margin-block: auto;
  height: fit-content;
}
.local-navigation ul {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  align-items: center;
}
.local-navigation .lnavi-link {
  color: #fff;
  text-decoration: none;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  column-gap: min(1rem, 0.7407407407vw);
  width: min(5rem, 3.7037037037vw);
  height: min(5rem, 3.7037037037vw);
}
.local-navigation .lnavi-link .lnavi-text {
  font-size: min(1.6rem, 1.1851851852vw);
  font-weight: bold;
  line-height: 1.3;
  text-align: right;
  position: absolute;
  right: min(7rem, 5.1851851852vw);
  width: min(15rem, 11.1111111111vw);
  opacity: 0;
  visibility: hidden;
}
.local-navigation .lnavi-link .lnavi-text,
.local-navigation .lnavi-link .c-icon {
  margin: 0;
  transition: 0.3s;
}
.local-navigation .lnavi-link::after {
  content: "";
  position: absolute;
  right: min(1.5rem, 1.1111111111vw);
  margin-block: 0;
  width: min(0.8rem, 0.5925925926vw);
  height: min(0.8rem, 0.5925925926vw);
  background: var(--color-base);
  border-radius: 50%;
  transform: translatex(100%);
  opacity: 0;
  transition: 0.3s;
}
.local-navigation .lnavi-link:hover .c-icon {
  transform: translatex(min(-2rem, -1.4814814815vw));
}
.local-navigation .lnavi-link:hover::after,
.local-navigation .lnavi-link:hover .lnavi-text {
  opacity: 1;
  visibility: visible;
}
.local-navigation .c-icon {
  fill: #fff;
}
.local-navigation .c-icon.icon-admission {
  width: min(3.1rem, 2.2962962963vw);
  height: min(2.4rem, 1.7777777778vw);
}
.local-navigation .c-icon.icon-contact {
  width: min(3rem, 2.2222222222vw);
  height: min(2rem, 1.4814814815vw);
}
.local-navigation .c-icon.icon-fee {
  width: min(2rem, 1.4814814815vw);
  height: min(2.3rem, 1.7037037037vw);
}

.precious {
  position: relative;
  background: url("../../images/new/bg_content.webp");
  background-size: cover;
  background-position: bottom center;
  height: min(130rem, 96.2962962963vw);
  padding-top: min(6.5rem, 4.8148148148vw);
  color: #fff;
  text-align: center;
}
.precious__main {
  width: min(29.5rem, 21.8518518519vw);
  margin-inline: auto;
  margin-bottom: min(3rem, 2.2222222222vw);
}
.precious__title {
  font-size: min(2.4rem, 1.7777777778vw);
  margin-bottom: min(3rem, 2.2222222222vw);
  text-shadow: 0 0 12px rgba(61, 85, 114, 0.2);
}
.precious__text {
  font-size: min(1.8rem, 1.3333333333vw);
  line-height: 2.3;
  text-shadow: 0 0 6px #3d5572;
}
.precious__text:last-child {
  margin-bottom: 0;
}
.precious__text.u-text-sm {
  font-size: min(1.5rem, 1.1111111111vw);
  line-height: inherit;
}
.precious__feature {
  position: relative;
  width: min(68.7rem, 50.8888888889vw);
  margin-inline: auto;
}
.precious__link {
  position: absolute;
  text-decoration: none;
  width: fit-content;
}
.precious__link:any-link {
  color: #fff;
}
.precious__link.to-wellness {
  text-align: center;
  margin-inline: auto;
  top: min(12.7rem, 9.4074074074vw);
  inset-inline: 0;
  padding-left: min(0.8rem, 0.5925925926vw);
}
.precious__link.to-wellness .precious__text {
  font-size: min(1.8rem, 1.3333333333vw);
  margin-top: min(1.7rem, 1.2592592593vw);
}
.precious__link.to-stay {
  text-align: left;
  margin-inline: auto;
  top: min(42rem, 31.1111111111vw);
  left: min(15.2rem, 11.2592592593vw);
}
.precious__link.to-stay .precious__text {
  margin-left: min(-1rem, -0.7407407407vw);
  text-align: right;
}
.precious__link.to-stay .precious__caption {
  margin-left: min(-1.5rem, -1.1111111111vw);
  text-align: right;
}
.precious__link.to-activity {
  text-align: left;
  margin-inline: auto;
  top: min(42rem, 31.1111111111vw);
  right: min(13.5rem, 10vw);
}
.precious__link.to-activity .precious__label {
  margin-left: min(1rem, 0.7407407407vw);
}
.precious__link.to-ride {
  text-align: center;
  margin-inline: auto;
  top: min(28.8rem, 21.3333333333vw);
  inset-inline: 0;
}
.precious__link.to-ride .precious__label {
  font-size: min(4.1rem, 3.037037037vw);
}
.precious__link.to-ride .precious__text {
  font-size: min(1.8rem, 1.3333333333vw);
  margin-top: min(1.7rem, 1.2592592593vw);
}
.precious__label {
  font-family: "Funnel Display", sans-serif;
  font-size: min(3.6rem, 2.6666666667vw);
  letter-spacing: -0.03em;
  line-height: 1;
  display: block;
}
.precious__caption {
  font-size: min(1.6rem, 1.1851851852vw);
  font-weight: bold;
  font-feature-settings: "palt";
  line-height: 1.5;
  margin-top: min(1.2rem, 0.8888888889vw);
  display: block;
}
.precious__image {
  position: absolute;
  right: 0;
  top: min(32rem, 23.7037037037vw);
  width: min(36rem, 26.6666666667vw);
}

.section__overview p {
  line-height: 2.3;
}
.section__overview .c-button__link {
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-inline: min(2.5rem, 1.8518518519vw);
  width: min(28rem, 20.7407407407vw);
  height: min(4.8rem, 3.5555555556vw);
  border: 1px solid;
  border-radius: min(2.4rem, 1.7777777778vw);
  margin-top: min(3.5rem, 2.5925925926vw);
}
.section__overview .c-button__link .c-icon {
  width: min(1.5rem, 1.1111111111vw);
  height: min(1.1rem, 0.8148148148vw);
  margin-left: auto;
  margin-right: 0;
}

.section__title {
  width: min(34.5rem, 25.5555555556vw);
}

.roop-slide-gallery:not(.is-vertical) {
  display: flex;
  align-items: center;
  overflow: hidden;
}
.roop-slide-gallery:not(.is-vertical) .slide-item {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}
.roop-slide-gallery:not(.is-vertical) .slide-item li {
  width: min(63rem, 46.6666666667vw);
  height: min(35rem, 25.9259259259vw);
  overflow: hidden;
}
.roop-slide-gallery:not(.is-vertical) .slide-item li img {
  border-left: 1px solid #fff;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.roop-slide-gallery.is-left .slide-item {
  animation: slide-to-left 60s infinite linear 1s both;
}
.roop-slide-gallery.is-right .slide-item {
  animation: slide-to-right 60s infinite linear 1s both;
}
.roop-slide-gallery.is-vertical .slide-item {
  animation: loop-slide-vertical 30s infinite linear 1s both;
}
.roop-slide-gallery.is-vertical .slide-item li img {
  border-bottom: 1px solid #fff;
}

@keyframes slide-to-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes slide-to-right {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0);
  }
}
@keyframes loop-slide-vertical {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-100%);
  }
}
.wellness {
  position: relative;
  color: #fff;
  background: url("../../images/new/bg_wellness.webp");
  background-size: cover;
  background-position: bottom center;
  padding-top: 21.1111111111vw;
  padding-bottom: 8.1481481481vw;
  margin-top: -12.962962963vw;
}
.wellness .section__div {
  width: 63.3333333333vw;
  margin-left: auto;
}
.wellness .section__title {
  margin-top: min(5rem, 3.7037037037vw);
}
.wellness .section__overview a:any-link {
  color: #fff;
}
.wellness .section__overview .c-button__link .c-icon {
  fill: #fff;
}
.wellness .section__overview .c-button__link:hover {
  background: #fff;
  border-color: #fff;
  color: var(--color-text);
}
.wellness .section__overview .c-button__link:hover .c-icon {
  fill: var(--color-text);
}

.stays {
  position: relative;
  color: #fff;
  background: url("../../images/new/bg_stay.webp");
  background-size: cover;
  background-position: bottom center;
  padding-bottom: 11.1111111111vw;
  margin-top: -2.2222222222vw;
}
.stays__gallery {
  width: 63.3333333333vw;
  margin-left: auto;
}
.stays .section__overview {
  width: min(115rem, 85.1851851852vw);
  margin-inline: auto;
}
.stays .section__overview a:any-link {
  color: #fff;
}
.stays .section__overview .c-button__link .c-icon {
  fill: #fff;
}
.stays .section__overview .c-button__link:hover {
  background: #fff;
  border-color: #fff;
  color: var(--color-text);
}
.stays .section__overview .c-button__link:hover .c-icon {
  fill: var(--color-text);
}
.stays .section__title {
  margin-top: min(1.5rem, 1.1111111111vw);
  margin-bottom: min(3rem, 2.2222222222vw);
}

.activity {
  position: relative;
  color: #fff;
  background: url("../../images/new/bg_activity.webp");
  background-size: cover;
  background-position: bottom center;
  padding-bottom: 7.4074074074vw;
  margin-top: -2.2222222222vw;
  overflow: hidden;
}
.activity__inner {
  width: min(115rem, 85.1851851852vw);
  margin-inline: auto;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-direction: row-reverse;
}
.activity__gallery {
  width: min(44.7rem, 33.1111111111vw);
  height: 57.037037037vw;
}
.activity .section__title {
  margin-bottom: min(3rem, 2.2222222222vw);
}

.spot {
  position: relative;
  padding-top: min(17.5rem, 12.962962963vw);
  padding-bottom: min(10rem, 7.4074074074vw);
  margin-top: -2.2222222222vw;
  overflow: hidden;
}
.spot__inner {
  width: min(115rem, 85.1851851852vw);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: min(10rem, 7.4074074074vw);
}
.spot__gallery:not(:last-child) {
  margin-bottom: min(6rem, 4.4444444444vw);
}
.spot__gallery figcaption {
  font-size: min(1.4rem, 1.037037037vw);
  line-height: 1;
  letter-spacing: 0.3em;
  width: fit-content;
  margin-top: 1em;
  margin-inline: auto;
  padding-inline: 1em;
  border-bottom: 1px solid;
}
.spot__gallery h3 {
  font-size: min(2.4rem, 1.7777777778vw);
  text-align: center;
  margin: min(2rem, 1.4814814815vw) auto;
}
.spot__gallery h3 img {
  width: min(13.75rem, 10.1851851852vw);
}
.spot__gallery p {
  color: #727c81;
  text-align: center;
}
.spot .section__div {
  flex: 1;
}
.spot .section__overview {
  width: fit-content;
  margin-inline: auto;
  margin-bottom: min(10rem, 7.4074074074vw);
}
.spot .section__overview p {
  font-size: min(1.8rem, 1.3333333333vw);
}
.spot .section__overview .c-button__link {
  color: var(--color-text);
}
.spot .section__overview .c-button__link .c-icon {
  fill: #8c8f99;
}
.spot .section__overview .c-button__link:hover {
  background: var(--color-text);
  border-color: var(--color-text);
  color: #fff;
}
.spot .section__overview .c-button__link:hover .c-icon {
  fill: #fff;
}
.spot .section__title {
  margin-bottom: min(3rem, 2.2222222222vw);
}

.content-under {
  background: url("../../images/new/bg_content-02.webp");
  background-size: cover;
  background-position: top center;
}

.ride {
  padding-bottom: min(22.5rem, 16.6666666667vw);
}
.ride .section__overview {
  max-width: min(115rem, 85.1851851852vw);
  margin-inline: auto;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}
.ride .section__title,
.ride .section__overview p {
  margin-block: 0;
}
.ride .section__overview p {
  margin-left: min(-7rem, -5.1851851852vw);
  margin-bottom: min(9rem, 6.6666666667vw);
}
.ride__gallery {
  position: relative;
}
.ride__gallery-link {
  color: var(--color-text);
  text-decoration: none;
}
.ride__gallery-caption {
  position: absolute;
  left: 0;
  bottom: 0;
  color: #fff;
  text-align: center;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: 0.3s;
  z-index: 1;
}
.ride__gallery-caption h3 {
  font-size: min(2.4rem, 1.7777777778vw);
  font-weight: normal;
  width: fit-content;
  margin-bottom: min(3.5rem, 2.5925925926vw);
  margin-left: min(2.3rem, 1.7037037037vw);
}
.ride__gallery-caption h3 .c-en {
  display: block;
  font-size: min(1.3rem, 0.962962963vw);
  margin-top: min(1.5rem, 1.1111111111vw);
}
.ride__gallery-caption .c-icon {
  fill: #fff;
  width: min(2.3rem, 1.7037037037vw);
  height: min(1.7rem, 1.2592592593vw);
  margin: 0;
  position: relative;
  right: min(-2rem, -1.4814814815vw);
}
.ride__gallery-image {
  overflow: hidden;
}
.ride__gallery-image img {
  transition: 0.3s;
}
.ride .swiper-wrapper {
  align-items: center;
  margin-left: -4%;
}
.ride .swiper-slide {
  width: 28.5714285714% !important;
}
.ride .swiper-slide-active {
  width: 35.5714285714% !important;
  margin-inline: 0.5%;
  -webkit-mask-image: url("../../images/new/mask_ride.svg");
          mask-image: url("../../images/new/mask_ride.svg");
  -webkit-mask-size: cover;
          mask-size: cover;
}
.ride__gallery-item {
  position: relative;
}
.ride__gallery-item figcaption {
  color: inherit;
  font-size: min(1.8rem, 1.3333333333vw);
  text-align: center;
}
.ride__gallery-item.swiper-slide-active .ride__gallery-link::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 21%, rgba(0, 0, 0, 0.65) 100%);
}
.ride__gallery-item.swiper-slide-active .ride__gallery-link:hover .ride__gallery-image img {
  transform: scale(1.1);
}
.ride__gallery-item.swiper-slide-active .ride__gallery-caption {
  opacity: 1;
}
.ride__gallery-item.swiper-slide-active figcaption {
  display: none;
}
.ride .m-slider__btns {
  position: absolute;
  inset: 0;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
}
.ride .m-slider__btns button {
  position: relative;
  width: min(5.6rem, 4.1481481481vw);
  height: min(5.6rem, 4.1481481481vw);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.ride .m-slider__btns button .c-icon {
  fill: #5e6270;
  width: min(1.9rem, 1.4074074074vw);
  height: min(1.4rem, 1.037037037vw);
  margin: 0;
}
.ride .m-slider__btn--prev {
  left: calc(50vw - (18.2857142857% + min(5.6rem, 4.1481481481vw)));
}
.ride .m-slider__btn--next {
  right: calc(50vw - (18.2857142857% + min(5.6rem, 4.1481481481vw)));
}

.bottom__inner {
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.bottom__div {
  position: relative;
  flex: 1;
}
.bottom__link-bg {
  transition: 0.3s;
}
.bottom__link-label {
  background: #fff;
  padding-inline: min(4.5rem, 3.3333333333vw);
  font-size: min(2rem, 1.4814814815vw);
  line-height: 1;
  height: min(7rem, 5.1851851852vw);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  column-gap: min(1.5rem, 1.1111111111vw);
}
.bottom__link-label .c-en {
  font-size: min(1.3rem, 0.962962963vw);
}
.bottom__link-label .c-icon {
  fill: #8c8f99;
  width: min(1.6rem, 1.1851851852vw);
  height: min(1.1rem, 0.8148148148vw);
  margin: 0;
}
.bottom__link-image {
  position: absolute;
  bottom: 0;
}
.bottom__link-image.--first {
  left: calc(50vw - min(62.7rem, 46.4444444444vw));
  width: min(25.4rem, 18.8148148148vw);
}
.bottom__link-image.--last {
  right: calc(50vw - min(62.7rem, 46.4444444444vw));
  width: min(22.8rem, 16.8888888889vw);
}
.bottom__link {
  text-decoration: none;
}
.bottom__link:any-link {
  color: var(--color-text);
}
.bottom__link:hover {
  color: var(--color-link);
}
.bottom__link:hover .bottom__link-bg {
  opacity: 0.6;
}
.bottom__link:hover .c-icon {
  fill: var(--color-link);
}
.bottom .sightseeing .bottom__link-label {
  flex-direction: row-reverse;
}
.bottom .sightseeing .bottom__link-label::before {
  position: relative;
  left: min(4.5rem, 3.3333333333vw);
  content: "";
  width: 1px;
  height: min(4.7rem, 3.4814814815vw);
  background: #d7d8dc;
}

.footer-upper {
  background: #1688bd;
  background: url("/themes/main/images/new/bg_footer.webp");
  background-size: cover;
  background-position: bottom center;
}

.news {
  padding-top: min(14rem, 10.3703703704vw);
  padding-bottom: min(1rem, 0.7407407407vw);
  color: #fff;
}
.news__inner {
  width: min(115rem, 85.1851851852vw);
  margin-inline: auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.news .section__div {
  flex: 1;
}
.news .section__div:first-child {
  flex: 0 0 min(18.3rem, 13.5555555556vw);
  max-width: min(18.3rem, 13.5555555556vw);
}
.news .section__title h2 {
  font-size: min(4rem, 2.962962963vw);
  font-weight: 300;
  margin-block: 0;
}
.news .article {
  font-size: min(1.6rem, 1.1851851852vw);
}
.news .article__link {
  color: #fff;
  text-decoration: none;
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  column-gap: min(3rem, 2.2222222222vw);
  padding-bottom: min(2rem, 1.4814814815vw);
  border-bottom: 1px solid #fff;
}
.news .article__link .c-icon {
  flex-shrink: 0;
  margin-left: auto;
  margin-right: min(1rem, 0.7407407407vw);
  fill: #fff;
  opacity: 0;
}
.news .article__link:hover .c-icon {
  opacity: 1;
}
.news .article:not(:first-child) {
  padding-top: min(2rem, 1.4814814815vw);
}
.news .article__date {
  flex-shrink: 0;
  letter-spacing: min(0.1rem, 0.0740740741vw);
}
.news .article__title {
  font-size: min(1.6rem, 1.1851851852vw);
  line-height: 1.5;
  margin-block: 0;
}