@charset "UTF-8";
abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0;
}

body {
  line-height: 1;
}

*, ::after, ::before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

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

ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:after, blockquote:before, q:after, q:before {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0;
}

ins {
  color: #000;
  text-decoration: none;
}

mark {
  color: #000;
  font-style: italic;
  font-weight: 700;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

input[type=button], input[type=submit] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  cursor: pointer;
}

input[type=button]::-webkit-search-decoration, input[type=submit]::-webkit-search-decoration {
  display: none;
}

input[type=button]::focus, input[type=submit]::focus {
  outline-offset: -2px;
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  font-size: 1.5rem;
  color: #fff;
  background: #000;
  letter-spacing: 0.05em;
  line-height: 2;
  font-family: "Lora", "Shippori Mincho", serif;
  font-weight: 400;
  font-style: normal;
  opacity: 0;
  -webkit-animation: bg_fadeIn 1.2s 0.5s ease forwards;
          animation: bg_fadeIn 1.2s 0.5s ease forwards;
}

a {
  text-decoration: none;
  -webkit-transition: 0.6s;
  transition: 0.6s;
  color: #fff;
}

a:hover {
  opacity: 0.6;
}

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

.wrapper {
  position: relative;
  min-height: 200vh;
}
.wrapper::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(../img/bk.png);
  background-size: 60%;
  background-repeat: no-repeat;
  background-position: bottom left;
  z-index: -1;
  pointer-events: none;
}

@media screen and (max-width: 860px) {
  .wrapper::before {
    background-size: 90%;
    background-position: bottom 50px left;
  }
}
img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

@media (min-width: 861px) {
  .sp {
    display: none !important;
  }
}

.pc {
  display: none !important;
}
@media (min-width: 861px) {
  .pc {
    display: block !important;
  }
}

.inner {
  max-width: 1100px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}

.mv {
  position: relative;
  height: 100svh;
}

.mv_slide img {
  height: 100svh;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mv_txt {
  position: absolute;
  top: 45%;
  left: 15%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.mv_txt p {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
  font-size: 1.6rem;
  letter-spacing: 0.4em;
  padding: 1em 0 0;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 860px) {
  .mv_txt {
    left: 8%;
  }
  .mv_txt p {
    font-size: 1.4rem;
  }
}

.mv .slick-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 5px;
}
.mv .slick-dots button {
  background: #eee;
  border: none;
  outline: none;
  font-size: 0;
  width: 28px;
  height: 2px;
}
.mv .slick-dots .slick-active button {
  background: #b74129;
}

.home_sec {
  padding: 80px 0;
}
@media screen and (max-width: 860px) {
  .home_sec {
    padding: 60px 0;
  }
}

.home_ttl {
  font-size: 3rem;
  letter-spacing: 0.1em;
  margin-bottom: 1.5em;
  text-align: center;
  text-transform: uppercase;
}
@media screen and (max-width: 860px) {
  .home_ttl {
    font-size: 2.4rem;
  }
}

.btn_line {
  height: 54px;
  width: 380px;
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 auto;
  border: 1px solid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.btn_line--reserve span {
  position: relative;
}

.btn_line--reserve span::before {
  content: "";
  width: 15px;
  height: 16px;
  background-image: url(../img/icon_reserve.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: -20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.cta {
  text-align: center;
}

.cta .btn_line--reserve {
  margin-top: 20px;
}

.intro__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 860px) {
  .intro__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px;
  }
}

.intro__content + .intro__content {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-top: 100px;
}
@media screen and (max-width: 860px) {
  .intro__content + .intro__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 60px;
  }
}

.intro__txt {
  width: 40%;
}
.intro__txt h2 {
  font-size: 2.4rem;
  letter-spacing: 0.1em;
}
.intro__txt p {
  margin-top: 1em;
}
@media screen and (max-width: 860px) {
  .intro__txt {
    width: 100%;
  }
  .intro__txt h2 {
    font-size: 2rem;
  }
}

.intro__img {
  width: 55%;
}
@media screen and (max-width: 860px) {
  .intro__img {
    width: 100%;
  }
}

.acsess {
  text-align: center;
}

.acsess .btn_line--reserve {
  margin: 20px auto 0;
}

.acsess__inner,
.acsess__map {
  display: inline-block;
  margin: 0 auto;
  text-align: left;
}

.acsess__mapIframe {
  margin: 40px 0 10px;
}
.acsess__mapIframe iframe {
  vertical-align: bottom;
}

.acsess__shopinfo {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 1em 1fr;
  grid-template-columns: auto 1fr;
  gap: 0.4em 1em;
}
.acsess__shopinfo dt {
  white-space: nowrap;
}
.acsess__shopinfo dt::after {
  content: "：";
}
.acsess__shopinfo dd {
  line-height: 1.8;
}

@media screen and (max-width: 959px) {
  .acsess__mapIframe {
    width: 100%;
  }
  .acsess__mapIframe iframe {
    max-width: 100%;
    width: 100%;
  }
}
.gallery__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 900px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.gallery__list li {
  width: calc((100% - 30px) / 4);
  height: 0;
  padding-top: calc((100% - 30px) / 4);
  position: relative;
}
.gallery__list li img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  cursor: -webkit-zoom-in;
  cursor: zoom-in;
}
.gallery__list li span {
  opacity: 0;
}
@media screen and (max-width: 860px) {
  .gallery__list {
    gap: 8px;
  }
  .gallery__list li {
    width: calc((100% - 8px) / 2);
    padding-top: calc((100% - 8px) / 2);
  }
}

/* 背景の箱 */
.modal__bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.85);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 9999;
  opacity: 0;
  -webkit-animation: modal-fadeIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
          animation: modal-fadeIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* 中の画像 */
.modal__container {
  width: 80%;
  max-width: 600px;
  position: relative;
}
.modal__container img {
  width: 100%;
}
.modal__container p {
  font-size: 1.3rem;
}
@media screen and (max-width: 860px) {
  .modal__container {
    width: 92%;
  }
}

.modal__container::before, .modal__container::after {
  content: "";
  display: block;
  width: 20px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: -10px;
}
.modal__container::before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.modal__container::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.modal-overlay.is-hide {
  -webkit-animation: modal-fadeOut 0.3s forwards;
          animation: modal-fadeOut 0.3s forwards;
}

@-webkit-keyframes modal-fadeIn {
  from {
    opacity: 0;
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  to {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes modal-fadeIn {
  from {
    opacity: 0;
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  to {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-webkit-keyframes modal-fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes modal-fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.footer {
  margin-top: 200px;
}
@media screen and (max-width: 860px) {
  .footer {
    margin-top: 100px;
  }
}

.footer__shopinfo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 50px;
  font-size: 1.2rem;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  color: #eee;
}
@media screen and (max-width: 860px) {
  .footer__shopinfo {
    gap: 10px;
    padding: 30px 0;
  }
}

.footer__shopinfoList {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 1em 1fr;
  grid-template-columns: auto 1fr;
  gap: 0 1em;
}
.footer__shopinfoList dt {
  white-space: nowrap;
}
.footer__shopinfoList dt::after {
  content: "：";
}
.footer__shopinfoList dd {
  line-height: 1.8;
}

.footer__copy {
  text-align: center;
  font-size: 1.2rem;
  padding: 10px;
  margin-top: 80px;
}
@media screen and (max-width: 860px) {
  .footer__copy {
    margin-top: 40px;
  }
}

.fix_btn_wrap {
  position: fixed;
  bottom: 0;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.fix_btn {
  background: #b74129;
  color: #fff;
  height: 54px;
  width: 260px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.fix_btn--acsess {
  border-right: 1px solid #000;
}

.fix_btn--acsess {
  border-right: 1px solid #000;
  position: relative;
  padding-left: 1.5em;
}
.fix_btn--acsess::before {
  content: "";
  width: 15px;
  height: 16px;
  background-image: url(../img/icon_acsess.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: calc(50% - 2.8em);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.fix_btn--reserve {
  position: relative;
  padding-left: 1.5em;
}
.fix_btn--reserve::before {
  content: "";
  width: 15px;
  height: 16px;
  background-image: url(../img/icon_reserve.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: calc(50% - 2.8em);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media screen and (max-width: 959px) {
  .fix_btn_wrap {
    width: 100%;
  }
  .fix_btn {
    width: 50%;
  }
}
/* --- スクロール出現アニメーション --- */
.js-fade {
  opacity: 0;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
}

.js-fade.is-show {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.delay-01 {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

.delay-02 {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}

.delay-03 {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}

.delay-04 {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}

/* --- ローディング画面 --- */
.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  background-size: cover;
  background-position: center;
  z-index: 10000;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: opacity 1s, visibility 1s;
  transition: opacity 1s, visibility 1s;
  display: none;
}

/* 初回のみ表示 */
.loading.is-active {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

/* ロゴの出現（墨の広がり風） */
.loading__logo {
  opacity: 0;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-transform: scale(0.5);
          transform: scale(0.5);
  -webkit-animation: logo_spread 2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
          animation: logo_spread 2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* フェードアウト用のクラス（JSで付与） */
.loading.is-hide {
  opacity: 0;
  visibility: hidden;
}

/* 背景がフェードインするアニメ */
@-webkit-keyframes bg_fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes bg_fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/* アニメーション定義 */
@-webkit-keyframes logo_spread {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
  50% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transform: scale(0.6);
            transform: scale(0.6);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transform: scale(0.6);
            transform: scale(0.6);
  }
}
@keyframes logo_spread {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
  50% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transform: scale(0.6);
            transform: scale(0.6);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transform: scale(0.6);
            transform: scale(0.6);
  }
}