/** Shopify CDN: Minification failed

Line 6223:0 Unexpected "}"
Line 6324:56 Unterminated string token

**/
@charset "utf-8";

@font-face {
  font-family: 'Noto Sans JP';
   src: url("/cdn/shop/files/NotoSansJP-Regular.woff?v=1710872515;") format("woff");
  font-weight: normal;
  font-style: normal;
}



/*
input[type~=radio] [id$="main-onesize-size"] {display:none;}
label [id$="main-onesize-size"] {display:none;}
.one_size_text {display:none;}
*/

a img:hover {opacity:0.9}

@media (max-width: 1199px) {
    #container {
        padding: 0px 1px 20px 1px;
    }

    .no-sp {
        display: none;
    }
}

@media (min-width: 1200px) {
    #container {
        padding: 0px 1px 0px 1px;
      max-width:1200px; 
      margin:0 auto;
      
    }

    .no-pc {
        display: none;
    }
}


/* =====================
 For SmartPhone Styles
==================== */

p, h1, h2, h3, h4, h5, h6, li, caption, td, th, dt, dd, input, textarea, select, address, a, span, strong {
font-family: 'Noto Sans JP','Helvetica, ',"Hiragino Kaku Gothic ProN", "Hiragino Sans", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Lucida Grande", Meiryo, "メイリオ", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
 letter-spacing: 0.1em; 
 font-weight:normal;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 500 !important;
}

a {
    text-decoration: none;
    color: #222;
}


@media (max-width: 1200px) {

    img {
        width: 100%;
        height: 100%;
    }


}


html {
    overflow-x: hidden;
}


body {
    font-size: 100%;
    min-width: 0;
    min-height: 100vh;

    overflow-x: hidden;
    -webkit-text-size-adjust: none;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 1199px) {

    div.wrapper {
        overflow: hidden;
        min-height: 100vh;
    }


    body {
        overflow-x: hidden;

    }
}


div.nav_overlay {
    z-index: -1;
    background: #000;
    opacity: 0;
    position: fixed;
    width: 100%;
    height: 100%;
    transition: opacity 0.1s;
}

body.nav_open,
body.filters_open {
    overflow-x: hidden;
}

body.nav_open div.nav_overlay,
body.filters_open div.nav_overlay {
    z-index: 99;
    opacity: 0.5;
}

section.main {
    position: static;
    /* transition:transform 0.5s;
        transform:translateX(0);

    padding-top: 104px;
  */
      padding-top: 60px;
    z-index: 1;
  
}

body.nav_open section.main,
body.filters_open section.main {
     transform:translateX(0px);
}


/* ======== Header ======== */

@media (min-width: 1200px) {

    .menu-header { /* WL変更 */

        height: 50px;
        padding: 5px;
        position: static;
        left: 0;
        top: 0;
        z-index: 100;
        width: 100%;
        box-sizing: border-box;
        background: #fff;

    }

    header div.logo {

        width: 230px;
        overflow: hidden;
        margin: 18px auto 0 auto;
        padding: 0;

      position:absolute;
      top: 10px;
      left: 50%;
      transform: translate(-50%, 0%);
      -webkit-transform: translate(-50%, 0%);
      -ms-transform: translate(-50%, 0%);
        z-index: 100;
    }

    header div.logo a {
        width: 100%;
        height: 100%;
        display: block;
    }


    header div.logo img {
        width: 230px;
        height: auto;
    }


    /*mobile menu*/
    header nav {
        position: absolute;
        box-sizing: border-box;
        width: 100%;
        z-index: 50; /* WL変更 カート通知重なり順調整のため z-index: 1; */
        top: 0;
        left: 0;
        padding: 13px 15px;
    }

    header nav.search {
        z-index: 55; /* WL変更 カート通知重なり順調整のため z-index: 6; */
    }

    header a.sp_nav_menu {
        display: none;
        /* display:block; */


        width: 30px;
        height: 30px;
        float: left;
        margin: 16px 20px 0;
    }

    header a.sp_nav_menu span {

        width: 100%;
        height: 1px;
        background: #666;
        display: block;
        margin-top: 7px;
        border-radius: 3px;
    }

    header a.sp_nav_menu span:first-child {
        margin-top: 0;
    }

    header a.cart {

        width: 30px;
        height: 30px;
        display: block;
        background: url(./sp_cart.png) no-repeat;
        background-size: contain;
        float: right;
        position: relative;
        text-decoration: none;
        color: #000;
        z-index: 7;
        margin-top: 13px;
        margin-right: 20px;
    }

    header a.cart span {
        font-size: 140%;
        display: block;
        font-weight: 500;
        text-align: center;
        margin-top: -0.25em;
        margin-left: 3px;
    }

    header div.search {

        position: absolute;
        width: 40px;
        height: 40px;
        top: 25px;
        left: 30px;
        overflow: hidden;
        z-index: 999999;
    }

    header div.search input.search_icon {
        width: 28px;
        height: 28px;
        overflow: hidden;
        border: none;
        background: #fff url(./icon_search.png) no-repeat;
        background-size: contain;
        text-indent: -9999px;
        outline: none;
        position: absolute;
        top: 1px;
        z-index: 2;
    }

    header div.search input[type~=text] {
        border: none;
        border-bottom: 1px solid #000;
        padding: 0 0 0 50px;
        top: 0;
        height: 35px;
        width: 100%;
        margin-bottom: 0;
        background: #ccc;
        position: relative;
        z-index: 1;
        outline: none;
        font-size: 200%;
        display: none;

    }

    header div.search.open {
        box-sizing: border-box;
        width: 100%;
        height: 75px;
        padding-right: 154px;
    }

    header div.search.open input[type~=text] {
        display: block;
    }

    /* WL追加 PCメニュー 日/英切り替えリンクデザインのため */
    header a.lang {
        width: 60px;
        height: 30px;
        letter-spacing:0em;
        float: right;
        font-size: 12px;
        position: relative;
        z-index: 7;
        margin-top: 20px;
        margin-right: 11px;
    }
    /* WL追加 ここまで */

    header a.mypage {
        width: 24px;
        height: 24px;
        display: block;
        background: url(./mypage.png) no-repeat;
        background-size: contain;
        float: right;
        position: relative;
        text-decoration: none;
        z-index: 7;
        margin: 13px 3px 0 0;

        text-indent: 100%;
        white-space: nowrap;
        overflow: hidden;


    }


}

/**/

@media (max-width: 1199px) {

    .menu-header {
        height: 0px;
        padding: 0px;
    }


    header {
        height: 5px;
        padding: 15px;
        position: static;
        top: 0;
        z-index: 50;
        width: 100%;
        box-sizing: border-box;
        background: #fff;
    }

    header div.logo {

        width: 170px !important;
        height: 41px;
        text-indent: -9999px;
        overflow: hidden;
        margin: 0 auto;
        padding: 0;
        position: absolute; 
        top: 12px;
        left: 50%;

        transform: translate(-50%, -0%);
       -webkit-transform: translate(-50%, -0%);
       -ms-transform: translate(-50%, -0%);

        z-index: 5;
    }

    header div.logo a {
        width: 100%;
        height: 100%;
        display: block;
    }

    header div.logo a img {
        width: 170px !important;
        height: auto;
    }


    header nav {
        position: absolute;
        box-sizing: border-box;
        width: 100%;
        z-index: 1;
        top: 0;
        left: 0;
        padding: 11px 15px;
    }

    header nav.search {
        z-index: 6;
    }

    header .sp_nav_menu {
        color:#fff;
    }

    header a.sp_nav_menu {
        width: 24px;
        height: 24px;
        display: block;
        float: left;
        margin: 4px 2px 0;
    }

    header a.sp_nav_menu span {
        width: 100%;
        height: 1px;
        background: #000;
        display: block;
        margin-top: 7px;
    }

    header a.sp_nav_menu span:first-child {
        margin-top: 2px;
    }

    /* WL追加 PCメニュー 日/英切り替えリンクデザインのため */
    header a.lang {
        width: 50px;
        height: 30px;
        float: right;
        font-size: 12px;
        position: relative;
        z-index: 7;
        margin-top: 6px;
        margin-right: 6px;
    }
    /* WL追加 ここまで */

    header a.cart {
        width: 28px;
        height: 28px;
        display: block;
        background: url(./sp_cart.png) no-repeat;
        background-size: contain;
        float: right;
        position: relative;
        text-decoration: none;
        color: #000;
        z-index: 7;
        margin-top: 4px;
    }

    header a.cart span {
        font-size: 120%;
        display: block;
        font-weight: 500;
        text-align: center;
        margin-top: -0.25em;
        margin-left: 3px;
    }

    header div.search {
        position: absolute;
        width: 26px;
        height: 31px;
        top: 12px;
        left: 52px;
        overflow: hidden;
    }

    header div.search input.search_icon {
        width: 20px;
        height: 20px;
        overflow: hidden;
        border: none;
        background: #fff url(./icon_search.png) no-repeat;
        background-size: contain;
        text-indent: -9999px;
        outline: none;
        position: absolute;
        top: 2px;
        z-index: 2;
    }

    header div.search input[type~=text] {
        border: none;
        border-bottom: 2px solid #000;
        padding-left: 38px;
        bottom: 0;
        height: 29px;
        width: 100%;
        background: #fff;
        position: relative;
        z-index: 1;
        outline: none;
        font-size: 175%;
        display: none;
    }

    header div.search.open {
        box-sizing: border-box;
        width: 100%;
        height: 31px;
        padding-right: 154px;
    }

    header div.search.open input[type~=text] {
        display: block;
    }


    header a.mypage {
        width: 20px;
        height: 20px;
        display: block;
        background: url(./mypage.png) no-repeat;
        background-size: contain;
        float: right;
        position: relative;
        text-decoration: none;
        z-index: 7;
        margin: 6px 3px 0 0;

        text-indent: 100%;
        white-space: nowrap;
        overflow: hidden;


    }


}

/**/


/* ======== Navigation ======== */
nav.slide_nav {
    position: fixed;
    top: 0;
    left: -301px;
    width: 300px;
    height: 100vh;
    z-index: 100;
    transition: left 0.5s;
    transition: transform 0.5s;
    transform: translateX(0);
    overflow: hidden;
    background: rgba(255, 255, 255, 0.98);
}

body.nav_open nav.slide_nav {
    transform: translateX(300px);
}

nav.slide_nav a.close {
    display: block;
    width: 24px;
    height: 24px;
    text-indent: -9999px;
    background: url(icon_close.png) no-repeat;
    opacity:0.7;
    background-size: contain;
    z-index: 3;
    padding: 0;
    margin: 13px 15px 10px;
    border-bottom: none;
}

nav.slide_nav div.slide_wrapper {
    position: absolute;
    left: 0;
    top: 0;
    width: 9999px;
    height: 100vh;
    transition: transform 0.5s;
}

nav.slide_nav div.slide_wrapper > div {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100vh;
    overflow-y: scroll;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

nav.slide_nav div.dpt2 {
    left: 300px;
}

nav.slide_nav div.dpt3 {
    left: 600px;
}

nav.slide_nav div.dpt4 {
    left: 900px;
}

nav.slide_nav div.dpt5 {
    left: 1200px;
}

nav.slide_nav div.dpt6 {
    left: 1500px;
}

nav.slide_nav div.slide_wrapper div > ul:after {
    display: block;
    content: "";
    height: 100px;
    width: 100%;
}

nav.slide_nav ul {
    position: absolute;
    width: 300px;
    height: 100%;
    left: 0;
    overflow: visible;
    transition: margin-left 0.1s;
    border-right: 1px solid #d6d6d6;
}

nav.slide_nav ul li {
    box-sizing: border-box;
    font-size: 125%;
    text-transform:uppercase;
}

nav.slide_nav ul li ul li {
    font-size: 100%;
    
}

nav.slide_nav ul li.cat-lv1 {
}

nav.slide_nav ul li.cat-lv2 a {
    padding-left: 40px;
    text-indent: -1em;
}

nav.slide_nav ul li.cat-lv2 a:before {
    content: "- ";
}

nav.slide_nav ul li a,
nav.slide_nav ul li strong {
    box-sizing: border-box;
    padding: 12px 30px;
    width: 100%;
    font-size: 100%;
    display: inline-block;
    font-weight: 400;
    border-bottom: 1px solid #dddddd;
}

nav.slide_nav ul li strong {
    font-size:110%;
    font-weight: 500;
    text-align:center;

}


nav.slide_nav ul.alphabet li:nth-child(1n+2) {
    width: 50px;
    float: left;
    border-right: 1px solid #dddddd;
}

nav.slide_nav ul.alphabet li.title {
    width: 100%;
    float: none;
}

nav.slide_nav ul.alphabet li:nth-child(1n+2) a {
    padding: 15px 0;
    width: 50px;
    text-align: center;
}

nav.slide_nav ul li a {
    background: url(./arrow_right.gif) right no-repeat;
    background-size: 5px 10px;
    background-position: right 10px bottom 50%, 0 0;
}

nav.slide_nav ul li strong {
    background: #fff url(./arrow_left.gif) left no-repeat;
    background-size: 5px 10px;
    background-position: left 10px top 50%;
}

nav.slide_nav ul li.border a {
    border-bottom: 1px solid #000;
}

nav.slide_nav ul li.end a {
    background: none;
}

nav.slide_nav ul li a.active {
    background: #eee;
}

nav.slide_nav ul.alphabet li:nth-child(1n+2) a {
    background: none;
}

nav.slide_nav ul li a span.nav-update {
    font-size: 80%;
}

nav.slide_nav ul li ul {
    position: absolute;
    margin-left: 300px;
    left: 0;
    top: 0;
    opacity: 0;
    z-index: 10
}

nav.slide_nav ul li ul li ul {
}

nav.slide_nav ul li a img {
    margin-top: 0.5em;
}

/* Alphabet Toggle */

nav.slide_nav ul li.toggle {
}

nav.slide_nav li.toggle ul {
    position: relative;
    width: 300px;
    height: 100%;
    margin-left: 0;
    display: none;
}

nav.slide_nav ul li.toggle.open ul {
    display: block;
    opacity: 1;
}

nav.slide_nav ul li.toggle.open ul li a {
    padding-left: 40px;
}

nav.slide_nav ul li.toggle.open > a {
    background: url(./arrow_down.gif) right no-repeat;
    background-size: 10px 5px;
    background-position: right 10px bottom 50%, 0 0;
}

/*-- Filters --*/


/*-- Filters --*/
/* button

section.content nav.filters{
    right:30px;
    position:fixed;
    bottom:50px;
    z-index:1;
}



section.content nav.filters div{
    width:50px;
    height:50px;
    display:block;
    border-radius:50%;
    padding:10px;
    background:#fff url(./icon_filters.gif) no-repeat;
    border:1px solid #ddd;

}

section.content nav.filters a{

}
section.content nav.filters p {
    padding:30px 0 0 5px;
    color:#000;
    font-size:100%;

}

*/


nav.slide_filters {
    position: fixed;
    top: 0;
    right: -301px;
    width: 300px;
    height: 100vh;
    max-height: 100%;
    z-index: 200; /* WL変更 PCメニュー・ヘッダーより上した z-index: 100 */;
    transition: left 0.1s;
    transition: transform 0.2s;
    transform: translateX(0);
    overflow: hidden;
    background: #efefef;
}


@media (max-width: 1199px){
    #boost-pfs-filter-tree2 {
        display: none;
    }
}
/* ここまで */
body.filters_open nav.slide_filters {
    transform: translateX(-300px);
}

nav.slide_filters form > div {
    position: absolute;
    background: #efefef;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    padding-top: 160px;
    margin-top: -160px;
    box-sizing: border-box;
    z-index: 1;
}

nav.slide_filters ul {
    width: 300px;
    left: 0;
    transition: margin-left 0.1s;
    border-right: 1px solid #d6d6d6;
}

nav.slide_filters ul li {
    box-sizing: border-box;
    font-size: 140%;
}

nav.slide_filters ul li ul li {
    font-size: 100%;
    background: #fff;
    box-sizing: border-box;
    /* padding:10px 20px 10px 40px; */
    width: 100%;
    border-bottom: 1px solid #b4b4b4;
    position: relative;
}

nav.slide_filters ul li a,
nav.slide_filters ul li strong,
nav.slide_filters p:first-child {
    box-sizing: border-box;
    padding: 10px 20px;
    width: 100%;
    font-size: 100%;
    font-weight: 500;
    display: inline-block;
    border-bottom: 1px solid #b4b4b4;
}

nav.slide_filters p:first-child {
	text-align:center;
}

/* WL追加ここから: 絞りこみ メインカテゴリのデザイン */
nav.slide_filters ul li a.filter-main-category-value {
    background: none !important;
    font-family:'Noto Sans JP', Helvetica, "Lucida Grande", Meiryo, "メイリオ", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 400 !important;
    border-bottom: none;
}
/* WL追加ここまで */

nav.slide_filters ul li strong {
    font-weight: 500;
}

nav.slide_filters ul li a span.activated_filter {
    color: #999;
    display: block;
    font-size: 85%;
    margin-top: 4px;
    font-weight: 300;
}

nav.slide_filters ul li a span.activated_filter span:before {
    content: ", ";
}

nav.slide_filters ul li a span.activated_filter span:first-child:before {
    content: "";
}

nav.slide_filters p:first-child {
    font-size: 140%;
}

nav.slide_filters p:first-child strong {
  /*
    background: url(./icon_filters_open.gif) left no-repeat;
    padding-left: 22px;
  background-size: 17px 17px;
  */
    padding: 8px 0 0 5px;

}

nav.slide_filters ul li.close > a {
    background: url(./arrow_right.gif) right no-repeat;
    background-size: 5px 10px;
    background-position: right 10px bottom 50%, 0 0;
    font-weight: 500;
}

nav.slide_filters ul li.open a {
    background: url(./arrow_down.gif) right no-repeat;
    background-size: 10px 5px;
    background-position: right 7px bottom 50%, 0 0;
    font-weight: 500;
}

nav.slide_filters ul li strong {
    font-weight: 500;
}

nav.slide_filters ul li.close ul {
    display: none;
}

nav.slide_filters ul li.open ul {
    display: block;
}

nav.slide_filters input[type~=checkbox] {
    width: 1em;
    height: 0;
    border: none;
    margin: 0 0.3em 0 0;
    position: absolute;
    left: 10px;
    top: 50%;
    -webkit-appearance:none; /* WL追加 ブラウザのデフォルトチェックボックスデザインを非表示 */
}

nav.slide_filters input[type~=checkbox]:before {
    position: relative;
    content: "";
    display: inline-block;
    top: -0.6em;
    width: 0.75em;
    height: 0.75em;
    border: 0.5px solid #ccc;
}

nav.slide_filters input[type~=checkbox]:checked:before {
    background: #222 url(./check.png) left 50% top 50% no-repeat;
    background-size: 60% 60%;
}

nav.slide_filters li label {
    position: relative;
    padding: 10px 20px 10px 40px;
    width: 100%;
    display: inline-block;
    box-sizing: border-box;
}

nav.slide_filters input.apply {
    -webkit-appearance: none;
    background: #fff;
    display: block;
    border: none;
    border-radius: 0;
    margin: 0 0 100px;
    padding: 5px;
    width: 80%;
    font-size: 140%;
    font-weight: 500;
    position: fixed;
    bottom: 0;
    left: 10%;
    z-index: 2;
    color: #000 !important;
}


/* ======== Footer ======== */

footer {
    position: relative;
    z-index: 1;
    text-align: center;
}

footer ul {
    margin: 30px auto 10px auto;
/*    border-top: 1px solid #d6d6d6; */
    padding-top: 20px;
    width: 100%;
    display: flex;
    justify-content: center;
    flex-wrap: nowrap;
}

footer ul li {
    font-size: 110%;
    margin: 10px;
    color: #ccc;
}


footer div#followus {
    /* margin-top:20px; */
    padding: 20px;
    margin-right: -15px;

}


footer div#followus div.follow-ic {
    width: 30px;
    height: 30px;
    margin-right: 15px;
    display: inline-block;
}

footer div#followus div.follow-ic a {
    width: 30px;
    height: 30px;
    display: block;
    overflow: hidden;
}

footer div#followus div.follow-ic a img {
    width: 30px;
    height: 60px;
}

footer div#followus div.follow-ic a:hover img {
    margin-top: -30px;
}


footer div#copyrights {
    margin: 2em 0;
}



/* ======== Contents ======== */

section {
    padding: 0px 0;
/*    padding: 5px 0;  */
}

.collection-grid-section {
  padding:0 5px;
}

section.content {
    padding: 0 5px 10px 5px;
    position: relative;
    z-index: 5;
    line-height: 1.5;
}

section.content h1 {
    font-weight: normal;
}

section.content h2 {
    font-size: 180%;
    text-align: center;
    margin: 0px;
    font-weight: normal;
}

section.content nav.path ol {
    margin: 10px 0;
}

section.content nav.path ol li {
    display: inline-block;
    font-size: 140%;
    margin-right: 0.3em;
}

section.content nav.path ol li strong {
    font-weight: normal;
}

section.content nav.path ol li:after {
    content: " /";
}

section.content nav.path ol li:last-child:after {
    content: "";
}

section.content p {
    font-size: 120%;
}

section.content li {
    font-size: 120%;
}

select {
    width: 100%;
    background: #fff;
    border: 1px solid #000;
    border-radius: 4px;
    height: 2em;
}

/* WL追加 ここから */
.adrs-edit-box select {
    width: 100%;
    background: #fff;
    border: 1px solid #000;
    border-radius: 4px;
    height: 30px;
}

/* WL追加 ここまで */

/*-- Filters --*/

section.content nav.filters {
    padding: 0 0 10px;
}

section.content nav.filters a,
section.content div.boost-pfs-filter-tree-mobile-button button { /* WL変更 */
    font-size: 140%;
    height: 10px;

  /*
    line-height: 1.1;
    display: inline-block;

  background: url(./icon_filters.gif) left no-repeat;
    background-size: contain;
    padding-left: 24px; 
  */
  /* WL変更 */
}


/*-- aside --*/


/* ======== Toppage ======== */


section.content.toppage ul.newarrivals {}

section.content.toppage {
    padding: 0px;

}

@media (min-width: 1200px) {
    section.content.toppage {
        /*margin-top: 40px;*/ /*WL変更*/
    }


}


section.content.toppage ul.newarrivals_slider p {

}

section.content.toppage ul.newarrivals {
    border-top: 1px solid #000;
}

section.content.toppage ul.newarrivals li {
    border-bottom: 1px solid #000;
    overflow: hidden;
}

section.content.toppage ul.newarrivals li a {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
}

section.content.toppage ul.newarrivals li img {
    max-width: 40%;
    margin-left: 8%;
    margin-right: 2%;
}

section.content.toppage ul.newarrivals li span {
    width: 49.5%;
}

section.content.toppage ul.topics {
}

section.content.toppage ul.recommended {
}

section.content.toppage ul.styles {

}

section.content.toppage ul.styles:after,
section.content.toppage ul.selection:after {
    content: "";
    display: block;
    clear: both;
}

/*
section.content.toppage ul.topics li,
section.content.toppage ul.recommended li{
    width:50%;
    float:left;
}*/

section.content.toppage ul.topics li,
section.content.toppage ul.recommended li,
section.content.toppage ul.styles li,
section.content.toppage ul.selection li {
    position: relative;
}


/* 適用する共通スタイル */
.styles li {
    box-sizing: border-box;
    transition: all 0.5s ease;
    opacity: 1; /* 追加 */
}

.styles li.hide {
    visibility: hidden;
    width: 0;
    opacity: 0; /* 追加 */
}

.tag-selector {
    margin-right: 5px;
    text-decoration: none;
}

@media (max-width: 1199px) {
    section.content.toppage ul.selection,
    section.content.toppage ul.styles {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 2px;  
        width: 100%;
        margin: 0 auto;
    }

    section.content.toppage ul.selection li,
    section.content.toppage ul.styles li {
        width: 100%;  
        box-sizing: border-box;
    }

    section.content.toppage ul.styles li img {
        height: auto;
        max-width: 100%;
        width: 100%;
    }
}

@media (min-width: 1200px) {
    section.content.toppage ul.selection,
    section.content.toppage ul.styles {
       marigin-top:30px;
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 10px;  /* 項目間のマージン */
        width: 100%;
        margin: 0 auto;
    }

    section.content.toppage ul.selection li,
    section.content.toppage ul.styles li {
        width: 100%;  
        box-sizing: border-box;
    }
  
    section.content.toppage ul.selection li img,
    section.content.toppage ul.styles li img {
        width: 100%;
        height: auto;
    }
}



/*
section.content.toppage ul.styles li {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.5s, transform 0.5s;  
}

section.content.toppage ul.styles li.show {
    opacity: 1;
    transform: translateY(0);
}
*/

/*
@media (max-width: 1199px) {


section.content.toppage ul.selection,
section.content.toppage ul.styles {
    display: flex;
    flex-wrap:wrap;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    margin: 0 auto;
}

section.content.toppage ul.selection li,
section.content.toppage ul.styles li {
    width: calc(50% - 2px);
    height: 50%;
    box-sizing: border-box;
    padding: 2px;
}

section.content.toppage ul.styles li img {
    height: auto;
    max-width: 100%;
    width: 100%;
}


}

@media (min-width: 1200px) {

section.content.toppage ul.selection,
section.content.toppage ul.styles {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    width: 100%;
    margin: 0 auto;
}

section.content.toppage ul.selection li,
section.content.toppage ul.styles li {
    width: calc(25% - 10px); 
    margin-bottom: 10px; 
   margin-right: 10px;  
    box-sizing: border-box;
}

section.content.toppage ul.selection li:nth-child(2n),
    section.content.toppage ul.styles li:nth-child(2n) {
        margin-right: 0;  
    }
  
section.content.toppage ul.selection li img,
section.content.toppage ul.styles li img {
    width: 100%;
    height: auto;
}

}
*/

section.content.toppage ul.topics h3,
section.content.toppage ul.recommended h3,
section.content.toppage ul.styles h3,
section.content.toppage ul.selection h3 {
    position: absolute;
    bottom: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    padding: 10px;
    box-sizing: border-box;
}

#slides li {
    margin-bottom: 10px;
}

#slides li a {
    position: relative;
    display: block;
}

#slides h3 {
    position: absolute;
    bottom: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    padding: 10px;
    box-sizing: border-box;
}

section.content.toppage div.slides div.pager_dots {
    margin-top: 10px;
    text-align: center;
}



/*-- Cases --*/


@media (min-width: 1200px) {

    /* ======== Products List ======== */
    ul.products,
    .boost-pfs-filter-products { /* WL追加 */
        width: 100%;
        clear: both;
        margin: 0 auto;
    }

    /* WL追加 */
    @media screen and (min-width: 1200px) and (max-width: 1400px){
        ul.products li.prd-list {
            position: relative;
            height: 650px; /* height: 756px; WL修正 #224サイズ非表示 */
        }
    }
    @media screen and (min-width: 1400px) and (max-width: 1600px){
        ul.products li.prd-list {
            position: relative;
            height: 700px; /* height: 800px; WL修正 #224サイズ非表示 */
        }
    }
    /* WL追加 */

    ul.products li.prd-list,
    .boost-pfs-filter-products li { /* WL追加 */
        font-size: 100%;
        float: left;
        line-height: 1.5em;
        overflow: hidden;
        width: 23%;
        margin-right: 1%;
        margin-bottom: 10px;

    }

    /* WL追加 */
    ul.products li.prd-filter,
    .boost-pfs-filter-products li.prd-filter {
        font-size: 100%;
        float: left;
        line-height: 1.5em;
        overflow: hidden;

        width: 100%;
        margin-right: 1%;

        padding-bottom: 30px;

    }

    /* ここまで */
    ul.products li:nth-child(1n),
    .boost-pfs-filter-products li:nth-child(1n) { /* WL追加 */
        margin-left: 1%;
    }

    ul.products li:nth-child(4n),
    .boost-pfs-filter-products li:nth-child(4n) { /* WL追加 */
    }

    ul.products li:nth-child(4n+1),
    .boost-pfs-filter-products li:nth-child(4n+1) { /* WL追加 */
    }

    ul.products li span.index-brand,
    .boost-pfs-filter-products li span.index-brand { /* WL追加 */
        color: #333;
        font-size: 120%;
        margin-top: 20px;        
        display: -webkit-box;
       /* overflow: hidden;*/
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
    }

    ul.products li span.index-name,
    ul.products li span.index-price,
    .boost-pfs-filter-products li span.index-name, /* WL追加 */
    .boost-pfs-filter-products li span.index-price { /* WL追加 */
        color: #111;
        font-size: 110%;
        height:50px;/*tnp*/
        margin-top: 1em;
        display: -webkit-box;
        overflow: hidden;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
    }

    ul.products li > a,
    .boost-pfs-filter-products li > a { /* WL追加 */
        position: relative;
        width: 100%;
        display: block;
    }

    ul.products li > a:before,
    .boost-pfs-filter-products li > a:before { /* WL追加 */
        content: "";
        display: block;
        padding-top: 125%;
    }

    ul.products li a img,
    .boost-pfs-filter-products li a img { /* WL追加 */
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: auto;

    }

    div.edit-section ul.linkset li {
        min-width: 65px;
    }


}

@media (min-width: 1600px) {

    ul.products li.prd-list {
        position: relative;
        width: 18%;
        height: 700px; /* height: 795px; WL修正 #224サイズ非表示 */
    }
}

@media (max-width: 1199px) {

    /* ======== Products List ======== */
    ul.products,
    .boost-pfs-filter-product { /* WL追加 */
        width: 100%;
        clear: both;
    }

    ul.products li.prd-list,
    .boost-pfs-filter-product li { /* WL追加 */
        position: relative;
        font-size: 90%;
        width: 48%;
        /*width:100%;*/
        float: left;
        margin-bottom: 30px;
        line-height: 1.5em;
    }

    ul.products li:nth-child(2n),
    .boost-pfs-filter-product li:nth-child(2n) { /* WL追加 */
        float: right;
    }

    ul.products li:nth-child(2n+1),
    .boost-pfs-filter-product li:nth-child(2n+1) { /* WL追加 */
        clear: both;
    }

    ul.products li span.index-brand,
    .boost-pfs-filter-product li span.index-brand { /* WL追加 */
        color: #333;
        font-size: 120%;
        margin-top: 20px;
        display: -webkit-box;
       /* overflow: hidden; */
/*        -webkit-line-clamp: 1; */
        -webkit-box-orient: vertical;
    }

    ul.products li span.index-name,
    ul.products li span.index-price,
    .boost-pfs-filter-product li span.index-name, /* WL追加 */
    .boost-pfs-filter-product li span.index-price { /* WL追加 */
        color: #111;
        height:50px; /*tnp*/
        font-size: 110%;
        margin-top: 0.5em;
        display: -webkit-box;
        overflow: hidden;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
    }

    ul.products li > a,
    .boost-pfs-filter-products li > a { /* WL追加 */
        position: relative;
        width: 100%;
        display: block;
    }

    ul.products li > a:before,
    .boost-pfs-filter-products li > a:before { /* WL追加 */
        content: "";
        display: block;
        padding-top: 125%;
    }

    ul.products li a img,
    .boost-pfs-filter-products li a img { /* WL追加 */
        position: absolute;
        left: 0;
        top: 0;
    }

    div.edit-section ul.linkset li {
        min-width: 65px;
    }


}


/* ======== Product Detail ======== */

.goods-stocks, .goods-detail {
    width: 100%;
    /*height: 120px;*/

    padding: 0px 0;
    margin: 0 0 0px 0;

    overflow: hidden;

}

/* WL追加 ここから */
.goods-stocks .one-size {
    width: auto;
}

/* WL追加 ここまで */

.goods-stocks span {
    width: 10%;
    float: left;
    font-size: 15px !important;
    list-style-type: none;
    color: #333;
    padding-top: 15px;
}

.goods-stocks .stock-ok {
    font-weight: 600;
}

.goods-stocks .stock-ng {
    text-decoration: line-through;
    color: #aaa;
}


#color-select {
    margin-top: 10px;
    width: 100%;
    clear: both;
}

#size-select {
    margin-bottom: 20px;
}


@media (min-width: 1200px) {

    section.detail {
        padding: 0 10px;

        width: 100%;
        margin: 10px auto 0 auto;
        
        z-index: 0;
        position: relative;

    }
}

@media (max-width: 1199px) {

    section.detail {
        padding: 0 5px;
        margin-top: -15px;

    }
}


section.detail h1 {
    font-size: 100%;
    margin-top: 20px;
}

section.detail h1 a.pr-brands, 
section.detail h1 div.pr-brands{
    font-size: 150%;
    display: block;
    font-weight: 500;

}

section.detail h1 span.pr-name {
    font-size: 150%;
    display: block;
    margin-top: 0.5em;
    font-weight: 500;
}

section.detail p.pr-price,
section.detail span.pr-price, /* WL追加 */
section.detail s.pr-price, /* WL追加 */
section.detail p.pr-color {
    font-size: 140%;
    margin-top: 1px;
    padding: 10px 0;
}


@media (max-width: 1199px) {

    section.detail div.pr-images {
        margin: 20px 0;
    }


    section.detail div.pr-images-pc {
        display: none;
    }

}

@media (min-width: 1200px) {


    section.detail div.pr-images {
    }


    div.pr-item-pc {
        width: 100%;
        margin-bottom: 100px;

    }

    div.pr-item-pc:after {
        content: "";
        display: block;
        padding-top: 65%;
        width: 100%;
    }


    div.pr-images-pc {
        width: 50%;
        float: left;
    }


    section.detail div#image-list {
        width: 8%;
        float: left;
        display: flex;
        flex-direction: column;
    }

    div#image-list img {
        border: 1px solid white;
        opacity: 0.6;
        width: 100%;
        margin-bottom: 1px;
    }

    div#image-list img:nth-child(1) {
        margin-top: 20px;
    }

    a.active img {
        border: 1px solid #eee !important;
        opacity: 1 !important;
    }

    div.image-main {
        width: 44vw;
        max-width: 90%;
        margin-top: 6px;
        float: left;
        margin-left: 2%;
        cursor: pointer !important;

    }

    div.image-main img,
    .zoomContainer img {
        width: 44vw !important;
        height: auto !important;

    }


    div#item-info {
        width: calc(50% - 20px);/*WL修正*/
        float: right;
        padding: 0px 0px 0 20px;
        box-sizing: border-box;
        position: sticky;
        top: 50px;

    }


}

/* pc */

section.detail div.pr-images div.bx-controls-direction {
    display: none;
}

section.detail div.pr-images div.bx-pager {
    text-align: center;
    margin-top: 20px;
}

section.detail div.pr-images div.bx-pager div.bx-pager-item {
    display: inline-block;
}

section.detail div.pr-images div.bx-pager a.bx-pager-link {
    display: inline-block;
    background: #d7d7d7;
    width: 1em;
    height: 1em;
    border-radius: 1em;
    text-indent: -9999px;
    overflow: hidden;
    margin: 0 0.5em;
}

section.detail div.pr-images div.bx-pager a.bx-pager-link.active {
    background: #707070;
}

section.detail div.pr-images div.slider div.pager_dots {
    margin-top: 10px;
    text-align: center;
}

section.detail div.pr-images div.slider div.pager_dots {
    margin-top: 10px;
    text-align: center;
}

section.detail div.pr-images div.slider div.pager_dots span.swiper-pagination-bullet {
    background: #d7d7d7;
}

section.detail div.pr-images div.slider div.pager_dots span.swiper-pagination-bullet-active {
    background: #707070;
}

section.detail div.toggle {
    overflow: hidden;
    max-height: 4.8em; /* WL変更 */
    padding: 10px;
    border-bottom: 1px solid #e7e7e7;
    border-top: 1px solid #e7e7e7;
    transition: max-height 0.1s;
}

section.detail div.toggle.open {
    max-height: 200px;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;

}

section.detail div.toggle + div.toggle {
    border-top: none;
}

section.detail div.toggle h3 {
    font-size: 140%;
    line-height: 2em;
    margin-bottom: 0.75em;
    background: url(./arrow_left.gif) right no-repeat;
    background-size: 5px 10px;
    font-weight: 400;
    cursor: pointer;
}

section.detail div.toggle.open h3 {
    background: url(./arrow_down.gif) right no-repeat;
    background-size: 10px 5px;
    font-weight: 400;
}

section.detail select {
    margin-top: 10px;
}


div.other-product {
    display: none;

}

div#wish_notice {
    margin-bottom: 20px;
}

div.buynow {
    margin-top: 20px;


}

div.buynow input,
div.buynow button { /* WL追加 */
    font-size: 130%;
    border: 2px solid;
    cursor: pointer;
    display: block;
    width: 100%;
    padding: 10px 0;
    margin: 20px 0;
    border-radius: 2px;
    -webkit-appearance: none;
}

/* WL追加 */
div.buynow button {
    font-size: 130%;
    border: none;
    cursor: pointer;
    display: block;
    width: 100%;
    padding: 10px 0;
    margin: 20px 0;
    font-weight: 400;
    background: #4e7795;
    color: #fff;
    border-radius: 7px;
}

div.buynow button:hover {
    background: #2A6195;
}

/* ここまで */

#addcart input {
    background: #4e7795;
    color: #fff;
    border-radius: 20px;
}

#addcart input:hover {
    background: #2A6195;
    color: #fff;
}

/* WL追加 */
#addcart input:disabled {
    background: #DCDCDC;
    cursor: not-allowed; /* 禁止カーソル */
}

#addcart button {
    background: #4e7795;
    color: #fff;
}

#addcart button:hover {
    background: #2A6195;
    color: #fff;
}

#addcart button:disabled {
    background: #DCDCDC;
    cursor: not-allowed; /* 禁止カーソル */
}

/* WL追加 */

#addcart a button { /* WL変更 */
    text-decoration: none;
}

#waiting input {
    background: #444;
    color: #fff;
}

#rearrive input {
    background: #00a0d2;
    border-color: #00a0d2;
    color: #fff;
}

#addwish input {
    background: #999;
    border-color: #666 #666 #666 #666;
    color: #fff;
}

input.inquiry {
    background: #fff;
    color: #000;
    border: 1px solid #ccc !important; 
    cursor: pointer;

}

p.index-price {
    padding: 0;
}

span.index-sale-price {
    color: #f00;
    padding: 5px 0 0 5px;
    font-weight: 500;
}

span.index-archive-sale-price {
    color: #00718d;
    padding: 5px 0 0 5px;
    font-weight: 500;
}

span.index-normal-price {
    text-decoration: line-through;
    padding: 5px 0 0 0;
    color: #999;
    font-weight: 500;
}

.item_btn {
    margin-top: 30px;
}


.news_btn_box {
    float: right;
    width: 25px;
    height: 20px;
    overflow: hidden;
    margin-right: 10px;
}

.news_btn_box img {
    opacity: 0.9;
    width: 25px;
}

.news_btn_box img:hover {
    margin-top: -21px;
}


.news_btn_box {
    width: 25px;
    height: 20px;
    float: left;
    margin-right: 6px;
}

.news_btn_box a {
    width: 25px;
    height: 20px;
    overflow: hidden;
    display: block;
}

.news_btn_box a img {
    width: 25px;
    height: 41px;
}

.news_btn_box a:hover img {
    margin-top: -21px;
}


@media (min-width: 1199px) {

    .idv-seealso {
        width: 80%;
        padding: 15px 0 25px;
        margin: 0 auto;
    }

    .idv-seealso h3 {
        margin-bottom: 0.5em;
        font-size: 160%;
        font-weight: 500;
        padding: 15px;
    }


    .idv-categories {
        width: 70%;
        /*margin: 0 auto;*/
        padding: 15px 0 25px;
        font-size: 120%;
        line-height: 2.5em;
    }


}

@media (max-width: 1200px) {

    .idv-seealso {
        width: 90%;
        padding: 15px 0 25px 0;
        margin: 0 auto;
    }

    .idv-seealso h3 {
        margin-bottom: 0.5em;
        font-size: 160%;
        font-weight: 500;
        padding: 15px 0;
    }


    .idv-categories {
        width: 90%;
        /*margin: 0 auto;*/
        padding: 5px 0 5px 0;
        font-size: 120%;
        line-height: 2.5em;
    }


}


/* ======== Editorial Contents ======== */

/*-- COMMON --*/

section.news p.category,
section.feature p.category {
    font-size: 140%;
    text-align: center;
}

section.news p.date,
section.news h1 {
    font-size: 160%;
    text-align: center;
    font-weight: 500;
    margin-bottom: 1em;
}

section.news p.date {
    margin-top: 2em;
}

section.news div.column_box + p.date {
    padding-top: 2em;
    border-top: 1px solid #d6d6d6;
}

section.news div.column_box p {
    margin-bottom: 1em;
}

section.news ul.pager,
section.feature ul.pager {
    margin-top: 30px;
    text-align: center;
}

section.news ul.pager {
    margin-top: 40px;
    padding-top: 40px;
    border-top: 1px solid #d6d6d6;
}

section.news ul.pager li,
section.feature ul.pager li {
    display: inline-block;
    margin: 0 4px 10px;
}

section.news ul.pager li span.current_page,
section.feature ul.pager li span.current_page {
    display: inline-block;
    background: #000;
    color: #fff;
    border-radius: 20px;
    padding: 5px;
    width: 1.5em;
    height: 1.5em;
}

section.news ul.pager li a,
section.feature ul.pager li a {
    border-radius: 20px;
    padding: 5px;
    width: 1.5em;
    height: 1.5em;
}

/*-- STYLE --*/

section.news.style div.column_box {
    display: flex;
    display: -webkit-flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    align-items: flex-start;
    -webkit-align-items: flex-start;
}

section.news.style div.column_box > p {
    width: 100%;
    display: block;
    margin: 0;
}

section.news.style div.column_box > div {
    width: 32%;
    margin-top: 15px;
    flex-basis: 32%;
    -webkit-flex-basis: 32%;
}

section.news.style div.column_box:after {
    content: "";
    width: 32%;
}

section.news.style div.column_box div.dammy {
    width: 32%;
}

section.news.style div#news-newar p,
section.news.style div.swiper-slide p {
    display: none;
}

.swiper-slide img:hover {opacity:1 !important;}

/*-- RECOMMENDED --*/

section.news.recommended img {
    margin-bottom: 0.5em;
}


/*-- FEATURE --*/

section.feature h1 {
    font-size: 200%;
    font-weight: 500;
    margin: 0.5em 0;
}

section.feature h3 {
    font-size: 140%;
    margin-top: 2em;
}

section.feature.index ul.feature_list {
    display: flex;
    display: -webkit-flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
}

section.feature.index ul.feature_list li {
    flex-basis: 100%;
    -webkit-flex-basis: 100%;
    margin-bottom: 4%;
}

section.feature.slides div.feature_slider > div {
    width: 100%;
    height: auto;
    display: block;
}


section.feature.detail {
    font-size: 140%;
    padding: 0;
}

section.feature.detail h1,
section.feature.detail h2,
section.feature.detail h3,
section.feature.detail h4,
section.feature.detail p {
    font-size: 100%;
}

section.feature.detail h1 {
    font-size: 150%;
}

section.feature.detail div.article_topimg img {
    margin-top: 0;
}

section.feature.detail .ft_article_en_link {
    font-style: italic;
    color: #555;
    margin: 0 0 20px 0;
    font-size: 18px;
}

section.feature.detail .ft_article_en_link a {
    color: #555;
}

section.feature.detail .ft_article_en_link:before {
    content: "\261B";
}

section.feature.detail .feature-ead {
    margin-bottom: 50px;
    font-weight: normal;
    text-align: left;
    color: #666;
}

section.feature.detail {
    font-size: 16px;
}

.feature-ead {
    font-size: 18px;
}

section.feature.detail img {
    margin-top: 30px;
    margin-bottom: 25px;
}

section.feature.detail .swiper-pagination {
    bottom: 20px !important;
}

section.feature.detail .ft_article_text p.intv {
    font-weight: 500;
    line-height: 180%;
    margin: 30px 0;
}

section.feature.detail .ft_article_text p.intv:before {
    content: "‐‐ "
}

section.feature.detail .ft_article_text p.info {
    font-weight: 500;
    line-height: 180%;
    margin: 30px 0 10px 0;
}

section.feature.detail .ft_article_text p.info:before {
    content: "\261B";
}

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



/* paginator */
.paginator {

    /*    clear: left; */
    /* text-align:right; */
    clear: both;
}

.paginator ul {
    display: flex;
}

/*
.paginator ul li {
    display: inline-block;
}
*/
.paginator li:first-child {
    flex-grow: 1;
}

#top-paginate.paginator {
    margin-bottom: 10px;
}

#top-paginate.paginator ul li,
#bottom-paginate.paginator ul li {
    word-wrap: normal;
   padding-right: 0.5em;
}


@media(min-width:1199px){
.pagehere {}
}
@media(max-width:1200px){
.pagehere {display:none;}
}


#top-paginate.paginator ul li.pagehere,
#bottom-paginate.paginator ul li.pagehere {
    margin-right: -1px;
 
}

#top-paginate.paginator ul li.pagehere:after,
#bottom-paginate.paginator ul li.pagehere:after {
    content: "";
    margin-right: 1px;
}

#top-paginate.paginator ul li a,
#bottom-paginate.paginator ul li a {

     padding: 15px 7px 0px 7px;
    border-radius: 3px;
  
   background:#FFF;
    color: #000;
    border:none !important;
 

}

#top-paginate.paginator ul li a:hover,
#bottom-paginate.paginator ul li a:hover {
    background: #777;
}
/*
.nav-sort {
    float: right;
    margin: 0 0 15px 0;
}

.nav-sort li {

    float: left
}

.nav-sort li:first-child {
	display:none;
}

select.sortSelector {
    width: auto !important;
  
}


.sortSelector {
    width: 50px !important;
    padding: 0 10px 0 10px;  WL変更 

    background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAHCAAAAADhOQgPAAAAM0lEQVR4AWPY+O7dn///9zM4/AcBRwaGfUDqEAMDgw2QdmEAgh3/jzCAgMV/dwYwqAViAIASGDOLUpFDAAAAAElFTkSuQmCC) 90% 50% no-repeat #000;

  background:#A6D183;
  font-size: 13px;
    color: #fff;
    border:none !important;
  margin-right:6px;
}

.sortSelectorInner {
    width: auto !important;
    padding: 0 20px 0 0;
}

.limitSelector {
	margin-top:-7px;
    padding: 0 10px;
    width: 50px;

    background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAHCAAAAADhOQgPAAAAM0lEQVR4AWPY+O7dn///9zM4/AcBRwaGfUDqEAMDgw2QdmEAgh3/jzCAgMV/dwYwqAViAIASGDOLUpFDAAAAAElFTkSuQmCC) 80% 50% no-repeat #000;

  background:#A6D183;
    color: #fff;
    font-size: 13px;
  border:none !important;
}

*/

.video {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 100%;
  /* pageflyでは使わない*/
}

.video iframe, .video object, .video embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*PC sale on off*/

a.nav-sale-link {
    color: #f00 !important;
}

/* delivery time date*/

.deliverdate {
}

/*PC archive sale on/off */


a.nav-archive-sale-link {
    color: #296781 !important;
}


/* Swiper Loading時のズレ修正 */
.swiper-container.top-page {
  visibility: hidden;
}
.swiper-container.top-page.swiper-ready {
  visibility: visible;
  transition: visibility 0s ease 0s;
}

/* 通常ページ用 Swiper */
.swiper-container:not(.top-page) {
  width: 100%;
}

/* 通常ページの画像（ボーダーなし） */
.swiper-container:not(.top-page) .swiper-slide img {
  width: 100%;
  height: auto;
  border: none;
}

/* スライド共通の構造（必要に応じて共通化） */
.swiper-container:not(.top-page) .swiper-slide {
  position: relative;
  overflow: hidden;
}


/* トップページ用 Swiper */
.swiper-container.top-page {
  position: relative;
  left: 50%;
  width: 100vw;
  margin-left: -50vw;
}


/* スライド本体 */
.swiper-container.top-page .swiper-slide {
  position: relative;
  overflow: hidden;
}

/* トップページの画像に白い境界線 */
.swiper-container.top-page .swiper-slide img {
  width: 100%;
  height: auto;
  border-left: 2px solid #fff;
  border-right: 2px solid #fff;
}



section.content.toppage ul.item-categories {
    height: 50px;

}

section.content.toppage ul.item-categories li {
    overflow: hidden;

}

section.content.toppage ul.item-categories li a {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
}

section.content.toppage ul.item-categories li img {
    max-width: 83%;
    margin-left: 2%;
    margin-right: 2%;
}

section.content.toppage ul.item-categories li span {
    width: 30.0%;
}

li#list-item {
    font-size: 100%;
    width: 25%;
    float: left;
    padding-bottom: 40px;
    line-height: 1.5em;
}

li#list-item:nth-child(2n) {

}

li#list-item:nth-child(2n+1) {

}


p.flow {
    clear: both;
    padding: 0 0 17px;
}

p.flow img {
    margin: 0 auto;
}


@media (min-width: 1200px) {

    .header-message_jp {
        margin-top: 60px;
        font-size: 12px;
        background: #4e7795;
        padding: 10px 0;
        text-align: center;
        color: #fff;

    }

}

@media (max-width: 1199px) {

    .header-message_jp {

        font-size: 90%;
        background: #4e7795;
        padding: 15px 0;
        text-align: center;
        color: #fff
    }

}


.header-message_en {

    font-size: 100%;
    background: #4e7795;
    padding: 10px 0;
    text-align: center;
    color: #fff
}

.header-message_jp div,
.header-message_en div {
    display: inline-block;
    vertical-align: top;
}

.message {
    height: 1.5em;
    overflow-y: hidden;
}

/* アニメーション */

.message span {
    position: relative;
    display: inline-block;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0 0 2px 0;
}

.message span {
    animation: messagetext 10s ease-in-out infinite;
    animation-direction: alternate;
}

@keyframes messagetext {

    0%, 50% {
        top: 0;
    }

    51%, 100% {
        top: -1.5em;
    }


    /*
      0%{
        opacity: 0;
      }

      1%,25%{
        top: 0;
        opacity: 1;
      }

      26%,50%{
        top: -1.5em;
      }

      51%,75%{
        top: -3em;
      }

      76%,100%{
        top: -4.5em;
      }
    */
}


/* 202004 renewal */

@media (min-width: 1200px) {

    .section_header_sp {
        margin: 20px auto 10px auto;
        text-align: center;
    }

    .section_header_sp h2 {
        font-size: 26px !important;
        font-weight: 500 !important;
    }

    .section_header_sp span {
        font-size: 12px;
        color:#666;
      display:none;
    }

    .section_header_sp span.sp_en {
        font-size: 13px;
        margin-top: 0;
        display:none;
    }

    /* pc */
    .sp_more_btn {
        background: #4e7795;
        color: #fff;
        font-size: 150%;
        padding: 10px 0px;
        margin: 0 auto;
        text-align: center;
        border-radius: 9px;
        width: 350px;
        display:block;
    }

    .sp_more_btn:hover {
      background-color: #2A6195;
}

    .sp_more_btn a,
    .sp_more_btn a:link { /* WL追加 */
        color: #fff;
        text-decoration: none;
    }

    .sp_more_btn:hover,
    .sp_more_btn_en:hover
    {
      background-color: #2A6195;
    }

    /* WL追加 */
    .top_recommended_link {
        color: #fff;
    }

    /* ここまで */

}

/* WL追加 */
.top_recommended_link {
    color: #fff;
}

/* ここまで */

@media (max-width: 1199px) {

    .section_header_sp {
        margin: 30px auto 20px auto;
        text-align: center;
    }

    .section_header_sp h2 {
        font-size: 18px;
        font-weight: 500 !important;
        margin-bottom: 0 !important;
    }

    .section_header_sp span {
        font-size: 11px;
        margin-top: 0;
        color:#666;
      display:none;
    }

    .section_header_sp span.sp_en {
        font-size: 11px;
        margin-top: 0;
        display:none;
    }

    /*sp*/
    .sp_more_btn {
        background: #4e7795;
        color: #fff;
        width: 330px;
        font-size: 12px;
        padding: 10px 10px;
        margin: 0 auto;
        text-align: center;
        border-radius: 9px;
    }

    .sp_more_btn a,
    .sp_more_btn a:link { /* WL追加 */
        color: #fff;
        text-decoration: none;
    }

 .sp_more_btn:hover {
      background-color: #2A6195;
}

}


.sp_feature {
    margin: 15px 0 15px 0;
    text-align: center;
}

.sp_feature img {
}

.sp_feature span {
    font-size: 11px !important;
    margin-top: 15px;
    font-weight: 500;
}

.sp_feature_title {
    text-align: center !important; /* WL変更 */
    font-size: 18px;
    font-weight: 500;
    margin: 15px auto 10px auto;
    line-height: 110%
}

.sp_feature_text {
    text-align: center !important; /* WL変更 */
    font-size: 12px;
    width: 90%;
    margin: 0 auto;
    font-weight:200;
}

.sp_feature_text p {
    margin-top: 15px;
    font-weight: 200;
    font-size: 12px !important;
}

.sp_feature_text_en {
    font-size: 11px;
    width: 50%;
    margin: 0 auto
}


.sp_style_box {
    margin: 15px auto 10px auto;
    text-align: center
}

.sp_style_box p {
    font-size: 16px !important;
    font-weight: 300;
    margin: 0 auto;
    padding-bottom: 0
}

.sp_style_box span {
    font-size: 10px;
}

.sp_style_box h5 {
    font-size: 13px;
    font-weight: 500;
}


.sp_recommended {
    margin: 15px auto 25px auto;
    text-align: center
}

.sp_recommended h4 {
    font-size: 14px;
    font-weight: 500;
    margin: 0 auto;
    padding-top: 15px;
}

.sp_recommended span {
    font-size: 10px
}


/* top page categories */

@media (min-width: 1200px) {

    li.list-item-big {
        font-size: 14px;
        font-weight: 500;
        width: 25%;
        float: left;
        padding-bottom: 40px;
        line-height: 1.5em;
        text-align: center;
    }

  


  
    li.list-item-small {
        width: 25%;
        float: left;
        padding-bottom: 40px;
        line-height: 1.5em;
        text-align: center;
        min-height: 80px;
 }


    li.list-item-small p {
        font-size: 14px;
        font-weight: 400;
        text-align:center;
	    width:100%;
	    padding:0 0 0 15px;
    }


}


@media (max-width: 1199px) {


 li.list-item-big {
        font-size: 11px;
        font-weight: 400;
        width: 25%;
        float: left;
        padding-bottom: 10px;
        line-height: 1.0em;
        text-align: center;
   		padding-right:3px;
 }

  li.list-item-big p {
  		padding-left:7px;
        font-size: 12px !important;    
  }

    li.list-item-small {
        font-size:12px;
        width: 33%;
        float: left;
        padding-bottom: 40px;
        line-height: 1.5em;
        text-align: center;
        min-height: 80px;
    }


 li.list-item-small p {
        font-size: 11px !important;
        font-weight: 400;
     	padding:0 0 0 10px;
   		height:30px;

 }

 li.list-item-small:nth-child(3n+1) {


    }

}


/* top page categories */


@media (min-width: 1200px) {
    .itemslist, .article {
        margin-top: 0px;
    }
}


.items-list-banner {
    width: 100%;
}

@media (min-width: 1200px) {
.items-list-banner img {
    width: 50%;
  margin:0 auto;
  padding:0;
}
}

@media (max-width: 1199px) {
.items-list-banner img {
  width: 80%;
  margin:0 auto;
  padding:0;
}
  
}  

.items-list-title {
    height:20px;
  /*
    padding: 15px 0 5px 0;
    border-bottom: 1px solid #ccc;
    margin-bottom: 10px;
  */  
}

.items-list-title h2 {
    display:none;
  
  	font-size: 28px !important;
    font-weight: 500;
}


.brand_info {
    min-height: 1px;
    max-height: 100px;
}


.message-close {
    position: absolute;
    right: 20px;
    top: 7px;
    cursor: pointer;
    font-size: 15px;
    color: #888;
    font-weight: 300;
    font-family: Arial, sans-serif;
    display: none !important;
}


.selection img {
    margin-bottom: 30px;
}

.selection li p {
    font-size: 90%;
}

.selection_header {
    margin: 20px auto 30px auto;
    text-align: center;
}

.selection_header h2 {
    margin: 10px 0;
    font-weight: 500;
    font-size: 30px !important;
}

.selection_header span {
    font-size: 13px;
}

.selection_line {
    margin: 0 auto;
    border-bottom: 1px solid #eee;
}

.selection_title_ja {
    margin: 30px 0 30px 0;
    text-align: left
}

.selection_title_ja h1 {
    font-weight: normal !important;
    font-size: 24px !important;
}

.selection_text_ja {
    line-height: 190%;
    font-size: 15px;
    margin: 40px 0;
}


.selection_header_en {
    margin: 20px auto 30px auto;
    text-align: center;
}

.selection_header_en h2 {
    margin: 10px 0;
    font-weight: 500;
    font-size: 32px !important;
}

.selection_header_en span {
    font-size: 13px;
}

.selection_title_en {
    margin: 40px 0 40px 0;
    text-align: left
}

.selection_title_en h1 {
    font-weight: normal !important;
    font-size: 28px !important;
}

.selection_text_en {
    line-height: 130%;
    font-size: 16px !important;
    margin: 40px 0;
}

.selection_text_en {
    font-family: "Helvetica", "Lucida Grande", sans-serif !important;
    font-weight: normal !important;
}

section.content.toppage ul.selection li {
    width: 49%;
    height: auto;
    float: left;
    overflow: hidden;
    border-right: 1px solid #eee;
    border-left: 1px solid #eee

}

section.content.toppage ul.selection li img {
    margin-bottom: 15px;
}

.sp_selection_box {
    margin: 0 auto 0px auto !important;
    text-align: center;
}

.sp_selection_box h2 {
    font-size: 14px !important;
    font-weight: 400 !important;
    margin: 0 auto;
    padding: 0 10px 0 10px;
  line-height:1.2em;
    height: 60px;
}

.sp_selection_box span {
    font-size: 12px;
}

.sp_selection_box h5 {
    font-size: 13px;
    font-weight: 500
}
section[id^="shopify-section-template--"] {
  padding:0 !important;
  margin:0px 0 0 0 !Important;
}

.section_grey {
    background: #eee;
   padding:20px 15px 25px 15px;

    border-radius: 15px;
    border-top: none !important;
}

section:after {

    content: "";
    display: block;
    clear: both;
    height: 100%;

}

/* feature pc */

@media (max-width: 1199px) {

    #feature_pc, #rec_pc {
        display: none;
    }

  ul.col_pc_list {width:100%;
                    display: flex;
  flex-wrap: wrap;
                 }

   li.col_box  {
        width: 50%;
        box-sizing: border-box;
        padding: 5px;
        min-height:410px;
       background:#fefefe;

    }

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

li.col_box span {
  display: inline-block;
  width: 90%;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

  
}


@media (min-width: 1200px) {

    #feature_sp, #rec_sp {
        display: none;
    }

    #feature_pc, #rec_pc {
    }


    .feature_wrapper_pc {
        width: 100%;
        float: left;

    }

    .feature_pc_btn {
        width: 100%;
        float: left;
        height: 100px;
        padding: 0px 0;
    }

    .feature_box {
        box-sizing: border-box;
        width: 50%;
        float: left;
        padding: 10px;
    }

    div.feature_box:nth-child(2n+1) {
        clear: both;

    }

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

   ul.col_pc_list ,
    ul.rec_pc_list {
        display: flex;
        flex-wrap: wrap;
        width: 100%;

    }

   li.col_box ,
    li.rec_box {
        width: 25%;
        box-sizing: border-box;
        padding: 10px;

    }
    li.col_box img ,
    li.rec_box img {
        width: 100%;
        height: auto;
    }

      li.col_box:nth-child(4n+1) ,
    li.rec_box:nth-child(4n+1) {
        clear: both;
    }


}


/* PC MENU */


/* global menu*/

#navi_block {
    margin: 0;
    position: static;
    left: 0;
    width: 100%;
    float: left;
    padding: 0;
    z-index: 100; /* WL変更 カート通知重なり順調整のため z-index: 10 */
    top: 50px;
}

#global_navi {
    float: left;
    width: 100%;
    margin: 0 auto;
    padding: 10px 0 0px 0;
    background: #fff;
    /* border-bottom: 1px solid #ccc; */
    z-index: 100; /* WL変更 カート通知重なり順調整のため  z-index: 10 */
}

@media (min-width: 1500px) {
    #global_navi {
        border-bottom: 1px solid #ccc;
    }
}



#global_navi a:link, #global_navi a:visited, #global_navi a:active {
    color: #000;
    text-decoration: none;
    text-shadow: none;
}

#global_navi a:hover {
    text-decoration: none;
    text-shadow: none !important;
}

#global_navi li:hover {
    text-decoration: none;
}


div.menu-sale {
    border-top-left-radius: 3px;
    border-top-right-radius: 3px;
    background: #f00;
    font-size: 13px;
    color: #fff !important;
    padding: 7px 12px 5px 12px;
    margin-top: -6px;
    margin-right: 20px;
}

div.menu-sale:hover {
    background: #000;
}

div.menu-sale a {
    text-shadow: none !important;
    color: #fff !important;
}

div.menu-sale a:hover {
    color: #fff !important;
}


.nav-box {
    width: 100%;
}


.nav,
.nav a,
.nav ul,
.nav li,
.nav div,
.nav form,
.nav input {
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
}


.nav a {
    text-decoration: none;
}

.nav li {
    list-style: none;
    text-transform: uppercase;
}

.nav {
    width: 70%;
    cursor: default;
    z-index: 1500;
    min-width: 1000px;
    margin: 0 auto;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
}

.nav > li {

    float: left;
    font-size: 13px;
    font-weight: 200 !important;
    text-align: center;
   color:#222;

}


.nav > li > a {

    z-index: 510;
    color: #222;
    width: 100%;
    padding: 20px 20px 10px 20px;
    font-weight: normal !important;

}

a.cat-root {
    display: block;
}

.cat-root {
    text-decoration: none;
    color: #5bc8ac;
    font-size: 110%;
}

.cat-text {
    position: relative;
	z-index: 12;
	font-weight:600;																			
}

.cat-text:after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -10px;
    width: 0%;
    height: 3px;
    background: #111;
    z-index: -1;
    transition: all 0.4s;
}

.cat-root:hover .cat-text:after {
    width: 100%;
}


.nav > li:hover > a {
    text-shadow: none !important;
    color: #999 !important;
}

.nav > li.archive-sale:hover > a {
    text-shadow: none !important;
    color: #00718d !important;
}

.nav > li:first-child > a {
    border-left: none;
}

/* brand list, category list */

.nav > li > div {
    position: absolute;
    display: block;
    width: 100%;
    margin-top: 0px;
    padding-top: 0px;
    left: 0;
    border-top: none;
    border-left: 0px solid #999;
    border-bottom: 1px solid #ccc;
    border-right: 0px solid #999;
    text-align: left;
    box-sizing: border-box;

    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    background: #fff;
    padding: 0px;

/*PC MENUの高さ*/
    top: 120px;
    z-index: 10000;

    -webkit-transition: all .3s ease .3s;
    -moz-transition: all .3s ease .3s;
    -o-transition: all .3s ease .3s;
    -ms-transition: all .3s ease .3s;
    transition: all .3s ease .3s;
}

/* new arrivals , recommended , style*/


.nav > li:hover > div {
    opacity: 1;
    visibility: visible;
    overflow: visible;
    transition-duration: 0s;
    transition-delay: 0s;

}


.nav .nav-column {
    float: left;
    padding: 20px 0 30px 50px;
    height: 50vh;
    overflow-y: scroll;
    overflow-x: hidden !important;
}

.nav .nav-column h3 a,
.nav .nav-column h3 {
    margin: 0px 0 20px 0;
    font-weight: 500;
    font-size: 14px;
    color: #000;
    text-transform: uppercase;
}

.nav .nav-column li {
    float: left;
    font-size: 12px;
    margin-bottom: 3px;
    font-weight:400;
}

.nav li.menu-apart {
    border-left: 0px solid #333;

}

.nav-column::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 2px;
}

.nav-column::-webkit-scrollbar-thumb {
    background: #ccc;
    border-radius: 4px;
    margin-left: 1px;

}

.nav-column::-webkit-scrollbar-track {
    width: 10px;
    background: #fff;

}

.nav-category {
    width: 25%;
    overflow-x: hidden;
    overflow-y: scroll !important;
}

.nav-category li {
    height: 20px;
    width: 100%;
    padding: 0 5px 0 5px;
}


.nav-brands {
    width: 25%;
    padding-left: 10%;
    padding-right: 0;
    margin-right: 0;
    overflow-x: hidden;
    overflow-y: scroll !important;
    border-left: 1px solid #eee !important;
    border-right: 1px solid #eee !important;
}


.nav-brands ul {
    display: flex;
    flex-direction: column;
    /*column-count: 4;
    -moz-column-count: 4;
    -webkit-column-count: 4;
    -o-column-count: 4;
    -ms-column-count: 4;
    */
}

.nav-brands li {
    list-style: none;
    padding: 0px 5px 0px 5px;
    float: left;
    line-height: 1.8em;
    margin-top: 0px;
    display: block;
    width: 80%;


}


.nav-pickup {
    width: 49%;
    overflow-x: hidden;
    overflow-y: hidden;

    margin-left: 1% !important;
}

.nav-category::-webkit-scrollbar-thumb,
.nav-brands::-webkit-scrollbar-thumb,
.nav-pickup::-webkit-scrollbar-thumb {
    -webkit-appearance: none;
    width: 7px;

    border-radius: 4px;
    background-color: rgba(0,0,0,.1);
    box-shadow: 0 0 1px rgba(255,255,255,.5);

}

/*
.nav-category::-webkit-scrollbar,
.nav-brands::-webkit-scrollbar,
.nav-pickup::-webkit-scrollbar {
    display: none;
}
*/
.nav-pickup-box {
    width: 90%;
    box-sizing: border-box;
    padding: 5px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.nav-pickup-img {
    float: left;
    width: 47%;
    min-height: 200px;

    height: auto;

    text-align: center;
}

.nav-pickup-img p {
    font-size: 12px;
    padding: 5px 0;
    text-align: left;


}

.nav-pickup-img img {
    width: 100%;
    height: auto;

}


.nav .nav-column li a {
    display: block;
    color: #333 !important;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    line-height:1.2em;
    
}

.nav-brands li.brand_alphabet {
    display: none;
    font-weight: 600 !important;
    padding: 2px 0;
    margin: 10px 0 0 -10px;

    border-bottom: 0px solid #ccc;

}

.nav-brands li.brand_alphabet:after {

    content: ""

}


.nav .nav-column li a:hover {
    color: #999 !important;
}

.nav .nav-column li.cat-lv1 {
    font-weight: 500;
}

.nav .nav-column li.cat-lv2 {
    text-indent: 1em;
}

.nav .nav-column li.cat-lv2 a:before {
    content: "- "
}

.nav .nav-column li.cat-lv3 {
    text-indent: 2em;
}

/* search */

li.nav-search {
    display: none;
}

/* WL変更
.nav > li.nav-search > form {

    position: relative;
    width: inherit;
    height: 20px;
    z-index: 510;
    border-left: 1px solid #333;
}
*/

.nav > li.nav-search input[type="text"] {
    display: block;
    float: left;
    width: 0px;
    height: 20px;
    font-weight: 500;
    font-size: 13px;
    color: #555;
    margin-top: 2px;
    z-index: 1000;
    -webkit-transition: all .3s ease 1s;
    -moz-transition: all .3s ease 1s;
    -o-transition: all .3s ease 1s;
    -ms-transition: all .3s ease 1s;
    transition: all .3s ease 1s;
}

.nav > li.nav-search input[type="text"]:focus {
    color: #000;
}

.nav > li.nav-search input[type="text"]:focus,
.nav > li.nav-search:hover input[type="text"] {
    width: 100px;
    padding: 0px 20px;

    -webkit-transition: all .3s ease .1s;
    -moz-transition: all .3s ease .1s;
    -o-transition: all .3s ease .1s;
    -ms-transition: all .3s ease .1s;
    transition: all .3s ease .1s;
}

.nav > li.nav-search input[type="submit"] {

    margin-top: 0px;

    display: block;
    float: left;
    width: 20px;
    height: 20px;
    padding: 0 25px;
    cursor: pointer;

    background: #fff url(search-btn.png) no-repeat center 0px; /* WL変更 URL */

    border-radius: 0 3px 3px 0;

    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -o-transition: all .3s ease;
    -ms-transition: all .3s ease;
    transition: all .3s ease;
}

.nav > li.nav-search input[type="submit"]:hover {
    background-color: #fff;
}


/* nav-content */

.nav-content {
    width: 100%;
    display: flex;
    justify-content: center
}

.nav-sale-content {
    margin: 0 auto;
    width: auto;
    height: auto;
    display: flex;
    justify-content: center;
    padding: 20px;
}



/* sale 4 category */

.nav-sale {
    text-align: center;
}

.nav-sale img {
    width: 70%;
    height: auto;
    cursor: pointer;
    margin: 50px auto;
    width: 280px;
    padding: 0 10px;
}

.nav-sale img:hover {
}


.nav-feature {
    width: 33%;
    height: auto;
    float: left;
    overflow: hidden;
    text-align: center;
    padding: 10px;
}

.nav-feature img {
    width: 80%;
    height: auto;
    margin: 30px auto 0 auto;
}


.nav-newarrivals {
    padding-top: 10px !important;
    width: 25%;
    height: auto;
    float: left;
    text-align: center;
    background: #f6f6f6;
    border-right: 2px solid #fff !important;
    box-sizing: border-box;
}

.nav-newarrivals:nth-child(4n) {
    border-right: none !important;
}

.nav-newarrivals img {
    width: 60%;
    height: auto;
    margin: 10px auto 0 auto;
}


.nav-feature p {
    padding: 30px 0 30px 0;
    background: #fff;
    font-size: 13px;
    letter-spacing: 0.05em;
}


.nav-newarrivals p {
    padding: 30px 0 30px 0;
    background: #fff;
    font-size: 15px;
    letter-spacing: 0.05em;
}

span.nav-update {
    padding-top: 15px;
    font-size: 12px;
}


/*system*/

@media (min-width: 1199px) {

    .page-title {
        padding: 60px 0 20px 0;

    }

    .page-title h2 {
        font-size: 22px !important;
        font-weight: 500;
    }


}

@media (max-width: 1200px) {
    .page-title {
        padding: 40px 0 40px 0;
        margin-bottom: 10px;
    }

    .page-title h2 {
        font-size: 18px !important;
        font-weight: 500;
    }

}

.page-sub {
    text-align: center;
    font-size: 12px;
    display: block;
    width: 180px;
    padding: 10px;
    margin: 30px auto 20px auto;
    border: 1px solid #333;
    cursor: pointer;
}

/* WL追加 アカウント有効化ページ > 招待を断る のデザイン競合のため */
.page-sub #decline-activate-btn {
    border: none;
    padding: unset;
    background-color: unset;
}

/* ここまで */

.mypage-logout {
    width: 180px;
    margin-left: auto;
    margin-right: auto;
}

.btn-wh a {
    background: #fff;
    color: #333;
}

.btn-bl a {
    background: #333;
    color: #fff;
}


.page-title span {
    text-align: center;
}

section.sys-page {
    width: 100%;
}

.section.sys-page h2 {
  padding:30px 0 !important;
}


/*register*/


@media (min-width: 1199px) {
    .register-body {
        width: 50%;
        margin: 0 auto;
    }
}

@media (max-width: 1200px) {
    .register-body {
        width: 90%;
        margin: 0 auto;
    }
}

.regi-text-error input {
    border: 2px solid #C00 !important;

}


.regi-error {
    width: 100%;
    border: 2px solid #c00;
    color: #c00;
    padding: 20px 0;
    border-radius: 5px;
    margin: 0 auto 30px auto;
    text-indent: 2%;
}

/* WL追加 ここから */
.address-regi-error {
    width: 100%;
    border: 2px solid #c00;
    color: #c00;
    padding: 20px 0;
    border-radius: 5px;
    margin: 0 auto 30px auto;
    text-indent: 2%;
    display: none;
}
/* WL追加 ここまで */

p.regi-error-message {
    font-size: 11px;
    color: #c00;
}

/* WL追加ここから Langify対応でpタグの中にspanを入れる必要ができたため */
p.regi-error-message > span.regi-error-message-main {
    font-size: 11px;
    color: #c00;
    line-height:0;
}
/* WL追加ここまで */

.regi-text {
    margin: 0 0 30px 0;
}

.regi-text:nth-last-child  {

}



.regi-text input {
    width: 100%;
    height: 30px;
    font-size: 150%;
    padding: 3px 0px;
    border: 1px solid #333;
    border-radius: 3px;
}

.regi-text span {
    font-size: 110%;
    line-height: 2.1em;
    color: #777;
}

.regi-btn {
    text-align: center;
}

.regi-btn p {
    font-size: 110% !important;
    margin: 0 auto;
}

.regi-btn input,
.regi-btn [type="submit"] { /* WL変更 */
    font-size: 120%;
    border: 2px solid;
    cursor: pointer;
    display: block;
    width: 50%;
    padding: 10px 0;
    margin: 20px auto;
    border: none;
    border-radius: 4px !important;
    -webkit-border-radius: 4px;
    -webkit-appearance: none;
    background: #333;
    color: #fff;
}

.cancel-btn [type="reset"] { /* WL変更 */
    font-size: 160%;
    border: 2px solid;
    cursor: pointer;
    display: block;
    width: 50%;
    padding: 10px 0;
    margin: 20px auto;
    border: none;
    border-radius: 4px !important;
    -webkit-border-radius: 4px;
    -webkit-appearance: none;
    background: #fff;
    color: #333;
}

/* contact */


.regi-message {
    width: 100%;
    color: #000;
    margin-bottom: 10px;
    font-size: 120%;
}

.star {
    color: #999 !important;
    margin: 0 0 0px 3px !important;
    font-size: 90% !important;
}

.regi-text select {
    padding-left: 15px;
    border: 1px solid #000;
    -webkit-appearance: none;
    text-align: center;
    position: relative;
    height: 50px;
    font-size: 130%;
    -webkit-border-radius: 4px;
    -webkit-appearance: none;

}

.regi-text textarea {
    font-size: 150%;
    padding: 3px 0px;
    border: 1px solid #333;
    border-radius: 5px;
}


@media (min-width: 1199px) {

    .regi-text textarea {
        width: 100%;
    }

    .regi-text select {
        width: 100%;
    }

}

@media (max-width: 1200px) {

    .regi-text textarea {
        width: 100%;
    }

    .regi-text select {
        width: 100%;
    }

}


/*cart page*/


.cart-body table {
    border-collapse: collapse;
}


@media (min-width: 1199px) {
    .cart-body,
    .cart-footer { /* WL追加 */
        width: 70%;
        margin: 0 auto;
    }

    .cart-body table {
        width: 100%;
        font-size: 90%;
    }
}

@media (max-width: 1200px) {
    .cart-body,
    .cart-footer { /* WL追加 */
        width: 98%;
        margin: 0 auto;
    }

    .cart-body table {
        width: 100%;
        font-size: 12px;
    }
}


td.cart_itm_list {
    border-bottom: 1px solid #000;
    padding-bottom: 5px;
    font-size: 12px !important; /*WL変更*/
}

td.cart_itm {
    padding-top: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
}


@media (min-width: 1199px) {

    .clm1 {
        width: 10%;
        text-align: left;
        padding: 10px 0 0 5px;
    }

    .clm2 {
        width: 50%;
        text-align: left;
        padding: 10px 0 0 20px;
    }

    .clm3 {
        width: 10%;
        text-align: center;
    }

    .clm4 {
        width: 30%;
        text-align: right;
        padding: 0 10px 0 0;
    }

    .clm5 {
        text-align: right;
        padding: 2em 0;
        font-size: 90%;
    }

}

@media (max-width: 1200px) {

    .clm1 {
        width: 15%;
        text-align: left;
        padding: 10px 0 0 5px;
    }

    .clm2 {
        width: 45%;
        text-align: left;
        padding: 5px 0 0 10px;
    }

    .clm3 {
        width: 10%;
        text-align: center;
    }

    .clm4 {
        width: 20%;
        text-align: right;
        font-size: 90%;
    }

    .clm5 {
        text-align: right;
        padding: 2em 0;
    }

    .price ul li{
        white-space: nowrap;
        font-size: 80%;
    }

    .no-wrap-price dt,
    .no-wrap-price dd{
        white-space: nowrap;
        font-size: 80%;
    }
    .no-wrap-price dd s div{
        white-space: nowrap;
        font-size: 75%;
    }
}

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


.cart_itm_name_size {
    font-weight: 500;
    line-height: 1.1em;
    font-size: 11px; /*WL変更*/
}

.cart_itm_price {
    text-align: right;
    line-height: 1.7em;
}

.cart_itm_price h3 {
    font-size: 180%; /*WL変更*/
    padding: 20px 0;
}

.cart_itm_price span {
    font-size: 11px;
    color: #333;
}

/* WL追加 */
.cart_itm_price .order-discount {
    color: var(--color-sale-text);
    display: block;
    line-height: 1.2em;
}

.cart_itm_price .order-discount span {
    color: var(--color-sale-text);
}

/* ここまで */
/*決済画面日付指定オンオフ*/
.cart_itm_date {

}

.itm_date_check {
    font-size: 120%; /*WL変更*/
    margin: 0.5rem 0;
}

.itm_date_check input[type="radio"] {
    position: absolute;
    opacity: 0;
}

.itm_date_check input[type="radio"] + .radio-label:before {
    content: '';
    background: #f4f4f4;
    border-radius: 100%;
    border: 1px solid #b4b4b4;
    display: inline-block;
    width: 1em;
    height: 1em;
    position: relative;
    top: 0em;
    margin-right: 0.5em;
    /*vertical-align: top; WL変更*/
    cursor: pointer;
    text-align: center;
    transition: all 150ms ease;
}

.itm_date_check input[type="radio"]:checked + .radio-label:before {
    background-color: #333;
    box-shadow: inset 0 0 0 4px #f4f4f4;
}

.itm_date_check input[type="radio"]:focus + .radio-label:before {
    outline: none;
    border-color: #333;
}

.itm_date_check input[type="radio"]:disabled + .radio-label:before {
    box-shadow: inset 0 0 0 4px #f4f4f4;
    border-color: #b4b4b4;
    background: #b4b4b4;
}

.itm_date_check input[type="radio"] + .radio-label:empty:before {
    margin-right: 0;
}


.cart_itm_date input[type="text"],
.cart_itm_date input[type="date"] {
    text-indent: 1em;
    width: 250px;
    height: 35px;
    font-size: 100%;
    text-align: left;
    border-radius: 0;

    margin: 0;
    border: 1px solid #ccc;

    background: url(calender.png) no-repeat; /* WL変更 URL */
    background-position: 220px 5px;
    background-size: 20px 20px;


}

input[type=date]::-webkit-calendar-picker-indicator {
    /* position: absolute;   width: 100%;  height: 100%; */
    background: none;
    cursor: pointer;
    width: 60px;
    height: 35px;
    opacity: 1;
    display: block;
}

select.cart_itm_time {
    margin: 0.5rem 0;
    text-indent: 1em;
    border: 1px solid #ccc;
    -webkit-appearance: none;
    border-radius: 0;
    width: 250px;
    height: 35px;
    font-size: 90%;
    text-align: right;
    box-sizing: border-box;
    background: url(arr_down.png) no-repeat; /* WL変更 URL */
    background-position: 220px 12px;

}

@media (min-width: 1199px) {
    select.cart_itm_time {
        margin-right: 3px;
        padding-right: 35px
    }

    .cart_message textarea {
        width: 250px;
        margin-right: 3px;
    }

}

@media (max-width: 1200px) {
    select.cart_itm_time {
        margin-right: 0px;
    }

    .cart_message textarea {
        width: 250px;
        margin-right: 0px;
    }

}

.cart_message textarea {
    border: 1px solid #ccc;
}


@media (min-width: 1199px) {
    .cart_btn input {
        width: 40%;
        margin: 20px auto;
    }
}

@media (max-width: 1200px) {
    .cart_btn input {
        width: 100%;
        margin: 20px 0;
    }
}


.cart_btn input {
    font-size: 140%;
    border: 2px solid;
    cursor: pointer;
    display: block;

    padding: 10px 0;
    border: none;
    border-radius: 4px !important;
    -webkit-border-radius: 4px;
    -webkit-appearance: none;
    background: #4e7795;
    color: #fff;
}

.cart_btn input:hover {

    background-color: #2A6195 !important;
    color: #fff;

}


.cart_backshop {
    width: 50%;
    text-align: left;
    font-size: 13px;
    color: #333;
    text-decoration: underline;
    float: left;
    padding: 10px 0;
}

.cart_btn {
    margin-top: 20px;
    width: 100%;
    float: left;
    text-align: center;
}


.cart_payment {
    width: 100%;
    text-align: center;

}

/* WL追加 */
.cart_payment ul {
    justify-content: center;
}

/* ここまで */

select.cart_num {
    font-size: 100%;
    width: 50%;
    text-indent: 30%;
    border: #ccc 1px solid;
    border-radius: 1px;
}


a.cart_minus,
a.cart_plus {
    font-size: 130%;
}

span.cart_itm_rsv {

    background: #000;
    color: #fff;
    padding: 2px 20px;
    border-radius: 4px;
    font-size: 95%;
    line-height: 3em;

}

/*cart empty*/

.cart_empty {
    width: 70%;
    margin: 30px auto 0 auto;
    height: 50vh;
    text-align: center;

}

.cart_empty h3 {
    margin: 30px 0;
    font-size: 150%;
}


.cart_cont_btn {
    margin: 0 auto;
    padding: 10px;
    font-size: 100%;
    color: #fff;
    background: #000;
    display: block;
    width: 180px;
}

.cart_cont_btn a {
    color: #fff;
}

.cart_cont_btn:hover {
    background: #333;
}

/* WL追加 */
.cart__continue-btn {
    border: 1px solid #333;
    background-color: #fff;
}

.empty-page-content a:hover {
    background-color: #fff;
}

/* ここまで */


/* my page */


@media (min-width: 1199px) {
    .mypage-body {
        width: 70%;
        margin: 0 auto;
        text-align: left !important;
    }

    .mypage-body table, .mypage-order table {
        width: 100%;
        font-size: 130%;
    }
}

@media (max-width: 1200px) {
    .mypage-body {
        width: 98%;
        margin: 0 auto;
    }

    .mypage-body table, .mypage-order table {
        width: 100%;
        font-size: 100%;
    }
}


.mypage-body h3 {
    font-size: 140%;
    padding: 30px 0 0 0;
    margin-bottom:30px;
    border-bottom:1px solid #ccc;
}


@media (min-width: 1199px) {
    .mypage-address {
        width: 100%;
        float: left;
        padding-left: 0%;
    }

    .mypage-order, .mypage-order-detail {
        width: 100%;
        float: left;
    }

}

@media (max-width: 1200px) {

    .mypage-address {
        width: 100%;
        float: left;
    }

    .mypage-order, .mypage-order-detail {
        width: 100%;
        float: left;
    }


}


.mypage-address-info {
    font-size: 100%;
}

/*-----------------------*/
/* アドレスページ追加 */

.address-add-card {
  display: flex;
  flex-direction: column; 
  align-items: center;
  justify-content: center;
  width: 250px;
  height: 250px;
  border: 2px dashed #ccc;
  border-radius: 8px;
  cursor: pointer;
  background-color: #fff;
  transition: all 0.2s ease;
  text-align: center;
}


.address-add-card:hover {
  border-color: #333;
  background-color: #efefef;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.address-add-card:focus-visible {
  outline: 2px solid #333;
}

.add-card-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  padding-top:50px;
}

.add-icon {
  font-size: 40px;
  color: #aaa;
  transition: color 0.2s;
}

.address-add-card:hover .add-icon {
  color: #333;
}

.add-label {
  font-weight: bold;
  color: #666;
  font-size: 16px;
  transition: color 0.2s;
}

.address-add-card:hover .add-label {
  color: #000;
}


#mypage-address-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;

}

.mypage-address-info {
    font-size: 100%;
}



#mypage-address-list li {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;

  padding: 0px 0 0 0;
  width: 250px;
  height: 250px;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 8px;
  background: #fff;
  position: relative;
  transition: all 0.2s ease;
  text-align:left;
}

/* 規定のアドレスだけ強調 */
#mypage-address-list li.is-default {
  border: 2px solid #444;
  background-color: #f8f8f8;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.);
}

@media (max-width: 768px) {

.add-card-inner {
  padding:10px 0 30px 0;
}    

  #mypage-address-list {
    flex-direction: column;
    align-items: stretch;
  }

  #mypage-address-list li {
    width: 100%;
    max-width: none;
    height: auto;
    margin: 0;
    border-radius: 0;
  }

  #mypage-address-list li + li {
    margin-top: 16px; /* カード間の余白 */
  }
}


.edit-btn,
.delete-btn {
  border:1px solid #ccc !important;
  background:#fff !important;
  color:#444 !important;
  font-size:11px !important;
}

.edit-btn:hover,
.delete-btn:hover {
  background:#efefef !important;
}

.address-default-badge {
  font-size: 13px;

  color: #000;
  padding:10px 8px 10px 8px;
  width:100%;
  border-bottom:1px solid #ccc;
  margin-bottom: 10px;
  text-align:center;
  display: inline-block;
}

.address-other {
  font-size: 11px;
  color: #000;
  padding:13px 8px;
  width:100%;
  margin-bottom: 10px;
  display: inline-block;
}


/*-----------------------*/




.mypage-address-btns {
  width: 100%;
  margin: 0 auto;  
  padding:10px 0;
  max-width: 890px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  box-sizing: border-box;
}

.mypage-address-btn {
  flex: 1 1 calc(25% - 12px); /* PC：4列 */
  padding: 10px;
  text-align: center;
  margin: 0;
  box-sizing: border-box;
  word-break: break-word;
}

@media screen and (max-width: 1199px) {
  .mypage-address-btn {
    flex: 1 1 calc(50% - 8px); /* タブレット・スマホ：2列 */
  }
}

/*
p.mypage-address-btn {
    display: block;
    padding: 10px;
    background: #333;
    margin: 20px 0;
    text-align: center;
    width: 200px;
}
*/
.mypage-address-btn a {
    padding: 3px 10px;
    color: #333;

}

/* ORDER HISTORY */

.mypage-order table, .mypage-order-detail table {
    border-collapse: collapse;
}

.mypage-order table td {
    border: 1px solid #ccc;
    box-sizing: border-box;
}


td.odr-list {
    font-weight: 500;
    font-size: 12px;
}

td.odr-info {
    font-weight: 400;
    font-size: 11px;
}

td.odr-info a {
    text-decoration: underline
}

td.odr-clm1 {
    width: 20%;
    padding: 10px 5px;
}

td.odr-clm2 {
    width: 20%;
    padding: 10px  5px;
}

td.odr-clm3 {
    width: 20%;
    padding: 10px;
}

td.odr-clm4 {
    width: 20%;
    padding: 10px;

}

td.odr-clm5 {
    width: 20%;
    padding: 10px;
    text-align: center;
}


@media (min-width: 1199px) {

    .odr-dt-clm1 {
        width: 10%;
        text-align: left;
        padding: 10px 0 0 5px;
    }

    /* WL追加 ここから */
    .odr-dt-clm1-header {
        width: 50%;
        text-align: left;
        padding: 10px 0 0 5px;
    }

    /* WL追加 ここまで */
    .odr-dt-clm2 {
        width: 50%;
        text-align: left;
        padding: 10px 0 0 20px;
    }

    .odr-dt-clm3 {
        width: 10%;
        text-align: center;
    }

    .odr-dt-clm4 {
        width: 30%;
        text-align: right;
        padding: 0 10px 0 0;
    }

}

@media (max-width: 1200px) {

    .odr-dt-clm1 {
        width: 15%;
        text-align: left;
        padding: 10px 0 0 5px;
    }

    .odr-dt-clm2 {
        width: 45%;
        text-align: left;
        padding: 5px 0 0 10px;
    }

    .odr-dt-clm3 {
        width: 10%;
        text-align: center;
    }

    .odr-dt-clm4 {
        width: 20%;
        text-align: right;
        font-size: 11px;
    }

}

td.odr-clm-bar {
    border-bottom: 1px solid #222;
    height: 3px;
}

td.odr-clm6 {
    font-size: 12px;
    font-weight: 300;
    padding: 10px;
}

td.odr-clm7 {
    font-size: 12px;
    padding: 10px;
    text-align: right;
    font-weight: 300;
}

td.odr-clm8 {
    font-size: 12px;
    font-weight: 500;
    padding: 10px;
}

td.odr-clm9 {
    font-size: 13px;
    padding: 10px;
    text-align: right;
    font-weight: 500;
}


/*  address */


.adrs {
    width: 50%;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 50px;
}


.mypage-address-info {
    font-size: 110%;
}



p.mypage-address-btn {
    background: #fff;
    text-align: center;
    border:solid 1px #111;
}

.mypage-address-btn a {
    padding: 3px 10px;
    color: #333;
}

p.mypage-address-btn:hover {
    background:#efefef;
}

.adrs-edit-btn-box {
    width: 150px;
    margin: 30px auto 0 auto;
    display: flex;
    justify-content: space-between;
}

.adrs-edit-btn {
    width: 45%;
    font-size: 120%;
    border: 1px solid #666;
    padding: 5px 0;
    display: block;
    cursor: pointer;
}

.btn-bl {
    background: #333;
    color: #fff;
}

.btn-bl a {
    background: #333;
    color: #fff;
}


.adrs-edit-box {
    width: 85%;
    margin: 0 auto 30px auto;
    clear: both;
}

.adrs-edit-box h3{
    font-size:150%;
    padding:30px 0;
}


/* WL追加 ここから */
.adrs-edit-box .regi-error ul {
    margin-bottom: 0;
    text-align: left;
}

/* WL追加 ここまで */

.adrs-text {
    margin: 0 0 30px 0;
}


@media (min-width: 1199px) {

    .adrs-text-box {
        display: flex;
        justify-content: space-between;
    }

    .adrs-text-s {
        width: 48%;
        float: left;
    }


}

@media (max-width: 1200px) {

    .adrs-text-box {
    }

    .adrs-text-s {
        width: 100%;
    }
}


.adrs-text input {
    width: 100%;
    height: 30px;
    font-size: 120%;
    padding: 3px 0px 3px 10px;
    border: 1px solid #333;
    border-radius: 3px;
}

.adrs-text span {
    font-size: 120%;
    line-height: 2.1em;
    color: #777;
}


.adrs-text label {
    display: inline-block;
    white-space: nowrap;
    font-size: 120%;
    padding-top: 6px; /* WL追加 */
    vertical-align: top; /* WL追加 */
}

.adrs-text input[type~=checkbox] {
    width: 15px;
}


/* list navi*/

.list-function {
    width: 100%;
    display: flex;
    border: 1px solid #ccc;
}

.list-function select {
    border: none;
    -webkit-appearance: none;
    text-align: center;
    width: 100%;
    text-indent: 30%;

    position: relative;
    z-index: 2;
    opacity: 0;

}

.list-sort, .list-view {
    position: relative;
}

.list-sort, .list-view, .list-filter {
    text-align: center;
    border-right: 1px solid #ccc;
    box-sizing: border-box;
    width: 33%;
    margin: 0;
    float: left;
    padding: 10px 0 10px 10px;
    height: 50px;
}


.list-function select:focus {
    opacity: 1;
    z-index: -1;
}

.list-function select:focus + .list-label {
    opacity: 0;
}

.list-label {
    position: absolute;
    top: 25%;
    left: 25%;
    z-index: 1;
}

/* WL追加 */
:root {
    --swiper-pagination-color: #000000;
}

.metafields-wrap {
    white-space: pre-wrap;
}

#item-info .price {
    margin-top: 1px;
    padding: 10px 0;
}

#BIS_trigger {
  display:none;
/*    display: block; */
  
  font-size: 130%;
    border: none;
    cursor: pointer;

    width: 100%;
    padding: 10px 0;
    margin: 15px 0;
    border-radius: 7px;
    font-weight: 400;
    background: #FF9E7E;
    color: #fff;
}

li.prd-list span.index-price dl.price span.price-item {
    color: #999;
}

/* ここまで */

/* search */

@media (min-width: 1199px) {

    .search-open {
        top: 15px;
        left: 30px;

    }

    .search-close {
        top: 10px;
        left: 30px;

    }

}

@media (max-width: 1200px) {

    .search-open {
        top: 0px;
        left: 40px;
    }

    .search-close {
        top: -8px;
        left: 40px;

    }
}


.search-open {
    position: absolute;
    background: #fff url(icon_search.png) no-repeat 15px center; /* WL変更 URL */
    background-size: 20px 20px;
    width: 50px;
    height: 50px;
    cursor: pointer;
    z-index: 110;
}


.search-close {
    position: absolute;
    z-index: 110;
    cursor: pointer;
    width: 50px;
    height: 50px;
}

.search-close span {
    display: inline-block;
    position: absolute;
    left: 14px;
    height: 2px;

    background-color: #000;
}

.search-close span:nth-of-type(1) {
    top: 26px;
    left: 15px;
    transform: translateY(6px) rotate(-135deg);
    width: 50%;
}

.search-close span:nth-of-type(2) {
    top: 38px;
    left: 15px;
    transform: translateY(-6px) rotate(135deg);
    width: 50%;
}


#search-window {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -100;
    opacity: 0;
    transition: all 0.3s;
    width: 100%;
    height: 20vh;
}

#search-window.search-active {
    opacity: 1;
    z-index: 130;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}

#search-window .search-area {
    display: none;
}

#search-window.search-active .search-area {
    display: block;
    width: 80%;
    position: relative;
}

#search-window form {
    position: relative;
    height: 66px;
}

#search-window input {
    -webkit-appearance: none;
    outline: none;
    cursor: pointer;
    color: #000;
    font-size: 20px;
}

#search-window input[type="text"] {
    -webkit-appearance: none;
    width: 95%;
    padding: 20px;
    border: none;
    border-bottom: 2px solid #666;
    transition: all 0.5s;
    letter-spacing: 0.05em;
}

#search-window input[type="text"]:focus {
    background: #fff;
}


#search-window input[type="submit"] {
    position: absolute;
    bottom: -20px;
    right: 10px;
    background: url(icon_search.png) no-repeat 15px center; /* WL変更 URL */
    background-size: 25px 25px;
    width: 60px;
    height: 60px;
    border: none;
}


/* feature  */

.ed_title {
    text-align: left;
}

@media (min-width: 1199px) {

    .ed_top_img {
        width: 1200px;
        margin: 10px auto 0 auto;
    }

    .ed_content {
        width: 1000px;
        margin: 0 auto;
        font-size: 16px;
    }

    .ed_title {
        padding: 30px 0 5px 0;
        width: 100%;
    }

    .ed_title p {
        font-size: 160% !important;
        font-weight: 500;
    }

    .ed_title h1 {
        font-size: 200% !important;
        font-weight: 500;
    }


    .swiper-img {
        width: 700px !important;
        height: auto !important;
        margin: 0 auto !important;
    }

    .swiper-img swiper-slide img {
        width: 700px !important
    }

}

@media (max-width: 1200px) {

    .ed_content {
        font-size: 16px;
    }

    .ed_title {
        padding: 30px 0 20px 0;
        margin-bottom: 10px;
    }

    .ed_title p {
        font-size: 110% !important;
        font-weight: 500;
    }

    .ed_title h1 {
        font-size: 130% !important;
        font-weight: 500;
    }

}

div.ed_lead {
    font-size: 100%;
    margin-top: 24px;
    font-weight: 500;
    color: #666;
    line-height: 1.5em;
}


div.ed_body {
    font-size: 100%;
    margin: 100px auto;
    line-height: 1.8em;
    width: 100%;
}


div.ed_body img {
    margin: 0 auto;
}


.ed_swiper {
    width: 100%;
    height: 300px
}


section.article .swiper {
    margin: 100px 0;
}

section.article .swiper {
    width: 100%;
    height: auto;
}

section.article .swiper-slide {
    font-size: 60%;
    line-height: 1.9em;
}

section.article .swiper-slide img {
    width: 100%;
    height: auto;
}



/* Progressバーの非アクティブな部分のスタイル */
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background-color: #ccc;
}

/* Progressバーのアクティブな部分のスタイル */
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill.swiper-pagination-progressbar-fill-active {
    background-color: #555;
}



/* editorial */


@media (min-width: 1199px) {

    section.editorial {
        padding: 70px 0;
    }


    .feature-list img {
        width: 350px;
      height:auto;
    }


    .recommended-list {
        width: 1200px;
        margin: 50px auto;
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .feature-list {
        width: 100%;
        margin: 50px auto;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }

  .feature-item { /* WL修正 .feature-list img */
    padding: 20px 0;
  }

    .hlt-article {
        width: 700px;
        margin: 100px auto;
    }

    .hlt-header h2 {
        margin: 0 !important;
        padding: 0em 0 10px 0 !important
    }


    .styles-list {
        width: 800px;
        margin: 50px auto;
    }

    .styles-title h2 {
        font-weight: 300 !important;
        font-size: 20px !important;
        margin: 30px 0 20px 0 !important;
    }

    .styles-text img {
        width: 800px;
        height: auto;
    }


    .rec-box {
        width: 300px;
        height: 300px;
    }

    .recommended-list img {
        width: 300px;
        height: 200px;
    }


}

/**/


@media (max-width: 1200px) {

    section.editorial {
        padding: 0px 0;
    }

.feature-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.feature-item {
  width: 48%;
  padding: 20px 0;
  box-sizing: border-box;
}

.feature-item img {
  width: 100%;
  height: auto;
  display: block;
}
  

    .hlt-header h2 {
        font-size: 200% !important;
        margin: 2em 0 0 0 !important;
        padding: 0 0 10px 0 !important
    }

    .hlt-article {
        margin: 100px 0 0 0;
    }


    .styles-list {
        margin: 50px 0;
    }

    .styles-title h2 {
        font-weight: 300 !important;
        font-size: 18px !important;
        margin: 20px 0 10px 0 !important;
    }

    .styles-date {
        padding: 1em 0 0 0;
    }

    .rec-box {
        margin-top: 30px;
    }


.recommended-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 20px;
}

.rec-box {
  width: calc(50% - 10px); /* 2列の幅（gap調整） */
  box-sizing: border-box;
}

.rec-img {
  width: 100%;
  height: 200px; /* 画像の高さ統一 */
  overflow: hidden; /* はみ出しをカット */
}

.rec-img img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* 中央でトリミングして均一化 */
  display: block;
}

  
}

/**/


.styles-date {
    font-size: 14px;
    text-align: center;
    font-weight: 300;
}



.hlt-header {
    text-align: center;
}

.hlt-header span {
    font-size: 13px;
}


.hlt-text-ja {
    font-size: 14px;
    line-height: 2.4em;
}

.hlt-article img {
    margin: 30px 0;
}

.hlt-splitter {
    border-top: 1px solid #ccc;
    margin: 100px 0;
}

.hlt-date {
    font-size: 14px;
    text-align: center;
}

.hlt-title-ja h1 {
    font-size: 200%;
}


.rec-info {
    font-size: 120%;
}


/*pagination*/

.pages {
    font-family: Helvetica, Avenir, "lucida grande", sans-serif;
    font-size: 15px;
    width: 100%;
    height: 50px;
    float: left;
    margin: 25px 0;
    text-align: center;
}

.pages .current_page {
    font-size: 15px;
    font-weight: normal;
    padding: 5px 10px;
    background: #000;
    height: 80px;
    width: 150px;
    border-radius: 5%;
    color: #fff;
}

.pages ul {
    list-style: none;
}

.pages li {
    float: left;
    font-weight: 500;
    padding: 0 2px;
}

.pages a:link,
.pages a:visited,
.pages a:active {
    color: #000;
    text-decoration: none !important;
    padding: 7px 12px;
}

.pages a:hover {
    text-decoration: none;
    color: #fff;
    background: #666;
    height: 80px;
    width: 80px;
    border-radius: 5%;
    color: #fff;

}


/*static*/

.splitter {
    border-top: 1px solid #ccc;
    margin: 30px 0;
}

.static {
    font-size: 13px;
}

@media (min-width: 1199px) {

    .static {
        width: 800px;
        margin: 0 auto;
        border: 1px solid #ccc;
      	border-radius:5px;
        padding: 30px;
    }

}

@media (max-width: 1200px) {

}

.static  .splitter {display:none;}  
  
.static p,
.static {
    font-size:12px !Important;
    color: #333;

}

.static h3 {
    font-weight: 600 !important;
    margin: 50px 0 20px 0px !important;
    padding:0 0 5px 0;
    color: #222;
    font-size:18px;
    border-bottom:1px solid #ccc;
}

.static span {
    font-size: 13px;
    color: #333;
}

.static b {
  margin:20px 0 !important;   
  font-weight:normal;
}  
  
.static ol li {
    font-size:12px;
    margin-bottom:10px;
}
.static ol li ol li{  
    font-size:12px;
    margin-left:10px;
}  

/* WL追加 start*/
.cart-item__error {
    display: flex;
    align-items: flex-start;
}

.cart-item__error-text {
    font-size: 1.2rem;
    order: 1;
}

.cart-item__error-text + svg {
    flex-shrink: 0;
    width: 1.2rem;
    margin-right: 0.7rem;
    margin-top: 0.1rem;
}

.cart-item__error-text:empty + svg {
    display: none;
}

/* WL追加 end*/

/*item-list-new*/


.fku-image {
    width: 100% !important;
    height: auto;
}

.fku-image img {
    width: 100% !important;
    height: auto;
}


p.fku-color-h {
    margin: 10px 0 10px 0; /*tnp*/
    font-size: 95% !important;
}

.fku-thumb {
    width: 100%;
    height: 110px;
}

.fku-color {
    width: 30%;
    height: auto;
    float: left;
    margin-right: 3px;
}

.fku-color img {
    width: 100%;
    height: auto;
}


p.ccsize-h {
    margin-bottom: 10px;
}

.ccsize {
    width: 100%;
}

.ccsize p {
    width: 100%;
}

.ccsize span {
    text-align: center;
    margin: 0 3px 4px 0;
    float: left;
    box-sizing: border-box;
}

.ccsize-ng {
    position: relative;
    width: 32px;
    height: 32px;
    border: 1px solid #ccc;
    line-height: 32px;
    background: #fff!important;
}

.ccsize-ok {
    position: relative;
    width: 32px;
    height: 32px;
    border: 1px solid #000;
    line-height: 32px;
}

.ccsize-midium-ng {
    position: relative;
    width: 64px;
    height: 32px;
    border: 1px solid #ccc;
    line-height: 32px;
    background: #fff!important;
}

.ccsize-midium-ok {
    position: relative;
    width: 64px;
    height: 32px;
    border: 1px solid #000;
    line-height: 32px;
}

.ccsize-ok:hover {
/*
    background: #FD5506;
*/
    background: #517896;     
    opacity: 0.6;
}

.ccsize-midium-ok:hover {
/*
    background: #FD5506;
*/    
    background: #517896; 
    opacity: 0.6;
}

.ccsize-select {
/*  
    background: #FD5505; 
    border: 1px solid #FD5505;
*/
    background: #517895; 
    border: 1px solid #517895;
    color: #fff;

}


.ccsize-ng::after {
    position: absolute;
    top: 50%;
    left: 0;
    content: "";
    display: block;
    width: 30px;
    border-top: 1px solid #ccc;
}

.ccsize-midium-ng::after {
    position: absolute;
    top: 50%;
    left: 0;
    content: "";
    display: block;
    width: 30px;
    border-top: 1px solid #ccc;
}

.ccsize-ng::before {
    transform: skewY(-45deg);
}

.ccsize-ng::after {
    transform: skewY(45deg);
}

.ccsize-midium-ng::before {
    transform: skewY(-45deg);
}

.ccsize-midium-ng::after {
    transform: skewY(45deg);
}


.splide-main .splide__slide {
}

.splide-thumb .splide__slide {
    opacity: 1;
}

.splide-thumb .splide__slide.is-active {
    opacity: 1;
    box-sizing: border-box;
    border: none;
}


.splide__arrow--prev {
    display: none !important
}


/*idv-new*/


@media (min-width: 1199px) {

    .item-detail {
        width: 100%;
        padding: 20px 0 0 0;
    }

.sec2.toggle {
    max-height: 500px; /* 開く幅を調整 */
    transition: max-height 0.5s ease; 
    padding: 15px　0 ; 
    line-height: 1.6; 
}  
}
  

    .idv-images {
        width: 49.5%;
        float: left;
        overflow: hidden;
    }

    .idv-images img {
        width: 100%;
    }


    .fku-variation {
        width: 85%;
        margin-top: 10px;
    }

    .fku-variation img {
        width: 100%;
    }ƒ

    .splide__slide {
        box-sizing: border-box !important;
    }

    div.fku-variation li.is-active,
    div.fku-variation li.is-active label img {
        /* border: 1px solid #ccc !important; */
    }
    div.fku-variation li.selected-color,
    div.fku-variation li.selected-color label img{
        border: 1px solid #eeeeee !important;
    }

}

@media (max-width: 1200px) {

    .item-detail {
        width: 100%;
        padding: 20px 0 0 0;
    }

    .idv-images {
        width: 100%;
        float: left;
        overflow: hidden;
        margin-bottom: 20px;
    }

    .idv-images img {
        width: 100%;
    }


    .fku-variation {
/*        width: 100%;*/
	    width:90vw;
        margin-top: 10px;
    }

    .fku-variation img {
        width: 100%;
    }

    .splide__slide {
        box-sizing: border-box !important;
    }

    div.fku-variation li.is-active,
    div.fku-variation li.is-active label img{
        /* border: 1px solid #ccc !important; */
    }
    div.fku-variation li.selected-color,
    div.fku-variation li.selected-color label img{
        border: 1px solid #ccc !important;
    }


}

.size-table {
    border-collapse: collapse
}

.size-table thead{
    background-color: #4e7795;
    color: #fff;
}


.size-table td,
.size-table th{
    padding: 2px 4px 2px 4px;
}

/* WL追加 価格スライダー */
.price-range-content {
    height: 160px;
    overflow: hidden;
    padding: 50px 60px 0px 30px;
}
/* WL追加 ここまで */

.no-wrap{
    white-space: nowrap;
}

.one-row{
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

/* WL追加 商品詳細お気に入りボタン */
.product-favorite-btn {
    border: 1px solid;
    cursor: pointer;
    /* display: block; */
    /* width: 100%; */
    /* padding: 10px 0; */
    /* margin: 20px 0; */
    border-radius: 4px;
    -webkit-appearance: none;
}
/* WL追加 ここまで */

/* WL追加 カートカスタムメッセージ */
.cart-custom-message p,
.cart-custom-message {
    margin: 10px 0 10px;
    text-align: right;
    line-height: 1.7em;
    font-size:100%;
    font-family:''Montserrat','Noto Sans JP',sans-serif;
}
/* WL追加ここまで */

/* WL追加 セール価格デザイン*/
.price-item--sale {
    color: red;
    font-weight: 500;
}
/* WL追加ここまで */

/* WL追加 商品詳細 サイズ説明 */
.size-map-container {
    padding: 10px 0;
}

.size-map-item {
    font-size: 120%;
}

.size-map-item > span:not(:last-child) {
    margin-right: 5px;
}

.size-map-text-header {
    margin: 0 3px 0 0;
}
/* WL追加ここまで */


/****** お気に入り登録追加 22-03-18 ここから　******/

@media(min-width:1199px){

    /*既存を変更*/		
    .idv-images {
        width:49.5%;
        float:left;
        overflow:hidden;
        position:relative;
    }
        
    /*新規追加*/	
    .menu-header .fav_page{ /*WL変更 header a.fav_page */
        width:23px;
        height:23px;
        display:block;
        background:url(./fav_off.png) no-repeat;
        background-size:contain;
        float:right;
        position:relative;
        text-decoration:none;
        z-index:7;
        margin:14px 13px 0 0;
        
        text-indent:100%;
        white-space:nowrap;
        overflow:hidden;
        
    }
    
    /*新規追加*/	
    .favorite {
        z-index:9999;
        position:absolute;
        bottom:2%;
        right:3%;
        width:30px;
        height:30px;
        overflow:hidden;
    }
    .favorite img {
        width:30px;
        height:auto;}
    
    .fav_off img {
        opacity:0.15;
        margin-top:-30px;
    }
    
    .favorite img:hover  {
        margin-top:0px;
        opacity:0.6;
    }
    
    .fav_on img {
        margin-top:0px;
        opacity:1;
    }
    
}
    
@media(max-width:1200px){
    
    /*既存を変更*/		
    .idv-images {
        width:100%;
        float:left;
        overflow:hidden;
        margin-bottom:20px;
        position:relative;
    }
    
    
    /*新規追加*/	
    .menu-header .fav_page{ /*WL変更 header a..fav_page */
        width:19px;
        height:19px;
        display:block;
        background:url(./fav_off.png) no-repeat;
        background-size:contain;
        float:right;
        position:relative;
        text-decoration:none;
        z-index:7;
        margin:7px 10px 0 0;
        
        text-indent:100%;
        white-space:nowrap;
        overflow:hidden;
        
    }
    
    
    /*新規追加*/	
    .favorite {
        z-index:9999;
        position:absolute;
        bottom:2%;
        right:3%;
        width:19px;
        height:19px;
        overflow:hidden;
    }
    .favorite img {
        width:19px;
        height:auto;
    }
    
    .fav_off img {
        opacity:0.15;
        margin-top:-19px;
    }
    
    .favorite img:hover  {
        margin-top:0px;
        opacity:0.6;
    }
    .fav_on img {
        margin-top:0px;
        opacity:1;
    }

}

/****** お気に入り登録追加 22-03-18 ここまで　******/

.easy-points {font-size:95% !important	;color:#666 !important	;}


@media(min-width:1199px){
#shopify-section-announcement-bar {width:100%;margin:0;z-index:99;position:relative;top:10px;}
}
@media(max-width:1200px){
#shopify-section-announcement-bar {width:100%;margin:0;z-index:99;position:relative;top:0px;}

}


.announcement-bar__link {color:#fff !important;font-size:11px;}

label.one_size_label {
    line-height: 13px !important;
}

.one_size_text {
    font-size: 70%;
}

/* 初期状態でボタンを非表示 */
.swiper-button-prev,
.swiper-button-next {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  width: 20px; 
  height: 20px; 
  font-size: 12px; 
}

/* 矢印アイコン自体のサイズ調整*/
.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 12px; 
}

.swiper-container:hover .swiper-button-prev,
.swiper-container:hover .swiper-button-next {
  opacity: 0.3;
  visibility: visible;
}

/*
.filters:hover { background:#666 !important; }
*/


@media (min-width: 1200px) {
    .pass-sp {
        display:none;
    }
}

@media (max-width: 1199px) {
    .pass-pc {
         display:none;
    }
}


/***** Recommended ******/


.container {
  display: grid;
  gap: 10px;
  padding: 10px;
  width:100%;
}
  
.item:hover img {
  opacity: 0.8;
  cursor:pointer;
}

.item:hover h4 {
  opacity: 1;
}
  
/* PC版 */
@media (min-width: 1200px) {
/*  
.item:hover::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
  z-index: 1;
}
*/

  ul.rec_pc_list {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
      margin:0 auto 0 5px;
      padding-bottom:50px;          
    }
  
  
.item:hover h4 {
  font-size:13px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  color: #fff;
  padding:10px;
}
  
.item h4 {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  height: 6.5em; /* 3 行分の高さに設定 */
  overflow: hidden;
}

  
.item {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f0f0f0;
  color: #333;
  position: relative;
  box-sizing: border-box;   
  overflow:hidden;
}
  


.item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

.item-n {
  width: calc(33.333% - 10px);
   padding-top: calc(33.333% - 10px);
  position: relative;
  height:0;
  box-sizing: border-box;    
}

.item-2n {
  width: calc(66.666% - 10px);
  padding-top: calc(33.333% - 10px);
  position: relative;
  height:0;
  box-sizing: border-box;      
}

  .container {
    width:100%;
    display: grid;
    grid-template-areas:
      "item-2n-0 item-n-0"
      "item-n-1 item-n-2 item-n-3"
      "item-2n-1 item-n-4"
      "item-n-5 item-n-6 item-n-7"
      "item-2n-2 item-n-8"
      "item-n-9 item-n-10 item-n-11"      
      grid-gap: 16px;
  }
  .item-2n-0 {    grid-area: item-2n-0;  }  
  .item-n-0 {    grid-area: item-n-0;  }  
  .item-n-1 {    grid-area: item-n-1;  }  
  .item-n-2 {    grid-area: item-n-2;  }  
  .item-n-3 {    grid-area: item-n-3;  }  

  .item-2n-1 {    grid-area: item-2n-1;  }  
  .item-n-4 {    grid-area: item-n-4;  }  
  .item-n-5 {    grid-area: item-n-5;  }  
  .item-n-6 {    grid-area: item-n-6;  }  
  .item-n-7 {    grid-area: item-n-7;  }

  .item-2n-2 {    grid-area: item-2n-2;  }  
  .item-n-8 {    grid-area: item-n-8;  }  
  .item-n-9 {    grid-area: item-n-9;  }  
  .item-n-10 {    grid-area: item-n-10;  }  
  .item-n-11 {    grid-area: item-n-11;  }

}



@media (max-width: 1199px) {

  ul.rec_pc_list {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
    list-style: none;
      padding-bottom:50px;      
  }

  
.item::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50px; 
  background-color: rgba(255, 255, 255, 0);
  z-index: 1;
}
.item h4 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 10px;
  margin: 0;
  line-height: 1.5;
  z-index: 2;
}
.item a h4 {
  text-align:left;
  color:#fff;
  font-size: 11px;
}

  .item {
    position: relative;
    overflow: hidden;
    box-sizing: border-box;

  }

  .item img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
      z-index: 0;
  }

.item-2n {
  width: calc(100% );
  padding-top: calc(50% - 5px); /* 1:2 aspect ratio */
  position: relative;
}

.item-n {
  width: calc(50% - 5px);
  padding-top: calc(50% - 5px); /* 1:1 aspect ratio */
  position: relative;
}


  .item a {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    height: 100%;
    text-align: center;
    color: #000;
  }

  .item h4 {
    margin: 0;
    font-size: 16px;
    line-height: 1.5;
  }
}


/******** styles list ******/

/* CSS */
.styles-container {
  display: grid;
  grid-gap: 5px;
  width: 100%; /* コンテナの横幅を100%に設定 */
  margin: 50px auto; /* コンテナを中央に配置 */
}

@media screen and (min-width: 1200px) {
  .styles-container {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media screen and (max-width: 1199px) {
  .styles-container {
    grid-template-columns: repeat(2, 1fr);
  }
}

.styles-box {
  padding: 5px;
/*
  background-color: #f1f1f1;
  border: 1px solid #ccc;
  box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.1);
*/  
}

.styles-img {
  width: 100%;
  height: auto;
  overflow: hidden; /* 画像がはみ出すのを防ぐ */
  position: relative; /* 子要素の位置を制御するために、relativeを設定 */
}

.styles-img img {
  width: 100%;
  height: auto;
  display: block; /* img要素がインライン要素であるため、ブロック要素に変更 */
  object-fit: cover; /* 画像がコンテナにフィットするように設定 */
  position: relative; /* 親要素（.styles-img）に対する位置を設定するために、relativeを設定 */
}

.rec-info {
  font-size: 12px;
  text-align: left;
}

 .style-all-btn {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
  }

.style-btn {
  margin: 30px 0 15px 0;
  flex-basis: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center; /* 追加 */
}

.top_style_btn {
  display: inline-block;
  font-size: 12px;
  color: #fff !important;
  background-color: #4e7795;
  border-radius: 5px;
  padding: 10px 5px;
  text-decoration: none;
  margin: auto;
  width: 100%; /* ボタンの幅を100%に設定 */
  max-width: 200px; /* ボタンの最大幅を設定 */
}

.top_style_btn:hover {
    background-color: #2A6195;
}


/** 一覧ボタン **/


/*
    nav.filters {
    background-color: #4e7795;
    color: #000;
    font-size:12px;
    border-radius: 4px;
    appearance: none;
    padding: 2px 15px 2px 15px;  
    float:left;
    border:1px solid #ccc;
      margin:0 0 20px 10px;
    }
*/


/* 2024.08.08

    .filters {
      position: fixed;
      right: 20px;
      bottom: 25px;
      background-color: #4e7795;
      color: #fff;
      font-size: 9px;
      border-radius: 50%;
      display: flex;
      justify-content: center;
      align-items: center;
      width: 70px;
      height: 70px;
      text-decoration: none;
     z-index:9999;
    }

  .filters:hoevr {
      background-color: #2A6195;
  }

    .filters a {
      color: #000;
      font-size: 12px;
      text-decoration: none;
    }
*/


    .filters {
      display:inline;
    }

  .filters:a hover {
      color:#666 !important;  
  }

    .filters a {
      border:none !important;
      color: #000 !important;
      font-size: 12px !important;
      background:none !important;
      text-align:center !important;
       padding:0 0 10px 0 !Important;      
    }


   .view-container {
      display: flex;
       justify-content: space-between;
      flex-wrap: nowrap;
      width:100%;
     padding:0px;
      clear:both;
        }

.view-btn-set {
    display:flex;
    align-items: flex-start;
}
/*
.view-btn {
  margin: 0 0px 20px 10px;
  box-sizing: border-box;
}
*/

.view-btn {
  margin: 0 0 15px 10px;
  box-sizing: border-box;
/*  flex: 0 1 auto;   Here is the change */
  flex-grow: 0;
  flex-shrink: 1;
  flex-basis: auto;  
}



.view-btn li a {
  color: #fff;
  text-decoration: none;
  font-size: 12px;
  background: #4e7795;
  border-radius: 4px;
  padding: 2px 10px 2px 10px;
  border: 1px solid #4e7795;
  white-space: nowrap;
}

.view-btn ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  width: auto; /* changed from 100% */
}

.view-btn li a:hover {
      background-color: #2A6195;
}


.view-btn li {
  margin: 3px 5px 0 0px;
  font-size: 12px;
  white-space: nowrap;
}

.page-btn {
  margin-top: 5px;
}

.view-btn:not(.page-btn) {
  min-width: 60px;
  max-width: 150px;  
  flex: 0 1 auto;
}

.page-btn {
  min-width: 60px;
  max-width: 300px;
}


  .limitSelector, .sortSelector {
    background-color: #fff;
    color: #000;
    appearance: none;
    padding: 0px 10px 0px 0px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='12' height='12'%3E%3Cpath fill='%23000' stroke='%23000' stroke-width='0.5' d='M5.293 9.293a1 1 0 011.414 0L12 14.586l5.293-5.293a1 1 0 011.414 1.414l-6 6a1 1 0 01-1.414 0l-6-6a1 1 0 010-1.414z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0px center;
    border: none;
    font-size: 12px;
    line-height: 1.5;
    min-width: 50px;
    height: 24px; 
  }



/** zoom **/

  .overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    z-index: 9999999;
  }

  .lightbox-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow-y: scroll;
    width: 90%;
    max-height: 95%;
    box-sizing: border-box;
  }

  .lightbox-container img {
    margin: 10px 0;
    max-height: 100%;
    cursor: zoom-out;
  }

  @media (max-width: 1200px) {
    .lightbox-container {
      width: 100vw;
      max-height: 100vh;
      padding: 10px;
    }

    .lightbox-container img {
      margin: 0;
      width: 100%;
      height: auto;
      max-height: none;
      max-width: 100%; /* 追加 */
      object-fit: contain; /* 追加 */
    }
  }


.swiper-slide img {
    cursor:pointer;
  }

.swiper-button-prev,
.swiper-button-next {
    cursor: pointer !important;
}      

/*pagefly　最初の要素

div[data-section-id]:first-child {
  margin-top:-30px !important;
  padding-top:50px;

}
*/
.top_style_title {padding:10px 0;font-size:12px !important;  }


/*customer fieldsフォームのマージン調整*/
.cf-field {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.staff_tags {margin-right:0.5em;}


#tagContainer {
  width:100%; font-size:12px;padding:20px 0;text-align:center;
  display:flex;flex-wrap:wrap;justify-content:center;
}
#tagContainer ul {padding:20px 0;}
#tagContainer li {display:inline;}

/* マウスオーバー2枚目表示*/
.hover-image-wrapper {
  position: relative;
  display: block;
  overflow: hidden;
}

.primary-image,
.hover-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  transition: opacity 0.3s ease;
}

.primary-image {
  opacity: 1;
  z-index: 1;
}

.hover-image {
  opacity: 0;
  z-index: 2;
  pointer-events: none;
}

.hover-image-wrapper:hover .primary-image {
  opacity: 0;
}

.hover-image-wrapper:hover .hover-image {
  opacity: 1;
}


/* SOLD OUTレイヤー：画像ブロック内に追加する */
.soldout-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255,255,255,0.7);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.soldout-overlay span {
  font-size: 1.4rem;
  font-weight: bold;
  color: #666;
  text-transform: uppercase;
  z-index: 11;
}

.soldout-overlay {
  animation: fadeIn 0.4s ease-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}


/*feature title mobile*/

@media screen and (max-width: 767px) {
  .pf-c h1 {
    font-size: 21px !important;
  }

  .pf-c h2 {
    font-size: 14px;
  }
}

