body {
  font-family: "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, sans-serif;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  color: #333333;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
  font-size: 16px;
  letter-spacing: 0.03em;
}

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

img {
  vertical-align: bottom !important;
  max-width: 100% !important;
  height: auto !important;
}

@media only screen and (max-width: 1024px) {
  img {
    border: 0 !important;
    max-width: 100% !important;
    height: auto !important;
  }
}

a {
  color: #333333 ;
  text-decoration: none ;
  -webkit-transition: 0.5s;
  transition: 0.5s !important;
}

a:hover {
  opacity: 0.7 !important;
}

a img {
  border: none !important;
}

i {
  padding: 0 5px !important;
}

ul {
  letter-spacing: -1em !important;
}

ul li {
  letter-spacing: 0 !important;
  list-style: none !important;
}

.pc {
  display: block;
}

@media only screen and (max-width: 1024px) {
  .pc {
    display: none;
  }
}

.tablet {
  display: none;
}

@media only screen and (max-width: 1024px) {
  .tablet {
    display: block;
  }
}

@media only screen and (max-width: 480px) {
  .tablet {
    display: none;
  }
}

.sp {
  display: none;
}

@media only screen and (max-width: 1024px) {
  .sp {
    display: block;
  }
}

.ssp {
  display: none;
}

@media only screen and (max-width: 480px) {
  .ssp {
    display: block;
  }
}

/*PC改行加える*/
.br-pc {
  display: inherit;
}

@media only screen and (max-width: 1024px) {
  .br-pc {
    display: none;
  }
}

/*PC改行無効*/
.br_sp {
  display: none;
}

@media only screen and (max-width: 1024px) {
  .br_sp {
    display: block;
  }
}

.br_ssp {
  display: none;
}

@media only screen and (max-width: 480px) {
  .br_ssp {
    display: block;
  }
}

/************************************

wrapper

************************************/
.wrapper {
  max-width: 1100px !important;
  width: 90% !important;
  margin: 0 auto !important;
}

.wrapper::after {
  content: "" !important;
  display: block !important;
  clear: both !important;
}

/************************************

.list(flexbox)

************************************/
.list {
  display: block !important;
  display: -ms-flexbox !important;
  display: -webkit-box !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
}

.list::after {
  content: "" !important;
  display: block !important;
  clear: both !important;
}

.list article {
  width: auto !important;
}

/************************************

header

************************************/
header {
  width: 100% !important;
  background-color: #fff;
  position: fixed !important;
  z-index: 20 !important;
  -webkit-transition: .5s !important;
  transition: .5s !important;
}

@media print {
  header {
    position: relative !important;
  }
}

header #head_top {
  width: 100% !important;
  border-bottom: 1px solid #ccc;
  padding: 10px 2% !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center ;
}

@media only screen and (max-width: 1024px) {
  header #head_top {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
  }
}

header #head_top .soryo {
  font-size: 12px !important;
  width: calc(100% - 600px) !important;
}

@media only screen and (max-width: 1024px) {
  header #head_top .soryo {
    display: none !important;
  }
}

header #head_top ul {
  /*width: 600px !important ;*/
  width:auto !important;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap !important;
  justify-content: center !important;
}

@media only screen and (max-width: 1024px) {
  header #head_top ul {
    width: 100% !important;
    padding-right: 50px !important;
    justify-content: flex-end !important;
  }
}

header #head_top ul li {
  font-size: 12px !important;
  margin: 0 0 0 15px !important;
}
@media only screen and (max-width: 1024px) {
header #head_top ul li {
  margin: 0 0 0 10px !important;
}
}
header #head_top ul li.pc_no{
display: none !important;
}
@media only screen and (max-width: 1024px) {
header #head_top ul li.pc_no{
display: block !important;
}
}

header #head_top ul li a {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

header #head_top ul li .icon {
  width: 20px !important;
  margin: 0 3px 0 0 !important;
}

@media only screen and (max-width: 1024px) {
  header #head_top ul li .icon {
    width: 18px !important;
  }
}

header #head_top ul li p {
  width: calc(100% - 23px) !important;
}

@media only screen and (max-width: 1024px) {
  header #head_top ul li p {
    display: none !important;
  }
  header #head_top ul li.tel_ue{
  display: flex !important;
-webkit-flex-wrap: wrap !important;
flex-wrap:  wrap !important;
  }
  header #head_top ul li.tel_ue p {
    display: block !important;
  }
}
@media only screen and (max-width: 360px) {

}header #head_top ul li.tel_ue p {
    display: none !important;
  }

header #head_top .search {
  width: 185px !important;
  margin-left: 15px !important;
}

@media only screen and (max-width: 1024px) {
  header #head_top .search {
    position: absolute !important;
    top: -32px !important;
    left: 5px !important;
  }
}

@media only screen and (max-width: 480px) {
  header #head_top .search {
    display: none !important;
  }
}

header #head_top .search .list {
  -webkit-box-align: center !important;
  -ms-flex-align: center !important;
  align-items: center !important;
}

header #head_top .search .icon {
  width: 20px !important;
  margin: 0 5px 0 0 !important;
}

@media only screen and (max-width: 1024px) {
  header #head_top .search .icon {
    width: 18px !important;
  }
}

header #head_top .search .form {
  width: 160px !important;
}

header #head_top .search .form input {
  padding: 7px !important;
  font-size: 13px !important;
  width: 100% !important;
  border: 1px solid #ccc;
}

@media only screen and (max-width: 1024px) {
  header #head_top .search .form input {
    padding: 5px !important;
  }
}

header #head_main {
  width: 100% !important;
  padding: 20px 1% !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}

@media only screen and (max-width: 1024px) {
  header #head_main {
    padding: 10px 1% !important;
  }
}

header #head_main .logo {
  width: 220px !important;/*220*/
  margin: 0 20px 0 0 !important;/**/
}
@media only screen and (max-width: 1200px) {
header #head_main .logo {
  width: 210px !important;/*220*/
  margin: 0 15px 0 0 !important;/*0 20px 0 0*/
}
}
@media only screen and (max-width: 1024px) {
  header #head_main .logo {
    width: 150px !important;
    margin: 0 10px 0 0 !important;
  }
}

header #head_main nav {
  width: calc(100% - 220px - 20px) !important;/**/
  /*max-width: 940px !important;*/
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;

  
  align-items: center !important;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
}
@media only screen and (max-width: 1200px) {
header #head_main nav {
  width: calc(100% - 210px - 15px) !important;/*calc(100% - 210px - 20px)*/
  }
}
@media only screen and (max-width: 1024px) {
  header #head_main nav {
    width: calc(100% - 170px) !important;
  }
}
header #head_main nav .info{
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  justify-content: flex-end;
  width: 240px !important;/*150px*/
  margin-right: 10px !important;
}
@media only screen and (max-width: 1200px) {
header #head_main nav .info{
/*width: 210px !important;*//*150px*/
}
}
@media only screen and (max-width: 1060px) {
header #head_main nav .info{
width: 210px !important;/*150px*/
}
}
@media only screen and (max-width: 1024px) {
header #head_main nav .info{
display: none !important;
}
}
header #head_main nav .info li{
width:33.3% !important;/*50%*/
display: flex !important;
-webkit-flex-wrap: wrap !important;
flex-wrap:  wrap !important;
align-items: center !important;
}
header #head_main nav .info li a{
display: flex !important;
-webkit-flex-wrap: wrap !important;
flex-wrap:  wrap !important;
align-items: center !important;

}
header #head_main nav .info li .icon{
width:20px !important;
margin-right: 3px !important;
}
header #head_main nav .info li p{
width:calc(100% - 20px - 3px) !important;
font-size: 13px !important;
line-height: 1.2 !important;
}
header #head_main nav .tel{
width: 160px !important;/**/
display: flex !important;
-webkit-flex-wrap: wrap !important;
flex-wrap:  wrap !important;
align-items: center !important;
}
@media only screen and (max-width: 1200px) {
header #head_main nav .tel{
width: 150px !important;/*160*/
}
}
@media only screen and (max-width: 1024px) {
header #head_main nav .tel{
display: none !important;
}
}
header #head_main nav .tel .icon{
width:20px !important;
margin-right: 5px !important;
}
header #head_main nav .tel a{
width:calc(100% - 20px - 5px) !important;
font-size: 15px !important;
line-height: 1.2 !important;
}
header #head_main nav .tel a span{
font-size: 9px !important;
display: block;
}
header #head_main nav .item {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  justify-content: flex-end;
  width: calc(100% - 250px - 160px - 90px) !important;
}
@media only screen and (max-width: 1060px) {
header #head_main nav .item {
width: calc(100% - 230px - 150px - 90px) !important;
}
}
@media only screen and (max-width: 1024px) {
  header #head_main nav .item {
    width: calc(100% - 120px) !important;
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
  }
}

@media only screen and (max-width: 570px) {
  header #head_main nav .item {
    width: 100% !important;
  }
}

header #head_main nav .item li {
  width: 80px !important;/*80*/
  text-align: center !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
}
@media only screen and (max-width: 1200px) {
header #head_main nav .item li {
  width: 70px !important;/*80*/
  }
}
@media only screen and (max-width: 1024px) {
  header #head_main nav .item li {
    max-width: 100px !important;
    font-size: 10px !important;
    width: 33.3% !important;
  }
}

header #head_main nav .item li:last-child {
  width: 110px !important;/*110*/
}
@media only screen and (max-width: 1200px) {
header #head_main nav .item li:last-child {
  width: 90px !important;/*110*/
}
}
@media only screen and (max-width: 1024px) {
  header #head_main nav .item li:last-child {
    display: none !important;
  }
}

header #head_main nav .item li strong {
  font-size: 17px !important;
  font-weight: 500 !important;
  display: block !important;
}

@media only screen and (max-width: 1024px) {
  header #head_main nav .item li strong {
    font-size: 15px !important;
  }
}

@media only screen and (max-width: 420px) {
  header #head_main nav .item li strong {
    display: block !important;
  }
}

header #head_main nav .item li label {
  display: block !important;
  padding: 15px 0 !important;
  position: relative !important;
  cursor: pointer !important;
}

@media only screen and (max-width: 1024px) {
  header #head_main nav .item li label {
    padding: 10px 0 15px !important;
  }
}

@media only screen and (max-width: 420px) {
  header #head_main nav .item li label {
    padding: 5px 0 15px !important;
  }
}

header #head_main nav .item li label::before {
  position: absolute !important;
  bottom: 0 !important;
  left: 0px !important;
  right: 0 !important;
  margin: auto !important;
  width: 16px !important;
  height: 16px !important;
  background-image: url("https://file003.shop-pro.jp/PA01469/987/images/yaji_down.svg");
  background-repeat: no-repeat;
  background-position: center !important;
  background-size: contain;
  content: "";
}

header #head_main nav .item input {
  display: none !important;
}

header #head_main nav .kodawari {
  /*border-left: 1px solid #ccc;*/
  font-size: 15px !important;
  line-height: 1.2 !important;
  width: 90px !important;/*90*/
  text-align: center !important;
  padding: 10px 0 !important;
}
@media only screen and (max-width: 1200px) {
header #head_main nav .kodawari {
width: 80px !important;/*90*/
}
}
@media only screen and (max-width: 1024px) {
  header #head_main nav .kodawari {
    width: 120px !important;
    font-size: 12px !important;
    letter-spacing: 0 !important;
  }
}

@media only screen and (max-width: 570px) {
  header #head_main nav .kodawari {
    display: none;
  }
}



header #head_main .submenu {
  position: absolute !important;
  top: calc(100% - 20px) !important;
  z-index: 10 !important;
  width: 100% !important;
  left: 0 !important;
  opacity: 0 !important;
  height: 0 !important;
  -webkit-transition: 0.5s !important;
  transition: 0.5s !important;
  overflow: hidden !important;
  padding: 0 !important;
}

header #head_main .item li:hover .submenu {
  opacity: 1 !important;
  height: auto !important;
  padding: 20px 0 0 !important;
}

@media only screen and (max-width: 1024px) {
  header #head_main .item li:hover .submenu {
    opacity: 0 !important;
    height: 0 !important;
    padding: 0 !important;
  }
}

@media only screen and (max-width: 1024px) {
  header #head_main .item li input[type="checkbox"]:checked + .submenu {
    opacity: 1 !important;
    height: auto !important;
    padding: 20px 0 0 !important;
  }
}

header #head_main .submenu_waku {
  background-image: url("https://file003.shop-pro.jp/PA01469/987/images/back_beige.jpg");
  padding: 50px 0 !important;
  text-align: center !important;
}

@media only screen and (max-width: 1024px) {
  header #head_main .submenu_waku {
    padding: 30px 0 !important;
  }
}

header #head_main .submenu_waku h3 {
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
  font-size: 24px !important;
  display: inline-block !important;
  border-bottom: 1px solid #333333;
  padding-bottom: 10px !important;
  margin-bottom: 20px !important;
}

@media only screen and (max-width: 1024px) {
  header #head_main .submenu_waku h3 {
    font-size: 18px !important;
  }
}

header #head_main .submenu_waku ul {
  width: 90% !important;
  margin: 0 auto !important;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
}

header #head_main .submenu_waku ul li {
  font-size: 16px !important;
  text-align: left !important;
  padding: 0 !important;
}

@media only screen and (max-width: 1024px) {
  header #head_main .submenu_waku ul li {
    font-size: 14px !important;
    max-width: 100% !important;
  }
}

header #head_main .submenu_waku ul li img {
  margin-bottom: 6px !important;
}

header #head_main .submenu_waku ul li a {
  padding: 0 !important;
}

header #head_main .submenu_waku ul li a::before {
  position: absolute !important;
  left: auto !important;
  right: 0 !important;
  background-image: url("https://file003.shop-pro.jp/PA01469/987/images/yaji_right.svg");
}

header #head_main .sozai .submenu_waku ul, header #head_main .original .submenu_waku ul {
  max-width: 700px !important;
}

header #head_main .sozai .submenu_waku ul li, header #head_main .original .submenu_waku ul li {
  width: 46% !important;
  margin: 0 2% !important;
}

header #head_main .yoto .submenu_waku ul {
  max-width: 1100px !important;
}

header #head_main .yoto .submenu_waku ul li {
  width: 23% !important;

  margin: 0px 1% 20px !important;
}

@media only screen and (max-width: 480px) {
  header #head_main .yoto .submenu_waku ul li {
    width: 48% !important;
    margin: 0px 1% 10px !important;
  }
  header #head_main .yoto .submenu_waku ul li:nth-child(5), header #head_main .yoto .submenu_waku ul li:nth-child(6), header #head_main .yoto .submenu_waku ul li:nth-child(7), header #head_main .yoto .submenu_waku ul li:nth-child(8) {
    width: 23% !important;
    font-size: 12px !important;
  }
}

header #head_main .katachi .submenu_waku ul {
  max-width: 1100px !important;
  -webkit-box-pack: center !important;
  -ms-flex-pack: center !important;
  justify-content: center !important;
}

header #head_main .katachi .submenu_waku ul li {
/*  width: 16% !important; */
  width: 23% !important;
  margin: 0px 2% !important;
  text-align: center !important;
}

@media only screen and (max-width: 480px) {
  header #head_main .katachi .submenu_waku ul li {
    width: 29.3% !important;
    margin: 0 2% 10px !important;
  }
}

header #head_main .katachi .submenu_waku ul li a::before {
  display: none !important;
}

/************************************

footer

************************************/
footer {
  color: #fff;
  /************************************

#foot_guide

************************************/
  /************************************

#foot_main

************************************/
}

footer a {
  color: #fff;
}

footer #foot_guide {
  background-color: #321500;
  padding: 60px 0 !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_guide {
    padding: 40px 0 !important;
  }
}

footer #foot_guide h2 {
  font-size: 15px !important;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
  text-align: center !important;
  font-weight: normal !important;
  margin: 0 0 30px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_guide h2 {
    margin: 0 0 20px !important;
  }
}

footer #foot_guide h2 .eng {
  display: block !important;
  font-family: "EB Garamond", serif;
  font-size: 36px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_guide h2 .eng {
    font-size: 24px !important;
  }
}

footer #foot_guide ul {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  max-width: 900px !important;
  margin: 0 auto !important;
}

footer #foot_guide ul li {
  width: 31.3% !important;
  margin: 0 1% 2% !important;
  background-color: #543c2b;
}

@media only screen and (max-width: 1024px) {
  footer #foot_guide ul li {
    width: 48% !important;
  }
}

footer #foot_guide ul li a {
  display: block !important;
  padding: 12px !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  -webkit-box-align: center !important;
  -ms-flex-align: center !important;
  align-items: center !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_guide ul li a {
    padding: 10px !important;
  }
}

footer #foot_guide ul li .icon {
  width: 20px !important;
}

footer #foot_guide ul li p {
  width: calc(100% - 20px) !important;
  font-weight: bold !important;
  text-align: center !important;
  font-size: 15px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_guide ul li p {
    font-size: 14px !important;
  }
}

@media only screen and (max-width: 480px) {
  footer #foot_guide ul li p {
    font-size: 12px !important;
  }
}

footer #foot_main {
  padding: 60px 0 !important;
  background-color: #000;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main {
    padding: 40px 0 !important;
  }
}

footer #foot_main .wrapper {
  max-width: 90% !important;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
}

footer #foot_main .text {
  width: 320px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main .text {
    width: 100% !important;
    margin: 0 0 40px !important;
    text-align: center !important;
  }
}

footer #foot_main .text h2 {
  margin: 0 0 20px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main .text h2 img {
    width: 170px !important;
  }
}

footer #foot_main .text p {
  font-size: 14px !important;
}

footer #foot_main .text .tel {
  font-family: "EB Garamond", serif;
  font-size: 26px !important;
  margin: 5px 0 15px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main .text .tel {
    font-size: 20px !important;
  }
}

footer #foot_main .text .bt a {
  border: 1px solid #fff;
  font-size: 13px !important;
  display: inline-block !important;
  line-height: 1 !important;
  padding: 12px 50px 12px 30px !important;
  position: relative !important;
}

footer #foot_main .text .bt a::before {
  position: absolute !important;
  top: 50% !important;
  -webkit-transform: translateY(-50%) !important;
  transform: translateY(-50%) !important;
  right: 10px !important;
  width: 12px !important;
  height: 1px !important;
  background-color: #fff !important;
  content: "" !important;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

footer #foot_main .text .bt a:hover {
  opacity: !important;
  background-color: #fff;
  color: #333333;
}

footer #foot_main .text .bt a:hover::before {
  background-color: #333333;
  -webkit-transform: translateX(5px) !important;
  transform: translateX(5px) !important;
}

footer #foot_main nav {
  width: calc( 100% - 320px) !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex !important;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main nav {
    width: 100% !important;
  }
}

footer #foot_main nav article {
  width: 23% !important;
  margin: 0 1% !important;
}

@media only screen and (max-width: 480px) {
  footer #foot_main nav article {
    width: 100% !important;
    margin: 0 0 20px !important;
  }
}

footer #foot_main nav article h3 {
  font-size: 17px !important;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
  margin: 0 0 20px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main nav article h3 {
    font-size: 15px !important;
    margin: 0 0 12px !important;
  }
}

@media only screen and (max-width: 480px) {
  footer #foot_main nav article ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex !important;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

footer #foot_main nav article ul li {
  position: relative !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  margin: 0 0 10px !important;
  padding-left: 20px !important;
}

@media only screen and (max-width: 1024px) {
  footer #foot_main nav article ul li {
    font-size: 13px !important;
    padding-left: 10px !important;
  }
}

@media only screen and (max-width: 480px) {
  footer #foot_main nav article ul li {
    margin: 0 20px 10px 0 !important;
  }
}

footer #foot_main nav article ul li::before {
  position: absolute !important;
  top: 6px !important;
  left: 0px !important;
  width: 8px !important;
  height: 1px !important;
  background-color: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  content: "";
}

@media only screen and (max-width: 1024px) {
  footer #foot_main nav article ul li::before {
    width: 5px !important;
  }
}

footer #foot_main nav article ul li:hover::before {
  -webkit-transform: translateX(3px) !important;
  transform: translateX(3px) !important;
}

footer #foot_main .copyright {
  width: 100% !important;
  margin: 40px 0 0 !important;
  text-align: center !important;
  font-size: 11px !important;
  font-family: "EB Garamond", serif;
}

/************************************

PageUP

************************************/
#pageup {
  position: fixed !important;
  width: 50px !important;
  height: 50px !important;
  bottom: 0 !important;
  right: 0 !important;
  z-index: 10 !important;
  font-size: 8px !important;
  -webkit-transition: 0.5s !important;
  transition: 0.5s !important;
}

@media only screen and (max-width: 1024px) {
  #pageup {
    bottom: 0px !important;
    right: 0px !important;
    font-size: 4px !important;
  }
}

#pageup.none {
  display: none !important;
}

#pageup a {
  width: 50px !important;
  display: block !important;
  text-decoration: none !important;
  line-height: 100% !important;
  color: #777 !important;
}

#pageup i {
  font-size: 40px !important;
  line-height: 0.8 !important;
}

@media only screen and (max-width: 1024px) {
  #pageup i {
    font-size: 36px !important;
  }
}

/************************************

main

************************************/
#main {
  display: block !important;
  padding-top: 141px !important;
}

@media only screen and (max-width: 1024px) {
  #main {
    padding-top: 102px !important;
  }
}

@media only screen and (max-width: 420px) {
  #main {
    padding-top: 109px !important;
  }
}

#main section {
  opacity: 0 !important;
  transform: translate(0, 0px) !important;
  -webkit-transform: translate(0, 0px) !important;
  -webkit-transition: 1s !important;
  transition: 1s !important;
}

#main section.mv07 {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
  -webkit-transform: translate(0, 0) !important;
}

@media print {
  #main section {
    opacity: 1 !important;
  }
}

/*移動＋フェードイン表示*/
.list-mv07:not(:target) {
  opacity: 1\9;
  /*IE9対策*/
}

.beige {
  background-image: url("https://file003.shop-pro.jp/PA01469/987/images/back_beige.jpg");
  padding: 70px 0 !important;
}

/************************************

.second_page

************************************/
.second_page {
  padding-top: 50px !important;
}

@media only screen and (max-width: 1024px) {
  .second_page {
    padding-top: 30px !important;
  }
}

/************************************

.page_title

************************************/
.page_title {
  margin: 0 0 70px !important;
}

@media only screen and (max-width: 1024px) {
  .page_title {
    margin: 0 0 40px !important;
  }
}

.page_title h1, .page_title h2 {
  font-size: 15px !important;
  font-weight: normal !important;
  text-align: center !important;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
}

.page_title h1 .eng, .page_title h2 .eng {
  display: block !important;
  font-family: "EB Garamond", serif;
  font-size: 36px !important;
}

@media only screen and (max-width: 1024px) {
  .page_title h1 .eng, .page_title h2 .eng {
    font-size: 28px !important;
  }
}

/************************************

#pickup

************************************/
#pickup {
  padding: 70px 0 !important;
}

@media only screen and (max-width: 1024px) {
  #pickup {
    padding: 40px 0 !important;
  }
}

#pickup .page_title {
  margin-bottom: 40px !important;
}

@media only screen and (max-width: 1024px) {
  #pickup .page_title {
    margin-bottom: 30px !important;
  }
}

#pickup .pickup_slide img {
  border-radius: 3px !important;
}

#pickup .pickup_slide .waku {
  text-align: center !important;
  margin: 0 5px !important;
  position: relative !important;
}

#pickup .pickup_slide .waku a {
  display: block !important;
}

#pickup .pickup_slide .waku .text {
  position: absolute !important;
  z-index: 2 !important;
  width: 100% !important;
  top: 35% !important;
  left: 0 !important;
  text-align: center !important;
}

#pickup .pickup_slide .waku h4 {
  display: inline-block !important;
  background-color: #333333;
  color: #fff;
  padding: 10px 20px !important;
  font-size: 14px !important;
}

/************************************

slick common

************************************/
/* Arrows */
.slick-prev,
.slick-next {
  width: 30px !important;
  height: 30px !important;
  z-index: 3 !important;
}

.slick-prev:before,
.slick-next:before {
  font-family: 'FontAwesome';
  font-size: 30px !important;
  line-height: 1 !important;
  opacity: .75 !important;
  color: #ccc;
}

.slick-prev {
  left: 20px !important;
}

@media only screen and (max-width: 1024px) {
  .slick-prev {
    left: 5px !important;
  }
}

.slick-prev:before {
  content: '\f104';
}

.slick-next {
  right: 20px !important;
}

@media only screen and (max-width: 1024px) {
  .slick-next {
    right: 5px !important;
  }
}

.slick-next:before {
  content: '\f105';
}

/************************************

.bt

************************************/
.bt a {
  display: inline-block !important;
  font-size: 13px !important;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
  padding: 10px 70px 10px 50px !important;
  position: relative !important;
  border: 1px solid #333333;
}

@media only screen and (max-width: 1024px) {
  .bt a {
    padding: 7px 30px 7px 20px !important;
    font-size: 11px !important;
  }
}

.bt a::before {
  position: absolute !important;
  top: 50% !important;
  -webkit-transform: translateY(-50%) !important;
  transform: translateY(-50%) !important;
  right: 12px !important;
  width: 12px !important;
  height: 1px !important;
  background-color: #333333;
  content: "" !important;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

@media only screen and (max-width: 1024px) {
  .bt a::before {
    right: 7px !important;
    width: 7px !important;
  }
}

.bt a:hover {
  background-color: #333333;
  color: #fff;
  opacity: 1 !important;
}

.bt a:hover::before {
  right: 8px !important;
  background-color: #fff;
}

@media only screen and (max-width: 1024px) {
  .bt a:hover::before {
    right: 7px !important;
  }
}

/************************************

raf

************************************/
.raf {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}

.raf img {
  width: 100%;
  height: auto;
}

.raf a:hover {
  opacity: 1;
}

/*!------------------------------------*\
    Base
\*!------------------------------------*/
.drawer-nav {
  position: fixed;
  z-index: 1000;
  top: 0;
  overflow: hidden;
  width: 80vw;
  color: #333333;
  height: 100%;
  background-color: #fff;
}

.drawer-menu {
  margin: 0!important;
  padding: 0 !important;
  list-style: none !important;
}

/*! overlay */
.drawer-overlay {
  position: fixed !important;
  z-index: 100 !important;
  top: 0 !important;
  left: 0 !important;
  display: none !important;
  width: 100% !important;
  height: 100% !important;
  background-color: rgba(0, 0, 0, 0.2);
}

.drawer-open .drawer-overlay {
  display: block !important;
}

.drawer--right.drawer-open .drawer-nav,
.drawer--right .drawer-hamburger,
.drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
  right: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/*!------------------------------------*\
    Right
\*!------------------------------------*/
.drawer--right .drawer-nav {
  right: -80vw;
  -webkit-transition: right 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: right 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.drawer--right.drawer-open .drawer-nav,
.drawer--right .drawer-hamburger,
.drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
  right: 0;
}

.drawer--right.drawer-open .drawer-hamburger {
  right: 80vw;
}

/*!------------------------------------*\
    Hamburger
\*!------------------------------------*/
.drawer-hamburger {
  position: fixed;
  z-index: 104;
  top: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 40px !important;
  padding:2px 2px 4px 8px!important;
  height:40px !important;
  background-color: #333333;
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  border: 0;
  outline: 0;
}

.drawer-hamburger:hover {
  cursor: pointer;
  background-color: #333333;
}

.drawer-hamburger-icon {
  position: relative;
  display: block;
  margin-top: 50px;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  width: 24px;
  height: 2px;
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  background-color: #fff;
}

.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  position: absolute;
  top: -8px;
  left: 0;
  content: ' ';
}

.drawer-hamburger-icon:after {
  top: 8px;
}

.drawer-open .drawer-hamburger-icon {
  background-color: transparent;
}

.drawer-open .drawer-hamburger-icon:before,
.drawer-open .drawer-hamburger-icon:after {
  top: 0;
}

.drawer-open .drawer-hamburger-icon:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.drawer-open .drawer-hamburger-icon:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

/*!------------------------------------*\
    accessibility
\*!------------------------------------*/
/*!
 * Only display content to screen readers
 * See: http://a11yproject.com/posts/how-to-hide-content
 */
.sr-only {
  position: absolute;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
}

/*!
 * Use in conjunction with .sr-only to only display content when it's focused.
 * Useful for "Skip to main content" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1
 * Credit: HTML5 Boilerplate
 */
.sr-only-focusable:active,
.sr-only-focusable:focus {
  position: static;
  overflow: visible;
  clip: auto;
  width: auto;
  height: auto;
  margin: 0;
}

/*!------------------------------------*\
    Container
\*!------------------------------------*/
.drawer-menu {
  padding: 8% !important;
}

.drawer-menu .logo {
  width: 170px !important;
  margin: 0 auto !important;
}

.drawer-menu .search {
  margin: 10px 0 !important;
  padding: 10px !important;
  background-color: #f2efea !important;
}

.drawer-menu .search .list {
  -webkit-box-align: center !important;
  -ms-flex-align: center !important;
  align-items: center !important;
}

.drawer-menu .search .icon {
  width: 20px !important;
  margin: 0 5px 0 0 !important;
}

.drawer-menu .search .form {
  width: calc(100% - 25px) !important;
}

.drawer-menu .search .form input {
  padding: 6px !important;
  font-size: 14px !important;
  border: 1px solid #ccc;
  width: 100% !important;
}

.drawer-menu nav .item article {
  border-bottom: 1px solid #ccc;
}

.drawer-menu nav .item article:first-child {
  border-top: 1px solid #ccc;
}

.drawer-menu nav .item article label {
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
  font-size: 15px !important;
  display: block !important;
  padding: 12px 5px !important;
}

.drawer-menu nav .item article label strong {
  font-size: 18px !important;
  font-weight: normal !important;
}

.drawer-menu nav .item article input[type="checkbox"] {
  display: none !important;
}

.drawer-menu nav .item article ul {
  opacity: 0 !important;
  height: 0 !important;
  -webkit-transition: 0.3s !important;
  transition: 0.3s !important;
  overflow: hidden !important;
}

.drawer-menu nav .item article input[type="checkbox"]:checked + ul {
  margin: 0 0 0 5px !important;
  opacity: 1 !important;
  height: auto !important;
}

.drawer-menu nav .item article li {
  margin: 0 0 0px !important;
  font-size: 14px !important;
  text-align: left !important;
  position: relative !important;
}

.drawer-menu nav .item article li a {
  display: block !important;
  padding: 7px 0 !important;
}

.drawer-menu nav .item article li a::before {
  position: absolute !important;
  top: 50% !important;
  -webkit-transform: translateY(-50%) !important;
  transform: translateY(-50%) !important;
  right: 0px !important;
  color: #b6641c !important;
  font-family: 'FontAwesome';
  content: "\f105" !important;
}

.drawer-menu nav .etc {
  margin-top: 12px !important;
}

.drawer-menu nav .etc li {
  margin: 0 0 0px !important;
  font-size: 14px !important;
  text-align: left !important;
  position: relative !important;
}

.drawer-menu nav .etc li a {
  display: block !important;
  padding: 7px 5px !important;
}

.drawer-menu nav .etc li a::before {
  position: absolute !important;
  top: 50% !important;
  -webkit-transform: translateY(-50%) !important;
  transform: translateY(-50%) !important;
  right: 0px !important;
  color: #b6641c !important;
  font-family: 'FontAwesome';
  content: "\f105" !important;
}

.drawer-menu .tel {
  font-family: "EB Garamond", serif;
  font-size: 20px !important;
  text-align: center !important;
  margin: 15px 0 0 !important;
  padding: 12px 0 !important;
  border-top: 1px solid #333333;
  border-bottom: 1px solid #333333;
}

/* 20251021 「料金」に関するコンテンツ設置 */
#foot_price {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-around;
    background-image: url(https://file003.shop-pro.jp/PA01469/987/images/back_beige.jpg);
    color: #000;
    padding: 20px 40px 20px !important;
    font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
}
#foot_price .foot_price_item {
    width: 20%;
}
#foot_price .foot_price_item_center {
    width: 46%;
}
#foot_price h2 {
    font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
    font-weight: normal !important;
    font-size: 21px !important;
    border-bottom: 1px solid #b6641c;
    letter-spacing: 0.1em !important;
    display: inline-block !important;
}
#foot_price h3 {
    font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
    font-weight: bold;
    font-size: 18px;
}
.foot_price_ttl {
    text-align: center;
    margin-bottom: 20px !important;
}
#foot_price .foot_price_text {
    font-size: 15px;
}
@media only screen and (max-width: 960px) {
    #foot_price {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column;
        background-image: url(https://file003.shop-pro.jp/PA01469/987/images/back_beige.jpg);
        color: #000;
        font-family: "Noto Serif JP", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif;
        row-gap: 20px;
    }
    #foot_price .foot_price_item {
        width: 100%;
    }
    #foot_price .foot_price_item_center {
        width: 100%;
    }
    #foot_price .foot_price_text {
        font-size: 14px !important;
    }
    #foot_price h3 {
        font-size: 18px;
    }
}