/*
Theme Name:custom theme
Description:カスタムテーマ
Author: app_murata
Version:1.0.0
*/

/*-------common------*/

html {
  font-size: 62.5%;
}

body {
  font-size: max(1.04vw, 1.6rem);
  /*20px*/
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 2;
  margin: 0;
  color: #635c53;
}

/*font*/
.main-tit {
  font-family: "Cormorant Garamond", serif;
  font-size: max(6.67vw, 4rem);
  /*128px*/
  font-weight: 400;
  line-height: 1;
}

.sub-tit {
  font-family: "Shippori Mincho B1", serif;
  font-size: max(1.67vw, 2rem);
  /*32px*/
  font-weight: 400;
}

.en-on {
  font-family: "Cormorant Garamond", serif;
  font-size: max(1.67vw, 3.2rem);
  font-weight: 600;
  line-height: 1.6;
}

.mincho {
  font-family: "Shippori Mincho B1", serif;
}

p {
  margin: 0;
}

a {
  text-decoration: none;
  color: #635c53;
}

h1,
h2,
h3 {
  margin: 0;
  font-weight: 400;
}

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

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

li {
  list-style: none;
  margin: 0;
  padding: 0;
}

ul {
  margin: 0;
  padding: 0;
}

body .sp-only {
  display: none;
}

.wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
}

.wrap.re-wrap {
  flex-direction: row-reverse;
}

.inner {
  padding-left: 18.412%;
  padding-right: 18.412%;
}

.s-inner {
  padding-right: 16.834%;
  padding-left: 16.834%;
}

.page-mv .inner,
.page-mv .s-inner {
  margin-bottom: 60px;
}

* {
  box-sizing: border-box;
}

/*btn*/
.btn {
  font-family: "Cormorant Garamond", "Shippori Mincho B1", serif;
  background: #596e60;
  line-height: 1.6;
  color: #fff;
  display: block;
  font-size: max(1.67vw, 2rem);
  padding: 0.6238em 0.9357em;
  border-radius: 100px;
  font-weight: 700;
  transition: 0.2s ease-in-out;
}

.btn:hover {
  opacity: 0.8;
}

.btn span {
  font-size: max(1.04vw, 1.6rem);
  vertical-align: baseline;
}

.tel-btn span {
  font-size: max(1.25vw, 1.6rem);
  font-family: "Shippori Mincho B1", serif;
  font-weight: 400;
  margin-left: 10px;
}

.reserve-btn span {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  margin-left: 20px;
}

.s-btn {
  max-width: 305px;
}

.l-btn {
  max-width: 360px;
  width: 100%;
}

.s-linkbtn {
  /* border-bottom: 1.52px solid #596E60; */
  padding: 0 2.225em 5px 0.835em;
  font-size: max(1.875vw, 2.4rem);
  line-height: 1.6;
  font-family: "Cormorant Garamond", "Shippori Mincho B1", serif;
  position: relative;
  transition: 0.2s ease-in-out;
  font-weight: 500;
  color: #596e60;
}

.s-linkbtn:hover:before {
  width: 110%;
}

.s-linkbtn:hover::after {
  right: -10%;
}

.s-linkbtn:before {
  content: "";
  background: #596e60;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1.52px;
  transition: 0.2s ease-in-out;
}

.s-linkbtn::after {
  content: "";
  background: #596e60;
  width: 1.52px;
  height: 20px;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: rotateZ(-60deg);
  transform-origin: bottom;
  transition: 0.2s ease-in-out;
}

.s-linkbtn.btnpt1 {
  font-size: max(1.25vw, 2.4rem);
  padding: 0 50px 5px;
}

.s-linkbtn.btnpt2 {
  font-size: max(1.04vw, 1.6rem);
  padding: 0 50px 5px;
  font-weight: 400;
}

/*hd*/
.hd-groop {
  display: flex;
  justify-content: right;
  align-items: center;
  flex-wrap: wrap;
  padding: 20px 0;
}

.main-menu {
  display: flex;
  justify-content: space-between;
}

.main-menu li {
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  line-height: 1.6;
}

.main-menu li a {
  transition: 0.2s ease-in-out;
}

.main-menu li a:hover {
  opacity: 0.5;
}

.logo-wrap {
  width: max(13.764792vw, 158.92px);
  margin-right: 2.66vw;
}

.main-menu-container {
  width: 42.08333vw;
  margin-right: 3.91vw;
}

.link-wrap {
  display: flex;
  align-items: center;
  gap: 1.57vw;
}

.hd-groop .reserve-btn {
  border-radius: 60px 0 0 60px;
}

/*ft*/
.f-logowrp {
  background: #596e60;
  padding: 20px 0;
  margin-bottom: 60px;
  text-align: center;
}

.f-logowrp img {
  max-width: 264.86px;
  width: 100%;
}

.footerwrap .btn {
  text-align: center;
}

.footerwrap .left {
  margin-right: 4.9vw;
}

.footerwrap .left .btn:first-child {
  margin-bottom: 14px;
}

.footerwrap .wrap {
  align-items: flex-start;
}

.copyright-container {
  text-align: center;
  padding: 30px 0;
  font-family: "Noto Serif", serif;
}

.copyright-container p {
  font-size: max(0.833vw, 1.3rem);
  font-weight: 400;
}

.copyright-container p span {
  font-weight: 600;
}

.footerwrap .wrap {
  margin-bottom: 60px;
  flex-wrap: wrap;
}

.ft-list {
  width: 31%;
}

.ft-list span {
  border: 1px solid #635c53;
  border-radius: 90px;
  padding: 10px 0px;
  display: block;
  margin-right: 20px;
  max-width: 120px;
  width: 100%;
  text-align: center;
  line-height: 1.6;
}

.ft-list li {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
  font-size: 2rem;
  line-height: 1.6;
  font-weight: 500;
}

.ft-list li:last-child {
  margin-bottom: 0;
}

.footerwrap .wrap .left .btn {
  font-size: max(1.67vw, 3.2rem);
}

.footerwrap .wrap .left .btn span {
  font-size: max(1.04vw, 2.4rem);
}

.footerwrap .wrap .left .reserve-btn span {
  font-size: max(1.04vw, 2rem);
}

.ft-list .space {
  margin-right: 1em;
}

.ft-list .space-l {
  margin-right: 2em;
}

/*anime*/
.fade-up-pt1.js-fade-up.is-visible {
  transform: translate(0%, -100%);
}

.fade-up-pt1.js-fade-up {
  transform: translate(0%, -50%);
}

.fade-up-pt2.js-fade-up.is-visible {
  transform: translate(0%, -50%);
}

.fade-up-pt2.js-fade-up {
  transform: translate(0%, 0%);
}

body .js-fade-up {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 1s, transform 1s;
}

.img-box.js-fade-up {
  opacity: 1;
  transform: none;
  transition: 1s ease-in-out;
}

.img-box.js-fade-up.is-visible::after {
  right: -100vw;
}

body .js-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.img-box::after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  display: inline-block;
  background: #fff;
  top: 0;
  right: 0;
  z-index: 5;
  transition: 0.8s;
  transition-delay: 0.4s;
}

.img-box {
  position: relative;
  overflow: hidden;
}
.tabsp-only {
  display: none;
}
@media screen and (max-width: 1400px) {
  .inner,
  .s-inner {
    padding-left: 5%;
    padding-right: 5%;
  }
  .tabsp-only {
    display: block;
  }
  .onepc-only {
    display: none;
  }
  .hd-groop {
    gap: 20px;
  }
  .main-menu-container {
    width: 60%;
    margin-left: 3.91vw;
  }
  .main-menu li {
    margin-right: 0;
  }
}
@media screen and (max-width: 680px) {
  .wrap,
  .wrap.re-wrap {
    flex-direction: column;
  }

  body .sp-only {
    display: block;
  }

  body .pc-only {
    display: none;
  }

  .inner,
  .s-inner {
    padding-left: 3%;
    padding-right: 3%;
  }

  .reserve-btn span {
    margin-left: 10px;
  }
}

/*-------common-end------*/

/*-------hamburger-css---*/
#menu-button {
  visibility: hidden;
  opacity: 1;
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 900;
  top: 0;
  right: 0;
  width: 60px;
  height: 60px;
}

#menu-button.nav-on {
  visibility: visible;
  opacity: 1;
}

#menu-button .ham-lines {
  position: relative;
  margin: 0 auto;
  width: 40px;
  height: 30px;
}

#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
  position: absolute;
  display: block;
  right: 0;
  left: 0;
  margin: 0 auto;
  width: 40px;
  height: 2px;
  background-color: #635c53;
  border-radius: 1px;
}

#menu-button .ham-lines span {
  transition: all 0.25s 0.25s;
  opacity: 1;
}

#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
  content: "";
}

#menu-button .ham-lines::before {
  bottom: 10px;
  animation: menu-bar01 0.75s forwards;
}

#menu-button .ham-lines::after {
  bottom: 0px;
  animation: menu-bar03 0.75s forwards;
}

#menu-button .ham-text {
  font-size: 12px;
  line-height: 1;
}

#menu-button.is-active .ham-lines span {
  opacity: 0;
}

#menu-button.is-active .ham-lines::before {
  animation: active-menu-bar01 0.5s forwards;
}

#menu-button.is-active .ham-lines::after {
  animation: active-menu-bar03 0.5s forwards;
}

@keyframes menu-bar01 {
  0% {
    transform: translateY(9px) rotate(45deg);
  }

  50% {
    transform: translateY(9px) rotate(0);
  }

  100% {
    transform: translateY(0) rotate(0);
  }
}

@keyframes menu-bar03 {
  0% {
    transform: translateY(-9px) rotate(-45deg);
  }

  50% {
    transform: translateY(-9px) rotate(0);
  }

  100% {
    transform: translateY(0) rotate(0);
  }
}

@keyframes active-menu-bar01 {
  0% {
    transform: translateY(0) rotate(0);
  }

  50% {
    transform: translateY(9px) rotate(0);
  }

  100% {
    transform: translateY(0px) rotate(15deg);
  }
}

@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0);
  }

  50% {
    transform: translateY(-9px) rotate(0);
  }

  100% {
    transform: translateY(-11px) rotate(-15deg);
  }
}

@media screen and (max-width: 680px) {
  body {
    padding-bottom: 60px;
  }

  .header {
    right: 0;
  }

  .hd-groop {
    justify-content: left;
  }

  body #menu-button {
    visibility: visible;
    opacity: 1;
    display: flex;
    z-index: 701;
    position: fixed;
    right: 0;
    z-index: 999999;
  }

  #main-menu-container {
    position: fixed;
    z-index: 800;
    top: 0;
    left: auto;
    right: -100vw;
    bottom: auto;
    overflow-y: auto;
    background: #fafafa;
    background-size: cover;
    display: none;
    width: 70vw;
    height: 100vh;
    transition: 0.3s linear;
    margin-right: 0;
  }

  #main-menu-container.is-active {
    right: 0vw;
  }

  body #main-menu-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: #e9dfd5;
    margin-left: 0;
  }

  .main-menu {
    flex-direction: column;
    gap: 27px;
    text-align: center;
    font-size: 2rem;
  }

  .header .pc-only {
    display: none;
  }

  .logo-wrap {
    margin-right: 0;
    margin-left: 23px;
  }

  .f-logowrp img {
    width: 158.92px;
  }

  .f-logowrp {
    margin-bottom: 30px;
  }

  .footerwrap .left {
    margin: 0 auto;
  }

  .copyright-container {
    padding: 20px 0;
  }

  body .ft-list {
    width: 100%;
  }

  .ft-list li {
    flex-direction: column;
  }

  .footerwrap .wrap {
    gap: 40px;
    margin-bottom: 40px;
  }

  .ft-list li {
    gap: 10px;
    text-align: center;
  }

  .ft-list li:nth-child(2) {
    text-align: left;
  }

  .ft-list span {
    margin-right: 0;
  }
}

/*-------ft-icon-css---*/

.sp-footer-icons-container {
  display: none;
  justify-content: space-around;
  align-items: stretch;
  position: fixed;
  z-index: 701;
  right: 0;
  left: 0;
  bottom: 10px;
  width: 100%;
  padding-bottom: calc(env(safe-area-inset-bottom) / 2);
}

@media screen and (max-width: 680px) {
  .sp-footer-icons-container {
    display: flex;
  }
}
