@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Shippori+Mincho:wght@600;700&display=swap');

@font-face {
  font-family: icon;
  src: url(./font/icon.eot);
  src: url(./font/icon.eot#iefix) format("embedded-opentype"),
       url(./font/icon.woff) format("woff"),
       url(./font/icon.ttf) format("truetype"),
       url(./font/icon.svg#icon) format("svg");
  font-weight: normal;
  font-style: normal;
}

 [class^="ico-"]:before, [class*=" ico-"]:before { display: inline-block; font-family: "icon"; font-size: 120%; font-style: normal; font-variant: normal; font-weight: normal; line-height: 1em; margin-left: .2em; margin-right: .2em; text-align: center; text-decoration: inherit; text-transform: none; width: 1em; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.ico-arrow:before { content: '\e800'; }
.ico-pagetop:before { content: '\e802'; }
.ico-angle-left:before { content: '\f104'; }
.ico-angle-right:before { content: '\f105'; }
.ico-angle-up:before { content: '\f106'; }
.ico-angle-down:before { content: '\f107'; }

.jtb-nav-breadcrumb { margin-bottom: 25px; max-width: 1236px; }
.l-page { font-family: 'Noto Sans JP', sans-serif; font-size: 16px; line-height: 1.6; text-align: center; width: 100%; }
.l-page * { box-sizing: border-box; }
.l-page h1 { font-family: 'Noto Sans JP', sans-serif; font-size: 18px; font-weight: bold; line-height: 1; margin: 0 auto 25px; max-width: 1236px; text-align: left; }
.l-page a { color: #ff253a; }
.l-page a, .l-page a img { transition: all .4s ease; }
.l-page em { font-family: 'Shippori Mincho', serif; font-weight: 600; }
.l-page img { display: block; margin: 0 auto; width: 100%; }
.l-page .lazyload { opacity: 0; transition: opacity .8s ease-out; }
.l-page .lazyloaded { opacity: 1; }

.l-page .c-btn { align-items: center; border-radius: .3125em; display: flex; justify-content: center; width: 100%; }
.l-page .c-btn span { font-family: 'Shippori Mincho', serif; font-weight: 700; }
.l-page .c-btn__plan { background-color: #fff; border: 2px solid #9c662b; box-shadow: 0 .3125em 0 0 #9c662b; }
.l-page .c-btn__plan span { color: #9c662b; }
.l-page .c-btn__coupon { background-color: #9c662b; box-shadow: 0 .3125em 0 0 #673c0d; }
.l-page .c-btn__coupon span { color: #fff; }
.l-page .c-inner { margin: 0 auto; max-width: 1236px; }
.l-page .c-pic { position: relative; }
.l-page .c-pic span { display: block; font-size: .875em; margin-top: .125em; text-align: right; }
.l-page .c-tab__list { display: flex; flex-wrap: wrap; }
.l-page .c-tab__txt { border-radius: .25em; color: #152929; display: block; font-family: 'Shippori Mincho', serif; transition: all .3s ease; width: 100%; }
.l-page .c-tab.is-selected .c-tab__txt { color: #9c662b; }
.l-page .c-tab__float.is-fixed { position: fixed; z-index: 100; }
.l-page .c-tab__float.is-fixed .c-trigger { align-items: center; background-color: #673c0d; border-radius: 50%; bottom: 0; cursor: pointer; display: flex; height: 4.4em; justify-content: center; position: absolute; right: -.5em; width: 4.4em; z-index: 1; }
.l-page .c-tab__float.is-fixed .c-trigger span, .l-page .c-tab__float.is-fixed .c-trigger span::before, .l-page .c-tab__float.is-fixed .c-trigger span::after { background-color: #fff; border-radius: 100vh; display: block; height: .25em; width: 50%; }
.l-page .c-tab__float.is-fixed .c-trigger span { position: relative; transition: all .3s ease; }
.l-page .c-tab__float.is-fixed .c-trigger span::before, .l-page .c-tab__float.is-fixed .c-trigger span::after { content: ""; left: 50%; position: absolute; transform: translateX(-50%); transition: all .3s ease; }
.l-page .c-tab__float.is-fixed .c-trigger span::before { top: -.5em; width: 80%; }
.l-page .c-tab__float.is-fixed .c-trigger span::after { top: .5em; width: 60%; }
.l-page .c-tab__float.is-fixed .c-trigger.is-open span { background-color: transparent; }
.l-page .c-tab__float.is-fixed .c-trigger.is-open span::before { left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(-315deg); width: 100% }
.l-page .c-tab__float.is-fixed .c-trigger.is-open span::after { left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(315deg); width: 100% }
.l-page .c-tab__float.is-fixed .c-tab__list { background-color: #fff; border: 3px solid #673c0d; border-radius: .75em; bottom: 3em; display: none; flex-direction: column; overflow: hidden; position: absolute; right: 1em; }
.l-page .c-tab__float.is-fixed .c-tab { padding: 0; }
.l-page .c-tab__float.is-fixed .c-tab + .c-tab { border-top: 1px solid #673c0d; }
.l-page .c-tab__float.is-fixed .c-tab__txt { padding: .25em; }
.l-page .c-tab__float.is-fixed .c-tab.is-selected .c-tab__txt { background-color: #f7efe6; }
.l-page .c-tab__float.is-fixed .c-tab__list.is-open { display: flex; }
.js-btn-page-top { bottom: 50px; cursor: pointer; display: none; position: fixed; right: 50px; z-index: 100; }
.js-btn-page-top a { display: block; height: 17px; position: relative; width: 35px; }
.js-btn-page-top a::before { color: #000; content: "\e802"; display: inline-block; font-family: "icon"; font-size: 17px; height: 17px; width: 35px; }
.js-btn-page-top a:hover { opacity: .8; }

.l-mv { align-items: center; background: url(../images/bg_mv.jpg) no-repeat 50% 50% / cover; display: flex; justify-content: center; position: relative; }
.l-mv p em { color: #fff; font-size: 1.5em; }
.l-mv__title { max-width: inherit; }
.l-contents { background-color: #fff; }
.l-contents .c-inner { margin: 0 auto; max-width: 1236px; }
.sec-hotels .c-panel__wrap { padding-top: 3em; }
.sec-hotels .c-panel { display: none; }
.sec-hotels .c-panel.is-selected { animation: .8s slide-in-up; display: block; }
.sec-hotels .c-panel__title { font-family: 'Shippori Mincho', serif; font-size: 1.625em; font-weight: 700; margin-bottom: 1.5em; }
.sec-hotels .c-panel__title em { color: #9c662b; font-size: 1.25em; }
.sec-hotels .c-hotel__item { background: #f7efe6 url(../images/bg_hotel.png) no-repeat 98% 98%; position: relative; text-align: left; }
.sec-hotels .c-hotel__heading { align-items: center; background-color: #9c662b; display: flex; font-family: 'Shippori Mincho', serif; line-height: 1; }
.sec-hotels .c-hotel__heading::before { background: repeating-linear-gradient(#dfbe99, #dfbe99 2px, transparent 2px, transparent 4px); content: ""; display: block; margin-right: 1.25em; width: .75em; }
.sec-hotels .c-hotel__heading .c-area { background-color: #fff; border-radius: 100vh; color: #673c0d; display: inline-block; margin-right: 1em; padding: .25em 1em; white-space: nowrap; }
.sec-hotels .c-hotel__heading .c-name { color: #fff; font-size: 1.5em; }
.sec-hotels .c-room__name { color: #291f15; font-size: 1.5em; font-weight: 700; }
.sec-hotels .c-room__name small { font-size: .625em; font-weight: normal; }
.sec-hotels .c-room__info { margin-top: .5em; }
.sec-hotels .c-room__capacity { background-color: #9c662b; border-radius: 100vh; color: #fff; display: inline-block; line-height: 1.5em; margin-right: 1em; white-space: nowrap; }
.sec-hotels .c-room__summary { font-size: 1.125em; margin-top: 2em; }
.sec-hotels .c-meal__block { font-size: 1.125em; margin-top: 1.5em; }
.sec-hotels .c-meal__block dt { color: #9c662b; font-weight: 700; width: 5.5em; }
.sec-hotels .c-meal__block dt::after { content: "："; }

@media screen and (min-width:768px) and ( max-width:1236px) {
  .l-page { font-size: 1.25vw; margin: 0; }
}
@media screen and (min-width:768px){
  .sp-item { display: none !important; }
  .breadcrumb-upper { display: none; }
  .l-page a:hover { text-decoration: none; }
  .l-page .c-btn__block { margin-top: 2.5em; }
  .l-page .c-btn { height: 5em; }
  .l-page .c-btn span { font-size: 1.375em; }
  .l-page .c-btn:hover { box-shadow: none; transform: translateY(.3125em); }
  .l-page .c-flex { display: flex; justify-content: center; }
  .l-page .c-tab__list { justify-content: center; }
  .l-page .c-tab__list::before, .l-page .c-tab__list::after { content: ""; width: 100%; }
  .l-page .c-tab__list::before { order: 2; }
  .l-page .c-tab { border-left: 1px solid #cdcdcd; margin: .25em 0; padding: 0 .25em; }
  .l-page .c-tab:nth-child(n+4) { order: 1; }
  .l-page .c-tab:nth-child(n+8) { order: 2; }
  .l-page .c-tab:last-child { border-right: 1px solid #cdcdcd;; }
  .l-page .c-tab__txt { padding: .125em 1.5em; }
  .l-page .c-tab__txt:hover { background-color: #f7efe6; cursor: pointer; }
  .l-page .c-tab__txt small { font-size: .8125em; }
  .l-page .c-tab__float.is-fixed { bottom: 5em; right: 42px; }
  .l-page .c-tab__float.is-fixed .c-tab { margin: 0; }
  .l-page .c-tab__float.is-fixed .c-tab__txt { width: 20em; }
  .l-contents .c-inner { padding: 2.75em 0; width: 88%; }
  .l-mv { height: 33.125em; }
  .l-mv__title { width: 48.625em; }
  .sec-hotels .c-hotel__item { background-size: 22.5em auto; padding: 0 4em 3.125em; }
  .sec-hotels .c-hotel__item + .c-hotel__item { margin-top: 2em; }
  .sec-hotels .c-hotel__heading { height: 5em; margin: 0 -4em; padding: 0 2.5em; }
  .sec-hotels .c-hotel__heading::before { height: 2.5em; }
  .sec-hotels .c-room__info { align-items: center; display: flex; }
  .sec-hotels .c-room__capacity { padding: 0 .875em; }
  .sec-hotels .c-pic__block { display: flex; justify-content: space-between; padding: 3em 0 1.5em; }
  .sec-hotels .c-pic { width: calc(calc(100% - 1.75em) / 3); }
  .sec-hotels .c-btn__block, .sec-hotels .c-meal__block { display: flex; justify-content: space-between; }
  .sec-hotels .c-btn__block .c-btn { width: calc(50% - .5em); }
  .sec-hotels .c-meal__block { align-items: flex-start; }
  .sec-hotels .c-meal__block dl { display: flex; flex-wrap: wrap; width: calc(50% - 1em); }
  .sec-hotels .c-meal__block dd { width: calc(100% - 5.5em); }
}

@media screen and (max-width:767px){
  .pc-item { display: none !important; }
  #JTBGF-ly_footer.JTBGF-ly_footer { margin-top: 0 !important; }
  .jtb-nav-breadcrumb { display: none; }
  .breadcrumb-upper { background-color: #fff; border-top: 1px solid #d7d7d7; display: flex; flex-wrap: nowrap; font-size: 10px; line-height: 3rem; margin-top: 5em; overflow: hidden; position: relative; }
  .breadcrumb-upper__fix { box-shadow: 6px 0 10px 0 rgba(0, 0, 0, .3); position: relative; transition: box-shadow .3s; width: 7em; z-index: 3; }
  .breadcrumb-upper__fix a { padding-left: .5rem; }
  .breadcrumb-upper__scroll { flex: 1; overflow: hidden; }
  .breadcrumb-upper__list { display: flex; flex-wrap: nowrap; height: 3rem; overflow-x: scroll; overflow-y: hidden; white-space: nowrap; }
  .breadcrumb-upper__item a { padding: 0 .5rem 0 1.8rem; }
  .breadcrumb-upper__item:last-child { padding: 0 1.2rem 0 1.8rem; }
  .breadcrumb-upper__fix a, .breadcrumb-upper__item a { display: block; background-color: #fff; text-align: center; position: relative; }
  .breadcrumb-upper__fix a::before, .breadcrumb-upper__item a::before, .breadcrumb-upper__fix a:after, .breadcrumb-upper__item a:after { content: ""; border-style: solid; border-width: 2rem 0 2rem 1rem; position: absolute; top: -.5rem; }
  .breadcrumb-upper__fix a::before, .breadcrumb-upper__item a::before { border-color: transparent transparent transparent #fff; right: -.9rem; z-index: 2; }
  .breadcrumb-upper__fix a::after, .breadcrumb-upper__item a::after { border-color: transparent transparent transparent #d7d7d7; right: -1rem; z-index: 1; }
  .js-btn-page-top { bottom: 20px; right: 20px; }
  .js-btn-page-top a { background-color: #999; border-radius: 6px; display: block; height: 30px; width: 30px; }
  .js-btn-page-top a::before { color: #fff; content: "\f106"; display: inline-block; font-family: "icon"; line-height: 29px; width: auto; }
  .l-page { font-size: 3.2vw; padding: 20px 0 0; }
  .l-page h1 { margin-bottom: 20px; padding: 0 1%; }
  .l-page .c-btn__block { margin-top: 1.5em; }
  .l-page .c-btn { height: 4em; }
  .l-page .c-btn + .c-btn { margin-top: 1em; }
  .l-page .c-btn span { font-size: 1.25em; }
  .l-page .c-pic { flex-direction: column; }
  .l-page .c-tab__list { background-color: #cdcdcd; gap: 1px; justify-content: space-between; }
  .l-page .c-tab { background-color: #f7efe6; width: calc(calc(100% - 2px) / 3); }
  /* .l-page .c-tab:nth-child(even) { border-left: 1px solid #cdcdcd; } */
  .l-page .c-tab__txt { padding: .5em 0; }
  .l-page .c-tab__txt small { display: block; font-size: .75em; }
  .l-page .c-tab__float.is-fixed { bottom: 64px; right: calc(35px - 3.6em / 2); }
  .l-page .c-tab__float.is-fixed .c-tab { background-color: #fff; width: 100%; }
  .l-page .c-tab__float.is-fixed .c-tab__txt { font-size: 1.125em; height: 2.5em; margin: 0; width: 62vw; }
  .l-page .c-tab__float.is-fixed .c-tab__txt small { display: inline; }
  .l-contents .c-inner { width: 100%; }
  .l-mv { height: 56vw; }
  .l-mv__title { width: 72%; }
  .l-mv__title p { font-size: .75em; }
  .sec-hotels .c-panel__title em small { font-size: .625em; }
  .sec-hotels .c-hotel__item { background-size: 80% auto; padding-bottom: 4em; }
  .sec-hotels .c-hotel__heading { height: 5em; padding: 0 1em; }
  .sec-hotels .c-hotel__heading::before { height: 2.5em; }
  .sec-hotels .c-room__data, .sec-hotels .c-room__summary, .sec-hotels .c-meal__block, .sec-hotels .c-btn__block { margin: 1em auto 0; width: 86%; }
  .sec-hotels .c-room__capacity { padding: .25em 1em; }
  .sec-hotels .c-pic__block { opacity: 0; transition: opacity .3s linear; }
  .sec-hotels .c-pic__block.slick-initialized { opacity: 1; }
  .sec-hotels .c-pic { margin: 0 .25em; }
  .sec-hotels .c-meal__block dt { clear: left; float: left; }
  .sec-hotels .c-meal__block dd { padding-left: 5.5em; }
}

/* Slider */
.slick-slider { position: relative; display: block; box-sizing: border-box; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-touch-callout: none; -khtml-user-select: none; -ms-touch-action: pan-y; touch-action: pan-y; -webkit-tap-highlight-color: transparent; }
.slick-list { position: relative; display: block; overflow: hidden; margin: 0; padding: 0; }
.slick-list:focus { outline: none; }
.slick-list.dragging { cursor: pointer; cursor: hand; }
.slick-slider .slick-track, .slick-slider .slick-list { -webkit-transform: translate3d(0, 0, 0); -moz-transform: translate3d(0, 0, 0);  -ms-transform: translate3d(0, 0, 0); -o-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); }
.slick-track { position: relative; top: 0; left: 0; display: flex; margin-left: auto; margin-right: auto; }
.slick-track::before, .slick-track::after { display: table; content: ""; }
.slick-track::after { clear: both; }
.slick-loading .slick-track { visibility: hidden; }
.slick-slide { display: none; float: left; height: auto !important; min-height: 1px; }
.slick-slide img { display: block; }
.slick-slide.slick-loading img { display: none; }
.slick-slide.dragging img { pointer-events: none; }
.slick-initialized .slick-slide { display: flex; }
.slick-loading .slick-slide { visibility: hidden; }
.slick-vertical .slick-slide { display: block; height: auto; border: 1px solid transparent; }
.slick-arrow.slick-hidden { display: none; }
.slick-dotted.slick-slider { margin-bottom: 2em; }
.slick-dots { bottom: -2em; display: block; margin: 0; padding: 0; position: absolute; text-align: center; width: 100%; }
.slick-dots li { display: inline-block; height: 1.5em; margin: 0; padding: 0; position: relative; width: 1.5em; }
.slick-dots li button { background-color: transparent; border: 0; color: transparent; display: block; height: 1.5em; line-height: 0; outline: none; width: 1.5em; }
.slick-dots li button:hover, .slick-dots li button:focus { outline: none; }
.slick-dots li button::before { background-color: #ccc; content: ""; border-radius: 100vh; display: inline-block; height: .625em; left: 50%; position: absolute; top: 50%; transform: translate(-50%, -50%); transition: width .4s ease; width: .625em; }
.slick-dots li.slick-active button::before { background-color: #d8420e; width: 1.5em; }
