@charset "UTF-8";
.bg_box, #top::before, .right_wrap .han #globalMenuSp .hb_contact_wrap li a.tel::before, .reservation .tel .icon, .modal__content .modal_slider li .img, .f_bottom .flex_box .left a .img {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
  outline: none !important;
}

html {
  overflow-y: scroll;
  scroll-behavior: smooth;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  font-size: 100%;
  font-weight: normal;
  line-height: 1;
}

ol,
ul,
li {
  list-style: none;
}

fieldset,
img {
  border: 0;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

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

caption,
th {
  text-align: left;
}

a {
  color: #000000;
  text-decoration: none;
  cursor: pointer;
}

a:focus {
  outline: none;
}

address,
caption,
cite,
code,
dfn,
em,
th,
var {
  font-style: normal;
  font-weight: normal;
}

body * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.scroll-point {
  height: 100%;
  overflow: hidden;
}

.sns {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.sns:hover {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}

.down-to-top {
  opacity: 0.01;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: all 1s;
  transition: all 1s;
}

.down-to-top.scrollin {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

#top {
  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;
  position: relative;
  position: fixed;
  bottom: 40px;
  right: 2.7%;
  cursor: pointer;
  z-index: 8;
  background-color: #e5c8c2;
  width: 7vw;
  height: 7vw;
  border-radius: 50%;
  text-align: center;
  color: #fff;
  letter-spacing: 0.1em;
}

#top p.f35 {
  margin-top: 3vw;
}

#top::before {
  position: absolute;
  content: '';
  background-image: url(../img/lp/icon_arrow_top.png);
  width: 2.3vw;
  height: 2.3vw;
  left: 0;
  right: 0%;
  margin: auto;
  top: 1vw;
}

/* ----------- フォント ----------- */
@font-face {
  font-family: 'yu-mincho';
  src: url("../fonts/yu-mincho-medium.woff") format("woff");
}

@font-face {
  font-family: 'yu-gothic';
  src: url("../fonts/yu-gothic-medium.woff") format("woff");
}

@font-face {
  font-family: 'angle';
  src: url("../fonts/angle.woff") format("woff");
}

body {
  font-family: 'yu-mincho';
  font-weight: 400;
}

.yuGothic {
  font-family: 'yu-gothic';
  font-style: normal;
}

.gennoMincho {
  font-family: source-han-serif-japanese, serif;
  font-style: normal;
}

.ambroise {
  font-family: ambroise-std, serif;
  font-style: normal;
}

.angle {
  font-family: 'angle';
  font-style: normal;
}

.m {
  font-weight: 500;
}

.sem_b {
  font-weight: 600;
}

b,
strong,
.bold {
  font-weight: 700;
}

.w_3 {
  font-weight: 300;
}

.f220 {
  font-size: 220px;
  font-size: 11.45833vw;
}

.f210 {
  font-size: 210px;
  font-size: 10.9375vw;
}

.f200 {
  font-size: 200px;
  font-size: 10.41667vw;
}

.f160 {
  font-size: 160px;
  font-size: 8.33333vw;
}

.f145 {
  font-size: 145px;
  font-size: 7.55208vw;
}

.f140 {
  font-size: 140px;
  font-size: 7.29167vw;
}

.f120 {
  font-size: 120px;
  font-size: 6.25vw;
}

.f100 {
  font-size: 100px;
  font-size: 5.20833vw;
}

.f95 {
  font-size: 95px;
  font-size: 4.94792vw;
}

.f90 {
  font-size: 90px;
  font-size: 4.6875vw;
}

.f80 {
  font-size: 80px;
  font-size: 4.16667vw;
}

.f70 {
  font-size: 70px;
  font-size: 3.64583vw;
}

.f65 {
  font-size: 65px;
  font-size: 3.38542vw;
}

.f62 {
  font-size: 62px;
  font-size: 3.22917vw;
}

.f60 {
  font-size: 60px;
  font-size: 3.125vw;
}

.f58 {
  font-size: 58px;
  font-size: 3.02083vw;
}

.f50 {
  font-size: 50px;
  font-size: 2.60417vw;
}

.f48 {
  font-size: 48px;
  font-size: 2.5vw;
}

.f47 {
  font-size: 46px;
  font-size: 2.39583vw;
}

.f46 {
  font-size: 46px;
  font-size: 2.39583vw;
}

.f45 {
  font-size: 45px;
  font-size: 2.34375vw;
}

.f42 {
  font-size: 42px;
  font-size: 2.1875vw;
}

.f40 {
  font-size: 40px;
  font-size: 2.08333vw;
}

.f39 {
  font-size: 39px;
  font-size: 2.03125vw;
}

.f38 {
  font-size: 38px;
  font-size: 1.97917vw;
}

.f37 {
  font-size: 37px;
  font-size: 1.92708vw;
}

.f36 {
  font-size: 36px;
  font-size: 1.875vw;
}

.f35 {
  font-size: 35px;
  font-size: 1.82292vw;
}

.f34 {
  font-size: 35px;
  font-size: 1.82292vw;
}

.f33 {
  font-size: 35px;
  font-size: 1.82292vw;
}

.f30 {
  font-size: 30px;
  font-size: 1.5625vw;
}

.f28 {
  font-size: 28px;
  font-size: 1.45833vw;
}

.f26 {
  font-size: 26px;
  font-size: 1.35417vw;
}

.f25 {
  font-size: 25px;
  font-size: 1.30208vw;
}

.f22 {
  font-size: 22px;
  font-size: 1.14583vw;
}

.f20 {
  font-size: 20px;
}

.f18 {
  font-size: 18px;
}

.f16 {
  font-size: 16px;
}

/* --------- color ---------- */
.c_white {
  color: #fff;
}

.c_black {
  color: #000;
}

.c_brown {
  color: #7c6b61;
}

.c_lightpink {
  color: #e0c8c2;
}

.c_pink {
  color: #b4857a;
}

.c_gold {
  color: #c8b6a1;
}

.c_gold2 {
  color: #c3b698;
}

.bc_white {
  background-color: #fff;
}

.bc_black {
  background-color: #000;
}

.bc_brown {
  background-color: #7c6b61;
}

.bc_lightpink {
  background-color: #e0c8c2;
}

.bc_lightpink2 {
  background-color: #ccb0a9;
}

.bc_pink {
  background-color: #b4857a;
}

.bc_human {
  background-color: #fdfbfa;
}

.bc_gold {
  background-color: #c8b6a1;
}

.bc_beige {
  background-color: #decebb;
}

.footer_brown {
  background-color: #84746b;
}

/* ----------- btn ------------ */
.opa {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.opa:hover {
  opacity: 0.7;
}

.opa_drk,
.opa_wht {
  position: relative;
  padding-bottom: 2px;
}

.opa_drk:hover:after,
.opa_wht:hover:after {
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
}

.opa_drk:after,
.opa_wht:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  height: 1px;
  width: 100%;
}

.opa_drk:after {
  background: #000;
}

.opa_wht:after {
  background: #fff;
}

.hov_red {
  -webkit-transition: 0.1s;
  transition: 0.1s;
  padding-bottom: 0px;
  border-bottom: 1px solid;
}

.hov_red:hover {
  color: #e21c35;
}

/* ----------- 改行＆表示切り替えレスポンシブ ------------ */
.on1280 {
  display: none;
}

.on1024 {
  display: none;
}

.on768 {
  display: none;
}

.on480 {
  display: none;
}

@media (max-width: 1280px) {
  .off1280 {
    display: none;
  }
  .on1280 {
    display: block;
  }
}

@media (max-width: 1024px) {
  .off1024 {
    display: none;
  }
  .on1024 {
    display: block;
  }
}

@media (max-width: 768px) {
  .off768 {
    display: none;
  }
  .on768 {
    display: block;
  }
}

@media (max-width: 480px) {
  .off480 {
    display: none;
  }
  .on480 {
    display: block;
  }
}

/* --------------------- common ------------------- */
.tac {
  text-align: center;
}

/* --------------------- header ------------------- */
.header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  border-bottom: 1px solid #ffffff65;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1.52vw 0;
  padding-right: 3.5vw;
  z-index: 10;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background-color: #e4e4e491;
}

.header .logo_img {
  max-width: 150px;
  width: 30%;
  margin-left: 30px;
  position: relative;
  z-index: 1000;
}

.header .right_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header .right_wrap .tel_icon a {
  max-width: 80px;
  padding: 15px;
  display: block;
  margin-right: 45px;
}

.header .right_wrap .tel_icon img {
  display: block;
  max-width: 50px;
}

.header .right_wrap .mail_icon a {
  display: block;
  padding: 30px;
  line-height: 1;
  margin-right: 80px;
}

.btn01 {
  border: 1px solid #b4857a;
  border-radius: 50px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.btn01:hover {
  border-color: #b4857a;
  background-color: #b4857a;
}

.hamburger_icon {
  position: relative;
  padding: 35px;
  right: 40px;
}

.hamburger_icon span {
  width: 100%;
  height: 5px;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: 0;
  bottom: 0;
}

.hamburger_icon span:nth-child(1) {
  top: 70%;
}

.hamburger_icon span:nth-child(3) {
  bottom: 70%;
}

.right_wrap .han {
  width: 70px;
}

.right_wrap .han #globalMenuSp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: auto;
  z-index: 999;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: all 0.6s;
  transition: all 0.6s;
  width: 100%;
  background-color: #b4857a;
  padding-left: 27vw;
  padding-right: 27vw;
}


.right_wrap .han #globalMenuSp ul {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
          justify-content: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: -1px;
  /* padding-top: 10%; */
  position: relative;
}

.right_wrap .han #globalMenuSp ul.link_wrap {
  margin-top: -2vw;
}

@media screen and (max-width: 1440px) {
  .right_wrap .han #globalMenuSp ul.link_wrap {
    margin-top: -4vw;
  }
}

.right_wrap .han #globalMenuSp ul li {
  width: 100%;
  line-height: 1.5;
}

.right_wrap .han #globalMenuSp ul li a {
  color: #fff;
  padding: 3% 0;
  display: block;
}

.right_wrap .han #globalMenuSp.active {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
}

.right_wrap .han #navToggle {
  position: relative;
  z-index: 999;
  height: 95px;
  cursor: pointer;
}

.right_wrap .han #navToggle.active span:nth-child(1) {
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.right_wrap .han #navToggle.active span:nth-child(n + 2) {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}

.right_wrap .han #navToggle span {
  display: inline-block;
  width: 80%;
  height: 2px;
  -webkit-transition: 0.35s;
  transition: 0.35s;
  margin-top: auto;
  margin-right: auto;
  margin-bottom: auto;
  margin-left: auto;
  background-color: #b4857a;
}

.right_wrap .han #navToggle span:nth-child(1) {
  position: absolute;
  top: 20px;
  right: 0;
  bottom: auto;
  left: 0;
  z-index: 0;
}

.right_wrap .han #navToggle span:nth-child(2) {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
}

.right_wrap .han #navToggle span:nth-child(3) {
  position: absolute;
  top: auto;
  right: 0;
  bottom: 20px;
  left: 0;
  z-index: 0;
}

.right_wrap .han #navToggle.active span {
  position: absolute;
  background-color: #fff;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
}

.right_wrap .han #globalMenuSp .link_wrap .link_item p.f45 {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.right_wrap .han #globalMenuSp .link_wrap .link_item p.f25 {
  line-height: 1.72;
  display: inline-block;
  margin-top: 0.4vw;
  padding-top: 0.4vw;
  position: relative;
}

.right_wrap .han #globalMenuSp .link_wrap .link_item p.f25::before {
  content: '';
  /*絶対配置で線の位置を決める*/
  position: absolute;
  top: 0;
  left: 0;
  /*線の形状*/
  width: 10vw;
  height: 2px;
  background: #fff;
  /*アニメーションの指定*/
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  /*X方向0、Y方向1*/
  -webkit-transform-origin: left top;
          transform-origin: left top;
  /*左上基点*/
}

.right_wrap .han #globalMenuSp .link_wrap .link_item:hover p.f45 {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  padding-left: 1vw;
}

.right_wrap .han #globalMenuSp .link_wrap .link_item:hover p.f25::before {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  /*X方向にスケール拡大*/
}

.right_wrap .han #globalMenuSp .link_wrap:last-child {
  margin-bottom: 0;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li {
  letter-spacing: 0.018em;
  text-align: center;
  color: #fff;
  margin-bottom: 3.073vw;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li p.f20 {
  line-height: 1.7;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li a {
  border: 1px solid #ffffff;
  border-radius: 135px;
  display: block;
  position: relative;
  margin-top: 1vw;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li a.tel::before {
  position: absolute;
  content: '';
  background-image: url(../img/lp/icon_tel01.png);
  top: 0;
  bottom: 0;
  left: 2vw;
  margin: auto;
  width: 35px;
  height: 35px;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li a.line {
  letter-spacing: 0.1em;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li a:hover {
  background-color: #fff;
  color: #b4857a;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li a:hover.tel::before {
  background-image: url(../img/lp/icon_tel01_p.png);
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li.sns_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: -1.5vw;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li.sns_box a {
  border: transparent;
  padding: 0;
  margin-right: 2.1vw;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap li.sns_box a:last-child {
  margin-right: 0;
}

.right_wrap .han #globalMenuSp .hb_contact_wrap.on480 {
  display: none;
}

/* --------------------- footer ------------------- */
.reservation {
  background-color: #ccb0a9;
  text-align: center;
  padding-top: 12.13vw;
  padding-bottom: 10.78vw;
}

.reservation p.f30 {
  margin-top: 2vw;
}

.reservation .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 4vw 0;
}

.reservation .tel .icon {
  width: 4.1034vw;
  height: 4.1034vw;
  margin-right: 1.48vw;
}

.reservation .tel a.f70 {
  color: #fff;
  letter-spacing: 0.1em;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.reservation .tel a.f70:hover {
  opacity: 0.6;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}

.reservation .link_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.reservation .link_box a {
  display: block;
  border: 2px solid #fff;
  text-align: center;
  border-radius: 120px;
  letter-spacing: 0.067em;
  width: 16.72%;
  margin-right: 2.1041vw;
  color: #fff;
  padding: 0.547% 0;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.reservation .link_box a:last-child {
  margin-right: 0;
}

.reservation .link_box a:hover {
  background-color: #fff;
  color: #ccb0a9;
}

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}

.modal__bg {
  display: none !important;
}

.modal__content {
  display: none !important;
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 80%;
  background-color: #fff;
  padding: 3vw 0;
}

.modal__content .modal_slider {
  width: 70%;
  margin: 0 auto;
}

.modal__content .modal_slider .slick-prev::before,
.modal__content .modal_slider .slick-next::before {
  top: 0;
  bottom: 0;
  margin: auto;
  background-image: url(../img/lp/modal_arrow.svg);
  background-size: auto;
  background-color: #707070;
  border-radius: 50%;
}

.modal__content .modal_slider .slick-prev::before {
  left: -5vw;
}

.modal__content .modal_slider .slick-next::before {
  right: -5vw;
}

.modal__content .modal_slider .slick-prev::after,
.modal__content .modal_slider .slick-next::after {
  display: none;
}

.modal__content .modal_slider li {
  margin: 0 10px;
}

.modal__content .modal_slider li .img {
  padding: 50% 0;
}

.modal__content a.js-modal-close {
  position: absolute;
  bottom: 100%;
  right: -3vw;
  top: -3vw;
}

.f_bottom {
  background-color: #84746b;
  padding: 2.2396vw 0;
}

.f_bottom .flex_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.f_bottom .flex_box .left {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
          flex: 0 0 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-right: 1px solid #fff;
  padding: 0.703vw 0;
}

.f_bottom .flex_box .left a {
  margin-right: 1vw;
}

.f_bottom .flex_box .left a .img {
  width: 2.9688vw;
  height: 2.9688vw;
}

.f_bottom .flex_box .left a:last-child {
  margin-right: 0;
}

.f_bottom .flex_box .right {
  text-align: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
          flex: 0 0 50%;
}

.f_bottom .flex_box .right small {
  letter-spacing: 0.067em;
  color: #fff;
}

@media screen and (max-width: 1680px) {
  .f18 {
    font-size: 16px;
    font-size: 0.95238vw;
  }
  .header {
    padding: 1vw 0;
    padding-right: 2vw;
  }
  .header .right_wrap .tel_icon a {
    max-width: 70px;
    padding: 10px;
  }
  .header .right_wrap .tel_icon img {
    max-width: 40px;
  }
  .header .right_wrap .mail_icon a {
    padding: 20px;
  }
  .right_wrap .han #navToggle {
    height: 80px;
  }
  .header .logo_img {
    max-width: 110px;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li a.tel::before {
    width: 30px;
    height: 30px;
  }
  .modal__content {
    padding: 2vw 0;
  }
  .modal__content a.js-modal-close {
    right: -1vw;
    top: -1vw;
  }
  .modal__content a.js-modal-close img {
    width: 5vw;
  }
}

@media screen and (max-width: 1440px) {
  .f20 {
    font-size: 18px;
    font-size: 1.31772vw;
  }
  .f18 {
    font-size: 16px;
    font-size: 1.1713vw;
  }
  .f16 {
    font-size: 14px;
    font-size: 1.02489vw;
  }
  .header .right_wrap .mail_icon a {
    margin-right: 50px;
    padding: 15px 20px;
  }
  .right_wrap .han #navToggle {
    height: 70px;
  }
  .right_wrap .han #navToggle span:nth-child(1) {
    top: 15px;
  }
  .right_wrap .han #navToggle span:nth-child(3) {
    bottom: 15px;
  }
  .right_wrap .han #navToggle.active span {
    top: 0;
  }
  .right_wrap .han #navToggle.active span:nth-child(3) {
    bottom: 0;
  }
  .header .right_wrap .tel_icon img {
    max-width: 35px;
  }
  .header .logo_img {
    max-width: 95px;
  }
  #top {
    width: 6vw;
    height: 6vw;
  }
  #top p.f35 {
    font-size: 20px;
    margin-top: 2vw;
  }
  #top::before {
    width: 2vw;
    height: 2vw;
  }
}

@media screen and (max-width: 1024px) {
  .right_wrap .han #globalMenuSp .hb_contact_wrap li a.tel::before {
    width: 20px;
    height: 20px;
  }
}

@media screen and (max-width: 768px) {
  .right_wrap .han #globalMenuSp {
    padding-left: 15vw;
    padding-right: 15vw;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap {
    margin-left: 4vw;
  }
  .right_wrap .han #globalMenuSp .link_wrap .link_item p.f45 {
    font-size: 25px;
  }
  .right_wrap .han #navToggle span {
    width: 70%;
  }
  .right_wrap .han #globalMenuSp .link_wrap .link_item p.f25 {
    font-size: 16px;
  }
  .right_wrap .han #globalMenuSp ul li a {
    padding: 4% 0;
  }
  .mv .mv_img .mv_list {
    padding-left: 10vw;
    padding-right: 10vw;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li.sns_box a {
    width: 20%;
  }
  .f18 {
    font-size: 16px;
  }
  .f16 {
    font-size: 14px;
  }
  #top {
    width: 7vw;
    height: 7vw;
  }
  #top p.f35 {
    font-size: 11px;
    margin-top: 2vw;
  }
}

@media screen and (max-width: 480px) {
  .f13 {
    font-size: 13px;
  }
  .f11 {
    font-size: 11px;
  }
  .header .right_wrap .mail_icon a,
  .header .right_wrap .tel_icon a {
    display: none;
  }
  .header {
    padding: 3.6% 0;
  }
  .header .logo_img {
    max-width: 44px;
    margin-left: 12px;
    z-index: 990;
  }
  .right_wrap .han #navToggle span:nth-child(1) {
    top: 0;
  }
  .right_wrap .han #navToggle {
    height: 20px;
  }
  .right_wrap .han #navToggle span:nth-child(3) {
    bottom: 0;
  }
  .right_wrap .han #navToggle span {
    height: 1px;
  }
  .right_wrap .han #navToggle span {
    width: 35%;
  }
  .right_wrap .han #globalMenuSp {
    display: block;
    padding-left: 0;
    padding-right: 0;
    overflow-y: scroll;
    padding-bottom: 8%;
  }
  .right_wrap .han #globalMenuSp .link_wrap .link_item p.f45 {
    font-size: 30px;
  }
  .right_wrap .han #globalMenuSp ul {
    text-align: center;
    height: auto;
    margin-right: 0;
  }
  .right_wrap .han #globalMenuSp .link_wrap .link_item p.f25 {
    font-size: 12px;
  }
  .right_wrap .han #globalMenuSp ul li a {
    padding: 0;
  }
  .right_wrap .han #globalMenuSp .link_wrap .link_item {
    margin-bottom: 30px;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap.off480 {
    display: none;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap.on480 {
    display: block;
    padding-left: 8vw;
    padding-right: 8vw;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap {
    padding-top: 5% !important;
    margin-top: 5%;
    margin-left: 0;
    border-top: 1px solid #ffffff;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li.sns_box a {
    width: 14.5%;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li.sns_box a {
    margin-right: 5vw;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li .tel {
    width: 83.8%;
    margin: 0 auto;
    font-size: 21px;
    padding: 2% 0;
    margin-top: 6%;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li a.tel::before {
    width: 24px;
    height: 24px;
    left: 9vw;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li.flex_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 5%;
    margin-bottom: 0;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li.flex_box a {
    font-size: 19px;
    text-align: center;
    width: 100%;
    padding: 3.1% 0;
  }
  .right_wrap .han #globalMenuSp .hb_contact_wrap li.flex_box a:first-child {
    margin-right: 4%;
  }
  #top {
    display: none !important;
  }

  footer .footer_link {
    padding: 8px 4.933vw;
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: #ffffff;
  }

  footer .footer_link h4 {
    font-size: 0.75rem;
    margin-bottom: 15px;
    padding: 5px;
    border: 1px solid #000;
    text-align: center;
    white-space: nowrap;
  }

  footer .footer_link h4 span {
    color: #df3a13;
  }

  footer .footer_link_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    
    /*        
    padding: 8px 6.933vw;
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: #ffffffa3;
    */
  }
  footer .footer_link_box a {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 32%;
            flex: 0 0 32%;
    font-size: 14px; /* フォントサイズを少し小さく調整 */
    text-align: center;
    display: block;
    color: #fff;
    border-radius: 10px;
    letter-spacing: 0.1em;
    margin-right: 4%;
    padding: 1.4% 0;
  }
  footer .footer_link_box a:first-child {
    background-color: #c9b342;
  }
  
  footer .footer_link_box a:nth-child(2) {
    background-color: #00ba00;
  }
  
  footer .footer_link_box a:last-child {
    margin-right: 0;
    background-color:#2C3E50;
  }
  .reservation {
    padding-top: 10vw;
    padding-bottom: 10vw;
  }
  .reservation .mds {
    font-size: 50px;
  }
  .reservation p.f30 {
    font-size: 10px;
  }
  .reservation .tel a.f70 {
    font-size: 25px;
  }
  .reservation .tel .icon {
    width: 25px;
    height: 25px;
  }
  .reservation .tel {
    margin: 6vw 0;
  }
  .reservation .link_box a {
    width: 38%;
    font-size: 16px;
    border: 1px solid #fff;
    margin-right: 30px;
    padding: 2% 0;
  }
  .f_bottom .flex_box .right small {
    font-size: 12px;
  }
  .f_bottom .flex_box .left a {
    margin-right: 3vw;
  }
  .f_bottom .flex_box .left a .img {
    width: 30px;
    height: 30px;
  }
  .f_bottom .flex_box .left {
    padding: 2vw 0;
  }
  .f_bottom {
    background-color: #84746b;
  }
  .right_wrap .han #globalMenuSp .sp_icon {
    width: 32%;
    margin: 0 auto;
    text-align: center;
  }
  .modal__content a.js-modal-close img {
    width: 13vw;
  }
  .modal__content a.js-modal-close {
    right: -6vw;
    top: -6vw;
  }
  .modal__content {
    width: 90%;
    padding: 6vw 0;
  }
  .modal__content .modal_slider .slick-prev::before {
    left: -9vw;
  }
  .modal__content .modal_slider .slick-next::before {
    right: -9vw;
  }
  .right_wrap .han #globalMenuSp .link_wrap .link_item p.f25::before{
    width: 100%;
  }
}

/* ------------ fadeIn css --------------- */
.feedin {
  opacity: 0;
  transform: translate(0, 80px);
  transition: .8s;
}
.feedin.is_show {
  transform: translate(0, 0);
  opacity: 1;
}
@media (max-width:480px) {
  .feedin.feedin_right{
    opacity: 1;
    transform: unset;
  }
}
