@charset "UTF-8";
/* =========================================

break point

========================================= */
html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, tr, dt, dd, p, a, header, hgroup, section, article, aside, hgroup, footer, figure, figcaption, nav {
  font-size: 16px;
  letter-spacing: 0.05rem;
  font-family: "Shippori Mincho", "Work Sans", serif;
}
@media screen and (max-width: 767px) {
  html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, tr, dt, dd, p, a, header, hgroup, section, article, aside, hgroup, footer, figure, figcaption, nav {
    font-size: 14px;
  }
}
html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, tr, dt, dd, p, a, header, hgroup, section, article, aside, hgroup, footer, figure, figcaption, nav {
  margin: 0;
  padding: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
  display: block;
}

html {
  font-size: 62.5%;
}

body {
  line-height: 1;
  -webkit-text-size-adjust: none;
}

.body {
  background: #f7f6f6;
}

.top-body {
  background-image: url(../images/body_bg.jpg);
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
}

img {
  border: 0;
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

table {
  border-spacing: 0;
  empty-cells: show;
}

/* clearfix */
.cf {
  zoom: 1;
}

.cf:before, .cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

* {
  font-family: "Noto Sans JP", sans-serif;
  list-style: none;
}

* {
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  font-size: 14px;
}

p {
  line-height: 1.5;
}

img {
  height: auto;
  max-width: 100%;
}

a {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

/* =========================================

break point

========================================= */
.flex {
  display: flex;
}
@media screen and (max-width: 767px) {
  .flex {
    flex-direction: column;
  }
}

.text-sp {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .text-sp {
    text-align: left;
  }
}

.section-padding {
  padding: 100px 20px;
}
@media screen and (max-width: 767px) {
  .section-padding {
    padding: 40px 20px;
  }
}

.container {
  max-width: 1100px;
  margin: 0 auto;
}

.mod-center {
  text-align: center;
}

.mod-hd__h2 {
  text-align: center;
}
.mod-hd__h2 h2 {
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 10px;
  position: relative;
  padding-bottom: 10px;
  margin-bottom: 6px;
}
.mod-hd__h2 h2::after {
  content: "";
  position: absolute;
  width: 350px;
  height: 1px;
  background: #323234;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .mod-hd__h2 h2::after {
    width: 280px;
  }
}
.mod-hd__h2 p {
  letter-spacing: 4px;
  font-size: 0.9rem;
}
.mod-hd__h2.white h2 {
  color: #fff;
}
.mod-hd__h2.white h2::after {
  background: #a2a2a2;
}
.mod-hd__h2.white p {
  color: #fff;
}

.mod-hd__h2__under {
  margin-top: 28px;
  padding: 0 20px;
}
.mod-hd__h2__under p {
  line-height: 2;
  font-size: 0.9rem;
}
.mod-hd__h2__under p span {
  display: block;
  font-size: 1rem;
  margin-bottom: 8px;
  font-family: "Shippori Mincho", "Work Sans", serif;
}
.mod-hd__h2__under .mod-hd__h2__under-btn {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .mod-hd__h2__under .mod-hd__h2__under-btn {
    text-align: center;
  }
}
.mod-hd__h2__under .mod-hd__h2__under-btn a {
  position: relative;
  font-size: 0.7rem;
}
.mod-hd__h2__under .mod-hd__h2__under-btn a:after {
  content: "";
  position: absolute;
  width: 5px;
  height: 5px;
  border-top: 1px solid #333333;
  border-right: 1px solid #333333;
  transform: rotate(45deg);
  top: 6px;
  right: -14px;
}

.mod-hd__h2__under.white p {
  color: #fff;
}

.btn a {
  display: inline;
  background: #496374;
  padding: 6px 20px;
  color: #f7f8f8;
  font-size: 0.8rem;
}

.page-header {
  position: relative;
  height: 650px;
  background-position: center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .page-header {
    height: 290px;
  }
}

.page-header.onsen {
  background-image: url(../images/onsen/onsen_img_01.jpg);
}

.page-header.rooms {
  background-image: url(../images/rooms/rooms_img_01.jpg);
}

.page-header.cuisine {
  background-image: url(../images/cuisine/cuisine_img_01.jpg);
}

.header-under {
  margin-top: 100px;
  padding: 80px 20px 0px;
}
@media screen and (max-width: 767px) {
  .header-under {
    padding: 60px 20px 0px;
    margin-top: 30px;
  }
}

.header-under.page {
  margin-top: 10px;
}

.header-under-img .header-under-img-md {
  margin: 80px 0 30px;
  text-align: center;
}
.header-under-img .header-under-img-md p {
  font-size: 0.8rem;
  letter-spacing: 2px;
}
.header-under-img .header-under-img-md h3 {
  font-size: 1.4rem;
  letter-spacing: 8px;
  margin: 12px 0 8px;
}

/* =========================================

break point

========================================= */
* {
  box-sizing: border-box;
  color: #2e2e2e;
}

.swiper-wrapper {
  /* wrapperのサイズを調整 */
  width: 100%;
  max-height: 570px;
  display: flex;
  align-items: flex-end;
  transition-timing-function: linear;
}
.swiper-slide {
  color: #ffffff;
  width: auto;
  height: 100%;
  text-align: center;
}
@media screen and (max-width: 1440px) {
  .swiper-slide.big {
    width: 30%;
  }
}
@media screen and (max-width: 1440px) {
  .swiper-slide.small {
    width: 20%;
  }
}
.swiper-slide img {
  width: auto;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
  display: inline-block;
}

header {
  width: 100%;
  z-index: 999;
}

#fixed-header {
  position: fixed;
  top: -80px;
  width: 100%;
  color: #fff;
  box-sizing: border-box;
  transition: 0.5s; /* アニメーションタイミング */
}
#fixed-header.is-scrolled {
  background: rgba(29, 25, 18, 0.7803921569);
}
#fixed-header.lower-page {
  background: rgba(29, 25, 18, 0.7803921569);
}
@media screen and (max-width: 767px) {
  #fixed-header {
    top: 0;
  }
}
#fixed-header .header-inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #fixed-header .header-inner {
    padding: 10px 0px 10px 30px;
  }
}
#fixed-header .header-inner .header-logo {
  max-width: 112px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #fixed-header .header-inner .header-logo {
    max-width: 80px;
  }
}
#fixed-header .header-inner .header-inner-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
#fixed-header .header-inner .header-inner-right .language {
  position: relative;
  bottom: 0;
  right: 50px;
}
@media screen and (max-width: 767px) {
  #fixed-header .header-inner .header-inner-right .language {
    display: none;
  }
}
#fixed-header .header-inner .header-inner-right .language a {
  display: flex;
  gap: 10px;
}
#fixed-header .header-inner .header-inner-right .language a img {
  width: 20px;
}
#fixed-header .header-inner .header-inner-right .language a p {
  color: #FFFFFF;
}
#fixed-header .header-inner .header-inner-right .header-inner-right__contact {
  transition: 0.4s;
}
#fixed-header .header-inner .header-inner-right .header-inner-right__contact img {
  width: 140px;
}
#fixed-header .header-inner .header-inner-right .header-inner-right__contact:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  #fixed-header .header-inner .header-inner-right .header-inner-right__contact {
    max-width: 80px;
  }
}
#fixed-header .header-inner .header-inner-right .header-inner-right__contact a img {
  width: 100%;
}
#fixed-header .header-inner .header-inner-right .header-inner-right__contact p {
  color: #FFFFFF;
  background-color: #b54443;
}

#fixed-header.is-show {
  top: 0;
}

.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

.container-700 {
  max-width: 700px;
  width: 100%;
  margin: 0 auto;
}

.pc {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

.sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }
}

h3 {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  h3 {
    font-size: 2rem;
  }
}

p {
  line-height: 1.8;
}

.sec {
  padding: 100px 0;
}
@media screen and (max-width: 767px) {
  .sec {
    padding: 40px 0;
  }
}

.fut {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

.spnav {
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  background: rgba(29, 25, 18, 0.7019607843);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transition: all 0.5s;
  z-index: 1001;
  opacity: 0;
  visibility: hidden;
}
@media screen and (max-width: 767px) {
  .spnav {
    max-width: 300px;
  }
}

.open .spnav {
  right: 0;
  opacity: 1;
  visibility: visible;
}

.spnav-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 100px 30px 20px 30px;
  max-width: 830px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .spnav-inner {
    flex-direction: column;
    padding: 80px 20px 20px;
  }
}
.spnav-inner .spnav-inner-left {
  max-width: 400px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left {
    max-width: 210px;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__list {
  margin-top: 20px;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li {
  margin: 0 0 40px 0;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__list li {
    margin: 0 0 20px 0;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__list li a {
  display: block;
  position: relative;
  max-width: 600px;
  width: 100%;
  color: #f7f8f8;
  letter-spacing: 6px;
  font-weight: 300;
  padding: 1.3em 0.5em;
  text-decoration: none;
  transition-duration: 0.2s;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__list li a {
    font-size: 1.1rem;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__list li a:hover {
  transition: 0.4s;
  background: #2e3b44;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li a:after {
  content: "HOME";
  position: absolute;
  right: 110px;
  color: #bbbbbb;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__list li a:after {
    font-size: 0.8rem;
    top: 0;
    left: 10px;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__list li:nth-child(2) a:after {
  content: "ONSEN";
  right: 97px;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li:nth-child(3) a:after {
  content: "ROOMS";
  right: 97px;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li:nth-child(4) a:after {
  content: "CUISINE";
  right: 75px;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li:nth-child(5) a:after {
  content: "KUSATSU MAP";
  right: -2px;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li:nth-child(6) a:after {
  content: "TOPICS";
  right: 90px;
}
.spnav-inner .spnav-inner-left .spnav-inner__list li.spnav-inner__list__item.searcherea a:after {
  content: "RESERVATION";
  right: -2px;
}
.spnav-inner .spnav-inner-left .spnav-inner__menu {
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__menu {
    margin-top: 0px;
    margin-left: 9px;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__menu ul {
  display: flex;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__menu ul {
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__menu ul {
    margin-bottom: 50px;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__menu ul li {
  position: relative;
  padding-left: 20px;
  transition: 0.4s;
}
@media screen and (min-width: 768px) {
  .spnav-inner .spnav-inner-left .spnav-inner__menu ul li:not(:first-child) {
    margin-left: 45px;
  }
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__menu ul li {
    padding-left: 24px;
    margin-bottom: 24px;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__menu ul li a {
  font-size: 1.6rem;
  color: #f7f8f8;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-left .spnav-inner__menu ul li a {
    font-size: 1.1rem;
  }
}
.spnav-inner .spnav-inner-left .spnav-inner__menu ul li:hover {
  opacity: 0.7;
}
.spnav-inner .spnav-inner-left .spnav-inner__menu ul li:before {
  content: "";
  position: absolute;
  background-image: url(../images/footer_info.png);
  background-repeat: no-repeat;
  background-size: contain;
  top: 3px;
  left: 0;
  width: 14px;
  height: 14px;
}
.spnav-inner .spnav-inner-right {
  max-width: 80px;
}
@media screen and (min-width: 768px) {
  .spnav-inner .spnav-inner-right {
    margin-left: auto;
  }
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-right {
    max-width: 60px;
  }
}
.spnav-inner .spnav-inner-right .spnav-inner-right__logo img {
  width: 100%;
}
.spnav-inner .spnav-inner-right .spnav-inner-right__sns {
  display: flex;
  justify-content: center;
  text-align: center;
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .spnav-inner .spnav-inner-right .spnav-inner-right__sns {
    margin-top: 50px;
    flex-direction: column;
  }
}
.spnav-inner .spnav-inner-right .spnav-inner-right__sns a {
  transition: 0.4s;
}
.spnav-inner .spnav-inner-right .spnav-inner-right__sns a:hover {
  opacity: 0.7;
}
.spnav-inner .spnav-inner-right .spnav-inner-right__sns a:not(:last-child) {
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-right .spnav-inner-right__sns a:not(:last-child) {
    margin-bottom: 0px;
    margin-right: 20px;
  }
}
.spnav-inner .spnav-inner-right .spnav-inner-right__sns a img {
  width: 24px;
  height: 24px;
}
@media screen and (max-width: 767px) {
  .spnav-inner .spnav-inner-right .spnav-inner-right__sns a img {
    height: 21px;
  }
}

.spnav-inner__menu {
  display: flex;
  flex-wrap: wrap;
}
.spnav-inner__menu .spnav-inner__menu__item {
  margin-top: 12px;
  width: 100%;
}
.spnav-inner__menu .spnav-inner__menu__item .spnav-inner__menu__item__col {
  margin-top: 8px;
  text-align: center;
  padding: 20px 20px;
  width: 100%;
  background: #f2a039;
}
.spnav-inner__menu .spnav-inner__menu__item .spnav-inner__menu__item__col a {
  color: #fff;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.toggle_btn {
  display: block;
  position: relative;
  top: 2px;
  right: 30px;
  width: 36px;
  height: 30px;
  transition: all 0.5s;
  cursor: pointer;
  z-index: 1002;
}
@media screen and (max-width: 767px) {
  .toggle_btn {
    right: 13px;
  }
}
.toggle_btn.is-hide {
  display: none !important;
}

.toggle_btn span {
  display: block;
  position: absolute;
  left: 0;
  width: 36px;
  height: 2px;
  background-color: #FFFFFF;
  border-radius: 4px;
  transition: all 0.5s;
}

.toggle_btn span:nth-child(1) {
  top: 5px;
}

.toggle_btn span:nth-child(2) {
  top: 13px;
}

.toggle_btn span:nth-child(3) {
  bottom: 7px;
}

.open .toggle_btn {
  position: fixed;
  top: 26px;
  right: 30px;
}

.open .toggle_btn span:nth-child(1) {
  transform: translateY(10px) rotate(-315deg);
  top: 2px;
  background: #fff;
}

.open .toggle_btn span:nth-child(2) {
  opacity: 0;
}

.open .toggle_btn span:nth-child(3) {
  transform: translateY(-10px) rotate(315deg);
  background: #fff;
  bottom: 6px;
}

.toggle_btn__txt {
  position: relative;
  top: 27px;
  color: blue;
  font-size: 0.66rem;
  font-weight: 800;
}

#mask {
  display: none;
  transition: all 0.5s;
}

.open #mask {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.8;
  z-index: 1000;
  cursor: pointer;
}

.fadein {
  opacity: 0;
  transition: all 1s;
}

.fadein.active {
  opacity: 1;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.js-fade-up {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 1.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 1.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.js-fade-up.is-animated {
  opacity: 1;
  transform: translateY(0);
}

.js-line-draw,
.js-line-draw-sp {
  opacity: 0;
}
.js-line-draw.is-drawing,
.js-line-draw-sp.is-drawing {
  animation: lineFadeIn 2s ease-out forwards;
}

@keyframes lineFadeIn {
  0% {
    opacity: 0;
    transform: scaleY(0);
    transform-origin: top center;
  }
  100% {
    opacity: 1;
    transform: scaleY(1);
  }
}
.js-text-fade,
.js-text-fade-sp {
  opacity: 0;
  transform: translateY(20px);
}
.js-text-fade.is-visible,
.js-text-fade-sp.is-visible {
  animation: textFadeIn 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

@keyframes textFadeIn {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
svg .svg-elem-1 {
  stroke-dashoffset: 568px;
  stroke-dasharray: 568px;
  transition: stroke-dashoffset 2.5s ease-out 0s;
}
svg .svg-elem-2 {
  stroke-dashoffset: 984.4683837891px;
  stroke-dasharray: 984.4683837891px;
  transition: stroke-dashoffset 6s ease-out 0s;
}
svg .svg-elem-3 {
  stroke-dashoffset: 338px;
  stroke-dasharray: 338px;
  transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}
svg .svg-elem-4 {
  stroke-dashoffset: 633.3473510742px;
  stroke-dasharray: 633.3473510742px;
  transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}
svg.active {
  stroke-dashoffset: 0;
}

.line-segment {
  stroke-dashoffset: 1000;
  stroke-dasharray: 1000;
}

/* 初期は全部非表示 */
.js-text-fade {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

/* 表示用 */
.js-text-fade.active {
  opacity: 1;
  animation: textFadeIn 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

/* SVG */
.line-segment {
  stroke-dasharray: 0;
  stroke-dashoffset: 0;
  transition: stroke-dashoffset 3s ease-out;
}

.toggle_btn_serch {
  position: relative;
  right: 10px;
  transition: all 0.5s;
  cursor: pointer;
  z-index: 900;
}
@media screen and (max-width: 767px) {
  .toggle_btn_serch {
    right: -12px;
    top: -8px;
  }
}

.spnavArea.open .toggle_btn_serch {
  z-index: 1030;
}

.toggle_btn_serch span {
  display: block;
  position: absolute;
  opacity: 0;
  left: 0;
  width: 36px;
  height: 2px;
  background-color: #496374;
  border-radius: 4px;
  transition: all 0.5s;
}

.toggle_btn_serch span:nth-child(1) {
  top: 5px;
}

.toggle_btn_serch span:nth-child(2) {
  top: 13px;
}

.toggle_btn_serch span:nth-child(3) {
  bottom: 7px;
}

.open .toggle_btn_serch {
  display: block;
  position: fixed;
  top: 26px;
  right: 30px;
  width: 36px;
  height: 30px;
}
.open .toggle_btn_serch .header-inner-right__contact {
  display: none !important;
}
.open .toggle_btn_serch span {
  opacity: 1;
  background-color: #fff;
  transform: translateY(10px) rotate(-315deg);
}

.open .toggle_btn_serch span:nth-child(1) {
  transform: translateY(10px) rotate(-315deg);
  top: 2px;
  background: #fff;
}

.open .toggle_btn_serch span:nth-child(2) {
  opacity: 0;
}

.open .toggle_btn_serch span:nth-child(3) {
  transform: translateY(-10px) rotate(315deg);
  background: #fff;
  bottom: 6px;
}

@media screen and (max-width: 767px) {
  #searcherea .spnav {
    max-width: inherit;
  }
}
#searcherea .spnav .spnav-inner {
  display: block;
}
#searcherea .spnav .spnav-inner .spnav-inner-hd h3 {
  color: #fff;
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 14px;
  text-align: center;
  padding-bottom: 10px;
  position: relative;
}
@media screen and (max-width: 767px) {
  #searcherea .spnav .spnav-inner .spnav-inner-hd h3 {
    font-size: 1.3rem;
  }
}
#searcherea .spnav .spnav-inner .spnav-inner-hd h3:after {
  content: "";
  position: absolute;
  width: 340px;
  height: 1px;
  background: #fff;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #searcherea .spnav .spnav-inner .spnav-inner-hd h3:after {
    width: 140px;
  }
}
#searcherea .spnav .spnav-inner .spnav-inner-hd p {
  padding-top: 14px;
  letter-spacing: 10px;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #searcherea .spnav .spnav-inner .spnav-inner-hd p {
    padding-top: 10px;
    font-size: 10px;
    letter-spacing: 6px;
  }
}

.search_panel form {
  background: none;
  box-shadow: none;
  padding-top: 130px;
  max-width: 630px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .search_panel form {
    padding-top: 40px;
  }
}
.search_panel form section {
  display: flex !important;
  flex-direction: column;
}
.search_panel form section div {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .search_panel form section div {
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  .search_panel form section div label {
    max-width: 340px;
    width: 340px;
  }
}
.search_panel form section div label {
  color: #fff !important;
  font-family: "Shippori Mincho", serif !important;
}
.search_panel form section div label.count-picker-label-b478f8 {
  color: #000 !important;
}
.search_panel form section .input-container-width-sm-88e98c {
  width: 450px;
}
@media screen and (min-width: 768px) {
  .search_panel form section .input-container-input-container-da40af {
    margin: 0 10px 60px 0 !important;
  }
}
.search_panel form section .search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af .input-container-title-db81ec {
  position: relative;
  top: -5px;
}
.search_panel form section .search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af .input-container-title-db81ec:after {
  content: "CHECK IN - CHECK OUT";
  font-family: "Work Sans" !important;
  position: absolute;
  bottom: -24px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .search_panel form section .search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af .input-container-title-db81ec:after {
    right: 0;
    margin: auto;
    text-align: center;
  }
}
.search_panel form section .input-container-input-container-da40af .input-container-title-db81ec {
  position: relative;
  top: -5px;
}
.search_panel form section .input-container-input-container-da40af .input-container-title-db81ec:after {
  content: "ROOMS";
  font-family: "Work Sans" !important;
  position: absolute;
  bottom: -24px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .search_panel form section .input-container-input-container-da40af .input-container-title-db81ec:after {
    right: 0;
    margin: auto;
    text-align: center;
  }
}
.search_panel form .search-widget-button-wrapper-d2b715 {
  display: block;
}
.search_panel form .search-widget-button-wrapper-d2b715 button {
  max-width: 300px;
  display: block;
  width: 100%;
  margin: 30px auto 0;
  background: #fff !important;
  color: #496374 !important;
  font-family: "Shippori Mincho", serif !important;
}
@media screen and (max-width: 767px) {
  .search_panel form .search-widget-button-wrapper-d2b715 button {
    width: 173px;
  }
}

.search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af.input-container-width-sm-88e98c .input-container-title-db81ec {
  position: relative;
  top: -5px;
}
.search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af.input-container-width-sm-88e98c .input-container-title-db81ec:after {
  content: "GUESTS" !important;
  font-family: "Work Sans" !important;
  position: absolute;
  bottom: -24px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af.input-container-width-sm-88e98c .input-container-title-db81ec:after {
    right: 0;
    margin: auto;
    text-align: center;
  }
}

.search_btn_plan {
  text-align: center;
  margin: 24px auto 0;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .search_btn_plan {
    margin: 4px auto 0;
  }
}
.search_btn_plan a {
  max-width: 300px;
  display: block;
  margin: auto;
  width: 100%;
  border: 1px solid #fff;
  color: #fff;
  padding: 14px 20px;
  border-radius: 4px;
}
@media screen and (max-width: 767px) {
  .search_btn_plan a {
    max-width: 173px;
  }
}
.search_btn_plan:hover a {
  background: #5e6c75;
}

.dropdown-dropdown-f4f232 {
  width: 520px !important;
}

.count-picker-count-wrapper-2377dc {
  flex-direction: column;
}

.dropdown-dropdown-f4f232 {
  display: block !important;
}

.dropdown-dropdown-f4f232 {
  left: -150px;
}

@media screen and (max-width: 767px) {
  .input-container-input-container-da40af .input-container-slot-239963 {
    margin-top: 20px;
  }
  .input-container-slot-239963 {
    width: 240px;
  }
  .dropdown-selector-container-ef1ce2 {
    width: 240px;
  }
  .search-widget-two-picker-wrapper-4ca735 {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 350px) {
  .mobile-bottom-modal-header-0e2120 {
    font-size: 14px;
  }
}
.fv {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 92vh;
  min-height: 800px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .fv {
    height: 93vh;
    min-height: inherit;
  }
}
.fv .fv-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0;
  animation: fadeIn 3s ease-out forwards;
}
@media screen and (max-width: 767px) {
  .fv .fv-img {
    height: 100%;
  }
}
.fv .fv-copy {
  max-width: 500px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  gap: 30px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .fv .fv-copy {
    gap: 40px;
  }
}
@media screen and (max-width: 991px) {
  .fv .fv-copy {
    max-width: 400px;
  }
}
.fv .fv-copy .fv-logo {
  width: 120px;
}
@media screen and (max-width: 991px) {
  .fv .fv-copy .fv-logo {
    width: 100px;
  }
}
@media screen and (max-width: 991px) {
  .fv .fv-copy .fv-text {
    min-width: 310px;
  }
}
.fv .fv-opening {
  width: 240px;
  position: absolute;
  bottom: 60px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .fv .fv-opening {
    width: 210px;
    bottom: 32px;
  }
}

.cookie {
  background-color: #FFFFFF;
  padding: 16px 0;
}
.cookie .cookie-container {
  display: flex;
  gap: 32px;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 0 24px;
}
@media screen and (max-width: 1199px) {
  .cookie .cookie-container {
    flex-direction: column;
    gap: 10px;
  }
}
@media screen and (max-width: 1199px) {
  .cookie .cookie-container {
    padding: 0 20px;
  }
}
.cookie .cookie-container .cookie-text {
  font-size: 1.2rem;
}
.cookie .cookie-container .cookie-text a {
  font-size: 1.2rem;
  color: #3264b7;
  text-decoration: underline;
  transition: 0.4s;
}
.cookie .cookie-container .cookie-text a:hover {
  opacity: 0.7;
}
.cookie .cookie-container .consent {
  font-size: 1.2rem;
  background-color: #b54443;
  color: #FFFFFF;
  padding: 4px 0;
  width: 120px;
  text-align: center;
  cursor: pointer;
}
.cookie .cookie-container .consent:hover {
  opacity: 0.7;
}
@media screen and (max-width: 440px) {
  .cookie .cookie-container .consent {
    width: 100%;
  }
}
.cookie .cookie-container .cookie-close {
  font-size: 1.6rem;
  color: #1d1912;
  position: absolute;
  top: -15px;
  right: 10px;
  cursor: pointer;
  transition: 0.4s;
}
.cookie .cookie-container .cookie-close:hover {
  opacity: 0.7;
}

.container-under-fv01 {
  position: relative;
  background-image: url(../images/bg_01.jpg);
  background-position: center;
  background-size: cover;
}

.container-under-fv02 {
  position: relative;
  background-image: url(../images/bg_02.jpg);
  background-position: center;
  background-size: cover;
}

.main_copy {
  margin: 0 auto;
  position: relative;
  text-align: center;
  height: 750px;
}
@media screen and (max-width: 767px) {
  .main_copy {
    text-align: initial;
    padding-bottom: 48px;
    margin-bottom: 72px;
  }
}
@media screen and (max-width: 440px) {
  .main_copy {
    margin-bottom: 0;
  }
}
.main_copy .line01 {
  position: absolute;
  top: 0;
  left: calc(50% + 200px);
  height: 50%;
}
@media screen and (max-width: 767px) {
  .main_copy .line01 {
    height: 240px;
    left: calc(50% + 38px);
  }
}
@media screen and (max-width: 440px) {
  .main_copy .line01 {
    height: 230px;
    left: calc(50% + 38px);
  }
}
.main_copy .line02 {
  position: absolute;
  top: 50%;
  right: calc(50% + 148px);
  height: 50%;
}
@media screen and (max-width: 1440px) {
  .main_copy .line02 {
    width: 60vw;
  }
}
@media screen and (max-width: 767px) {
  .main_copy .line02 {
    width: 440px;
    top: inherit;
    right: inherit;
    bottom: -300px;
    left: 50%;
    transform: translateX(-402px) translateY(-50%);
  }
}
@media screen and (max-width: 440px) {
  .main_copy .line02 {
    width: 280px;
    top: inherit;
    right: inherit;
    bottom: -240px;
    left: 50%;
    transform: translateX(-243px) translateY(-50%);
  }
}
.main_copy .line_sp01 {
  margin-left: auto;
  padding-bottom: 30px;
  width: 40%;
}
.main_copy .line_sp01 img {
  width: 100px;
}
.main_copy .line_sp02 {
  width: 60%;
  display: inline-block;
  margin-right: auto;
}
.main_copy .main_copy_box {
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  gap: 40px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box {
    flex-direction: column;
    align-items: center;
  }
}
.main_copy .main_copy_box .main_copy_jp {
  writing-mode: vertical-rl;
  text-orientation: upright;
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box .main_copy_jp {
    padding-right: 0;
  }
}
.main_copy .main_copy_box .main_copy_jp p {
  font-size: 2.2rem;
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box .main_copy_jp p {
    font-size: 2rem;
  }
}
.main_copy .main_copy_box .main_copy_en {
  text-align: right;
  padding-left: 32px;
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box .main_copy_en {
    padding-left: 0;
  }
}
.main_copy .main_copy_box .main_copy_en img {
  display: block;
  margin-left: auto;
}
.main_copy .main_copy_box .main_copy_en .main_copy_en01 {
  height: 32px;
  margin-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box .main_copy_en .main_copy_en01 {
    height: 24px;
  }
}
.main_copy .main_copy_box .main_copy_en .main_copy_en02 {
  height: 32px;
  margin-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box .main_copy_en .main_copy_en02 {
    height: 24px;
  }
}
.main_copy .main_copy_box .main_copy_en .main_copy_en03 {
  height: 32px;
}
@media screen and (max-width: 767px) {
  .main_copy .main_copy_box .main_copy_en .main_copy_en03 {
    height: 24px;
  }
}

.concept {
  padding-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .concept {
    padding-bottom: 80px;
  }
}
.concept h2 {
  margin-bottom: 48px;
}
@media screen and (max-width: 767px) {
  .concept h2 {
    margin-bottom: 16px;
  }
}
.concept h2 img {
  height: 50px;
}
@media screen and (max-width: 767px) {
  .concept h2 img {
    height: 52px;
  }
}
.concept h3 {
  padding-left: 68px;
  padding-right: 40px;
  margin-bottom: 32px;
}
@media screen and (max-width: 991px) {
  .concept h3 {
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (max-width: 991px) {
  .concept h3 {
    margin-bottom: 44px;
  }
}
.concept .container {
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .concept .container {
    flex-direction: column;
    padding: 0;
  }
}
.concept .container .container-left {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .concept .container .container-left {
    width: 100%;
    padding: 0 20px;
  }
}
.concept .container .container-left p {
  padding-left: 68px;
  padding-right: 40px;
  font-weight: 600;
}
@media screen and (max-width: 991px) {
  .concept .container .container-left p {
    padding-left: 0;
    padding-right: 0;
  }
}
.concept .container .container-left .concept_img01 {
  width: 360px;
  margin-top: 60px;
}
.concept .container .container-right {
  width: 50%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .concept .container .container-right {
    width: 100%;
  }
}
.concept .container .container-right.sp {
  gap: 8%;
}
@media screen and (max-width: 767px) {
  .concept .container .container-right.sp {
    display: flex !important;
  }
}
.concept .container .container-right.sp .container-right-img-box01 {
  width: 57%;
  position: relative;
}
.concept .container .container-right.sp .container-right-img-box01 .concept_img01 {
  position: absolute;
  bottom: -50px;
  right: -132px;
  width: 85%;
}
.concept .container .container-right.sp .container-right-img-box02 {
  width: 35%;
}
.concept .container .container-right .concept_img02 {
  width: 440px;
}
@media screen and (max-width: 1199px) {
  .concept .container .container-right .concept_img02 {
    width: 380px;
  }
}
@media screen and (max-width: 767px) {
  .concept .container .container-right .concept_img02 {
    width: 100%;
  }
}
.concept .container .container-right .concept_img03 {
  width: 240px;
  position: absolute;
  bottom: -80px;
  right: -40px;
}
@media screen and (max-width: 1199px) {
  .concept .container .container-right .concept_img03 {
    bottom: 0;
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  .concept .container .container-right .concept_img03 {
    position: static;
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .rooted {
    padding-bottom: 100px;
  }
}
.rooted .title-en {
  position: relative;
  margin-bottom: 20px;
  margin-left: -24px;
  display: inline-block;
}
@media screen and (max-width: 1199px) {
  .rooted .title-en {
    margin-left: 80px;
  }
}
.rooted .title-en::before {
  content: "";
  background-color: #b54443;
  position: absolute;
  top: 50%;
  right: 100%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  width: 100vw;
  height: 1px;
  margin-right: 16px;
  z-index: 10;
}
.rooted .title-en img {
  width: 160px;
}
@media screen and (max-width: 767px) {
  .rooted .title-en img {
    width: 132px;
  }
}
.rooted h3 {
  padding-left: 124px;
  margin-bottom: 44px;
}
@media screen and (max-width: 1199px) {
  .rooted h3 {
    padding-left: 80px;
  }
}
@media screen and (max-width: 767px) {
  .rooted h3 {
    padding-left: 0;
    text-align: center;
    margin-bottom: 32px;
  }
}
@media screen and (max-width: 440px) {
  .rooted h3 {
    text-align: left;
  }
}
.rooted .container {
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .rooted .container {
    flex-direction: column;
    gap: 48px;
    padding: 0;
  }
}
.rooted .container .container-left {
  width: 52%;
}
@media screen and (max-width: 991px) {
  .rooted .container .container-left {
    width: 55%;
  }
}
@media screen and (max-width: 767px) {
  .rooted .container .container-left {
    width: 100%;
    padding: 0 20px;
  }
}
.rooted .container .container-left .container-left-inner-box {
  display: flex;
  gap: 60px;
}
@media screen and (max-width: 991px) {
  .rooted .container .container-left .container-left-inner-box {
    gap: 20px;
  }
}
@media screen and (max-width: 767px) {
  .rooted .container .container-left .container-left-inner-box {
    justify-content: center;
  }
}
@media screen and (max-width: 440px) {
  .rooted .container .container-left .container-left-inner-box {
    justify-content: flex-start;
  }
}
.rooted .container .container-left .container-left-inner-box .text-min p {
  font-weight: 600;
}
.rooted .container .container-left .container-left-inner-box .text-min p:first-child {
  margin-bottom: 20px;
}
.rooted .container .container-left .rooted_img01 {
  width: 180px;
  margin-top: 32px;
}
.rooted .container .container-right {
  width: calc(48% - 40px);
}
@media screen and (max-width: 991px) {
  .rooted .container .container-right {
    width: calc(45% - 40px);
  }
}
@media screen and (max-width: 767px) {
  .rooted .container .container-right {
    width: 100%;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .rooted .container .container-right .rooted_img01 {
    width: 30%;
    position: absolute;
    left: 0;
    bottom: -40px;
  }
}
.rooted .container .container-right .rooted_img02 {
  width: 480px;
  display: block;
  margin-right: left;
}
@media screen and (max-width: 767px) {
  .rooted .container .container-right .rooted_img02 {
    width: 80%;
    margin-left: auto;
  }
}

@media screen and (max-width: 767px) {
  .stayscenes {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
.stayscenes .container {
  position: relative;
}
.stayscenes .container .building-img {
  position: absolute;
  top: -76px;
  right: 0;
  width: 576px;
}
@media screen and (max-width: 1199px) {
  .stayscenes .container .building-img {
    top: -96px;
    width: 400px;
    right: 20px;
  }
}
@media screen and (max-width: 440px) {
  .stayscenes .container .building-img {
    width: 280px;
  }
}
.stayscenes h2 {
  margin-bottom: 32px;
}
.stayscenes h2 img {
  height: 50px;
}
@media screen and (max-width: 767px) {
  .stayscenes h2 img {
    height: 52px;
  }
}
.stayscenes h3 {
  padding-left: 120px;
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .stayscenes h3 {
    padding-left: 0;
    margin-bottom: 56px;
  }
}
.stayscenes h3 img {
  width: 220px;
}

.atmosphere {
  position: relative;
}
.atmosphere .atmosphere-bg {
  width: 100%;
}
.atmosphere .atmosphere-wrap {
  position: relative;
  display: inline-block; /* 必要に応じて */
}
.atmosphere .atmosphere-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  pointer-events: none;
}
.atmosphere .white-texts {
  position: absolute;
  top: 40px;
  right: 40px;
  width: 112px;
}
@media screen and (max-width: 767px) {
  .atmosphere .white-texts {
    width: 96px;
  }
}
@media screen and (max-width: 440px) {
  .atmosphere .white-texts {
    width: 80px;
    top: 20px;
    right: 20px;
  }
}

@media screen and (max-width: 767px) {
  .rooms {
    padding-bottom: 88px;
  }
}
.rooms h2 {
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .rooms h2 {
    width: 100%;
    text-align: center;
  }
}
@media screen and (max-width: 440px) {
  .rooms h2 {
    text-align: left;
  }
}
.rooms h2 img {
  height: 40px;
}
@media screen and (max-width: 767px) {
  .rooms h2 img {
    height: 37px;
  }
}
.rooms h3 {
  margin-bottom: 48px;
}
@media screen and (max-width: 767px) {
  .rooms h3 {
    margin-bottom: 36px;
  }
}
.rooms .container {
  display: flex;
  align-items: center;
  gap: 80px;
}
@media screen and (max-width: 1199px) {
  .rooms .container {
    gap: 48px;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container {
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container {
    flex-direction: column-reverse;
    align-items: flex-start;
  }
}
.rooms .container .container-left {
  width: 50%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .rooms .container .container-left {
    width: 100%;
    display: flex;
    gap: 20px;
    justify-content: center;
  }
}
@media screen and (max-width: 440px) {
  .rooms .container .container-left {
    justify-content: flex-start;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container .container-left .room_img01 {
    width: calc(50% - 10px);
  }
}
@media screen and (max-width: 440px) {
  .rooms .container .container-left .room_img01 {
    width: 75%;
  }
}
.rooms .container .container-left .room_img02 {
  width: 220px;
  position: absolute;
  bottom: -60px;
  right: 0;
}
@media screen and (max-width: 1199px) {
  .rooms .container .container-left .room_img02 {
    right: -15px;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container .container-left .room_img02 {
    position: static;
    width: calc(50% - 10px);
  }
}
@media screen and (max-width: 440px) {
  .rooms .container .container-left .room_img02 {
    position: absolute;
    width: 35%;
    right: 0;
  }
}
.rooms .container .container-right {
  width: 50%;
  position: relative;
}
@media screen and (max-width: 1199px) {
  .rooms .container .container-right {
    padding-left: 0;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container .container-right {
    width: 100%;
    text-align: center;
  }
}
@media screen and (max-width: 440px) {
  .rooms .container .container-right {
    text-align: left;
  }
}
.rooms .container .container-right p {
  font-weight: 600;
}
.rooms .container.light-img-box {
  position: relative;
}
.rooms .container.light-img-box .light-img {
  position: absolute;
  top: -80px;
  right: -40px;
  width: 100px;
}
@media screen and (max-width: 1199px) {
  .rooms .container.light-img-box .light-img {
    right: 10px;
    width: 88px;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container.light-img-box .light-img {
    top: -40px;
  }
}
@media screen and (max-width: 767px) {
  .rooms .container.light-img-box .light-img {
    width: 79px;
    right: 6px;
  }
}

.facilities {
  padding-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .facilities {
    padding-bottom: 60px;
  }
}
@media screen and (min-width: 768px) {
  .facilities .container .container-left .facilities_img01 {
    bottom: -70px;
    position: relative;
  }
}
@media screen and (min-width: 768px) {
  .facilities .container .container-left .facilities_img02 {
    width: 250px;
    bottom: -230px;
    right: -170px;
  }
}
.facilities .light-img-box .facilities-img {
  top: -100px !important;
  right: -40px !important;
  width: 210px !important;
}
@media screen and (max-width: 767px) {
  .facilities .light-img-box .facilities-img {
    top: -50px !important;
    right: 40px !important;
    width: 140px !important;
  }
}

.restaurant_lounge {
  padding-bottom: 280px;
}
@media screen and (max-width: 767px) {
  .restaurant_lounge {
    padding-bottom: 80px;
  }
}
@media screen and (max-width: 440px) {
  .restaurant_lounge {
    padding-bottom: 140px;
  }
}
@media screen and (min-width: 1441px) {
  .restaurant_lounge .spoon_folk {
    width: 400px;
  }
}
@media screen and (max-width: 1440px) {
  .restaurant_lounge .spoon_folk {
    width: 240px;
  }
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .spoon_folk {
    width: 220px;
  }
}
.restaurant_lounge .title-box {
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .title-box {
    width: 100%;
  }
}
.restaurant_lounge h2 {
  margin-left: auto;
  padding-right: 18px;
  margin-bottom: 36px;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .restaurant_lounge h2 {
    text-align: center;
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 440px) {
  .restaurant_lounge h2 {
    text-align: left;
  }
}
.restaurant_lounge h2 img {
  height: 104px;
}
@media screen and (max-width: 767px) {
  .restaurant_lounge h2 img {
    height: 80px;
  }
}
.restaurant_lounge h3 {
  margin-bottom: 48px;
}
@media screen and (max-width: 767px) {
  .restaurant_lounge h3 {
    margin-bottom: 32px;
  }
}
.restaurant_lounge .container {
  display: flex;
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .container {
    flex-direction: column;
    gap: 40px;
  }
}
.restaurant_lounge .container .container-left {
  width: 50%;
  padding-top: 60px;
}
@media screen and (max-width: 991px) {
  .restaurant_lounge .container .container-left {
    width: 60%;
  }
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .container .container-left {
    width: 100%;
    text-align: center;
  }
}
@media screen and (max-width: 440px) {
  .restaurant_lounge .container .container-left {
    padding-top: 48px;
    text-align: left;
  }
}
.restaurant_lounge .container .container-left p {
  font-weight: 600;
}
.restaurant_lounge .container .container-right {
  width: 50%;
  position: relative;
}
@media screen and (max-width: 991px) {
  .restaurant_lounge .container .container-right {
    width: 40%;
  }
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .container .container-right {
    width: 100%;
    display: flex;
    gap: 20px;
  }
}
.restaurant_lounge .container .container-right .restaurant_lounge_img01 {
  width: 540px;
}
@media screen and (max-width: 991px) {
  .restaurant_lounge .container .container-right .restaurant_lounge_img01 {
    width: 330px;
  }
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .container .container-right .restaurant_lounge_img01 {
    position: static;
    width: calc(50% - 10px);
  }
}
@media screen and (max-width: 440px) {
  .restaurant_lounge .container .container-right .restaurant_lounge_img01 {
    width: 90%;
    display: inline-block;
    margin-left: auto;
  }
}
.restaurant_lounge .container .container-right .restaurant_lounge_img02 {
  width: 400px;
  position: absolute;
  bottom: -200px;
  left: -100px;
}
@media screen and (max-width: 991px) {
  .restaurant_lounge .container .container-right .restaurant_lounge_img02 {
    width: 330px;
    bottom: -30px;
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .restaurant_lounge .container .container-right .restaurant_lounge_img02 {
    position: static;
    width: calc(50% - 10px);
  }
}
@media screen and (max-width: 440px) {
  .restaurant_lounge .container .container-right .restaurant_lounge_img02 {
    position: absolute;
    width: 50%;
    bottom: -40px;
    left: 0;
  }
}

.access {
  position: relative;
  background-color: #1d1912;
}
.access p {
  color: #FFFFFF;
}
.access h2 {
  margin-bottom: 48px;
}
@media screen and (max-width: 767px) {
  .access h2 {
    margin-bottom: 32px;
  }
}
.access h2 img {
  height: 40px;
}
@media screen and (max-width: 767px) {
  .access h2 img {
    height: 37px;
  }
}
.access .line03 {
  position: absolute;
  top: -80px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .access .line03 {
    top: -60px;
    width: 120px;
    height: 90px;
    display: block;
  }
}
.access .container {
  display: flex;
  width: 960px;
}
@media screen and (max-width: 991px) {
  .access .container {
    width: 100%;
  }
}
.access .container .container-left {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .access .container .container-left {
    width: 100%;
    text-align: center;
  }
}
@media screen and (max-width: 440px) {
  .access .container .container-left {
    text-align: left;
  }
}
.access .container .container-left p {
  font-weight: 600;
}
.access .container .container-left p:not(:last-child) {
  margin-bottom: 32px;
}
.access .container .container-left .access_img01 {
  width: 100%;
  max-width: 440px;
  display: inline-block !important;
}
@media screen and (min-width: 768px) {
  .access .container .container-left .access_img01.sp {
    display: none !important;
  }
}
@media screen and (max-width: 440px) {
  .access .container .container-left .access_img01 {
    max-width: 100%;
  }
}
.access .container .container-right {
  width: 50%;
  padding-top: 32px;
}
.access .container .container-right .access_img01 {
  width: 100%;
}

.line03-red, .line03-white, .svg-elem-5, .svg-elem-6, .svg-elem-7, .svg-elem-8 {
  stroke-dasharray: auto;
  stroke-dashoffset: auto;
  transition: stroke-dashoffset 3s cubic-bezier(0.47, 0, 0.745, 0.715);
}

.line03-red, .line03-white {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  transition: stroke-dashoffset 2s cubic-bezier(0.47, 0, 0.745, 0.715);
}
.line03-red.active, .line03-white.active {
  stroke-dashoffset: 0;
}

.googlemaps {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  .googlemaps {
    width: 100%;
    max-width: 440px;
    display: inline-block !important;
    margin-top: 20px;
    margin-bottom: 32px;
  }
  .googlemaps.pc {
    display: none !important;
  }
}
.googlemaps iframe {
  height: 450px;
}
@media screen and (max-width: 767px) {
  .googlemaps iframe {
    height: 360px;
  }
}

/* スマホ用 固定ボタン */
@media screen and (min-width: 768px) {
  .sp-reserve-btn {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .sp-reserve-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 999;
  }
  .sp-reserve-btn.is-hide {
    display: none !important;
  }
  .sp-reserve-btn .reserve-link {
    display: block;
    text-align: center;
    padding: 22px 0;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 600;
    background-color: #b54443;
    color: #FFFFFF;
    width: 100%;
    text-align: center;
  }
  .sp-reserve-btn .reserve-link-2 {
    display: block;
    text-align: center;
    padding: 22px 0;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 600;
    background-color: #b54443;
    color: #FFFFFF;
    width: 100%;
    text-align: center;
  }
}

footer {
  background: #71281E;
  padding-bottom: 40px;
}
footer .footer {
  max-width: 960px;
  margin: 0 auto 40px;
  padding: 60px 0 20px;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 991px) {
  footer .footer {
    padding: 40px 0 20px;
    gap: 10px;
  }
}
@media screen and (max-width: 767px) {
  footer .footer {
    flex-direction: column;
    text-align: center;
    gap: 32px;
  }
}
footer .footer p, footer .footer p a, footer .footer ul li a {
  color: #FFFFFF;
  font-size: 1.4rem;
}
@media screen and (max-width: 991px) {
  footer .footer p, footer .footer p a, footer .footer ul li a {
    font-size: 1.5rem;
  }
}
footer .footer .footer-menu .footer-logo {
  transition: 0.4s;
}
footer .footer .footer-menu .footer-logo:hover {
  opacity: 0.7;
}
footer .footer .footer-menu .footer-logo img {
  width: 100px;
}
@media screen and (max-width: 991px) {
  footer .footer .footer-menu .footer-logo img {
    width: 80px;
  }
}
footer .footer .footer-menu .footer-menu-title {
  font-size: 1.6rem;
  margin-bottom: 12px;
}
footer .footer .footer-menu .footer-menu-box li {
  transition: 0.4s;
}
footer .footer .footer-menu .footer-menu-box li:hover {
  opacity: 0.7;
}
footer .footer .footer-menu .footer-menu-box li:not(:last-child) {
  margin-bottom: 12px;
}
footer .footer .footer-menu .footer-googlemaps {
  display: inline-block;
  margin-top: 14px;
  transition: 0.4s;
}
footer .footer .footer-menu .footer-googlemaps:hover {
  opacity: 0.7;
}
footer .footer .footer-menu .footer-googlemaps img {
  width: 160px;
}
footer .footer .footer-menu .sns-icon-box {
  display: flex;
  gap: 40px;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  footer .footer .footer-menu .sns-icon-box {
    gap: 20px;
    justify-content: center;
  }
}
footer .footer .footer-menu .sns-icon {
  width: 36px;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  footer .footer .footer-menu .sns-icon {
    width: 24px;
  }
}
footer .footer .footer-menu .sns-icon:hover {
  opacity: 0.7;
}
footer .footer .footer-menu .top_arrow {
  transition: 0.4s;
}
footer .footer .footer-menu .top_arrow:hover {
  opacity: 0.7;
}
footer .footer .footer-menu .top_arrow img {
  width: 36px;
}
footer .copyright {
  text-align: center;
  color: #FFFFFF;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  footer .copyright {
    font-size: 1.1rem;
  }
}

#testSvg {
  border: 1px solid #ccc; /* 見やすくする用 */
}

/* ===== Privacy Policy ==== */
.privacy-header {
  text-align: center;
  padding: 160px 15px 30px;
}
@media screen and (max-width: 767px) {
  .privacy-header {
    padding: 100px 15px 30px;
  }
}
.privacy-header {
  /* 英語タイトル */
}
.privacy-header .privacy-header__hd {
  margin: 0;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: 0.12em;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .privacy-header .privacy-header__hd {
    font-size: 22px;
  }
}
.privacy-header .privacy-header__hd {
  /* 中のspanで装飾 */
}
.privacy-header .privacy-header__hd span {
  display: inline-block;
  padding-bottom: 6px;
  border-bottom: 2px solid #212529;
}
.privacy-header {
  /* 日本語サブタイトル */
}
.privacy-header .header-txt1 {
  margin-top: 12px;
  font-size: 15px;
  color: #666;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .privacy-header .header-txt1 {
    font-size: 12px;
  }
}

/* ===== Bootstrap風レイアウト最低限 ===== */
.row {
  display: flex;
  flex-wrap: wrap;
}
.row.justify-content-center {
  justify-content: center;
  /* 余白（好みで調整OK） */
  padding: 10px 10px 60px;
}
@media screen and (max-width: 767px) {
  .row.justify-content-center {
    padding: 10px 10px 40px;
  }
}

.col-md-10 {
  width: 100%;
  /* md(768px)以上の時だけ 10/12 幅 + 最大幅 */
}
@media (min-width: 768px) {
  .col-md-10 {
    flex: 0 0 83.333333%;
    max-width: 900px;
  }
}

/* ===== Card ===== */
.card {
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.125);
  border-radius: 10px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
  overflow: hidden;
}
.card .card-body {
  padding: 28px 28px;
  font-size: 15px;
  letter-spacing: 0.02em;
  line-height: 1.5;
  overflow-wrap: anywhere;
  word-break: break-word;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 767px) {
  .card .card-body {
    padding: 22px 20px;
    font-size: 14px;
  }
}
.card .card-body {
  /* 本文の整形（br多用でも読みやすく） */
}
.card .card-body br + br {
  line-height: 1.2;
}
.card .card-body.text-dark {
  color: #212529;
}

/* ===== FAQ ===== */
.faq-section {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.faq-section .faq-lead {
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.faq-section .faq-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.faq-section .faq-item {
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  background: #fafafa;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}
.faq-section .faq-item .faq-item__question,
.faq-section .faq-item .faq-item__answer {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 12px;
  padding: 14px 16px;
  align-items: start;
}
@media screen and (max-width: 767px) {
  .faq-section .faq-item .faq-item__question,
  .faq-section .faq-item .faq-item__answer {
    grid-template-columns: 30px 1fr;
    padding: 12px 12px;
  }
}
.faq-section .faq-item .faq-item__question p,
.faq-section .faq-item .faq-item__answer p {
  margin: 0;
  line-height: 1.7;
  font-size: 15px;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 767px) {
  .faq-section .faq-item .faq-item__question p,
  .faq-section .faq-item .faq-item__answer p {
    font-size: 14px;
    line-height: 1.5;
  }
}
.faq-section .faq-item .faq-item__question a,
.faq-section .faq-item .faq-item__answer a {
  font-weight: bold;
  color: #3197bd;
  font-family: "Noto Sans JP", sans-serif;
}
.faq-section .faq-item .faq-item__question {
  background: #f0f4f7;
  border-bottom: 1px solid #e5e5e5;
}
.faq-section .faq-item .faq-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-weight: 700;
  color: #fff;
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .faq-section .faq-item .faq-badge {
    width: 26px;
    height: 26px;
    font-size: 12px;
  }
}
.faq-section .faq-item .faq-badge.faq-badge--q {
  background: #3a4f68;
}
.faq-section .faq-item .faq-badge.faq-badge--a {
  background: #8bb03d;
}
.faq-section .faq-item .faq-cancel-list {
  margin: 10px 0 0 0;
  padding-left: 18px;
  list-style: disc;
  color: #333;
}
.faq-section .faq-item .faq-cancel-list li {
  margin-bottom: 6px;
  line-height: 1.6;
}

.yoyakubtn {
  max-width: 140px;
}/*# sourceMappingURL=style.css.map */