@charset "UTF-8";
/* cms管理画面でデザインモードの体裁を整えるのに使います */
@import "common.css";
/*!
global > color
------------------------------
*/
/*!
global > content-width
------------------------------
*/
/*!
global > font
------------------------------
*/
/*!
global > function
------------------------------
*/
/*!
global > mixin
------------------------------
*/
/*使うときは @include g.aspect-ratio(100,60)*/
/*使うときは @include g.aspect-ratio(100, 60, 100);*/
/*使うときは @include g.inner()*/
* {
  margin: 0;
  padding: 0;
}

body {
  padding: 5px;
}

body, p, caption, th, td, ul, ol, li, dl, dt, dd, form, input, textarea {
  font-family: "ＭＳ Ｐゴシック", Osaka, "ヒラギノ角ゴ Pro W3";
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  font-style: normal;
  font-weight: normal;
}

body, th, td {
  font-size: 84%;
  margin: 0;
}

.imgLeft {
  display: block;
  float: left;
}

.imgCenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.imgRight {
  display: block;
  float: right;
}

/* ul li タグ クラスなしの場合*/
ul:not([class]) {
  margin: 1rem 0;
  padding-left: 1rem;
}
ul:not([class]) li:not([class]) {
  line-height: 1.5;
  margin: 0.625rem 0;
  padding-left: 1rem;
  position: relative;
}
ul:not([class]) li:not([class])::before {
  background: #C5B27A;
  border-radius: 6px;
  content: "";
  display: inline-block;
  height: 6px;
  left: 0px;
  position: absolute;
  top: 10px;
  width: 6px;
}

/* ol li タグ クラスなしの場合*/
ol:not([class]) {
  margin: 1rem 0;
  padding-left: 2rem;
}
/* dl dt ddタグ クラスなしの場合*/
@media screen and (min-width: 768px) {
  dl:not([class]) {
    display: flex;
    flex-wrap: wrap;
  }
}
dl:not([class]) dt:not([class]) {
  font-size: 0.75rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  dl:not([class]) dt:not([class]) {
    border-top: 1px solid #E0E0E0;
    margin-top: 1rem;
    padding: 0.5rem 0;
  }
}
@media screen and (min-width: 768px) {
  dl:not([class]) dt:not([class]) {
    border-top: 2px solid #C5B27A;
    font-size: 0.9375rem;
    padding: 0.75rem 0;
    width: 20%;
  }
}
@media screen and (max-width: 767px) {
  dl:not([class]) dt:not([class]) {
    position: relative;
  }
  dl:not([class]) dt:not([class])::before {
    background: #C5B27A;
    content: "";
    display: inline-block;
    height: 2px;
    left: 0;
    position: absolute;
    top: -1px;
    width: 80px;
  }
}
dl:not([class]) dd:not([class]) {
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  margin-left: 0;
}
@media screen and (min-width: 768px) {
  dl:not([class]) dd:not([class]) {
    border-top: 1px solid #E0E0E0;
    box-sizing: border-box;
    font-size: 0.9375rem;
    padding: 0.75rem 0 0.75rem 1.125rem;
    width: 80%;
  }
}

/* table クラスなしの場合 */
table:not([class]) {
  border-bottom: 1px solid #C5B27A;
  margin: 1rem 0;
}
table:not([class]) th:not([class]) {
  border-top: 1px solid #C5B27A;
  padding: 0.5rem;
}
table:not([class]) td:not([class]) {
  border-top: 1px solid #C5B27A;
  padding: 0.5rem;
}

/* aタグ クラスなしの場合*/
a:not([class]) {
  display: inline-block;
  position: relative;
}
a:not([class]):not([class]) {
  color: #333;
  text-decoration: underline;
  transition: color 0.3s;
}
@media screen and (min-width: 768px) {
  a:not([class]):not([class]):hover {
    -webkit-text-decoration: underline dotted;
    color: #C5B27A;
    text-decoration: underline dotted;
  }
}
a:not([class])[href$=".pdf"][target=_blank]::after {
  -webkit-transform: translateY(-50%);
  background: url(../img/icon/dl-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 17px;
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 13px;
}
a:not([class])[href$=".pdf"][rel=external]::after {
  -webkit-transform: translateY(-50%);
  background: url(../img/icon/dl-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 17px;
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 13px;
}
a:not([class])[href$=".pdf"]::after {
  -webkit-transform: translateY(-50%);
  background: url(../img/icon/dl-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 17px;
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 13px;
}
a:not([class])[target=_blank]::after {
  -webkit-transform: translateY(-50%);
  background: url(../img/icon/exlink-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 16px;
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
}

/* aタグ　buttonクラスの場合 */
a.button {
  background-color: #fff;
  border: 1px solid #C5B27A;
  color: #1A1A1A;
  display: inline-block;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  overflow: hidden;
  padding: 0.75rem 0;
  padding: 0.75rem 1.25rem 0.75rem 2.5rem;
  position: relative;
  text-align: left;
  transition: opacity 0.5s;
  transition: color 0.3s;
}
a.button::before {
  -webkit-transform: translateY(-50%);
  background: url(../img/icon/arrow-right-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 18px;
  left: 20px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: left 0.3s;
  width: 9px;
}
@media screen and (min-width: 768px) {
  a.button:hover {
    color: #C5B27A;
  }
  a.button:hover::before {
    left: 24px;
  }
}

/* h2　クラスなしの場合 */
h2:not([class]) {
  border-bottom: 2px solid #C5B27A;
  font-size: 1.125rem;
  font-weight: 500;
  margin-top: 1.5rem;
  padding-bottom: 0.375rem;
}
@media screen and (min-width: 768px) {
  h2:not([class]) {
    font-size: 1.375rem;
    padding-bottom: 0.5rem;
  }
}

h3:not([class]) {
  border-bottom: 1px solid #E0E0E0;
  margin-top: 1.125rem;
  padding-bottom: 0.375rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  h3:not([class]) {
    padding-bottom: 0.5rem;
  }
}
h3:not([class])::before {
  background: #C5B27A;
  bottom: -1px;
  content: "";
  display: inline-block;
  height: 2px;
  left: 0;
  position: absolute;
  width: 80px;
}

h4:not([class]) {
  padding-left: 1.5rem;
  position: relative;
}
h4:not([class])::before {
  background: url(../img/icon/friends-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 16px;
  left: 0px;
  position: absolute;
  top: 6px;
  width: 16px;
}
@media screen and (min-width: 768px) {
  h4:not([class])::before {
    left: 0px;
    top: 8px;
  }
}

/* imgタグ クラスなしの場合*/
img {
  max-width: 100%;
  vertical-align: top;
}

/* aboutページ（当館について） */
.bl_history_cont {
  position: relative;
}
@media screen and (max-width: 767px) {
  .bl_history_cont {
    padding: 0 1.875rem;
  }
}
.bl_history_cont .js-accordion-btn {
  background-color: #fff;
  border: 1px solid #C5B27A;
  bottom: 0;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-size: 18px;
  left: 0;
  margin: auto;
  padding: 0.75rem 0;
  position: absolute;
  right: 0;
  text-align: center;
  transition: all 0.3s;
  width: 315px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .bl_history_cont .js-accordion-btn {
    width: 426px;
  }
}
.bl_history_cont .js-accordion-btn::before {
  background: url(../img/icon/plus-gold.svg) no-repeat;
  content: "";
  height: 12px;
  left: 20px;
  position: absolute;
  top: 22px;
  width: 12px;
}
.bl_history_cont .js-accordion-btn::after {
  color: #333;
  content: "もっと見る";
  font-size: 1rem;
}
.bl_history_cont .js-accordion-btn.is-show {
  bottom: -4em;
}
.bl_history_cont .js-accordion-btn.is-show::before {
  content: none;
}
.bl_history_cont .js-accordion-btn.is-show::after {
  content: "閉じる";
}
.bl_history_cont .js-accordion-txt {
  overflow: hidden; /* テキストを隠す */
  position: relative;
}
.bl_history_cont .js-accordion-txt.is-hide {
  height: 400px;
}
.bl_history_cont .js-accordion-txt::before {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0.6) 80%, #fff 100%);
  bottom: 0;
  content: "";
  height: 160px; /* グラデーションで隠す高さ */
  position: absolute;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .bl_history_cont .js-accordion-txt dt {
    font-weight: 500;
  }
  .bl_history_cont .js-accordion-txt dd {
    margin-bottom: 0.75rem;
  }
}
@media screen and (min-width: 768px) {
  .bl_history_cont .js-accordion-txt {
    display: flex;
    flex-wrap: wrap;
  }
  .bl_history_cont .js-accordion-txt dt, .bl_history_cont .js-accordion-txt dd {
    font-size: 0.875rem;
    font-weight: 500;
  }
  .bl_history_cont .js-accordion-txt dt {
    padding: 0.625rem 0;
    width: 20.5949656751%;
  }
  .bl_history_cont .js-accordion-txt dd {
    padding: 0.625rem 0;
    width: 78.9473684211%;
  }
}
.bl_history_cont .js-accordion-txt dd {
  margin-left: 0;
}
.bl_history_cont .js-accordion-btn.is-show + .js-accordion-txt::before {
  display: none;
}

/* floorページ（施設のご案内　＞　フロアマップ） */
@media screen and (max-width: 767px) {
  .bl_floor_bottom_cont {
    padding: 0 1.25rem;
  }
}

.bl_floor_bottom_ttl {
  font-size: 0.9375rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .bl_floor_bottom_ttl {
    width: 26.9399707174vw;
  }
}
@media screen and (min-width: 1400px) {
  .bl_floor_bottom_ttl {
    width: 23rem;
  }
}

.bl_floor_bottom_txt {
  font-size: 0.875rem;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .bl_floor_bottom_txt {
    font-size: 1rem;
    width: 26.9399707174vw;
  }
}
@media screen and (min-width: 1400px) {
  .bl_floor_bottom_txt {
    width: 23rem;
  }
}

.bl_floor_bottom_img {
  position: absolute;
}
@media screen and (max-width: 1399px) {
  .bl_floor_bottom_img {
    width: 40.9956076135vw;
  }
}
@media screen and (max-width: 767px) {
  .bl_floor_bottom_img {
    left: -6%;
    top: -20.6442166911vw;
    width: 560px;
  }
}
@media screen and (max-width: 576px) {
  .bl_floor_bottom_img {
    width: 96%;
  }
}
.bl_floor_bottom_img img {
  -o-object-fit: cover;
  aspect-ratio: 2.0895522388;
  max-width: 560px;
  object-fit: cover;
  width: 100%;
}

/* 友の会ページ */
.bl_friends_h2 {
  font-size: 1.25rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .bl_friends_h2 {
    font-size: 1.5rem;
  }
}

.bl_friends_lead {
  font-size: 1rem;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .bl_friends_lead {
    font-size: 1.125rem;
  }
}

.bl_friends_txt {
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .bl_friends_txt {
    font-size: 1rem;
  }
}

.bl_friends_h3 {
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 0.625rem;
  margin-top: 1.625rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_h3 {
    font-size: 1.375rem;
    margin-top: 3.5rem;
  }
}

.bl_friends_p {
  letter-spacing: 0.1em;
  padding: 0 1rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_p {
    padding: 0 3.125rem;
  }
}

.bl_friends_ul li {
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  line-height: 2.5;
  padding: 0 0 0 2.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .bl_friends_ul li {
    font-size: 1rem;
    padding: 0 0 0 4.75rem;
  }
}
.bl_friends_ul li::before {
  background: url(../img/icon/friends-gold.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 16px;
  left: 16px;
  position: absolute;
  top: 10px;
  width: 16px;
}
@media screen and (min-width: 768px) {
  .bl_friends_ul li::before {
    left: 50px;
    top: 14px;
  }
}

.bl_friends_num {
  display: flex;
  margin-top: 2.25rem;
  padding-left: 1rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_num {
    padding-left: 3.125rem;
  }
}
.bl_friends_num .bl_circle_num {
  color: #fff;
  font-size: 1.25rem;
  font-weight: 700;
  position: relative;
}
@media screen and (min-width: 768px) {
  .bl_friends_num .bl_circle_num {
    font-size: 1.5rem;
  }
}
.bl_friends_num .bl_circle_num::before {
  background-color: #B39C56;
  border-radius: 50%;
  color: #fff;
  content: "";
  height: 36px;
  left: -12px;
  margin-right: 10px;
  position: absolute;
  top: 0;
  width: 36px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .bl_friends_num .bl_circle_num::before {
    height: 40px;
    width: 40px;
  }
}
.bl_friends_num p {
  font-size: 1rem;
  font-weight: 700;
  margin: 0.375rem 0 0;
  padding-left: 1.25rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_num p {
    font-size: 1.125rem;
  }
}

.bl_friends_contact {
  margin-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_contact {
    padding-left: 6.25rem;
  }
}

.bl_friends_contact_wrap {
  border: 1px solid #C5B27A;
}

.bl_friends_contact_lead {
  font-size: 1rem;
  font-weight: 500;
  padding-left: 1.875rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .bl_friends_contact_lead {
    font-size: 1.25rem;
  }
}
.bl_friends_contact_lead::before {
  background-color: #C5B27A;
  content: "";
  height: 20px;
  left: 0;
  position: absolute;
  top: 6px;
  width: 6px;
}
@media screen and (min-width: 768px) {
  .bl_friends_contact_lead::before {
    top: 10px;
  }
}

.bl_friends_bg {
  background-color: #F3EFE2;
  margin: 1.25rem 0.875rem;
  padding: 1.25rem 0.75rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_bg {
    margin: 1.25rem 4rem;
    padding: 1.25rem 2.5rem;
  }
}

.bl_friends_bg_txt {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .bl_friends_bg_txt {
    font-size: 1.125rem;
  }
}

@media screen and (min-width: 992px) {
  .bl_friends_bg_wrap {
    display: flex;
  }
}

.bl_friends_bg_tel {
  align-items: center;
  display: flex;
  justify-content: center;
}
.bl_friends_bg_tel img {
  height: 54px;
  width: 54px;
}
.bl_friends_bg_tel p {
  font-family: "Roboto", sans-serif;
  font-size: 1.375rem;
  font-weight: 500;
  line-height: 1;
  margin: 0;
}
@media screen and (min-width: 992px) {
  .bl_friends_bg_tel p {
    font-size: 1.625rem;
  }
}
.bl_friends_bg_tel div {
  margin-left: 0.75rem;
}
.bl_friends_bg_tel div span {
  font-size: 0.8125rem;
}

.bl_friends_bg_fax p {
  font-family: "Roboto", sans-serif;
  font-size: 1.375rem;
  font-weight: 500;
  line-height: 1;
  margin: 0;
}
@media screen and (max-width: 991px) {
  .bl_friends_bg_fax p {
    margin-top: 1.875rem;
    text-align: center;
  }
}
@media screen and (min-width: 992px) {
  .bl_friends_bg_fax p {
    font-size: 1.625rem;
    padding-left: 2.25rem;
  }
}

.bl_friends_footer {
  font-size: 1rem;
  font-weight: 500;
  padding-left: 1rem;
}
@media screen and (min-width: 768px) {
  .bl_friends_footer {
    font-size: 1.25rem;
    padding-left: 4rem;
  }
}

.bl_friends_bottom {
  margin-top: 4.5rem;
}

.bl_friends_bottom_bg {
  background-color: #F2F2F2;
  padding: 2.25rem 0 1.875rem;
  text-align: center;
}
.bl_friends_bottom_bg h3 {
  border-bottom: none;
  margin: 0;
}
.bl_friends_bottom_bg h3::before {
  content: none;
}
.bl_friends_bottom_bg p {
  margin: 0 auto;
}

.bl_friends_bottom_btn {
  padding-top: 1rem;
  text-align: center;
  width: 80%;
}
@media screen and (min-width: 768px) {
  .bl_friends_bottom_btn {
    width: 320px;
  }
}

/* mediaページ（広報・プレス） */
@media screen and (min-width: 768px) {
  .hp_media_image_inner {
    padding: 0 1.875rem;
  }
}

.hp_media_txt {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .hp_media_txt {
    margin-top: 3rem;
  }
}

.bl_image-list {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .bl_image-list li {
    margin-right: 1%;
    margin-top: 2rem;
    width: 49.5%;
  }
  .bl_image-list li:nth-child(2n) {
    margin-right: 0;
  }
}
@media screen and (max-width: 576px) {
  .bl_image-list li {
    margin-right: 0;
    margin-top: 1rem;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .bl_image-list li {
    margin-right: 1%;
    margin-top: 2rem;
    width: 32.6666666667%;
  }
  .bl_image-list li:nth-child(3n) {
    margin-right: 0;
  }
}
.bl_image-list li a {
  display: block;
  opacity: 1;
  text-decoration: none;
  transition: opacity 0.3s;
}
.bl_image-list li a:hover {
  opacity: 0.7;
  text-decoration: none;
}
.bl_image-list li img {
  -o-object-fit: cover;
  aspect-ratio: 1.6136363636;
  max-width: 600px;
  object-fit: cover;
  width: 100%;
}
.bl_image-list li figure {
  margin: 0;
}
.bl_image-list li figcaption {
  color: #1a1a1a;
  font-family: "Roboto", sans-serif;
  font-size: 0.8125rem;
  margin-top: 0.5rem;
  text-align: center;
}

.hp_media_h3 {
  font-size: 1.125rem;
  font-weight: 700;
  margin-top: 3rem;
  padding: 0 1.875rem;
  padding-left: 1.125rem;
  position: relative;
}
.hp_media_h3::before {
  background-color: #B39C56;
  content: "";
  height: 22px;
  left: 0px;
  position: absolute;
  top: 4px;
  width: 5px;
}
@media screen and (min-width: 768px) {
  .hp_media_h3::before {
    left: 0px;
    top: 4px;
  }
}

.bl_media_image_btn {
  margin-top: 1.25rem;
  max-width: 430px;
}
@media screen and (min-width: 768px) {
  .bl_media_image_btn {
    margin-left: 1.875rem;
    margin-top: 3.125rem;
  }
}

.bl_media_image_contact {
  background-color: #F2F2F2;
  margin-top: 3.125rem;
  padding: 1rem 0;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .bl_media_image_contact {
    margin-top: 4.5rem;
    padding: 1.875rem 0;
  }
}

.bl_media_image_contact_ttl {
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .bl_media_image_contact_ttl {
    font-size: 1.375rem;
  }
}

.bl_media_image_contact_txt {
  font-size: 0.75rem;
  line-height: 1.35;
  margin: 0.625rem 0 1.25rem;
}
@media screen and (min-width: 768px) {
  .bl_media_image_contact_txt {
    font-size: 0.875rem;
  }
}

.bl_media_image_contact .bl_fax {
  font-family: "Roboto", sans-serif;
  font-size: 1.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1;
  margin: 0;
}
@media screen and (min-width: 768px) {
  .bl_media_image_contact .bl_fax {
    font-size: 2rem;
  }
}
.bl_media_image_contact .bl_mail {
  color: #C5B27A;
  font-size: 1rem;
  font-weight: 500;
  margin: 0;
  padding-bottom: 1.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .bl_media_image_contact .bl_mail {
    font-size: 1.125rem;
  }
}
.bl_media_image_contact .bl_mail::after {
  -webkit-transform: translateX(-50%);
  background-color: #DBDBDB;
  bottom: 0px;
  content: "";
  height: 1px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 70%;
}

.bl_media_image_contact_btn {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .bl_media_image_contact_btn {
    width: 80%;
  }
}
@media screen and (min-width: 768px) {
  .bl_media_image_contact_btn {
    max-width: 320px;
  }
}

/* プライバシーポリシーページ */
.bl_privacy-policy_h2 {
  font-size: 1.25rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .bl_privacy-policy_h2 {
    font-size: 1.5rem;
  }
}

.bl_privacy-policy_h3 {
  font-size: 1rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .bl_privacy-policy_h3 {
    font-size: 1.125rem;
    margin-bottom: 0.75rem;
    margin-top: 2.5rem;
  }
}

.bl_privacy-policy_lead {
  margin-bottom: 4rem;
}

.bl_privacy-policy_footer {
  margin-top: 4rem;
}

/* 定例イベントページ */
.bl_entry_inner div {
  background-color: #F9F9F9;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 767px) {
  .bl_entry_inner div {
    margin-left: 4.39238653vw;
    padding: 29.2825768668vw 8.78477306vw 3.513909224vw 4.0995607613vw;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div {
    width: 88.2459312839%;
  }
}
.bl_entry_inner div img {
  -o-object-fit: cover;
  aspect-ratio: 2.0895522388;
  max-width: 560px;
  object-fit: cover;
  position: absolute;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .bl_entry_inner div img {
    left: -4.39238653vw;
    top: -11.420204978vw;
    width: 92%;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div img {
    width: 50.6329113924vw;
  }
}
.bl_entry_inner div h3 {
  border-bottom: none;
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 0;
}
.bl_entry_inner div h3::before {
  content: none;
}
.bl_entry_inner div h4 {
  font-size: 0.9375rem;
  font-weight: 500;
  margin-top: 0;
  padding-left: 0;
}
.bl_entry_inner div h4::before {
  content: none;
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div p {
    max-width: 23rem;
  }
}
.bl_entry_inner div:first-child {
  border-left: 4px solid #E08081;
}
@media screen and (max-width: 767px) {
  .bl_entry_inner div:first-child {
    margin-top: 21.9619326501vw;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:first-child {
    border-left: 8px solid #E08081;
  }
}
.bl_entry_inner div:not(:first-child) {
  margin-top: 21.9619326501vw;
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:not(:first-child) {
    margin-top: 6rem;
  }
}
@media screen and (max-width: 767px) {
  .bl_entry_inner div:nth-child(2) {
    border-left: 4px solid #A9C25C;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:nth-child(2) {
    border-right: 8px solid #A9C25C;
    margin-top: 6rem;
  }
}
.bl_entry_inner div:nth-child(3) {
  border-left: 4px solid #DDC354;
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:nth-child(3) {
    border-left: 8px solid #DDC354;
    margin-top: 6rem;
  }
}
@media screen and (max-width: 767px) {
  .bl_entry_inner div:last-child {
    border-left: 4px solid #4EA497;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:last-child {
    border-right: 8px solid #4EA497;
    margin-top: 6rem;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:first-child, .bl_entry_inner div:nth-child(3) {
    margin-right: auto;
    padding: 4.0995607613vw 42.4597364568vw 4.0995607613vw 5.1244509517vw;
  }
}
@media screen and (min-width: 1200px) {
  .bl_entry_inner div:first-child, .bl_entry_inner div:nth-child(3) {
    padding: 3.5rem 35rem 3.5rem 4.375rem;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:first-child img, .bl_entry_inner div:nth-child(3) img {
    -webkit-transform: translateY(-50%);
    right: -90px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media screen and (min-width: 1200px) {
  .bl_entry_inner div:first-child img, .bl_entry_inner div:nth-child(3) img {
    right: -60px;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:nth-child(2), .bl_entry_inner div:last-child {
    margin-left: auto;
    padding: 4.0995607613vw 5.1244509517vw 4.0995607613vw 43.9238653001vw;
  }
}
@media screen and (min-width: 1200px) {
  .bl_entry_inner div:nth-child(2), .bl_entry_inner div:last-child {
    padding: 3.5rem 4.375rem 3.5rem 35rem;
  }
}
@media screen and (min-width: 768px) {
  .bl_entry_inner div:nth-child(2) img, .bl_entry_inner div:last-child img {
    -webkit-transform: translateY(-50%);
    left: -90px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media screen and (min-width: 1200px) {
  .bl_entry_inner div:nth-child(2) img, .bl_entry_inner div:last-child img {
    left: -60px;
  }
}

/* シェ・ヨシページ */
.bl_restaurant_upper_img {
  margin-top: 1.25rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_img {
    margin-top: 3.25rem;
  }
}
.bl_restaurant_upper_img img {
  width: 100%;
}

.bl_restaurant_upper_img_inner {
  box-sizing: border-box;
  height: inherit;
  margin: 0 auto;
  max-width: 1220px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_img_inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.bl_restaurant_upper_inner {
  box-sizing: border-box;
  height: inherit;
  margin: 0 auto;
  max-width: 932px;
  padding-left: 16px;
  padding-right: 16px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.bl_restaurant_upper_wrap {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_wrap {
    display: flex;
    justify-content: space-between;
    margin-top: 6.625rem;
  }
  .bl_restaurant_upper_wrap .bl_txt {
    width: 54.4444444444%;
  }
  .bl_restaurant_upper_wrap .bl_snslink {
    width: 25.7777777778%;
  }
}
.bl_restaurant_upper_wrap .bl_txt {
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .bl_restaurant_upper_wrap .bl_snslink {
    margin-top: 2rem;
  }
}
.bl_restaurant_upper_wrap .bl_snslink .bl_snslink_ttl {
  color: #7E6728;
  font-size: 0.8125rem;
  font-weight: 500;
}
.bl_restaurant_upper_wrap .bl_snslink .bl_snslink_txt {
  font-size: 0.9375rem;
  margin-bottom: 0.25rem;
}
.bl_restaurant_upper_wrap .bl_snslink .bl_snslink_btn {
  margin-top: 0;
}
.bl_restaurant_upper_wrap .bl_snslink .bl_snslink_btn .el_btn_border {
  box-sizing: border-box;
  font-size: 0.9375rem;
  padding-left: 0.75rem;
  text-align: left;
}

.bl_restaurant_upper_special {
  margin-top: 3.25rem;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_special {
    margin-top: 4.5rem;
  }
}

.bl_restaurant_upper_special_wrap {
  border: 1px solid #C5B27A;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .bl_restaurant_upper_special_wrap {
    padding-bottom: 5.625rem;
  }
}
.bl_restaurant_upper_special_wrap::after {
  background: url(../img/sub/img-restaurant-glass.png) no-repeat;
  background-size: contain;
  bottom: -2px;
  content: "";
  height: 90px;
  position: absolute;
  right: 20px;
  width: 88px;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_special_wrap::after {
    right: 50px;
  }
}
.bl_restaurant_upper_special_wrap h3 {
  background-color: #B39C56;
  border-bottom: none;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 700;
  margin-top: 0;
  padding: 0.625rem 0;
  text-align: center;
}
.bl_restaurant_upper_special_wrap h3::before {
  content: none;
}
.bl_restaurant_upper_special_wrap h4 {
  color: #7E6728;
  margin-bottom: 0.75rem;
  margin-top: 2.25rem;
  padding-left: 0;
}
.bl_restaurant_upper_special_wrap h4::before {
  content: none;
}
.bl_restaurant_upper_special_wrap .bl_txt_upper {
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: 0;
  margin-top: 0.75rem;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_special_wrap .bl_txt_upper {
    font-size: 1.375rem;
  }
}
.bl_restaurant_upper_special_wrap .bl_txt_lower {
  font-size: 1.125rem;
  font-weight: 500;
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_special_wrap .bl_txt_lower {
    font-size: 1.625rem;
  }
}

.bl_restaurant_upper_guide {
  margin-top: 5.125rem;
}
.bl_restaurant_upper_guide dl {
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_upper_guide dl {
    margin-top: 3.25rem;
  }
}
.bl_restaurant_upper_guide dl .hp_font {
  font-family: "Roboto", sans-serif;
  font-size: 1.375rem;
  font-weight: 500;
}

.bl_restaurant_footer_img {
  margin-bottom: 5rem;
  margin-top: 5rem;
}

@media screen and (min-width: 768px) {
  .bl_restaurant_footer_wrap {
    display: flex;
    justify-content: center;
  }
}
.bl_restaurant_footer_wrap img {
  display: block;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_restaurant_footer_wrap img {
    padding: 0 1.25rem;
  }
}
@media screen and (max-width: 767px) {
  .bl_restaurant_footer_wrap img:last-child {
    margin-top: 1.25rem;
  }
}

/* ミュージアムショップページ */
.bl_shop-list_upper_img {
  margin-top: 1.25rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .bl_shop-list_upper_img {
    margin-top: 3.25rem;
  }
}
.bl_shop-list_upper_img img {
  width: 100%;
}

.bl_shop-list_upper_img_inner {
  box-sizing: border-box;
  height: inherit;
  margin: 0 auto;
  max-width: 1220px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_shop-list_upper_img_inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.bl_shop-list_upper {
  margin-top: 2.875rem;
}
@media screen and (min-width: 768px) {
  .bl_shop-list_upper {
    margin-top: 6.625rem;
  }
}

.bl_shop-list_upper_inner {
  box-sizing: border-box;
  height: inherit;
  margin: 0 auto;
  max-width: 932px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_shop-list_upper_inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.bl_shop-list_h3 {
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
}

.bl_shop-list_p {
  font-size: 1rem;
  margin-bottom: 0;
  text-align: center;
}

.bl_shop-list_lead {
  margin: 0 1rem;
  padding: 1.25rem 0 1.5rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .bl_shop-list_lead {
    padding-bottom: 3.125rem;
    padding-top: 2.25rem;
  }
}
.bl_shop-list_lead p {
  display: inline-block;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .bl_shop-list_lead p {
    text-align: center;
  }
}
.bl_shop-list_lead.hp_shop_border {
  border-bottom: 1px solid #DBDBDB;
}

.bl_snslink_wrap {
  border-bottom: 1px solid #DBDBDB;
  padding-bottom: 3.125rem;
}
@media screen and (min-width: 768px) {
  .bl_snslink_wrap {
    display: flex;
    justify-content: space-between;
  }
}
.bl_snslink_wrap div {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .bl_snslink_wrap div {
    width: 33.3333333333%;
  }
}
.bl_snslink_wrap .bl_snslink_txt {
  font-size: 0.875rem;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .bl_snslink_wrap .bl_snslink_txt {
    margin-bottom: 0.375rem;
  }
}
.bl_snslink_wrap .bl_snslink_btn {
  margin: 0 auto;
  max-width: 230px;
  width: 80%;
}

/* サイトポリシーページ */
.bl_site-policy_h2 {
  font-size: 1.25rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .bl_site-policy_h2 {
    font-size: 1.5rem;
    margin-top: 4rem;
  }
}
/*# sourceMappingURL=sourcemaps/wysiwyg.css.map */