.pcbr {
  display: block;
}
@media screen and (max-width: 768px) {
  .pcbr {
    display: inline;
  }
}

@media screen and (max-width: 768px) {
  .spbr {
    display: block;
  }
}

@-webkit-keyframes shine {
  100% {
    left: 125%;
  }
}

@keyframes shine {
  100% {
    left: 125%;
  }
}
.js_fixed {
  height: 100%;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .js_fixed {
    position: relative;
    overflow: hidden;
  }
}
.js_fixed #header .header_box .header_btn {
  border-radius: 0px 0px 0px 30px;
  border-bottom: 3px solid #735C48;
  border-left: 3px solid #735C48;
  background: rgba(78, 54, 32, 0.4);
}
.js_fixed #header .header_box .header_btn .menu_wrap .menu_sp::after {
  content: "CLOSE";
}
.header_wrap {
  display: flex;
  flex-direction: column;
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 120;
}

#header {
  position: relative;
  width: 100%;
}
#header .header_box {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  height: 125px;
  background: linear-gradient(180deg, rgba(90, 79, 49, 0.45) 37.44%, rgba(140, 131, 111, 0.28) 71.12%, rgba(200, 196, 186, 0.13) 90%, rgba(255, 255, 255, 0) 100%);
}
@media screen and (max-width: 768px) {
  #header .header_box {
    min-width: 100%;
    height: 105px;
  }
}
#header .header_box .header_logo_box {
  position: absolute;
  left: 0;
  height: 125px;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_logo_box {
    height: 105px;
  }
}
#header .header_box .header_logo_box .header_logo {
  margin: 17px 0 0 32px;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_logo_box .header_logo {
    height: 105px;
    margin: 16px 0 0 17px;
  }
}
#header .header_box .header_logo_box .header_logo .logo_img {
  width: 340px;
  height: auto;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_logo_box .header_logo .logo_img {
    width: 260px;
    transition: all 0.3s;
  }
}
@media screen and (max-width: 330px) {
  #header .header_box .header_logo_box .header_logo .logo_img {
    width: 220px;
  }
}
#header .header_box .header_btn {
  display: flex;
  align-items: center;
  width: 200px;
  height: 90px;
  z-index: 110;
  transition: all 0.3s;
  position: relative;
  border-radius: 0px 0px 0px 30px;
  border-bottom: 3px solid #fff;
  border-left: 3px solid #fff;
  background: rgba(255, 255, 255, 0.16);
  box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 768px) {
  #header .header_box .header_btn {
    width: 85px;
    height: 78px;
  }
}
#header .header_box .header_btn.fixed {
  position: fixed;
}
#header .header_box .header_btn .menu_wrap {
  width: 100%;
  height: 100%;
}
#header .header_box .header_btn .menu_wrap .menu_sp {
  width: 100%;
  height: 100%;
  position: relative;
  transition: all 0.3s;
  overflow: hidden;
}
#header .header_box .header_btn .menu_wrap .menu_sp::after {
  content: "MENU";
  color: #fff;
  text-shadow: 0px 3px 5px rgba(0, 0, 0, 0.2);
  font-family: "Sorts Mill Goudy", serif;
  font-size: 1.6rem;
  letter-spacing: 0.32rem;
  position: absolute;
  left: 33px;
  top: 50%;
  transform: translatey(-50%);
  transition: all 0.3s;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_btn .menu_wrap .menu_sp::after {
    position: absolute;
    top: 12px;
    left: 50%;
    transform: translateX(-50%) translatey(0);
    font-size: 1.1rem;
    letter-spacing: 0.22rem;
  }
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line {
  background: #fff;
  display: block;
  height: 2px;
  transition: all 0.3s;
  width: 60px;
  position: absolute;
  right: 25px;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_btn .menu_wrap .menu_sp .menu__line {
    width: 38px;
    right: 22.5px;
  }
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line--top {
  top: 25px;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_btn .menu_wrap .menu_sp .menu__line--top {
    top: 35px;
  }
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line--center {
  top: 39px;
}
@media screen and (max-width: 768px) {
  #header .header_box .header_btn .menu_wrap .menu_sp .menu__line--center {
    top: 44px;
  }
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line--bottom {
  top: 53px;
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line--top.active {
  transform-origin: left top;
  transform: rotate(28.5deg);
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line--center.active {
  display: none;
}
#header .header_box .header_btn .menu_wrap .menu_sp .menu__line--bottom.active {
  transform-origin: left bottom;
  transform: rotate(-28.5deg);
}
#header .gnav {
  display: block;
  height: 100%;
  position: fixed;
  z-index: 102;
  top: 0;
  right: -470px;
  transition: all 0.6s;
}
@media screen and (max-width: 768px) {
  #header .gnav {
    z-index: 90;
    width: 100%;
    top: 0;
    right: -100%;
    padding: 0;
    overflow: scroll;
  }
}
#header .gnav.open {
  right: 0;
}
#header .gnav .gnav_wrap {
  width: auto;
  padding: 160px 80px 80px;
  background: rgba(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  height: 100%;
  width: 470px;
  overflow: scroll;
}
@media screen and (max-width: 768px) {
  #header .gnav .gnav_wrap {
    padding: 120px 8% 80px;
    border-radius: 0;
    width: 100%;
  }
}
#header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap {
  width: 100%;
}
#header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box {
  display: flex;
  align-items: center;
  flex-direction: column;
}
#header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul {
  display: flex;
  flex-direction: column;
  gap: 35px;
  width: 340px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  #header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul {
    width: 100%;
  }
}
#header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul > li {
  width: 100%;
  position: relative;
  padding: 0 0 0 50px;
}
#header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul > li::before {
  content: "";
  background: #4E3620;
  background-size: cover;
  width: 20px;
  height: 1px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translatey(-50%);
}
@media screen and (min-width: 769px) {
  #header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul > li a:hover {
    opacity: 0.7;
  }
}
#header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul > li .li_menu {
  text-align: left;
  color: #4E3620;
  font-family: YakuHanMP, "Noto Serif JP", serif;
  font-size: 1.9rem;
  font-weight: 500;
  line-height: 2.7rem;
  letter-spacing: 0.285rem;
}
@media screen and (max-width: 768px) {
  #header .gnav .gnav_wrap .gnav_menu .bigmenu_box_wrap .bigmenu_box > ul > li .li_menu {
    font-size: 1.7rem;
    font-weight: 500;
    letter-spacing: 0.255rem;
  }
}

.contents {
  max-width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .contents {
    width: 100%;
    padding: 0 4%;
  }
}

.contents_full {
  width: 100%;
  min-width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .contents_full {
    width: 100%;
    min-width: auto;
  }
}

.bold {
  font-weight: 700;
}

#footer .contents_full {
  background: #4E3620;
  padding: 47px 0 73px;
}
@media screen and (max-width: 768px) {
  #footer .contents_full {
    padding: 40px 0;
  }
}

.ft_conts {
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 40px;
  width: 975px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .ft_conts {
    width: 85%;
    flex-direction: column;
    gap: 0;
  }
}
.ft_conts .ft_logo {
  width: 100%;
}
.ft_conts .ft_logo img {
  width: 370px;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_logo img {
    width: 290px;
  }
}
.ft_conts .ft_schedule {
  padding: 5px 20px;
  width: 560px;
  border-radius: 15px;
  border: 2px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule {
    margin: 30px auto 0;
    width: 100%;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.5);
  }
}
.ft_conts .ft_schedule table {
  width: 100%;
}
.ft_conts .ft_schedule table tr th {
  text-align: center;
  vertical-align: middle;
  font-size: 1.7rem;
  font-weight: 500;
  line-height: 2.6rem;
  letter-spacing: 0.17rem;
  padding: 12px 10px;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule table tr th {
    font-size: 1.4rem;
    line-height: 1.7rem;
    letter-spacing: -0.042rem;
    padding: 9px 5px;
  }
}
.ft_conts .ft_schedule table tr th:first-child {
  text-align: left;
  padding: 12px 20px 12px 30px;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule table tr th:first-child {
    font-size: 1.4rem;
    padding: 9px;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule table tr th:last-child {
    padding: 9px 16px 9px 5px;
  }
}
.ft_conts .ft_schedule table tr td {
  text-align: center;
  vertical-align: middle;
  font-size: 1.7rem;
  font-weight: 500;
  line-height: 2.6rem;
  letter-spacing: 0.17rem;
  padding: 12px 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule table tr td {
    font-size: 1.4rem;
    line-height: 1.7394rem;
    letter-spacing: -0.042rem;
    padding: 9px 5px;
  }
}
.ft_conts .ft_schedule table tr td:first-child {
  text-align: left;
  padding: 12px 20px 12px 30px;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule table tr td:first-child {
    font-size: 1.4rem;
    text-align: center;
    padding: 9px 5px;
  }
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_schedule table tr td:last-child {
    padding: 9px 16px 9px 5px;
  }
}
.ft_conts .ft_info {
  width: 370px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_info {
    width: 100%;
    margin: 20px auto 0;
    gap: 8px;
  }
}
.ft_conts .ft_info .txt_01 {
  font-size: 1.7rem;
  font-weight: 500;
  line-height: 3rem;
  letter-spacing: 0.255rem;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_info .txt_01 {
    font-size: 1.5rem;
    line-height: 2.4rem;
    letter-spacing: 0.1rem;
  }
}
.ft_conts .ft_info .txt_01 .span {
  font-size: 2.1rem;
}
@media screen and (max-width: 768px) {
  .ft_conts .ft_info .txt_01 .span {
    font-size: 1.8rem;
    line-height: 2.6rem;
    letter-spacing: 0.1rem;
  }
}
@media screen and (max-width: 768px) {
  .ft_conts .map {
    margin: 35px auto 0;
    width: 100%;
  }
}
.ft_conts .map iframe {
  width: 975px;
  height: 335px;
}
@media screen and (max-width: 768px) {
  .ft_conts .map iframe {
    width: 100%;
    height: 200px;
  }
}

.ft_bnr_box {
  padding: 20px 0 25px;
}
.ft_bnr_box .bnr_item {
  margin: 0 auto;
  width: 260px;
}
@media screen and (max-width: 768px) {
  .ft_bnr_box .bnr_item {
    width: 200px;
  }
}
.ft_bnr_box .bnr_item a img {
  border: 1px solid #CEC9C6;
}
.ft_bnr_box .bnr_item a .span {
  display: block;
  padding: 10px 0 0;
  color: #222;
  text-align: center;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: 1.5rem;
  line-height: 1;
  letter-spacing: 0.15rem;
}
@media screen and (max-width: 768px) {
  .ft_bnr_box .bnr_item a .span {
    font-size: 1.2rem;
    letter-spacing: 0.1rem;
  }
}

.copy {
  background: linear-gradient(90deg, #F4EFE2 2.83%, #FBF6EA 57.14%, #D9D3C4 98.11%);
  color: #4C4C4C;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: 1.4rem;
  line-height: 3.2rem;
  letter-spacing: 0.14rem;
  padding: 10px 0 110px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .copy {
    font-size: 1.3rem;
    line-height: 3.2rem;
    letter-spacing: 0.13rem;
    padding: 10px 0 80px;
  }
}

#pagetop {
  display: block;
  position: fixed;
  bottom: 110px;
  right: 16px;
  z-index: 20;
}
@media screen and (max-width: 768px) {
  #pagetop {
    bottom: 80px;
  }
}
#pagetop a {
  width: 46px;
  height: 46px;
}

.conv_box {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 10;
  height: 95px;
  display: flex;
}
@media screen and (max-width: 768px) {
  .conv_box {
    width: 100%;
    height: 70px;
  }
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel {
    width: 33.3333333333%;
  }
}
.conv_box .conv_tel a {
  height: 95px;
  color: #fff;
  border-radius: 30px 0px 0px 0px;
  background: rgba(78, 54, 32, 0.75);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0 45px;
  pointer-events: none;
  position: relative;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel a {
    background: rgb(78, 54, 32);
    border-radius: 0;
    pointer-events: all;
    height: 70px;
    width: 100%;
    padding: 0 0 10px;
    justify-content: flex-end;
  }
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel a::before {
    content: "";
    background: url(../images/common/icon_tel.svg);
    background-size: cover;
    width: 25px;
    height: 23px;
    position: absolute;
    top: 9px;
    left: 50%;
    transform: translateX(-50%);
  }
}
.conv_box .conv_tel a .txt_01 {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.7rem;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel a .txt_01 {
    display: none;
  }
}
.conv_box .conv_tel a .txt_02 {
  font-family: YakuHanMP, "Noto Serif JP", serif;
  font-size: 2.6rem;
  font-weight: 500;
  line-height: 2.7rem;
  letter-spacing: 0.39rem;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel a .txt_02 {
    display: none;
  }
}
.conv_box .conv_tel a .txt_02 .span {
  font-family: "Sorts Mill Goudy", serif;
  font-size: 1.8rem;
  line-height: 2.7rem;
  letter-spacing: 0.27rem;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel a .txt_02 .span {
    display: none;
  }
}
.conv_box .conv_tel a .txt_03 {
  display: none;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_tel a .txt_03 {
    display: block;
    font-size: 1.4rem;
    line-height: 1.5;
    letter-spacing: 0.255rem;
  }
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item {
    width: 33.3333333333%;
  }
}
.conv_box .conv_item.item_web a {
  color: #fff;
  background: rgba(129, 102, 63, 0.75);
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item.item_web a {
    background: rgb(129, 102, 63);
  }
}
.conv_box .conv_item.item_web a::before {
  background: url(../images/common/icon_web.svg);
  background-size: cover;
  width: 32px;
  height: 26px;
  top: 19px;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item.item_web a::before {
    width: 26px;
    height: 20px;
    top: 13px;
  }
}
.conv_box .conv_item.item_web a::after {
  background: rgba(255, 255, 255, 0.6);
}
.conv_box .conv_item.item_monshin a {
  color: #4E3620;
  background: rgba(255, 255, 255, 0.7);
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item.item_monshin a {
    background: rgb(255, 255, 255);
  }
}
.conv_box .conv_item.item_monshin a::before {
  width: 32px;
  height: 30px;
  top: 16px;
  -webkit-mask-image: url(../images/common/icon_monshin.svg);
  mask-image: url(../images/common/icon_monshin.svg);
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  background-color: #4E3620;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item.item_monshin a::before {
    width: 27px;
    height: 24px;
    top: 10px;
  }
}
.conv_box .conv_item.item_monshin a::after {
  background: #4E3620;
}
.conv_box .conv_item a {
  width: 157px;
  height: 95px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  font-size: 1.7rem;
  font-weight: 500;
  line-height: 2.7rem;
  letter-spacing: 0.255rem;
  padding: 0 0 20px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item a {
    height: 70px;
    width: 100%;
    padding: 0 0 10px;
    font-size: 1.4rem;
    line-height: 1.5;
    letter-spacing: 0.255rem;
  }
}
.conv_box .conv_item a::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.conv_box .conv_item a::after {
  content: "";
  width: 15px;
  height: 15px;
  -webkit-clip-path: polygon(100% 100%, 100% 0%, 0% 100%);
          clip-path: polygon(100% 100%, 100% 0%, 0% 100%);
  position: absolute;
  right: 6px;
  bottom: 6px;
}
@media screen and (max-width: 768px) {
  .conv_box .conv_item a::after {
    width: 10px;
    height: 10px;
  }
}
@media screen and (min-width: 769px) {
  .conv_box .conv_item a:hover {
    opacity: 0.7;
  }
}
/*# sourceMappingURL=style.css.map */