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

body { color: #64463c; background: #f5f5f5; font-size: 1.6vw; letter-spacing: .08em; line-height: 1.6; font-weight: 400; font-optical-sizing: auto; font-style: normal; font-family: 'Noto Sans JP', BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif; font-feature-settings: "palt"; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
@media screen and (max-width: 599px) { body { font-size: 3.2vw; } }

_:lang(x)::-ms-backdrop, .selector { font-family: "Segoe UI", Meiryo, sans-serif; }

.fnt-Pns6 { font-family: "Poppins", sans-serif; font-weight: 600; font-style: normal; letter-spacing: 0; }

.fnt-NSJ5 { font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; }

.fnt-NSJ7 { font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 700; font-style: normal; }

p { line-height: 1.8; }

img { border: 0; vertical-align: top; }

input, select { position: relative; top: 1px; }

table, th, td { border-collapse: collapse; border-spacing: 0; }

ul, li { list-style: none; }

a:link, a:visited { color: #64463c; text-decoration: none; transition: opacity 0.5s; }
a:hover, a:active { opacity: .6; }

#cover { width: 100%; height: 100%; position: fixed; background: #fff; top: 0; left: 0; z-index: 10000; }

#loader { opacity: 0; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; width: 300px; height: 250px; }
#loader img { width: 100%; height: auto; }
@media screen and (max-width: 599px) { #loader { width: 210px; height: 175px; } }

#wrapper { overflow: hidden; position: relative; }

#page-top { opacity: 0; position: fixed; bottom: 20px; right: 20px; z-index: 9000; width: 40px; pointer-events: none; }
#page-top img { width: 100%; height: auto; }
#page-top.fade { opacity: 1; transition: opacity .5s; pointer-events: auto; }

.dd599 { display: none; }
@media screen and (max-width: 599px) { .dd599 { display: block !important; } }

@media screen and (max-width: 599px) { .nn599 { display: none !important; } }

.fadeinS, .fadein1, .fadein2, .fadein3, .fadein4, .fadein5, .fadein6, .fadeinF { opacity: 0; transform: translateY(30px); transition: opacity 1s ease-in, transform 1s ease-out; }
.fadeinS.active, .fadein1.active, .fadein2.active, .fadein3.active, .fadein4.active, .fadein5.active, .fadein6.active, .fadeinF.active { opacity: 1; transform: translateY(0); }

#header { overflow: hidden; position: fixed; z-index: 900; display: flex; justify-content: space-between; align-items: center; width: 100%; padding: .6em 1.4em .4em; border-bottom-left-radius: .5em; border-bottom-right-radius: .5em; background: #fff; }
@media screen and (max-width: 599px) { #header { padding: 1.2em 4% 1em; border-bottom-left-radius: .8em; border-bottom-right-radius: .8em; } }
#header h2 { position: relative; width: 15vw; }
@media screen and (max-width: 599px) { #header h2 { width: 38vw; } }
#header h2 img { width: 100%; height: auto; }
#header nav .gMenu { position: relative; }
#header nav .gMenu ul { position: relative; display: flex; width: 100%; }
#header nav .gMenu ul li { padding-left: 1.4em; }
#header nav .gMenu ul li a { display: block; background: #ffa000; text-align: center; color: #fff; font-size: 60%; letter-spacing: -.01em; line-height: 1; padding: .9em 1.6em; border-radius: 2em; }
@media screen and (max-width: 599px) { #header nav .gMenu ul li a { font-size: 100%; } }

main { overflow: hidden; position: relative; }
main section { overflow: hidden; position: relative; }
main section#topMainSct { background: url("../img/top_main_pic.webp") no-repeat center top/100%; padding: 11.5em 5% 3em; }
@media screen and (max-width: 599px) { main section#topMainSct { background-image: url("../img/top_main_pic-sp.webp"); padding: 14.2em 5% 2em; } }
main section#topMainSct .copy { position: relative; display: block; width: 17em; margin: 0 0 1.8em 5%; }
@media screen and (max-width: 599px) { main section#topMainSct .copy { width: 19em; margin: 0 auto 1.5em; } }
main section#topMainSct .copy img { width: 100%; height: auto; }
main section#topMainSct h1 { position: relative; margin: 0 0 3em 0; width: 23em; }
@media screen and (max-width: 599px) { main section#topMainSct h1 { width: 90%; margin: 0 auto 22em; } }
main section#topMainSct h1 img { width: 100%; height: auto; }
main section#topMainSct .r-btn { position: relative; margin-left: 14%; }
@media screen and (max-width: 599px) { main section#topMainSct .r-btn { margin: 0; } }
main section#topMainSct .r-btn a { position: relative; display: block; text-align: center; width: 12vw; height: 12vw; padding-top: .8em; background: #fff; border-radius: 50%; box-shadow: 1px 1px 20px 1px rgba(0, 0, 0, 0.3); }
@media screen and (max-width: 599px) { main section#topMainSct .r-btn a { margin: 0 auto; width: 46vw; height: 46vw; padding-top: 1.2em; } }
main section#topMainSct .r-btn a img { position: relative; top: -3.8vw; display: block; width: 12vw; height: auto; margin: 0 auto -4vw; }
@media screen and (max-width: 599px) { main section#topMainSct .r-btn a img { top: -12vw; width: 43vw; margin: 0 auto -13vw; } }
main section#topMainSct .r-btn a p { display: block; color: #64463c; font-size: 60%; line-height: 1.4; letter-spacing: .03em; }
@media screen and (max-width: 599px) { main section#topMainSct .r-btn a p { font-size: 120%; } }
main section#topMainSct .r-btn a::after { content: ""; position: absolute; left: 50%; bottom: 1em; transform: translateX(-50%); width: 1em; height: 1em; background: url("../img/icn_arrow.svg") no-repeat center center/contain; }
@media screen and (max-width: 599px) { main section#topMainSct .r-btn a::after { width: 2em; height: 2em; bottom: 2em; } }
main section#topWhatisSct { padding: 7em 0 0; }
@media screen and (max-width: 599px) { main section#topWhatisSct { padding: 1em 0 0; } }
main section#topWhatisSct .head { display: block; width: 72%; margin: 0 auto .5em; }
@media screen and (max-width: 599px) { main section#topWhatisSct .head { width: 100%; margin: 0 auto 2.5em; } }
main section#topWhatisSct .head img { width: 100%; height: auto; }
main section#topWhatisSct .copyB { position: relative; display: flex; justify-content: space-between; width: 84%; margin: 0 auto 4em; }
@media screen and (max-width: 599px) { main section#topWhatisSct .copyB { display: block; width: 90%; margin: 0 auto 6em; } }
main section#topWhatisSct .copyB .copy1 { position: relative; display: block; line-height: 1; margin: 0 0 .5em 1.8em; }
@media screen and (max-width: 599px) { main section#topWhatisSct .copyB .copy1 { margin: 0 0 1em 0; } }
main section#topWhatisSct .copyB .copy1 span { display: inline-block; background: #fff; font-size: 150%; letter-spacing: .18em; padding: .2em; margin-bottom: .4em; }
@media screen and (max-width: 599px) { main section#topWhatisSct .copyB .copy1 span { font-size: 170%; letter-spacing: .1em; } }
main section#topWhatisSct .copyB .copy2 { width: 37vw; }
@media screen and (max-width: 599px) { main section#topWhatisSct .copyB .copy2 { position: relative; display: block; width: 98%; margin: 0 auto; } }
main section#topWhatisSct .copyB .copy2 span { display: block; margin-bottom: 1em; font-size: 75%; }
@media screen and (max-width: 599px) { main section#topWhatisSct .copyB .copy2 span { font-size: 125%; } }
main section#topWhatisSct .pointB { position: relative; }
main section#topWhatisSct .pointB .innerB { position: relative; display: flex; background: #64463c; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB { display: block; } }
main section#topWhatisSct .pointB .innerB:nth-child(1) { flex-direction: row-reverse; }
main section#topWhatisSct .pointB .innerB:nth-child(1) .txtB { background: #64463c url("../img/top_whatis_point1.svg") no-repeat 40% 2.5em/76%; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB:nth-child(1) .txtB { background-position: 45% 1em; background-size: 94%; } }
main section#topWhatisSct .pointB .innerB:nth-child(2) .txtB { background: #64463c url("../img/top_whatis_point2.svg") no-repeat 40% 2.5em/76%; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB:nth-child(2) .txtB { background-position: 45% 1em; background-size: 94%; } }
main section#topWhatisSct .pointB .innerB:nth-child(3) { flex-direction: row-reverse; }
main section#topWhatisSct .pointB .innerB:nth-child(3) .txtB { background: #64463c url("../img/top_whatis_point3.svg") no-repeat 40% 2.5em/76%; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB:nth-child(3) .txtB { background-position: 45% 1em; background-size: 94%; } }
main section#topWhatisSct .pointB .innerB .imgB { width: 50%; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB .imgB { width: 100%; } }
main section#topWhatisSct .pointB .innerB .imgB img { width: 100%; height: auto; }
main section#topWhatisSct .pointB .innerB .txtB { width: 50%; color: #fff; padding: 6.5em 8.5% 2em; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB .txtB { width: 100%; padding: 6.5em 5% 4em; } }
main section#topWhatisSct .pointB .innerB .txtB .ttl { display: block; font-size: 120%; line-height: 1.5; margin-bottom: .8em; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB .txtB .ttl { font-size: 160%; } }
main section#topWhatisSct .pointB .innerB .txtB .txt { font-size: 75%; }
@media screen and (max-width: 599px) { main section#topWhatisSct .pointB .innerB .txtB .txt { font-size: 120%; } }
main section#topBuySct { padding: 12em 0 0; background: #f5f0eb url("../img/top_buy_bg.webp") no-repeat right top/102.3%; }
@media screen and (max-width: 599px) { main section#topBuySct { padding: 43em 0 1em; background: #f5f0eb url("../img/top_buy_bg-sp.webp") no-repeat center top/100%; } }
main section#topBuySct .buyB { position: relative; width: 28%; text-align: center; margin: 0 0 5em 8%; }
@media screen and (max-width: 599px) { main section#topBuySct .buyB { width: 90%; margin: 0 auto 5em; } }
main section#topBuySct .buyB .itemP { display: block; width: 76%; margin: 0 auto .8em; }
main section#topBuySct .buyB .txt { display: inline-block; text-align: left; font-size: 65%; margin-bottom: 1.2em; }
@media screen and (max-width: 599px) { main section#topBuySct .buyB .txt { font-size: 125%; } }
main section#topBuySct .buyB .btn { position: relative; display: inline-block; margin-bottom: 1em; padding-top: 2em; background: url("../img/icn_tanuki.svg") no-repeat center top/3.6em; }
@media screen and (max-width: 599px) { main section#topBuySct .buyB .btn { margin-bottom: 2em; } }
main section#topBuySct .buyB .btn a { position: relative; z-index: 5; display: inline-block; background: #ffa000; color: #64463c; font-size: 80%; line-height: 1.4; padding: 1.2em 5em; border-radius: 3em; box-shadow: 2px 2px 15px 1px rgba(0, 0, 0, 0.2); }
@media screen and (max-width: 599px) { main section#topBuySct .buyB .btn a { display: block; font-size: 125%; line-height: 1.5; margin: 0 auto; } }
main section#topBuySct .buyB .btn a::after { position: absolute; content: ""; top: 50%; transform: translateY(-48%); right: 1.8em; width: 1.4em; height: 1em; background: url("../img/icn_arrow3.svg") no-repeat center center/contain; }
@media screen and (max-width: 599px) { main section#topBuySct .buyB .btn a::after { width: 1.8em; height: 1.4em; } }
main section#topSpecialSct { position: relative; padding: 4em 0 0; }
@media screen and (max-width: 599px) { main section#topSpecialSct { padding: 2em 0 0; } }
main section#topSpecialSct .ttlB { display: block; margin: 0 auto 2em; width: 10em; }
@media screen and (max-width: 599px) { main section#topSpecialSct .ttlB { margin: 0 auto 1.5em; } }
main section#topSpecialSct .ttlB img { width: 100%; height: auto; }
main section#topSpecialSct .inB { position: relative; display: flex; align-items: center; padding: 0 7% 5em; }
@media screen and (max-width: 599px) { main section#topSpecialSct .inB { display: block; padding: 0 0 1em; } }
main section#topSpecialSct .inB .picB { width: 55%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .inB .picB { width: 100%; } }
main section#topSpecialSct .inB .picB img { width: 100%; height: auto; }
main section#topSpecialSct .inB .txtB { width: 45%; padding-left: 5%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .inB .txtB { width: 100%; padding: 3em 5%; } }
main section#topSpecialSct .inB .txtB .logo { display: block; width: 17em; margin-bottom: .8em; }
@media screen and (max-width: 599px) { main section#topSpecialSct .inB .txtB .logo { width: 74%; margin: 0 auto 1.2em; } }
main section#topSpecialSct .inB .txtB .logo img { width: 100%; height: auto; }
main section#topSpecialSct .inB .txtB .ttl { display: block; font-size: 115%; line-height: 1.6; margin-bottom: 1.2em; }
@media screen and (max-width: 599px) { main section#topSpecialSct .inB .txtB .ttl { white-space: nowrap; font-size: 165%; text-align: center; margin-bottom: 1.4em; } }
main section#topSpecialSct .inB .txtB .txt { font-size: 70%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .inB .txtB .txt { font-size: 120%; } }
main section#topSpecialSct .pointB { position: relative; }
main section#topSpecialSct .pointB .innerB { position: relative; display: flex; align-items: center; background: #64463c; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB { display: block; } }
main section#topSpecialSct .pointB .innerB:first-child .txtB .ttl { font-size: 85%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB:first-child .txtB .ttl { font-size: 160%; } }
main section#topSpecialSct .pointB .innerB:first-child .txtB .txt { font-size: 60%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB:first-child .txtB .txt { font-size: 120%; } }
main section#topSpecialSct .pointB .innerB:nth-child(2n+1) { flex-direction: row-reverse; }
main section#topSpecialSct .pointB .innerB .imgB { width: 50%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB .imgB { width: 100%; } }
main section#topSpecialSct .pointB .innerB .imgB img { width: 100%; height: auto; }
main section#topSpecialSct .pointB .innerB .txtB { width: 50%; color: #fff; padding: 0 8.5%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB .txtB { width: 100%; padding: 5em 5%; } }
main section#topSpecialSct .pointB .innerB .txtB .ttl { display: block; font-size: 110%; line-height: 1.5; margin-bottom: .8em; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB .txtB .ttl { font-size: 160%; } }
main section#topSpecialSct .pointB .innerB .txtB .txt { font-size: 75%; }
@media screen and (max-width: 599px) { main section#topSpecialSct .pointB .innerB .txtB .txt { font-size: 120%; } }
main section#topRecommendSct { padding: 12em 0 0; background: #f5f0eb url("../img/top_buy_bg.webp") no-repeat right top/102.3%; }
@media screen and (max-width: 599px) { main section#topRecommendSct { padding: 43em 0 0; background: #f5f0eb url("../img/top_buy_bg-sp.webp") no-repeat center top/100%; } }
main section#topRecommendSct .buyB { position: relative; width: 28%; text-align: center; margin: 0 0 5em 8%; }
@media screen and (max-width: 599px) { main section#topRecommendSct .buyB { width: 90%; margin: 0 auto 5em; } }
main section#topRecommendSct .buyB .itemP { display: block; width: 76%; margin: 0 auto .8em; }
main section#topRecommendSct .buyB .txt { display: inline-block; text-align: left; font-size: 65%; margin-bottom: 1.2em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .buyB .txt { font-size: 125%; } }
main section#topRecommendSct .buyB .btn { position: relative; display: inline-block; margin-bottom: 1em; padding-top: 2em; background: url("../img/icn_tanuki.svg") no-repeat center top/3.6em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .buyB .btn { margin-bottom: 2em; } }
main section#topRecommendSct .buyB .btn a { position: relative; z-index: 5; display: inline-block; background: #ffa000; color: #64463c; font-size: 80%; line-height: 1.4; padding: 1.2em 5em; border-radius: 3em; box-shadow: 2px 2px 15px 1px rgba(0, 0, 0, 0.2); }
@media screen and (max-width: 599px) { main section#topRecommendSct .buyB .btn a { display: block; font-size: 125%; line-height: 1.5; margin: 0 auto; } }
main section#topRecommendSct .buyB .btn a::after { position: absolute; content: ""; top: 50%; transform: translateY(-48%); right: 1.8em; width: 1.4em; height: 1em; background: url("../img/icn_arrow3.svg") no-repeat center center/contain; }
@media screen and (max-width: 599px) { main section#topRecommendSct .buyB .btn a::after { width: 1.8em; height: 1.4em; } }
main section#topRecommendSct .recB { position: relative; z-index: 5; padding: 8em 0 1em; background: url("../img/top_recm_bg.webp") no-repeat center top/100%; height: 44em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB { padding: 12em 0 1em; background-image: url("../img/top_recm_bg-sp.webp"); height: 76em; } }
main section#topRecommendSct .recB h3 { display: block; text-align: center; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB h3 { margin-bottom: 1.4em; } }
main section#topRecommendSct .recB h3 small { display: block; font-size: 70%; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB h3 small { font-size: 120%; } }
main section#topRecommendSct .recB h3 span { display: block; font-size: 180%; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB h3 span { font-size: 220%; } }
main section#topRecommendSct .recB .itemSlider { position: relative; display: flex; justify-content: center; margin-bottom: .8em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .itemSlider { margin-bottom: 2em; } }
main section#topRecommendSct .recB .itemSlider li { width: 20%; padding: 1.8em .25em 2em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .itemSlider li { width: 74%; } }
main section#topRecommendSct .recB .itemSlider li .box { position: relative; background: #fff; padding: 1.8em 1em 1em; border-radius: .5em; box-shadow: 1px 1px 10px 1px rgba(229, 229, 229, 0.5); }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .itemSlider li .box { padding: 3.5em 2em 2em; } }
main section#topRecommendSct .recB .itemSlider li .box a { display: block; }
main section#topRecommendSct .recB .itemSlider li .box a .img { display: block; width: 90%; height: auto; margin: 0 auto 1em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .itemSlider li .box a .img { width: 88%; margin: 0 auto 3em; } }
main section#topRecommendSct .recB .itemSlider li .box a .name { font-size: 60%; line-height: 1.6; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .itemSlider li .box a .name { font-size: 110%; line-height: 1.8; letter-spacing: .08em; margin-bottom: .8em; } }
main section#topRecommendSct .recB .itemSlider li .box a .price { display: block; color: #808080; font-size: 80%; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .itemSlider li .box a .price { font-size: 140%; } }
main section#topRecommendSct .recB .itemSlider li .box a .price small { font-size: 70%; }
main section#topRecommendSct .recB .itemSlider li .box a .price span { font-size: 70%; background: #efefef; border-radius: 2em; padding: .2em 1em; }
main section#topRecommendSct .recB .btn2 { display: block; text-align: center; }
main section#topRecommendSct .recB .btn2 a { position: relative; display: inline-block; background: #fff; color: #64463c; font-size: 80%; line-height: 1.1; padding: 1.2em 4em; border-radius: 3em; box-shadow: 2px 2px 15px 1px rgba(0, 0, 0, 0.2); }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .btn2 a { display: block; font-size: 120%; line-height: 1.4; padding: .7em 0; width: 80%; margin: 0 auto; } }
main section#topRecommendSct .recB .btn2 a::after { position: absolute; content: ""; top: 50%; transform: translateY(-48%); right: 1.8em; width: 1em; height: 1em; background: url("../img/icn_arrow.svg") no-repeat center center/contain; }
@media screen and (max-width: 599px) { main section#topRecommendSct .recB .btn2 a::after { width: 1.8em; height: 1.4em; } }
main section#topRecommendSct .aboutB { position: relative; z-index: 1; top: -10.3em; margin-bottom: -10.3em; padding: 7.5em 0 4em; background: url("../img/top_about_bg.webp") no-repeat center top/cover; }
@media screen and (max-width: 599px) { main section#topRecommendSct .aboutB { padding: 8.5em 0 4em; background-image: url("../img/top_about_bg-sp.webp"); } }
main section#topRecommendSct .aboutB h3 { display: block; text-align: center; margin-bottom: 16em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .aboutB h3 { margin-bottom: 20em; } }
main section#topRecommendSct .aboutB h3 span { display: block; font-size: 180%; padding-right: .2em; margin-bottom: .6em; }
@media screen and (max-width: 599px) { main section#topRecommendSct .aboutB h3 span { font-size: 220%; margin-bottom: .5em; } }
main section#topRecommendSct .aboutB h3 .shop { display: block; width: 21vw; margin: 0 auto; }
@media screen and (max-width: 599px) { main section#topRecommendSct .aboutB h3 .shop { width: 52vw; } }
main section#topRecommendSct .aboutB h3 .shop img { width: 100%; height: auto; }
main section#topRecommendSct .aboutB .btn { position: relative; text-align: center; padding-right: .5em; }
main section#topRecommendSct .aboutB .btn a { display: inline-block; background: #fff; border-radius: 2em; color: #64463c; font-size: 70%; line-height: 1.1; padding: 1.2em 5.5em; box-shadow: 1px 1px 10px 1px rgba(0, 0, 0, 0.2); }
@media screen and (max-width: 599px) { main section#topRecommendSct .aboutB .btn a { font-size: 90%; padding: 2em 5.5em; border-radius: 3em; } }

#footer { overflow: hidden; position: relative; padding: 3em 0; }
#footer .cpr { text-align: center; font-size: 60%; }
