/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

main {
    display: block
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace,monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b,strong {
    font-weight: bolder
}

code,kbd,samp {
    font-family: monospace,monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -0.25em
}

sup {
    top: -0.5em
}

img {
    border-style: none
}

button,input,optgroup,select,textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button,input {
    overflow: visible
}

button,select {
    text-transform: none
}

button,[type=button],[type=reset],[type=submit] {
    -webkit-appearance: button
}

button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring {
    outline: 1px dotted #000
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox],[type=radio] {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

template {
    display: none
}

[hidden] {
    display: none
}

*,*::before,*::after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit
}

html {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

body,button,input,select,optgroup,textarea {
    font-size: 1rem;
    line-height: 1.5
}

h1,h2,h3,h4,h5,h6 {
    clear: both
}

p {
    margin-bottom: 1.5em
}

dfn,cite,em,i {
    font-style: italic
}

blockquote {
    margin: 0 1.5em
}

address {
    margin: 0 0 1.5em
}

pre {
    background: #eee;
    font-family: "Courier 10 Pitch",courier,monospace;
    line-height: 1.75;
    margin-bottom: 1.6em;
    max-width: 100%;
    overflow: auto;
    padding: 1.6em
}

code,kbd,tt,var {
    font-family: monaco,consolas,"Andale Mono","DejaVu Sans Mono",monospace
}

abbr,acronym {
    border-bottom: 1px dotted #666;
    cursor: help
}

mark,ins {
    background: #fff9c0;
    text-decoration: none
}

big {
    font-size: 125%
}

body {
    background: #fff
}

hr {
    background-color: #ccc;
    border: 0;
    height: 1px;
    margin-bottom: 1.5em
}

ul,ol {
    margin: 0 0 1.5em 3em
}

ul {
    list-style: disc
}

ol {
    list-style: decimal
}

li>ul,li>ol {
    margin-bottom: 0
}

dt {
    font-weight: 700
}

dd {
    margin: 0 1.5em 1.5em
}

embed,iframe,object {
    max-width: 100%
}

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

figure {
    margin: 1em 0
}

table {
    margin: 0 0 1.5em;
    width: 100%
}

button,input[type=button],input[type=reset],input[type=submit] {
    border: 1px solid;
    border-color: #ccc #ccc #bbb;
    border-radius: 3px;
    background: #e6e6e6;
    color: rgba(0,0,0,.8);
    line-height: 1
}

button:hover,input[type=button]:hover,input[type=reset]:hover,input[type=submit]:hover {
    border-color: #ccc #bbb #aaa
}

button:active,button:focus,input[type=button]:active,input[type=button]:focus,input[type=reset]:active,input[type=reset]:focus,input[type=submit]:active,input[type=submit]:focus {
    border-color: #aaa #bbb #bbb
}

input[type=text],input[type=email],input[type=url],input[type=password],input[type=search],input[type=number],input[type=tel],input[type=range],input[type=date],input[type=month],input[type=week],input[type=time],input[type=datetime],input[type=datetime-local],input[type=color],textarea {
    color: #666;
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 3px;
    -webkit-appearance: none
}

input[type=text]:focus,input[type=email]:focus,input[type=url]:focus,input[type=password]:focus,input[type=search]:focus,input[type=number]:focus,input[type=tel]:focus,input[type=range]:focus,input[type=date]:focus,input[type=month]:focus,input[type=week]:focus,input[type=time]:focus,input[type=datetime]:focus,input[type=datetime-local]:focus,input[type=color]:focus,textarea:focus {
    color: #111
}

select {
    border: 1px solid #ccc
}

textarea {
    width: 100%
}

.main-navigation {
    display: block;
    width: 100%
}

.main-navigation ul {
    display: none;
    list-style: none;
    margin: 0;
    padding-left: 0
}

.main-navigation ul ul {
    -webkit-box-shadow: 0 3px 3px rgba(0,0,0,.2);
    box-shadow: 0 3px 3px rgba(0,0,0,.2);
    float: left;
    position: absolute;
    top: 100%;
    left: -999em;
    z-index: 99999
}

.main-navigation ul ul ul {
    left: -999em;
    top: 0
}

.main-navigation ul ul li:hover>ul,.main-navigation ul ul li.focus>ul {
    display: block;
    left: auto
}

.main-navigation ul ul a {
    width: 200px
}

.main-navigation ul li:hover>ul,.main-navigation ul li.focus>ul {
    left: auto
}

.main-navigation li {
    position: relative
}

.main-navigation a {
    display: block;
    text-decoration: none
}

.menu-toggle,.main-navigation.toggled ul {
    display: block
}

@media screen and (min-width: 37.5em) {
    .menu-toggle {
        display:none
    }

    .main-navigation ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.site-main .comment-navigation,.site-main .posts-navigation,.site-main .post-navigation {
    margin: 0 0 1.5em
}

.comment-navigation .nav-links,.posts-navigation .nav-links,.post-navigation .nav-links {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.comment-navigation .nav-previous,.posts-navigation .nav-previous,.post-navigation .nav-previous {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%
}

.comment-navigation .nav-next,.posts-navigation .nav-next,.post-navigation .nav-next {
    text-align: end;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%
}

.sticky {
    display: block
}

.updated:not(.published) {
    display: none
}

.page-links {
    clear: both;
    margin: 0 0 1.5em
}

.comment-content a {
    word-wrap: break-word
}

.bypostauthor {
    display: block
}

.widget {
    margin: 0 0 1.5em
}

.widget select {
    max-width: 100%
}

.page-content .wp-smiley,.entry-content .wp-smiley,.comment-content .wp-smiley {
    border: none;
    margin-bottom: 0;
    margin-top: 0;
    padding: 0
}

.custom-logo-link {
    display: inline-block
}

.wp-caption {
    margin-bottom: 1.5em;
    max-width: 100%
}

.wp-caption img[class*=wp-image-] {
    display: block;
    margin-left: auto;
    margin-right: auto
}

.wp-caption .wp-caption-text {
    margin: .8075em 0
}

.wp-caption-text {
    text-align: center
}

.infinite-scroll .posts-navigation,.infinite-scroll.neverending .site-footer {
    display: none
}

.infinity-end.neverending .site-footer {
    display: block
}

.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    width: 1px;
    word-wrap: normal !important
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    -webkit-box-shadow: 0 0 2px 2px rgba(0,0,0,.6);
    box-shadow: 0 0 2px 2px rgba(0,0,0,.6);
    clip: auto !important;
    -webkit-clip-path: none;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: .875rem;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000
}

#primary[tabindex="-1"]:focus {
    outline: 0
}

.alignleft {
    float: left;
    margin-right: 1.5em;
    margin-bottom: 1.5em
}

.alignright {
    float: right;
    margin-left: 1.5em;
    margin-bottom: 1.5em
}

.aligncenter {
    clear: both;
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5em
}

html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    vertical-align: baseline
}

img {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    vertical-align: bottom;
    background: transparent
}

article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {
    display: block
}

ol,ul {
    list-style: none
}

blockquote,q {
    quotes: none
}

blockquote:before,blockquote:after,q:before,q:after {
    content: "";
    content: none
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

caption,th,td {
    font-weight: normal;
    text-align: left
}

ol,ul {
    list-style: none
}

blockquote,q {
    quotes: none
}

:focus {
    outline: 0
}

a img {
    border: 0
}

img {
    max-width: 100%;
    vertical-align: bottom
}

article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {
    display: block
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    text-decoration: none
}

ins {
    text-decoration: none
}

.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden
}

.clearfix {
    display: inline-table;
    min-height: 1%
}

* html .clearfix {
    height: 1%
}

.clearfix {
    display: block
}

.clear {
    clear: both
}

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,object,iframe,pre,code,p,blockquote,form,fieldset,legend,table,th,td,caption,tbody,tfoot,thead,article,aside,figure,footer,header,hgroup,menu,nav,section,audio,video,canvas {
    margin: 0;
    padding: 0
}

article,aside,figure,figcaption,footer,h1,h2,h3,h4,h5,h6,header,hgroup,menu,nav,section {
    display: block
}

html,body {
    height: 100%;
    width: 100%
}

a {
    -webkit-font-smoothing: antialiased
}

a:link,a:visited {
    text-decoration: none
}

a:hover,a:active {
    text-decoration: none
}

li {
    list-style: none
}

fieldset {
    border: none
}

input,textarea,select,label {
    font-family: inherit;
    margin-bottom: 0;
    margin-top: 0;
    padding-bottom: 0;
    padding-top: 0;
    vertical-align: middle
}

textarea {
    overflow: auto
}

legend {
    display: none
}

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

object {
    outline: none;
    vertical-align: middle
}

em,strong {
    font-style: normal;
    font-weight: bold
}

abbr,acronym {
    border: none;
    font-variant: normal
}

.boxRight {
    float: right !important
}

#i18 {
    z-index: 2005;
    left: 10px;
    position: fixed;
    top: calc(var(--information-banner-height, 0px) + 10px)
}

#i18 .lang {
    float: left;
    margin: 0 5px 0 0;
    position: relative
}

#i18 .lang:before {
    background: url("https://thebase.in/img/shop/arrow.gif") no-repeat;
    background-size: 10px 7px;
    content: "";
    height: 7px;
    position: absolute;
    right: 13px;
    top: 12px;
    width: 10px
}

#i18 .currency {
    float: left;
    position: relative
}

#i18 .currency:before {
    background: url("https://thebase.in/img/shop/arrow.gif") no-repeat;
    background-size: 10px 7px;
    content: "";
    height: 7px;
    position: absolute;
    right: 13px;
    top: 12px;
    width: 10px
}

#i18 select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 2px;
    color: #000;
    cursor: pointer;
    font-family: inherit;
    line-height: 18px;
    min-width: inherit;
    padding: 5px 25px 5px 10px;
    vertical-align: middle
}

#privacy,#law {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-family: Arial,Helvetica,"Hiragino Kaku Gothic ProN","ヒラギノ角ゴ Pro W3","Meiryo",sans-serif;
    line-height: 1.6em;
    margin: 0 auto;
    padding: 0 40px 0;
    text-align: left;
    max-width: 960px
}

#privacy h2,#law h2 {
    font-size: 22px;
    font-weight: bold;
    margin: 20px 0 0;
    padding: 0 0 20px
}

#privacy h3,#privacy dt {
    font-weight: bold;
    margin: 15px 0 8px
}

#privacy .privacy_intro {
    margin: 0 0 20px
}

#law h3 {
    font-weight: bold;
    margin: 20px 0 5px
}

#law .atobaraiTerm {
    margin: 20px 0
}

#law .atobaraiTerm .atobaraiTerm__title {
    margin-bottom: 8px
}

#law .atobaraiTerm .atobaraiTerm__body {
    padding-left: 20px
}

#law .atobaraiTerm p {
    font-size: 100%;
    line-height: 1.5;
    margin: 0 0 10px
}

.itemCb #cboxPrevious {
    background: url("https://thebase.in/i/controls.png") no-repeat 0 0;
    bottom: 0;
    height: 20px;
    left: 0;
    overflow: visible;
    text-indent: -9999px;
    width: 20px
}

.itemCb #cboxNext {
    background: url("https://thebase.in/i/controls.png") no-repeat -22px 0;
    bottom: 0;
    height: 20px;
    left: 30px !important;
    overflow: visible;
    text-indent: -9999px;
    width: 20px
}

.itemCb #cboxClose {
    background: url("https://thebase.in/i/controls.png") no-repeat -52px 0;
    height: 20px;
    overflow: visible;
    text-indent: -9999px;
    width: 20px
}

.itemCb #cboxContent button {
    border: none
}

.itemCb:focus {
    outline: none
}

a.cboxElement:focus {
    outline: none
}

.clearfix {
    zoom:1}

.clearfix:after {
    clear: both;
    content: "";
    display: block
}

.show {
    display: block !important
}

.hide {
    display: none !important
}

.overlayBackground {
    background-color: rgba(0,0,0,.5);
    cursor: pointer;
    display: none;
    height: 100%;
    left: 0;
    overflow: hidden;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 9999
}

#baseMenu {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: fixed;
    right: 25px;
    top: calc(var(--information-banner-height, 0px) + 5px);
    z-index: 2002
}

#baseMenu>ul>li {
    float: left;
    list-style: none
}

#baseMenu>ul>li.base {
    margin: 0 10px 0 0
}

#baseMenu>ul>li a {
    background-color: #fff;
    -webkit-box-shadow: 0 1px 0 1px rgba(150,150,150,.4);
    box-shadow: 0 1px 0 1px rgba(150,150,150,.4);
    cursor: pointer;
    display: block;
    -webkit-font-smoothing: antialiased;
    padding: 5px 15px;
    text-decoration: none;
    -webkit-transition-duration: .2s;
    transition-duration: .2s
}

#baseMenu>ul>li a:hover {
    -webkit-box-shadow: 0 0 0 1px rgba(150,150,150,.2);
    box-shadow: 0 0 0 1px rgba(150,150,150,.2);
    padding: 6px 15px 4px
}

@font-face {
    font-family: "baseicon";
    font-style: normal;
    font-weight: normal;
    src: url("https://static.thebase.in/font/v1/baseicon.eot?317xhh");
    src: url("https://static.thebase.in/font/v1/baseicon.eot?317xhh#iefix") format("embedded-opentype"),url("https://static.thebase.in/font/v1/baseicon.ttf?317xhh") format("truetype"),url("https://static.thebase.in/font/v1/baseicon.woff?317xhh") format("woff"),url("https://static.thebase.in/font/v1/baseicon.svg?317xhh#baseicon") format("svg")
}

@font-face {
    font-family: "shopicon";
    font-style: normal;
    font-weight: normal;
    src: url("https://static.thebase.in/font/v1/shopicon.eot?317xhh");
    src: url("https://static.thebase.in/font/v1/shopicon.eot?317xhh#iefix") format("embedded-opentype"),url("https://static.thebase.in/font/v1/shopicon.ttf?317xhh") format("truetype"),url("https://static.thebase.in/font/v1/shopicon.woff?317xhh") format("woff"),url("https://static.thebase.in/font/v1/shopicon.svg?317xhh#baseicon") format("svg")
}

[class^=icon-],[class*=" icon-"] {
    font-family: "baseicon" !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    line-height: 1;
    speak: none;
    text-transform: none
}

.icon-cart:before {
    content: ""
}

.icon-search:before {
    content: ""
}

.icon-information:before {
    content: ""
}

.icon-tipi:before {
    content: ""
}

.icon-pin:before {
    content: ""
}

#reportBtn a.cboxElement button {
    cursor: pointer
}

#fixedHeader ul li {
    float: left
}

#fixedHeader li.topRightNavLi a {
    background-color: #fff;
    border-radius: 5px;
    -webkit-box-shadow: 0 1px 0 2px rgba(150,150,150,.4);
    box-shadow: 0 1px 0 2px rgba(150,150,150,.4);
    display: block;
    -webkit-font-smoothing: antialiased;
    margin: 1px 0 0;
    padding: 5px 15px;
    -webkit-transition-duration: .2s;
    transition-duration: .2s
}

#fixedHeader li.topRightNavLi a:hover {
    -webkit-box-shadow: 0 0 0 1px rgba(150,150,150,.2);
    box-shadow: 0 0 0 1px rgba(150,150,150,.2);
    padding: 6px 15px 4px
}

#fixedHeader li.topRightNavLi.base {
    margin: 0 10px 0 0
}

body.shop {
    line-height: 1.5;
    -webkit-text-size-adjust: none
}

body.shop .wrapper {
    margin: 0 auto 60px;
    padding: 0 10px
}

@media(min-width: 769px) {
    body.shop .wrapper {
        width:960px
    }
}

body.shop #mainHeader {
    margin: 0 auto
}

body.shop #fixedHeader {
    padding: 5px 10px;
    position: fixed;
    right: 0;
    top: 0
}

body.shop #shopHeader h1 {
    display: block;
    text-align: center
}

body.shop #shopHeader h1 img {
    vertical-align: top
}

body.shop #shopHeader nav {
    font-weight: bold
}

body.shop #shopHeader nav ul {
    width: 100%
}

body.shop #shopHeader nav ul li {
    display: block
}

body.shop #shopHeader nav ul li.itemSearch {
    width: 100%
}

body.shop #shopHeader nav ul li.itemSearch form {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: inline-block;
    position: relative;
    width: 100%
}

body.shop #shopHeader nav ul li.itemSearch form input {
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-box-shadow: none;
    box-shadow: none;
    display: inline-block;
    margin: auto
}

body.shop #shopHeader nav ul li.itemSearch form .itemSearch__btn {
    display: block;
    width: auto;
    cursor: pointer
}

body.shop #shopHeader nav ul li a {
    display: block
}

@media(min-width: 481px) {
    body.shop #shopHeader nav ul {
        -ms-flex-wrap:nowrap;
        flex-wrap: nowrap;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }

    body.shop #shopHeader nav ul li {
        -webkit-box-flex: 1;
        -ms-flex: 1;
        flex: 1;
        width: auto
    }
}

.titleForSearchResult {
    font-size: 14px;
    font-weight: 400;
    margin: -20px auto 0;
    padding: 0 0 30px;
    text-align: center;
    width: 100%
}

@media(min-width: 769px) {
    .titleForSearchResult {
        width:960px
    }
}

body.shop #mainFooter {
    font-weight: bold;
    margin: 60px auto 100px
}

body.shop #mainFooter .footerMenu ul {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

body.shop #mainFooter .footerMenu ul li {
    width: 100%;
    margin-bottom: 16px;
    color: gray;
    font-weight: normal;
    line-height: 20px;
    text-align: center;
    vertical-align: middle
}

body.shop #mainFooter .footerMenu li.boxRight>div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

body.shop #mainFooter .footerMenu .twitter {
    margin: 0 0 0 8px
}

@media(min-width: 769px) {
    body.shop #mainFooter .footerMenu ul {
        -ms-flex-wrap:nowrap;
        flex-wrap: nowrap;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }

    body.shop #mainFooter .footerMenu ul li {
        width: auto;
        margin-right: 16px
    }

    body.shop #mainFooter .footerMenu li.boxRight {
        -webkit-box-flex: 1;
        -ms-flex: 1;
        flex: 1
    }

    body.shop #mainFooter .footerMenu li.boxRight>div {
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end
    }
}

.pinnedBlog {
    padding: 0 0 34px
}

.pinnedBlog .pinnedBlog_title {
    font-size: 12px;
    text-align: center
}

.pinnedBlog .pinnedBlog_title::before {
    content: "";
    font-family: "shopicon";
    padding: 0 5px 0 0
}

.pinnedBlog .pinnedBlog_title a {
    color: inherit;
    display: inline
}

.publish_date.blog_pinned::before {
    content: "";
    font-family: "shopicon";
    padding: 0 2px 0 0
}

body#shopTopPage .itemList {
    margin: 0 auto;
    overflow: hidden;
    width: calc(100% - 32px);
    padding: 0 16px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

body#shopTopPage .item {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    float: left;
    text-align: center;
    width: calc(50% - 4px);
    margin-right: 4px;
    margin-bottom: 8px
}

@media(min-width: 481px)and (max-width: 768px) {
    body#shopTopPage .item {
        width:calc(33% - 4px)
    }
}

@media(min-width: 769px) {
    body#shopTopPage .itemList {
        max-width:987px
    }

    body#shopTopPage .item {
        padding: 14px 0 0;
        margin: 0 18px 30px
    }

    body#shopTopPage .item .itemImg {
        height: 210px;
        line-height: 208px
    }

    body#shopTopPage .item .itemImg img {
        max-height: 206px;
        max-width: 206px
    }
}

body#shopTopPage .item .itemTitle {
    margin: 20px 0 5px;
    text-align: center
}

body#shopTopPage .item a {
    color: #4d4d4d
}

body#shopTopPage .item a .itemTitle h2 {
    display: block;
    font-size: 14px;
    font-weight: bold;
    margin: 2px auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
}

body#shopTopPage .item .itemImg {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    margin: auto;
    overflow: hidden;
    padding: 1px;
    vertical-align: middle
}

body#shopTopPage .item:hover .itemImg {
    border: 1px dotted #ed4242;
    padding: 0
}

body#shopTopPage .item:hover a {
    color: #ed4242
}

body#shopTopPage .item .itemImg a {
    display: block;
    position: relative
}

body#shopTopPage .item .itemImg a::before {
    content: "";
    display: block;
    padding-top: 100%
}

body#shopTopPage .item .itemImg img.image-resize {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain
}

body#shopTopPage .item .itemImg a .soldout_cover {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-color: rgba(255,255,255,.9);
    bottom: 0;
    filter: alpha(opacity=80);
    left: 0;
    opacity: .75;
    position: absolute;
    right: 0;
    top: 0;
    zoom:1}

body#shopTopPage .item .itemImg a .soldout_cover p {
    color: #ed4242;
    font-size: 22px;
    font-weight: bold;
    text-align: center
}

body#shopTopPage .item .itemDetail .itemPrice {
    font-size: 10px;
    letter-spacing: 1px;
    text-align: center
}

body#shopTopPage .item .itemDetail .discountPrice {
    color: #e75c5c;
    margin: 0
}

body#shopTopPage .item .itemDetail .discountPrice__ratio {
    border: 1px solid #e75c5c;
    display: inline-block;
    font-size: 10px;
    font-weight: bold;
    line-height: 18px;
    margin-right: 5px;
    padding: 0 5px
}

body#shopTopPage .item .itemDetail .discountPrice__calcPrice {
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: 1.8;
    white-space: nowrap
}

body#shopTopPage .item .comingSoon {
    color: #11beae;
    font-size: 14px;
    margin-top: 8px
}

body#shopTopPage .item .preOrder,body#shopTopPage .item .lottery,body#shopTopPage .item .takeout,body#shopTopPage .item .community {
    border: 1px solid #252525;
    border-radius: 2px;
    color: #252525;
    display: inline-block;
    font-size: 10px;
    font-weight: bold;
    padding: 2px 6px;
    margin-top: 6px
}

body#shopTopPage .item .community {
    background-color: #f2bb31;
    border: 1px solid #f2bb31;
    color: #fff
}

body#shopDetailPage #mainContent {
    background-color: #fff;
    margin-bottom: 50px
}

body#shopDetailPage .itemImg {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: calc(100vw - 80px)
}

body#shopDetailPage .itemImgSlide {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1
}

body#shopDetailPage #slideImg .imgBox {
    border-radius: 10px;
    text-align: center
}

body#shopDetailPage #slideImg .imgBox img {
    width: 100%;
    vertical-align: middle
}

body#shopDetailPage #slideImg .imgBox img.label_image {
    width: auto
}

body#shopDetailPage #slideImgPager {
    float: left;
    overflow: hidden;
    padding: 0 0 0 10px;
    width: 64px
}

body#shopDetailPage #slideImgPager li+li {
    margin-top: 10px
}

body#shopDetailPage #slideImgPager .smallImgBox {
    height: 64px;
    line-height: 64px;
    text-align: center;
    width: 64px
}

body#shopDetailPage #slideImgPager .smallImgBox img {
    max-height: 64px;
    max-width: 64px;
    vertical-align: middle
}

body#shopDetailPage #slideImgPager .mCSB_inside>.mCSB_container {
    margin: 0
}

body#shopDetailPage #mainContent .purchase {
    border-bottom: dotted 1px #000;
    border-top: dotted 1px #000;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

body#shopDetailPage header h1.itemTitle {
    color: #3c3c3c;
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 32px
}

body#shopDetailPage #purchase_form {
    margin-bottom: 35px
}

body#shopDetailPage #purchase_form select {
    cursor: pointer
}

body#shopDetailPage #purchase_form #purchaseSelect {
    margin: 0
}

body#shopDetailPage #purchase_form .purchaseElement {
    margin: 5px 0 15px;
    overflow: hidden
}

body#shopDetailPage #purchase_form input,body#shopDetailPage #purchase_form select {
    width: 100%;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    word-wrap: normal
}

body#shopDetailPage #purchase_form #itemSelect input::-webkit-input-placeholder {
    font-size: 14px;
    color: #ccc
}

body#shopDetailPage #purchase_form #itemSelect input::-moz-placeholder {
    font-size: 14px;
    color: #ccc
}

body#shopDetailPage #purchase_form #itemSelect input:-ms-input-placeholder {
    font-size: 14px;
    color: #ccc
}

body#shopDetailPage #purchase_form #itemSelect input::-ms-input-placeholder {
    font-size: 14px;
    color: #ccc
}

body#shopDetailPage #purchase_form #itemSelect input::placeholder {
    font-size: 14px;
    color: #ccc
}

body#shopDetailPage #purchase_form label {
    font-size: 14px;
    margin: 16px 0 8px 0;
    line-height: 1em;
    display: block
}

body#shopDetailPage #purchase_form .itemOption__caption {
    font-size: 12px;
    margin: 8px 0 8px 0;
    line-height: 1.5em;
    display: block
}

body#shopDetailPage #purchase_form .itemOption__bottomCaptionBlock {
    overflow: hidden
}

body#shopDetailPage #purchase_form .itemOption__caption--error {
    float: left;
    font-size: 12px;
    line-height: 1em;
    display: block;
    color: #f07f7f;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d
}

body#shopDetailPage #purchase_form .itemOption__count {
    float: right;
    font-size: 12px;
    line-height: 1em;
    display: block;
    color: #777
}

body#shopDetailPage #purchase_form .itemOption__count--error {
    color: #f07f7f
}

body#shopDetailPage #purchase_form #itemSelect .itemOption__input[data-dirty=true][data-has-error=true] {
    border: #f07f7f 1px solid
}

body#shopDetailPage #purchase_form #amountSelect {
    width: auto;
    max-width: 375px
}

body#shopDetailPage #purchase_form .purchaseElement label {
    font-size: 14px;
    margin-right: 10px
}

body#shopDetailPage .report {
    text-align: left
}

body#shopDetailPage .report a {
    color: #aaa;
    display: block;
    font-size: 11px;
    margin-right: 15px;
    padding-top: 3px;
    text-align: right
}

body#shopDetailPage .report a:hover {
    text-decoration: underline
}

body#shopDetailPage .itemPrice h2 {
    color: #262626;
    font-size: 24px;
    font-weight: normal;
    letter-spacing: 1px;
    margin: 30px 0;
    text-align: left
}

body#shopDetailPage .itemPrice .discountPrice__default {
    color: #666;
    display: inline-block;
    font-size: 16px;
    line-height: 20px;
    margin-right: 10px;
    text-decoration: line-through;
    vertical-align: top
}

body#shopDetailPage .itemPrice .discountPrice__ratio {
    border: 1px solid #e75c5c;
    color: #e75c5c;
    display: inline-block;
    font-size: 12px;
    font-weight: bold;
    line-height: 18px;
    padding: 0 5px;
    vertical-align: top
}

body#shopDetailPage .itemPrice .discountPrice__calcPrice {
    color: #e75c5c;
    display: block;
    font-weight: bold;
    line-height: 1.3;
    padding: 10px 0 0
}

body#shopDetailPage .purchase .itemPrice_soldout {
    margin-top: 25px
}

body#shopDetailPage .purchase .itemPrice_soldout h2 {
    display: block;
    margin: 0;
    text-decoration: line-through
}

body#shopDetailPage .purchase .itemPrice_soldout>span {
    color: #ed4242;
    display: block;
    font-size: 16px;
    margin-bottom: 20px
}

body#shopDetailPage .purchase .comingSoon {
    color: #11beae;
    font-size: 19px;
    margin: 0 0 20px
}

body#shopDetailPage .preOrder,body#shopDetailPage .lottery,body#shopDetailPage .takeout,body#shopDetailPage .community {
    margin: 16px 0
}

body#shopDetailPage .preOrder__label,body#shopDetailPage .lottery__label,body#shopDetailPage .takeout__label {
    border: 1px solid #252525;
    border-radius: 2px;
    color: #252525;
    display: inline-block;
    font-size: 12px;
    font-weight: bold;
    padding: 4px 6px 4px;
    margin: 0 0 4px 0
}

body#shopDetailPage .preOrder__data,body#shopDetailPage .lottery__data {
    font-size: 12px;
    color: #252525
}

body#shopDetailPage .takeout .takeout__data {
    font-size: 12px;
    margin-top: 4px;
    display: block
}

body#shopDetailPage .lottery>* {
    margin-bottom: 8px
}

body#shopDetailPage #itemAttention {
    color: #868686;
    font-size: 11px;
    line-height: 1.5em;
    margin-bottom: 25px
}

body#shopDetailPage #itemAttention .attention a {
    color: #868686
}

body#shopDetailPage #itemAttention .attention a:hover {
    text-decoration: underline
}

body#shopDetailPage #itemAttention .attention.deliveryShortestDay {
    border: 1px solid #11beae;
    border-radius: 2px;
    color: #11beae;
    display: inline-block;
    font-size: 10px;
    font-weight: bold;
    margin-bottom: 25px;
    padding: 5px;
    width: 100%;
    text-align: center
}

body#shopDetailPage #itemAttention .attention.free {
    font-weight: bold
}

body#shopDetailPage #itemAttention .attention.free .free__text {
    color: #11beae;
    font-weight: bold
}

body#shopDetailPage #itemAttention .takeout__text {
    color: #252525;
    cursor: pointer;
    font-weight: bold;
    margin: 0 3px;
    text-decoration: underline
}

body#shopDetailPage #itemAttention .attention.salesPeriod--term {
    background: #ceefeb;
    border: 1px solid #11beae;
    color: #11beae;
    font-size: 13px;
    font-weight: bold;
    line-height: 1.7;
    margin-bottom: 36px;
    padding: 10px
}

body#shopDetailPage #itemAttention .attention.salesPeriod--willStart {
    background: #ceefeb;
    border: 1px solid #11beae;
    color: #11beae;
    font-size: 13px;
    font-weight: bold;
    line-height: 1.7;
    margin-bottom: 30px;
    padding: 10px;
    text-align: center
}

body#shopDetailPage #itemAttention .attention.salesPeriod--finish {
    border: 1px solid #999;
    color: #999;
    font-size: 13px;
    font-weight: bold;
    line-height: 1.7;
    margin-bottom: 36px;
    padding: 10px;
    text-align: center
}

body#shopDetailPage .itemDescription {
    margin: 60px 7px 24px 0
}

body#shopDetailPage .itemDescription p {
    line-height: 24px
}

body.shop #embedded-tag {
    font-size: 14px;
    letter-spacing: 1px;
    line-height: 24px;
    padding: 20px 0 0
}

body#shopDetailPage #embedded-tag p {
    margin: 0 0 5px
}

body#shopDetailPage #embedded-tag textarea {
    border: 1px solid #e2e2e2;
    border-radius: 5px;
    color: #838383;
    padding: 5px;
    width: 100%
}

body#shopDetailPage #purchase_form .purchaseButton {
    margin: 30px 0 0;
    text-align: center
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn {
    background: #000;
    border: none;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #fff;
    cursor: pointer;
    display: block;
    font-size: 12px;
    font-weight: bold;
    outline: none;
    padding: 14px 0;
    text-align: center;
    text-decoration: none;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    width: 100%
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn.purchaseButton__btn--outOfStock {
    color: #fff;
    background: #888
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn:hover {
    cursor: pointer;
    opacity: .7
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn.purchaseButton__btn--comingSoonStay:disabled {
    cursor: not-allowed;
    opacity: 1
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn.purchaseButton__btn--comingSoonStay {
    background: #eee;
    color: #999;
    cursor: not-allowed;
    opacity: 1
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn.purchaseButton__btn--notApplying:disabled {
    cursor: not-allowed;
    opacity: 1
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn:disabled {
    background: #eee;
    color: #999;
    cursor: not-allowed;
    opacity: 1
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn--disabled {
    background: #eee;
    color: #999;
    cursor: not-allowed;
    opacity: 1
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn:disabled:hover {
    opacity: 1
}

body#shopDetailPage #purchase_form .purchaseButton .purchaseButton__btn--disabled:hover {
    opacity: 1
}

body#shopDetailPage .shareButtons {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

body#shopDetailPage .shareButtons>div {
    margin-right: 4px
}

@media(min-width: 769px) {
    body#shopDetailPage #mainContent {
        padding:80px 65px;
        width: 830px
    }

    body#shopDetailPage #mainContent .item {
        float: left;
        position: relative;
        width: 493px
    }

    body#shopDetailPage #mainContent .purchase {
        margin: 0 0 0 520px;
        width: 280px
    }

    body#shopDetailPage header h1.itemTitle {
        font-size: 27px;
        margin-bottom: 55px
    }

    body#shopDetailPage #mainContent .item .itemImg {
        height: 400px
    }

    body#shopDetailPage #mainContent .item .itemImgSlide {
        float: left;
        width: 400px
    }

    body#shopDetailPage #mainContent .item .bx-wrapper {
        float: left;
        width: 400px
    }

    body#shopDetailPage #slideImg .imgBox {
        border-radius: 10px;
        height: 400px;
        line-height: 400px;
        text-align: center;
        width: 400px
    }

    body#shopDetailPage #slideImg .imgBox img {
        max-height: 400px;
        max-width: 400px;
        vertical-align: middle
    }

    body#shopDetailPage #slideImgPager {
        float: left;
        height: 400px;
        overflow: hidden;
        padding: 0 0 0 10px;
        width: 83px
    }
}

#widget {
    margin: 0 !important
}

#twitter-widget-0 {
    width: 75px
}

#twitter-widget-1 {
    width: 75px
}

body.shop #mainFooter .footerMenu li .fb-like {
    margin-top: -5px
}

.main {
    height: auto;
    margin: 0 auto;
    text-align: left;
    max-width: 960px
}

.main #about {
    margin: 0 auto;
    padding: 85px 0;
    max-width: 820px
}

.main #about h2 {
    font-size: 22px;
    letter-spacing: 3px;
    margin-bottom: 24px;
    text-align: left;
    text-transform: uppercase
}

@media(min-width: 769px) {
    .main #about h2 {
        font-size:30px;
        margin-bottom: 60px
    }
}

.main #about h3 {
    font-size: 28px
}

.main #about p {
    line-height: 1.6em
}

.main #about .social {
    margin: 40px 0 0;
    text-align: center;
    width: 100%
}

.main #about .social>ul {
    display: inline-block
}

.main #about .social ul li {
    float: left;
    margin-right: 15px
}

.main #about .social ul li:last-child {
    margin-right: 0
}

body.shop #mainFooter .footerMenu ul .social_btn {
    float: right;
    width: 215px
}

body.shop #mainFooter .footerMenu ul .social_btn li {
    margin: 0
}

body.shop #mainFooter .footerMenu ul .social_btn li.twitter {
    margin: -5px 0 0 0
}

.inquirySection {
    padding: 60px
}

.inquirySection h1 {
    color: #1a1a1a;
    font-size: 35px;
    letter-spacing: 3px;
    line-height: 35px;
    margin: 0 0 20px;
    text-align: left;
    text-transform: uppercase
}

.inquirySection p {
    font-size: 13px;
    line-height: 13px;
    text-align: left
}

.inquirySection form {
    width: 100%
}

@media(min-width: 769px) {
    .inquirySection form {
        margin:40px auto 0
    }
}

.inquirySection dl {
    text-align: left
}

.inquirySection dl dt {
    font-size: 16px;
    line-height: 16px;
    margin-bottom: 10px
}

.inquirySection dl dt span {
    color: #fb7c8a;
    font-size: 11px;
    line-height: 11px;
    display: inline-block
}

.inquirySection dl dd {
    margin-bottom: 20px
}

.inquirySection dl dd input {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-radius: 5px;
    padding: 5px 10px;
    width: 100%
}

.inquirySection dl dd textarea {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-radius: 5px;
    height: 135px;
    padding: 10px;
    width: 100%
}

@-moz-document url-prefix() {
    .inquirySection dl dd textarea {
        font-size: 11px
    }
}

.inquirySection .control-panel input#buttonLeave {
    border: none;
    color: #ccc;
    display: inherit;
    font-size: 12px;
    -webkit-font-smoothing: antialiased;
    font-weight: bold;
    letter-spacing: 5px;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease-in-out;
    transition-timing-function: ease-in-out;
    width: 290px
}

.inquirySection .control-panel input#buttonLeave:hover {
    cursor: pointer;
    -ms-filter: "alpha(opacity=70)";
    filter: alpha(opacity=70);
    -moz-opacity: .7;
    -khtml-opacity: .7;
    opacity: .7
}

#inquiryConfirmSection p {
    font-size: 13px;
    line-height: 13px
}

#inquiryConfirmSection dd {
    font-size: 12px;
    padding-left: 15px
}

#inquiryCompleteSection p {
    line-height: 1.4em;
    margin: 30px 0 0
}

#inquiryCompleteSection a {
    background-color: #000;
    color: #ccc;
    display: block;
    font-size: 12px;
    -webkit-font-smoothing: antialiased;
    font-weight: bold;
    letter-spacing: 5px;
    margin: 35px auto 0;
    padding: 14px 0;
    text-align: center;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease-in-out;
    transition-timing-function: ease-in-out;
    width: 290px
}

#inquiryCompleteSection a:hover {
    -ms-filter: "alpha(opacity=70)";
    filter: alpha(opacity=70);
    -moz-opacity: .7;
    -khtml-opacity: .7;
    opacity: .7
}

@media(max-width: 769px) {
    .main,#privacy,#law {
        margin:0 auto;
        padding: 0
    }

    .main #about,.main .inquirySection {
        width: 100%;
        padding: 0
    }
}

.template #category-menu {
    display: block
}

.template #category-menu span {
    cursor: pointer
}

.template #category-menu .category-list {
    display: none
}

.template #category-menu:hover .category-list {
    display: block;
    padding: 20px 0 0;
    position: absolute;
    z-index: 9999
}

.template #category-menu .category-list ul {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 5px;
    -webkit-box-shadow: 0 1px 3px #646464;
    box-shadow: 0 1px 3px #646464;
    cursor: pointer;
    margin: 0;
    max-width: 250px;
    padding: 10px
}

.template #category-menu .category-list ul li {
    border: none;
    float: none;
    height: auto;
    line-height: 26px;
    margin: 0;
    padding: 0;
    position: relative;
    text-align: left;
    width: 100%
}

.template #category-menu .category-list ul li a {
    display: inline;
    font-size: 12px;
    font-weight: normal;
    letter-spacing: 1px;
    line-height: 18px;
    white-space: nowrap
}

.template #category-menu .category-list ul li a:hover {
    border-bottom: none;
    text-decoration: underline
}

body.shop #shopHeader nav ul#appsItemCategoryTag {
    display: block
}

body.template #category-menu span {
    display: block;
    -webkit-font-smoothing: antialiased;
    padding: 10px;
    text-transform: uppercase;
    -webkit-transition-duration: .3s;
    transition-duration: .3s
}

body.template #category-menu:hover .category-list ul {
    border: inherit;
    border-radius: inherit;
    padding: 0
}

body.template #category-menu:hover .category-list ul li:before {
    padding-top: 15px
}

body.template #category-menu:hover .category-list ul li:after {
    padding-bottom: 15px
}

body.template #category-menu:hover .category-list ul li:hover {
    background-color: #b3b3b3;
    border-bottom: none;
    height: auto
}

body.template #category-menu:hover .category-list ul li a {
    display: block;
    margin: 0;
    max-width: 250px;
    overflow: hidden;
    padding: 10px 20px;
    text-overflow: ellipsis;
    white-space: nowrap
}

body.template #category-menu:hover .category-list ul li a:hover {
    text-decoration: none
}

.template #category-menu .appsItemCategoryTag_child .appsItemCategoryTag_lowerchild {
    display: none
}

@media(min-width: 769px) {
    .template #category-menu .appsItemCategoryTag_child .appsItemCategoryTag_lowerchild {
        display:none;
        left: 99%;
        position: absolute;
        top: 0;
        z-index: -1
    }

    .template #category-menu .appsItemCategoryTag_lowerchild:hover,.template #category-menu .appsItemCategoryTag_child:hover .appsItemCategoryTag_lowerchild {
        display: block
    }
}

.categoryTitle01 {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.1;
    margin: 38px 0 0;
    text-align: center
}

.childCategoryList01 {
    padding: 17px 0 0;
    text-align: center
}

.childCategoryList01_child {
    display: inline-block;
    font-size: 14px;
    letter-spacing: -0.4em
}

.childCategoryList01_link {
    display: inline-block;
    letter-spacing: normal;
    line-height: 2;
    padding: 0 15px
}

.childCategoryList01_link:hover {
    text-decoration: underline
}

body.template .etc-menu span {
    display: block;
    -webkit-font-smoothing: antialiased;
    text-transform: uppercase;
    -webkit-transition-duration: .3s;
    transition-duration: .3s
}

.product-img{
    width:50%;
}
.chumon-btn{
    width: 250px;
    background-color: red;
    height: 50px;
    text-align: center;
    line-height: 50px;
    color: white;
    font-weight: 700;
    border-radius: 50px;
    display: block;
    margin: 30px auto;
}
@media(max-width: 768px) {
    .main .communityMain {
        width:100%;
        padding: 0
    }
    .product-img{
        width:100%;
    }

    .main .communityMain #limitedItem,.main .communityMain #limitedUrl {
        width: 100%
    }

    .main .communityMain .communityItems,.main .communityMain #productsLimitedUrl {
        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
    }

    .main .communityMain .communityItems .communityItem {
        width: 31%;
        margin: 0 0 12px 0
    }

    .main .communityMain .communityItems .communityItem .communityImageContainer {
        position: relative;
        width: 100%;
        height: auto
    }

    .main .communityMain .communityItems .communityItem .communityImageContainer::before {
        content: "";
        display: block;
        padding-top: 100%
    }

    .main .communityMain .communityItems .communityItem .communityImageContainer .communityImageResize {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        -o-object-fit: contain;
        object-fit: contain
    }

    .main .communityMain #productsLimitedUrl .urlBox {
        width: 44%;
        margin: 0 0 12px 0 !important
    }
}

@media(max-width: 480px) {
    .main .communityMain .communityContent {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }

    .main .communityMain .communityContent .communityOverview,.main .communityMain .communityContent .communityNav {
        width: 100%;
        margin: 0
    }

    .main .communityMain .communityItems .communityItem {
        width: 49%
    }

    .main .communityMain #productsLimitedUrl .urlBox {
        width: 100%;
        margin: 0 0 12px 0 !important
    }
}

.hsp {
    display: none
}

@media screen and (min-width: 1024px) {
    .hsp {
        display:block
    }
}

@media screen and (min-width: 1024px) {
    .hpc {
        display:none
    }
}

@media screen and (min-width: 1024px) {
    .vsp {
        display:none
    }
}

.vpc {
    display: none
}

@media screen and (min-width: 1024px) {
    .vpc {
        display:block
    }
}

.vtb {
    display: none
}

@media screen and (min-width: 768px) {
    .vtb {
        display:block
    }
}

.m-0 {
    margin: 00px !important
}

.mb-0 {
    margin-bottom: 00px !important
}

.mt-0 {
    margin-top: 00px !important
}

.ml-0 {
    margin-left: 00px !important
}

.mr-0 {
    margin-right: 00px !important
}

.p-0 {
    padding: 00px !important
}

.pb-0 {
    padding-bottom: 00px !important
}

.pt-0 {
    padding-top: 00px !important
}

.pl-0 {
    padding-left: 00px !important
}

.pr-0 {
    padding-right: 00px !important
}

.m-1 {
    margin: 10px !important
}

.mb-1 {
    margin-bottom: 10px !important
}

.mt-1 {
    margin-top: 10px !important
}

.ml-1 {
    margin-left: 10px !important
}

.mr-1 {
    margin-right: 10px !important
}

.p-1 {
    padding: 10px !important
}

.pb-1 {
    padding-bottom: 10px !important
}

.pt-1 {
    padding-top: 10px !important
}

.pl-1 {
    padding-left: 10px !important
}

.pr-1 {
    padding-right: 10px !important
}

.m-2 {
    margin: 20px !important
}

.mb-2 {
    margin-bottom: 20px !important
}

.mt-2 {
    margin-top: 20px !important
}

.ml-2 {
    margin-left: 20px !important
}

.mr-2 {
    margin-right: 20px !important
}

.p-2 {
    padding: 20px !important
}

.pb-2 {
    padding-bottom: 20px !important
}

.pt-2 {
    padding-top: 20px !important
}

.pl-2 {
    padding-left: 20px !important
}

.pr-2 {
    padding-right: 20px !important
}

.m-3 {
    margin: 30px !important
}

.mb-3 {
    margin-bottom: 30px !important
}

.mt-3 {
    margin-top: 30px !important
}

.ml-3 {
    margin-left: 30px !important
}

.mr-3 {
    margin-right: 30px !important
}

.p-3 {
    padding: 30px !important
}

.pb-3 {
    padding-bottom: 30px !important
}

.pt-3 {
    padding-top: 30px !important
}

.pl-3 {
    padding-left: 30px !important
}

.pr-3 {
    padding-right: 30px !important
}

.m-4 {
    margin: 40px !important
}

.mb-4 {
    margin-bottom: 40px !important
}

.mt-4 {
    margin-top: 40px !important
}

.ml-4 {
    margin-left: 40px !important
}

.mr-4 {
    margin-right: 40px !important
}

.p-4 {
    padding: 40px !important
}

.pb-4 {
    padding-bottom: 40px !important
}

.pt-4 {
    padding-top: 40px !important
}

.pl-4 {
    padding-left: 40px !important
}

.pr-4 {
    padding-right: 40px !important
}

.m-5 {
    margin: 50px !important
}

.mb-5 {
    margin-bottom: 50px !important
}

.mt-5 {
    margin-top: 50px !important
}

.ml-5 {
    margin-left: 50px !important
}

.mr-5 {
    margin-right: 50px !important
}

.p-5 {
    padding: 50px !important
}

.pb-5 {
    padding-bottom: 50px !important
}

.pt-5 {
    padding-top: 50px !important
}

.pl-5 {
    padding-left: 50px !important
}

.pr-5 {
    padding-right: 50px !important
}

.m-6 {
    margin: 60px !important
}

.mb-6 {
    margin-bottom: 60px !important
}

.mt-6 {
    margin-top: 60px !important
}

.ml-6 {
    margin-left: 60px !important
}

.mr-6 {
    margin-right: 60px !important
}

.p-6 {
    padding: 60px !important
}

.pb-6 {
    padding-bottom: 60px !important
}

.pt-6 {
    padding-top: 60px !important
}

.pl-6 {
    padding-left: 60px !important
}

.pr-6 {
    padding-right: 60px !important
}

.m-7 {
    margin: 70px !important
}

.mb-7 {
    margin-bottom: 70px !important
}

.mt-7 {
    margin-top: 70px !important
}

.ml-7 {
    margin-left: 70px !important
}

.mr-7 {
    margin-right: 70px !important
}

.p-7 {
    padding: 70px !important
}

.pb-7 {
    padding-bottom: 70px !important
}

.pt-7 {
    padding-top: 70px !important
}

.pl-7 {
    padding-left: 70px !important
}

.pr-7 {
    padding-right: 70px !important
}

.m-8 {
    margin: 80px !important
}

.mb-8 {
    margin-bottom: 80px !important
}

.mt-8 {
    margin-top: 80px !important
}

.ml-8 {
    margin-left: 80px !important
}

.mr-8 {
    margin-right: 80px !important
}

.p-8 {
    padding: 80px !important
}

.pb-8 {
    padding-bottom: 80px !important
}

.pt-8 {
    padding-top: 80px !important
}

.pl-8 {
    padding-left: 80px !important
}

.pr-8 {
    padding-right: 80px !important
}

.m-9 {
    margin: 90px !important
}

.mb-9 {
    margin-bottom: 90px !important
}

.mt-9 {
    margin-top: 90px !important
}

.ml-9 {
    margin-left: 90px !important
}

.mr-9 {
    margin-right: 90px !important
}

.p-9 {
    padding: 90px !important
}

.pb-9 {
    padding-bottom: 90px !important
}

.pt-9 {
    padding-top: 90px !important
}

.pl-9 {
    padding-left: 90px !important
}

.pr-9 {
    padding-right: 90px !important
}

.m-10 {
    margin: 100px !important
}

.mb-10 {
    margin-bottom: 100px !important
}

.mt-10 {
    margin-top: 100px !important
}

.ml-10 {
    margin-left: 100px !important
}

.mr-10 {
    margin-right: 100px !important
}

.p-10 {
    padding: 100px !important
}

.pb-10 {
    padding-bottom: 100px !important
}

.pt-10 {
    padding-top: 100px !important
}

.pl-10 {
    padding-left: 100px !important
}

.pr-10 {
    padding-right: 100px !important
}

.m-11 {
    margin: 110px !important
}

.mb-11 {
    margin-bottom: 110px !important
}

.mt-11 {
    margin-top: 110px !important
}

.ml-11 {
    margin-left: 110px !important
}

.mr-11 {
    margin-right: 110px !important
}

.p-11 {
    padding: 110px !important
}

.pb-11 {
    padding-bottom: 110px !important
}

.pt-11 {
    padding-top: 110px !important
}

.pl-11 {
    padding-left: 110px !important
}

.pr-11 {
    padding-right: 110px !important
}

.m-12 {
    margin: 120px !important
}

.mb-12 {
    margin-bottom: 120px !important
}

.mt-12 {
    margin-top: 120px !important
}

.ml-12 {
    margin-left: 120px !important
}

.mr-12 {
    margin-right: 120px !important
}

.p-12 {
    padding: 120px !important
}

.pb-12 {
    padding-bottom: 120px !important
}

.pt-12 {
    padding-top: 120px !important
}

.pl-12 {
    padding-left: 120px !important
}

.pr-12 {
    padding-right: 120px !important
}

.m-13 {
    margin: 130px !important
}

.mb-13 {
    margin-bottom: 130px !important
}

.mt-13 {
    margin-top: 130px !important
}

.ml-13 {
    margin-left: 130px !important
}

.mr-13 {
    margin-right: 130px !important
}

.p-13 {
    padding: 130px !important
}

.pb-13 {
    padding-bottom: 130px !important
}

.pt-13 {
    padding-top: 130px !important
}

.pl-13 {
    padding-left: 130px !important
}

.pr-13 {
    padding-right: 130px !important
}

.m-14 {
    margin: 140px !important
}

.mb-14 {
    margin-bottom: 140px !important
}

.mt-14 {
    margin-top: 140px !important
}

.ml-14 {
    margin-left: 140px !important
}

.mr-14 {
    margin-right: 140px !important
}

.p-14 {
    padding: 140px !important
}

.pb-14 {
    padding-bottom: 140px !important
}

.pt-14 {
    padding-top: 140px !important
}

.pl-14 {
    padding-left: 140px !important
}

.pr-14 {
    padding-right: 140px !important
}

.m-15 {
    margin: 150px !important
}

.mb-15 {
    margin-bottom: 150px !important
}

.mt-15 {
    margin-top: 150px !important
}

.ml-15 {
    margin-left: 150px !important
}

.mr-15 {
    margin-right: 150px !important
}

.p-15 {
    padding: 150px !important
}

.pb-15 {
    padding-bottom: 150px !important
}

.pt-15 {
    padding-top: 150px !important
}

.pl-15 {
    padding-left: 150px !important
}

.pr-15 {
    padding-right: 150px !important
}

@media screen and (min-width: 1024px) {
    .pc-m-0 {
        margin:00px !important
    }

    .pc-mb-0 {
        margin-bottom: 00px !important
    }

    .pc-mt-0 {
        margin-top: 00px !important
    }

    .pc-ml-0 {
        margin-left: 00px !important
    }

    .pc-mr-0 {
        margin-right: 00px !important
    }

    .pc-p-0 {
        padding: 00px !important
    }

    .pc-pb-0 {
        padding-bottom: 00px !important
    }

    .pc-pt-0 {
        padding-top: 00px !important
    }

    .pc-pl-0 {
        padding-left: 00px !important
    }

    .pc-pr-0 {
        padding-right: 00px !important
    }

    .pc-m-1 {
        margin: 10px !important
    }

    .pc-mb-1 {
        margin-bottom: 10px !important
    }

    .pc-mt-1 {
        margin-top: 10px !important
    }

    .pc-ml-1 {
        margin-left: 10px !important
    }

    .pc-mr-1 {
        margin-right: 10px !important
    }

    .pc-p-1 {
        padding: 10px !important
    }

    .pc-pb-1 {
        padding-bottom: 10px !important
    }

    .pc-pt-1 {
        padding-top: 10px !important
    }

    .pc-pl-1 {
        padding-left: 10px !important
    }

    .pc-pr-1 {
        padding-right: 10px !important
    }

    .pc-m-2 {
        margin: 20px !important
    }

    .pc-mb-2 {
        margin-bottom: 20px !important
    }

    .pc-mt-2 {
        margin-top: 20px !important
    }

    .pc-ml-2 {
        margin-left: 20px !important
    }

    .pc-mr-2 {
        margin-right: 20px !important
    }

    .pc-p-2 {
        padding: 20px !important
    }

    .pc-pb-2 {
        padding-bottom: 20px !important
    }

    .pc-pt-2 {
        padding-top: 20px !important
    }

    .pc-pl-2 {
        padding-left: 20px !important
    }

    .pc-pr-2 {
        padding-right: 20px !important
    }

    .pc-m-3 {
        margin: 30px !important
    }

    .pc-mb-3 {
        margin-bottom: 30px !important
    }

    .pc-mt-3 {
        margin-top: 30px !important
    }

    .pc-ml-3 {
        margin-left: 30px !important
    }

    .pc-mr-3 {
        margin-right: 30px !important
    }

    .pc-p-3 {
        padding: 30px !important
    }

    .pc-pb-3 {
        padding-bottom: 30px !important
    }

    .pc-pt-3 {
        padding-top: 30px !important
    }

    .pc-pl-3 {
        padding-left: 30px !important
    }

    .pc-pr-3 {
        padding-right: 30px !important
    }

    .pc-m-4 {
        margin: 40px !important
    }

    .pc-mb-4 {
        margin-bottom: 40px !important
    }

    .pc-mt-4 {
        margin-top: 40px !important
    }

    .pc-ml-4 {
        margin-left: 40px !important
    }

    .pc-mr-4 {
        margin-right: 40px !important
    }

    .pc-p-4 {
        padding: 40px !important
    }

    .pc-pb-4 {
        padding-bottom: 40px !important
    }

    .pc-pt-4 {
        padding-top: 40px !important
    }

    .pc-pl-4 {
        padding-left: 40px !important
    }

    .pc-pr-4 {
        padding-right: 40px !important
    }

    .pc-m-5 {
        margin: 50px !important
    }

    .pc-mb-5 {
        margin-bottom: 50px !important
    }

    .pc-mt-5 {
        margin-top: 50px !important
    }

    .pc-ml-5 {
        margin-left: 50px !important
    }

    .pc-mr-5 {
        margin-right: 50px !important
    }

    .pc-p-5 {
        padding: 50px !important
    }

    .pc-pb-5 {
        padding-bottom: 50px !important
    }

    .pc-pt-5 {
        padding-top: 50px !important
    }

    .pc-pl-5 {
        padding-left: 50px !important
    }

    .pc-pr-5 {
        padding-right: 50px !important
    }

    .pc-m-6 {
        margin: 60px !important
    }

    .pc-mb-6 {
        margin-bottom: 60px !important
    }

    .pc-mt-6 {
        margin-top: 60px !important
    }

    .pc-ml-6 {
        margin-left: 60px !important
    }

    .pc-mr-6 {
        margin-right: 60px !important
    }

    .pc-p-6 {
        padding: 60px !important
    }

    .pc-pb-6 {
        padding-bottom: 60px !important
    }

    .pc-pt-6 {
        padding-top: 60px !important
    }

    .pc-pl-6 {
        padding-left: 60px !important
    }

    .pc-pr-6 {
        padding-right: 60px !important
    }

    .pc-m-7 {
        margin: 70px !important
    }

    .pc-mb-7 {
        margin-bottom: 70px !important
    }

    .pc-mt-7 {
        margin-top: 70px !important
    }

    .pc-ml-7 {
        margin-left: 70px !important
    }

    .pc-mr-7 {
        margin-right: 70px !important
    }

    .pc-p-7 {
        padding: 70px !important
    }

    .pc-pb-7 {
        padding-bottom: 70px !important
    }

    .pc-pt-7 {
        padding-top: 70px !important
    }

    .pc-pl-7 {
        padding-left: 70px !important
    }

    .pc-pr-7 {
        padding-right: 70px !important
    }

    .pc-m-8 {
        margin: 80px !important
    }

    .pc-mb-8 {
        margin-bottom: 80px !important
    }

    .pc-mt-8 {
        margin-top: 80px !important
    }

    .pc-ml-8 {
        margin-left: 80px !important
    }

    .pc-mr-8 {
        margin-right: 80px !important
    }

    .pc-p-8 {
        padding: 80px !important
    }

    .pc-pb-8 {
        padding-bottom: 80px !important
    }

    .pc-pt-8 {
        padding-top: 80px !important
    }

    .pc-pl-8 {
        padding-left: 80px !important
    }

    .pc-pr-8 {
        padding-right: 80px !important
    }

    .pc-m-9 {
        margin: 90px !important
    }

    .pc-mb-9 {
        margin-bottom: 90px !important
    }

    .pc-mt-9 {
        margin-top: 90px !important
    }

    .pc-ml-9 {
        margin-left: 90px !important
    }

    .pc-mr-9 {
        margin-right: 90px !important
    }

    .pc-p-9 {
        padding: 90px !important
    }

    .pc-pb-9 {
        padding-bottom: 90px !important
    }

    .pc-pt-9 {
        padding-top: 90px !important
    }

    .pc-pl-9 {
        padding-left: 90px !important
    }

    .pc-pr-9 {
        padding-right: 90px !important
    }

    .pc-m-10 {
        margin: 100px !important
    }

    .pc-mb-10 {
        margin-bottom: 100px !important
    }

    .pc-mt-10 {
        margin-top: 100px !important
    }

    .pc-ml-10 {
        margin-left: 100px !important
    }

    .pc-mr-10 {
        margin-right: 100px !important
    }

    .pc-p-10 {
        padding: 100px !important
    }

    .pc-pb-10 {
        padding-bottom: 100px !important
    }

    .pc-pt-10 {
        padding-top: 100px !important
    }

    .pc-pl-10 {
        padding-left: 100px !important
    }

    .pc-pr-10 {
        padding-right: 100px !important
    }
}

.text-center {
    text-align: center
}

* {
    margin: 0;
    padding: 0;
    -webkit-box-sizing: inherit;
    box-sizing: inherit
}

html {
    font-size: 62.5%
}

body {
    line-height: 1.75;
    letter-spacing: .1em;
    font-size: 1.3rem;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    font-family: "Noto Sans JP","ヒラギノ角ゴ Pro W3","Yu Gothic Medium","游ゴシック Medium",YuGothic,游ゴシック体,メイリオ,sans-serif;
    color: #3e3e3e;
    font-weight: 400;
    word-wrap: break-word
}

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

body {
    font-size: 14px;
    overflow-x: hidden
}

@media screen and (min-width: 1024px) {
    body {
        font-size:16px
    }
}

body.is-bodyColorDesignOption-dark {
    color: #fff
}

body.is-bodyFontDesignOption-mintyo {
    font-family: "Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru {
    font-family: "M PLUS Rounded 1c",sans-serif
}

body.is-testBg {
    background-color: #fff6f6
}

body p {
    letter-spacing: .05em;
    line-height: 1.75
}

@media screen and (min-width: 1024px) {
    body p {
        line-height:1.75
    }
}

a {
    color: #3e3e3e;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    word-wrap: break-word
}

a:hover {
    opacity: .8
}

.l-main {
    overflow: hidden;
    width: 100%
}

.site-wrapper {
    width: 100%;
    position: relative;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.site-wrapper.is-open {
    overflow: hidden
}

img[src$=".svg"],image[link$=".svg"] {
    max-width: 100%;
    height: auto
}

.ttl-main,.ttl-txt01,#contact-page .inquirySection h1,.top-about__desc p,.top-cate__ttl,.top-cate__desc,.top-faq__q,.top-faq__a,.top-shop__desc p,.about-subcontents__desc,.header__logo__subtxt,.footer-mailmagazine__ttl,.footer-mailmagazine__desc {
    white-space: pre-line;
    word-wrap: break-word
}

.l-wrapper {
    margin: auto;
    position: relative;
    width: 90%
}

@media screen and (min-width: 768px) {
    .l-wrapper {
        width:90%
    }
}

.l-wrapper.is-sp-100 {
    width: 100%
}

@media screen and (min-width: 768px) {
    .l-wrapper.is-sp-100 {
        width:90%
    }
}

.l-wrapper.is-sp-96 {
    width: 96%
}

@media screen and (min-width: 768px) {
    .l-wrapper.is-sp-96 {
        width:90%
    }
}

.l-wrapper.is-sp-90 {
    width: 90%
}

@media screen and (min-width: 768px) {
    .l-wrapper.is-sp-90 {
        width:90%
    }
}

.l-wrapper.is-sp-80 {
    width: 80%
}

@media screen and (min-width: 768px) {
    .l-wrapper.is-sp-80 {
        width:90%
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper01 {
        max-width:1050px
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper02 {
        max-width:1150px
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper03 {
        max-width:900px
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper04 {
        max-width:1150px
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper05 {
        max-width:1050px
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper06 {
        max-width:720px
    }
}

@media screen and (min-width: 768px) {
    .l-wrapper.wrapper07 {
        max-width:650px
    }
}

.l-sec01 {
    padding: 50px 0 70px
}

@media screen and (min-width: 768px) {
    .l-sec01 {
        padding:100px 0 100px
    }
}

.l-sec02 {
    padding: 40px 0 60px
}

@media screen and (min-width: 768px) {
    .l-sec02 {
        padding:65px 0 80px
    }
}

.l-sec03 {
    padding: 40px 0 5vw
}

@media screen and (min-width: 768px) {
    .l-sec03 {
        padding:65px 0 80px
    }
}

.l-sec04 {
    padding: 0 0 40px
}

@media screen and (min-width: 768px) {
    .l-sec04 {
        padding:0 0 80px
    }
}

.l-sec05 {
    padding: 0 0 0
}

@media screen and (min-width: 768px) {
    .l-sec05 {
        padding:20px 0 0
    }
}

.l-sec06 {
    padding: 80px 0 60px
}

@media screen and (min-width: 768px) {
    .l-sec06 {
        padding:100px 0 40px
    }
}

.l-sec07 {
    padding: 0 0 60px 0
}

@media screen and (min-width: 768px) {
    .l-sec07 {
        padding:0
    }
}

.l-sec08 {
    padding: 0 0 0
}

@media screen and (min-width: 768px) {
    .l-sec08 {
        padding:20px 0 0
    }
}

.l-sec09 {
    padding: 40px 0 90px
}

@media screen and (min-width: 768px) {
    .l-sec09 {
        padding:100px 0 120px
    }
}

.navBar {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background-color: #fff
}

.navBar__inner {
    display: block;
    width: 18px;
    height: 14px;
    position: relative;
    z-index: 1
}

.navBar__line {
    display: block;
    position: absolute;
    background: #5e5e5e;
    width: 18px;
    height: 2px
}

.navBar__line.line01 {
    -webkit-transition: all .4s;
    transition: all .4s
}

.navBar__line.line01.active {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg)
}

.navBar__line.line02 {
    -webkit-transition: all .4s;
    transition: all .4s;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

.navBar__line.line02.active {
    display: none
}

.navBar__line.line03 {
    -webkit-transition: all .4s;
    transition: all .4s;
    bottom: 0
}

.navBar__line.line03.active {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg)
}

.ttl-main {
    position: relative;
    text-align: center;
    margin-bottom: 30px;
    font-size: 20px;
    letter-spacing: .1em;
    font-family: "Lato","Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .ttl-main {
        font-size:24px;
        margin-bottom: 35px
    }
}

body.is-ttlFontDesignOption-mintyo .ttl-main {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .ttl-main {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.ttl-main.is-bigMb {
    margin-bottom: 40px
}

@media screen and (min-width: 768px) {
    .ttl-main.is-bigMb {
        margin-bottom:80px
    }
}

.ttl-main.has-mb {
    margin-bottom: 35px
}

@media screen and (min-width: 768px) {
    .ttl-main.has-mb {
        margin-bottom:45px
    }
}

.ttl-main.is-small {
    font-size: 18px
}

@media screen and (min-width: 768px) {
    .ttl-main.is-small {
        font-size:22px
    }
}

.ttl-main.has-paddingX {
    padding-left: 5%;
    padding-right: 5%
}

.ttl-txt01,#contact-page .inquirySection h1 {
    text-align: center;
    margin-bottom: 18px;
    font-size: 18px;
    letter-spacing: .1em;
    font-family: "Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .ttl-txt01,#contact-page .inquirySection h1 {
        font-size:22px;
        margin-bottom: 20px
    }
}

.ttl-txt01.is-small,#contact-page .inquirySection h1.is-small {
    font-size: 16px
}

@media screen and (min-width: 768px) {
    .ttl-txt01.is-small,#contact-page .inquirySection h1.is-small {
        font-size:18px
    }
}

body.is-ttlFontDesignOption-mintyo .ttl-txt01,body.is-ttlFontDesignOption-mintyo #contact-page .inquirySection h1,#contact-page .inquirySection body.is-ttlFontDesignOption-mintyo h1 {
    font-family: "Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .ttl-txt01,body.is-ttlFontDesignOption-maru #contact-page .inquirySection h1,#contact-page .inquirySection body.is-ttlFontDesignOption-maru h1 {
    font-family: "M PLUS Rounded 1c",sans-serif
}

.ttl-txt02 {
    text-align: center;
    margin-bottom: 20px;
    font-size: 20px;
    letter-spacing: .1em;
    font-family: "Lato","Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .ttl-txt02 {
        font-size:24px;
        margin-bottom: 30px
    }
}

body.is-bodyFontDesignOption-mintyo .ttl-txt02 {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .ttl-txt02 {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.ttl-txt02.is-bigMb {
    margin-bottom: 60px
}

@media screen and (min-width: 768px) {
    .ttl-txt02.is-bigMb {
        margin-bottom:80px
    }
}

.ttl-txt02.has-paddingX {
    padding-left: 5%;
    padding-right: 5%
}

.btn01,#blog-page .read_more a,.item-detail__form .purchaseButton button,.item-detail__form .purchaseButton .purchaseButton__btn,.btn02 {
    display: block;
    color: #fff;
    background-color: #252525;
    border: 1px solid rgba(255,255,255,.6);
    display: block;
    padding: 15px 20px;
    line-height: 1.2;
    font-size: 14px;
    font-weight: bold;
    text-align: center;
    position: relative;
    cursor: pointer;
    text-decoration: none !important;
    max-width: 80vw;
    margin: 0 auto;
    border-radius: 60px;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

@media screen and (min-width: 768px) {
    .btn01,#blog-page .read_more a,.item-detail__form .purchaseButton button,.item-detail__form .purchaseButton .purchaseButton__btn,.btn02 {
        font-size:16px;
        display: inline-block;
        padding: 20px 20px;
        margin: 0;
        min-width: 400px
    }
}

body.is-btnDesignOption-light .btn01,body.is-btnDesignOption-light #blog-page .read_more a,#blog-page .read_more body.is-btnDesignOption-light a,body.is-btnDesignOption-light .item-detail__form .purchaseButton button,.item-detail__form .purchaseButton body.is-btnDesignOption-light button,body.is-btnDesignOption-light .item-detail__form .purchaseButton .purchaseButton__btn,.item-detail__form .purchaseButton body.is-btnDesignOption-light .purchaseButton__btn,body.is-btnDesignOption-light .btn02 {
    color: #3e3e3e;
    background-color: #fff;
    border: 1px solid #3e3e3e
}

body.is-btnDesignOption-dark .btn01,body.is-btnDesignOption-dark #blog-page .read_more a,#blog-page .read_more body.is-btnDesignOption-dark a,body.is-btnDesignOption-dark .item-detail__form .purchaseButton button,.item-detail__form .purchaseButton body.is-btnDesignOption-dark button,body.is-btnDesignOption-dark .item-detail__form .purchaseButton .purchaseButton__btn,.item-detail__form .purchaseButton body.is-btnDesignOption-dark .purchaseButton__btn,body.is-btnDesignOption-dark .btn02 {
    color: #fff;
    background-color: #252525;
    border: 1px solid rgba(255,255,255,.6)
}

.btn01:hover,#blog-page .read_more a:hover,.item-detail__form .purchaseButton button:hover,.item-detail__form .purchaseButton .purchaseButton__btn:hover,.btn02:hover {
    opacity: .75
}

.btn02 {
    display: block;
    width: 100%;
    min-width: auto
}

@media screen and (min-width: 768px) {
    .btn02 {
        display:block
    }
}

.btn-field01 {
    margin-top: 30px;
    text-align: center
}

@media screen and (min-width: 768px) {
    .btn-field01 {
        margin-top:40px
    }
}

.bg-base {
    background-color: rgba(62,62,62,.05)
}

body.is-bgBaseColorDesignOption-gray10 .bg-base {
    background-color: rgba(62,62,62,.1)
}

body.is-bgBaseColorDesignOption-gray50 .bg-base {
    background-color: rgba(62,62,62,.5)
}

body.is-bgBaseColorDesignOption-white5 .bg-base {
    background-color: rgba(255,255,255,.05)
}

body.is-bgBaseColorDesignOption-white10 .bg-base {
    background-color: rgba(255,255,255,.1)
}

body.is-bgBaseColorDesignOption-white50 .bg-base {
    background-color: rgba(255,255,255,.5)
}

body.is-bgBaseColorDesignOption-none .bg-base {
    background-color: transparent
}

.bg-white {
    background-color: #fff;
    color: #3e3e3e
}

.l-header {
    position: relative;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 9999;
    -webkit-transition: all .3s ease-in;
    transition: all .3s ease-in;
    color: #3e3e3e
}

.header__inner {
    padding: 75px 5vw 30px
}

@media screen and (min-width: 768px) {
    .header__inner {
        padding:75px 5vw 25px
    }
}

.header__head {
    max-width: 1000px;
    margin: 0 auto;
    position: relative
}

.header__logo {
    position: relative;
    width: calc(100% - 120px);
    margin: 0 auto
}

@media screen and (min-width: 768px) {
    .header__logo {
        width:calc(100% - 360px)
    }
}

.header__logo__subtxt {
    text-align: center;
    font-size: 12px;
    margin-bottom: 1em;
    line-height: 1.3;
    font-family: "Lato","Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .header__logo__subtxt {
        font-size:14px
    }
}

body.is-bodyColorDesignOption-dark .header__logo__subtxt {
    color: #fff
}

body.is-ttlFontDesignOption-mintyo .header__logo__subtxt {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .header__logo__subtxt {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__logo__title {
    margin: 0;
    text-align: center;
    line-height: 1
}

.header__logo__link {
    display: inline-block;
    color: #3e3e3e
}

.header__logo__link .logoText {
    font-family: "Lato","Noto Sans JP",sans-serif;
    display: block;
    width: 100%;
    line-height: 1.2;
    font-size: 24px;
    max-width: 100%;
    padding-bottom: 5px;
    word-break: normal
}

@media screen and (min-width: 768px) {
    .header__logo__link .logoText {
        padding-bottom:0;
        font-size: 28px;
        width: 100%
    }
}

body.is-ttlFontDesignOption-mintyo .header__logo__link .logoText {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .header__logo__link .logoText {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__logo .logoImage {
    margin: auto 0;
    max-width: 80% !important;
    height: auto;
    max-height: 100px
}

@media screen and (min-width: 768px) {
    .header__logo .logoImage {
        max-height:180px
    }
}

.header__body {
    display: none
}

@media screen and (min-width: 768px) {
    .header__body {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center !important;
        -ms-flex-align: center !important;
        align-items: center !important;
        margin-top: 30px
    }
}

.header__gnav__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.header__gnav__item {
    margin: 0 10px;
    display: block
}

.header__gnav__link {
    color: #3e3e3e;
    font-weight: bold;
    margin: 5px;
    font-size: 14px;
    display: block;
    font-family: "Lato","Noto Sans JP",sans-serif
}

@media screen and (min-width: 1280px) {
    .header__gnav__link {
        font-size:16px
    }
}

body.is-bodyColorDesignOption-dark .header__gnav__link {
    color: #fff
}

body.is-bodyFontDesignOption-mintyo .header__gnav__link {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .header__gnav__link {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__gnav__cateNavBox {
    position: relative
}

.header__gnav__cateNav {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    min-width: 200px;
    max-width: 250px;
    height: 1px;
    top: 100%;
    left: 0;
    right: 0;
    margin: 0 auto;
    -webkit-transform: translate(0px, -10px);
    transform: translate(0px, -10px);
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.header__gnav__cateNav.is-active {
    visibility: visible;
    opacity: 1;
    top: 100%;
    -webkit-transform: translate(0px, 0px);
    transform: translate(0px, 0px);
    height: auto
}

.header__gnav__cateNav__wrapper {
    padding-top: 20px
}

.header__gnav__cateNav__whiteBox {
    background-color: #fff;
    color: #3e3e3e;
    border-radius: 5px;
    -webkit-box-shadow: 0px 2px 5px 0px rgba(0,0,0,.08);
    box-shadow: 0px 2px 5px 0px rgba(0,0,0,.08);
    padding: 20px;
    max-height: calc(100vh - 250px);
    overflow-y: auto
}

.header__gnav__cateNav__smallTtlBox {
    margin-bottom: 10px
}

.header__gnav__cateNav__smallTtl {
    font-size: 12px;
    opacity: .6;
    font-family: "Lato","Noto Sans JP",sans-serif;
    letter-spacing: .1em;
    line-height: 1.2
}

body.is-ttlFontDesignOption-mintyo .header__gnav__cateNav__smallTtl {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .header__gnav__cateNav__smallTtl {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__gnav__cateNav__otherNav__item {
    margin-bottom: 5px
}

.header__gnav__cateNav__otherNav__item:last-child {
    margin-bottom: 0
}

.header__gnav__cateNav__otherNav__link {
    font-size: 14px;
    color: #3e3e3e;
    font-weight: bold;
    display: block;
    margin-bottom: 8px
}

.header__gnav__cateNav .appsItemCategoryTag_child {
    font-family: "Noto Sans JP",sans-serif;
    margin-bottom: 5px
}

body.is-bodyFontDesignOption-mintyo .header__gnav__cateNav .appsItemCategoryTag_child {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .header__gnav__cateNav .appsItemCategoryTag_child {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__gnav__cateNav .appsItemCategoryTag_child a {
    font-size: 14px;
    color: #3e3e3e;
    font-weight: bold;
    display: block;
    margin-bottom: 8px
}

.header__gnav__cateNav .appsItemCategoryTag_lowerchild {
    font-family: "Noto Sans JP",sans-serif;
    margin-top: 5px;
    margin-left: 2px;
    padding-left: 10px;
    border-left: 1px solid rgba(62,62,62,.2)
}

body.is-bodyFontDesignOption-mintyo .header__gnav__cateNav .appsItemCategoryTag_lowerchild {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .header__gnav__cateNav .appsItemCategoryTag_lowerchild {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__gnav__cateNav .appsItemCategoryTag_lowerLink {
    font-size: 12px;
    color: #3e3e3e;
    font-weight: bold;
    line-height: 1.2
}

.header__rightBtns {
    position: absolute;
    right: 3vw;
    top: 10px
}

@media screen and (min-width: 1024px) {
    .header__rightBtns {
        right:calc((100% - 1000px)/2);
        top: 20px
    }
}

.header__rightBtns__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.header__rightBtns__item {
    margin-left: 10px
}

.header__rightBtns__item.is-pcOnly {
    display: none
}

@media screen and (min-width: 768px) {
    .header__rightBtns__item.is-pcOnly {
        display:block
    }
}

.header__rightBtns__icon {
    display: none
}

@media screen and (min-width: 768px) {
    .header__rightBtns__icon {
        position:relative;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        cursor: pointer;
        width: 38px;
        height: 38px;
        border-radius: 50%;
        background-color: #fff;
        cursor: pointer
    }
}

.header__rightBtns__icon img {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto
}

.header__rightBtns__itemSearch {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto 0;
    z-index: 99999;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    visibility: hidden;
    opacity: 0;
    width: 0
}

.header__rightBtns__itemSearch.is-active {
    visibility: visible;
    opacity: 1;
    width: 240px
}

.header__rightBtns__itemSearch__mask.is-active {
    width: 100vw;
    height: 150vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99998;
    background-color: rgba(0,0,0,.3);
    cursor: pointer
}

.header__rightBtns__itemSearch form.itemSearch__form {
    position: relative;
    height: 45px
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field {
    width: 100%;
    padding: 10px 20px 10px 40px;
    font-size: 14px;
    width: 100%;
    height: 45px;
    border-radius: 23px;
    border: 1px solid rgba(62,62,62,.2);
    line-height: normal
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    -webkit-transform: translate(0px, -2px);
    transform: translate(0px, -2px)
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-moz-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field:-ms-input-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-ms-input-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    -webkit-transform: translate(0px, -2px);
    transform: translate(0px, -2px)
}

body.is-ttlFontDesignOption-mintyo .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    font-family: "Lora","Noto Serif JP",serif;
    font-weight: 400
}

body.is-ttlFontDesignOption-mintyo .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-moz-placeholder {
    font-family: "Lora","Noto Serif JP",serif;
    font-weight: 400
}

body.is-ttlFontDesignOption-mintyo .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field:-ms-input-placeholder {
    font-family: "Lora","Noto Serif JP",serif;
    font-weight: 400
}

body.is-ttlFontDesignOption-mintyo .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-ms-input-placeholder {
    font-family: "Lora","Noto Serif JP",serif;
    font-weight: 400
}

body.is-ttlFontDesignOption-mintyo .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::placeholder {
    font-family: "Lora","Noto Serif JP",serif;
    font-weight: 400
}

body.is-ttlFontDesignOption-maru .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-moz-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field:-ms-input-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-ms-input-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__rightBtns__itemSearch form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    position: relative;
    top: .2em
}

.header__rightBtns__itemSearch form.itemSearch__form .itemSearch__btn {
    background-color: transparent;
    border: none !important;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 15px;
    margin: auto 0;
    width: 20px;
    height: 20px
}

.header__rightBtns__itemSearch form.itemSearch__form .itemSearch__btn img {
    width: 20px;
    height: auto
}

.header__leftBtns {
    position: absolute;
    left: 4vw;
    top: 18px
}

@media screen and (min-width: 1024px) {
    .header__leftBtns {
        left:calc((100% - 1000px)/2);
        top: 28px
    }
}

@media screen and (min-width: 768px) {
    .header__leftBtns__langage {
        padding-left:20px
    }
}

.header__navBar {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: 1
}

@media screen and (min-width: 768px) {
    .header__navBar {
        display:none
    }
}

.header__snav {
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    position: fixed;
    z-index: 99999;
    top: 0;
    right: 0;
    height: 100vh;
    width: 250px;
    -webkit-transform: translate(250px);
    transform: translate(250px)
}

@media screen and (min-width: 340px) {
    .header__snav {
        width:300px;
        -webkit-transform: translate(300px);
        transform: translate(300px)
    }
}

.header__snav.active {
    -webkit-transform: translate(0);
    transform: translate(0)
}

.header__snav__open {
    width: 100%;
    height: 100vh;
    position: relative;
    display: block;
    background-color: #fff;
    color: #3e3e3e;
    z-index: 3
}

.header__snav__wrapper {
    overflow-y: auto;
    width: 100%;
    height: 100%;
    padding-top: 30px
}

.header__snav__closeBtn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    position: absolute;
    z-index: 2;
    top: 10px;
    right: 3vw;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background-color: #fff
}

.header__snav__closeBtn__inner {
    display: block;
    width: 18px;
    height: 14px;
    position: relative;
    z-index: 1
}

.header__snav__closeBtn__line {
    display: block;
    position: absolute;
    background: #252525;
    width: 18px;
    height: 2px
}

.header__snav__closeBtn__line.line01 {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg)
}

.header__snav__closeBtn__line.line02 {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg)
}

.header__snav__navBox {
    position: relative;
    padding: 20px 25px 120px;
    min-height: 100%;
    z-index: 1
}

@media screen and (min-width: 768px) {
    .header__snav__navBox {
        padding:30px 30px 120px
    }
}

.header__snav__nav {
    width: 100%;
    margin-bottom: 40px
}

.header__snav__item {
    margin-bottom: 5px;
    display: block;
    width: 100%;
    text-align: left
}

.header__snav__link {
    font-size: 16px;
    color: #3e3e3e;
    font-weight: bold;
    font-family: "Lato","Noto Sans JP",sans-serif;
    display: block
}

body.is-bodyFontDesignOption-mintyo .header__snav__link {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .header__snav__link {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__snav__smallTtlBox {
    margin-bottom: 5px
}

.header__snav__smallTtl {
    font-size: 12px;
    opacity: .6;
    font-family: "Lato","Noto Sans JP",sans-serif;
    letter-spacing: .1em
}

body.is-ttlFontDesignOption-mintyo .header__snav__smallTtl {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .header__snav__smallTtl {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__snav__otherNav__item {
    margin-bottom: 5px
}

.header__snav__otherNav__link {
    font-size: 16px;
    color: #3e3e3e;
    font-weight: bold;
    display: block;
    margin-bottom: 8px
}

.header__snav .appsItemCategoryTag_child {
    font-family: "Noto Sans JP",sans-serif;
    margin-bottom: 5px
}

body.is-bodyFontDesignOption-mintyo .header__snav .appsItemCategoryTag_child {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .header__snav .appsItemCategoryTag_child {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__snav .appsItemCategoryTag_child a {
    font-size: 16px;
    color: #3e3e3e;
    font-weight: bold;
    display: block;
    margin-bottom: 8px
}

.header__snav .appsItemCategoryTag_lowerchild {
    font-family: "Noto Sans JP",sans-serif;
    margin-top: 5px;
    margin-bottom: 20px;
    margin-left: 2px;
    padding-left: 10px;
    border-left: 1px solid rgba(62,62,62,.2)
}

body.is-bodyFontDesignOption-mintyo .header__snav .appsItemCategoryTag_lowerchild {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-bodyFontDesignOption-maru .header__snav .appsItemCategoryTag_lowerchild {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__snav .appsItemCategoryTag_lowerLink {
    font-size: 14px;
    color: #3e3e3e;
    font-weight: bold;
    line-height: 1.2
}

.header__snav__icon__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%
}

.header__snav__icon__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    width: 45px;
    height: 45px;
    border-radius: 23px;
    background-color: #fff;
    margin-right: 10px
}

.header__snav__icon__item img {
    width: 23px;
    height: auto
}

.header__snav__icon__baseitem li {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important
}

.header__snav form.itemSearch__form {
    position: relative;
    margin-top: 40px;
    height: 45px
}

.header__snav form.itemSearch__form input.itemSearch__field {
    width: 100%;
    padding: 10px 20px 10px 40px;
    font-size: 14px;
    width: 100%;
    height: 45px;
    border-radius: 23px;
    border: 1px solid #3e3e3e;
    line-height: normal
}

.header__snav form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    -webkit-transform: translate(0px, -2px);
    transform: translate(0px, -2px)
}

.header__snav form.itemSearch__form input.itemSearch__field::-moz-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.header__snav form.itemSearch__form input.itemSearch__field:-ms-input-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.header__snav form.itemSearch__form input.itemSearch__field::-ms-input-placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.header__snav form.itemSearch__form input.itemSearch__field::placeholder {
    font-family: "Lato","Noto Sans JP",sans-serif;
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    -webkit-transform: translate(0px, -2px);
    transform: translate(0px, -2px)
}

body.is-ttlFontDesignOption-mintyo .header__snav form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-mintyo .header__snav form.itemSearch__form input.itemSearch__field::-moz-placeholder {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-mintyo .header__snav form.itemSearch__form input.itemSearch__field:-ms-input-placeholder {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-mintyo .header__snav form.itemSearch__form input.itemSearch__field::-ms-input-placeholder {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-mintyo .header__snav form.itemSearch__form input.itemSearch__field::placeholder {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .header__snav form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__snav form.itemSearch__form input.itemSearch__field::-moz-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__snav form.itemSearch__form input.itemSearch__field:-ms-input-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__snav form.itemSearch__form input.itemSearch__field::-ms-input-placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

body.is-ttlFontDesignOption-maru .header__snav form.itemSearch__form input.itemSearch__field::placeholder {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.header__snav form.itemSearch__form input.itemSearch__field::-webkit-input-placeholder {
    position: relative;
    top: .2em
}

.header__snav form.itemSearch__form .itemSearch__btn {
    background-color: transparent;
    border: none !important;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 15px;
    margin: auto 0
}

.header__snav form.itemSearch__form .itemSearch__btn img {
    width: 20px;
    height: auto
}

.header__snav__overlay {
    content: "";
    display: block;
    width: 0;
    height: 0;
    background-color: rgba(0,0,0,.5);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99998;
    opacity: 0;
    -webkit-transition: opacity .5s;
    transition: opacity .5s;
    cursor: pointer
}

.header__snav__overlay.active {
    width: 100%;
    height: 100%;
    opacity: 1
}

#baseMenu {
    position: relative;
    right: auto;
    top: auto
}

#baseMenu>ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap
}

@media screen and (min-width: 1024px) {
    #baseMenu>ul>li {
        position:relative;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        cursor: pointer;
        width: 38px;
        height: 38px;
        border-radius: 23px;
        cursor: pointer
    }
}

#baseMenu>ul>li a {
    position: relative;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
    padding: 8px !important;
    border-radius: 50%;
    width: 38px;
    height: 38px;
    text-align: center;
    overflow: hidden
}

#baseMenu>ul>li a img {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto
}

#baseMenu>ul>li.base {
    margin-right: 10px
}

@media screen and (min-width: 1024px) {
    #baseMenu>ul>li.base {
        margin-right:10px
    }
}

.is-not-baselogo #baseMenu>ul>li.base {
    display: none !important
}

.header__rightBtns #baseMenu>ul>li.base {
    display: none
}

@media screen and (min-width: 768px) {
    .header__rightBtns #baseMenu>ul>li.base {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

#baseMenu>ul>li.base img {
    -webkit-transform: translate(0, -1px);
    transform: translate(0, -1px)
}

#baseMenu>ul>li.cart img {
    -webkit-transform: translate(-1px, 0);
    transform: translate(-1px, 0)
}

.footer {
    margin: 0 !important
}

.footer__wrapper {
    padding: 0 0 80px
}

.footer-mailmagazine {
    margin-top: 60px;
    margin-bottom: 60px;
    padding: 40px 5vw 45px;
    border-radius: 20px;
    border: 1px solid rgba(62,62,62,.05)
}

@media screen and (min-width: 768px) {
    .footer-mailmagazine {
        padding:50px 5vw 55px;
        border-radius: 40px
    }
}

body.is-bodyColorDesignOption-dark .footer-mailmagazine {
    border-color: rgba(255,255,255,.3)
}

.footer-mailmagazine__txtBox {
    margin-bottom: 25px;
    text-align: center;
    padding: 0 5vw
}

@media screen and (min-width: 768px) {
    .footer-mailmagazine__txtBox {
        padding:0
    }
}

.footer-mailmagazine__ttl {
    font-size: 18px;
    margin-bottom: 20px
}

@media screen and (min-width: 1024px) {
    .footer-mailmagazine__ttl {
        font-size:20px
    }
}

.footer-mailmagazine__desc {
    font-size: 12px;
    margin-top: 10px;
    font-weight: normal
}

.footer-mailmagazine__formBox {
    max-width: 500px;
    margin: 0 auto
}

.footer-mailmagazine__formBox .mailMagazineSubscribe_field {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.footer-mailmagazine__formBox input {
    padding: 10px 15px !important;
    font-size: 16px !important;
    border-color: #ddd;
    border-radius: 5px !important;
    vertical-align: middle;
    width: calc(100% - 70px) !important;
    margin-bottom: 0 !important
}

.footer-mailmagazine__formBox input::-webkit-input-placeholder {
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    -webkit-transform: translate(0px, -2px);
    transform: translate(0px, -2px)
}

.footer-mailmagazine__formBox input::-moz-placeholder {
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.footer-mailmagazine__formBox input:-ms-input-placeholder {
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.footer-mailmagazine__formBox input::-ms-input-placeholder {
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    transform: translate(0px, -2px)
}

.footer-mailmagazine__formBox input::placeholder {
    color: #3e3e3e;
    opacity: .5;
    font-size: 12px;
    -webkit-transform: translate(0px, -2px);
    transform: translate(0px, -2px)
}

.footer-mailmagazine__formBox input::-webkit-input-placeholder {
    position: relative;
    top: .2em
}

.footer-mailmagazine__formBox button {
    padding: 15px 15px;
    background-color: #252525;
    color: #fff;
    border: 1px solid rgba(255,255,255,.6);
    font-size: 14px;
    border-radius: 5px;
    letter-spacing: .1em;
    vertical-align: middle;
    font-weight: bold;
    cursor: pointer;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.footer-mailmagazine__formBox button:hover {
    opacity: .75
}

.footer-bottomBox {
    border-top: 1px solid rgba(62,62,62,.1)
}

body.is-bodyColorDesignOption-dark .footer-bottomBox {
    border-color: rgba(255,255,255,.3)
}

.footer-suvNav__list {
    text-align: center;
    display: block !important;
    margin-top: 70px;
    margin-bottom: 40px
}

@media screen and (min-width: 768px) {
    .footer-suvNav__list {
        display:-webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -webkit-box-pack: center !important;
        -ms-flex-pack: center !important;
        justify-content: center !important;
        -ms-flex-wrap: wrap !important;
        flex-wrap: wrap !important
    }
}

.footer-suvNav__link {
    padding: 10px 10px;
    font-size: 12px;
    font-weight: normal;
    display: block
}

@media screen and (min-width: 768px) {
    .footer-suvNav__link {
        padding:10px 10px
    }
}

body.is-bodyColorDesignOption-dark .footer-suvNav__link {
    color: #fff
}

.footer-sns__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 40px;
    margin-bottom: 40px
}

.footer-sns__item {
    margin: 5px
}

.footer-sns__link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-color: #fff;
    border-radius: 50%;
    width: 36px;
    height: 36px
}

@media screen and (min-width: 768px) {
    .footer-sns__link {
        width:42px;
        height: 42px
    }
}

.footer-sns__link img {
    width: 20px;
    height: auto
}

@media screen and (min-width: 768px) {
    .footer-sns__link img {
        width:22px
    }
}

.footer-langage {
    text-align: center
}

.footer-copyright {
    margin-top: 40px;
    padding: 0 5vw;
    text-align: center
}

.footer-copyright p {
    font-size: 12px;
    font-weight: normal
}

#i18 {
    position: relative;
    top: auto;
    left: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 0
}

#i18 select {
    border-radius: 15px;
    font-size: 11px
}

.kv {
    position: relative;
    width: 100%;
    height: 50vw;
    overflow: hidden;
    margin: 0 auto 10px
}

@media screen and (min-width: 576px) {
    .kv {
        height:46vw
    }
}

@media screen and (min-width: 1024px) {
    .kv {
        height:480px
    }
}

.kv__list {
    z-index: 1
}

.kv__img {
    width: 95%;
    height: 50vw;
    border-radius: 25vw;
    overflow: hidden;
    position: relative;
    margin: 0 auto;
    background-color: #fff;
    border: 5px solid #fff
}

@media screen and (min-width: 576px) {
    .kv__img {
        height:46vw;
        border-radius: 23vw
    }
}

@media screen and (min-width: 768px) {
    .kv__img {
        border:10px solid #fff
    }
}

@media screen and (min-width: 1024px) {
    .kv__img {
        height:480px;
        border-radius: 250px
    }
}

.kv__img img {
    vertical-align: bottom;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

.top-about {
    text-align: center;
    padding: 30px 0 10px
}

@media screen and (min-width: 1024px) {
    .top-about {
        padding:50px 0 30px
    }
}

.top-about__desc {
    text-align: left
}

body.is-AboutTextAlignDesignOption-center .top-about__desc {
    text-align: center
}

.top-cate {
    text-align: center;
    padding: 40px 0 20px
}

@media screen and (min-width: 1024px) {
    .top-cate {
        padding:60px 0 20px
    }
}

@media screen and (min-width: 768px) {
    .top-cate__list {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center
    }
}

.top-cate__item {
    text-align: center;
    margin: 20px 0;
    padding: 0 5% 20px
}

@media screen and (min-width: 768px) {
    .top-cate__item {
        width:25%;
        padding: 0 1.5% 20px;
        margin: 0
    }
}

.top-cate__link {
    display: block;
    z-index: 2
}

body.is-bodyColorDesignOption-dark .top-cate__link {
    color: #fff
}

.top-cate__link:hover {
    opacity: 1
}

.top-cate__imgBox {
    margin-bottom: 20px;
    padding: 0 5%
}

@media screen and (min-width: 768px) {
    .top-cate__imgBox {
        margin-bottom:25px;
        padding: 0 13%
    }
}

body.is-PickupSpCarouselInDesignOption-false .top-cate__imgBox {
    margin-bottom: 25px;
    padding: 0 20%
}

@media screen and (min-width: 768px) {
    body.is-PickupSpCarouselInDesignOption-false .top-cate__imgBox {
        margin-bottom:25px;
        padding: 0 13%
    }
}

.top-cate__img {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    border-radius: 50%;
    -webkit-box-shadow: 0px 0px 0px 5px #fff;
    box-shadow: 0px 0px 0px 5px #fff;
    background-color: #fff;
    z-index: 1
}

@media screen and (min-width: 768px) {
    .top-cate__img {
        -webkit-box-shadow:0px 0px 0px 10px #fff;
        box-shadow: 0px 0px 0px 10px #fff
    }
}

.top-cate__img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    z-index: 1;
    -webkit-transition: all .5s ease;
    transition: all .5s ease
}

a:hover .top-cate__img img {
    -webkit-transform: translate(-50%, -50%) scale(1.1, 1.1);
    transform: translate(-50%, -50%) scale(1.1, 1.1)
}

a:hover .top-cate__txtBox {
    opacity: .7
}

.top-cate__ttl {
    font-size: 16px;
    font-family: "Lato","Noto Sans JP",sans-serif
}

body.is-ttlFontDesignOption-mintyo .top-cate__ttl {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .top-cate__ttl {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.top-cate__desc {
    margin-top: 10px;
    text-align: left
}

body.is-PickupTextAlignDesignOption-center .top-cate__desc {
    text-align: center
}

.top-items {
    padding: 40px 0 80px
}

@media screen and (min-width: 768px) {
    .top-items {
        padding:60px 0 120px
    }
}

.top-faq {
    text-align: center;
    padding: 40px 0
}

@media screen and (min-width: 1024px) {
    .top-faq {
        padding:80px 0
    }
}

.top-faq__list {
    margin-top: 10px
}

@media screen and (min-width: 1024px) {
    .top-faq__list {
        margin-top:40px
    }
}

.top-faq__item {
    margin-bottom: 5px;
    background-color: #fff;
    text-align: left;
    padding: 15px 20px;
    cursor: pointer;
    border: 1px solid rgba(62,62,62,.1);
    border-radius: 15px;
    color: #3e3e3e
}

@media screen and (min-width: 768px) {
    .top-faq__item {
        margin-bottom:10px;
        padding: 20px 30px;
        border-radius: 20px
    }
}

.top-faq__item:last-child {
    margin-bottom: 0
}

.top-faq__q {
    padding-left: 1.7em;
    text-indent: -1.7em
}

@media screen and (min-width: 768px) {
    .top-faq__q {
        padding-left:2.1em;
        text-indent: -2.1em
    }
}

.top-faq__q::before {
    content: "Q.";
    font-size: 120%;
    margin-right: 3px;
    opacity: .5;
    font-weight: bold;
    font-family: "Lato","Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .top-faq__q::before {
        margin-right:10px
    }
}

body.is-ttlFontDesignOption-mintyo .top-faq__q::before {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .top-faq__q::before {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.top-faq__a {
    padding-top: 10px;
    padding-left: 1.7em
}

@media screen and (min-width: 768px) {
    .top-faq__a {
        padding-top:10px;
        padding-left: 2.1em
    }
}

.top-blog {
    padding: 50px 0 80px
}

@media screen and (min-width: 768px) {
    .top-blog {
        padding:100px 0 150px
    }
}

.top-blog__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 40px
}

@media screen and (min-width: 768px) {
    .top-blog__list {
        margin-top:60px
    }
}

.top-blog__item {
    width: 100%;
    padding: 0 2%;
    margin-bottom: 25px;
    position: relative
}

@media screen and (min-width: 768px) {
    .top-blog__item {
        width:50%;
        padding: 0 .5%;
        margin-bottom: 40px
    }
}

.top-blog__link {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #3e3e3e;
    z-index: 2;
    height: 100%
}

.top-blog__link:hover {
    opacity: 1
}

body.is-bodyColorDesignOption-dark .top-blog__link {
    color: #fff
}

.top-blog__imgBox {
    position: relative;
    width: 100px
}

@media screen and (min-width: 576px) {
    .top-blog__imgBox {
        width:120px
    }
}

@media screen and (min-width: 768px) {
    .top-blog__imgBox {
        width:130px
    }
}

.top-blog__img {
    width: 100%;
    border-radius: 15px;
    overflow: hidden;
    position: relative;
    z-index: 1;
    -webkit-box-shadow: 0px 0px 0px 5px #fff;
    box-shadow: 0px 0px 0px 5px #fff;
    background-color: #fff
}

@media screen and (min-width: 768px) {
    .top-blog__img {
        border-radius:20px;
        -webkit-box-shadow: 0px 0px 0px 10px #fff;
        box-shadow: 0px 0px 0px 10px #fff
    }
}

body.is-blogImgDesignOption-horizon .top-blog__img,body.is-blogImgDesignOption-square .top-blog__img {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 0
}

body.is-blogImgDesignOption-horizon .top-blog__img {
    padding-bottom: 61.8%
}

body.is-blogImgDesignOption-square .top-blog__img {
    padding-bottom: 100%
}

.top-blog__img img {
    width: 100%;
    -webkit-transition: all .3s ease;
    transition: all .3s ease
}

body.is-blogImgDesignOption-horizon .top-blog__img img,body.is-blogImgDesignOption-square .top-blog__img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

a:hover .top-blog__img img {
    -webkit-transform: scale(1.1, 1.1);
    transform: scale(1.1, 1.1)
}

body.is-blogImgDesignOption-horizon a:hover .top-blog__img img,body.is-blogImgDesignOption-square a:hover .top-blog__img img {
    -webkit-transform: translate(-50%, -50%) scale(1.1, 1.1);
    transform: translate(-50%, -50%) scale(1.1, 1.1)
}

.top-blog__txtBox {
    padding: 0 15px;
    width: calc(100% - 110px)
}

@media screen and (min-width: 576px) {
    .top-blog__txtBox {
        width:calc(100% - 130px)
    }
}

@media screen and (min-width: 1024px) {
    .top-blog__txtBox {
        padding:0 20px;
        width: calc(100% - 140px)
    }
}

.top-blog__txt-ttl {
    font-weight: bold;
    font-size: 14px;
    line-height: 1.3;
    margin-bottom: 5px;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    text-align: left
}

@media screen and (min-width: 768px) {
    .top-blog__txt-ttl {
        font-size:16px
    }
}

a:hover .top-blog__txt-ttl {
    opacity: .6
}

.top-blog__txt-date {
    font-size: 12px;
    opacity: .7;
    line-height: 1;
    margin-top: 10px;
    -webkit-transition: all .3s ease;
    transition: all .3s ease
}

@media screen and (min-width: 768px) {
    .top-blog__txt-date {
        font-size:14px;
        margin-bottom: 5px
    }
}

a:hover .top-blog__txt-date {
    opacity: .4
}

.top-blog__noPostsText {
    width: 100%;
    display: block;
    text-align: center;
    margin: 40px auto
}

.top-shop {
    overflow: hidden;
    position: relative;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
    padding: 60px 0;
    padding: 5vw 0
}

@media screen and (min-width: 1024px) {
    .top-shop {
        padding:120px 0
    }
}

.top-shop__imgBox {
    position: absolute;
    z-index: -1;
    width: 100%;
    height: 100%;
    overflow: hidden;
    top: 0;
    left: 0
}

.top-shop__img {
    width: 100%;
    height: 100%
}

.top-shop__img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

.top-shop__whiteBox {
    position: relative;
    background-color: #fff;
    color: #3e3e3e;
    border-radius: 20px;
    border: 1px solid rgba(62,62,62,.1);
    padding: 40px 5vw 45px;
    z-index: 2
}

@media screen and (min-width: 768px) {
    .top-shop__whiteBox {
        padding:60px 60px 70px;
        border-radius: 40px
    }
}

.top-shop__innerBox {
    max-width: 600px;
    margin: 0 auto
}

.top-shop__desc {
    text-align: left
}

body.is-ShopTextAlignDesignOption-center .top-shop__desc {
    text-align: center
}

.top-bottomBigImg__img {
    position: relative;
    width: 100%
}

body.is-shopImageTrimmingDesignOption-true .top-bottomBigImg__img {
    overflow: hidden;
    height: 0;
    padding-bottom: 53%
}

@media screen and (min-width: 768px) {
    body.is-shopImageTrimmingDesignOption-true .top-bottomBigImg__img {
        padding-bottom:36%
    }
}

.top-bottomBigImg__img img {
    width: 100%
}

body.is-shopImageTrimmingDesignOption-true .top-bottomBigImg__img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

#x_startMessenger.is-hide,.informationBanner.is-hide {
    display: none
}

.page-main {
    padding: 0 0 40px
}

@media screen and (min-width: 768px) {
    .page-main {
        padding:0 0 60px
    }
}

.page-wrapper {
    padding: 40px 5vw 80px;
    border-radius: 20px
}

@media screen and (min-width: 768px) {
    .page-wrapper {
        padding:60px 60px 80px;
        border-radius: 40px
    }
}

.page-wrapper.is-aboutContents {
    padding: 40px 5vw 60px
}

@media screen and (min-width: 768px) {
    .page-wrapper.is-aboutContents {
        padding:60px 60px
    }
}

.page-wrapper.is-itemDetail {
    padding: 5vw 5vw 80px
}

@media screen and (min-width: 576px) {
    .page-wrapper.is-itemDetail {
        padding:40px 40px 80px
    }
}

@media screen and (min-width: 768px) {
    .page-wrapper.is-itemDetail {
        padding:60px 60px 80px
    }
}

.page-wrapper.is-blog {
    padding: 5vw 5vw 40px
}

@media screen and (min-width: 576px) {
    .page-wrapper.is-blog {
        padding:40px 5vw 40px
    }
}

@media screen and (min-width: 768px) {
    .page-wrapper.is-blog {
        padding:60px 60px 80px
    }
}

.page-ttl01 {
    text-align: center;
    font-size: 20px;
    margin-bottom: 15px;
    font-family: "Lato","Noto Sans JP",sans-serif;
    word-wrap: break-word
}

@media screen and (min-width: 768px) {
    .page-ttl01 {
        font-size:24px;
        margin-bottom: 25px
    }
}

body.is-ttlFontDesignOption-mintyo .page-ttl01 {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .page-ttl01 {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.page-ttl01.has-mt {
    padding-top: 20px
}

@media screen and (min-width: 768px) {
    .page-ttl01.has-mt {
        padding-top:40px
    }
}

.page-ttl01.has-mb {
    margin-bottom: 40px
}

@media screen and (min-width: 768px) {
    .page-ttl01.has-mb {
        margin-bottom:60px
    }
}

.page-ttl01.has-paddingX {
    padding-left: 5%;
    padding-right: 5%
}

.page-breadcrumb {
    padding: 0 10px 20px;
    opacity: .8
}

@media screen and (min-width: 768px) {
    .page-breadcrumb {
        padding:0 30px 30px
    }
}

.breadcrumb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    list-style: none;
    max-width: 100%
}

.breadcrumb__child {
    display: block;
    font-size: 10px;
    padding-right: 10px;
    margin-right: 10px;
    position: relative;
    line-height: 1.3
}

@media screen and (min-width: 1024px) {
    .breadcrumb__child {
        font-size:14px
    }
}

.breadcrumb__child:first-child {
    text-transform: uppercase
}

.breadcrumb__child:not(:last-child):after {
    content: "";
    width: 6px;
    height: 6px;
    display: block;
    border: 0px;
    border-top: solid 1px #3e3e3e;
    border-right: solid 1px #3e3e3e;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto 0
}

body.is-bodyColorDesignOption-dark .breadcrumb__child:not(:last-child):after {
    border-color: #fff
}

.breadcrumb__link {
    display: block;
    text-decoration: none;
    word-wrap: break-word
}

body.is-bodyColorDesignOption-dark .breadcrumb__link {
    color: #fff
}

.breadcrumb__notlink {
    text-decoration: none;
    height: 20px;
    word-wrap: break-word;
    font-weight: bold
}

.about-kv__img {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 40vw
}

@media screen and (min-width: 768px) {
    .about-kv__img {
        height:36vw
    }
}

.about-kv__img img {
    vertical-align: bottom;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

.about-maintxt {
    line-height: 1.75
}

body.is-AboutPageTextAlignDesignOption-center .about-maintxt {
    text-align: center
}

.about-maintxt a {
    text-decoration: underline
}

.about-contentsImg__img {
    width: 100%;
    margin-top: 25px
}

@media screen and (min-width: 768px) {
    .about-contentsImg__img {
        margin-top:40px
    }
}

.about-contentsImg__img img {
    max-width: 100%
}

.about-subcontents {
    margin-top: 60px
}

@media screen and (min-width: 768px) {
    .about-subcontents {
        margin-top:80px
    }
}

.about-subcontents:last-child {
    margin-bottom: 20px
}

.about-subcontents__desc {
    line-height: 1.75
}

body.is-AboutPageTextAlignDesignOption-center .about-subcontents__desc {
    text-align: center
}

.about-subcontents__desc a {
    text-decoration: underline
}

.about-subcontents__img {
    width: 100%;
    margin-top: 25px
}

@media screen and (min-width: 768px) {
    .about-subcontents__img {
        margin-top:40px
    }
}

.about-subcontents__img img {
    max-width: 100%
}

.inquirySection h1:not([class]) {
    display: none;
    font-size: 30px;
    text-align: center
}

.inquirySection p {
    text-align: center
}

#contact-page .inquirySection {
    padding: 0;
    word-break: normal
}

.communityMain {
    background-color: #fff;
    color: #3e3e3e;
    width: auto !important;
    border-radius: 20px;
    padding: 0 !important
}

@media screen and (min-width: 768px) {
    .communityMain {
        border-radius:40px
    }
}

.communityMain .communityTitle {
    font-family: "Lato","Noto Sans JP",sans-serif
}

body.is-ttlFontDesignOption-mintyo .communityMain .communityTitle {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .communityMain .communityTitle {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.communityMain .communityContent {
    display: block !important;
    padding: 20px 15px !important;
    border-radius: 15px
}

@media screen and (min-width: 576px) {
    .communityMain .communityContent {
        padding:20px 24px !important
    }
}

.communityMain .communityOverview {
    width: 100% !important
}

.communityMain .communityNav {
    width: 100% !important;
    margin-left: 0 !important;
    margin-top: 40px !important
}

.communityMain .communitySignin {
    padding: 10px !important;
    border-radius: 5px !important
}

@media screen and (min-width: 576px) {
    .communityMain .communitySignin {
        padding:16px !important
    }
}

.communityMain .communityItemHeader {
    text-align: center !important;
    font-size: 18px !important;
    margin-top: 40px !important;
    font-family: "Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .communityMain .communityItemHeader {
        font-size:20px !important;
        margin-top: 60px !important
    }
}

body.is-ttlFontDesignOption-mintyo .communityMain .communityItemHeader {
    font-family: "Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .communityMain .communityItemHeader {
    font-family: "M PLUS Rounded 1c",sans-serif
}

.communityMain #limitedItem {
    width: 100% !important
}

.communityMain .communityItem {
    margin-left: 0 !important;
    width: 100% !important;
    margin-bottom: 15px;
    position: relative
}

@media screen and (min-width: 768px) {
    .communityMain .communityItem {
        width:33.333% !important;
        padding: 0 1.5% !important;
        margin-bottom: 40px
    }
}

.communityMain .communityLabelImage {
    position: absolute;
    top: -10px !important;
    left: -10px !important;
    width: 60px;
    height: auto;
    z-index: 10;
    pointer-events: none
}

.communityMain .communityImageContainer {
    width: 100% !important;
    height: 0 !important;
    padding-bottom: 100%;
    overflow: hidden;
    position: relative;
    border-radius: 20px
}

body.is-itemsImgDesignOption-horizon .communityMain .communityImageContainer {
    padding-bottom: 61.8%
}

body.is-itemsImgDesignOption-vertical .communityMain .communityImageContainer {
    padding-bottom: 141.4%
}

body.is-itemsImgDesignOption-square .communityMain .communityImageContainer {
    overflow: hidden;
    padding-bottom: 100%
}

body.is-itemsImgDesignOption-none .communityMain .communityImageContainer {
    overflow: hidden;
    padding-bottom: 100%;
    background-color: #f8f8f8
}

.communityMain .communityImageResize {
    position: absolute;
    top: 50% !important;
    bottom: auto !important;
    left: 50% !important;
    right: auto !important;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    -o-object-fit: cover !important;
    object-fit: cover !important;
    font-family: "object-fit: cover;" !important
}

body.is-itemsImgDesignOption-none .communityMain .communityImageResize {
    -o-object-fit: contain !important;
    object-fit: contain !important;
    font-family: "object-fit: contain;" !important
}

.communityMain .communityItemTitle {
    width: 100% !important;
    margin-bottom: 10px !important
}

.communityMain #limitedUrl {
    width: 100% !important
}

.communityMain #limitedUrl .communityUrlHeader {
    text-align: center !important;
    font-size: 18px !important;
    margin-top: 40px !important;
    margin-bottom: 20px;
    font-family: "Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .communityMain #limitedUrl .communityUrlHeader {
        font-size:20px !important;
        margin-top: 60px !important;
        margin-bottom: 20px
    }
}

body.is-ttlFontDesignOption-mintyo .communityMain #limitedUrl .communityUrlHeader {
    font-family: "Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .communityMain #limitedUrl .communityUrlHeader {
    font-family: "M PLUS Rounded 1c",sans-serif
}

.communityMain #limitedUrl p {
    text-align: center;
    margin: 0
}

.communityMain #limitedUrl #productsLimitedUrl {
    margin-top: 20px;
    display: block !important
}

@media screen and (min-width: 768px) {
    .communityMain #limitedUrl #productsLimitedUrl {
        display:-webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }
}

.communityMain #limitedUrl .urlBox {
    width: 100% !important;
    border-radius: 15px !important
}

@media screen and (min-width: 768px) {
    .communityMain #limitedUrl .urlBox {
        width:calc((100% - 20px)/2) !important;
        margin: 10px 0 !important
    }
}

.communityMain .communityNotExists {
    padding-top: 30px
}

#privacy,#law {
    font-size: 14px;
    word-break: normal
}

#privacy h2,#law h2 {
    font-family: "Noto Sans JP",sans-serif;
    text-align: center;
    font-size: 20px;
    margin-bottom: 40px
}

body.is-ttlFontDesignOption-mintyo #privacy h2,body.is-ttlFontDesignOption-mintyo #law h2 {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru #privacy h2,body.is-ttlFontDesignOption-maru #law h2 {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

#privacy h3,#privacy dt,#law h3,#law dt {
    margin: 40px 0 10px;
    font-size: 16px
}

#privacy a,#law a {
    text-decoration: underline
}

#privacy li,#law li {
    margin: 10px 0 20px
}

.page-membership .page-wrapper {
    padding: 5vw 5vw 60px
}

@media screen and (min-width: 768px) {
    .page-membership .page-wrapper {
        padding:60px 60px 80px
    }
}

.page-membership #membership {
    width: 100%;
    padding: 0
}

.page-membership #membership .img-wrapper {
    margin-bottom: 40px
}

.page-membership #membership .img-wrapper .img {
    height: auto
}

.page-membership #membership .content>.heading {
    text-align: center;
    font-size: 20px;
    margin-top: 40px;
    margin-bottom: 20px;
    letter-spacing: .025em;
    line-height: 1.7;
    font-family: "Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .page-membership #membership .content>.heading {
        font-size:24px;
        margin-top: 10px;
        margin-bottom: 35px
    }
}

body.is-ttlFontDesignOption-mintyo .page-membership #membership .content>.heading {
    font-family: "Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .page-membership #membership .content>.heading {
    font-family: "M PLUS Rounded 1c",sans-serif
}

.page-membership #membership .content>.description>p {
    line-height: 1.75
}

.page-membership #membership .mypage-link {
    margin-top: 60px
}

.page-membership #membership .mypage-link .link {
    padding: 15px 20px;
    line-height: 1.2;
    font-size: 14px;
    border: 1px solid rgba(255,255,255,.5)
}

@media screen and (min-width: 768px) {
    .page-membership #membership .mypage-link .link {
        padding:20px 20px;
        font-size: 16px
    }
}

.page-membership #membership .register {
    margin-top: 64px;
    padding: 40px 20px;
    background-color: rgba(62,62,62,.05);
    border: 1px solid rgba(62,62,62,.08);
    border-radius: 5px
}

@media screen and (min-width: 768px) {
    .page-membership #membership .register {
        padding:50px 50px
    }
}

.page-membership #membership .register .heading {
    font-size: 18px;
    margin-bottom: 25px
}

.page-membership #membership .register .box {
    margin: -20px auto 40px;
    width: 100%;
    max-width: 100%
}

@media screen and (min-width: 768px) {
    .page-membership #membership .register .box {
        margin:0 auto 40px;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center
    }
}

.page-membership #membership .register .box::before {
    margin-top: 4px
}

.page-membership #membership .register .link-wrapper .link {
    padding: 15px 20px;
    line-height: 1.2;
    font-size: 14px;
    border: 1px solid rgba(255,255,255,.5)
}

@media screen and (min-width: 768px) {
    .page-membership #membership .register .link-wrapper .link {
        padding:20px 20px;
        font-size: 16px
    }
}

.page-membership #membership .leave-modal-wrapper .leave-overlay {
    z-index: 9999
}

.page-membership #membership .leave-modal-wrapper .leave-modal {
    z-index: 10000
}

.page-membership .mypage .heading-wrapper {
    margin-top: 20px;
    margin-bottom: 20px
}

@media screen and (min-width: 768px) {
    .page-membership .mypage .heading-wrapper {
        margin-top:0;
        margin-bottom: 30px !important
    }
}

@media screen and (min-width: 768px) {
    .page-membership .mypage .info {
        -webkit-box-pack:justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }
}

.page-membership .mypage .card {
    max-width: 100% !important;
    min-width: 100% !important;
    width: 100%;
    margin-bottom: 20px !important;
    padding: 20px;
    text-align: center;
    font-family: "Lato","Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    .page-membership .mypage .card {
        max-width:40% !important;
        min-width: 40% !important;
        margin-right: 0 !important
    }
}

body.is-ttlFontDesignOption-mintyo .page-membership .mypage .card {
    font-family: "Lora","Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .page-membership .mypage .card {
    font-family: "Comfortaa","M PLUS Rounded 1c",sans-serif
}

.page-membership .mypage .card .logo-text {
    font-size: 24px !important
}

@media screen and (min-width: 768px) {
    .page-membership .mypage .content {
        width:55% !important
    }
}

.page-membership .mypage .content .customer-info {
    padding: 20px 0 !important
}

@media screen and (min-width: 768px) {
    .page-membership .mypage .content .customer-info {
        padding:16px 0 !important
    }
}

.page-membership .mypage .content .definition-description .mail-address {
    background-color: rgba(62,62,62,.05) !important;
    border: 1px solid rgba(62,62,62,.08);
    padding: 16px !important
}

.page-membership .mypage .content .definition-description .edit {
    padding: 16px 0 !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.page-membership .login .heading {
    margin-top: 40px !important
}

@media screen and (min-width: 768px) {
    .page-membership .login .heading {
        margin-top:0 !important
    }
}

.page-membership .login .link {
    padding: 15px 20px !important;
    line-height: 1.2 !important;
    font-size: 14px !important;
    border: 1px solid rgba(255,255,255,.5);
    max-width: 100% !important
}

@media screen and (min-width: 768px) {
    .page-membership .login .link {
        padding:20px 20px !important;
        font-size: 16px !important
    }
}

.page-membership .draft {
    margin-top: 40px
}

@media screen and (min-width: 768px) {
    .page-membership .draft {
        margin-top:0px
    }
}

.communityModal .communityModalHeader {
    color: #3e3e3e !important
}

.communityModal .communityTitle {
    color: #3e3e3e !important
}

.communityModal .communityPrice {
    color: #3e3e3e !important
}

.communityModal .communityOverview {
    color: #3e3e3e !important
}

.communityModal .communityTextNotice {
    color: #3e3e3e !important
}

.communityModal .communityTerms {
    color: #3e3e3e !important
}

#law .telnumValid img {
    -webkit-filter: drop-shadow(0px 0px 1px rgba(255, 255, 255, 0.5));
    filter: drop-shadow(0px 0px 1px rgba(255, 255, 255, 0.5))
}

#law .telnumValid__txt {
    color: #3e3e3e !important
}

.purchaseButtonModal__ageVerificationWarningText {
    color: #3e3e3e !important
}

.purchaseButtonModal__information i {
    color: #3e3e3e !important
}

.msg_messenger {
    color: #3e3e3e
}

.items-archive__list,.communityMain .communityItems {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (min-width: 768px) {
    .items-archive__list,.communityMain .communityItems {
        padding-top:10px
    }
}

.items-archive__item {
    width: 50%;
    padding: 0 10px;
    margin-bottom: 20px;
    position: relative
}

@media screen and (min-width: 768px) {
    .items-archive__item {
        width:33.333%;
        padding: 0 20px;
        margin-bottom: 40px
    }
}

.items-archive__link {
    position: relative;
    display: block;
    color: #3e3e3e;
    z-index: 2;
    height: 100%;
    background-color: #fff;
    border-radius: 20px;
    -webkit-box-shadow: 0px 0px 0px 5px #fff;
    box-shadow: 0px 0px 0px 5px #fff
}

@media screen and (min-width: 768px) {
    .items-archive__link {
        border-radius:30px;
        -webkit-box-shadow: 0px 0px 0px 10px #fff;
        box-shadow: 0px 0px 0px 10px #fff
    }
}

.items-archive__link:hover {
    opacity: 1
}

.items-archive__imgBox {
    margin-bottom: 10px;
    position: relative
}

@media screen and (min-width: 768px) {
    .items-archive__imgBox {
        margin-bottom:20px
    }
}

.items-archive__img {
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    z-index: 1
}

@media screen and (min-width: 768px) {
    .items-archive__img {
        border-radius:30px
    }
}

body.is-itemsImgDesignOption-horizon .items-archive__img {
    height: 0;
    padding-bottom: 61.8%
}

body.is-itemsImgDesignOption-vertical .items-archive__img {
    height: 0;
    padding-bottom: 141.4%
}

body.is-itemsImgDesignOption-square .items-archive__img {
    height: 0;
    overflow: hidden;
    padding-bottom: 100%
}

.items-archive__img img {
    width: 100%;
    -webkit-transition: all .5s ease;
    transition: all .5s ease
}

body.is-itemsImgDesignOption-horizon .items-archive__img img,body.is-itemsImgDesignOption-vertical .items-archive__img img,body.is-itemsImgDesignOption-square .items-archive__img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

a:hover .items-archive__img img {
    -webkit-transform: scale(1.1, 1.1);
    transform: scale(1.1, 1.1)
}

body.is-itemsImgDesignOption-horizon a:hover .items-archive__img img,body.is-itemsImgDesignOption-vertical a:hover .items-archive__img img,body.is-itemsImgDesignOption-square a:hover .items-archive__img img {
    -webkit-transform: translate(-50%, -50%) scale(1.1, 1.1);
    transform: translate(-50%, -50%) scale(1.1, 1.1)
}

.items-archive__img img.is-img02 {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 101%;
    min-height: 101%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    z-index: 2;
    opacity: 0
}

a:hover .items-archive__img img.is-img02 {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(1.1, 1.1);
    transform: translate(-50%, -50%) scale(1.1, 1.1)
}

.items-archive__txtBox {
    padding: 5px 0 15px
}

@media screen and (min-width: 768px) {
    .items-archive__txtBox {
        padding:5px 0 15px
    }
}

.items-archive__txt-ttl {
    font-weight: bold;
    font-size: 14px;
    line-height: 1.3;
    margin-bottom: 5px;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    text-align: center
}

@media screen and (min-width: 768px) {
    .items-archive__txt-ttl {
        font-size:16px
    }
}

a:hover .items-archive__txt-ttl {
    opacity: .6
}

.items-archive__txt-price {
    width: 100%;
    opacity: .6;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    text-align: center;
    margin-top: 5px;
    line-height: 1.2;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    word-break: break-all
}

a:hover .items-archive__txt-price {
    opacity: .4
}

.items-archive__txt-price.is-red {
    opacity: 1;
    color: #e74c3c
}

a:hover .items-archive__txt-price.is-red {
    opacity: .7
}

.items-archive__txt-price-main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 14px;
    padding: 0 5px
}

@media screen and (min-width: 768px) {
    .items-archive__txt-price-main {
        font-size:16px
    }
}

.items-archive__txt-price-main span {
    display: block
}

.items-archive__txt-price-small {
    font-size: 10px;
    margin-top: 3px;
    display: block;
    padding: 0 5px
}

@media screen and (min-width: 768px) {
    .items-archive__txt-price-small {
        font-size:12px
    }
}

.items-archive__tagBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 5px;
    width: 100%;
    overflow: hidden
}

.items-archive__tag {
    line-height: 1;
    font-size: 10px;
    color: #fff;
    font-weight: bold;
    padding: 4px 10px 5px;
    margin-right: 2px;
    margin-top: 5px;
    background-color: #919191;
    border: 1px solid #fff;
    border-radius: 5px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    max-width: 100%;
    height: 22px;
    word-wrap: normal;
    white-space: nowrap
}

@media screen and (min-width: 576px) {
    .items-archive__tag {
        font-size:12px;
        height: 26px
    }
}

.items-archive__tag.is-black {
    background-color: #3e3e3e
}

.items-archive__tag.is-gray {
    background-color: #919191
}

.items-archive__tag.is-yellow {
    background-color: #eabe4f
}

.items-archive__tag.is-red {
    background-color: #e74c3c
}

.items-archive__tag.is-white {
    background-color: #fff;
    color: #3e3e3e;
    border-color: #3e3e3e
}

.items-archive__tag.is-green {
    background-color: #fff;
    color: #11beae;
    border-color: #11beae
}

.items-archive__noItemsMessage {
    text-align: center;
    margin: 60px 0 40px
}

@media screen and (min-width: 768px) {
    .items-archive__noItemsMessage {
        margin:100px 0 40px
    }
}

.items-cateList {
    margin-bottom: 20px;
    padding: 0 15px
}

@media screen and (min-width: 768px) {
    .items-cateList {
        margin-bottom:30px
    }
}

.items-cateList.has-mb {
    margin-bottom: 40px
}

@media screen and (min-width: 768px) {
    .items-cateList.has-mb {
        margin-bottom:40px
    }
}

@media screen and (min-width: 1024px) {
    .items-cateList.has-mb {
        margin-bottom:50px
    }
}

.items-cateList__line {
    border-top: 1px solid rgba(62,62,62,.1);
    border-bottom: 1px solid rgba(62,62,62,.1);
    padding: 10px 5px
}

body.is-bodyColorDesignOption-dark .items-cateList__line {
    border-color: rgba(255,255,255,.3)
}

@media screen and (min-width: 768px) {
    .items-cateList__line {
        padding:20px 10px
    }
}

.items-cateList__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.items-cateList__item {
    margin: 5px 5px;
    font-size: 12px;
    display: block
}

@media screen and (min-width: 768px) {
    .items-cateList__item {
        margin:5px 20px;
        font-size: 14px
    }
}

.items-cateList__link {
    display: block
}

body.is-bodyColorDesignOption-dark .items-cateList__link {
    color: #fff
}

@media screen and (min-width: 1024px) {
    .item-detail__mainContents {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }
}

.item-detail__imgBox {
    margin-bottom: 40px
}

@media screen and (min-width: 1024px) {
    .item-detail__imgBox {
        width:40%
    }
}

.item-detail__slider {
    position: relative
}

.item-detail__mainSlider {
    margin-bottom: 10px;
    position: relative
}

.item-detail__mainSlider__list.slick-slider {
    display: none
}

.item-detail__mainSlider__list.slick-slider.slick-initialized {
    display: block
}

.item-detail__mainSlider__list.is-loading .slick-list {
    height: auto;
    overflow: visible
}

.item-detail__mainSlider__item:nth-child(n+2) {
    display: none
}

.slick-list .item-detail__mainSlider__item:nth-child(n+2) {
    display: block !important
}

.item-detail__mainSlider__img {
    width: 100%
}

.item-detail__mainSlider__img img {
    width: 100%;
    border-radius: 10px
}

.item-detail__mainSlider__arrow__icon {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto 0;
    z-index: 3;
    background-color: transparent;
    border: none;
    font-size: 0;
    cursor: pointer;
    background-color: rgba(62,62,62,.3);
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 30px;
    height: 30px
}

.item-detail__mainSlider__arrow__icon::before {
    content: "";
    width: 10px;
    height: 10px;
    border: 0px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.item-detail__mainSlider__arrow__icon.is-prev {
    left: 5px
}

.item-detail__mainSlider__arrow__icon.is-prev::before {
    -webkit-transform: translate(2px, 0px) rotate(-135deg);
    transform: translate(2px, 0px) rotate(-135deg)
}

.item-detail__mainSlider__arrow__icon.is-next {
    right: 5px
}

.item-detail__mainSlider__arrow__icon.is-next::before {
    -webkit-transform: translate(-2px, 0px) rotate(45deg);
    transform: translate(-2px, 0px) rotate(45deg)
}

.item-detail__thumbnail__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%
}

.item-detail__thumbnail__item {
    width: 20%;
    position: relative;
    cursor: pointer
}

.item-detail__thumbnail__item::after {
    content: "";
    border: 1px solid #fff;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    border-radius: 10px
}

.item-detail__thumbnail__img {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    border-radius: 10px
}

.item-detail__thumbnail__img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;"
}

@media screen and (min-width: 1024px) {
    .item-detail__txtBox {
        width:44%
    }
}

.item-detail__ttlBox .item-detail__ttl {
    padding-top: 15px !important;
    line-height: 1.2;
    font-family: "Noto Sans JP",sans-serif;
    font-size: 20px;
    margin-bottom: 0 !important;
    word-wrap: break-word !important;
    background: none !important;
    color: black !important;
    border: none !important;
    padding: 10px 0px !important;
}
.item-detail__ttlBox .item-detail__ttl::after{
    content:none;
}
.item-detail__ttlBox .item-detail__ttl::before{
    content:none;
}

@media screen and (min-width: 768px) {
    .item-detail__ttl {
        font-size:26px;
        margin-bottom: 20px
    }
}

body.is-ttlFontDesignOption-mintyo .item-detail__ttl {
    font-family: "Noto Serif JP",serif
}

body.is-ttlFontDesignOption-maru .item-detail__ttl {
    font-family: "M PLUS Rounded 1c",sans-serif
}

.item-detail__price {
    width: 100%;
    opacity: .7;
    font-size: 1.1em;
    margin-top: 20px;
    line-height: 1.2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    word-break: break-all
}

.item-detail__price.is-discountPrice {
    opacity: 1;
    margin-top: 10px
}

.item-detail__price.has-arrow {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.item-detail__price.has-arrow::after {
    content: "";
    display: inline-block;
    background-image: url("https://basefile.akamaized.net/ISHdesign-theshop-jp/625c1c9b94c3e/icon-arrow2.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    width: 10px;
    height: 10px;
    margin: 0 5px;
    vertical-align: middle
}

.item-detail__price__default {
    text-decoration: line-through;
    line-height: 1.2;
    font-size: 16px;
    vertical-align: middle
}

.item-detail__price__calcPrice {
    color: #e74c3c;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-right: 10px;
    font-weight: bold;
    font-size: 18px
}

.item-detail__price__calcPrice span {
    display: block
}

.item-detail__price__ratio {
    color: #e74c3c;
    font-size: 14px;
    display: block;
    margin-top: 3px
}

.item-detail__tagBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
    overflow: hidden
}

.item-detail__tag {
    line-height: 1;
    font-size: 12px;
    color: #fff;
    font-weight: bold;
    letter-spacing: .1em;
    padding: 4px 10px 5px;
    margin-right: 5px;
    margin-top: 5px;
    background-color: #919191;
    border: 1px solid #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 5px;
    max-width: 100%;
    height: 26px;
    word-wrap: normal;
    white-space: nowrap
}

.item-detail__tag.is-gray {
    background-color: #919191
}

.item-detail__tag.is-yellow {
    background-color: #eabe4f
}

.item-detail__tag.is-red {
    background-color: #e74c3c
}

.item-detail__tag.is-white {
    background-color: #fff;
    color: #3e3e3e;
    border-color: #3e3e3e
}

.item-detail__tag.is-green {
    background-color: #fff;
    color: #11beae;
    border-color: #11beae
}

.item-detail__form {
    margin-top: 20px
}

.item-detail__form label {
    font-size: 14px;
    margin-right: 10px
}

.item-detail__form select {
    color: #3e3e3e
}

.item-detail__form .itemOptionElement {
    margin: 30px 0
}

.item-detail__form .itemOption__name {
    display: block;
    font-weight: bold;
    min-width: 80px
}

.item-detail__form .itemOption__select {
    display: block
}

.item-detail__form .itemOption__caption {
    font-size: 12px;
    opacity: .7;
    margin: 8px 0;
    line-height: 1.3
}

.item-detail__form .itemOption__caption--error {
    font-size: 12px;
    margin: 6px 0 5px;
    color: #e74c3c;
    display: block;
    position: relative
}

.item-detail__form .itemOption__count {
    font-size: 10px;
    opacity: .7;
    margin: 5px
}

.item-detail__form #variationSelectWrap {
    margin-top: 25px
}

.item-detail__form #variationSelectWrap label {
    font-weight: bold;
    display: block;
    min-width: 80px
}

.item-detail__form #amountSelectWrap {
    margin-top: 25px
}

.item-detail__form #amountSelectWrap label {
    font-weight: bold;
    display: block;
    min-width: 80px
}

.item-detail__form .purchaseButton {
    margin-top: 25px
}

.item-detail__form .purchaseButton button,.item-detail__form .purchaseButton .purchaseButton__btn {
    width: 100%;
    max-width: 100%;
    min-width: auto;
    background-color: #3e3e3e !important;
    color: #fff !important;
    cursor: pointer
}

.item-detail__form .purchaseButton button:disabled,.item-detail__form .purchaseButton .purchaseButton__btn:disabled {
    cursor: not-allowed;
    background-color: #919191 !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.4) !important;
    opacity: .75
}

.item-detail__form .purchaseButton button:disabled::after,.item-detail__form .purchaseButton .purchaseButton__btn:disabled::after {
    content: none
}

.item-detail__form .purchaseButton .purchaseButton__btn--disabled {
    cursor: not-allowed;
    background-color: #919191 !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.4) !important;
    opacity: .75
}

.item-detail__form .purchaseButton .purchaseButton__btn--disabled::after {
    content: none
}

.item-detail .communityModal {
    width: 600px;
    max-width: 90%;
    max-height: 85vh;
    overflow-y: auto
}

.item-detail .communityRegisterButtons {
    text-align: center
}

.item-detail .communityRegisterButtons .buttonPayid {
    margin: 10px !important
}

@media screen and (min-width: 768px) {
    .item-detail .communityRegisterButtons .buttonPayid {
        margin:10px 5px !important
    }
}

.item-detail__meta {
    margin-top: 20px;
    font-size: 14px;
    word-break: normal
}

.item-detail__meta p {
    font-size: 14px
}

.item-detail__meta a {
    word-break: normal
}

.item-detail__meta .attention {
    opacity: .7
}

.item-detail__meta .attention.salesPeriod--term {
    opacity: 1
}

.item-detail__meta .communityLabel {
    padding: 15px;
    background-color: #fff2d2;
    color: #d49c00;
    border-radius: 5px;
    margin: 15px 0
}

.item-detail__meta .communityLabel .communityLabel__note {
    margin-top: 0
}

.item-detail__meta .takeout,.item-detail__meta .lottery,.item-detail__meta .preOrder {
    padding: 15px;
    font-size: 14px;
    background-color: #f8f8f8;
    margin: 15px 0;
    border-radius: 5px
}

.item-detail__meta .lottery__label,.item-detail__meta .takeout__label,.item-detail__meta .preOrder__label {
    font-weight: bold
}

.item-detail__meta .salesPeriod--term {
    margin-bottom: 10px
}

.item-detail__meta .preOrder {
    margin-bottom: 10px
}

.item-detail__desc {
    margin: 30px 0;
    font-size: 14px;
    line-height: 1.75
}

.item-detail__desc p {
    font-size: 14px;
    line-height: 1.75
}

.item-detail__accordionPanelBox {
    padding: 15px 5px;
    border-top: 1px solid #ddd;
    margin-top: 30px
}

.item-detail__accordionPanelBox__ttlBox {
    padding-right: 26px;
    position: relative
}

.item-detail__accordionPanelBox__ttlBox.accordionPanel-click {
    cursor: pointer
}

.item-detail__accordionPanelBox__icon {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 5px;
    margin: auto 0;
    width: 12px;
    height: 12px
}

.item-detail__accordionPanelBox__icon__wrapper {
    position: relative;
    width: 12px;
    height: 12px
}

.item-detail__accordionPanelBox__icon__line {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    display: block;
    width: 12px;
    height: 2px;
    background-color: rgba(62,62,62,.6)
}

.item-detail__accordionPanelBox__icon__line.is-line02 {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
}

.accordionPanel-click.is-active .item-detail__accordionPanelBox__icon__line.is-line02 {
    display: none;
    opacity: 0
}

.item-detail__accordionPanelBox__ttl {
    font-size: 14px
}

.item-detail__accordionPanelBox__contentsBox {
    display: none
}

.item-detail__accordionPanelBox__contentsBox.is-active {
    display: block
}

.item-detail__accordionPanelBox__contents {
    font-size: 14px;
    line-height: 1.75;
    margin-top: 10px
}

.item-detail__smallBtnBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 40px;
    padding: 10px 5px;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd
}

.item-detail__sns ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.item-detail__sns li {
    margin-right: 10px;
    padding: 5px 0
}

.item-detail__sns iframe {
    vertical-align: bottom
}

.item-detail__reportAlert {
    font-size: 12px;
    margin-top: 10px
}

@media screen and (min-width: 414px) {
    .item-detail__reportAlert {
        margin-top:0
    }
}

.item-detail__reportAlert a {
    padding: 5px 0 10px
}

.item-detail__detailContents {
    margin-top: 60px;
    margin-bottom: 60px
}

@media screen and (min-width: 1024px) {
    .item-detail__detailContents {
        margin-top:80px;
        margin-bottom: 80px;
        padding: 0 60px
    }
}

.item-detail__detailContents a {
    text-decoration: underline
}

.item-detail__relatedItemsContents {
    margin-top: 60px;
    margin-bottom: 60px
}

@media screen and (min-width: 768px) {
    .item-detail__relatedItemsContents {
        margin-top:80px;
        margin-bottom: 80px
    }
}

.item-detail__relatedItemsContents .items-archive__item {
    width: 90%;
    padding: 10px 10px;
    margin: 0 auto
}

@media screen and (min-width: 768px) {
    .item-detail__relatedItemsContents .items-archive__item {
        width:33.333%;
        padding: 0 1.5%
    }
}

.item-detail__reviewContents {
    margin-top: 60px;
    margin-bottom: 40px
}

@media screen and (min-width: 1024px) {
    .item-detail__reviewContents {
        margin-top:80px;
        margin-bottom: 40px
    }
}

.itemOption__input[data-has-error=true]+.itemOption__bottomCaptionBlock .itemOption__caption--error {
    background-color: #ffebeb;
    padding: 5px
}

.itemOption__input[data-has-error=true]+.itemOption__bottomCaptionBlock .itemOption__caption--error::after {
    border: solid transparent;
    content: "";
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    border-color: rgba(0,153,255,0);
    border-top-width: 5px;
    border-bottom-width: 5px;
    border-left-width: 5px;
    border-right-width: 5px;
    margin-left: -5px;
    bottom: 100%;
    left: 5%;
    border-bottom-color: #ffebeb
}

.baseCarousel__button {
    margin: auto 10px
}

.item-detail__meta #postageClose {
    z-index: 10002
}

.centeringFixForPostageInfo {
    position: fixed;
    top: 50% !important;
    left: 50% !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    -webkit-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%)
}

.label_image {
    position: absolute;
    top: -8px;
    left: -8px;
    width: 48px;
    height: auto;
    z-index: 10;
    pointer-events: none;
    border-radius: 0
}

@media screen and (min-width: 576px) {
    .label_image {
        top:-10px;
        left: -10px;
        width: 60px
    }
}

.ageVerificationWarning {
    background: #fff;
    padding: 5px;
    word-break: normal
}

#ageVerificationModal .purchaseButtonModal__inputAreaLabel,#ageVerificationModal .ageVerificationModal__warningText {
    color: #3e3e3e
}

#blog-page .blogListMain {
    padding: 0;
    width: 700px;
    max-width: 100%
}

#blog-page .blogListMain .blog_inner {
    padding: 40px 0 !important;
    border-bottom: 1px solid #ddd
}

@media screen and (min-width: 768px) {
    #blog-page .blogListMain .blog_inner {
        padding:40px 0 !important
    }
}

#blog-page .blogListMain .blog_inner:first-child {
    padding-top: 20px !important
}

@media screen and (min-width: 768px) {
    #blog-page .blogListMain .blog_inner:first-child {
        padding-top:0 !important
    }
}

#blog-page .blogListMain .blog_contents {
    height: auto !important;
    overflow: auto
}

#blog-page .blogListMain .blog_publish {
    margin: 5px 0 !important
}

#blog-page .blogListMain .blog_body {
    margin: 10px 0
}

@media screen and (min-width: 768px) {
    #blog-page .blogListMain .blog_body {
        margin:15px 0
    }
}

#blog-page .blogListMain .blog_title h2 {
    font-size: 20px;
    font-family: "Noto Sans JP",sans-serif
}

@media screen and (min-width: 768px) {
    #blog-page .blogListMain .blog_title h2 {
        font-size:22px
    }
}

body.is-ttlFontDesignOption-mintyo #blog-page .blogListMain .blog_title h2 {
    font-family: "Noto Serif JP",serif;
    font-weight: bold
}

body.is-ttlFontDesignOption-maru #blog-page .blogListMain .blog_title h2 {
    font-family: "M PLUS Rounded 1c",sans-serif
}

#blog-page .blogListMain .blog_head_image img {
    border-radius: 20px
}

#blog-page .blogListMain ul.paginate {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

#blog-page .blogListMain ul.paginate li {
    position: relative;
    border: none
}

#blog-page .blogListMain ul.paginate li a {
    width: 31px;
    height: 31px;
    border-radius: 50%;
    border: 1px solid #919191;
    color: #3e3e3e;
    font-weight: bold;
    background-color: transparent;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    letter-spacing: 0;
    vertical-align: top
}

@media screen and (min-width: 768px) {
    #blog-page .blogListMain ul.paginate li a {
        width:41px;
        height: 41px
    }
}

#blog-page .blogListMain ul.paginate li.current a {
    color: #fff;
    background-color: #3e3e3e
}

#blog-page .blogListMain ul.paginate li.prev a,#blog-page .blogListMain ul.paginate li.next a {
    font-size: 0
}

#blog-page .blogListMain ul.paginate li.prev a::after,#blog-page .blogListMain ul.paginate li.next a::after {
    content: "";
    width: 5px;
    height: 5px;
    border: 0px;
    border-top: solid 2px #919191;
    border-right: solid 2px #919191;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto
}

@media screen and (min-width: 768px) {
    #blog-page .blogListMain ul.paginate li.prev a::after,#blog-page .blogListMain ul.paginate li.next a::after {
        width:8px;
        height: 8px
    }
}

#blog-page .blogListMain ul.paginate li.prev a::after {
    -webkit-transform: translate(1px, 0px) rotate(-135deg);
    transform: translate(1px, 0px) rotate(-135deg)
}

#blog-page .blogListMain ul.paginate li.next a::after {
    -webkit-transform: translate(-1px, 0px) rotate(45deg);
    transform: translate(-1px, 0px) rotate(45deg)
}

#blog-page .blogDetail {
    padding: 0;
    width: 700px;
    max-width: 100%
}

#blog-page .blogDetail .blog_inner {
    border: none !important;
    padding: 20px 0 0 0 !important
}

@media screen and (min-width: 768px) {
    #blog-page .blogDetail .blog_inner {
        padding-top:0 !important
    }
}

#blog-page .blogDetail .blog_contents a {
    text-decoration: underline
}

#blog-page .blogDetail .blog_body {
    margin: 20px 0 60px
}

#blog-page .blogDetail .blog_body a {
    text-decoration: underline
}

#blog-page .blogDetail .blog_title h2 a {
    pointer-events: none;
    text-decoration: none
}

#blog-page .blogDetail .blog_publish {
    margin: 0 !important
}

#blog-page .blog_title h2 {
    letter-spacing: .1em;
    margin-bottom: 0px;
    font-family: "Noto Sans JP",sans-serif
}

body.is-ttlFontDesignOption-mintyo #blog-page .blog_title h2 {
    font-family: "Noto Serif JP",serif;
    font-weight: bold
}

body.is-ttlFontDesignOption-maru #blog-page .blog_title h2 {
    font-family: "M PLUS Rounded 1c",sans-serif
}

#blog-page .blog_head_image {
    margin: 15px 0 5px
}

@media screen and (min-width: 768px) {
    #blog-page .blog_head_image {
        margin:15px 0
    }
}

#blog-page .blog_head_image img {
    width: 100%
}

#blog-page .read_more {
    bottom: 0 !important;
    padding-top: 0 !important;
    position: relative !important;
    margin-top: 15px
}

@media screen and (min-width: 768px) {
    #blog-page .read_more {
        margin-top:30px
    }
}

#blog-page .read_more a {
    width: 100%
}

.main .blogDetail .social {
    padding: 40px 0 20px
}

@media screen and (min-width: 768px) {
    .main .blogDetail .social {
        padding:40px 0 0
    }
}

.main .blogDetail .social li {
    padding: 10px;
    margin: 0 5px !important;
    background-color: #fff;
    border-radius: 5px
}

.main .blogDetail .social .btn01,.main .blogDetail .social .btn02,.main .blogDetail .social .item-detail__form .purchaseButton button,.item-detail__form .purchaseButton .main .blogDetail .social button,.main .blogDetail .social .item-detail__form .purchaseButton .purchaseButton__btn,.item-detail__form .purchaseButton .main .blogDetail .social .purchaseButton__btn,.main .blogDetail .social #blog-page .read_more a,#blog-page .read_more .main .blogDetail .social a {
    display: inline-block !important
}

.inquirySection form {
    width: 100%;
    max-width: 650px;
    text-align: left;
    font-size: 16px;
    margin: 40px auto 0
}

@media screen and (min-width: 768px) {
    .inquirySection form {
        margin:40px auto 0
    }
}

.inquirySection form input,.inquirySection form textarea {
    padding: 10px 15px;
    font-size: 16px;
    background-color: #fff;
    border-color: #ddd
}

.inquirySection form .control-panel input#buttonLeave {
    background-color: #252525;
    color: #fff;
    padding: 20px 60px;
    font-size: 14px;
    margin: 40px auto 20px;
    letter-spacing: .1em;
    border-radius: 60px
}

@media screen and (min-width: 768px) {
    .inquirySection form .control-panel input#buttonLeave {
        margin:40px auto 0
    }
}

.inquirySection form .error-message {
    font-size: 13px;
    margin: 0px 0 30px;
    color: #e74c3c;
    font-weight: bold;
    display: block;
    position: relative;
    background-color: #ffebeb;
    padding: 5px 10px
}

.inquirySection form .error-message::after {
    border: solid transparent;
    content: "";
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    border-color: rgba(0,153,255,0);
    border-top-width: 5px;
    border-bottom-width: 5px;
    border-left-width: 5px;
    border-right-width: 5px;
    margin-left: -5px;
    bottom: 100%;
    left: 5%;
    border-bottom-color: #ffebeb
}

#inquiryCompleteSection a {
    background-color: #252525;
    color: #fff;
    padding: 20px 40px;
    font-size: 14px;
    margin: 40px auto 20px;
    letter-spacing: .1em;
    border-radius: 60px;
    width: auto !important;
    max-width: 400px
}

@media screen and (min-width: 768px) {
    #inquiryCompleteSection a {
        margin:40px auto 0
    }
}

.item-detail__form input[type=text] {
    padding: 0 20px 0 10px;
    height: 40px !important;
    border-radius: 5px;
    border-color: #ddd;
    width: 100%;
    margin: 8px 0;
    background-color: #fff;
    font-size: 13px !important
}

.item-detail__form select {
    padding: 10px 25px 10px 10px !important;
    min-width: 100px;
    width: 100%;
    border-radius: 5px;
    border-color: #ddd;
    min-height: 40px !important;
    margin: 8px 0;
    background-color: #fff !important;
    background-position: right 10px center !important;
    font-size: 13px !important
}

body.is-animationFadeInDesignOption-true .fadeUp {
    opacity: 0;
    -webkit-transform: translateY(5px);
    transform: translateY(5px);
    -webkit-transition: all .3s ease-in;
    transition: all .3s ease-in
}

body.is-animationFadeInDesignOption-true .fadeUp.active {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
}

body.is-animationFadeInDesignOption-true .fadeIn {
    opacity: 0;
    -webkit-transition: all .3s ease-in;
    transition: all .3s ease-in
}

body.is-animationFadeInDesignOption-true .fadeIn.active {
    opacity: 1
}

.slider-kv {
    position: relative
}

.slider-kv .slick-dots {
    position: absolute;
    bottom: 40px;
    right: 0;
    left: 0;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    z-index: 3
}

@media screen and (min-width: 768px) {
    .slider-kv .slick-dots {
        bottom:40px
    }
}

.slider-kv .slick-dots li {
    height: .5em
}

.slider-kv .slick-dots li.slick-active button::before {
    background-color: #fff
}

.slider-kv .slick-dots li button {
    font-size: 0;
    position: relative;
    border: none;
    padding: 5px;
    background-color: transparent;
    cursor: pointer
}

.slider-kv .slick-dots li button::before {
    content: "";
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color: rgba(255,255,255,.5);
    display: block;
    -webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,.1);
    box-shadow: 0px 0px 10px 0px rgba(0,0,0,.1)
}

@media screen and (min-width: 768px) {
    .slider-kv .slick-dots li button::before {
        width:8px;
        height: 8px
    }
}

.slider-kv .slick-arrow {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto 0;
    z-index: 10;
    background-color: transparent;
    border: none;
    font-size: 0;
    cursor: pointer;
    background-color: #fff;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 30px;
    height: 30px
}

.slider-kv .slick-arrow::before {
    content: "";
    width: 10px;
    height: 10px;
    border: 0px;
    border-top: solid 2px #3e3e3e;
    border-right: solid 2px #3e3e3e;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.slider-kv .slick-arrow.slick-prev {
    left: -35px
}

.slider-kv .slick-arrow.slick-prev::before {
    -webkit-transform: translate(2px, 0px) rotate(-135deg);
    transform: translate(2px, 0px) rotate(-135deg)
}

.slider-kv .slick-arrow.slick-next {
    right: -35px
}

.slider-kv .slick-arrow.slick-next::before {
    -webkit-transform: translate(-2px, 0px) rotate(45deg);
    transform: translate(-2px, 0px) rotate(45deg)
}

.slider-relatedItems {
    position: relative
}

.slider-relatedItems .slick-track {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.slider-relatedItems .slick-slide {
    height: auto !important
}

.slider-relatedItems .slick-dots {
    position: absolute;
    bottom: -22px;
    right: 0;
    left: 0;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    z-index: 3
}

.slider-relatedItems .slick-dots li {
    height: .5em
}

.slider-relatedItems .slick-dots li.slick-active button::before {
    background-color: #3e3e3e
}

body.is-bodyColorDesignOption-dark .slider-relatedItems .slick-dots li.slick-active button::before {
    background-color: #fff
}

.slider-relatedItems .slick-dots li button {
    font-size: 0;
    position: relative;
    border: none;
    padding: 5px;
    background-color: transparent;
    cursor: pointer
}

.slider-relatedItems .slick-dots li button::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: rgba(0,0,0,.1);
    display: block
}

body.is-bodyColorDesignOption-dark .slider-relatedItems .slick-dots li button::before {
    background-color: rgba(255,255,255,.3)
}

.faq-click__a {
    display: none;
    height: 0
}

.faq-click__a.is-active {
    display: block;
    height: 100%;
    -webkit-animation: faqshow .3s ease-in;
    animation: faqshow .3s ease-in
}

@-webkit-keyframes faqshow {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes faqshow {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

body.is-animationFadeInDesignOption-true .about-kv__img {
    -webkit-animation: pagefadeImage 1.5s 0s forwards;
    animation: pagefadeImage 1.5s 0s forwards
}

body.is-animationFadeInDesignOption-true .top-shop__img.active {
    -webkit-animation: pagefadeImage 1s 0s forwards;
    animation: pagefadeImage 1s 0s forwards
}

@-webkit-keyframes pagefadeImage {
    0% {
        -webkit-transform: scale(1.03);
        transform: scale(1.03)
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@keyframes pagefadeImage {
    0% {
        -webkit-transform: scale(1.03);
        transform: scale(1.03)
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@media all and (-ms-high-contrast: none) {
    *::-ms-backdrop,.ie-only {
        display: none
    }
}

.item-detail__detailContents .product-content img{
    width:auto !important;
    margin: 10px auto;
}
.item-detail__detailContents .product-content{
    margin: auto;
}