@charset "UTF-8";
/*******************************************************
 * 共通
 *******************************************************/
.inner {
  width: 95%;
  max-width: 1080px;
  margin: 0 auto;
}

@media (max-width: 834px) {
  .inner {
    width: 100%;
  }
}
.page-ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 18px;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.page-ttl-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 58px;
}

@media (max-width: 834px) {
  .page-ttl-head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 20px;
  }
}
.page-ttl-bl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  gap: 8px;
}
@media (max-width: 499px) {
  .page-ttl-bl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.page-content-wrapper {
  padding-top: 157px;
  font-weight: 600;
  padding: 100px 0;
}
@media (max-width: 639px) {
  .page-content-wrapper {
    padding: 60px 0;
  }
}

@media (max-width: 1024px) {
  .page-content-wrapper {
    padding-top: 95px;
  }
}
/* 改行 */
.br-1240 {
  display: none;
}

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

.br-639 {
  display: none;
}
@media (max-width: 639px) {
  .br-639 {
    display: block;
  }
}

@media (max-width: 499px) {
  .br-500 {
    display: block;
  }
}
.br-834 {
  display: none;
}

@media (max-width: 834px) {
  .br-834 {
    display: block;
  }
}
.no-br-500 {
  display: block;
}
@media (max-width: 499px) {
  .no-br-500 {
    display: none;
  }
}

/* 角丸画像 */
.img-radius20 {
  border-radius: 20px;
  overflow: hidden;
}

/* パンくずリスト */
.breadcrumb {
  display: inline-block;
}
@media (max-width: 834px) {
  .breadcrumb {
    display: none;
  }
}

.breadcrumb span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
  background: #fff;
  border-radius: 30px;
  padding: 4px 18px;
  font-weight: 600;
}

.breadcrumb span span {
  padding: 0;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.breadcrumb span span:first-child {
  text-decoration: underline;
}

.breadcrumb span span:not(:last-child) {
  position: relative;
}

.breadcrumb span span:not(:last-child)::after {
  display: block;
  content: "";
  position: absolute;
  top: 7px;
  right: -12px;
  width: 4px;
  height: 4px;
  border: 0;
  border-top: solid 1px var(--green);
  border-right: solid 1px var(--green);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

/* パンくずリスト（SP） */
.breadcrumb-sp {
  display: none;
}
@media (max-width: 834px) {
  .breadcrumb-sp {
    display: inline-block;
    margin-bottom: 40px;
  }
}

/* キービジュアル */
.kv {
  width: 100%;
  overflow: hidden;
  border-radius: 20px;
  margin: 0 auto 60px;
}
@media (max-width: 834px) {
  .kv {
    margin-bottom: 20px;
  }
}
@media (max-width: 499px) {
  .kv {
    margin-bottom: 12px;
  }
}

/* フッター箇所の背景色（アクセス、お食事） */
body.page-id-25,
body.page-id-23 {
  position: relative;
}

body.page-id-25::after,
body.page-id-23::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 25%;
  background-color: #d0cb9d;
  z-index: -1;
}

/* フッター箇所の背景色（周辺観光） */
body.page-id-27 {
  position: relative;
}

body.page-id-27::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 60%;
  background-color: #62c0b4;
  z-index: -1;
}

@media (max-width: 1240px) {
  body.page-id-27::after {
    height: 72%;
  }
}
@media (max-width: 1024px) {
  body.page-id-27::after {
    height: 78%;
  }
}
@media (max-width: 834px) {
  body.page-id-27::after {
    height: 80%;
  }
}
@media (max-width: 630px) {
  body.page-id-27::after {
    height: 82%;
  }
}
@media (max-width: 499px) {
  body.page-id-27::after {
    height: 79%;
  }
}
/* フッター箇所の背景色（コンセプト） */
body.page-id-37 {
  position: relative;
}

body.page-id-37::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50%;
  background-color: #d0cb9d;
  z-index: -1;
}

/* 矢印 */
/* 緑ボタン×白矢印 */
.arrow-down-bl {
  width: 60px;
  height: 30px;
  border-radius: 50px;
  background-color: var(--green);
  position: relative;
  overflow: hidden;
  line-height: 1;
}

/* 白ボタンの矢印 */
.arrow-down-bl-white {
  background-color: #fff;
}

.arrow-down01 {
  position: absolute;
  top: 41%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  width: 12px;
  display: block;
}

.arrow-down-bl .arrow-down01,
.arrow-down-bl .arrow-down02 {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  display: block;
}

.arrow-down-bl .arrow-down01 {
  top: -100%;
  width: 12px;
}

.arrow-down-bl .arrow-down02 {
  top: 15%;
  width: 12px;
}

a:hover .arrow-down01 {
  top: 15%;
}

a:hover .arrow-down02 {
  top: 100%;
}

/* 白ボタン×緑矢印 */
.arrow-down-bl.arrow-down-bl-white {
  background-color: #fff;
  width: 48px;
  height: 23px;
}

.arrow-down-bl.arrow-down-bl-white .arrow-down01 {
  width: 10px !important;
}

.arrow-down-bl.arrow-down-bl-white .arrow-down02 {
  top: 17%;
  width: 10px !important;
}

a:hover .arrow-down-bl.arrow-down-bl-white .arrow-down01 {
  top: 17%;
}

a:hover .arrow-down-bl.arrow-down-bl-white .arrow-down02 {
  top: 100%;
}

/*******************************************************
 * よくあるご質問
 *******************************************************/
.faq-main {
  margin-bottom: 100px;
}

@media (max-width: 834px) {
  .faq-main {
    margin-bottom: 56px;
  }
}
.faq__ttl-img {
  margin-bottom: 8px;
  width: 203px;
  height: auto;
}

/* メイン箇所 */
.faq-category {
  -webkit-animation: fadeIn 0.7s ease 0s 1 normal;
  animation: fadeIn 0.7s ease 0s 1 normal;
}

/*コンテンツ見出し*/
.faq-category-ttl {
  font-size: 42px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 56px;
}
@media (max-width: 499px) {
  .faq-category-ttl {
    margin-bottom: 30px;
    font-size: 35px;
  }
}

/* 回答箇所 */
.faq-a .small {
  font-size: 14px;
}
.faq-a .note {
  font-size: 13px;
}
.faq-a__link {
  text-decoration: underline;
}
.faq-a__cancel-fee-table-img {
  width: 60%;
  min-width: 400px;
}
@media (max-width: 639px) {
  .faq-a__cancel-fee-table-img {
    min-width: auto;
    width: 100%;
  }
}
.faq-a__temperature-img {
  width: 100%;
}

/*カテゴリーボタン*/
.faq-category-buttons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 13% 2%;
  margin-bottom: 80px;
}

@media (max-width: 1240px) {
  .faq-category-buttons {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 834px) {
  .faq-category-buttons {
    gap: 8% 2%;
  }
}
@media (max-width: 834px) and (max-width: 499px) {
  .faq-category-buttons {
    gap: 5% 2%;
  }
}
@media (max-width: 639px) {
  .faq-category-buttons {
    grid-template-columns: repeat(2, 1fr);
  }
}
.faq-category-button {
  font-size: 18px;
  font-weight: bold;
  padding: 14px 0 12px;
  border-radius: 50px;
  color: var(--green);
  background: #fff;
}
@media (max-width: 499px) {
  .faq-category-button {
    font-size: 15px;
  }
}

.faq-category-button:hover,
.faq-category-button.is-active {
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  color: #fff;
  background: var(--green);
}

/* アコーディオン */
.accordion-btn {
  border-radius: 20px;
  background: #fff;
  padding: 22px 90px 32px 90px;
  -webkit-transition: height 0.1s ease-in-out, border-radius 0.3s ease-in-out;
  transition: height 0.1s ease-in-out, border-radius 0.3s ease-in-out;
  position: relative;
  font-weight: bold;
  width: 100%;
  font-size: 18px;
  font-weight: bold;
  cursor: pointer;
}

.accordion-btn p {
  padding-left: 24px;
  text-indent: -60px;
}

@media (max-width: 834px) {
  .accordion-btn p {
    padding-left: 0px;
    text-indent: -44px;
  }
}
.accordion-btn p:before {
  content: "";
  display: inline-block;
  width: 50px;
  height: 38px;
  margin-right: 10px;
  background-image: url(../img/faq/q-icon.webp);
  background-size: cover;
  background-position: center;
  position: relative;
  top: 13px;
  left: -10px;
}

@media (max-width: 834px) {
  .accordion-btn p:before {
    width: 33px;
    height: 25px;
    top: 6px;
    left: 3px;
  }
}
@media (max-width: 834px) {
  .accordion-btn {
    padding: 12px 56px 13px 64px;
  }
}
.faq-item.accordion-open .accordion-btn {
  border-radius: 20px 20px 0 0;
}

.faq-item.accordion-open .accordion-btn + .faq-a::before {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #d2cfad 1px, transparent 1px);
  background-size: 4px 4px;
  width: calc(100% - 80px);
  margin: 0 auto;
  background-repeat: repeat;
  opacity: 1;
  visibility: visible;
  -webkit-transition: opacity 0.3s ease-in-out, visibility 0s 0.3s;
  transition: opacity 0.3s ease-in-out, visibility 0s 0.3s;
}

@media (max-width: 834px) {
  .faq-item.accordion-open .accordion-btn + .faq-a::before {
    width: calc(100% - 40px);
  }
}
/* アンサー */
.faq-a {
  border-radius: 0 0 20px 20px;
  background: #fff;
  position: relative;
  font-weight: 600;
  font-size: 16px;
  height: 0;
  overflow: hidden; /* 初期状態でアンサーを隠す */
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.faq-a p {
  text-indent: -62px;
  font-weight: 500;
}

@media (max-width: 834px) {
  .faq-a p {
    text-indent: -42px;
  }
}
.faq-a p:before {
  content: "";
  display: inline-block;
  width: 49px;
  height: 31px;
  margin-right: 10px;
  background-image: url(../img/faq/a-icon.webp);
  background-size: cover;
  background-position: center;
  position: relative;
  top: 10px;
  left: -10px;
}

@media (max-width: 834px) {
  .faq-a p:before {
    width: 32px;
    height: 20px;
    top: 2px;
    left: 3px;
  }
}
.faq-a::before {
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.3s ease-in-out, visibility 0s 0.3s;
  transition: opacity 0.3s ease-in-out, visibility 0s 0.3s;
}

.faq-item + .faq-item {
  margin-top: 40px;
}
@media (max-width: 499px) {
  .faq-item + .faq-item {
    margin-top: 20px;
  }
}

@media (max-width: 834px) {
  .faq-item {
    margin-top: 20px;
  }
}
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
  }
}
/* A.内コンテンツ */
.faq-a-content {
  padding: 22px 40px 32px 117px;
}
@media (max-width: 834px) {
  .faq-a-content {
    padding: 12px 40px 12px 63px;
  }
}

/*「料金について」テーブル*/
.faq-a p.clause__caution {
  text-indent: 0;
}

.faq-a p.clause__caution:before {
  content: none;
}

/*「施設利用」テーブル*/
.temperature-table-wrap {
  overflow-x: auto;
  width: 100%;
}

.temperature-table {
  font-size: 15px;
  border-spacing: 0;
  border-collapse: collapse;
  width: 839px;
  height: auto;
  max-width: none;
}

.temperature-table,
.temperature-table th,
.temperature-table td {
  border: 1px solid var(--green);
  padding: 0.5em;
}

/* 開閉ボタン */
.open-close-btn::before {
  content: "";
  position: absolute;
  top: 52px;
  right: 50px;
  -webkit-transform: translate(50%, -50%);
  transform: translate(50%, -50%);
  width: 3px;
  height: 20px;
  background: var(--green);
  -webkit-transition: all 0.2s 0s ease;
  transition: all 0.2s 0s ease;
}

@media (max-width: 834px) {
  .open-close-btn::before {
    right: 30px;
    top: 30px;
  }
}
.open-close-btn::after {
  content: "";
  position: absolute;
  top: 52px;
  right: 50px;
  -webkit-transform: translate(50%, -50%);
  transform: translate(50%, -50%);
  width: 20px;
  height: 3px;
  background: var(--green);
  -webkit-transition: all 0.2s 0s ease;
  transition: all 0.2s 0s ease;
}

@media (max-width: 834px) {
  .open-close-btn::after {
    right: 30px;
    top: 30px;
  }
}
.faq-item.accordion-open .open-close-btn::before {
  opacity: 0;
  -webkit-transition: all 0.2s 0s ease;
  transition: all 0.2s 0s ease;
}

.faq-item.accordion-open .open-close-btn::after {
  content: "";
  -webkit-transform: translate(50%, -50%) rotate(180deg);
  transform: translate(50%, -50%) rotate(180deg);
  -webkit-transition: all 0.2s 0s ease;
  transition: all 0.2s 0s ease;
}

/*******************************************************
 * 宿泊約款
 *******************************************************/
.clause__ttl-img {
  width: 315px;
  height: auto;
}

.clause__list {
  counter-reset: count;
}

.clause__list > li {
  counter-increment: count;
}

.clause__list > li::before {
  content: counter(count) ". ";
}

.clause__sub-list {
  counter-reset: sub-count;
  padding-left: 10px;
}

.clause__sub-list li {
  counter-increment: sub-count;
}

.clause__sub-list li::before {
  content: "(" counter(sub-count) ") ";
}

/* 見出し */
.clause__ttl {
  font-weight: bold;
  font-size: 24px;
  position: relative;
  padding-left: 13px;
  margin-bottom: 30px;
}
@media (max-width: 499px) {
  .clause__ttl {
    font-size: 20px;
  }
}

/* 緑の縦線*/
.clause__ttl::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 4px;
  height: 25px;
  background-color: var(--green);
  border-radius: 5px;
}

/* ドットの下線 */
.clause__ttl::after {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #d2cfad 1px, transparent 1px);
  background-size: 4px 4px;
  margin: 0 auto;
  background-repeat: repeat;
  width: calc(100% + 20px);
  margin-left: -16px;
}

.clause-contents {
  font-weight: 600;
  font-size: 16px;
}

.clause__list-item {
  padding-left: 1.4em;
  text-indent: -1.2em;
}

.clause__item + .clause__item {
  margin-top: 70px;
}
@media (max-width: 499px) {
  .clause__item + .clause__item {
    margin-top: 30px;
  }
}

.clause__sub-item {
  padding-left: 1em;
  text-indent: -1.6em;
}

.clause__table {
  border-radius: 10px;
  border: 1px solid var(--green);
  border-spacing: 0;
  border-collapse: separate;
  font-size: 18px;
  min-height: 318px;
}
@media (max-width: 499px) {
  .clause__table {
    font-size: 15px;
  }
}

@media (max-width: 1399px) {
  .clause__table {
    width: 100%;
  }
}
.clause__table th {
  background: #dedcc6;
  padding: 20px;
}

.clause__table th,
.clause__table td {
  padding: 20px;
  border-bottom: 1px solid var(--green);
}
@media (max-width: 499px) {
  .clause__table th,
  .clause__table td {
    padding: 8px;
  }
}

.clause__table tr:last-child th,
.clause__table tr:last-child td {
  border-bottom: none;
}

.clause__table tr {
  border-bottom: 1px solid var(--green);
}

.clause__table tr + .clause__table tr {
  border-top: 1px solid var(--green);
}

.clause__table tr:first-child th:first-child {
  border-radius: 10px 0 0 0;
}

.clause__table tr:last-child th:first-child {
  border-radius: 0 0 0 10px;
}

.clause__caution {
  font-size: 14px;
}

.clause__note-list {
  font-size: 14px;
  counter-reset: count;
}

.clause__note-list > li {
  counter-increment: count;
}

.clause__note-list > li::before {
  content: counter(count) ". ";
}

.clause__table-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.5%;
  margin-top: 84px;
  margin-bottom: 40px;
}

@media (max-width: 1399px) {
  .clause__table-list {
    grid-template-columns: repeat(1, 1fr);
    gap: 30px;
  }
}
@media (max-width: 499px) {
  .clause__table-list {
    margin-top: 30px;
    margin-bottom: 20px;
  }
}
.clause__table-ttl {
  font-size: 24px;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 30px;
}
@media (max-width: 499px) {
  .clause__table-ttl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 6px;
    margin-bottom: 0;
  }
}

@media (max-width: 1399px) {
  .clause__table-ttl {
    margin-bottom: 20px;
  }
}
@media (max-width: 499px) {
  .clause__table-ttl {
    margin-bottom: 0px;
    font-size: 20px;
  }
}
.clause__table-item:first-child .clause__table th {
  width: 22%;
}

@media (max-width: 1399px) {
  .clause__table-item:first-child .clause__table th {
    width: 30%;
  }
}
@media (max-width: 499px) {
  .clause__table-item:first-child .clause__table th {
    width: 40%;
  }
}
@media (max-width: 1399px) {
  .clause__table-item .clause__table th {
    width: 30%;
  }
}
@media (max-width: 499px) {
  .clause__table-item .clause__table th {
    width: 40%;
  }
}
.clause__label {
  font-size: 20px;
  border: 1px solid var(--green);
  border-radius: 50px;
  padding: 0px 30px;
}
@media (max-width: 499px) {
  .clause__label {
    font-size: 16px;
  }
}

/*******************************************************
 * 宿泊約款
 *******************************************************/
.company__ttl-img {
  width: 437px;
  height: auto;
}

.company__table {
  background: #fff;
  border-radius: 20px;
  padding: 30px 5%;
  position: relative;
  margin: 0 auto;
  width: 100%;
}
@media (max-width: 499px) {
  .company__table {
    padding: 20px 3%;
  }
}

.company__table th,
.company__table td {
  font-size: 17px;
  padding: 40px 10px;
}

.company__table tr {
  position: relative;
  /* ドットの下線 */
  /* 最後の行には線を引かない */
}

.company__table tr::after {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #d2cfad 1px, transparent 1px);
  background-size: 4px 4px;
  margin: 0 auto;
  background-repeat: repeat;
  width: calc(100% - 20px);
  position: absolute;
  bottom: 0;
  left: 10px;
}

.company__table tr:last-child::after {
  display: none;
}

@media (max-width: 834px) {
  .company__table tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.company__table th {
  font-size: 17px;
  width: 20%;
  padding-left: 30px;
  text-align: left;
}

@media (max-width: 834px) {
  .company__table th {
    width: 100%;
    padding-top: 20px;
    padding-left: 20px;
    padding-bottom: 0px;
  }
}
.company__table td {
  font-weight: 600;
  font-size: 16px;
}

@media (max-width: 834px) {
  .company__table td {
    width: 100%;
    padding-top: 0px;
    padding-left: 20px;
    padding-bottom: 10px;
    font-size: 14px;
  }
}
/* 所在地 */
.company__address-list li span {
  min-width: 100px;
  display: inline-block;
}
@media (max-width: 499px) {
  .company__address-list li span {
    min-width: auto;
  }
}

/*******************************************************
 * アクセス
 *******************************************************/
main#access {
  overflow: hidden;
}

.access__ttl-img {
  width: 351px;
  height: auto;
}

/* マップ、アクセス詳細  */
.access-map {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 60px;
}

@media (max-width: 1240px) {
  .access-map {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    margin-bottom: 90px;
  }
}
@media (max-width: 499px) {
  .access-map {
    margin-bottom: 40px;
  }
}
/* グーグルマップ */
.access-map__google-map {
  width: 48%;
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 50/57;
  position: relative;
}

@media (max-width: 1240px) {
  .access-map__google-map {
    width: 100%;
  }
}
.access-map__google-map iframe {
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

/* アクセス詳細 */
.access-info {
  width: 48%;
}

@media (max-width: 1240px) {
  .access-info {
    width: 100%;
    margin-bottom: 30px;
  }
}
.access-info__ttl-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 6%;
  margin-bottom: 30px;
}

@media (max-width: 1240px) {
  .access-info__ttl-wrap {
    margin-bottom: 24px;
  }
}
.access-info__logo {
  width: 125px;
  height: auto;
}

.access-info__ttl {
  font-weight: bold;
  font-size: clamp(22px, 2vw, 32px);
}

@media (max-width: 1240px) {
  .access-info__table {
    width: 100%;
  }
}
.access-info__table th,
.access-info__table td {
  padding: 23px 0;
}

.access-info__table th {
  font-size: 17px;
  font-weight: bold;
  width: 30%;
  min-width: 150px;
  text-align: left;
}

@media (max-width: 1599px) {
  .access-info__table th {
    width: 25%;
    min-width: 130px;
  }
}
@media (max-width: 499px) {
  .access-info__table th {
    padding-bottom: 0;
    padding-top: 16px;
  }
}
.access-info__table td {
  font-size: 16px;
}
@media (max-width: 499px) {
  .access-info__table td {
    padding-top: 4px;
    padding-bottom: 16px;
    font-size: 14px;
  }
}

.access-info__table tr {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media (max-width: 499px) {
  .access-info__table tr {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

/* 下線 */
.access-info__table tr::after {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #d2cfad 1px, transparent 1px);
  background-size: 4px 4px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0px;
}

.access-info__check-in-check-out {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.access-info__check-in-check-out th {
  width: 30%;
  min-width: auto;
  margin-right: 10px;
  text-align: left;
}

@media (max-width: 1599px) {
  .access-info__check-in-check-out th {
    width: 25%;
    min-width: 120px;
  }
}
@media (max-width: 499px) {
  .access-info__check-in-check-out th {
    width: 100%;
    min-width: auto;
  }
}
@media (max-width: 499px) {
  .access-info__check-out {
    padding-top: 0 !important;
  }
}

.access-info__check-out + td {
  padding-bottom: 8px;
}

.access-info__check-in-check-out::after {
  content: none !important;
}

.access-info__check-out {
  margin-left: auto;
}

.access-info__caution {
  font-size: 13px;
}

.access-map .access-info__check-out + td {
  padding-bottom: 23px;
}

/* LUXUNA伊勢志摩への行き方 */
.access-directions {
  background-image: url(../img/access/directions-bg.webp);
  background-size: cover;
  padding-top: 250px;
  z-index: 1;
  position: relative;
  background-position: calc(50% + 278px) center;
}
@media (max-width: 499px) {
  .access-directions {
    padding-top: 230px;
  }
}

.access-directions::before {
  width: 165px;
  aspect-ratio: 330/496;
  content: "";
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  top: -50px;
  left: 37%;
  background-image: url(../img/access/directions-head-icon01.webp);
}
@media (max-width: 1024px) {
  .access-directions::before {
    left: 4%;
    width: 120px;
  }
}
@media (max-width: 499px) {
  .access-directions::before {
    width: 22%;
    top: 0;
  }
}

.access-directions::after {
  width: 241px;
  aspect-ratio: 482/270;
  content: "";
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  top: 90px;
  right: 4%;
  background-image: url(../img/access/directions-head-icon02.webp);
}
@media (max-width: 1024px) {
  .access-directions::after {
    width: 200px;
  }
}
@media (max-width: 499px) {
  .access-directions::after {
    width: 40%;
    top: 111px;
  }
}

.access-directions__ttl {
  font-size: 42px;
  text-align: center;
}
@media (max-width: 499px) {
  .access-directions__ttl {
    font-size: 24px;
  }
}

.transport-options__ttl {
  font-size: 24px;
  text-align: center;
  margin: 48px auto 72px;
  display: inline-block;
  position: relative;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media (max-width: 499px) {
  .transport-options__ttl {
    font-size: 18px;
    margin: 12px auto 52px;
  }
}

.transport-options__ttl::after {
  content: "";
  display: block;
  height: 9px;
  background-image: radial-gradient(circle, #fff 3px, transparent 1px);
  background-size: 10px 10px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 104%;
  position: absolute;
  bottom: -6px;
  left: -6px;
}

.transport-options__list {
  width: 85%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3.5%;
  margin: 0 auto;
  margin-bottom: 80px;
}

@media (max-width: 1240px) {
  .transport-options__list {
    width: 100%;
  }
}
@media (max-width: 834px) {
  .transport-options__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 0px;
  }
}
.transport-options__list li {
  width: 33.3%;
}

@media (max-width: 834px) {
  .transport-options__list li {
    width: 48%;
    margin-bottom: 50px;
  }
}
@media (max-width: 499px) {
  .transport-options__list li {
    width: 30%;
    margin-bottom: 30px;
  }
}
.transport-options__item-img {
  position: absolute;
  margin-top: -57px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media (max-width: 499px) {
  .transport-options__item-img {
    margin-top: -44px;
  }
}

.transport-options__car-img {
  width: 82px;
}
@media (max-width: 499px) {
  .transport-options__car-img {
    width: 45%;
  }
}

.transport-options__train-img {
  width: 91px;
}
@media (max-width: 499px) {
  .transport-options__train-img {
    width: 45%;
  }
}

.transport-options__plane-img {
  width: 89px;
}
@media (max-width: 499px) {
  .transport-options__plane-img {
    width: 45%;
  }
}

.transport-options__item-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 18px 10px;
  position: relative;
  background: #fff;
  border: 1px solid var(--green);
  border-radius: 70px;
  font-size: 20px;
  text-align: center;
}

.transport-options__item-link p {
  font-size: clamp(15px, 1.3vw, 20px);
}
@media (max-width: 499px) {
  .transport-options__item-link p {
    font-size: 13px;
    line-height: 1.3;
    white-space: nowrap;
  }
}

.transport-options__item-link span {
  font-size: clamp(20px, 1.3vw, 28px);
}
@media (max-width: 499px) {
  .transport-options__item-link span {
    font-size: 18px;
  }
}

/* お車でお越しの場合 */
.directions-item__ttl {
  font-size: 34px;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  position: relative;
}
@media (max-width: 499px) {
  .directions-item__ttl {
    font-size: 24px;
  }
}

/* 緑のドット下線 */
.directions-item__ttl::after {
  content: "";
  display: block;
  height: 6px;
  background-image: radial-gradient(circle, var(--green) 2px, transparent 1px);
  background-size: 6px 6px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0px;
}

.directions-item + .directions-item {
  margin-top: 50px;
}

.directions-car__ttl-img {
  width: 69px;
}
@media (max-width: 499px) {
  .directions-car__ttl-img {
    width: 13%;
  }
}

.directions-train__ttl-img {
  width: 76px;
}
@media (max-width: 499px) {
  .directions-train__ttl-img {
    width: 13%;
  }
}

.directions-plane__ttl-img {
  width: 74px;
}
@media (max-width: 499px) {
  .directions-plane__ttl-img {
    width: 13%;
  }
}

.directions-item__ttl-img {
  margin-bottom: 13px;
}

.directions-item {
  background: #fff;
  border-radius: 20px 0px 0 20px;
  padding: 62px 7%;
}
@media (max-width: 499px) {
  .directions-item {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.directions-list .right-wrapper {
  width: calc(100% - 480px);
}

@media (max-width: 1399px) {
  .directions-list .right-wrapper {
    width: calc(100% - 380px);
  }
}
@media (max-width: 1024px) {
  .directions-list .right-wrapper {
    width: 95%;
  }
}
.directions-car__flex-item {
  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;
  margin-top: 29px;
}

@media (max-width: 1240px) {
  .directions-car__flex-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media (max-width: 499px) {
  .directions-car__flex-item {
    margin-top: 10px;
  }
}
.car-routes {
  width: 48%;
}

@media (max-width: 1240px) {
  .car-routes {
    width: 100%;
  }
}
.car-routes li {
  font-size: 17px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  padding: 16px 0;
}
@media (max-width: 499px) {
  .car-routes li {
    font-size: 15px;
  }
}

.car-routes li::after {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #d2cfad 1px, transparent 1px);
  background-size: 4px 4px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0px;
}

.car-routes li:last-child::after {
  display: none;
}

.car-routes-button {
  color: #fff;
  background: var(--green);
  border-radius: 50px;
  min-width: 140px;
  text-align: center;
  font-size: 14px;
  padding: 4px 0;
  margin-left: 10px;
}
@media (max-width: 499px) {
  .car-routes-button {
    min-width: 130px;
    text-align: center;
    font-size: 14px;
  }
}

.destination {
  width: 48%;
  background: #e6e3c9;
  padding: 30px;
  border-radius: 20px;
  text-align: center;
}

@media (max-width: 1240px) {
  .destination {
    width: 100%;
  }
}
@media (max-width: 499px) {
  .destination {
    padding: 24px;
  }
}
.destination-img {
  border-radius: 15px;
  margin-bottom: 14px;
  overflow: hidden;
}

.destination-txt {
  font-size: 14px;
  text-align: left;
  margin-bottom: 20px;
}

.destination-txt span {
  font-size: 18px;
}

.destination-button {
  margin: 0 auto;
  font-size: 16px;
  padding: 5px 0;
  min-width: 240px;
  border-radius: 50px;
  background: #ffe33f;
  color: var(--green);
  position: relative;
  line-height: 1.2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  text-align: left;
  padding-left: 29px;
  display: inline-block;
}
@media (max-width: 499px) {
  .destination-button {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 0;
    padding-right: 10%;
  }
}

.destination-button-inner {
  text-align: center;
  display: inline-block;
}

.destination-button-inner span {
  font-size: 24px;
}

.destination-button::after {
  background: url(../img/access/by-car_icon.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 71px;
  height: 99px;
  top: -28px;
  right: 22px;
  z-index: 1;
}

/* 電車でお越しの場合 */
.directions-train {
  text-align: center;
  font-size: 16px;
}

.directions-train span {
  font-size: 22px;
}

.directions-train__txt {
  margin-top: 49px;
}
@media (max-width: 499px) {
  .directions-train__txt {
    margin-top: 10px;
  }
}

.directions-train__flex-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 85%;
  gap: 10%;
  display: flex;
  margin: 60px auto 60px;
}

@media (max-width: 1240px) {
  .directions-train__flex-item {
    width: 100%;
  }
}
@media (max-width: 834px) {
  .directions-train__flex-item {
    gap: 3.5%;
  }
}
@media (max-width: 639px) {
  .directions-train__flex-item {
    margin: 30px auto 30px;
  }
}
.directions-train__flex-item li {
  width: 48%;
}

@media (max-width: 639px) {
  .directions-train__flex-item li {
    width: 100%;
  }
}
.access-directions__list .arrow-down-bl .arrow-down02 {
  top: 6%;
}
.access-directions__list a:hover .arrow-down02 {
  top: 100%;
}
.access-directions__list a:hover .arrow-down01 {
  top: 6%;
}

.directions-train__bus-route {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 18px 10px;
  position: relative;
  background: #fff;
  border: 1px solid var(--green);
  border-radius: 70px;
  font-size: 20px;
  text-align: center;
}
@media (max-width: 499px) {
  .directions-train__bus-route {
    padding: 8px;
  }
}
@media (max-width: 639px) {
  .directions-train__bus-route .arrow-down-bl {
    margin-top: 4px;
  }
}

.directions-train__route-button-img {
  margin-right: 10px;
}
@media (max-width: 499px) {
  .directions-train__route-button-img {
    margin-right: 0;
  }
}

.directions-train__bus-img {
  width: 55px;
}
@media (max-width: 639px) {
  .directions-train__bus-img {
    width: 50px;
  }
}

.directions-train__ship-img {
  width: 61px;
}
@media (max-width: 639px) {
  .directions-train__ship-img {
    width: 56px;
  }
}

.directions-train__route-button-ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: clamp(15px, 1.3vw, 20px);
}
.directions-train__route-button-ttl p {
  line-height: 1.4;
}
@media (max-width: 499px) {
  .directions-train__route-button-ttl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.directions-train__route-button-ttl span {
  font-size: clamp(20px, 1.3vw, 28px);
}

.directions-train__route-button-item-link:hover {
  cursor: pointer;
}

/* バスをご利用の場合 */
.route-map__ttl {
  background: var(--green);
  color: #fff;
  border-radius: 20px 20px 0 0;
  padding: 32px 5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media (max-width: 1240px) {
  .route-map__ttl {
    padding: 24px 4%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.route-map__ttl p {
  font-size: 16px;
}

.route-map__ttl p span {
  font-size: 28px;
}
@media (max-width: 499px) {
  .route-map__ttl p span {
    font-size: 25px;
  }
}

.route-map__ttl p span.route-map__ttl-highlight {
  background: #e6e3c9;
  color: var(--green);
  border-radius: 5px;
  padding: 3px;
}
@media (max-width: 499px) {
  .route-map__ttl p span.route-map__ttl-highlight {
    font-size: 25px;
  }
}

.route-map__ttl-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-right: 10px;
}

@media (max-width: 1240px) {
  .route-map__ttl-inner {
    margin-right: 0;
    margin-bottom: 20px;
  }
}
@media (max-width: 1240px) {
  .route-map__ttl-inner {
    margin-right: 0;
    margin-bottom: 20px;
  }
}
.route-map__ttl-inner p {
  text-align: left;
}
@media (max-width: 499px) {
  .route-map__ttl-inner p {
    width: 100%;
  }
}

.route-map__ttl-img {
  margin-right: 10px;
  margin-top: 4px;
}
@media (max-width: 639px) {
  .route-map__ttl-img {
    margin-top: 11px;
  }
}

.route-map__ttl-img-bus {
  width: 74px;
}
@media (max-width: 499px) {
  .route-map__ttl-img-bus {
    width: 18%;
  }
}

.route-map__ttl-img-ship {
  width: 87px;
}
@media (max-width: 499px) {
  .route-map__ttl-img-ship {
    width: 18%;
  }
}

.route-map__timetable-button {
  background: #fff;
  border-radius: 50px;
  padding: 4px 3%;
  color: var(--green);
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 14px;
  white-space: nowrap;
}
@media (max-width: 499px) {
  .route-map__timetable-button {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media (max-width: 1240px) {
  .route-map__timetable-button {
    margin-left: 0;
  }
}
.route-map__timetable-button span {
  font-size: 14px;
  padding-bottom: 2px;
  margin-left: 14px;
}

.route-map__body {
  background: #f9f6e2;
  padding: 40px;
  border-radius: 0 0 20px 20px;
}
@media (max-width: 499px) {
  .route-map__body {
    padding: 24px 4%;
  }
}

@media (max-width: 834px) {
  .route-map__img {
    overflow-x: auto;
  }
}
@media (max-width: 834px) {
  .route-map__img img {
    display: block;
    width: 750px;
    height: auto;
    max-width: none;
  }
}

.route-map__item + .route-map__item {
  margin-top: 60px;
}
@media (max-width: 499px) {
  .route-map__item + .route-map__item {
    margin-top: 30px;
  }
}

/* トゥクトゥク */
.tuk-tuk {
  margin-top: 60px;
  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;
  text-align: left;
}

@media (max-width: 1240px) {
  .tuk-tuk {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
@media (max-width: 499px) {
  .tuk-tuk {
    margin-top: 30px;
  }
}
.tuk-tuk__img {
  overflow: hidden;
  border-radius: 20px;
}

.tuk-tuk__img,
.tuk-tuk__body {
  width: 48%;
}

@media (max-width: 1240px) {
  .tuk-tuk__img,
  .tuk-tuk__body {
    width: 100%;
  }
}
.tuk-tuk__ttl {
  font-size: 24px;
  margin-bottom: 24px;
  font-weight: bold;
  line-height: 1.5;
}

@media (max-width: 1240px) {
  .tuk-tuk__ttl {
    margin-top: 12px;
    margin-bottom: 24px;
  }
}
@media (max-width: 499px) {
  .tuk-tuk__ttl {
    line-height: 1.3;
    margin-bottom: 12px;
    font-size: 22px;
  }
}
.tuk-tuk__ttl span {
  font-size: 32px;
}
@media (max-width: 499px) {
  .tuk-tuk__ttl span {
    font-size: 25px;
  }
}

.tuk-tuk__info-list li {
  padding-left: 16px;
  position: relative;
  line-height: 1.8;
}

.tuk-tuk__info-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 12px;
  height: 12px;
  background-color: var(--green);
  border-radius: 50%;
}

/* 飛行機でお越しの場合 */
.directions-plane__route-map {
  padding-top: 39px;
}
@media (max-width: 499px) {
  .directions-plane__route-map {
    padding-top: 10px;
  }
}

.route-map__ttl-ship {
  color: #fff;
  border-radius: 50px;
  padding: 4px 10px;
  text-align: center;
  font-size: 24px;
  margin-bottom: 24px;
}
@media (max-width: 499px) {
  .route-map__ttl-ship {
    font-size: 20px;
    margin-bottom: 12px;
  }
}

.route-map__ttl-ship01 {
  background: #eb8c6e;
}

.route-map__ttl-ship02 {
  background: #81b8df;
}

/* お電話でのお問い合わせはこちら */
.contact-tel__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 6%;
  background: #e6e3c9;
  border-radius: 20px;
  padding: 54px 5%;
  position: relative;
  width: 90%;
  max-width: 1000px;
  margin: 75px auto 0;
}

@media (max-width: 1240px) {
  .contact-tel__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 30px 5%;
  }
}
@media (max-width: 499px) {
  .contact-tel__inner {
    padding: 20px 3%;
    margin-top: 30px;
  }
}
/* 左アイコン */
.contact-tel__inner::before {
  background: url(../img/access/contact-tel-icon01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 22%;
  aspect-ratio: 360/296;
  top: 88px;
  left: -12%;
  z-index: 1;
}

@media (max-width: 1240px) {
  .contact-tel__inner::before {
    left: -9%;
  }
}
@media (max-width: 499px) {
  .contact-tel__inner::before {
    width: 32%;
  }
}
/* 右アイコン */
.contact-tel__inner::after {
  background: url(../img/access/contact-tel-icon02.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 12%;
  aspect-ratio: 190/298;
  top: 85px;
  right: -6%;
  z-index: 1;
}
@media (max-width: 499px) {
  .contact-tel__inner::after {
    width: 18%;
  }
}

.contact-tel__txt {
  font-size: 22px;
}
@media (max-width: 499px) {
  .contact-tel__txt {
    text-align: center;
    font-size: 18px;
    line-height: 1.3;
  }
}

.contact-tel__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media (max-width: 499px) {
  .contact-tel__info {
    line-height: 1.3;
  }
}

.contact-tel__info a {
  font-size: 39px;
  font-family: var(--quick);
  font-weight: bold;
}
@media (max-width: 499px) {
  .contact-tel__info a {
    font-size: 32px;
  }
}

.contact-tel__info p {
  font-size: 16px;
}
@media (max-width: 499px) {
  .contact-tel__info p {
    font-size: 15px;
  }
}

/*******************************************************
 * お食事
 *******************************************************/
/* 見出し */
.food__ttl-bl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.food__en {
  margin-bottom: 20px;
}
@media (max-width: 499px) {
  .food__en {
    margin-bottom: 12px;
  }
}

.food__ttl {
  font-size: 18px;
}
@media (max-width: 1399px) {
  .food__ttl {
    font-size: 1.7rem;
  }
}

.food__ttl-img {
  margin-bottom: 8px;
  width: 232px;
  height: auto;
}

/*注釈*/
.food__caution-list {
  font-size: 13px;
}

.food__caution-list li {
  position: relative;
}

.food__caution-list li:before {
  content: "※";
}

/* メニューボタン */
.food__menu-buttons {
  width: 90%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2.5%;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 auto;
}
@media (max-width: 834px) {
  .food__menu-buttons .arrow-down-bl .arrow-down01 {
    width: 10px;
  }
}
@media (max-width: 834px) {
  .food__menu-buttons .arrow-down-bl .arrow-down02 {
    top: 16%;
    width: 10px;
  }
}
@media (max-width: 834px) {
  .food__menu-buttons a:hover .arrow-down02 {
    top: 100%;
  }
  .food__menu-buttons a:hover .arrow-down01 {
    top: 16%;
  }
}

@media (max-width: 834px) {
  .food__menu-buttons {
    margin-top: -24px;
  }
}
@media (max-width: 1240px) {
  .food__menu-buttons {
    width: 100%;
  }
}
.food__menu-buttons li {
  width: 30%;
}

@media (max-width: 834px) {
  .food__menu-buttons li {
    width: 48%;
    margin-top: 24px;
  }
}
.food__menu-buttons li a {
  border-radius: 80px;
  border: 1px solid var(--green);
  width: 100%;
  height: 9vw;
  max-height: 110px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: #fff;
  font-weight: bold;
  font-size: clamp(18px, 1.5vw, 22px);
}

@media (max-width: 1240px) {
  .food__menu-buttons li a {
    height: 11vw;
  }
}
@media (max-width: 834px) {
  .food__menu-buttons li a {
    height: 9vw;
    max-height: none;
    min-height: 68px;
    line-height: 1.3;
    padding: 7px 16px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 15px;
  }
}
@media (max-width: 499px) {
  .food__menu-buttons li a {
    height: 16vw;
    text-align: center;
  }
}
.food__menu-buttons li:nth-of-type(1) a {
  background: url(../img/food/menu-button01.webp);
}

.food__menu-buttons li:nth-of-type(2) a {
  background: url(../img/food/menu-button02.webp);
}

.food__menu-buttons li:nth-of-type(3) a {
  background: url(../img/food/menu-button03.webp);
}

.food__menu-buttons li .arrow-down-bl {
  margin-top: 8px;
  background-color: #ffe33f;
  width: 60px;
  height: 30px;
  border-radius: 50px;
  position: relative;
  overflow: hidden;
  line-height: 1;
}

@media (max-width: 1240px) {
  .food__menu-buttons li .arrow-down-bl {
    margin-top: 0;
  }
}
@media (max-width: 834px) {
  .food__menu-buttons li .arrow-down-bl {
    width: 40px;
    height: 25px;
    margin-left: auto;
  }
}
/* Dinner Menu */
.dinner__en {
  width: 53%;
  max-width: 812px;
}
@media (max-width: 639px) {
  .dinner__en {
    width: 100%;
  }
}

.dinner {
  position: relative;
  overflow-x: hidden;
  padding-top: 60px;
}
@media (max-width: 834px) {
  .dinner {
    padding-top: 40px;
  }
}

.dinner .right-wrapper {
  position: relative;
  border-radius: 20px 0 0 20px;
  width: calc(100% - 480px);
  margin-left: 480px;
}

@media (max-width: 1399px) {
  .dinner .right-wrapper {
    width: calc(100% - 380px);
    margin-left: 380px;
  }
}
@media (max-width: 1024px) {
  .dinner .right-wrapper {
    margin-left: 5%;
    width: 90%;
  }
}
.dinner__head {
  margin: 151px 0 20px;
  position: relative;
  font-size: 42px;
}

@media (max-width: 1399px) {
  .dinner__head {
    margin-top: 120px;
  }
}
@media (max-width: 1240px) {
  .dinner__head {
    font-size: 32px;
  }
}
.dinner__head::before {
  background: url(../img/food/dinner-bubble01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 110px;
  aspect-ratio: 262/267;
  top: -118px;
  left: 130px;
  z-index: 1;
}

@media (max-width: 1399px) {
  .dinner__head::before {
    width: 90px;
    top: -88px;
    left: 159px;
  }
}
@media (max-width: 1240px) {
  .dinner__head::before {
    top: -98px;
    left: 96px;
  }
}
.dinner__head::after {
  background: url(../img/food/dinner-bubble02.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 110px;
  aspect-ratio: 262/267;
  top: -118px;
  left: 260px;
  z-index: 1;
}

@media (max-width: 1399px) {
  .dinner__head::after {
    width: 90px;
    top: -88px;
  }
}
@media (max-width: 1240px) {
  .dinner__head::after {
    top: -98px;
    left: 199px;
  }
}
.dinner__lead {
  width: 60%;
}
@media (max-width: ) {
  .dinner__lead {
    width: 46%;
  }
}

@media (max-width: 1399px) {
  .dinner__lead {
    width: 60%;
  }
}
@media (max-width: 1024px) {
  .dinner__lead {
    width: 50%;
  }
}
@media (max-width: 834px) {
  .dinner__lead {
    width: 65%;
  }
}
@media (max-width: 639px) {
  .dinner__lead {
    width: 100%;
    padding-top: 19vw;
  }
}
.dinner__lead-txt {
  font-size: 18px;
}

/* 見出し下画像（共通） */
.dinner__img-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: absolute;
  right: -100px;
  top: 0px;
}
@media (max-width: 639px) {
  .dinner__img-wrap.--pc {
    display: none;
  }
}
.dinner__img-wrap.--sp {
  display: none;
  width: 100vw;
  left: -6%;
}
.dinner__img-wrap.--sp img {
  height: 100%;
}
.dinner__img-wrap.--sp img:nth-of-type(1) {
  right: 40px;
  top: 0px;
  width: 50vw;
  height: auto;
  position: absolute;
}
.dinner__img-wrap.--sp img:nth-of-type(2) {
  left: -10px;
  top: 50px;
  width: 60vw;
}
.dinner__img-wrap.--sp img:nth-of-type(3) {
  right: -10px;
  top: 28vw;
  width: 38vw;
}
@media (max-width: 639px) {
  .dinner__img-wrap.--sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    top: unset;
    right: unset;
    position: relative;
  }
}

@media (max-width: 1024px) {
  .dinner__img-wrap {
    right: -142px;
  }
}
@media (max-width: 834px) {
  .dinner__img-wrap {
    top: 0px;
  }
}
@media (max-width: 639px) {
  .dinner__img-wrap {
    display: none;
  }
}
.dinner__img-wrap img {
  width: 30vw;
}

@media (max-width: 1399px) {
  .dinner__img-wrap img {
    width: 23vw;
  }
}
@media (max-width: 1024px) {
  .dinner__img-wrap img {
    width: 32vw;
  }
}
.dinner__img-wrap img:nth-of-type(1) {
  max-width: 450px;
}

@media (max-width: 1399px) {
  .dinner__img-wrap img:nth-of-type(1) {
    position: relative;
    right: 80px;
  }
}
.dinner__img-wrap img:nth-of-type(2) {
  max-width: 480px;
  position: relative;
  right: 130px;
  top: -50px;
}

@media (max-width: 1399px) {
  .dinner__img-wrap img:nth-of-type(2) {
    right: 160px;
  }
}
.dinner__img-wrap img:nth-of-type(3) {
  max-width: 450px;
  position: relative;
  right: -70px;
  top: -100px;
  z-index: -1;
}

@media (max-width: 1399px) {
  .dinner__img-wrap img:nth-of-type(3) {
    right: 40px;
  }
}
.amanoniwa {
  position: relative;
  margin-top: 120px;
}

.amanoniwa::before {
  background: url(../img/food/amanoniwa.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 34%;
  max-width: 350px;
  aspect-ratio: 655/850;
  top: -24px;
  left: -1%;
  z-index: 1;
}

@media (max-width: 1240px) {
  .amanoniwa::before {
    left: -1%;
  }
}
@media (max-width: 834px) {
  .amanoniwa::before {
    left: auto;
    right: 3%;
    width: 200px;
    top: -95px;
  }
}
@media (max-width: 639px) {
  .amanoniwa::before {
    top: -111px;
    width: 183px;
  }
}
@media (max-width: 499px) {
  .amanoniwa::before {
    width: 40%;
  }
}
@media (max-width: 399px) {
  .amanoniwa::before {
    width: 34%;
    top: -70px;
  }
}
.amanoniwa::after {
  background: url(../img/food/dinner-icon01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 128px;
  aspect-ratio: 335/228;
  top: -59px;
  right: 33%;
  z-index: 1;
}

@media (max-width: 834px) {
  .amanoniwa::after {
    right: auto;
    left: 3%;
  }
}
.amanoniwa__inner {
  background: #fff;
  width: 96%;
  border-radius: 20px;
  padding: 40px 5% 40px 370px;
}

@media (max-width: 1599px) {
  .amanoniwa__inner {
    padding: 40px 5% 40px 35%;
  }
}
@media (max-width: 1024px) {
  .amanoniwa__inner {
    width: 100%;
  }
}
@media (max-width: 834px) {
  .amanoniwa__inner {
    padding: 40px 5%;
  }
}
.amanoniwa__ttl {
  background: var(--green);
  color: #fff;
  border-radius: 5px;
  font-size: 18px;
  display: inline-block;
  padding: 4px;
}

.amanoniwa__lead {
  margin: 12px 0 24px;
  font-weight: bold;
  font-size: 24px;
}

.amanoniwa__txt {
  font-size: 16px;
  margin-bottom: 27px;
}

.amanoniwa__txt span {
  font-size: 13px;
}

.amanoniwa__caution {
  text-align: right;
  font-size: 13px;
  margin-top: 8px;
  max-width: 1060px;
  width: 95%;
}

@media (max-width: 1240px) {
  .amanoniwa__caution {
    text-align: left;
  }
}
/* BBQスライド */
.bbq-slide {
  margin: 98px 0;
  position: relative;
  z-index: 1;
}

.bbq-slide:before {
  content: "";
  display: block;
  background: url(../img/food/bbq-slide.webp) repeat-x 0 0;
  width: 100%;
  height: 80px;
  overflow: hidden;
  -webkit-animation: loop 60s linear infinite;
  animation: loop 60s linear infinite;
}

@-webkit-keyframes loop {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -1932px 0;
  }
}
@keyframes loop {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -1932px 0;
  }
}
@media screen and (max-width: 834px) {
  .bbq-slide {
    margin: 56px 0;
  }
  .bbq-slide:before {
    height: 40px;
    background-size: 966px 40px;
    -webkit-animation: loop 60s linear infinite;
    animation: loop 60s linear infinite;
  }
  @-webkit-keyframes loop {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: -966px 0;
    }
  }
  @keyframes loop {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: -966px 0;
    }
  }
}
@media (max-width: 499px) {
  .bbq-slide {
    margin: 30px 0;
  }
}
/* BBQメニュー */
.bbq-item {
  background: #fff;
  border-radius: 20px;
  padding: 60px 7%;
}

@media (max-width: 1240px) {
  .bbq-item {
    padding: 30px 7%;
  }
}
.bbq-item + .bbq-item {
  margin-top: 60px;
}

.bbq {
  margin-bottom: 72px;
}

.bbq .right-wrapper {
  width: calc(100% - 520px);
  margin-left: 480px;
}

@media (max-width: 1399px) {
  .bbq .right-wrapper {
    width: calc(100% - 420px);
    margin-left: 380px;
  }
}
@media (max-width: 1024px) {
  .bbq .right-wrapper {
    margin-left: 5%;
    width: 90%;
  }
}
.bbq__head-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media (max-width: 1240px) {
  .bbq__head-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.bbq__ttl,
.bbq__head-txt {
  width: 48%;
}

@media (max-width: 1240px) {
  .bbq__ttl,
  .bbq__head-txt {
    width: 100%;
  }
}
.bbq__ttl {
  font-weight: bold;
  font-size: 29px;
}
@media (max-width: 499px) {
  .bbq__ttl {
    line-height: 1.3;
  }
}

.bbq__ttl span {
  font-size: 18px;
}

.bbq__head-txt {
  font-size: 16px;
}

.bbq__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 40px;
}
@media (max-width: 499px) {
  .bbq__body {
    margin-top: 20px;
  }
}

@media (max-width: 1240px) {
  .bbq__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.bbq__body-img {
  width: 60%;
}

@media (max-width: 1240px) {
  .bbq__body-img {
    width: 100%;
    margin-bottom: 20px;
  }
}
@media (max-width: 1240px) {
  .bbq__body-img.--course03 {
    margin-bottom: 40px;
  }
}

.bbq__body-txt {
  width: 36%;
}

@media (max-width: 1240px) {
  .bbq__body-txt {
    width: 100%;
  }
}
.food-course-swiper03 {
  position: relative;
}
.food-course-swiper03 img {
  border-radius: 20px;
}
.food-course-swiper03 .swiper-pagination {
  bottom: -30px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.food-course-swiper03 .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #317c63;
}
.food-course-swiper03 .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
}

.food-course__head {
  background: var(--green);
  color: #fff;
  display: inline-block;
  width: 100%;
  padding-top: 3px;
  font-size: 18px;
  border-radius: 5px;
  text-align: center;
}

.food-course__list {
  margin: 24px 0;
  font-size: 16px;
  counter-reset: count 0;
}
.food-course__list li {
  padding-left: 1.8rem;
  text-indent: -1.8rem;
}

.food-course__list li:before {
  content: counter(count) ". ";
  counter-increment: count 1;
}

/* 美味しく味わうコツ */
.enjoy-tips {
  margin-bottom: 120px;
}

.enjoy-tips .right-wrapper {
  width: calc(100% - 520px);
  margin-left: 480px;
}

@media (max-width: 1399px) {
  .enjoy-tips .right-wrapper {
    width: calc(100% - 420px);
    margin-left: 380px;
  }
}
@media (max-width: 1024px) {
  .enjoy-tips .right-wrapper {
    margin-left: 5%;
    width: 90%;
  }
}
.enjoy-tips__ttl {
  background: #ffe33f;
  text-align: center;
  border-radius: 50px;
  width: 100%;
  padding: 10px;
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 49px;
  position: relative;
}
@media (max-width: 499px) {
  .enjoy-tips__ttl {
    margin-bottom: 20px;
  }
}

@media (max-width: 639px) {
  .enjoy-tips__ttl {
    font-size: 18px;
  }
}
.enjoy-tips__ttl::before {
  background: url(../img/food/check-icon.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 161px;
  aspect-ratio: 382/156;
  bottom: 0px;
  left: 6%;
  z-index: 1;
}

@media (max-width: 834px) {
  .enjoy-tips__ttl::before {
    width: 131px;
  }
}
@media (max-width: 639px) {
  .enjoy-tips__ttl::before {
    bottom: 67%;
    left: 5%;
    max-width: 160px;
    width: 46%;
  }
}
.enjoy-tips__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 7% 2.5%;
}

@media (max-width: 834px) {
  .enjoy-tips__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 3%;
  }
}
.enjoy-tips p {
  font-size: 18px;
  font-weight: bold;
  margin-top: 18px;
  text-align: center;
}
@media (max-width: 499px) {
  .enjoy-tips p {
    margin-top: 8px;
    font-size: 15px;
    line-height: 1.3;
  }
}

/* 動画サムネイル */
.enjoy-tips__img {
  position: relative;
  overflow: hidden;
}
.enjoy-tips__img::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
.enjoy-tips__img::after {
  content: "";
  background-image: url("../img/food/play-btn.png");
  background-size: contain;
  background-repeat: no-repeat;
  width: 65px;
  height: 65px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

a:hover .enjoy-tips__img::before,
a:hover .enjoy-tips__img::after {
  opacity: 1;
}

/* Breakfast Menu, Other Menu */
.breakfast-and-others {
  background-image: url(../img/food/meals-bg.webp);
  background-size: cover;
  padding-top: 190px;
  z-index: 1;
  position: relative;
}

.meals .right-wrapper {
  position: relative;
}

.meals .right-wrapper::before {
  width: 165px;
  aspect-ratio: 454/332;
  content: "";
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  top: -195px;
  left: 30;
  background-image: url(../img/food/meals-icon01.webp);
}

.meals .right-wrapper::after {
  width: 165px;
  aspect-ratio: 454/332;
  content: "";
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  top: -195px;
  right: 0;
  background-image: url(../img/food/meals-icon02.webp);
}

.meals__item {
  position: relative;
}

.meals__ttl-bl {
  margin-bottom: 53px;
  position: absolute;
  top: -35px;
  left: 35px;
}

@media (max-width: 639px) {
  .meals__ttl-bl {
    top: -25px;
    left: 5%;
  }
}
.meals__content {
  background: #fff;
  border-radius: 20px;
  padding: 100px 5% 60px;
  overflow: hidden;
}
@media (max-width: 499px) {
  .meals__content {
    padding: 70px 5% 24px;
  }
}

.meals__head {
  font-size: 18px;
  font-weight: bold;
}
@media (max-width: 499px) {
  .meals__head {
    line-height: 1.3;
  }
}

.meals__head span {
  font-size: 32px;
}
@media (max-width: 499px) {
  .meals__head span {
    font-size: 28px;
  }
}

.meals__item + .meals__item {
  margin-top: 96px;
}

/* Breakfast Menu */
.breakfast__en {
  width: 51vw;
}
@media (max-width: 1024px) {
  .breakfast__en {
    width: 63vw;
  }
}
@media (max-width: 639px) {
  .breakfast__en {
    width: 95%;
  }
}

.breakfast__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media (max-width: 1240px) {
  .breakfast__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.breakfast__body {
  width: 48%;
}

@media (max-width: 1240px) {
  .breakfast__body {
    width: 100%;
  }
}
.breakfast__img {
  width: 48%;
}

@media (max-width: 1240px) {
  .breakfast__img {
    width: 100%;
  }
}
.breakfast__txt {
  margin: 16px 0 40px;
  font-size: 16px;
}
@media (max-width: 1240px) {
  .breakfast__txt {
    margin: 0 0 20px;
  }
}

/* Other Menu */
.other__en {
  width: 38vw;
}
@media (max-width: 1024px) {
  .other__en {
    width: 47vw;
  }
}
@media (max-width: 639px) {
  .other__en {
    width: 70%;
  }
}

.other__body {
  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;
}

@media (max-width: 1240px) {
  .other__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.other__head {
  width: 48%;
}

@media (max-width: 1240px) {
  .other__head {
    width: 100%;
  }
}
.other__txt {
  width: 46%;
  font-size: 16px;
}

@media (max-width: 1240px) {
  .other__txt {
    width: 100%;
  }
}
/* Other Menu 画像ラップ */
/* Other Menu スライダー */
.food-slider01-wrap {
  margin: 45px -23% 60px;
  padding: 0;
}
@media (max-width: 499px) {
  .food-slider01-wrap {
    margin-top: 20px;
    margin-bottom: 20px;
  }
}

.food-swiper .swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}
.food-swiper img {
  border-radius: 20px;
}

/* Other Menu アニバーサリーケーキ */
.anniversary-cake {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

@media (max-width: 1240px) {
  .anniversary-cake {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
.anniversary-cake__body {
  background: url(../img/food/cake.webp) no-repeat;
  background-size: cover;
  background-position: center center;
  padding: 50px 5%;
  color: #fff;
  margin-bottom: 8px;
  width: 100%;
}
@media (max-width: 499px) {
  .anniversary-cake__body {
    padding: 30px 5%;
  }
}
@media (max-width: 499px) {
  .anniversary-cake__body .base__link {
    margin: 0 auto;
  }
}

.anniversary-cake__head {
  font-size: 18px;
  font-weight: bold;
}
@media (max-width: 499px) {
  .anniversary-cake__head {
    line-height: 1.3;
  }
}

.anniversary-cake__head span {
  font-size: 32px;
}
@media (max-width: 499px) {
  .anniversary-cake__head span {
    font-size: 25px;
  }
}

.anniversary-cake__txt {
  font-size: 16px;
  margin: 40px auto 36px;
}
@media (max-width: 499px) {
  .anniversary-cake__txt {
    margin-top: 20px;
    margin-bottom: 20px;
  }
}

/*******************************************************
 * 周辺観光
 *******************************************************/
main#sightseeing {
  overflow: hidden;
}

/* 見出し */
.sightseeing__ttl-img {
  width: 552px;
}
@media (max-width: 1240px) {
  .sightseeing__ttl-img {
    width: 372px;
  }
}
@media (max-width: 639px) {
  .sightseeing__ttl-img {
    width: 372px;
  }
}

/* 観光スポットマップ */
.spot-map {
  margin-bottom: 100px;
}

@media (max-width: 1399px) {
  .spot-map {
    margin-bottom: 330px;
  }
}
@media (max-width: 1240px) {
  .spot-map {
    margin-bottom: 490px;
  }
}
@media (max-width: 1100px) {
  .spot-map {
    margin-bottom: 650px;
  }
}
@media (max-width: 1024px) {
  .spot-map {
    margin-bottom: 570px;
  }
}
@media (max-width: 1024px) {
  .spot-map {
    margin-bottom: 660px;
  }
}
@media (max-width: 639px) {
  .spot-map {
    margin-bottom: 640px;
  }
}
@media (max-width: 499px) {
  .spot-map {
    margin-bottom: 670px;
  }
}
@media (max-width: 399px) {
  .spot-map {
    margin-bottom: 680px;
  }
}
.spot-map {
  position: relative;
}
.spot-map__ttl {
  font-size: 38px;
  margin-bottom: 20px;
}
@media (max-width: 1599px) {
  .spot-map__ttl {
    font-size: 33px;
  }
}
@media (max-width: 1240px) {
  .spot-map__ttl {
    font-size: 23px;
  }
}
.spot-map__txt {
  font-size: 16px;
}
.spot-map .right-wrapper {
  position: absolute;
  top: 130px;
}
@media (max-width: 639px) {
  .spot-map .right-wrapper {
    top: 190px;
  }
}
.spot-map__txt-wrap {
  max-width: 690px;
  width: 50%;
  margin-left: auto;
  margin-top: 130px;
}
@media (max-width: 1599px) {
  .spot-map__txt-wrap {
    width: 42%;
  }
}
@media (max-width: 1399px) {
  .spot-map__txt-wrap {
    display: none;
  }
}
.spot-map__txt-wrap.spot-map__txt-wrap-sp {
  display: none;
}
@media (max-width: 1399px) {
  .spot-map__txt-wrap.spot-map__txt-wrap-sp {
    display: block;
    width: 100%;
    max-width: none;
  }
}
@media (max-width: 1240px) {
  .spot-map__txt-wrap.spot-map__txt-wrap-sp {
    margin-top: 50px;
  }
}
@media (max-width: 639px) {
  .spot-map__txt-wrap.spot-map__txt-wrap-sp {
    margin-top: 30px;
  }
}
.spot-map__img-wrap {
  width: 1300px;
  height: auto;
  margin-left: 280px;
  margin-top: -230px;
  position: relative;
  z-index: -1;
}
@media (max-width: 1599px) {
  .spot-map__img-wrap {
    width: 1200px;
  }
}
@media (max-width: 1399px) {
  .spot-map__img-wrap {
    width: 1000px;
    margin-left: 260px;
  }
}
@media (max-width: 1240px) {
  .spot-map__img-wrap {
    width: 910px;
  }
}
@media (max-width: 1024px) {
  .spot-map__img-wrap {
    width: 1000px;
    margin-left: -130px;
  }
}
@media (max-width: 639px) {
  .spot-map__img-wrap {
    width: 758px;
  }
}
@media (max-width: 499px) {
  .spot-map__img-wrap {
    width: 597px;
  }
}
.spot-map__img-wrap::after {
  background: url(../img/sightseeing/mie-ttl.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 30%;
  aspect-ratio: 706/462;
  top: 230px;
  left: 15%;
  z-index: 1;
}
@media (max-width: 1399px) {
  .spot-map__img-wrap::after {
    left: 10%;
  }
}
@media (max-width: 1240px) {
  .spot-map__img-wrap::after {
    left: 11%;
  }
}
@media (max-width: 1024px) {
  .spot-map__img-wrap::after {
    left: 16%;
  }
}
@media (max-width: 834px) {
  .spot-map__img-wrap::after {
    width: 25%;
    top: 197px;
  }
}
@media (max-width: 639px) {
  .spot-map__img-wrap::after {
    left: 20%;
    top: 187px;
  }
}
@media (max-width: 499px) {
  .spot-map__img-wrap::after {
    left: 24%;
    top: 181px;
  }
}
.spot-map__img {
  display: block;
  width: 100%;
  height: auto;
  /* 地図画像のマスク */
  -webkit-mask-image: -webkit-gradient(linear, left top, right top, color-stop(-100%, rgba(0, 0, 0, 0)), color-stop(30%, rgb(0, 0, 0))), -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), color-stop(20%, rgb(0, 0, 0)));
  -webkit-mask-image: linear-gradient(to right, rgba(0, 0, 0, 0) -100%, rgb(0, 0, 0) 30%), linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 20%);
  mask-image: -webkit-gradient(linear, left top, right top, color-stop(-100%, rgba(0, 0, 0, 0)), color-stop(30%, rgb(0, 0, 0))), -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), color-stop(20%, rgb(0, 0, 0)));
  mask-image: linear-gradient(to right, rgba(0, 0, 0, 0) -100%, rgb(0, 0, 0) 30%), linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 20%);
  -webkit-mask-composite: source-in, xor;
  mask-composite: intersect;
}

/* 各ボタンレスポンシブ */
.spot-map__sp {
  margin-top: 750px;
}
@media (max-width: 1240px) {
  .spot-map__sp {
    margin-top: 660px;
  }
}
@media (max-width: 1024px) {
  .spot-map__sp {
    margin-top: 750px;
  }
}
@media (max-width: 639px) {
  .spot-map__sp {
    margin-top: 470px;
  }
}
@media (max-width: 499px) {
  .spot-map__sp {
    margin-top: 330px;
  }
}

.spot-map__btn--pc {
  display: block;
}
@media (max-width: 1240px) {
  .spot-map__btn--pc {
    display: none;
  }
}
.spot-map__btn--sp {
  display: none;
}
@media (max-width: 1240px) {
  .spot-map__btn--sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 5px;
  }
  .spot-map__btn--sp .map-btn01,
  .spot-map__btn--sp .map-btn02,
  .spot-map__btn--sp .map-btn03,
  .spot-map__btn--sp .map-btn04 {
    inset: unset;
    position: static;
    padding: 10px;
  }
}
@media (max-width: 1100px) {
  .spot-map__btn--sp {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px;
  }
}
@media (max-width: 639px) {
  .spot-map__btn--sp {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px 0;
  }
}
@media (max-width: 1100px) {
  .spot-map__btn--sp .map-btn01:hover,
  .spot-map__btn--sp .map-btn01.active {
    background-image: url(../img/sightseeing/area01-bg-sp.webp);
    background-size: cover;
  }
}
@media (max-width: 1100px) {
  .spot-map__btn--sp .map-btn02:hover,
  .spot-map__btn--sp .map-btn02.active {
    background-image: url(../img/sightseeing/area02-bg-sp.webp);
    background-size: cover;
  }
}
@media (max-width: 1100px) {
  .spot-map__btn--sp .map-btn03:hover,
  .spot-map__btn--sp .map-btn03.active {
    background-image: url(../img/sightseeing/area03-bg-sp.webp);
    background-size: cover;
  }
}
@media (max-width: 1100px) {
  .spot-map__btn--sp .map-btn04:hover,
  .spot-map__btn--sp .map-btn04.active {
    background-image: url(../img/sightseeing/area04-bg-sp.webp);
    background-size: cover;
  }
}
@media (max-width: 1100px) {
  .spot-map__btn--sp .map-btn {
    width: 48%;
    border-radius: calc(infinity * 1px);
  }
}
@media (max-width: 639px) {
  .spot-map__btn--sp .map-btn {
    width: 49%;
  }
}
.spot-map__btn--sp .map-btn .arrow-down-bl-white {
  margin-top: auto;
}
.spot-map__btn--sp .map-btn__head {
  margin-top: auto;
}

/* 各ボタン */
.map-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 240px;
  height: 240px;
  font-weight: bold;
  border-radius: 50%;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  color: var(--green);
  border: 1px solid var(--green);
}

@media (max-width: 1599px) {
  .map-btn {
    width: 200px;
    height: 200px;
  }
}
@media (max-width: 1240px) {
  .map-btn {
    width: 160px;
    height: 160px;
    gap: 0;
  }
}
@media (max-width: 639px) {
  .map-btn {
    width: 48%;
    border-radius: 50px;
  }
}
.map-btn:hover {
  color: #fff;
}

.map-btn:hover .arrow-down-bl-white {
  background-color: #fff;
}

.map-btn .arrow-down-bl-white {
  background-color: var(--green);
}

.map-btn__head {
  font-size: 16px;
  position: relative;
}
@media (max-width: 639px) {
  .map-btn__head {
    font-size: 11px;
  }
}

.map-btn__head::after {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #e0ddc0 1px, transparent 1px);
  background-size: 4px 4px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
}

.map-btn__head::after:hover {
  background-image: radial-gradient(circle, #fff 1px, transparent 1px);
}

.map-btn__txt {
  font-size: 15px;
  text-align: center;
}

@media (max-width: 1240px) {
  .map-btn__txt {
    font-size: 13px;
    line-height: 1.4;
  }
}
@media (max-width: 639px) {
  .map-btn__txt {
    font-size: 12px;
  }
}
.map-btn__txt span {
  margin-top: -5px;
  font-size: 28px;
}

@media (max-width: 1240px) {
  .map-btn__txt span {
    font-size: 23px;
  }
}
@media (max-width: 639px) {
  .map-btn__txt span {
    font-size: 20px;
  }
}
/* 伊勢エリア */
.map-btn01 {
  background: #fff;
  position: absolute;
  left: 3%;
  top: 395px;
}

@media (max-width: 1399px) {
  .map-btn01 {
    left: 0%;
    top: 295px;
  }
}
@media (max-width: 1240px) {
  .map-btn01 {
    top: 303px;
  }
}
@media (max-width: 1024px) {
  .map-btn01 {
    top: 295px;
  }
}
@media (max-width: 639px) {
  .map-btn01 {
    top: 135px;
    left: -3%;
  }
}
.map-btn01:hover,
.map-btn01.active {
  background-image: url(../img/sightseeing/area01-bg.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* 鳥羽エリア */
.map-btn02:hover,
.map-btn02.active {
  background-image: url(../img/sightseeing/area02-bg.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.map-btn02 {
  background: #fff;
  position: absolute;
  right: -1%;
  top: 400px;
}

@media (max-width: 1399px) {
  .map-btn02 {
    right: 29%;
    top: 79px;
  }
}
@media (max-width: 1024px) {
  .map-btn02 {
    top: 80px;
  }
}
@media (max-width: 639px) {
  .map-btn02 {
    right: 25%;
    top: -33px;
  }
}
@media (max-width: 499px) {
  .map-btn02 {
    right: 31%;
    top: -56px;
  }
}
/* 志摩エリア */
.map-btn03 {
  background: #fff;
  position: absolute;
  left: 7%;
  top: 688px;
}
@media (max-width: 1399px) {
  .map-btn03 {
    top: 488px;
    left: 13%;
  }
}
@media (max-width: 639px) {
  .map-btn03 {
    top: 288px;
    left: 3%;
  }
}
@media (max-width: 499px) {
  .map-btn03 {
    top: 291px;
    left: 12%;
  }
}

.map-btn03:hover,
.map-btn03.active {
  background-image: url(../img/sightseeing/area03-bg.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* 御座エリア */
.map-btn04 {
  background: #fff;
  position: absolute;
  right: 9%;
  top: 669px;
}

.map-btn04:hover,
.map-btn04.active {
  background-image: url(../img/sightseeing/area04-bg.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

@media (max-width: 1599px) {
  .map-btn04 {
    right: 2%;
    top: 749px;
  }
}
@media (max-width: 1399px) {
  .map-btn04 {
    top: 249px;
  }
}
@media (max-width: 1240px) {
  .map-btn04 {
    top: 159px;
  }
}
@media (max-width: 1024px) {
  .map-btn04 {
    right: 3%;
    top: 260px;
  }
}
@media (max-width: 834px) {
  .map-btn04 {
    right: -2%;
    top: 170px;
  }
}
@media (max-width: 639px) {
  .map-btn04 {
    top: 89px;
  }
}
@media (max-width: 499px) {
  .map-btn04 {
    top: 16px;
  }
}
/* マップアイコン */
.map-icon {
  width: 50px;
  height: auto;
  position: absolute;
  z-index: -1;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
}
@media (max-width: 1100px) {
  .map-icon {
    opacity: 1;
    visibility: visible;
  }
}

.map-icon01 {
  top: 510px;
  left: 530px;
}

.map-icon01.active {
  opacity: 1;
  visibility: visible;
}

@media (max-width: 1599px) {
  .map-icon01 {
    top: 450px;
    left: 470px;
  }
}
@media (max-width: 1399px) {
  .map-icon01 {
    top: 350px;
    left: 440px;
  }
}
@media (max-width: 1240px) {
  .map-icon01 {
    left: 387px;
    top: 320px;
  }
}
@media (max-width: 1024px) {
  .map-icon01 {
    left: 380px;
    top: 360px;
  }
}
@media (max-width: 639px) {
  .map-icon01 {
    left: 260px;
    top: 170px;
  }
}
@media (max-width: 499px) {
  .map-icon01 {
    left: 175px;
    top: 90px;
  }
}
.map-icon02 {
  top: 610px;
  left: 710px;
}

.map-icon02.active {
  opacity: 1;
  visibility: visible;
}

@media (max-width: 1599px) {
  .map-icon02 {
    top: 560px;
    left: 630px;
  }
}
@media (max-width: 1399px) {
  .map-icon02 {
    top: 440px;
    left: 560px;
  }
}
@media (max-width: 1240px) {
  .map-icon02 {
    top: 390px;
    left: 511px;
  }
}
@media (max-width: 1024px) {
  .map-icon02 {
    top: 430px;
    left: 511px;
  }
}
@media (max-width: 639px) {
  .map-icon02 {
    top: 230px;
    left: 361px;
  }
}
@media (max-width: 499px) {
  .map-icon02 {
    top: 140px;
    left: 253px;
  }
}
.map-icon03 {
  top: 740px;
  left: 560px;
}

.map-icon03.active {
  opacity: 1;
  visibility: visible;
}

@media (max-width: 1599px) {
  .map-icon03 {
    top: 690px;
    left: 520px;
  }
}
@media (max-width: 1399px) {
  .map-icon03 {
    top: 530px;
    left: 470px;
  }
}
@media (max-width: 1240px) {
  .map-icon03 {
    top: 470px;
    left: 410px;
  }
}
@media (max-width: 1024px) {
  .map-icon03 {
    left: 400px;
    top: 530px;
  }
}
@media (max-width: 639px) {
  .map-icon03 {
    left: 280px;
    top: 300px;
  }
}
@media (max-width: 499px) {
  .map-icon03 {
    left: 190px;
    top: 190px;
  }
}
.map-icon04 {
  top: 826px;
  left: 468px;
}

.map-icon04.active {
  opacity: 1;
  visibility: visible;
}

@media (max-width: 1599px) {
  .map-icon04 {
    top: 745px;
    left: 408px;
  }
}
@media (max-width: 1399px) {
  .map-icon04 {
    top: 592px;
    left: 385px;
  }
}
@media (max-width: 1240px) {
  .map-icon04 {
    left: 338px;
    top: 521px;
  }
}
@media (max-width: 1024px) {
  .map-icon04 {
    left: 321px;
    top: 590px;
  }
}
@media (max-width: 930px) {
  .map-icon04 {
    left: 328px;
  }
}
@media (max-width: 834px) {
  .map-icon04 {
    left: 339px;
  }
}
@media (max-width: 639px) {
  .map-icon04 {
    left: 219px;
    top: 344px;
  }
}
@media (max-width: 499px) {
  .map-icon04 {
    left: 137px;
    top: 218px;
  }
}
/* マップ設定 */
.cls-2.city:hover {
  cursor: pointer;
}

.city {
  fill: #62c0b4;
  -webkit-transition: fill 0.5s;
  transition: fill 0.5s;
}

.city.active {
  fill: #ffe33f;
}

/* 各観光地詳細 */
.spot .right-wrapper {
  position: relative;
  width: calc(100% - 480px);
  margin-left: 480px;
}
@media (max-width: 1399px) {
  .spot .right-wrapper {
    width: calc(100% - 380px);
    margin-left: 380px;
  }
}
@media (max-width: 1024px) {
  .spot .right-wrapper {
    width: 95%;
    margin-left: 5%;
  }
}

.spot {
  background-image: url(../img/sightseeing/spot-bg.webp);
  background-size: cover;
  padding-top: 210px;
  z-index: 1;
  background-size: 100%;
  position: relative;
  /* セクション区切りアイコン */
  /* 各見出し画像 */
}
@media (max-width: 834px) {
  .spot {
    padding-top: 180px;
  }
}
@media (max-width: 499px) {
  .spot {
    padding-top: 160px;
  }
}
.spot::before {
  background: url(../img/sightseeing/spot-map-icon01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 16%;
  aspect-ratio: 514/288;
  top: -24px;
  left: 45%;
  z-index: 0;
}
@media (max-width: 1024px) {
  .spot::before {
    left: 19%;
    width: 152px;
  }
}
@media (max-width: 834px) {
  .spot::before {
    left: 5%;
  }
}
@media (max-width: 499px) {
  .spot::before {
    width: 33%;
  }
}
.spot::after {
  background: url(../img/sightseeing/spot-map-icon02.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 28%;
  aspect-ratio: 1087/388;
  top: 20px;
  right: 4%;
  z-index: 0;
}
@media (max-width: 1024px) {
  .spot::after {
    width: 267px;
  }
}
@media (max-width: 499px) {
  .spot::after {
    width: 52% !important;
    top: 0;
  }
}
.spot__ttl-ise {
  width: 253px;
}
@media (max-width: 639px) {
  .spot__ttl-ise {
    width: 183px;
  }
}
.spot__ttl-toba {
  width: 247px;
}
@media (max-width: 639px) {
  .spot__ttl-toba {
    width: 183px;
  }
}
.spot__ttl-shima {
  width: 248px;
}
@media (max-width: 639px) {
  .spot__ttl-shima {
    width: 183px;
  }
}
.spot__ttl-goza {
  width: 231px;
}
@media (max-width: 639px) {
  .spot__ttl-goza {
    width: 183px;
  }
}
.spot__item {
  border-radius: 20px 0 0 20px;
  background: #fff;
  padding: 80px 8%;
  position: relative;
}
@media (max-width: 499px) {
  .spot__item {
    padding: 40px 8%;
  }
}
.spot__item + .spot__item {
  margin-top: 145px;
}
@media (max-width: 499px) {
  .spot__item + .spot__item {
    margin-top: 120px;
  }
}
.spot__ttl {
  position: absolute;
  left: 50px;
  top: -90px;
}
@media (max-width: 639px) {
  .spot__ttl {
    top: -64px;
    left: 8%;
  }
}

.spot-top {
  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;
  margin-bottom: 40px;
}
.spot-top-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media (max-width: 1240px) {
  .spot-top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 499px) {
  .spot-top {
    margin-bottom: 20px;
  }
}
.spot-top__img {
  width: 60%;
}
@media (max-width: 1240px) {
  .spot-top__img {
    width: 100%;
    margin-bottom: 24px;
  }
}
@media (max-width: 499px) {
  .spot-top__img {
    margin-bottom: 16px;
  }
}
.spot-top__txt-wrap {
  width: 36%;
}
@media (max-width: 1240px) {
  .spot-top__txt-wrap {
    width: 100%;
  }
}
.spot-top__head {
  font-size: 26px;
  font-weight: bold;
  margin-bottom: 32px;
}
@media (max-width: 639px) {
  .spot-top__head {
    margin-bottom: 12px;
  }
}
@media (max-width: 499px) {
  .spot-top__head {
    line-height: 1.3;
    font-size: 20px;
    margin-bottom: 6px;
  }
}
.spot-top__head span {
  font-size: 42px;
}
@media (max-width: 499px) {
  .spot-top__head span {
    font-size: 28px;
  }
}
.spot-top__txt {
  font-size: 16px;
}

.spot-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 3%;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: -32px;
}
@media (max-width: 1240px) {
  .spot-body {
    margin-bottom: -20px;
  }
}
@media (max-width: 639px) {
  .spot-body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.spot-body > li {
  width: 31.3%;
  margin-bottom: 32px;
}
@media (max-width: 1240px) {
  .spot-body > li {
    width: 48.3%;
    margin-bottom: 20px;
  }
}
@media (max-width: 639px) {
  .spot-body > li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    gap: 4%;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media (max-width: 639px) {
  .spot-body__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 63%;
  }
}
.spot-body__img {
  width: 100%;
  aspect-ratio: 320/230;
}
@media (max-width: 639px) {
  .spot-body__img {
    width: 48%;
  }
}
.spot-body__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.spot-body__ttl {
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  margin: 8px 0 2px;
}
@media (max-width: 834px) {
  .spot-body__ttl {
    line-height: 1.4;
  }
}
@media (max-width: 639px) {
  .spot-body__ttl {
    margin: 0px 0 4px;
    text-align: left;
  }
}
@media (max-width: 499px) {
  .spot-body__ttl {
    font-size: 18px;
  }
}
.spot-body__info {
  font-size: 15px;
  margin-bottom: -4px;
}
@media (max-width: 639px) {
  .spot-body__info {
    font-size: 13px;
  }
}
.spot-body__info li {
  margin-bottom: 4px;
}
.spot-body__info li:first-child {
  position: relative;
  padding-left: 28px;
}
.spot-body__info li:first-child:before {
  position: absolute;
  top: -8px;
  left: 0;
  font-family: "Material Icons";
  content: "\e0c8";
  color: var(--green);
  font-size: 22px;
}
.spot-body__info li:last-child {
  position: relative;
  padding-left: 28px;
}
.spot-body__info li:last-child:before {
  position: absolute;
  top: -8px;
  left: 0;
  font-family: "Material Icons";
  content: "\e531";
  color: var(--green);
  font-size: 22px;
}
.spot-body__umaise-wrap {
  width: 56% !important;
  margin-left: auto;
}
@media (max-width: 1240px) {
  .spot-body__umaise-wrap {
    width: 100% !important;
  }
}
.spot-body__umaise-img {
  aspect-ratio: auto;
  max-width: 500px;
  margin: 0 auto !important;
}
@media (max-width: 639px) {
  .spot-body__umaise-img {
    max-width: none;
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}

/* 志摩 */
.spot__shima {
  position: relative;
}
.spot__shima::before {
  background: url(../img/sightseeing/shima-icon01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 16%;
  aspect-ratio: 413/251;
  top: -45px;
  right: 23%;
  z-index: 1;
}
@media (max-width: 1240px) {
  .spot__shima::before {
    width: 133px;
    right: 25%;
  }
}
@media (max-width: 639px) {
  .spot__shima::before {
    width: 20%;
  }
}
@media (max-width: 499px) {
  .spot__shima::before {
    width: 18%;
    right: 22%;
  }
}
.spot__shima::after {
  background: url(../img/sightseeing/shima-icon02.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 14%;
  aspect-ratio: 308/283;
  top: -38px;
  right: 3%;
  z-index: 1;
}
@media (max-width: 1240px) {
  .spot__shima::after {
    width: 111px;
  }
}
@media (max-width: 639px) {
  .spot__shima::after {
    width: 17%;
  }
}

/* グルメ・ショッピング施設 */
.spot-gourmet-shopping {
  margin-top: 12px;
}
.spot-gourmet-shopping__ttl {
  font-size: 30px;
  position: relative;
  padding-bottom: 8px;
  margin-bottom: 29px;
  /* アイコン */
  /* ドット下線 */
}
@media (max-width: 639px) {
  .spot-gourmet-shopping__ttl {
    font-size: 26px;
  }
}
@media (max-width: 499px) {
  .spot-gourmet-shopping__ttl {
    font-size: 22px;
  }
}
.spot-gourmet-shopping__ttl:before {
  content: "";
  display: inline-block;
  width: 58px;
  height: 56px;
  margin-right: 10px;
  background-image: url(../img/sightseeing/spot-gourmet-shopping-ttl.webp);
  background-size: cover;
  background-position: center;
  position: relative;
  top: 12px;
  left: 0;
}
@media (max-width: 639px) {
  .spot-gourmet-shopping__ttl:before {
    width: 45px;
    height: 43px;
  }
}
.spot-gourmet-shopping__ttl:after {
  content: "";
  display: block;
  height: 6px;
  background-image: radial-gradient(circle, var(--green) 2px, transparent 1px);
  background-size: 6px 6px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0px;
}

.spot-body__umaise-wrap .spot-body__img {
  width: 100%;
}

/*******************************************************
 * コンセプト
 *******************************************************/
/* イントロ */
.concept-intro {
  position: relative;
  font-weight: bold;
  overflow: hidden;
  margin-top: -177px;
  padding-bottom: 180px;
}
@media (max-width: 1024px) {
  .concept-intro {
    margin-top: -117px;
  }
}
@media (max-width: 639px) {
  .concept-intro {
    margin-top: -138px;
  }
}
@media (max-width: 499px) {
  .concept-intro {
    padding-bottom: 170px;
  }
}
.concept-intro__main .right-wrapper {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 70px;
}
@media (max-width: 499px) {
  .concept-intro__main .right-wrapper {
    margin-top: 48px;
  }
}
.concept-intro__ttl {
  width: 39%;
  margin-bottom: 38px;
  margin-top: 120px;
}
@media (max-width: 1024px) {
  .concept-intro__ttl {
    margin-top: 48px;
  }
}
@media (max-width: 639px) {
  .concept-intro__ttl {
    width: 60%;
    margin-top: 88px;
  }
}
@media (max-width: 499px) {
  .concept-intro__ttl {
    width: 70%;
    font-size: 23px;
    margin-bottom: 20px;
  }
}
.concept-intro__heading {
  font-size: 32px;
  margin-bottom: 70px;
}
@media (max-width: 1599px) {
  .concept-intro__heading {
    margin-bottom: 35px;
  }
}
@media (max-width: 1240px) {
  .concept-intro__heading {
    font-size: 26px;
  }
}
@media (max-width: 834px) {
  .concept-intro__heading {
    font-size: 23px;
  }
}
@media (max-width: 499px) {
  .concept-intro__heading {
    margin-bottom: 20px;
  }
}
.concept-intro__txt {
  font-size: 18px;
  line-height: 2.4;
}
@media (max-width: ) {
  .concept-intro__txt {
    line-height: 2;
  }
}
@media (max-width: 834px) {
  .concept-intro__txt {
    font-size: 16px;
  }
}
@media (max-width: 499px) {
  .concept-intro__txt {
    font-size: 15px;
    line-height: 2;
  }
}
.concept-intro__img {
  position: absolute;
  display: inline-block;
  overflow: visible;
}
.concept-intro__img img {
  border-radius: 20px;
}
.concept-intro__img01 {
  right: -1%;
  width: 24%;
}
@media (max-width: 1024px) {
  .concept-intro__img01 {
    right: -3%;
    width: 33%;
  }
}
@media (max-width: 639px) {
  .concept-intro__img01 {
    right: -4%;
  }
}
.concept-intro__img02 {
  right: 9%;
  top: 27vw;
  width: 12%;
}
@media (max-width: 1599px) {
  .concept-intro__img02 {
    right: 6%;
  }
}
@media (max-width: 1024px) {
  .concept-intro__img02 {
    width: 18%;
    right: 6%;
    top: 38vw;
  }
}
@media (max-width: 834px) {
  .concept-intro__img02 {
    top: 62vw;
  }
}
@media (max-width: 639px) {
  .concept-intro__img02 {
    right: 5%;
    top: 55vw;
  }
}
@media (max-width: 499px) {
  .concept-intro__img02 {
    width: 22%;
    right: -4%;
    top: 97vw;
  }
}
@media (max-width: 399px) {
  .concept-intro__img02 {
    top: 111vw;
  }
}
.concept-intro__img02::after {
  background: url(../img/concept/intro-icon02-01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 50%;
  aspect-ratio: 226/310;
  bottom: -6.5vw;
  right: 0;
  z-index: 1;
}
@media (max-width: 499px) {
  .concept-intro__img02::after {
    width: 60%;
    left: 10px;
    bottom: -12.5vw;
  }
}
.concept-intro__img03 {
  right: 61px;
  bottom: 21px;
  width: 17%;
  overflow: visible;
}
@media (max-width: 1599px) {
  .concept-intro__img03 {
    right: 48px;
  }
}
@media (max-width: 1240px) {
  .concept-intro__img03 {
    right: -15px;
  }
}
@media (max-width: 1024px) {
  .concept-intro__img03 {
    right: 33px;
    width: 28%;
  }
}
@media (max-width: 499px) {
  .concept-intro__img03 {
    right: -13px;
    width: 39%;
    bottom: 5px;
  }
}
.concept-intro__img03::after {
  background: url(../img/concept/intro-icon03-01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 46%;
  aspect-ratio: 274/126;
  bottom: -1vw;
  left: -4vw;
  z-index: 1;
}
.concept-intro__img04 {
  left: 481px;
  top: 14vw;
  width: 14%;
  overflow: visible;
}
@media (max-width: 1399px) {
  .concept-intro__img04 {
    left: 377px;
  }
}
@media (max-width: 1024px) {
  .concept-intro__img04 {
    left: 47px;
    width: 20%;
  }
}
@media (max-width: 639px) {
  .concept-intro__img04 {
    top: 28vw;
    left: -24px;
  }
}
@media (max-width: 499px) {
  .concept-intro__img04 {
    left: -39px;
    top: 28vw;
    width: 25%;
  }
}
.concept-intro__img04::after {
  background: url(../img/concept/intro-icon04-01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 53%;
  aspect-ratio: 248/434;
  bottom: -8.5vw;
  right: -5vw;
  z-index: 1;
}
@media (max-width: 1240px) {
  .concept-intro__img04::after {
    width: 47%;
    right: -2vw;
  }
}
@media (max-width: 499px) {
  .concept-intro__img04::after {
    width: 55%;
  }
}
.concept-intro__img05 {
  left: 496px;
  top: 43vw;
  width: 17%;
  overflow: visible;
}
@media (max-width: 1599px) {
  .concept-intro__img05 {
    left: 481px;
  }
}
@media (max-width: 1399px) {
  .concept-intro__img05 {
    left: 381px;
    top: 46vw;
  }
}
@media (max-width: 1240px) {
  .concept-intro__img05 {
    left: 352px;
    top: 51vw;
  }
}
@media (max-width: 1024px) {
  .concept-intro__img05 {
    width: 27%;
    left: -18px;
    top: 53vw;
  }
}
@media (max-width: 834px) {
  .concept-intro__img05 {
    top: 64vw;
  }
}
@media (max-width: 639px) {
  .concept-intro__img05 {
    top: 92vw;
    left: -29px;
    width: 30%;
  }
}
@media (max-width: 499px) {
  .concept-intro__img05 {
    width: 33%;
    top: 106vw;
    left: -57px;
  }
}
@media (max-width: 399px) {
  .concept-intro__img05 {
    top: 118vw;
  }
}
.concept-intro__img05::after {
  background: url(../img/concept/intro-icon05-01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 57%;
  aspect-ratio: 434/248;
  top: -3vw;
  left: 1vw;
  z-index: 1;
}
/* メインコンテンツ */
.concept-content {
  background-image: url(../img/concept/content-bg.webp);
  background-size: cover;
  padding-top: 190px;
  margin-top: -165px;
}
.concept-content__list {
  position: relative;
  margin-top: 50px;
}
.concept-content__list::before {
  background: url(../img/concept/cont-icon01.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 24%;
  aspect-ratio: 516/366;
  top: -16vw;
  left: 4vw;
  z-index: 1;
}
@media (max-width: 1240px) {
  .concept-content__list::before {
    width: 25%;
  }
}
@media (max-width: 1024px) {
  .concept-content__list::before {
    top: -18vw;
  }
}
@media (max-width: 639px) {
  .concept-content__list::before {
    width: 32%;
    top: -25vw;
  }
}
@media (max-width: 499px) {
  .concept-content__list::before {
    width: 40%;
  }
}
.concept-content__list::after {
  background: url(../img/concept/cont-icon02.webp) no-repeat center;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  width: 24%;
  aspect-ratio: 516/366;
  top: -4vw;
  right: 4vw;
  z-index: 1;
}
@media (max-width: 1240px) {
  .concept-content__list::after {
    width: 25%;
    top: -6vw;
  }
}
@media (max-width: 1240px) {
  .concept-content__list::after {
    top: -8vw;
  }
}
@media (max-width: 639px) {
  .concept-content__list::after {
    width: 32%;
  }
}
@media (max-width: 499px) {
  .concept-content__list::after {
    width: 40%;
  }
}
.concept-content__item {
  background: #fff;
  border-radius: 20px;
}
.concept-content__item + .concept-content__item {
  margin-top: 60px;
}
@media (max-width: 499px) {
  .concept-content__item + .concept-content__item {
    margin-top: 30px;
  }
}
.concept-content__item01 {
  padding-bottom: 80px;
}
@media (max-width: 499px) {
  .concept-content__item01 {
    padding-bottom: 40px;
  }
}
.concept-content__flex-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 1240px) {
  .concept-content__flex-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.concept-content__item01-img {
  width: 47%;
  max-width: 500px;
}
@media (max-width: 1240px) {
  .concept-content__item01-img {
    width: 100%;
    max-width: 389px;
    margin-top: 40px;
  }
}
@media (max-width: 639px) {
  .concept-content__item01-img {
    width: 90%;
    max-width: auto;
  }
}
@media (max-width: 499px) {
  .concept-content__item01-img {
    margin-top: 20px;
  }
}
.concept-content__item01-head-txt-wrap {
  width: 47%;
}
@media (max-width: 1240px) {
  .concept-content__item01-head-txt-wrap {
    width: 100%;
  }
}
.concept-content__head {
  font-size: clamp(12px, 1.7vw, 15px);
  position: relative;
  display: inline-block;
}
.concept-content__head::after {
  content: "";
  display: block;
  height: 4px;
  background-image: radial-gradient(circle, #d2cfad 1px, transparent 1px);
  background-size: 4px 4px;
  margin: 0 auto;
  background-repeat: repeat;
  width: 100%;
  position: absolute;
  bottom: 0px;
  left: 0px;
}
.concept-content__lead {
  margin: 16px 0 51px;
  font-size: 32px;
  font-weight: bold;
  line-height: 1.5;
}
@media (max-width: 1240px) {
  .concept-content__lead {
    margin: 15px 0 21px;
  }
}
@media (max-width: 639px) {
  .concept-content__lead {
    font-size: 24px;
  }
}
@media (max-width: 499px) {
  .concept-content__lead {
    margin: 10px 0;
    font-size: 20px;
  }
}
.concept-content__lead span {
  font-size: 42px;
}
@media (max-width: 639px) {
  .concept-content__lead span {
    font-size: 27px;
  }
}
@media (max-width: 399px) {
  .concept-content__lead span {
    font-size: 24px;
  }
}
.concept-content__txt {
  font-size: clamp(14px, 1.7vw, 16px);
}
@media (max-width: 499px) {
  .concept-content__txt {
    text-align: left;
  }
}
.concept-content__inner {
  padding: 80px 5%;
}
@media (max-width: 499px) {
  .concept-content__inner {
    padding: 40px 7%;
  }
}

/* スライダー */
.concept-slider01-wrap {
  overflow: hidden;
}

.concept-swiper img {
  border-radius: 20px;
}
.concept-swiper .swiper-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

/* 滞在そのものが旅になる */
.concept-content__item02-head-txt-wrap {
  text-align: center;
}
.concept-content__item02-list {
  margin-top: 73px;
}
@media (max-width: 639px) {
  .concept-content__item02-list {
    margin-top: 60px;
  }
}
@media (max-width: 499px) {
  .concept-content__item02-list {
    margin-top: 40px;
  }
}
@media (max-width: 1240px) {
  .concept-content__item02-list .concept-content__flex-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.concept-content__item02-item + .concept-content__item02-item {
  margin-top: 100px;
}
@media (max-width: 834px) {
  .concept-content__item02-item + .concept-content__item02-item {
    margin-top: 88px;
  }
}
@media (max-width: 639px) {
  .concept-content__item02-item + .concept-content__item02-item {
    margin-top: 60px;
  }
}
.concept-content__flex-item-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media (max-width: 1240px) {
  .concept-content__flex-item-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.concept-content__item02-img {
  overflow: visible;
  position: relative;
}
.concept-content__item02-img img {
  border-radius: 20px;
}
@media (max-width: 1240px) {
  .concept-content__item02-img {
    width: 100%;
    margin-bottom: 20px;
  }
}
@media (max-width: 499px) {
  .concept-content__item02-img {
    margin-bottom: 10px;
  }
}
.concept-content__item02-img01 {
  position: relative;
}
.concept-content__item02-img-wrap {
  position: relative;
  width: 48%;
}
@media (max-width: 1240px) {
  .concept-content__item02-img-wrap {
    width: 100%;
  }
}
.concept-content__item02-ttl {
  position: absolute;
  top: -2vw;
  left: 18px;
}
@media (max-width: 1240px) {
  .concept-content__item02-ttl {
    top: -4vw;
  }
}
.concept-content__item02-ttl.concept-content__item02-ttl02 {
  left: auto;
  right: 18px;
}
.concept-content__item02-ttl01 {
  width: 50%;
}
@media (max-width: 1024px) {
  .concept-content__item02-ttl01 {
    width: 37%;
  }
}
@media (max-width: 499px) {
  .concept-content__item02-ttl01 {
    width: 50%;
  }
}
.concept-content__item02-ttl02 {
  width: 54%;
}
@media (max-width: 1024px) {
  .concept-content__item02-ttl02 {
    width: 40%;
  }
}
@media (max-width: 499px) {
  .concept-content__item02-ttl02 {
    width: 54%;
  }
}
.concept-content__item02-ttl03 {
  width: 54%;
}
@media (max-width: 1024px) {
  .concept-content__item02-ttl03 {
    width: 39%;
  }
}
@media (max-width: 499px) {
  .concept-content__item02-ttl03 {
    width: 54%;
  }
}
.concept-content__item02-txt-wrap {
  width: 48%;
}
@media (max-width: 1240px) {
  .concept-content__item02-txt-wrap {
    width: 100%;
  }
}
.concept-content__item02-txt-ttl {
  font-size: clamp(20px, 1.7vw, 24px);
  font-weight: bold;
}
@media (max-width: 499px) {
  .concept-content__item02-txt-ttl {
    text-align: center;
  }
}
.concept-content__item02-txt {
  font-size: clamp(14px, 1.7vw, 16px);
  margin: 28px 0 36px;
}
@media (max-width: 1240px) {
  .concept-content__item02-txt {
    margin: 20px 0 20px;
  }
}
@media (max-width: 499px) {
  .concept-content__item02-txt {
    margin: 0 0 16px;
  }
}

@media (max-width: 499px) {
  #concept .base__link {
    width: 100%;
  }
}/*# sourceMappingURL=under01.css.map */