@charset "utf-8";

/* -------------------------
 * 下層用 フォント
 * ------------------------- */

:root {
  --jp: "Noto Sans JP", sans-serif;
  --jp02: "Shippori Mincho", serif;
  --en: "Gilda Display", serif;
  --num: "Work Sans", sans-serif;
}

.jp {
  font-family: var(--jp);
}

.jp02 {
  font-family: var(--jp02);
}

.en {
  font-family: var(--en);
}

.num {
  font-family: var(--num);
}


:root {
  --utxt16: 1.6rem;
  --utxt18: 1.8rem;
  --uf10: 1rem;
  --uf10all: 1rem;
  --uf12: 1.2rem;
  --uf12all: 1.2rem;
  --uf13: 1.3rem;
  --uf13all: 1.3rem;
  --uf14: 1.4rem;
  --uf14all: 1.4rem;
  --uf15: 1.5rem;
  --uf15all: 1.5rem;
  --uf16: 1.6rem;
  --uf17: 1.7rem;
  --uf18: 1.8rem;
  --uf19: 1.9rem;
  --uf20: 2rem;
  --uf21: 2.1rem;
  --uf22: 2.4rem;
  --uf24: 2.4rem;
  --uf26: 2.6rem;
  --uf28: 2.8rem;
  --uf30: 3rem;
  --uf32: 3.2rem;
  --uf34: 3.4rem;
  --uf36: 3.6rem;
  --uf38: 3.8rem;
  --uf40: 4rem;
  --uf42: 4.2rem;
  --uf44: 4.4rem;
  --uf46: 4.6rem;
  --uf48: 4.8rem;
  --uf50: 5rem;
  --uf52: 5.2rem;
  --uf54: 5.4rem;
  --uf56: 5.6rem;
  --uf58: 5.8rem;
  --uf60: 6rem;
  --uf62: 6.2rem;
  --uf64: 6.4rem;
  --uf70: 7rem;
  --uf80: 8rem;
  --uf90: 9rem;
  --uf96: 9.6rem;
  --uf100: 10rem;
  --uf120: 12rem;
}

@media(max-width:1445px) {
  :root {
    --utxt16: 1.5rem;
    --utxt18: 1.7rem;
    --uf10: 1rem;
    --uf10all: 1rem;
    --uf12: 1.2rem;
    --uf12all: 1.2rem;
    --uf13: 1.3rem;
    --uf13all: 1.3rem;
    --uf14: 1.4rem;
    --uf14all: 1.4rem;
    --uf15: 1.5rem;
    --uf15all: 1.5rem;
    --uf16: 1.5rem;
    --uf17: 1.7rem;
    --uf18: 1.8rem;
    --uf19: 1.9rem;
    --uf20: 1.85rem;
    --uf21: 1.9rem;
    --uf22: 2rem;
    --uf24: 2.1rem;
    --uf26: 2.25rem;
    --uf28: 2.4rem;
    --uf30: 2.6rem;
    --uf32: 2.8rem;
    --uf34: 2.8rem;
    --uf36: 3rem;
    --uf38: 3rem;
    --uf40: 3.15rem;
    --uf42: 3.2rem;
    --uf44: 3.3rem;
    --uf46: 3.4rem;
    --uf48: 3.9rem;
    --uf50: 4rem;
    --uf52: 4.1rem;
    --uf54: 4.2rem;
    --uf56: 4.3rem;
    --uf58: 4.4rem;
    --uf60: 4.5rem;
    --uf62: 4.5rem;
    --uf64: 4.6rem;
    --uf70: 5rem;
    --uf80: 5.5rem;
    --uf90: 6rem;
    --uf96: 6.4rem;
    --uf100: 6.75rem;
    --uf120: 8rem;
  }
}

@media(max-width:834px) {
  :root {
    --utxt16: 1.4rem;
    --utxt18: 1.6rem;
    --uf10: 0.9rem;
    --uf10all: 1rem;
    --uf12: 1.1rem;
    --uf12all: 1.2rem;
    --uf13: 1.2rem;
    --uf13all: 1.3rem;
    --uf14: 1.3rem;
    --uf14all: 1.4rem;
    --uf15: 1.4rem;
    --uf15all: 1.5rem;
    --uf16: 1.4rem;
    --uf17: 1.6rem;
    --uf18: 1.6rem;
    --uf19: 1.6rem;
    --uf20: 1.675rem;
    --uf21: 1.7rem;
    --uf22: 1.75rem;
    --uf24: 1.8rem;
    --uf26: 1.825rem;
    --uf28: 1.85rem;
    --uf30: 1.875rem;
    --uf32: 1.9rem;
    --uf34: 2.0rem;
    --uf36: 2.0rem;
    --uf38: 2.1rem;
    --uf40: 2.15rem;
    --uf42: 2.4rem;
    --uf44: 2.4rem;
    --uf46: 2.4rem;
    --uf48: 2.4rem;
    --uf50: 2.4rem;
    --uf52: 2.5rem;
    --uf54: 2.6rem;
    --uf56: 2.7rem;
    --uf58: 2.8rem;
    --uf60: 3.0rem;
    --uf62: 3.1rem;
    --uf64: 3.2rem;
    --uf70: 3.6rem;
    --uf80: 4.2rem;
    --uf90: 4.6rem;
    --uf96: 4.8rem;
    --uf100: 5rem;
    --uf120: 6rem;
  }
}

.utxt16 {
  font-size: var(--utxt16);
  font-weight: 300;
  line-height: 2;
}

.utxt18 {
  font-size: var(--utxt18);
  font-weight: 300;
  line-height: 2;
}

.uf120 {
  font-size: var(--uf120);
}

.uf100 {
  font-size: var(--uf100);
}

.uf96 {
  font-size: var(--uf96);
}

.uf90 {
  font-size: var(--uf90);
}

.uf80 {
  font-size: var(--uf80);
}

.uf70 {
  font-size: var(--uf70);
}

.uf64 {
  font-size: var(--uf64);
}

.uf62 {
  font-size: var(--uf62);
}

.uf60 {
  font-size: var(--uf60);
}

.uf56 {
  font-size: var(--uf56);
}

.uf54 {
  font-size: var(--uf54);
}

.uf52 {
  font-size: var(--uf52);
}

.uf50 {
  font-size: var(--uf50);
}

.uf48 {
  font-size: var(--uf48);
}

.uf42 {
  font-size: var(--uf42);
}

.uf40 {
  font-size: var(--uf40);
}

.uf36 {
  font-size: var(--uf36);
}

.uf34 {
  font-size: var(--uf34);
}

.uf32 {
  font-size: var(--uf32);
}

.uf30 {
  font-size: var(--uf30);
}

.uf28 {
  font-size: var(--uf28);
}

.uf26 {
  font-size: var(--uf26);
}

.uf24 {
  font-size: var(--uf24);
}

.uf22 {
  font-size: var(--uf22);
}

.uf21 {
  font-size: var(--uf21);
}

.uf20 {
  font-size: var(--uf20);
}

.uf18 {
  font-size: var(--uf18);
}

.uf18all {
  font-size: 1.8rem;
}

.uf17 {
  font-size: var(--uf17);
}

.uf16 {
  font-size: var(--uf16);
}

.uf15 {
  font-size: var(--uf15);
}

.uf15all {
  font-size: var(--uf15all);
}

.uf14 {
  font-size: var(--uf14);
}

.uf14all {
  font-size: var(--uf14all);
}

.uf13 {
  font-size: var(--uf13);
}

.uf13all {
  font-size: var(--uf13all);
}

.uf12 {
  font-size: var(--uf12);
}

.uf12all {
  font-size: var(--uf12all);
}

.uf10 {
  font-size: var(--uf10);
}

.uf10all {
  font-size: var(--uf10all);
}


.h {
  font-weight: 900;
}

.eb {
  font-weight: 800;
}

.b {
  font-weight: 700;
}

.sb {
  font-weight: 600;
}

.m {
  font-weight: 500;
}

.r {
  font-weight: 400;
}

.l {
  font-weight: 300;
}

.el {
  font-weight: 200;
}

.t {
  font-weight: 100;
}


.lh20 {
  line-height: 2;
}


.lh18 {
  line-height: 1.8;
}

.lh17 {
  line-height: 1.7;
}

.lh16 {
  line-height: 1.6;
}

.lh15 {
  line-height: 1.5;
}

.lh14 {
  line-height: 1.4;
}

.lh13 {
  line-height: 1.3;
}

.lh12 {
  line-height: 1.2;
}

.lh10 {
  line-height: 1;
}

.ls0 {
  letter-spacing: 0em;
}

.ls1 {
  letter-spacing: 0.1em;
}

.ls02 {
  letter-spacing: 0.02em;
}

.fcw {
  color: #fff;
}

/* フォント ↑ */

.tac {
  text-align: center;
}

.tas {
  text-align: start;
}

.tae {
  text-align: end;
}

.underline02 {
  text-decoration: underline 1px currentColor;
}

.underline {
  position: relative;
}

.underline::before {
  position: absolute;
  content: '';
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
}

.max1200 {
  display: none;
}

.min1200 {
  display: block;
}

@media(max-width:1200px) {
  .max1200 {
    display: block;
  }

  .min1200 {
    display: none;
  }
}

.max834 {
  display: none;
}

.min835 {
  display: block;
}

@media(max-width:834px) {

  .max834 {
    display: block;
  }

  .min835 {
    display: none;
  }
}

.max700 {
  display: none;
}

@media(max-width:700px) {
  .max700 {
    display: block;
  }
}

.max600 {
  display: none;
}

.min601 {
  display: block;
}

@media(max-width:600px) {
  .max600 {
    display: block;
  }

  .min601 {
    display: none;
  }
}

.max550 {
  display: none;
}

@media(max-width:550px) {
  .max550 {
    display: block;
  }
}

.max500 {
  display: none;
}

@media(max-width:500px) {
  .max500 {
    display: block;
  }
}

.max470 {
  display: none;
}

@media(max-width:470px) {
  .max470 {
    display: block;
  }
}

.max450 {
  display: none;
}

@media(max-width:450px) {
  .max450 {
    display: block;
  }
}

.max400 {
  display: none;
}

@media(max-width:400px) {
  .max400 {
    display: block;
  }
}

.max380 {
  display: none;
}

@media(max-width:380px) {
  .max380 {
    display: block;
  }
}

.max370 {
  display: none;
}

@media(max-width:370px) {
  .max370 {
    display: block;
  }
}

.h-op {
  transition: all .3s ease-in-out;
}

.h-op:hover {
  cursor: pointer;
  opacity: .7;
  transition: all .3s ease-in-out;
}

/*  */

.under-button {
  font-size: var(--uf15);
  color: var(--navy);
  border: 1px solid var(--cream);
  background: var(--cream);
  padding: 0.4em 1em 0.3em 1.3em;
  border-radius: 30px;

  font-family: var(--ff-shippori);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 0.3em;
  width: min(100%, 13.3rem);
  white-space: nowrap;
  border: 1px solid var(--navy);
}


/* sightseeing */

.sightseeing-intro__inner {
  display: grid;
  grid-template-columns: 1fr 47%;
  gap: 25px 20px;
}

.sightseeing-intro__img-wrap {
  margin-top: 120px;
}


.sightseeing-nav__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  max-width: 850px;
  width: 100%;
  margin: 120px auto 0;
}

.sightseeing-nav__item:not(:last-of-type) {
  border-right: 1px dotted #edeae4;
}

.sightseeing-nav__item-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.5;
  transition: all .4s ease-in-out;
}

.sightseeing-nav__item-link:hover {
  opacity: .7;
  transition: all .4s ease-in-out;
}

.sightseeing-nav__item-arrow {
  position: relative;
  width: 2rem;
  height: 2rem;
}

.sightseeing-nav__item-arrow::after {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  content: '\e313';
  font-size: 2rem;
  font-weight: 500;
}

.sightseeing-cont {}

.sightseeing-cont__list {
  display: flex;
  flex-direction: column;
  gap: 80px;
  margin-top: 90px;
}

.sightseeing-cont__item-ttl {
  display: flex;
  align-items: center;
  gap: 25px;
  font-weight: 400;
  line-height: 1.3;
  border-bottom: 1px solid #e4e4e4;
  padding-bottom: 10px;
  margin-bottom: 50px;
}

.sightseeing-cont__item-mess {
  text-align: center;
}

.sightseeing-cont__item-txt {
  text-align: center;
  margin-top: 20px;
}

.sightseeing-cont__item-children {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 65px 5%;
  margin-top: 60px;
}

.sightseeing-cont__item-child {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.sightseeing-cont__item-child__img-area {
  position: relative;
}

.sightseeing-cont__item-child__img-tag {
  position: absolute;
  top: 10px;
  left: 9px;
  width: 95%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}

.sightseeing-cont__item-child__img-tag span {
  display: block;
  background: #fff;
  width: fit-content;
  white-space: nowrap;
  border-radius: 15px;
  padding: 2px 10px 3px;
}

.sightseeing-cont__item-child__ttl {
  text-align: center;
  font-weight: 400;
  line-height: 1.5;
  margin-top: 20px;
}

.sightseeing-cont__item-child__txt {
  margin-top: 15px;
  margin-bottom: 20px;
}

.sightseeing-cont__item-child__access,
.sightseeing-cont__item-child__car {
  position: relative;
  padding-left: 2.5rem;
}

.sightseeing-cont__item-child__access::before,
.sightseeing-cont__item-child__car::before {
  position: absolute;
  top: 50%;
  left: 1rem;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  font-size: 2rem;
  font-weight: 400;
  font-variation-settings:
    'FILL' 1,
    /* 塗り 「0」→塗りなし 「1」→塗りあり*/
    'wght' 700,
    /* 線の太さ */
    'GRAD' 0,
    /* 線の太さ（wghtよりも微調整が可能）*/
    'opsz' 48;
  /* アイコンのサイズ */

}

.sightseeing-cont__item-child__access::before {
  /* location_on */
  content: '\e0c8';
}

.sightseeing-cont__item-child__car::before {
  /* directions_car */
  content: '\e531';
}

.sightseeing-cont__item-child__access {}

@media (max-width: 1334px) {
  .sightseeing-intro__img-wrap {
    margin-top: 7.5vw;
  }

  .sightseeing-nav__list {
    margin-top: 7vw;
  }

  .sightseeing-cont {}
}

@media (max-width: 834px) {
  .sightseeing-intro__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px 20px;
  }

  .sightseeing-intro__img-wrap {
    margin-top: 55px;
  }

  .sightseeing-nav__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 0;
    margin-top: 55px;
  }

  .sightseeing-cont {}

  .sightseeing-cont__list {
    gap: 55px;
    margin-top: 55px;
  }

  .sightseeing-cont__item-ttl {
    gap: 15px;
    padding-bottom: 10px;
    margin-bottom: 20px;
  }

  .sightseeing-cont__item-txt {
    text-align: start;
    margin-top: 15px;
  }

  .sightseeing-cont__item-children {
    display: grid;
    grid-template-columns: 1fr;
    gap: 50px 3%;
    margin-top: 50px;
  }

  .sightseeing-cont__item-child__img-tag span {
    padding: 0px 10px 1px;
  }
}

@media (max-width: 600px) {
  .sightseeing-cont__item-children {
    grid-template-columns: 1fr;
    gap: 40px 3%;
    margin-top: 40px;
  }

  .sightseeing-cont__item-child__txt {
    margin-top: 10px;
    margin-bottom: 20px;
  }
}


.room-intro__inner {
  display: grid;
  grid-template-columns: 1fr 47%;
  gap: 25px 20px;
}

.room-intro__description02 {
  margin-top: 2rem;
}

.room-intro__img-wrap {
  /* aspect-ratio: 1573 / 900; */
  margin-top: 120px;
}

@media (max-width: 834px) {
  .room-intro__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px 20px;
  }

  .room-intro__img-wrap {
    margin-top: 55px;
  }
}

.room-cont__list {
  display: flex;
  flex-direction: column;
  gap: 130px;
  margin-top: 130px;
}

.room-cont__item {
  display: grid;
  grid-template-columns: 53vw 1fr;
  align-items: center;
}

.room-cont__item-main {
  /* padding-right: calc(50vw - 650px); */
  padding-right: 11vw;
  padding-left: 20%;
}

.room-cont__item-ttl {
  display: flex;
  flex-direction: column;
  align-items: start;
  line-height: 1.2;
}

.room-cont__item-txt {
  margin-top: 3.5rem;
  margin-bottom: 5rem;
}

.room-cont__item-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 153px;
  height: 32px;
  line-height: 32px;
  border-radius: 20px;
  color: #fff;
  background: #3d4658;
  font-size: 1.6rem;
  font-family: var(--num);
}

.room-cont__item-btn__plus {
  color: #3d4658;
  background: #fff;
  width: 16px;
  height: 16px;
  line-height: 16px;
  text-align: center;
  border-radius: 100vmax;
}

@media (max-width: 1530px) {
  .room-cont__item-ttl01 {
    font-size: 4vw;
  }
}

@media (max-width: 1445px) {
  .room-cont__item-main {
    padding-right: 5vw;
    padding-left: 14%;
  }
}


@media (max-width: 1024px) {

  .room-cont__list {
    display: flex;
    flex-direction: column;
    gap: 80px;
    margin-top: 80px;
  }

  .room-cont__item {
    display: grid;
    grid-template-columns: 50vw 1fr;
    align-items: center;
  }

  .room-cont__item-ttl01 {
    font-size: 4.5rem;
  }
}

@media (max-width: 834px) {
  .room-cont__item-ttl01 {
    font-size: 3.5rem;
  }

  .room-cont__item-txt {
    margin-top: 2.5rem;
    margin-bottom: 4rem;
  }
}

@media (max-width: 600px) {
  .room-cont__list {
    display: flex;
    flex-direction: column;
    gap: 60px;
    margin-top: 55px;
  }

  .room-cont__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }

  .room-cont__item-main {
    padding-right: 5vw;
    padding-left: 5vw;
  }

  .room-cont__item-txt {
    margin-top: 2.5rem;
    margin-bottom: 3rem;
  }
}

/* modal */

.room__modal {
  position: fixed;
  z-index: 1200;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  visibility: hidden;
  opacity: 0;
  transform: translate(100%, 0);
  transition:
    opacity .6s ease-in-out,
    transform .6s ease-in-out,
    background-color .2s ease-in-out;
}

.room__modal.active {
  visibility: visible;
  opacity: 1;
  transform: translate(0, 0);
  background-color: #000000cc;
  transition:
    opacity .6s ease-in-out,
    transform .6s ease-in-out,
    background-color .8s ease-in-out;
}

.room__modal-list {
  width: 67%;
  min-width: 1100px;
  height: 100vh;
  margin: 0 0 0 auto;
}

.room__modal-item {
  display: none;
  overflow: scroll;
  height: 100%;
  /* padding: 50px 0 70px; */
}

.room__modal-item.active {
  display: block;
}

.room__modal-item__inner {
  width: 100%;
  height: fit-content;
  background-color: #fff;
  padding-bottom: 20vw;
  margin: 0 auto;
}

.room__modal-closebtn {
  position: absolute;
  z-index: 3;
  top: 20px;
  right: calc(67vw + 22px);
  width: 90px;
  height: 90px;
  border-radius: 100vmax;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2%;
  background: #f7f6f4;
}

.room__modal-closebtn:hover {
  cursor: pointer;
}

.room__modal-closebtn__ham {
  position: relative;
  width: 30px;
  height: 30px;
  overflow: hidden;
}

.room__modal-closebtn__ham span {
  position: absolute;
  top: 30%;
  left: 0%;
  width: 100%;
  height: 3px;
  border-radius: 4px;
  background-color: #3d4658;
  transition: all .4s ease;
}

.room__modal-closebtn__ham span:nth-of-type(1) {
  top: 50%;
  transform: rotate(45deg);
}

.room__modal-closebtn__ham span:nth-of-type(2) {
  top: 50%;
  transform: rotate(-45deg);
}

.room__modal-closebtn__txt {
  font-size: var(--uf16);
  font-family: var(--num);
  font-weight: 400;
  color: #3d4658;
  line-height: 1.5;
}

@media(max-width:1647px) {

  .room__modal-closebtn {
    position: absolute;
    top: 20px;
    right: 1122px;
  }

}


@media(max-width:1230px) {
  .room__modal-list {
    width: calc(100% - 120px);
    min-width: unset;
    height: 100vh;
    margin: 0 0 0 auto;
  }

  .room__modal-closebtn {
    position: absolute;
    top: 20px;
    right: unset;
    left: 20px;
    width: 80px;
    height: 80px;
  }

}

@media (max-width: 600px) {
  .room__modal-list {
    width: 100%;
  }

  .room__modal-closebtn {
    position: absolute;
    top: 10px;
    right: unset;
    left: 10px;
    width: 55px;
    height: 55px;
    gap: 0;
  }

  .room__modal-closebtn__ham {
    width: 22px;
    height: 22px;
  }
}


/* @media(max-width:1430px) {
  .room__modal-list {
    margin: 50px auto 10px 0;
  }
}

@media(max-width:1000px) {
  .room__modal-list {
    margin: 50px auto 10px;
  }
}

@media(max-width:500px) {
  .room__modal-list {
    margin: 50px auto 10px;
  }
} */


/* モーダル中身 */

.room__modal-item__thumbnail-area {
  max-width: 900px;
  width: 90%;
  margin: 25px auto 0;
}

.room__modal-item__thumbnail06-inner {
  background: #3d4658;
  width: 100%;
  aspect-ratio: 22 / 15;
  display: flex;
  align-items: center;
  justify-content: center;
}

.room__modal-item__thumbnail06-txt {
  color: #f7f6f4;
}

.room__modal-item__cont {
  max-width: 900px;
  width: 90%;
  margin: 9rem auto 0;
}

.room__modal-item__head {
  display: grid;
  grid-template-columns: 4fr 6fr;
  gap: 2.5rem 0;
}

.room__modal-item__head-ttl {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.room__modal-item__head-mess {
  line-height: 1.35;
}

.room__modal-item__head-txt {
  margin-top: 2.5rem;
}

.room__modal-item__data {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #ddd;
  margin-top: 8rem;
}

.room__modal-item__data-dt,
.room__modal-item__data-dd {
  padding: 2.5rem 0;
}

.room__modal-item__data-dt {
  width: 190px;
}

.room__modal-item__data-dd {
  width: calc(100% - 190px);
  border-bottom: 1px dotted #ddd;
}

.room__modal-item__data-dd:last-of-type {
  border-bottom: none;
}

.room__modal-item__data-dd__link {
  display: block;
  width: fit-content;
  margin-top: 3rem;
  margin-bottom: 1rem;
}

.room__modal-item__use {
  background: #dcdee2;
  padding: 6rem 5% 2rem;
  margin-top: 120px;
}

.room__modal-item__use-ttl {
  text-align: center;
}

.room__modal-item__use-dl__area {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem 5%;
  margin-top: 6rem;
}

.room__modal-item__use-dt {
  border-bottom: 1px solid #ccc;
  padding-bottom: .3em;
  margin-bottom: 2rem;
}

.room__modal-item__use-dd {
  margin-bottom: 4rem;
}

.room__modal-item__use-dl:first-of-type .room__modal-item__use-dd:first-of-type {
  height: 128px;
}

.room__modal-item__use-dd__list {
  background: #f7f6f4;
  padding: 1rem 1rem 1rem 2rem;
  margin-top: 2rem;
}

.room__modal-item__reservation {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  aspect-ratio: 900 / 100;
  color: #f7f6f4;
  background: #3d4658;
  margin-top: 8rem;
}

@media (max-width: 1445px) {
  .room__modal-item__use-dl:first-of-type .room__modal-item__use-dd:first-of-type {
    height: 120px;
  }
}

@media (max-width: 1024px) {
  .room__modal-item__use {
    padding: 5rem 5% 2rem;
    margin-top: 55px;
  }

  .room__modal-item__use-dl__area {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0rem 5%;
    margin-top: 4rem;
  }

  .room__modal-item__use-dl:first-of-type .room__modal-item__use-dd:first-of-type {
    height: unset;
  }

  .room__modal-item__reservation {
    margin-top: 5rem;
  }

}

@media (max-width: 834px) {
  .room__modal-item__cont {
    margin: 5rem auto 0;
  }

  .room__modal-item__head {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3.5rem 0;
  }

  .room__modal-item__data {
    margin-top: 5rem;
  }

  .room__modal-item__data-dt {
    width: 120px;
  }

  .room__modal-item__data-dd {
    width: calc(100% - 120px);
  }
}

@media (max-width: 600px) {
  .room__modal-item__data-dt {
    width: 95px;
  }

  .room__modal-item__data-dd {
    width: calc(100% - 95px);
  }

  .room__modal-item__use {
    padding: 3rem 5% 0rem;
    margin-top: 35px;
  }

  .room__modal-item__use-dl__area {
    margin-top: 2.5rem;
  }

  .room__modal-item__reservation {
    height: 60px;
    margin-top: 3rem;
  }
}


.facility-intro__inner {
  display: grid;
  grid-template-columns: 1fr 47%;
  gap: 25px 20px;
}

.facility-intro__description02 {
  margin-top: 2rem;
}

.facility-intro__img-wrap {
  aspect-ratio: 1573 / 570;
  margin-top: 120px;
}

@media (max-width: 834px) {
  .facility-intro__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px 20px;
  }

  .facility-intro__img-wrap {
    margin-top: 55px;
  }
}

.facility-cont {
  color: #f7f6f4;
  background: url(../img/facility/bg.webp) no-repeat center / cover;
}

.facility-cont__inner {
  display: flex;
  align-items: start;
}

.facility-cont__head {
  position: sticky;
  top: 100px;
  left: 0;
  width: 50%;
  height: fit-content;
  padding: 30px 0 0 5%;
}

.facility-cont__list {
  width: 50%;
  display: flex;
  flex-direction: column;
  padding: 0 6% 100px;
}

.facility-cont__head-img__area {
  position: relative;
  transform: translate(-3%, 0);
}

.facility-cont__head-location__item {
  position: absolute;
}

/* 管理棟 */
.facility-cont__head-location__item01 {
  top: 73%;
  left: 77.5%;
  transform: translate(-50%, -50%);
}

/* バレル sauna */
.facility-cont__head-location__item02 {
  top: 58%;
  left: 32.1%;
  transform: translate(-50%, -50%);
}

/* tent sauna */
.facility-cont__head-location__item03 {
  top: 56.7%;
  left: 30.7%;
  transform: translate(-50%, -50%);
}

/* beach */
.facility-cont__head-location__item04 {
  top: 42%;
  left: 43%;
  transform: translate(-50%, -50%);
}

/* fire */
.facility-cont__head-location__item05 {
  top: 49.8%;
  left: 47.3%;
  transform: translate(-50%, -50%);
}

/* Bar */
.facility-cont__head-location__item06 {
  top: 77.5%;
  left: 56.5%;
  transform: translate(-50%, -50%);
}

/* Parking */
.facility-cont__head-location__item07 {
  top: 67%;
  left: 85.5%;
  transform: translate(-50%, -50%);
}


.facility-cont__head-location__item-icon {
  position: relative;
  width: 28px;
  aspect-ratio: 75 / 105;
}

.facility-cont__head-location__item-icon::after {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  /* location_on */
  content: '\e0c8';
  font-size: 2rem;
  line-height: 1;
  color: #cde89b;
  font-variation-settings:
    'FILL' 1,
    /* 塗り 「0」→塗りなし 「1」→塗りあり*/
    'wght' 400,
    /* 線の太さ */
    'GRAD' 0,
    /* 線の太さ（wghtよりも微調整が可能）*/
    'opsz' 48;
  /* アイコンのサイズ */

  transition: transform .8s ease;
  transform-origin: center bottom;
}

.facility-cont__head-location__item-icon.active::after {
  transform: translate(-50%, -50%) scale(2.5);
}

.facility-cont__item {
  padding-top: 120px;
}

.facility-cont__item-ttl {
  margin: 3.5rem 0 3.5rem;
}

.facility-cont__item-dl {
  display: flex;
  flex-wrap: wrap;
  margin-top: 4.5rem;
}

.facility-cont__item-dt,
.facility-cont__item-dd {
  line-height: 1.7;
  border-top: 1px solid #ffffff33;
  padding: 2rem 1rem;
}

.facility-cont__item-dt {
  width: 160px;
}

.facility-cont__item-dd {
  width: calc(100% - 160px);
}

.facility-cont__item01-cont {
  border: 1px solid #ffffff33;
  background: #ffffff10;
  padding: 3rem 5%;
  margin-top: 3.5rem;
}

.facility-cont__item01-cont__ttl {}

.facility-cont__item01-cont__txt {
  margin-top: 2rem;
}

.facility-cont__item01-cont__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 15px;
  margin-top: 2rem;
}

.facility-cont__item01-cont__item {}

.facility-cont__item01-cont__item-img {}

.facility-cont__item01-cont__item-txt {
  position: relative;
  padding-left: 1.3em;
  margin-top: 1.5rem;
}

.facility-cont__item01-cont__item-txt::before {
  position: absolute;
  content: '';
  top: 1em;
  left: 0;
  transform: translate(0, -50%);
  width: .8em;
  aspect-ratio: 1 / 1;
  border-radius: 100vmax;
  background: #f7f6f4;
}

.facility-cont__item06-link {
  position: relative;
  padding-right: 2em;
  line-height: 1.5;
}

.facility-cont__item06-link::after {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  font-size: 1.6rem;
  font-weight: 300;
  /* open_in_new */
  content: '\e89e';
  font-variation-settings:
    'FILL' 0,
    /* 塗り 「0」→塗りなし 「1」→塗りあり*/
    'wght' 300,
    /* 線の太さ */
    'GRAD' 0,
    /* 線の太さ（wghtよりも微調整が可能）*/
    'opsz' 14;
  /* アイコンのサイズ */

}

/* inner1500 */
@media (max-width: 1667px) {
  .facility-cont__head {
    position: sticky;
    top: 90px;
    left: 0;
    width: 800px;
    height: fit-content;
    padding: 30px 0 0 1%;
  }

  .facility-cont__list {
    width: calc(100% - 800px);
    padding: 0 4% 100px 3%;
  }

  .facility-cont__head-img__area {
    transform: translate(0, 0);
  }
}

@media (max-width: 1300px) {
  .facility-cont__head {
    position: sticky;
    top: 90px;
    width: 50%;
    padding: 30px 0 0 1%;
  }

  .facility-cont__list {
    width: 50%;
    padding: 0 4% 100px 3%;
  }
}

@media (max-width: 834px) {
  .facility-cont__inner {
    display: block;
  }

  .facility-cont__head {
    position: sticky;
    z-index: 3;
    top: 0px;
    width: auto;
    height: 40vh;
    max-width: 100%;
    padding: 0px 1% 0 0%;
    background: url(../img/facility/bg.webp) no-repeat center / cover;
  }

  .facility-cont__list {
    z-index: 2;
    width: 100%;
    padding: 0 5% 50px 5%;
  }

  .facility-cont__item {
    padding-top: 40vh;
    margin-top: calc(-40vh + 50px);
  }
}

@media (max-width: 834px) {}

@media (max-width: 500px) {
  .facility-cont__item-ttl {
    margin: 2.5rem 0 2rem;
  }

  .facility-cont__item-dl {
    margin-top: 3.5rem;
  }

  .facility-cont__item-dt {
    width: 111px;
  }

  .facility-cont__item-dd {
    width: calc(100% - 111px);
  }

  .facility-cont__item01-cont__list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px 15px;
    margin-top: 2rem;
  }
}

@media (max-width: 370px) {
  .facility-cont__item01-cont__ttl {
    font-size: 1.6rem;
  }
}

.meal-intro {
  position: relative;
  padding-bottom: 28vw;
}

.meal-intro__inner {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  align-items: center;
}

.meal-intro__cont {
  width: 50%;
  padding-right: calc(50vw - 650px);
  z-index: 2;
}

.meal-intro__description01 {
  margin-top: 2rem;
}

.meal-intro__description02 {
  margin-top: 2rem;
}

.meal-intro__img01-wrap {
  width: 42%;
}

.meal-intro__img02-wrap {
  position: absolute;
  bottom: 0;
  right: 54%;
  width: 19.6vw;
}

.meal-intro__img03-wrap {
  position: absolute;
  bottom: 15%;
  right: 7%;
  width: 20.83vw;
}

.meal-intro__img04-wrap {
  position: absolute;
  bottom: 42%;
  right: 0;
  width: 16.07vw;
  z-index: 1;
}

/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {
  .meal-intro__cont {
    width: 53%;
    padding-right: 5vw;
  }
}

@media (max-width: 1100px) {
  .meal-intro__img03 {
    position: absolute;
    bottom: 9%;
    right: 24%;
    width: 20.83vw;
  }

  .meal-intro__img04 {
    position: absolute;
    bottom: 13%;
    right: 0;
    width: 16.07vw;
  }
}

@media (max-width: 834px) {
  .meal-intro {
    padding-bottom: 0;
  }

  .meal-intro__inner {
    display: flex;
    flex-direction: column-reverse;
    gap: 3.5rem;
    justify-content: space-between;
    align-items: center;
  }

  .meal-intro__cont {
    width: 90%;
    padding-right: 0;
  }

  .meal-intro__description02 {
    margin-top: 1rem;
  }

  .meal-intro__img01-wrap {
    width: 100%;
  }

  .meal-intro__img02-wrap {
    position: absolute;
    bottom: 0;
    right: 67%;
    width: 27.6vw;
  }

  .meal-intro__img03-wrap {
    position: absolute;
    bottom: 3%;
    right: 32%;
    width: 30.83vw;
  }

  .meal-intro__img04-wrap {
    position: absolute;
    bottom: 8%;
    right: 3%;
    width: 25.07vw;
  }
}

@media (max-width: 500px) {}

.meal-cont {
  margin-top: 130px;
}

.meal-cont__head {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  margin: 130px 0;
}

.meal-cont__head-cont {
  padding-right: 10%;
  padding-left: calc(50vw - 650px);
}

.meal-cont__head-ttl {
  line-height: 1.5;
}

.meal-cont__head-mess {
  line-height: 1.35;
  margin-top: 1rem;
  margin-bottom: 2.5rem;
}

.meal-cont__head-txt02 {
  margin-top: 2rem;
}

.meal-cont__top-img__wrap {
  /* aspect-ratio: 1573 / 900; */
}

/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {
  .meal-cont {
    margin-top: 8vw;
  }

  .meal-cont__head {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
    margin: 8vw 0;
  }

  .meal-cont__head-cont {
    padding-left: 5vw;
    padding-right: 7%;
  }
}

@media (max-width: 1024px) {
  .meal-cont {
    margin-top: 50px;
  }

  .meal-cont__head {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px 0;
    align-items: start;
    width: 90%;
    margin: 50px auto;
  }

  .meal-cont__head-cont {
    padding-left: 0;
    padding-right: 0;
  }
}

@media (max-width: 834px) {
  .meal-cont__head {
    gap: 30px 0;
    margin: 30px auto;
  }
}


.meal-cont01__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.meal-cont01__item {
  background: #dcdee2;
  padding: 70px 5%;
}

.meal-cont01__item-head {
  display: grid;
  grid-template-columns: 55fr 45fr;
  border-bottom: 1px solid #ccc;
  padding-bottom: 2rem;
  margin-bottom: 4rem;
}

.meal-cont01__item-ttl__wrap {
  display: flex;
  align-items: center;
  gap: 15px;
}

.meal-cont01__item-ttl01 {
  width: 70px;
  line-height: 70px;
  text-align: center;
  aspect-ratio: 1 / 1;
  background: #ebedf2;
}

.meal-cont01__item-ttl__r {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: .5rem;
  line-height: 1.5;
}

.meal-cont01__item-bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.meal-cont01__item-bottom__main {
  padding-left: 7%;
}

.meal01-cont__item-bottom__ttl {
  text-align: center;
  background-color: #9499a4;
  height: 3rem;
  line-height: 3rem;
}

.meal01-cont__item-bottom__list-area {
  display: grid;
  grid-template-columns: 5fr 4fr;
  gap: 2rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}


/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {}

@media (max-width: 1200px) {
  .meal-cont01__item {
    padding: 50px 5%;
  }

  .meal-cont01__item-head {
    display: grid;
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1024px) {
  .meal01-cont__item-bottom__list-area {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0 2rem;
  }
}

@media (max-width: 834px) {
  .meal-cont01__list {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }

  .meal-cont01__item {
    padding: 30px 5%;
  }

  .meal-cont01__item-head {
    padding-bottom: 2rem;
    margin-bottom: 2.5rem;
  }

  .meal-cont01__item-bottom {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .meal-cont01__item-bottom__main {
    padding-left: 0;
  }

  .meal01-cont__item-bottom__ttl {
    height: 2.5rem;
    line-height: 2.5rem;
  }
}

@media (max-width: 500px) {
  .meal-cont01__item-ttl__wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 15px;
    margin-bottom: 1.5rem;
  }

  .meal-cont01__item-ttl01 {
    width: 60px;
    line-height: 60px;
  }

  .meal-cont01__item-ttl__r {
    align-items: center;
  }
}

.meal-cont02__menu-ttl {
  border-bottom: 1px solid #ddd;
}

.meal-cont02__menu-dl {
  display: grid;
  grid-template-columns: 350px 1fr;
}

.meal-cont02__menu-dt,
.meal-cont02__menu-dd {
  margin-top: 2rem;
}

.meal-cont02__menu-dt {
  padding-top: 1.2rem;
}

.meal-cont02__menu-subdl {
  display: grid;
  grid-template-columns: 180px 1fr;
}

.meal-cont02__menu-subdt,
.meal-cont02__menu-subdd {
  padding: 2.5rem 0;
  border-bottom: 1px dotted #ddd;
}

.meal-cont02__menu-subdd__list {
  display: flex;
  flex-direction: column;
  gap: 1.5em;
}


/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {
  .meal-cont02__menu-dl {
    display: grid;
    grid-template-columns: 300px 1fr;
  }

  .meal-cont02__menu-dt {
    padding-top: 1.4rem;
  }

}

@media (max-width: 1024px) {
  .meal-cont02__menu-dl {
    display: grid;
    grid-template-columns: 1fr;
  }

  .meal-cont02__menu-dt {
    padding-top: 0;
  }


  .meal-cont02__menu-dd {
    padding-left: 2rem;
    margin-top: 0rem;
  }
}

@media (max-width: 834px) {
  .meal-cont02__menu-subdl {
    display: grid;
    grid-template-columns: 150px 1fr;
  }

  .meal-cont02__menu-subdt,
  .meal-cont02__menu-subdd {
    padding: 2rem 0;
    border-bottom: 1px dotted #ddd;
  }
}

@media (max-width: 500px) {
  .meal-cont02__menu-dd {
    padding-left: 1.5rem;
    margin-top: 0rem;
  }

  .meal-cont02__menu-subdl {
    display: grid;
    grid-template-columns: 120px 1fr;
  }
}

.meal-cont03__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4rem 3rem;
}

.meal-cont03__item-ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.5;
  height: 3em;
}

.meal-cont03__item-detail {
  margin-top: 1.5rem;
}

/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {}

@media (max-width: 1100px) {
  .meal-cont03__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4rem 3rem;
  }

}

@media (max-width: 834px) {}

@media (max-width: 600px) {
  .meal-cont03__list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 4rem 3rem;
  }

}

.meal-anniversary {
  padding-top: 130px;
}

.meal-anniversary__inner {
  display: flex;
  justify-content: end;
  max-width: 1445px;
  width: 90%;
  background: url(../img/meal/anniversary_bg.webp) no-repeat center / cover;
  aspect-ratio: 1445 / 380;
  margin: 0 auto;
}

.meal-anniversary__cont {
  width: 50%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.meal-anniversary__ttl-wrap {
  display: flex;
  flex-direction: column;
}

.meal-anniversary__ttl02 {
  line-height: 1.5;
}

.meal-anniversary__more {
  display: block;
  width: fit-content;
  background: #f7f6f4;
  text-align: center;
  line-height: 32px;
  height: 32px;
  border-radius: 20px;
  padding: 0 25px;
  margin-top: 2.5rem;
}

/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {
  .meal-anniversary {
    padding-top: 8vw;
  }
}

@media (max-width: 1200px) {
  .meal-anniversary__inner {
    background: url(../img/meal/anniversary_bg.webp) no-repeat center / cover;
    aspect-ratio: 1000 / 380;
  }

  .meal-anniversary__more {
    margin-top: 1.5rem;
  }
}

@media (max-width: 834px) {
  .meal-anniversary {
    padding-top: 50px;
  }

  .meal-anniversary__cont {
    width: 53%;
  }

  .meal-anniversary__more {
    line-height: 27px;
    height: 27px;
    border-radius: 20px;
    padding: 0 20px;
    margin-top: 1rem;
  }
}

@media (max-width: 650px) {
  .meal-anniversary__inner {
    background: url(../img/meal/anniversary_bg.webp) no-repeat left / cover;
    aspect-ratio: 500 / 380;
    margin: 0 auto;
  }

  .meal-anniversary__cont {
    width: 100%;
    height: 100%;
    padding: 0 5%;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

/* inner1500 */
@media (max-width: 1667px) {}

/* inner1300 */
@media (max-width: 1445px) {}

@media (max-width: 834px) {}