html {
  font-size: 62.5%;
}

body {
  width: 100%;
  height: 100%;
  background-color: #fff;
  -webkit-text-size-adjust: 100%;
  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'ＭＳ Ｐゴシック', 'MS P Gothic', Osaka, Arial, Helvetica, Verdana, sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  font-weight: 500;
  color: #3F3C3C;
}

*,
*:before,
*:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }

img { width: auto; height: auto; max-width: 100%; border: none; vertical-align: top; }
picture { display: block; position: relative; width: 100%; }

/* utility
------------------------------------------------ */
.u-reset-btn { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; font-family: inherit; cursor: pointer; }
.u-reset-lists { margin: 0; padding: 0; list-style: none; }
.u-object-fit { width: 100%; height: 100%; max-width: inherit; object-fit: cover; font-family: 'object-fit: cover;'; }
.u-align-center { text-align: center; }

@media screen and (max-width: 768px) {
  .u-show-mobile { display: inherit !important; }
  .u-show-desktop { display: none !important; }
}

@media screen and (min-width: 769px) {
  .u-show-mobile { display: none !important; }
  .u-show-desktop { display: inherit !important; }
}

/* component
------------------------------------------------ */
/* lazy */
.lazy-scroll { opacity: 0; }
.lazy-scroll-done { opacity: 1; }

/* link */
.link-skipcontent { position: absolute; margin: -1px; width: 1px; height: 1px; overflow: hidden; }

/* title */
.title-1 { position: relative; margin: 0; text-align: center; }
.title-1 img { width: 47.6744186047%; }

/* btn */
.btn-1 { margin: 30px 0 0; }
.btn-1 > a,
.btn-1 > button { display: flex; justify-content: center; align-items: center; padding: 4px 0; width: 100%; min-height: 11.1627906977vw; background-color: #87B96B; border-radius: 17px; box-shadow: 0 1.86046511628vw 0 #77A35E; text-align: center; text-decoration: none; font-size: 3.68837209302vw; font-weight: 900; line-height: 1.2; color: #fff; }

@media screen and (min-width: 769px) {
  .btn-1 > a,
  .btn-1 > button { min-height: 48px; box-shadow: 0 8px 0 #77A35E; font-size: 1.586rem; }
}

/* container
------------------------------------------------ */
.l-container { position: relative; background-color: #B1CF88; }
.l-contents { position: relative; margin: 0 auto; background-color: #F8EDE1; z-index: 2; }
.l-main { position: relative; }

@media screen and (max-width: 768px) {
  .l-cover { display: none; }
}

@media screen and (min-width: 769px) {
  .l-contents { margin-left: 45.3125%; max-width: 430px; box-shadow: 0 0 13px rgba(37,30,28,0.8); }
  .l-cover { position: fixed; top: 0; width: 100%; height: 100%; z-index: 1;}
  .l-cover-block { position: absolute; top: 0; width: calc(50% - 200px); height: 100%; }
  .l-cover-block.is-right { right: 0; width: calc(100% - (430px + 45.3125%)); }
  .l-cover-block.is-left { left: 0; width: 45.3125%; }
  .l-cover-logo { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); aspect-ratio: 1 / 0.8775051721; margin: 0; width: 51.167605178%; text-indent: -9999px; white-space: nowrap; overflow: hidden; }
  .l-cover-logo::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(../img/share/logo.svg) no-repeat center center; background-size: 100% 100%; }
  .l-cover-introduce { display: flex; flex-flow: column; justify-content: center; align-items: center; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); aspect-ratio: 1 / 1; width: 68.0459770115%; }
  .l-cover-introduce::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: #88BA6B; border-radius: 50%; z-index: -1; }
  .l-cover-introduce__title { position: relative; aspect-ratio: 1 / 0.259342185545; margin: 0 0 2.70833333333vw; width: 52.7124324324%; text-indent: -9999px; overflow: hidden; }
  .l-cover-introduce__title::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(../img/share/cover_introduce_title.svg) no-repeat center center; background-size: 100% 100%; }
  .l-cover-introduce__text { margin: 0 8.5%; text-align: center; font-size: 0.72916666666vw; font-weight: 700; line-height: 1.92857142857; color: #fff; }
  .l-cover-introduce i { position: absolute; background-repeat: no-repeat; background-position: center center; background-size: 100% 100%; }
  .l-cover-introduce i:nth-of-type(1) { top: 3.37837837838%; left: -3.04054054054%; aspect-ratio: 1 / 1; width: 24.3243243243%; background-image: url(../img/share/cover_introduce_photo1.png); }
  .l-cover-introduce i:nth-of-type(2) { top: 71.7905405405%; left: 77.3648648649%; aspect-ratio: 1 / 1.34375; width: 27.027027027%; background-image: url(../img/share/cover_introduce_photo2.png); }
}

/* top page
------------------------------------------------ */
/* visual */
.top-visual { position: relative; padding: 34.8837209302vw 0 38px; background-color: #87B96B; overflow: hidden; }
.top-visual::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(../img/top/visual_deco1.svg) no-repeat left top; background-size: 100% auto; z-index: 1; }
.top-visual-main { position: relative; margin: 0 auto; width: 79.0697674419%; aspect-ratio: 1 / 1.42145470588; background: url(../img/top/visual_main_bg.svg) no-repeat center top; background-size: 100% 100%; z-index: 2; }
.top-visual-logo { position: absolute; top: 30.6231437306%; left: 50%; transform: translateX(-50%); margin: 0; width: 77.9193529412%; z-index: 2; }
.top-visual-pics { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.top-visual-pics > span { position: absolute; }
.top-visual-pics > span:nth-of-type(1) { top: 6.62525879917%; left: -2.05882352941%; width: 28.3823529412%; }
.top-visual-pics > span:nth-of-type(2) { top: -0.82815734989%; left: 71.1764705882%; width: 45.7352941176%; }
.top-visual-pics > span:nth-of-type(3) { top: 77.6397515528%; left: -14.7058823529%; width: 36.6176470588%; }
.top-visual-pics > span:nth-of-type(4) { top: 84.6790890269%; left: 75%; width: 35.5882352941%; }
.top-visual-area { margin: 38px auto 0; padding: 8px 0; width: 57.8291162791%; border-top: 2px solid #3F3C3C; border-bottom: 2px solid #3F3C3C; text-align: center; }
.top-visual-area img { width: 70.4279891195%; }

@media screen and (min-width: 769px) {
  .top-visual { padding-top: 150px; }
}

/* start */
.top-start { margin: 0 auto 44px; width: 86.0465116279%; }

/* about */
.top-about { position: relative; padding-bottom: 11.6279069767vw; }
.top-about::before,
.top-about::after { content: ''; pointer-events: none; position: absolute; }
.top-about::before { top: 4.18604651163vw; right: 5.58139534884%; width: 3.48837209302%; height: calc(100% - (4.18604651163vw + 11.6279069767vw)); background: url(../img/top/deco_rail1.png) repeat-y top center; background-size: 100% auto; }
.top-about::after { bottom: 0; left: 6.51162790698%; width: 87.9069767442%; height: 14.4186046512vw; background: url(../img/top/deco_rail2.png) no-repeat left top; background-size: 100% 100%; }
.top-about .title-1 { margin-bottom: 18px; }
.top-about .title-1::before,
.top-about .title-1::after { content: ''; position: absolute; top: 50%; transform: translateY(-50%); }
.top-about .title-1::before { right: 2.09302325581%; width: 10.6976744186vw; height: 10.6976744186vw; background-color: #fff; border: 3.02325581395vw solid #3F3C3C; border-radius: 50%; }
.top-about .title-1::after { left: 73.2558139535%; width: 14.4186046512vw; height: 7px; background-color: #3F3C3C; }
.top-about-copy { margin: 0; text-align: center; font-size: 5.3488372093vw; font-weight: 900; line-height: 1.47826086957; }
.top-about-text { margin: 15px auto 12px; width: 68.1885581395%; text-align: center; font-size: 3.48837209302vw; font-weight: 500; line-height: 1.75; }

@media screen and (min-width: 769px) {
  .top-about { padding-bottom: 50px; }
  .top-about::before { top: 18px; height: calc(100% - (18px + 50px)); }
  .top-about::after { height: 62px; }
  .top-about .title-1::before { width: 46px; height: 46px; border-width: 13px; }
  .top-about .title-1::after { width: 62px; }
  .top-about-copy { font-size: 2.3rem; }
  .top-about-text { font-size: 1.5rem; }
}

/* notice */
.top-notice { position: relative; padding: 3.48837209302vw 0 12.0930232558vw; }
.top-notice::before,
.top-notice::after { content: ''; pointer-events: none; position: absolute; }
.top-notice::before { top: 0; left: 6.51162790698%; width: 3.48837209302%; height: calc(100% - 12.0930232558vw); background: url(../img/top/deco_rail1.png) repeat-y top center; background-size: 100% auto; }
.top-notice::after { bottom: 0; left: 6.51162790698%; width: 87.9069767442%; height: 12.0930232558vw; background: url(../img/top/deco_rail3.png) no-repeat left top; background-size: 100% 100%; }
.top-notice .title-1 { margin-bottom: 20px; }
.top-notice .title-1::before,
.top-notice .title-1::after { content: ''; position: absolute; top: 50%; transform: translateY(-50%); }
.top-notice .title-1::before { left: 3.02325581395%; width: 10.6976744186vw; height: 10.6976744186vw; background-color: #fff; border: 3.02325581395vw solid #3F3C3C; border-radius: 50%; }
.top-notice .title-1::after { right: 73.2558139535%; width: 14.4186046512vw; height: 7px; background-color: #3F3C3C; }
.top-notice-content { margin-left: 14.4186046512%; padding: 24px 24px 54px; width: 71.6279069767%; background-color: #fff; border: 1.39534883721vw solid #3F3C3C; border-radius: 7.44186046512vw; }
.top-notice-block:not(:last-child) { margin-bottom: 24px; padding-bottom: 40px; border-bottom: 1px dashed #3F3C3C; }
.top-notice-title { margin: 0 0 14px; text-align: center; font-size: 5.3488372093vw; font-weight: 900; line-height: 1.47826086957; }
.top-notice-subtitle { margin: 32px 0 14px; position: relative; text-align: center; font-size: 3.02325581395vw; font-weight: 700; line-height: 1.2; }
.top-notice-subtitle::after { content: ''; position: absolute; top: 50%; left: 0; width: 100%; height: 1px; background-color: #3F3C3C; z-index: 1; }
.top-notice-subtitle > span { display: inline-block; position: relative; padding: 0 10px; background-color: #fff; vertical-align: top; z-index: 2; }
.top-notice-text { margin: 0; font-size: 2.79069767442vw; font-weight: 500; line-height: 2; }
.top-notice-note { margin: 18px 0 0; text-align: center; font-size: 2.55813953488vw; font-weight: 300; line-height: 1.6; }
.top-notice-store { display: none; margin-top: -20px; }
.top-notice-store__lists { padding: 40px 10px 20px; background-color: #B1CF88; border-radius: 0 0 17px 17px; }
.top-notice-store__lists__item { font-size: 2.79069767442vw; font-weight: 700; line-height: 1.4; }
.top-notice-store__lists__item:not(:last-child) { border-bottom: 1px solid #fff; }
.top-notice-store__lists__item > a { display: block; position: relative; padding: 8px 0 8px 28px; text-decoration: none; color: #3F3C3C; }
.top-notice-store__lists__item > a::before { content: ''; position: absolute; top: 50%; left: 6px; transform: translateY(-50%); width: 14px; height: 14px; background-color: #fff; border: 4px solid #3F3C3C; border-radius: 50%; }

@media screen and (min-width: 769px) {
  .top-notice { padding: 15px 0 52px; }
  .top-notice::before { height: calc(100% - 52px); }
  .top-notice::after { height: 52px; }
  .top-notice .title-1::before { width: 46px; height: 46px; border-width: 13px; }
  .top-notice .title-1::after { width: 62px; }
  .top-notice-content { border-width: 6px; border-radius: 32px; }
  .top-notice-title { font-size: 2.3rem; }
  .top-notice-subtitle { font-size: 1.3rem; }
  .top-notice-text { font-size: 1.2rem; }
  .top-notice-note { font-size: 1.1rem; }
  .top-notice-store__lists__item { font-size: 1.2rem; }
}

/* item */
.top-item { position: relative; padding: 79.5348837209vw 0 106px; background-color: #87B96B; }
.top-item::before,
.top-item::after { content: ''; pointer-events: none; position: absolute; }
.top-item::before { top: 0; right: 6.04651162791%; width: 3.48837209302%; height: 18.6046511628vw; background: url(../img/top/deco_rail1.png) repeat-y top center; background-size: 100% auto; z-index: 2; }
.top-item::after { top: 0; left: 0; width: 100%; height: 100%; background: url(../img/top/item_deco1.svg) no-repeat left top; background-size: 100% auto; z-index: 1; }
.top-item .title-1 { position: absolute; top: 9.76744186047vw; left: 0; width: 100%; z-index: 3; }
.top-item .title-1::before,
.top-item .title-1::after { content: ''; position: absolute; top: 50%; transform: translateY(-50%); }
.top-item .title-1::before { right: 2.32558139535%; width: 10.6976744186vw; height: 10.6976744186vw; background-color: #fff; border: 3.02325581395vw solid #3F3C3C; border-radius: 50%; }
.top-item .title-1::after { left: 73.2558139535%; width: 14.4186046512vw; height: 7px; background-color: #3F3C3C; }
.top-item-slide + .top-item-slide { margin-top: 70px; }

.top-item-lists__item { padding: 15px 18px; background-color: #E7EFD3; border: 2px solid #fff; border-radius: 15px; }
.top-item-lists__photo { aspect-ratio: 1 / 1; margin-bottom: 12px; background-color: #fff; border-radius: 12px; overflow: hidden; }

.top-item-gallery { margin-bottom: 12px; }
.top-item-gallery .splide__track { aspect-ratio: 1 / 1; border-radius: 12px; background-color: #fff; overflow: hidden; }
.top-item-gallery__lists { height: 100%; }
.top-item-gallery__lists__item { aspect-ratio: 1 / 1; }
.top-item-gallery .splide__pagination { position: relative; bottom: auto; right: auto; left: auto; margin-top: 12px; padding: 0; }
.top-item-gallery .splide__pagination li { margin: 0 5px; }
.top-item-gallery .splide__pagination__page { margin: 0; width: 12px; height: 12px; background-color: #9D9D9D; opacity: 1; }
.top-item-gallery .splide__pagination__page.is-active { transform: scale(1); background-color: #585757; }

.top-item-lists__info { margin-top: 10px; text-align: center; }
.top-item-lists__title { margin: 0; font-size: 4.6511627907vw; font-weight: 700; line-height: 1.483125; color: #585757; }
.top-item-lists__price { margin: -2px 0 0; font-size: 7.44186046512vw; font-weight: 500; line-height: 1.2; }
.top-item-lists__tax { margin: 2px 0 0; font-size: 3.25581395349vw; font-weight: 700; line-height: 1.2; color: #585757; }

@media screen and (min-width: 769px) {
  .top-item { padding-top: 342px; }
  .top-item::before { height: 80px; }
  .top-item .title-1 { top: 42px; }
  .top-item .title-1::before { width: 46px; height: 46px; border-width: 13px; }
  .top-item .title-1::after { width: 62px; }
  .top-item-lists__title { font-size: 2rem; }
  .top-item-lists__price { font-size: 3.2rem; }
  .top-item-lists__tax { font-size: 1.4rem; }
}

/* footer
------------------------------------------------ */
.l-footer { position: relative; padding: 48px 0 8px; }
.l-footer-logo { margin: 0 auto; width: 48.182%; }
.l-footer-jreast { margin-top: 36px; text-align: center; }
.l-footer-jreast__note { margin: 0; font-size: 1.62790697674vw; font-weight: 700; line-height: 1.2; color: #585757; }
.l-footer-jreast__copyright { margin: 4px 0 0; font-family: Helvetica, 'Noto Sans JP', sans-serif; font-size: 2.79069767442vw; font-weight: 400; line-height: 1.2; color: #251E1C; }
.l-footer-sns { display: flex; justify-content: center; align-items: center; margin-top: 48px; }
.l-footer-sns__item:not(:first-child) { margin-left: 7.5%; }
.l-footer-sns__item > a { display: block; width: 100%; text-align: center; }
.l-footer-sns__item.is-sns-x { width: 9%; }
.l-footer-sns__item.is-sns-instagram { width: 9%; }
.l-footer-sns__item.is-sns-youtube { width: 11%; }
.l-footer-sns__item.is-sns-tiktok { margin-left: 6.25%; width: 8%; }
.l-footer-copyright { margin: 52px 0 0; text-align: center; font-family: Helvetica, sans-serif; font-size: 3vw; line-height: 1.75; }
.l-footer-copyright small { font-size: inherit; }

@media screen and (min-width: 769px) {
  .l-footer-jreast__note { font-size: 0.7rem; }
  .l-footer-jreast__copyright { font-size: 1.2rem; }
  .l-footer-copyright { font-size: 1.2rem; }
}