@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@media (max-width: 768px) {
  .disp_pc {
    display: none;
  }
}
@media (min-width: 769px) {
  .disp_pc {
    display: block;
  }
}

@media (max-width: 768px) {
  .disp_sp {
    display: block;
  }
}
@media (min-width: 769px) {
  .disp_sp {
    display: none;
  }
}

img {
  width: 100%;
  height: auto;
  max-width: inherit;
  max-height: inherit;
}

a {
  -webkit-tap-highlight-color: #ebf3eb;
}

a:active {
  color: #ebf3eb;
}

body {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.07em;
}
@media (min-width: 769px) {
  body #wrapper {
    max-width: inherit;
  }
}
body #wrapper #header {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media (max-width: 768px) {
  body #wrapper #header {
    width: 100%;
    height: 21.3333333333vw;
    padding: 0 5.3333333333vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header {
    padding: 45px 0;
    width: 206px;
    height: 100vh;
    position: fixed;
  }
}
body #wrapper #header .logo {
  height: auto;
}
@media (max-width: 768px) {
  body #wrapper #header .logo {
    width: 32.2666666667vw;
    height: 11.4666666667vw;
    margin: 0;
    top: 5vw;
    position: absolute;
  }
}
@media (max-width: 768px) {
  body #wrapper #header .logo h1.site-name {
    width: 32.2666666667vw;
    height: 11.4666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header .logo h1.site-name {
    width: 115px;
    height: 138px;
    margin: 0 auto;
    padding: 0;
  }
}
body #wrapper #header .logo h1.site-name a {
  max-height: inherit;
  width: 100%;
}
body #wrapper #header .logo h1.site-name a img {
  max-height: inherit;
}
@media (max-width: 768px) {
  body #wrapper #header .menubtn {
    background-color: transparent;
    width: auto;
    height: auto;
    line-height: 1;
    top: 4vw;
    right: 7vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header .menubtn {
    display: none;
  }
}
body #wrapper #header .menubtn #jq-open-btn {
  width: auto;
  height: auto;
  background-color: transparent;
}
body #wrapper #header .menubtn #jq-open-btn:before {
  color: #000;
  font-size: 21px;
}
body #wrapper #header .menubtn #jq-open-btn:hover {
  background-color: transparent;
}
body #wrapper #header ul.header-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (max-width: 768px) {
  body #wrapper #header ul.header-menu {
    position: absolute;
    width: 27vw;
    top: 8vw;
    right: 19vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header ul.header-menu {
    width: 115px;
    margin: 37px auto 0 auto;
  }
}
@media (max-width: 768px) {
  body #wrapper #header ul.header-menu li {
    height: 7vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header ul.header-menu li {
    width: 20px;
    height: auto;
  }
}
body #wrapper #header ul.header-menu li a {
  background-color: transparent;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  border: 0;
  display: block;
  text-align: center;
}
@media (max-width: 768px) {
  body #wrapper #header ul.header-menu li a {
    background-size: contain;
    background-position: center;
    width: 100%;
    height: 100%;
    line-height: 1;
  }
}
body #wrapper #header ul.header-menu li a:before {
  position: relative;
  color: #000;
  margin: 0;
}
@media (max-width: 768px) {
  body #wrapper #header ul.header-menu li a:before {
    top: 1px;
    font-size: 6.5vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header ul.header-menu li a:before {
    font-size: 18px;
  }
}
@media (max-width: 768px) {
  body #wrapper #header #global-nav {
    position: absolute;
    background-color: #fff;
    width: 100vw;
    height: calc(100vh - 21.3333333333vw);
    top: 21.3333333333vw;
    left: 0;
    padding: 19.3333333333vw 25.3333333333vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav {
    display: block;
    position: relative;
    width: 115px;
    margin: 0 auto;
  }
}
body #wrapper #header #global-nav .header-top {
  border: none;
  display: block;
  position: relative;
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav .header-top {
    margin-top: 10px;
    width: 100%;
    height: auto;
  }
}
body #wrapper #header #global-nav .header-top .search-area {
  background-color: transparent;
  padding: 0;
  width: auto;
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav .header-top .search-area {
    width: auto;
  }
}
body #wrapper #header #global-nav .header-top .search-area .searchform3 {
  background-color: #bdccd4;
}
body #wrapper #header #global-nav .header-top .search-area .searchform3 input[type=text] {
  position: relative;
  padding: 0 15px;
  left: 0;
}
body #wrapper #header #global-nav .header-top .search-area .searchform3 .sbtn3 {
  left: auto;
  right: 0;
}
body #wrapper #header #global-nav .header-top .search-area .searchform3 .sbtn3::after {
  content: "\e92b";
  font-family: "icomoon";
  color: #000;
  vertical-align: middle;
  position: absolute;
}
@media (max-width: 768px) {
  body #wrapper #header #global-nav .header-top .search-area .searchform3 .sbtn3::after {
    font-size: 4vw;
    top: 2vw;
    right: 3vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav .header-top .search-area .searchform3 .sbtn3::after {
    font-size: 10px;
    top: 10px;
    right: 10px;
  }
}
body #wrapper #header #global-nav ul.gnavi {
  border-top: 1px solid #000;
}
@media (max-width: 768px) {
  body #wrapper #header #global-nav ul.gnavi {
    margin-top: 12vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav ul.gnavi {
    margin-top: 10px;
    width: 100%;
  }
}
body #wrapper #header #global-nav ul.gnavi li a {
  display: block;
  border-bottom: 1px solid #999999;
  line-height: 1;
  text-align: center;
  width: 100%;
}
@media (max-width: 768px) {
  body #wrapper #header #global-nav ul.gnavi li a {
    font-size: 5.8666666667vw;
    padding: 0.85em 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav ul.gnavi li a {
    font-size: 14px;
    padding: 12px 0;
  }
}
body #wrapper #header #global-nav ul.sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0;
  padding: 0;
}
@media (max-width: 768px) {
  body #wrapper #header #global-nav ul.sns {
    margin: 11vw auto 0;
    width: 26vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav ul.sns {
    margin: 33px auto 0 auto;
    width: 63px;
  }
}
body #wrapper #header #global-nav ul.sns li {
  margin: 0;
  padding: 0;
}
body #wrapper #header #global-nav ul.sns li a {
  display: block;
  height: auto;
  line-height: 1;
  font-size: 0;
}
@media (max-width: 768px) {
  body #wrapper #header #global-nav ul.sns li a {
    width: 8.5vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #header #global-nav ul.sns li a {
    width: 20px;
  }
}
body #wrapper #header #global-nav .cat-menu {
  display: none;
}
body #wrapper #container {
  background-color: #ebf3eb;
}
@media (min-width: 769px) {
  body #wrapper #container {
    margin: 0 0 0 206px;
    width: calc(100% - 206px);
  }
}
@media (max-width: 768px) {
  body #wrapper #container #top-main {
    margin: 0;
  }
}
@media (max-width: 768px) {
  body #wrapper #container #top-main .swiper {
    width: 100%;
    height: 77.3333333333vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #top-main .swiper {
    width: 100%;
    height: 520px;
    margin-bottom: 50px;
  }
}
body #wrapper #container #top-main .swiper .swiper-wrapper {
  width: 100%;
  height: 100%;
}
body #wrapper #container #top-main .swiper .swiper-wrapper span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
}
body #wrapper #container #top-main .swiper .swiper-wrapper span img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: auto;
}
body #wrapper #container section {
  position: relative;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block {
    padding: 10vw 6.6666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block {
    padding: 0 5.859375vw 25px;
  }
}
body #wrapper #container section.section-block .section-head {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.07em;
  border: none;
  display: inline-block;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block .section-head {
    margin: 0 0 9.3333333333vw 0;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block .section-head {
    margin: 0 0 50px 0;
    padding: 0;
  }
}
body #wrapper #container section.section-block .section-head h2,
body #wrapper #container section.section-block .section-head .sub-title {
  color: #000;
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  border: none;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block .section-head h2 {
    font-size: 4.4vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block .section-head h2 {
    font-size: 25px;
  }
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block .section-head .sub-title {
    font-size: 2.6666666667vw;
    margin: 0 0 0 8vw;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block .section-head .sub-title {
    font-size: 14px;
    margin-left: 40px;
  }
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product {
    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;
    padding: 0;
  }
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li {
    margin: 0 0 6.6666666667vw 0;
    padding: 0;
    width: 40vw;
  }
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li .item-photo {
    max-width: inherit;
    margin: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block ul.list-product li .item-photo {
    margin-bottom: 15px;
  }
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li .item-photo img {
    max-width: inherit;
    width: 40vw;
    height: auto;
  }
}
body #wrapper #container section.section-block ul.list-product li .item-info {
  text-align: left;
}
body #wrapper #container section.section-block ul.list-product li .item-info .item-name,
body #wrapper #container section.section-block ul.list-product li .item-info .item-price {
  font-weight: 500;
  position: relative;
  text-align: left;
}
body #wrapper #container section.section-block ul.list-product li .item-info .item-name a {
  font-weight: 500;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-name a {
    font-size: 2.6666666667vw;
    line-height: 1.75;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-name a {
    font-size: 14px;
    line-height: 1.75;
  }
}
body #wrapper #container section.section-block ul.list-product li .item-info .item-price {
  font-weight: 500;
  position: relative;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-price {
    font-size: 2.6666666667vw;
    margin-top: 1.3333333333vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-price {
    font-size: 14px;
  }
}
body #wrapper #container section.section-block ul.list-product li .item-info .item-price:before {
  content: "";
  display: block;
  background-color: #000;
  position: relative;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-price:before {
    width: 2.4vw;
    height: 1px;
    margin-bottom: 1.3333333333vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-price:before {
    width: 18px;
    height: 2px;
    margin-bottom: 8px;
  }
}
body #wrapper #container section.section-block ul.list-product li .item-info .item-nonstock {
  background-color: transparent;
  margin: 0.5em 0 0 0;
  padding: 0;
  line-height: 1;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-nonstock {
    font-size: 2.6666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block ul.list-product li .item-info .item-nonstock {
    font-size: 12px;
  }
}
body #wrapper #container section.section-block.about {
  background-color: #bdd7bd;
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block.about {
    padding-top: 45px;
    padding-bottom: 45px;
  }
}
body #wrapper #container section.section-block.about .inner {
  padding: 0;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block.about .inner {
    margin: 0;
    padding: 0;
    width: auto;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block.about .inner {
    margin: 0;
    width: auto;
  }
}
body #wrapper #container section.section-block.about .inner p {
  color: #000;
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block.about .inner p {
    font-size: 2.6666666667vw;
    line-height: 2;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block.about .inner p {
    font-size: 14px;
    line-height: 2;
  }
}
@media (max-width: 768px) {
  body #wrapper #container section.section-block.about .inner .photo {
    width: 100%;
    margin-top: 10.6666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container section.section-block.about .inner .photo {
    position: absolute;
    width: 420px;
    top: 0;
    left: 490px;
  }
}
body #wrapper #container #secondary {
  margin: 0;
  padding: 0;
  border-top: none;
}
body #wrapper #container #secondary .left-block {
  display: none;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .right-block {
    margin: 0;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .right-block {
    padding-left: 0;
    padding-right: 0;
    width: 100%;
  }
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .right-block .right-block-inner {
    padding: 10vw 6.6666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .right-block .right-block-inner {
    padding: 45px 5.859375vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .right-block .right-block-inner.right-block-calendar {
    padding-top: 65px;
  }
}
body #wrapper #container #secondary .right-block .right-block-inner.right-block-guide {
  background-color: #bdd7bd;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .right-block .right-block-inner.right-block-guide {
    padding: 11.3333333333vw 10vw 6.6666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .right-block .right-block-inner.right-block-guide {
    padding-top: 40px;
    padding-bottom: 0;
  }
}
body #wrapper #container #secondary .secondary-head {
  padding: 0;
  text-align: left;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .secondary-head {
    margin: 0;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .secondary-head {
    margin-bottom: 45px;
  }
}
body #wrapper #container #secondary .secondary-head .title2,
body #wrapper #container #secondary .secondary-head .sub-title {
  color: #000;
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  border: none;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .secondary-head .title2 {
    font-size: 4.4vw;
    margin: 0 0 8vw 0;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .secondary-head .title2 {
    font-size: 25px;
  }
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .secondary-head .sub-title {
    font-size: 2.6666666667vw;
    margin-left: 8vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .secondary-head .sub-title {
    font-size: 14px;
    margin-left: 40px;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .block-in {
    width: 680px;
  }
}
body #wrapper #container #secondary .schedule-area2 {
  background-color: #fff;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .schedule-area2 {
    padding: 3.3333333333vw 2.6666666667vw;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary .schedule-area2 {
    margin-bottom: 0;
    padding: 15px;
    margin-right: 0;
    width: 50%;
  }
}
body #wrapper #container #secondary .schedule-area2 .months {
  padding: 0;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary .schedule-area2 .months {
    margin-bottom: 3.3333333333vw;
  }
}
body #wrapper #container #secondary .schedule-area2 .calendar table {
  width: 100%;
}
body #wrapper #container #secondary ul.list-event {
  border-top: none;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary ul.list-event {
    margin: 3.3333333333vw 0 0 0;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary ul.list-event {
    background-color: #fff;
    width: 680px;
  }
}
body #wrapper #container #secondary ul.guide-nav {
  padding: 0;
}
@media (max-width: 768px) {
  body #wrapper #container #secondary ul.guide-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #secondary ul.guide-nav {
    padding: 0;
  }
}
@media (max-width: 768px) {
  body #wrapper #container #secondary ul.guide-nav li {
    width: 50%;
    margin-top: 2.2vw;
  }
}
@media (max-width: 768px) {
  body #wrapper #container #secondary ul.guide-nav li a {
    font-size: 2.6666666667vw;
  }
}
@media (max-width: 768px) {
  body #wrapper #container #secondary ul.guide-nav li:first-child, body #wrapper #container #secondary ul.guide-nav li:nth-child(2) {
    margin-top: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper #container #item-detail .item-2column {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
body #wrapper footer {
  background-color: #bdd7bd;
  border-top: none;
}
@media (max-width: 768px) {
  body #wrapper footer {
    padding: 0 5.3333333333vw;
  }
}
@media (min-width: 769px) {
  body #wrapper footer {
    margin: 0 0 0 206px;
    padding: 35px 0;
    width: calc(100% - 206px);
    max-width: inherit;
  }
}
body #wrapper footer .inner {
  border-top: 1px solid #000;
  max-width: inherit;
}
@media (max-width: 768px) {
  body #wrapper footer .inner {
    margin: 0;
    padding: 0;
  }
}
@media (min-width: 769px) {
  body #wrapper footer .inner {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    margin: 0 5.859375vw;
    padding: 35px 0;
    text-align: right;
    width: auto;
  }
}
body #wrapper footer .inner .copyright {
  padding: 0;
}
@media (max-width: 768px) {
  body #wrapper footer .inner .copyright {
    font-size: 1.8666666667vw;
    padding: 4vw 0;
  }
}
@media (min-width: 769px) {
  body #wrapper footer .inner .copyright {
    font-size: 11px;
  }
}