/* TOPページ */
/*.top_slid {padding-top: 80px;}
@media screen and (max-width:896px) {
.top_slid {padding-top: 0;}
}*/
.top_mv {
  position: relative;
}
.top_mv img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
}
.top_mv h2 {
  color: #fff;
  /* width: 100%; */
  /* line-height: 1.5; */
  font-weight: bold;
  /* text-shadow: #222 1px 1px 10px, #222 -1px 1px 10px; */
  position: absolute;
  /* top: 55%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  font-size: 4rem; */
}
@media screen and (max-width: 896px) {
  .top_mv img {
    height: 280px;
  }
  img.slide_position {
    object-position: 15% 50%;
  }
  .top_mv h2 {
    font-size: 2.3rem;
  }
  .top_mv h2 span {
    font-size: 1.6rem;
    margin-left: -6px;
  }
}
.top_view .container {
  display: flex;
  align-items: center;
  height: 100%;
}
.top_news {
  background: #fff;
}
.top_news img {
  width: 100%;
}
.top_news ul li span.cate {
  background: #fff;
  padding: 4px 10px;
  margin-right: 30px;
  font-size: 1.4rem;
  color: #222;
}
@media screen and (max-width: 896px) {
  .top_news ul li span.cate {
    padding: 1% 2%;
    font-size: 1.2rem;
  }
}
.top_news ul li span.cate a {
  color: #fff;
}
/*厳選コンテンツ*/
/* .top_pickup_list {
  padding: 80px 0;
}
.top_pickup_list h2 {
  margin-bottom: 30px;
}
.top_pickup_list ul li {
  width: 32%;
  margin: 30px 10px;
  text-align: left;
  background: #fff;
  height: 430px;
}
.top_pickup_list ul li h3 {
  padding: 20px 20px 10px;
  text-align: left;
  font-size: 18px;
  font-weight: bold;
}
.top_pickup_list p.top_pickup_img img {
  width: 100%;
  height: 240px;
  object-fit: cover;
}
@media screen and (min-width: 1800px) {
  .top_pickup_list ul li {
    margin: 30px 20px;
  }
  .top_pickup_list p.top_pickup_img img {
  width: 100%;
  height: 370px;
  object-fit: cover;
}
}
.top_pickup_list p.top_pickup_text {
  padding: 0 20px 30px;
} */
/* ------------------------------
   20240220追記
------------------------------ */
.top_slid {
  /*  margin-top: 80px;*/
  position: relative;
}
@media screen and (max-width: 896px) {
  .top_slid {
    margin-top: 60px;
    height: 310px;
  }
}
/* ===================================================
MV
=================================================== */
.top_mv h2 {
  font-family: "Dancing Script", cursive;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: min(6vw, 80px);
  line-height: 1.3;
  text-shadow: 0px 2px 10px rgba(53, 107, 142, 0.49);
  text-align: left;
  letter-spacing: 0.08em;
  margin: auto 0;
  inset: 0 auto 0 8%;
  width: fit-content;
  height: fit-content;
  z-index: 1;
}
.top_mv h2 .sbttl {
  display: block;
  letter-spacing: 0;
  font-size: 26px;
}
.top_mv h2:after {
  content: "";
  background: url(../img/top/mv_en.png) no-repeat center / contain;
  width: 385px;
  height: 99px;
  position: absolute;
  right: -110px;
  bottom: -43px;
}
@media screen and (max-width: 896px) {
  .top_mv h2 {
    font-size: 50px;
    left: 15px;
    margin: 80px auto;
  }
  .top_mv h2 .sbttl {
    font-size: 16px;
  }
  .top_mv h2:after {
    width: 220px;
    height: 68px;
    right: 83px;
    bottom: -39px;
  }
}
/* ===================================================
お知らせ
=================================================== */
.top_news {
  display: flex;
  margin-top: -60px;
  width: 830px;
  max-width: 90%;
  position: relative;
  z-index: 1;
}
.top_news h2 {
  font-size: 26px;
  color: #656565;
  margin-bottom: 10px;
}
.top_news ul {
  background-color: #fcfcfc;
  padding: 20px 45px;
  width: 830px;
}
.top_news ul li {
  border-bottom: 1px dotted #424242;
  font-size: 14px;
  display: flex;
  gap: 20px;
  line-height: 1.7;
  padding: 10px 0 5px;
}
.top_news ul li span.date {
  flex-shrink: 0;
}
.top_news_list {
  background: rgb(234, 234, 234);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 10px 50px;
}
.top_news_list a {
  border: 1px solid #656565;
  color: #656565;
  font-size: 10px;
  text-align: center;
  padding: 5px 30px;
  position: relative;
}
.top_news_list a:after {
  content: "";
  mask: url(../img/common/ico_arrow.svg) no-repeat center / contain;
  background-color: #656565;
  width: 9px;
  height: 9px;
  position: absolute;
  margin: auto 0;
  inset: 0 7px 0 auto;
}
@media screen and (max-width: 896px) {
  .top_news {
    flex-direction: column;
    margin-top: -30px;
    /*max-width: calc(100% - 15px);*/
    max-width: 100%;
  }
  .top_news ul {
    max-width: calc(100% - 0px);
  }
  .top_news h2 {
    font-size: 20px;
    margin-bottom: 0;
  }
  .top_news_list {
    flex-direction: row;
    justify-content: space-between;
    padding: 20px 15px;
  }
  .top_news ul {
    padding: 10px 15px 20px;
  }
  .top_news ul li {
    font-size: 12px;
    flex-direction: column;
    gap: 0;
  }
}
/* ===================================================
location
=================================================== */
.top_location {
  margin-top: 85px;
  display: flex;
  gap: 5.67%;
}
.top_location_img {
  flex-shrink: 0;
  width: 45%;
  text-align: center;
}
.top_location h2 {
  text-align: left;
}
.top_location_txt {
  padding-top: 55px;
  padding-right: 6%;
  width: 55%;
  position: relative;
  z-index: 0;
}
.top_location_txt:after {
  content: "";
  background-color: #f0f8fb;
  width: 30.31vw;
  height: 21.67vw;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: -1;
}
.top_location_txt .txt--en {
  margin-bottom: 10px;
}
@media screen and (max-width: 896px) {
  .top_location {
    margin-top: 70px;
    flex-direction: column;
    gap: 40px;
    padding: 0 15px;
  }
  .top_location_img {
    width: 100%;
  }
  .top_location_txt {
    padding-top: 0;
    padding-right: 0;
    padding-bottom: 60px;
    width: 100%;
  }
  .top_location_txt:after {
    top: 245px;
    right: -15px;
    width: 65vw;
    height: auto;
  }
  .top_location_txt .txt--en img {
    width: 322px;
  }
}
/* ===================================================
EXPREIENCE
=================================================== */
.top_expreience {
  margin-top: 180px;
  position: relative;
}
.top_expreience:before {
  content: "";
  background: rgb(227, 235, 150);
  background: linear-gradient(120deg, rgba(227, 235, 150, 1) 0%, rgba(220, 235, 150, 1) 26%, rgba(219, 235, 151, 1) 35%, rgba(226, 234, 150, 1) 54%, rgba(237, 232, 149, 1) 78%, rgba(254, 249, 228, 1) 100%);
  height: 278px;
  position: absolute;
  inset: auto -50px 0;
  z-index: -1;
  opacity: 0.73;
}
@media screen and (max-width: 896px) {
  .top_expreience {
    margin-top: 70px;
  }
  .top_expreience:before {
    display: none;
  }
}
/* ===================================================
EXPREIENCE　アンカー
=================================================== */
.top_expreience {
  overflow: hidden;
}
.top_expreience .anchor {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 2%;
  padding-bottom: 110px;
  position: relative;
}
.top_expreience .anchor--item {
  width: calc(100% / 3);
}
.top_expreience .anchor a {
  display: block;
}
.top_expreience .anchor .txt_head {
  text-align: center;
  margin-bottom: 30px;
}
.top_expreience .anchor .txt_head img {
  margin: 0 auto 10px;
}
.top_expreience .anchor .txt_head span {
  display: block;
}
.top_expreience .anchor .txt_head .en {
  font-family: "PT Sans", sans-serif;
  font-size: 40px;
  color: #c7cb65;
  font-weight: 700;
  letter-spacing: 0;
}
.top_expreience .anchor .txt_head .ja {
  font-size: 16px;
  margin-top: 5px;
}
.top_expreience_section {
  margin-top: 100px;
  scroll-margin-top: 180px;
}
.top_expreience_section .sbttl {
  font-size: 18px;
}
.top_expreience_section h2 {
  font-size: min(1.803vw, 30px);
  text-align: left;
  margin-bottom: 30px;
}
@media (max-width: 1350px) {
  .top_expreience_section h2 {
    font-size: 22px;
  }
}
@media screen and (max-width: 896px) {
  .top_expreience_section {
    margin-top: 70px;
    scroll-margin-top: 130px;
  }
  .top_expreience .anchor {
    flex-direction: column;
    align-items: center;
    gap: 40px;
    padding-bottom: 0;
  }
  .top_expreience .anchor--item {
    width: fit-content;
    position: relative;
    padding: 0 15px 50px;
    margin: 0 -15px;
    position: relative;
  }
  .top_expreience .anchor--item:before {
    content: "";
    background: rgb(227, 235, 150);
    background: linear-gradient(120deg, rgba(227, 235, 150, 1) 0%, rgba(220, 235, 150, 1) 26%, rgba(219, 235, 151, 1) 35%, rgba(226, 234, 150, 1) 54%, rgba(237, 232, 149, 1) 78%, rgba(254, 249, 228, 1) 100%);
    height: 160px;
    position: absolute;
    inset: auto -50vw 0;
    z-index: -1;
    opacity: 0.73;
  }
  .top_expreience .anchor .txt_head img {
    width: 40px;
    height: 40px;
  }
  .top_expreience .anchor .txt_head .en {
    font-size: 30px;
  }
  .top_expreience .anchor .txt_head .ja {
    font-size: 13px;
  }
}
/* ===================================================
EXPREIENCE共通
=================================================== */
.top_expreience_section--lead {
  display: flex;
  align-items: flex-start;
}
.top_expreience_section--lead .img {
  text-align: center;
  width: 57.67%;
}
.top_expreience_section--lead .txt {
  margin-left: -75px;
  width: calc(100% - 57.67% + 75px);
  min-width: 500px;
  position: relative;
}
.top_expreience_section--lead .txt_inner {
  background-color: #fff;
  position: relative;
  padding: 68px 65px;
  z-index: 0;
}
.top_expreience_section--lead .txt_inner:before {
  content: "";
  border: 2px solid #999;
  position: absolute;
  inset: 15px;
}
.top_expreience_section--lead .txt_head {
  margin-bottom: -27px;
  margin-left: 95px;
  position: relative;
  z-index: 1;
}
.top_expreience_section--lead .txt_head span {
  display: block;
}
.top_expreience_section--lead .txt_head .ja {
  font-size: 16px;
}
.top_expreience_section--lead .txt_head .en {
  font-family: "PT Sans", sans-serif;
  font-size: 90px;
  color: #c7cb65;
  font-weight: 700;
  letter-spacing: 0;
  background: rgb(13, 74, 140);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: fit-content;
  opacity: 0.6;
}
.top_expreience_section--lead .btn a {
  font-size: 15px;
  line-height: 2rem;
}
@media screen and (max-width: 896px) {
  .top_expreience_section--lead {
    flex-direction: column;
    align-items: normal;
    gap: 30px;
  }
  .top_expreience_section--lead .img {
    width: 100%;
  }
  .top_expreience_section--lead .txt {
    margin-left: 0;
    width: 100%;
    min-width: auto;
  }
  .top_expreience_section--lead .txt_inner {
    padding: 50px 20px;
  }
  .top_expreience_section--lead .txt_inner:before {
    inset: 10px;
  }
  .top_expreience_section--lead .txt_head {
    margin-bottom: -17px;
    margin-left: 30px;
  }
  .top_expreience_section--lead .txt_head .ja {
    font-size: 11px;
  }
  .top_expreience_section--lead .txt_head .en {
    font-size: 40px;
  }
  .top_expreience_section .sbttl {
    font-size: 15px;
    line-height: 1.5;
  }
}
/* ===================================================
食べる
=================================================== */
.top_eat h3 {
  font-size: 28px;
  margin-bottom: 40px;
  text-align: center;
}
.top_eat--menu {
  margin-top: 100px;
  padding-bottom: 60px;
  position: relative;
}
.top_eat--menu:before {
  content: "";
  background: url(../img/common/pt_g.png) repeat 0 0;
  height: 485px;
  overflow-x: hidden;
  position: absolute;
  inset: auto -50vw 0;
  z-index: -1;
}
.top_eat--menu-inner {
  display: flex;
  gap: 2%;
}
.top_eat--menu-item {
  width: calc(100% / 3);
}
.top_eat--menu-item .txt {
  text-align: center;
}
.top_eat--menu-item .txt_head {
  font-size: 22px;
  font-weight: 500;
  margin: 10px 0 20px;
}
@media screen and (max-width: 896px) {
  .top_eat h3 {
    font-size: 18px;
    margin-bottom: 35px;
    line-height: 1.5;
  }
  .top_eat--menu {
    margin-top: 60px;
    padding-bottom: 40px;
  }
  .top_eat--menu:before {
    height: auto;
    inset: 150px -20px 0;
  }
  .top_eat--menu-inner {
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }
  .top_eat--menu-item {
    width: 480px;
    max-width: 100%;
  }
  .top_eat--menu-item .txt_head {
    font-size: 18px;
    margin: 10px 0;
  }
}
/* ===================================================
体験する
=================================================== */
.top_foodexperience--lead .txt {
  order: -1;
  margin-right: -5%;
  margin-left: 0;
  z-index: 1;
}
.top_foodexperience--lead .txt_head {
  margin-left: 20px;
}
.top_foodexperience--menu {
  margin-top: 100px;
  padding: 180px 0;
  position: relative;
}
.top_foodexperience--menu:before {
  content: "";
  background: rgb(227, 235, 150);
  background: linear-gradient(120deg, rgba(227, 235, 150, 1) 0%, rgba(220, 235, 150, 1) 26%, rgba(219, 235, 151, 1) 35%, rgba(226, 234, 150, 1) 54%, rgba(237, 232, 149, 1) 78%, rgba(254, 249, 228, 1) 100%);
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0.56;
}
.top_foodexperience--menu:after {
  content: "FOOD EXPERIENCE";
  color: #fff;
  font-family: "PT Sans", sans-serif;
  font-size: 200px;
  font-weight: 700;
  opacity: 0.54;
  position: absolute;
  right: -340px;
  bottom: -40px;
  z-index: -1;
}
.top_foodexperience--menu .txt--lead {
  text-align: center;
}
.top_foodexperience--menu-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(4vw, 60px) 2%;
  margin-top: 60px;
}
.top_foodexperience--menu-item {
  width: calc(100% / 4 - 23px);
}
.top_foodexperience--menu-item a {
  display: block;
  background-color: #fff;
  box-shadow: 0px 0px 20px 0px rgba(34, 73, 65, 0.12);
}
.top_foodexperience--menu-item .txt {
  font-size: min(1.333vw, 20px);
  text-align: center;
  padding: 20px 10px;
}
.top_foodexperience--menu-item .txt.-s {
  font-size: min(1.2vw, 18px);
}
@media screen and (max-width: 896px) {
  .top_foodexperience--lead .txt {
    order: 0;
    margin-right: 0;
  }
  .top_foodexperience--menu {
    margin-top: 70px;
    padding: 70px 0;
  }
  .top_foodexperience--menu:after {
    font-size: 50px;
    right: auto;
    left: 66px;
    bottom: 0;
    width: max-content;
  }
  .top_foodexperience--menu-inner {
    flex-direction: column;
    align-items: center;
    gap: 40px;
    margin-top: 30px;
  }
  .top_foodexperience--menu-item {
    width: fit-content;
  }
  .top_foodexperience--menu-item .txt {
    font-size: 16px;
  }
  .top_foodexperience--menu-item .txt.-s {
    font-size: 16px;
  }
}
/* ===================================================
泊まる
=================================================== */
.top_stay--menu {
  margin-top: 100px;
  padding-bottom: 180px;
  position: relative;
}
.top_stay--menu:before {
  content: "";
  background: url(../img/common/pt_g.png) repeat 0 0;
  position: absolute;
  inset: 320px 0 0 7vw;
  z-index: -1;
}
.top_stay--menu h3 {
  font-size: 28px;
  text-align: center;
  margin-bottom: 40px;
}
.top_stay--menu-item .img {
  position: relative;
}
.top_stay--menu-inner .txt {
  font-size: 16px;
  margin-top: 10px;
  text-align: center;
}
.top_stay--menu-inner .txt:before {
  content: "";
  margin-right: 10px;
  display: inline-block;
}
.top_stay--menu-item .is-hidden_sp .hover {
  opacity: 0;
  color: #fff;
  font-size: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: absolute;
  inset: 0;
  transition: 0.3s;
}
.top_stay--menu-inner_01 .top_stay--menu-item .is-hidden_sp .hover {
  background: rgba(224, 235, 151, 0.89);
}
.top_stay--menu-inner_02 .top_stay--menu-item .is-hidden_sp .hover {
  background: rgba(239, 230, 113, 0.89);
}
.top_stay--menu-item .is-hidden_sp .hover:before {
  content: "";
  mask: url(../img/common/ico_doom.svg) no-repeat center / contain;
  background-color: #fff;
  display: block;
}
.top_stay--menu-inner_01 .top_stay--menu-item .is-hidden_sp .hover:before {
  mask: url(../img/common/ico_doom.svg) no-repeat center / contain;
  width: 100px;
  height: 100px;
}
.top_stay--menu-inner_02 .top_stay--menu-item .is-hidden_sp .hover:before {
  mask: url(../img/common/ico_dog.svg) no-repeat center / contain;
  width: 71px;
  height: 71px;
}
.top_stay--menu-item .is-hidden_sp .hover .hover_member {
  background-color: #fff;
  color: #72749e;
  margin: 25px 0 13px;
  padding: 5px 25px;
  width: fit-content;
}
.top_stay--menu-item .is-hidden_sp .hover .btn {
  margin-top: 20px;
}
.top_stay--menu-item .is-hidden_sp .hover .btn a {
  color: #fff;
  font-size: 20px;
  border-color: #fff;
  margin: 0 auto;
  width: 250px;
}
.top_stay--menu-item .is-hidden_sp .hover .btn a:after {
  background-color: #fff;
}
.top_stay--menu-item .is-hidden_sp .hover .btn a:hover {
  background-color: #fff;
  color: #b9d157;
}
.top_stay--menu-inner_02 .is-hidden_sp .hover .btn a:hover {
  color: #f6d554;
}
.top_stay--menu-item .is-hidden_sp .hover .btn a:hover:after {
  background-color: #b9d157;
}
.top_stay--menu-inner_02 .top_stay--menu-item .is-hidden_sp .hover .btn a:hover:after {
  background-color: #f6d554;
}
.top_stay--menu-item .is-hidden_sp:hover .hover {
  opacity: 1;
}
.top_stay--menu-inner_01 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(2.666vw, 40px) 3.03%;
  margin: 0 auto;
  width: 990px;
  max-width: 100%;
}
.top_stay--menu-inner_01 .txt:before {
  background: url(../img/common/ico_doom.svg) no-repeat center / contain;
  width: 24px;
  height: 20px;
}
.top_stay--menu-inner_01 .top_stay--menu-item {
  width: calc(100% / 2 - 3.03% / 2);
}
.top_stay--menu-inner_02 {
  margin-top: 80px;
}
.top_stay--menu-inner_02 {
  display: flex;
  gap: 2%;
}
.top_stay--menu-inner_02 .txt:before {
  background: url(../img/common/ico_dog.svg) no-repeat center / contain;
  width: 18px;
  height: 20px;
}
.top_stay--menu-inner_02 .top_stay--menu-item {
  width: calc(100% / 3);
}
@media screen and (max-width: 896px) {
  .top_stay--menu h3 {
    font-size: 18px;
  }
  .top_stay--menu {
    margin-top: 50px;
    padding-bottom: 70px;
  }
  .top_stay--menu:before {
    inset: 235px 0 0 0;
  }
  .top_stay--menu-inner .txt:before {
    margin-right: 5px;
  }
  .top_stay--menu-inner_01 {
    gap: 40px;
  }
  .top_stay--menu-inner_02 {
    margin-top: 40px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }
  .top_stay--menu-inner_01 .top_stay--menu-item, .top_stay--menu-inner_02 .top_stay--menu-item {
    width: auto;
  }
}
/* ===================================================
FAQ
=================================================== */
.top_faq {
  /*background: url(../img/top/faq_bg.jpg) no-repeat center / auto 100% #fff;*/
  background: #f7f7f7;
  margin-top: 180px;
  margin-left: auto;
  padding: 90px 20px 90px 130px;
  position: relative;
  width: calc(100% - 50px - 70px);
}
.top_faq:after {
  content: "";
  background: linear-gradient(90deg, rgba(220, 234, 255, 1), rgba(205, 242, 243, 1));
  position: absolute;
  inset: 44px 0 -95px -70px;
  z-index: -1;
}
.top_faq h2 {
  text-align: left;
}
.top_faq .btn {
  margin-top: 60px;
}
.top_faq .btn a {
  font-size: 20px;
  padding: 15px;
  width: 360px;
}
@media screen and (max-width: 896px) {
  .top_faq {
    background: #f7f7f7;
    margin-top: 70px;
    padding: 70px 35px 70px 20px;
    width: calc(100% - 15px);
  }
  .top_faq h2 {
    text-align: center;
  }
  .top_faq:after {
    inset: 30px 0 -40px -15px;
  }
  .top_faq .btn {
    margin-top: 40px;
  }
  .top_faq .btn a {
    font-size: 16px;
    max-width: 100%;
  }
}
/* ===================================================
フォトギャラリー
=================================================== */
.top_gallery {
  margin-top: 360px;
}
.top_gallery--inner {
  position: relative;
}
.top_gallery--inner .container {
  display: flex;
  flex-wrap: wrap;
  gap: min(2vw, 30px) 2%;
  padding-bottom: 95px;
}
.top_gallery--inner:before {
  content: "";
  background: rgb(227, 235, 150);
  background: linear-gradient(120deg, rgba(227, 235, 150, 1) 0%, rgba(220, 235, 150, 1) 26%, rgba(219, 235, 151, 1) 35%, rgba(226, 234, 150, 1) 54%, rgba(237, 232, 149, 1) 78%, rgba(254, 249, 228, 1) 100%);
  position: absolute;
  inset: 125px 20vw 0 0;
  z-index: -1;
  opacity: 0.41;
}
.top_gallery--inner .img {
  width: calc(100% / 4 - 23px);
}
@media screen and (max-width: 896px) {
  .top_gallery {
    margin-top: 140px;
  }
  .top_gallery h2.ttl_yellow {
    text-align: left;
  }
  .top_gallery--inner .container {
    justify-content: center;
    gap: 20px 15px;
    padding-bottom: 60px;
  }
  .top_gallery--inner:before {
    inset: 65px 10vw 0 0;
  }
  .top_gallery--inner .img {
    max-width: calc(100% / 2 - 7.5px);
    width: fit-content;
  }
}
/* ===================================================
アクセス
=================================================== */
.top_access {
  background-color: #fbfbfb;
  padding: 180px 0;
  margin-top: 180px;
}
.top_access--inner {
  display: flex;
  align-items: : flex-start;
  gap: 55px;
  margin-top: 30px;
}
.top_access .g_map {
  width: 51%;
}
.top_access .g_map iframe {
  width: 100%;
  height: 566px;
}
.top_access .txt {
  width: 49%;
}
.top_access .txt * {
  font-size: 16px;
  line-height: 2;
}
.top_access .txt dl > div {
  margin-top: 30px;
}
.top_access .txt dl dt {
  font-weight: 500;
  font-size: 20px;
}
@media screen and (max-width: 896px) {
  .top_access {
    padding: 70px 0;
    margin-top: 70px;
  }
  .top_access--inner {
    flex-direction: column;
    gap: 30px;
  }
  .top_access .g_map {
    width: 100%;
  }
  .top_access .g_map iframe {
    height: 254px;
  }
  .top_access .txt {
    width: 100%;
  }
  .top_access .txt * {
    font-size: 15px;
  }
  .top_access .txt dl dt {
    font-size: 18px;
  }
}
/* ===================================================
周辺観光
=================================================== */
.top_gf {
  margin-top: 180px;
  margin-bottom: 100px;
}
.top_gf ul {
  display: flex;
  gap: 2%;
}
.top_gf ul li {
  width: calc(100% / 4);
}
.top_gf ul li .img img {
  aspect-ratio: 352 / 250;
  object-fit: cover;
  object-position: center;
}
.top_gf ul li h3 {
  margin-top: 10px;
  font-weight: 500;
  font-size: 20px;
}
.top_gf .btn {
  margin-top: 60px;
}
.top_gf .btn a {
  font-size: 20px;
  padding: 15px;
  width: 360px;
  margin: 0 auto;
}
@media screen and (max-width: 896px) {
  .top_gf {
    margin-top: 70px;
  }
  .top_gf ul {
    flex-wrap: wrap;
    gap: 30px 15px;
  }
  .top_gf ul li {
    width: calc(100% / 2 - 7.5px);
  }
  .top_gf ul li h3 {
    font-size: 13px;
  }
  .top_gf .btn {
    margin-top: 40px;
  }
  .top_gf .btn a {
    font-size: 16px;
    padding: 15px;
    width: 360px;
    margin: 0 auto;
  }
}
/* 20240220追記　ここまで
------------------------------ */
/*フォトギャラリー*/
.meal-box {
  padding: 90px 0;
}
.meal-box ul {
  width: 100%;
  margin: 0 auto;
}
.meal-box ul li {
  width: 24%;
}
.meal-box ul li img {
  width: 100%;
  object-fit: cover;
  border-radius: 5px;
}
.meal-box ul li img:hover {
  transition: 0.2s;
  transform: scale(1.02);
}
.inr {
  padding-right: 70px;
  padding-left: 70px;
}
.mb45 {
  margin-bottom: 45px;
}
.meal-box h2 {
  font-size: 2.6rem;
  text-align: center;
  margin-bottom: 45px;
  line-height: 1.8;
}
/*PC*/
@media screen and (min-width: 768px) {}
/*END*/
/*Smartphone*/
@media screen and (max-width:896px) {
  .meal-box {
    padding: 50px 0 90px;
  }
  .meal-box ul {
    width: 100%;
  }
  .meal-box ul li {
    width: 49%;
  }
  .meal-box ul li img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    border-radius: 3px;
  }
  .inr {
    padding: 15px
  }
  .mb45 {
    margin-bottom: 20px;
  }
}
/*	flexbox
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ */
.fb {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.fb-both {
  /*両端揃え*/
  justify-content: space-between;
  -webkit-justify-content: space-between;
}
.fb-right {
  /*右寄せ*/
  justify-content: flex-end;
  -webkit-justify-content: flex-end;
}
.fb-center {
  /*中央揃え*/
  justify-content: center;
  -webkit-justify-content: center;
}
.fb-rev {
  flex-direction: row-reverse;
}
.fb-col-rev {
  flex-direction: column-reverse;
}
.fb-al-center {
  align-items: center;
}
.fb-al-top {
  align-items: flex-start;
}
.fb-al-bottom {
  align-items: flex-end;
}
.inb {
  display: inline-block;
}
/*PC*/
@media screen and (min-width: 768px) {
  .pc-t-center {
    text-align: center;
  }
  .pc-t-center img {
    margin-right: auto;
    margin-left: auto;
  }
  .pc-t-left {
    text-align: left;
  }
  .pc-t-right {
    text-align: right;
  }
  .pc-t-jus {
    text-align: justify;
  }
  .pc-fb {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .pc-fb-both {
    /*両端揃え*/
    justify-content: space-between;
    -webkit-justify-content: space-between;
  }
  .pc-fb-right {
    /*右寄せ*/
    justify-content: flex-end;
    -webkit-justify-content: flex-end;
  }
  .pc-fb-center {
    /*中央揃え*/
    justify-content: center;
    -webkit-justify-content: center;
  }
  .pc-fb-rev {
    flex-direction: row-reverse;
  }
  .pc-fb-col-rev {
    flex-direction: column-reverse;
  }
  .pc-fb-al-center {
    align-items: center;
  }
}
/*END*/
/*------------------------------------------

ギャラリー内「もっと見る」

------------------------------------------*/
.readmore {
  position: relative;
  box-sizing: border-box;
  margin-top: 100px;
}
.readmore-content {
  position: relative;
  overflow: hidden;
  height: 520px;
}
.readmore-content::before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  content: "";
  /*以下お好み グラデーションの色と高さ 高さはreadmoreのheight以下にすること*/
  height: 50px;
  background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 50%, rgba(255, 255, 255, 0.8) 50%, #fff 100%);
  background: linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 50%, rgba(255, 255, 255, 0.8) 50%, #fff 100%);
}
/* 続きを読むボタン */
.readmore-label {
  display: table;
  position: absolute;
  bottom: 75px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  margin: 0 auto;
  z-index: 2;
  font-size: 18px;
  text-align: center;
  width: 180px;
  color: #40646B;
  background: #fff;
  margin-top: 30px;
  border: 1px solid #979797;
  color: #333;
  padding: 10px;
  max-width: 90%;
  font-size: 20px;
  padding: 15px;
  width: 360px;
  margin: 0 auto;
}
.readmore-label:before {
  content: 'See more';
}
.readmore-check {
  display: none;
}
/*チェック時にボタンを非表示*/
.readmore-check:checked ~ .readmore-label {
  position: static;
  transform: translateX(0);
  -webkit-transform: translateX(0);
  /* 「続きを読む」を押した後、元に戻す必要がない場合は、上のオプションを消してこの1行だけにする */
  /* display: none; */
}
.readmore-check:checked ~ .readmore-label:before {
  content: 'Close up';
}
/*チェック時に高さを自動に戻す*/
.readmore-check:checked ~ .readmore-content {
  height: auto;
}
@media screen and (max-width:896px) {
  .readmore-check:checked ~ .readmore-content {
    height: auto;
  }
  .readmore-label {
    width: 320px;
  }
}
/*チェック時グラデーション等を削除*/
.readmore-check:checked ~ .readmore-content::before {
  display: none;
}
/*END*/
.facility_map {
  width: 70%;
  margin: 50px auto 100px;
}
.facility_map img {
  width: 100%;
  object-fit: cover;
}
@media screen and (max-width:896px) {
  .facility_map {
    width: 100%;
    margin: 50px auto;
  }
}
.top_bnr {
  margin: 50px auto;
}
.top_bnr ul {
  display: flex;
  justify-content: space-evenly;
}
.top_bnr ul li {
  width: 32%;
  margin: 0px;
}
.top_bnr ul li img {
  width: 100%;
  object-fit: cover;
}
@media screen and (max-width:896px) {
  .top_bnr ul li {
    width: 100%;
    margin: 5px;
  }
}
/*閉じるバナー*/
.callout-container {
  position: fixed;
  width: 400px;
  left: 0;
  background-color: #fff;
  padding: 2px;
  z-index: 100;
}
.callout-container img {
  width: 100%;
  object-fit: cover;
  border-radius: 10px;
}
.bnr_close {
  position: absolute;
  top: -5px;
  right: 5px;
  color: white;
  font-size: 40px;
  padding: 10px;
  line-height: 1;
  cursor: pointer;
  z-index: 100;
}
.bnr_close:hover {
  color: lightgrey;
}
/* レスポンシブ対応 */
@media screen and (max-width: 897px) {
  .callout-container {
    width: 100%;
    padding: 2px;
  }
  .bnr_close {
    top: -10px;
    right: 0;
  }
}
.btn.facility_btn a {
  font-size: 20px;
  padding: 15px;
  width: 360px;
  margin: 0 auto;
}
.anchor {
  position: relative;
}
.anchor::before {
  content: '';
  display: block;
  height: 100px;
  margin-top: -100px;
}
/* 250331追加 */
@media screen and (max-width: 897px) {
  .top_pickup_list .top_pickup_text {
    margin-bottom: 10px;
  }
}
.room_share .txt {
  margin-bottom: 20px;
}
.room_share li {
  margin: 0 10px;
}
@media screen and (max-width: 897px) {
  .room_share .txt {
    margin-bottom: 10px;
  }
}
/* ギャラリー */
#gallery .swiper-wrapper {
  width: 100%;
  height: auto;
}
#gallery .swiper-slide {
  height: auto;
}
#gallery .swiper-slide img {
  width: 100%;
  height: auto;
  object-fit: contain;
}
@media screen and (max-width: 896px) {
  #gallery .swiper-wrapper, #gallery .swiper-slide img {
    height: auto;
  }
}
/*ページネーション*/
.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  color: #000;
}
span {
  display: inline-block;
}
.modal-box {
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 10000;
  top: 0;
  left: 0;
  display: none;
}
.modal-box > .bg-box {
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
}
.modal-box .content-box {
  width: calc(100% - 40px);
  max-width: 1000px;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.modal-box .modal-close {
  position: absolute;
  width: 50px;
  height: 50px;
  top: 30px;
  right: 30px;
}
.modal-box .modal-close > span {
  width: 100%;
  height: 3px;
  display: block;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
}
.modal-box .modal-close > span:nth-of-type(1) {
  transform: translate(-50%, -50%) rotate(45deg);
}
.modal-box .modal-close > span:nth-of-type(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.modal-box .content-box .modal-list {
  position: relative;
}
.modal-box .content-box .modal-list > li {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: 0.3s;
}
.modal-box .content-box .modal-list > li > img {
  width: 100%;
}
.modal-box .content-box .left-arr, .modal-box .content-box .right-arr {
  position: absolute;
  width: 30px;
  height: 30px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  border-bottom: 3px solid #fff;
  border-left: 3px solid #fff;
  cursor: pointer;
  transform-origin: center;
}
.modal-box .content-box .left-arr {
  left: -40px;
  transform: rotate(45deg);
}
.modal-box .content-box .right-arr {
  right: -40px;
  transform: rotate(-135deg);
}
@media only screen and (max-width: 896px) {
  .modal-box .modal-close {
    width: 30px;
    height: 30px;
    top: 15px;
    right: 15px;
  }
  .modal-box .content-box .left-arr, .modal-box .content-box .right-arr {
    width: 20px;
    height: 20px;
  }
  .modal-box .content-box .left-arr {
    left: 14px;
  }
  .modal-box .content-box .right-arr {
    right: 14px;
  }
}
.gallery-box {
  background: #f0f8fb;
  padding: 50px 0 80px;
}
.gallery-box h2.top {
  margin-bottom: 75px;
}
.gallery-box .photo-gallery .swiper-slide .item {
  cursor: pointer;
  transition: 0.3s;
}
.gallery-box .photo-gallery .swiper-slide .item:hover {
  opacity: 0.7;
}
@media only screen and (max-width: 896px) {
  .gallery-box {
    padding: 10px 0 30px;
  }
  .gallery-box h2.top {
    margin-bottom: 34px;
    margin-top: 30px;
  }
}
.lity-close {
  position: absolute !important;
  width: 75px !important;
  height: 75px !important;
  right: -34px !important;
  top: -40px !important;
  font-size: 100px !important;
}
@media only screen and (max-width: 896px) {
  .lity-close {
    right: 0 !important;
    top: 42px !important;
    font-size: 80px !important;
  }
}
/* ギャラリー　END */
/* 250331追加 END*/
/*おすすめのご宿泊プラン*/
.plan_box {
  padding: 150px 0 0;
}
.plan-list {
  list-style: none;
  margin: 0;
  padding: 50px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  justify-content: center;
}
.plan-item {
  width: calc(32% - 15px);
  text-align: center;
}
.plan-item a {
  text-decoration: none;
  color: #000;
  display: block;
  transition: transform 0.3s;
}
.plan-item img {
  width: 100%;
  display: block;
  border-radius: 0;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.plan-title {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #456e99;
  color: #fff;
  padding: 8px 0;
  min-height: 50px;
  text-align: center;
  line-height: 1.4;
  font-size: 1.8rem;
}
.plan-item a:hover {
  transform: translateY(-5px);
}
@media screen and (max-width: 896px) {
  .plan_box {
    padding: 80px 0 0;
  }
  .plan-list {
    gap: 20px;
    justify-content: flex-start;
    padding: 0;
  }
  .plan-item {
    width: calc(50% - 10px);
  }
  .plan-title {
    padding: 0px 0;
    font-size: 1.5rem;
  }
}