@charset "UTF-8";
body {
  line-height: 1.5;
}

.iglogo {
  width: 40px;
  height: 40px;
}
.iglogo__flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

#header {
  position: fixed;
  width: 100%;
  margin: 0 auto;
  z-index: 100;
}

.header {
  display: flex;
  justify-content: space-between;
  position: relative;
  opacity: 0;
  animation: 1s fadeup ease-in-out forwards;
  /* ナビゲーションリスト */
  /* 予約ボタン */
}
.header__logo {
  padding: 16px 16px 16px 80px;
  display: block;
}
.header__nav {
  padding-right: 80px;
}
.header__img {
  display: block;
  margin-top: 8px;
}
.header__img-sp {
  display: none;
}
.header__ul {
  display: flex;
  color: #fff;
}
.header__li {
  display: block;
  cursor: pointer;
  color: #fff;
  padding: 29px;
  position: relative;
}
.header__li::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background-color: #fff;
  transition: width 0.4s ease;
}
.header__li:hover::after {
  width: 100%;
}
.header__reserve {
  border: 2px solid #fff;
  background-color: rgba(255, 255, 255, 0.3);
  border-radius: 50px;
  display: block;
  padding: 13px 24px;
  margin: 13px 0px 13px 26px;
}
.header__reserve:hover {
  background-color: rgba(179, 211, 229, 0.8);
  color: #002940;
  transition: 0.3s;
}

.hamburger {
  display: none;
}

.hero {
  width: 100%;
  height: 100vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  left: 0;
  z-index: -2;
  opacity: 1;
  transition: opacity 1s ease;
}
.hero__catch {
  line-height: 1.6;
  font-size: 40px;
  color: #fff;
  position: absolute;
  left: 80px;
  bottom: 72px;
}

.hero__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: 64% 24%;
  opacity: 0;
  transition: opacity 1s ease; /* スムーズな切り替え */
}

.hero__image.image1 {
  opacity: 1; /* 最初の画像を表示 */
}

@keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.praymessage {
  width: calc(100% - 400px);
  margin: 0 auto;
  line-height: 2;
}

.sun {
  display: block;
  width: 100%;
  height: 320px; /* セクションの高さ */
  margin-top: 80px;
  background-image: url(images/img_para.jpg);
  background-size: cover;
  background-attachment: fixed; /* パララックス効果 */
  background-repeat: no-repeat;
  background-position: center;
}

.story {
  margin-top: 160px;
}
.story__contentred,
.story__contentview {
  display: flex;
  gap: 80px;
}
.story__imageroom {
  display: block;
  width: 51%;
}
.story__textblock {
  width: 40%;
  position: relative;
}
.story__imagestory,
.story__shapebig,
.story__shapesmall {
  position: absolute;
}
.story__imagestory {
  top: 0;
  right: 0px;
}
.story__shapebig {
  top: 132px;
  left: -115px;
}
.story__shapesmall {
  top: -78px;
  right: 0;
}
.story__heading {
  font-size: 40px;
  line-height: 1.5;
}
.story__ptop {
  margin-top: 80px;
  line-height: 2;
}
.story__pmiddle,
.story__pbottom {
  margin-top: 32px;
  line-height: 2;
}
.story__contentview {
  margin-top: 160px;
}
.story__p {
  line-height: 2;
}
.story__text {
  padding-left: 80px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.story__button {
  width: 100%;
  background-color: #c30900;
  color: #fff;
  border: 0px;
  margin-top: 40px;
  margin-bottom: 80px;
  font-family: "Shippori Mincho";
  box-shadow: 0 2px 0 #a00800;
  font-size: 18px;
  border-radius: 32px;
}
.story__button:hover {
  cursor: pointer;
  transition: 0.2s;
  background-color: #d72219;
  transform: translateY(2px);
  box-shadow: 0 0px 0 #a00800;
}
.story__buttona {
  padding: 18px 0;
  display: block;
}

.bond {
  overflow-x: hidden;
  box-sizing: border-box;
  max-width: 100%;
  margin-top: 160px;
  position: relative;
}
.bond__h3 {
  display: flex;
}
.bond__h3::before {
  content: "";
  display: block;
  width: 80px;
  border-top: 1px solid #333;
  margin-top: 8px;
}
.bond__h2 {
  font-size: 40px;
  line-height: 1.5;
}
.bond__h {
  display: flex;
  gap: 16px;
  flex-direction: column-reverse;
}
.bond__p {
  margin-top: 48px;
  line-height: 1.5;
}
.bond__wrap {
  padding: 0 80px;
  width: calc(58% - 160px);
  position: relative;
}
.bond__boxsmall {
  position: absolute;
  top: 0;
  right: 0px;
}
.bond__boxbig {
  position: absolute;
  top: 80px;
  right: 400px;
}
.bond__text {
  position: absolute;
  top: 0px;
  right: 0;
}
.bond__slide {
  margin-top: 64px;
  display: flex;
  gap: 32px;
  width: 100%;
  max-width: 100%;
}

.rule {
  margin-top: 160px;
  position: relative;
}
.rule__h2 {
  font-size: 40px;
  line-height: 1.5;
  text-align: center;
}
.rule__h3 {
  margin-bottom: 16px;
}
.rule__box {
  position: absolute;
  top: 13px;
  left: 30%;
}
.rule__box2 {
  position: absolute;
  top: 13px;
  right: 30%;
}
.rule__explain {
  display: flex;
  justify-content: space-between;
  gap: 80px;
  margin-top: 64px;
}
.rule__left {
  width: 41%;
  padding-left: 80px;
}
.rule__right {
  width: 46%;
}
.rule__time {
  display: flex;
  align-items: center;
  gap: 16px;
}
.rule__time span {
  font-size: 24px;
}
.rule__starttime,
.rule__endtime,
.rule__p,
.rule__checkout {
  font-size: 56px;
}
.rule__flex {
  display: flex;
  margin-top: 48px;
  gap: 120px;
}
.rule__button {
  padding: 18px;
  width: 100%;
  background-color: #679fbe;
  color: #fff;
  border: 0px;
  font-family: "Shippori Mincho";
  box-shadow: 0 2px 0 #3e7d9f;
  font-size: 18px;
  border-radius: 32px;
  margin-top: 80px;
}
.rule__button:hover {
  cursor: pointer;
  transition: 0.2s;
  background-color: #7cb5d4;
  transform: translateY(2px);
  box-shadow: 0 0px 0 #3e7d9f;
}

.access {
  margin-top: 160px;
  position: relative;
}
.access__h2 {
  font-size: 40px;
  line-height: 1.5;
  text-align: center;
}
.access__address {
  margin-top: 64px;
  text-align: center;
  line-height: 2;
  text-align: center;
  position: relative;
}
.access__address::after {
  z-index: -2;
  position: absolute;
  content: "";
  top: 300px;
  display: block;
  width: 100%;
  background-color: #f0f0f0;
  height: 600px;
}
.access__map {
  display: block;
  width: 70%;
  margin: 40px auto 0 auto;
}
.access__boxbig {
  position: absolute;
  top: -32px;
  left: 30%;
}
.access__boxsmall {
  position: absolute;
  top: 10%;
  right: 30%;
}
.access__bottom {
  width: 70%;
  margin: 0 auto;
}
.access__h3 {
  font-size: 24px;
  margin-top: 40px;
}
.access__p {
  line-height: 1.5;
  margin-top: 24px;
}

.reserve {
  margin-top: 240px;
  position: relative;
}
.reserve__h2 {
  font-size: 40px;
  text-align: center;
}
.reserve__h2::before {
  content: "";
  display: block;
  width: 35px;
  height: 35px;
  background-color: #b3d3e5;
  position: relative;
  position: absolute;
  left: 32%;
  top: 10px;
  animation: floatButton 4s ease-in-out infinite;
}
.reserve__h2::after {
  content: "";
  display: block;
  width: 35px;
  height: 35px;
  background-color: #b3d3e5;
  position: relative;
  position: absolute;
  right: 32%;
  top: 10px;
  animation: floatButton 4s ease-in-out infinite;
}
.reserve__button {
  display: block;
  width: 50%;
  margin: 80px auto 0 auto;
  background-color: #679fbe;
  color: #fff;
  border: 0px;
  font-family: "Shippori Mincho";
  box-shadow: 0 2px 0 #3e7d9f;
  font-size: 18px;
  border-radius: 32px;
}
.reserve__button:hover {
  cursor: pointer;
  transition: 0.2s;
  background-color: #7cb5d4;
  transform: translateY(2px);
  box-shadow: 0 0px 0 #3e7d9f;
}
.reserve__buttona {
  display: block;
  padding: 18px 0;
}

.footer {
  background-color: #788ca7;
  color: #fff;
  padding: 80px;
  margin-top: 160px;
}
.footer__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.footer__ul {
  display: flex;
}
.footer__li {
  padding: 14px 24px;
}
.footer__bottom {
  margin-top: 48px;
  line-height: 1.5;
}
.footer__lisence1 {
  margin-top: 24px;
}
.footer__lisence2 {
  margin-top: 8px;
}

.fade-in-section {
  opacity: 0; /* 初期状態：透明 */
  transform: translateY(20px); /* 少し下に位置する */
  transition: opacity 0.8s ease-out, transform 0.8s ease-out; /* スムーズなアニメーション */
}

.fade-in-section.show {
  opacity: 1;
  transform: translateY(0);
}

html {
  scroll-behavior: smooth;
}

.bond {
  overflow: hidden;
  width: 1640px;
  position: relative;
}

.spot {
  width: 100%;
  display: flex;
  gap: 24px;
  margin-top: 200px;
}
.spot__middle {
  width: 33%;
}
.spot__left,
.spot__right {
  width: 35%;
  height: 849px;
}
.spot__h2 {
  writing-mode: vertical-rl;
  font-size: 40px;
  letter-spacing: 0.15em;
  margin: 40px auto 0 auto;
}
.spot__boxsmall {
  position: absolute;
  top: 0;
  left: 40%;
}
.spot__boxbig {
  position: absolute;
  top: 40%;
  right: 40%;
}
.spot__p {
  margin-top: 120px;
  line-height: 1.5;
}
.spot__button {
  width: 100%;
  background-color: #63bfbf;
  color: #fff;
  border: 0px;
  margin-top: 40px;
  font-family: "Shippori Mincho";
  box-shadow: 0 2px 0 #3f9494;
  font-size: 18px;
  border-radius: 32px;
}
.spot__button:hover {
  cursor: pointer;
  transition: 0.2s;
  background-color: #7dd9d9;
  transform: translateY(2px);
  box-shadow: 0 0px 0 #3f9494;
}
.spot__buttona {
  padding: 18px 0;
  display: block;
}
.spot__slide-wrapper {
  display: none;
}
.spot__left {
  overflow: hidden;
  height: 849px;
  position: relative;
}
.spot__scroll-container {
  display: flex;
  flex-direction: column;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
}
.spot__scroll-container img {
  display: block;
}
.spot__right {
  overflow: hidden;
  height: 849px;
  position: relative;
}
.spot__scroll-containerright {
  display: flex;
  flex-direction: column;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
}
.spot__scroll-containerright img {
  display: block;
}
.spot__slide {
  display: none;
}

@media (max-width: 1024px) {
  .header__li {
    padding: 26px 20px;
  }
  .header__nav {
    padding-right: 40px;
  }
  .header__logo {
    padding: 16px 16px 16px 40px;
  }
  .hero__catch {
    font-size: 40px;
    left: 40px;
    bottom: 40px;
  }
  .praymessage {
    width: 80%;
  }
  .story__imageroom {
    width: 48%;
    height: -moz-fit-content;
    height: fit-content;
  }
  .story__contentred,
  .story__contentview {
    gap: 40px;
  }
  .story__textblock {
    width: calc(50% - 40px);
  }
  .story__imagestory {
    top: 0;
    right: 0;
  }
  .story__shapebig {
    top: 50px;
    left: -100px;
  }
  .story__shapesmall {
    top: -78px;
    right: 0;
  }
  .story__heading {
    font-size: 32px;
  }
  .story__ptop {
    margin-top: 40px;
    line-height: 2;
  }
  .story__pmiddle,
  .story__pbottom {
    margin-top: 32px;
    line-height: 2;
  }
  .story__contentview {
    margin-top: 80px;
  }
  .story__imageview {
    width: 50%;
    height: -moz-fit-content;
    height: fit-content;
  }
  .story__text {
    padding-left: 40px;
  }
  .bond {
    margin-top: 80px;
  }
  .bond__h2 {
    font-size: 32px;
  }
  .bond__p {
    margin-top: 40px;
    line-height: 1.5;
  }
  .bond__wrap {
    padding: 0 40px;
    width: calc(60% - 40px);
  }
  .bond__boxsmall {
    position: absolute;
    top: 0;
    right: 0px;
  }
  .bond__boxbig {
    display: none;
  }
  .bond__text {
    right: 0;
    top: 0px;
  }
  .rule {
    margin-top: 160px;
  }
  .rule__h2 {
    font-size: 32px;
  }
  .rule__box {
    position: absolute;
    top: 5px;
  }
  .rule__box2 {
    position: absolute;
    top: 5px;
  }
  .rule__explain {
    gap: 40px;
  }
  .rule__left {
    width: 48%;
    padding-left: 40px;
  }
  .rule__right {
    width: 46%;
    height: -moz-fit-content;
    height: fit-content;
  }
  .rule__flex {
    display: flex;
    margin-top: 48px;
    gap: 40px;
  }
  .rule__starttime,
  .rule__endtime,
  .rule__p,
  .rule__checkout {
    font-size: 40px;
  }
  .rule__button {
    margin-top: 40px;
  }
  .spot__left {
    width: 30%;
  }
  .spot__middle {
    width: 35%;
  }
  .spot__right {
    width: 30%;
  }
  .access__h2 {
    font-size: 32px;
  }
  .access__address::after {
    z-index: -2;
    position: absolute;
    content: "";
    top: 300px;
    display: block;
    width: 100%;
    background-color: #f0f0f0;
    height: 600px;
  }
  .access__map {
    display: block;
    width: 88%;
    margin: 40px auto 0 auto;
  }
  .access__bottom {
    width: 88%;
    margin: 0 auto;
  }
  .reserve {
    margin-top: 240px;
  }
  .reserve__h2 {
    font-size: 32px;
  }
  .reserve__h2::before {
    left: 30%;
  }
  .reserve__h2::after {
    right: 30%;
  }
  .reserve__button {
    width: 80%;
  }
  .footer {
    padding: 40px;
    margin-top: 160px;
  }
  .footer__top {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    gap: 40px;
  }
  .footer__li {
    padding: 14px 40px 14px 0;
  }
  .footer__bottom {
    margin-top: 48px;
    line-height: 1.5;
  }
  .footer__lisence1 {
    margin-top: 24px;
  }
  .footer__lisence2 {
    margin-top: 8px;
  }
}
@media (max-width: 840px) {
  .header {
    /* ナビゲーションリスト */
  }
  .header__li {
    padding: 26px 20px;
  }
  .header__img {
    display: none;
  }
  .header__img-sp {
    display: block;
  }
  .header__nav {
    margin-top: 24px;
    width: 56px;
  }
  .header__ul {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: -72px;
    left: 0;
    width: calc(100% - 48px);
    height: 100vh;
    background-color: rgba(8, 44, 62, 0.8);
    transition: opacity 0.4s ease, visibility 0.4s ease;
    padding: 120px 24px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    opacity: 0;
    visibility: hidden;
    z-index: -1;
  }
  .header__ul.active {
    opacity: 1;
    visibility: visible;
    z-index: 2;
  }
  .header__li {
    text-align: center;
    padding: 16px;
  }
  .header__reserve {
    margin: 16px auto;
    text-align: center;
    margin-top: 240px;
  }
  .hero {
    width: 100%;
    height: 90vh;
    background-size: cover;
    background-position: 64% 24%;
    background-repeat: no-repeat;
    position: relative;
    left: 0;
    top: -80px;
    z-index: -2;
    animation: fadeSlider 20s infinite;
  }
  .hero__catch {
    font-size: 32px;
    color: #fff;
    position: absolute;
    left: 16px;
    bottom: 24px;
  }
  .praymessage {
    width: calc(100% - 32px);
  }
  .story {
    margin-top: 160px;
  }
  .story__contentred,
  .story__contentview {
    flex-direction: column-reverse;
    width: 100%;
  }
  .story__imageroom {
    width: calc(100% - 32px);
    margin: 0 auto;
  }
  .story__textblock {
    width: calc(100% - 32px);
    margin: 0 auto;
  }
  .story__imagestory,
  .story__shapebig,
  .story__shapesmall {
    position: absolute;
  }
  .story__imagestory {
    width: 60%;
    height: -moz-fit-content;
    height: fit-content;
    top: -80px;
    right: 0px;
  }
  .story__shapebig {
    top: 40px;
    left: calc(100% - 56px);
    width: 56px;
    height: 56px;
  }
  .story__shapesmall {
    top: -56px;
    right: calc(100% - 32px);
  }
  .story__heading {
    font-size: 24px;
  }
  .story__contentview {
    flex-direction: column-reverse;
    margin-top: 16px;
  }
  .story__p {
    line-height: 2;
  }
  .story__text {
    padding-left: 0px;
    width: calc(100% - 32px);
    margin: 0 auto;
  }
  .story__imageview {
    width: calc(100% - 32px);
    margin: 0 auto;
  }
  .bond {
    overflow-x: hidden;
    box-sizing: border-box;
    max-width: 100%;
    margin-top: 80px;
    position: relative;
  }
  .bond__h3 {
    font-size: 14px;
  }
  .bond__h2 {
    font-size: 24px;
  }
  .bond__h {
    display: flex;
    gap: 8px;
    flex-direction: column-reverse;
  }
  .bond__p {
    margin-top: 48px;
    line-height: 1.5;
  }
  .bond__wrap {
    padding: 0px;
    width: calc(100% - 32px);
    margin: 0 auto;
  }
  .bond__boxsmall {
    position: absolute;
    top: 0px;
    right: 16px;
  }
  .bond__boxbig {
    display: none;
  }
  .bond__text {
    position: absolute;
    top: 0px;
    right: 0;
    width: 60%;
    height: -moz-fit-content;
    height: fit-content;
  }
  .bond__slide {
    margin-top: 24px;
    display: flex;
    gap: 32px;
    width: 100%;
    max-width: 100%;
  }
  .bond__slide02 {
    width: 100%;
    display: block;
  }
  .iglogo {
    width: 40px;
    height: 40px;
  }
  .iglogo__wrap {
    display: block;
    width: 40px;
    height: 40px;
    margin-top: 40px;
  }
  .iglogo__flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
  }
  .rule__h2 {
    font-size: 24px;
  }
  .rule__h3 {
    margin-bottom: 16px;
  }
  .rule__box {
    position: absolute;
    top: 64px;
    left: 4%;
    width: 24px;
    height: 24px;
  }
  .rule__box2 {
    position: absolute;
    top: -32px;
    right: 4%;
    width: 40px;
    height: 40px;
  }
  .rule__explain {
    margin-top: 40px;
    width: 100%;
    flex-direction: column-reverse;
  }
  .rule__left {
    width: calc(100% - 32px);
    margin: 0 auto;
    padding-left: 0px;
  }
  .rule__right {
    width: 100%;
  }
  .rule__time {
    display: flex;
    align-items: center;
    gap: 16px;
  }
  .rule__time span {
    font-size: 24px;
  }
  .rule__starttime,
  .rule__endtime,
  .rule__p,
  .rule__checkout {
    font-size: 40px;
  }
  .rule__flex {
    display: flex;
    margin-top: 48px;
    gap: 40px;
  }
  .rule__button {
    margin-top: 40px;
  }
  .spot__left {
    display: none;
  }
  .spot__middle {
    width: calc(100% - 32px);
    margin: 0 auto;
  }
  .spot__right {
    display: none;
  }
  .spot__h2 {
    font-size: 24px;
  }
  .spot__boxsmall {
    position: absolute;
    top: 0;
    left: 32%;
  }
  .spot__boxbig {
    position: absolute;
    top: 256px;
    right: 32%;
  }
  .spot__p {
    margin-top: 120px;
    line-height: 1.5;
  }
  .spot__button {
    padding: 18px;
    width: 100%;
    background-color: #63bfbf;
    color: #fff;
    border: 0px;
    margin-top: 40px;
    font-family: "Shippori Mincho";
    box-shadow: 0 2px 0 #3f9494;
    font-size: 18px;
    border-radius: 32px;
  }
  .spot__button:hover {
    cursor: pointer;
    transition: 0.2s;
    background-color: #7dd9d9;
    transform: translateY(2px);
    box-shadow: 0 0px 0 #3f9494;
  }
  .spot__slide-wrapper {
    display: block;
  }
  .access {
    margin-top: 120px;
  }
  .access__h2 {
    font-size: 24px;
  }
  .access__map {
    width: calc(100% - 32px);
    height: 400px;
  }
  .access__boxbig {
    position: absolute;
    top: -32px;
    left: 16px;
    width: 56px;
    height: 56px;
  }
  .access__boxsmall {
    position: absolute;
    top: 35px;
    right: 16px;
  }
  .access__bottom {
    width: calc(100% - 32px);
  }
  .access__h3 {
    font-size: 20px;
  }
  .access__p {
    line-height: 1.5;
    margin-top: 24px;
  }
  .reserve {
    margin-top: 180px;
  }
  .reserve__h2 {
    font-size: 24px;
    text-align: center;
  }
  .reserve__h2::before {
    width: 24px;
    height: 24px;
    left: 16px;
    top: 24px;
  }
  .reserve__h2::after {
    width: 40px;
    height: 40px;
    right: 16px;
    top: -40px;
  }
  .reserve__button {
    width: calc(100% - 32px);
    margin: 64 px auto 0 auto;
  }
  .footer {
    text-align: center;
    margin-top: 80px;
    padding: 80px 16px;
  }
  .footer__top {
    align-items: center;
  }
  .footer__ul {
    flex-direction: column;
    align-items: center;
  }
  .footer__li {
    display: block;
    padding: 16px 16px 16px 0;
  }
  .footer__lisence1 {
    margin-top: 24px;
    line-height: 1.5;
  }
  .footer__lisence2 {
    margin-top: 4px;
  }
  /* ハンバーガー */
  .hamburger {
    display: block;
    position: relative;
    width: 48px;
    height: 48px;
    border: none;
    background: none;
    cursor: pointer;
    z-index: 10;
  }
  .header__nav {
    margin-top: 16px;
  }
  .hamburger span {
    display: block;
    height: 4px;
    background-color: #fff;
    border-radius: 4px;
    transition: transform 0.4s ease, opacity 0.4s ease;
  }
  .hamburger span:not(:last-child) {
    margin-bottom: 8px;
  }
  .hamburger.active span:nth-child(1) {
    transform: rotate(45deg) translateY(8px) translateX(8px);
  }
  .hamburger.active span:nth-child(2) {
    opacity: 0;
  }
  .hamburger.active span:nth-child(3) {
    transform: rotate(-45deg) translateY(-8px) translateX(8px);
  }
  /* メニュー */
  .header__ul {
    display: flex;
    gap: 16px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    flex-direction: column;
    background-color: rgba(0, 0, 0, 0.7);
    color: #fff;
    padding: 0;
    max-height: 0; /* 初期状態で高さを0に */
    overflow: hidden;
    opacity: 0; /* 初期状態で透明に */
    visibility: hidden; /* 初期状態で非表示 */
    transform: translateY(-20px); /* 初期状態で少し上にオフセット */
    /* transition: max-height 0.6s ease, opacity 0.6s ease, visibility 0.6s ease, transform 0.6s ease; 移動アニメーション追加 */
    z-index: 9;
  }
  .header__ul.active {
    width: calc(100% - 32px);
    max-height: 90vh; /* メニューが開いたときに画面全体を使用 */
    opacity: 1; /* メニューが開いたときに表示 */
    visibility: visible;
    transform: translateY(0); /* オフセットをリセット */
    padding: 104px 16px 0 16px;
  }
  .header__li {
    padding: 24px;
    text-align: center;
  }
  .header__reserve {
    margin: 24px auto;
  }
}
/* ボックスのふよふよアニメーション */
@keyframes float {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(16px); /* 上に移動 */
  }
  100% {
    transform: translateY(0); /* 元に戻る */
  }
}
.story__shapebig,
.story__shapesmall,
.bond__boxsmall,
.bond__boxbig,
.spot__boxsmall,
.spot__boxbig,
.access__boxsmall,
.access__boxbig,
.rule__box,
.rule__box2 {
  display: block;
  animation: float 3s ease-in-out infinite;
}

@keyframes floatButton {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px); /* 上に移動 */
  }
  100% {
    transform: translateY(0); /* 元に戻る */
  }
}
.gallaryfv {
  background-image: url(images/fv-gallary.jpg);
  width: 100%;
  height: 72vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  left: 0;
  top: -88px;
  z-index: -2;
  opacity: 1;
  transition: opacity 1s ease;
}
.gallaryfv__catch {
  line-height: 1.5;
  font-size: 40px;
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
}

.madori {
  width: calc(100% - 160px);
  margin: 0 auto;
  z-index: -5;
}
.madori__all {
  display: block;
  width: 80%;
  max-width: 960px;
  margin: 0 auto;
  height: -moz-fit-content;
  height: fit-content;
}
.madori__allsp {
  display: none;
}
.madori__flex {
  display: flex;
  align-items: baseline;
  gap: 2px;
  flex-direction: row;
  justify-content: center;
}
.madori__h {
  font-size: 32px;
  margin-right: 6px;
}
.madori__hana {
  display: block;
  width: 24px;
  height: 24px;
}
.madori__space {
  font-size: 32px;
}
.madori__wrap,
.madori__wrap2,
.madori__wrap3,
.madori__wrap4,
.madori__wrap5,
.madori__wrap6,
.madori__wrap7,
.madori__wrap8 {
  width: 100%;
}
.madori__card {
  width: 100%;
  margin-top: 16px;
}
.madori__cardimg {
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
  transition: opacity 0.5s ease-in-out;
  opacity: 1;
}
.madori__cardimg .fade {
  opacity: 0;
}
.madori__select {
  margin-top: 16px;
  width: 100%;
  display: flex;
  gap: 8px;
}
.madori__carding {
  display: block;
  width: calc(25% - 4px);
  height: auto;
  cursor: pointer;
  transition: opacity 0.3s ease;
  -o-object-fit: cover;
  object-fit: cover;
}
.madori__carding :hover {
  opacity: 0.8;
}
.madori__carding .active {
  opacity: 0.6; /* アクティブなサムネイルの透明度を変更 */
}
.madori__gallary {
  width: calc(100% - 160px);
  margin: 160px auto 0px auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 80px;
}

@media (max-width: 1024px) {
  .madori {
    width: calc(100% - 32px);
  }
  .madori__all {
    width: 100%;
  }
  .madori__h {
    font-size: 22px;
    margin-right: 0px;
  }
  .madori__hana {
    width: 16px;
    height: 16px;
  }
  .madori__space {
    font-size: 22px;
  }
  .madori__wrap,
  .madori__wrap2,
  .madori__wrap3,
  .madori__wrap4,
  .madori__wrap5,
  .madori__wrap6,
  .madori__wrap7,
  .madori__wrap8 {
    width: 100%;
    margin-top: 64px;
  }
  .madori__gallary {
    width: calc(100% - 32px);
    margin: 40px auto 0px auto;
    gap: 16px;
  }
  .gallaryfv__catch {
    font-size: 32px;
    white-space: nowrap;
  }
}
@media (max-width: 600px) {
  .madori__all {
    display: none;
  }
  .madori__allsp {
    display: block;
    width: 100%;
  }
  .madori__gallary {
    width: calc(100% - 32px);
    margin: 40px auto 0px auto;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 24px;
  }
}
/* 初期状態は非表示 */
.fade-in-section {
  opacity: 0;
  transform: translateY(20px); /* 少し下から浮き上がる感じ */
  transition: opacity 0.5s ease, transform 1s ease;
}

/* 表示時 */
.fade-in-section.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.rulefv {
  background-image: url(images/fv-rule.jpg);
  width: 100%;
  height: 72vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  left: 0;
  top: -88px;
  z-index: -2;
  opacity: 1;
  transition: opacity 1s ease;
}
.rulefv__catch {
  line-height: 1.5;
  font-size: 40px;
  color: #fff;
  text-shadow: 0 1px 4px #ddd;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.hrule {
  width: calc(100% - 160px);
  margin: 0 auto;
}
.hrule__note {
  text-align: center;
  margin: -88px 0 80px 0;
  background-color: #ffbc6a;
  padding: 16px;
}
.hrule__flex {
  display: flex;
  align-items: center;
  gap: 8px;
}
.hrule__flex span {
  font-family: "ivypresto-display", serif;
  color: #a9cfe3;
  margin: 0 0 -5px 0;
}
.hrule__miniflex {
  display: flex;
  align-items: center;
  gap: 8px;
}
.hrule__wrap {
  margin-top: 64px;
}
.hrule__h {
  font-size: 32px;
  color: #679fbe;
}
.hrule__icon {
  display: block;
  width: 24px;
  height: 24px;
  margin-top: 6px;
}
.hrule__middle {
  font-size: 20px;
  margin: 16px 0 0 32px;
  line-height: 1.5;
}
.hrule__p {
  font-size: 16px;
  margin: 8px 0 0 32px;
  line-height: 1.5;
}
.hrule__pcard {
  margin: 8px 0 0 0px;
  font-size: 16px;
  margin: 8px 0 0 32px;
  line-height: 1.5;
}

@media (max-width: 1024px) {
  .hrule {
    width: calc(100% - 80px);
  }
}
@media (max-width: 600px) {
  .hrule {
    width: calc(100% - 32px);
  }
  .hrule__h {
    font-size: 24px;
    color: #679fbe;
  }
  .hrule__miniflex {
    margin: 0 auto;
  }
  .hrule__flex {
    flex-direction: column;
    align-items: start;
    gap: 4px;
  }
  .hrule__flex span {
    margin: 0 auto;
    display: block;
    text-align: center;
    font-size: 14px;
  }
  .hrule__middle {
    margin: 12px 0 0 0px;
    text-align: center;
  }
  .hrule__p {
    margin: 8px 0 0 0px;
  }
  .hrule__pcard {
    margin: 8px 0 0 0px;
    text-align: center;
  }
  .sun {
    display: none;
  }
  .bond__boxbig {
    display: none;
  }
}
.tripfv {
  background-image: url(images/fv-trip.jpg);
  width: 100%;
  height: 72vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  left: 0;
  top: -88px;
  z-index: -2;
  opacity: 1;
  transition: opacity 1s ease;
}
.tripfv__catch {
  line-height: 1.5;
  font-size: 40px;
  color: #fff;
  text-shadow: 0 0px 2px #ddd;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.trip {
  width: calc(100% - 160px);
  margin: 80px auto 160px auto;
}
.trip__wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  margin-top: 64px;
}
.trip__wrap.active {
  width: 100%;
  margin-top: 64px;
}
.trip__info {
  margin-top: 40px;
}
.trip__img {
  width: 100%;
}
.trip__h2 {
  font-size: 32px;
  text-align: center;
}
.trip__info {
  display: flex;
  justify-content: space-between;
}
.trip__explain {
  width: 60%;
  margin: 40px auto 0 auto;
  line-height: 1.5;
}
.trip__buttonflex {
  margin-top: 80px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.trip__button {
  font-size: 16px;
  background-color: #fff;
  color: #aaaaaa;
  width: 100%;
  padding: 16px;
  border-radius: 50px;
  border: 1px solid #aaaaaa;
}
.trip__button:hover {
  color: #63bfbf;
  border: 1px solid #63bfbf;
  background-color: #f8ffff;
  cursor: pointer;
}
.trip__h3 {
  font-size: 24px;
}
.trip__yomi {
  font-size: 14px;
  margin-top: 14px;
  display: block;
}
.trip__distanceflex {
  display: flex;
  align-items: baseline;
}
.trip__distanceflex::before {
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background-image: url(images/walk.png);
  background-size: contain;
}
.trip__distanceflexcar {
  display: flex;
  gap: 4px;
  align-items: baseline;
}
.trip__distanceflexcar::before {
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background-image: url(images/car.png);
  background-size: contain;
}
.trip__distance {
  font-size: 32px;
  color: #63bfbf;
  font-family: oswald, sans-serif;
}
.trip__p {
  margin-top: 32px;
  line-height: 1.5;
}
.trip__linkflex {
  display: flex;
  gap: 16px;
  margin-top: 24px;
  width: 100%;
}
.trip__buttonbox {
  width: 50%;
}
.trip__official,
.trip__route {
  display: block;
  text-align: left;
  color: #fff;
  background-color: #63bfbf;
  width: calc(100% - 24px);
  border-radius: 4px;
  padding: 12px;
  border: none;
  box-shadow: 3px 3px 9px rgba(0, 0, 0, 0.16);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 16px;
}
.trip__official::after,
.trip__route::after {
  content: ">";
  display: block;
}
.trip__official:hover,
.trip__route:hover {
  background-color: #7dd5d5;
  transition: 0.3s;
}
.trip__listflex {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

@media (max-width: 1366px) {
  .trip {
    width: calc(100% - 80px);
    margin: 80px auto 160px auto;
  }
  .trip__listflex {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}
@media (max-width: 1100px) {
  .trip {
    width: calc(100% - 32px);
  }
  .trip__official,
  .trip__route {
    font-size: 14px;
  }
  .trip__linkflex {
    gap: 8px;
  }
  .trip__buttonflex {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }
  .trip__button {
    width: 100%;
  }
}
@media (max-width: 800px) {
  .trip {
    margin: 0px auto;
  }
  .trip__h2 {
    font-size: 24px;
  }
  .trip__linkflex {
    flex-direction: column;
    display: flex;
    gap: 8px;
  }
  .trip__button {
    font-size: 14px;
    padding: 8px;
  }
  .trip__buttonbox {
    width: 100%;
  }
  .trip__h3 {
    font-size: 20px;
    font-weight: bold;
  }
  .trip__listflex {
    grid-template-columns: repeat(1, 1fr);
  }
  .trip__explain {
    width: 100%;
  }
}
@media (max-width: 600px) {
  .trip__buttonflex {
    margin-top: 64px;
    grid-template-columns: repeat(3, 1fr);
  }
  .trip__wrap:first-child {
    margin-top: 24px;
  }
}
.trip__wrap {
  display: none;
  display: inline-flex;
} /* 初期状態では非表示 */
.trip__wrap.active {
  display: inline-flex;
} /* activeクラスで表示 */
.trip__button.active {
  font-weight: bold;
} /* 選択中ボタンを強調 */
/* フェードイン・アウト共通 */
.fade-in,
.fade-out {
  transition: opacity 0.5s ease;
}

/* 初期フェードイン */
.fade-in {
  opacity: 0;
  animation: fadeIn 0.5s ease forwards;
}

/* フェードアウト */
.fade-out {
  opacity: 0;
}

/* フェードインアニメーション定義 */
@keyframes fadeIn {
  to {
    opacity: 1;
  }
}
@media (max-width: 600px) {
  .header__li {
    padding: 26px 20px;
  }
  .header__nav {
    padding-right: 8px;
  }
  .header__logo {
    padding: 16px;
  }
  .spot__slide-wrapper {
    display: block;
  }
  .tripfv {
    background-position: -240px 80px;
  }
}
.footer__lisence1 {
  line-height: 1.5;
}

.iframe {
  width: 100%;
  margin: 0 auto;
  background-color: #fff;
}

.joshi {
  font-size: 24px;
} /*# sourceMappingURL=style.css.map */
