@charset "utf-8";
/*------------------------------------------------------------------------------------------
*
*
    webstore_sp.css
*
*
------------------------------------------------------------------------------------------ */
/* --------------------------------------------------------------------------------------------------------------
*
    max-width: 640px;
*
-------------------------------------------------------------------------------------------------------------- */
@media screen and (max-width: 640px) {
.coming_txt{
    margin: 30px 0 20px 0;
    padding: 0 25px;
    font-size: 13px;
    letter-spacing: .1em;
    line-height: 2em;
}

.txt_coming{
    display: none;
}

.sold_resale{
    text-align: left;
    text-indent: -1em;
    padding-left: 1em;
    display: none;
    margin: 10px 0 0 0;
    color: #666;
    font-size: 90%;
    line-height: 1.6em;
}

.sold_resale a{
    text-decoration: underline;
}

.is_pc .sold_resale a:hover,
.is_sp .sold_resale a.touch{
    text-decoration: none;
}

.yuko_higuchi .sold .sold_resale{
    display: block !important;
}

.c_disabled .txt_coming{
    margin: 0 0 -20px 0;
    display: block;
    font-size: 13px;
    line-height: 1.6em;
    color: #ff8000;
    position: relative;
    top: -17px;
}

.c_disabled.end .txt_coming{
    top: -15px !important;
}



#contents_area.single{
    padding: 35px 0 0 0;
}

#contents_area.webstore_cat,
#contents_area.p_fav{
    padding-top: 35px;
}

#contents_area.p_fav{
    min-height: 70vh;
}

#contents_area.p_fav .how_to{
    display: none;
}

.fav_head{
    margin: 0 0 20px 0;
    text-align: center;
}

.fav_head .fav_num{
    font-weight: 500;
    letter-spacing: .1em;
    color: #ff8200;
}

/* --------------------------------------------------
*
    #mv
*
-------------------------------------------------- */
#mv{
    margin: 30px 0 0 0;
    background-position: center;
    background-size: cover;
    position: relative;
    color: #fff;
}

#mv:before{
    content: '';
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(0, 0, 0, .4);
    position: absolute;
    top: 0;
    left: 0;
}

#mv img{
    width: 100%;
    min-height: 260px;
    visibility: hidden;
}

#mv .section_wrap{
    width: 100%;
    height: 100%;
    margin: auto;
    text-align: center;
    display: table;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
}

#mv .section_wrap .section_inner{
    width: 100%;
    height: 100%;
    display: table-cell;
    vertical-align: middle;
}

#mv h1{
    margin: 0 0 25px 0;
    font-size: 20px;
    letter-spacing: .2em;
}

#mv .desc{
    font-size: 13px;
    letter-spacing: .1em;
    line-height: 2em;
}


#head_notes{
    padding: 0 0 10px 0;
}

#head_notes p{
    text-align: center;
    font-size: 12px;
    letter-spacing: .1em;
    line-height: 2em;
    color: #ff8200;
}

#store_desc_sub{
    padding: 20px 10px;
    text-align: center;
}

#store_desc_sub .inner{
    display: inline-block;
    text-align: left;
    padding: 15px;
    background-color: #fff;
}

.is_pc #store_desc_sub .inner a:hover{
    padding: 0 0 2px 0;
    border-bottom: 1px solid transparent;
}

.is_pc #store_desc_sub .inner a:hover,
.is_sp #store_desc_sub .inner a.touch{
    border-bottom: 1px solid #ff8000;
}

#store_desc_sub .inner p{
    margin: 0 0 25px 0;
    font-size: 13px;
    letter-spacing: .1em;
    line-height: 2em;
}

#store_desc_sub .inner p:last-child{
    margin: 0 0 5px 0;
}


/* --------------------------------------------------
*
    #product_wrap
*
-------------------------------------------------- */
#product_wrap{
    margin: 0 auto;
}


/* --------------------------------------------------
*
    #topic_path
*
-------------------------------------------------- */
#topic_path{
    margin: 0 auto;
    padding: 10px 15px 25px 15px;
    position: relative;
    overflow: hidden;
}

#topic_path br{
    display: none !important;
}

#topic_path ul{
    margin: 0 0 10px 0;
    text-align: left;
    letter-spacing: -.40em;
}

#topic_path li{
    box-sizing: border-box;
    display: inline-block;
    letter-spacing: normal;
    font-size: 10px;
    letter-spacing: .05em;
    line-height: 1.5em;
    position: relative;
}

#topic_path li.nw{
    white-space: nowrap !important;
}

#topic_path li:last-child{
    white-space: inherit;
}

#topic_path li:after{
    content: '〉';
    margin: 0 0 0 5px;
    font-size: 10px;
}

#topic_path li:last-child:after{
    display: none;
}

#topic_path li.disabled a{
    text-decoration: none !important;
}

#topic_path li a{
    color: #666;
}

.is_pc #topic_path li a:hover,
.is_sp #topic_path li a.touch{
    text-decoration: underline;
}

#topic_path .how_to{
    padding: 15px 0;
    text-align: center;
    position: relative;
}

#topic_path .how_to a{
    padding: 0 0 2px 0;
    font-size: 14px;
    letter-spacing: .2em;
    color: #ff8000;
    border-bottom: 2px solid #ff8000;
    transition: opacity .1s ease .0s;
}

#topic_path .how_to a:hover,
#topic_path .how_to a.touch{
    opacity: .7;
    transition: opacity .15s ease .05s;
}



/* --------------------------------------------------
*
    #store_info
*
-------------------------------------------------- */
#store_info{
    margin: 0 auto 20px auto;
}

#store_info .col_l{
    margin: 0 0 20px 0;
    width: 50%;
    max-width: 240px;
    margin: 0 auto;
    vertical-align: top;
    text-align: center;
}

#store_info .col_l .pic{
    margin: 0 0 0 0;
    overflow: hidden;
    border-radius: 15px;
}

#store_info .col_r{
    padding: 20px 15px 5px 15px;
    text-align: center;
    vertical-align: top;
    position: relative;
}

#store_info .col_r h2{
    margin: 0 0 5px 0;
    font-size: 16px;
    line-height: 1.6em;
    display: inline-block;
}

#store_info .col_r h2 br{
    display: inherit !important;
}

#store_info .col_r .exhibitor{
    margin: 0 0 20px 0;
    font-size: 15px;
    line-height: 1.5em;
}

#store_info .col_r .shop_link{
    margin: 0 0 30px 0;
}

#store_info .col_r .shop_link a{
    font-size: 13px;
    letter-spacing: .1em;
    border-bottom: 1px solid transparent;
    transition: border .1s ease .0s;
}

.is_pc #store_info .col_r .shop_link a:hover,
.is_sp #store_info .col_r .shop_link a.touch{
    border-bottom: 1px solid #ff8200;
    transition: border .15s ease .05s;
}

#store_info .col_r .desc{
    padding: 20px 5px;
    border-top: 1px solid #ffc878;
    border-bottom: 1px solid #ffc878;
    font-size: 13px;
    letter-spacing: .1em;
    line-height: 2em;
    text-align: left;
}

#store_info .col_r .desc br{
    display: inline !important;
}

#store_info .col_r .desc br + br{
}

#store_info .col_r .desc a{
    padding: 0 0 1px 0;
    border-bottom: 1px solid transparent;
}

.is_pc #store_info .col_r .desc a:hover,
.is_sp #store_info .col_r .desc a.touch{
    border-bottom: 1px solid #ff8000;
}


/* --------------------------------------------------
*
    .img_slider
*
-------------------------------------------------- */
#post_single{
    padding: 0;
    margin: 0 auto 30px auto;
    clear: both;
    overflow: hidden;
    position: relative;
}

.single .how_to{ display: none;}
.single #topic_path{ padding-bottom: 5px;}

#post_single:after{
    clear: both;
    content: '';
    display: block;
    font-size: 0;
}

#post_single .col_l{

}

#post_single .col_r{
    padding: 0 15px;
}

#post_single .col_l .img_slider{
    height: 100%;
    margin: 0 0 40px 0;
    display: block;
    background-color: #fff;
}

#post_single .col_l .img_slider .pic{
    height: 100%;
    padding: 15px;
    transition: border .1s ease .0s;
    overflow: hidden;
    cursor: pointer;
    position: relative;
}

#post_single .col_l .img_slider.on_number .pic:before{
    content: '';
    width: 32px;
    height: 32px;
    text-align: center;
    line-height: 30px;
    display: block;
    position: absolute;
    border-radius: 50%;
    top: 10px;
    right: 10px;
    font-size: 15px;
    background-color: #f0f0f0;
    border: 1px dashed #888;
    color: #666;
    z-index: 1;
}


#post_single .col_l .img_slider .pic img{
    width: 100%;
}

#post_single .col_l .img_slider .pic:after{
    display: none !important;
    content: '';
    width: 26px;
    height: 26px;
    display: block;
    position: absolute;
    background-image:url(../images/parts_ico_zoom.png);
    background-repeat: no-repeat;
    background-size: 26px;
    background-position: center;
    bottom: 15px;
    right: 15px;
    opacity: 0;
    transform-origin: bottom;
    -webkit-transform-origin: bottom;
    transform: scale(.85);
    transition: transform .1s ease .0s, opacity .1s ease .0s;
    -webkit-transform: scale(.85);
    -webkit-transition: transform .1s ease .0s, opacity .1s ease .0s;
}

.is_pc #post_single .col_l .img_slider:hover .pic:after,
.is_sp #post_single .col_l .img_slider.touch .pic:after{
    opacity: 1;
    transform: scale(1);
    transition: transform .15s ease .05s, opacity .15s ease .05s;
    -webkit-transform: scale(1);
    -webkit-transition: transform .15s ease .05s, opacity .15s ease .05s;
}

#post_single .col_l .thumb{
    width: calc(100% + 6px);
    display: inline-block;
    position: relative;
    left: -3px;
    letter-spacing: -.40em;
    display: none;
}

#post_single .col_l .thumb .pic{
    width: calc(16.666% - 18px);
    margin: 0 3px 6px 3px;
    padding: 6px;

    background-color: #fff;
    display: inline-block;
    vertical-align: top;
    cursor: pointer;
    position: relative;
}

#post_single .col_l .thumb .pic:after{
    content: '';
    width: 100%;
    height: 100%;
    display: block;
    opacity: 0;
    background-color: rgba(0, 0, 0, .2);
    position: absolute;
    top: 0;
    left: 0;
    transition: opacity .1s ease .0s;
}

.is_pc #post_single .col_l .thumb .pic:hover:after,
.is_sp #post_single .col_l .thumb .pic.touch:after,
#post_single .col_l .thumb .pic.on:after{
    opacity: 1;
    transition: opacity .15s ease .05s;
}

#post_single .col_r .shop_name{
    font-size: 13px;
    letter-spacing: .1em;
    line-height: 1.6em;
}

#post_single .col_r h2{
    margin: 0 0 15px 0;
    font-size: 18px;
    letter-spacing: .1em;
    line-height: 1.6em;
}

#post_single .col_r h2 br{ display: inline !important;}

#post_single .cart_area{
    width: calc(100%);
}

#post_single .cart_area .p_img{
    width: 180px;
    margin: 0 auto 20px auto;
    display: block;
    text-align: center;
    vertical-align: top;
}

#post_single .cart_area .p_img li{
    width: 180px;
    display: none;
}

#post_single .cart_area .p_img li img{
    width: 100%;
}
    
#post_single .cart_area p.price{
    margin: 0 0 20px 0;
    padding: 15px 5px;
    border-top: 1px solid #FFC878;
    border-bottom: 1px solid #FFC878;
    font-size: 18px;
    letter-spacing: .1em;
    opacity: 0;
}

#post_single .cart_area p.price .s{
    margin: 10px 0 0 0;
    text-indent: -.5em;
    font-size: 12px;
    display: block;
    font-weight: normal !important;
}

#post_single .cart_list{
    margin: 0 0 25px 0;
}

#post_single .cart_list .price,
#post_single .cart_list .cart{ display: none;}

#post_single .cart_list .stock{
    margin: 10px 0 5px 0;
    font-size: 12px;
    color: #ff8000;
    display: block;
}

#post_single .cart_list .shipment{
    font-size: 13px;
    margin: 10px 0 0 0;
    display: block;
}

#post_single .cart_list .domestic{
    font-size: 13px;
    margin: 10px 0 0 0;
    display: block;
}

.cart_area{
    margin: 0 0 20px 0;
}

.cart_area select{
    width: calc(100%);
    height: 40px;
    font-size: 16px;
    display: inline-block;
    vertical-align: bottom;
    color: #666;
}

.cart_area select{
    margin: 0 0 20px 0;
    padding: 0 45px 0 15px;
    opacity: 0;
    border: 1px solid #CACACA;
    border-radius: 3px;
    background-image:url(../images/parts_ico_select_arrow.png);
    background-repeat: no-repeat;
    background-size: 6px;
    background-position: calc(100% - 20px) center;
    -webkit-appearance: none;
    background-color: #fff;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    transition: border .1s ease .0s;
    position: relative;
    cursor: pointer;
}

.cart_area select.disabled{
    display: none;
}

.is_pc .cart_area select:hover,
.is_sp .cart_area select.touch{
    border-color: #10375c;
	transition: border .15s ease .05s;
}

#post_single select option{
    padding: 10px !important;
    font-size: 16px !important;
    background-color: #fff !important;
    outline: none;
    border: none;
}

#post_single .desc{
    box-sizing: border-box;
    border-top: 1px solid #FFC878;
}

#post_single .desc a{
    padding: 0 0 2px 0;
    border-bottom: 1px solid transparent;
}

.is_pc #post_single .desc a:hover,
.is_sp #post_single .desc a.touch{
    border-bottom: 1px solid #ff8000;
}

#post_single .desc::-webkit-scrollbar{ width: 6px; background:#fff3df; border-radius: 6px;}
#post_single .desc::-webkit-scrollbar:horizontal{ height: 6px; border-radius: 6px;}
#post_single .desc::-webkit-scrollbar-button{ width: 6px; height: 6px; background: #979797; border-radius: 6px;}
#post_single .desc::-webkit-scrollbar-piece{ background:#fff3df; border-radius: 6px;}
#post_single .desc::-webkit-scrollbar-piece:start{ background:#fff3df; border-radius: 6px;}
#post_single .desc::-webkit-scrollbar-thumb{ background:#979797; border-radius: 6px; transition: background .15s ease .05s;}
#post_single .desc::-webkit-scrollbar-corner{ background:#979797; border-radius: 6px; transition: background .15s ease .05s;}
#post_single .desc::-webkit-scrollbar-thumb:hover{ background:#000; border-radius: 6px; transition: background .15s ease .05s;}

#post_single .desc p{
    padding: 20px 5px 0 5px;
    line-height: 1.8em;
    font-size: 13px;
    letter-spacing: .1em;
}

#post_single .desc br{
    display: inline !important;
}



#post_single .section_cart{
    position: relative;
    text-align: center;
    visibility: hidden;
}

#post_single .btn_cart a{
    max-width: 260px;
    height: 40px;
    padding: 0 20px;
    margin: 0 auto;
    line-height: 40px;
    text-align: left;
    box-sizing: border-box;
    background-image:url(../images/parts_cart_ico_cart.png);
    background-repeat: no-repeat;
    background-position: calc(100% - 10px) center;
    background-size: 19px;
    border-radius: 3px;
    display: block;
    background-color: #FF8000;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .1em;
    transition: background .1s ease .0s;
}

#post_single .btn_cart a:hover,
#post_single .btn_cart a.touch{
    background-color: #ff6d00;
    transition: background .15s ease .05s;
}

.sale_s #post_single .btn_cart.sold a{
    background: none;
    background-color: #666666;
    cursor: default;
    opacity: 1 !important;
}

#post_single .btn_fav{

}

#post_single .btn_fav .fav{
    max-width: 260px;
    height: 40px;
    margin: 0 auto;
    padding: 0 20px;
    line-height: 36px;
    text-align: left;
    box-sizing: border-box;
    background-image:url(../images/parts_ico_fav_on.png);
    background-repeat: no-repeat;
    background-position: calc(100% - 10px) center;
    background-size: 15px;
    border: 2px solid #CACACA;
    border-radius: 3px;
    display: block;
    background-color: #EAEAEA;
    color: #666;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .1em;
    position: relative;
    cursor: pointer;
    transition: border .1s ease .0s, background .1s ease .0s, color .1s ease .0s;
}

#post_single .btn_fav .fav.on{
    background-color: #ffdabc !important;
    border: 2px solid #ff8000 !important;
    color: #ff8000 !important;
    transition: border .15s ease .05s, background .15s ease .05s, color .15s ease .05s;
}

#post_single .btn_fav .fav:after{
    content: '';
    width: 17px;
    height: 17px;
    opacity: 1 !important;
    background-image:url(../images/parts_ico_fav_off.png);
    background-repeat: no-repeat;
    background-size: 17px;
    background-position: center;
    position: absolute;
    top: 9px;
    right: 9px;
    transform: scale(1);
    -webkit-transform: scale(1);
    transition: opacity .1s ease .0s, transform .1s ease .0s;
    -webkit-transition: opacity .1s ease .0s, transform .1s ease .0s;
}

#post_single .btn_fav .fav.on:after{
    opacity: 0 !important;
    transition: opacity .15s ease .05s, transform .15s ease .05s;
    -webkit-transition: opacity .15s ease .05s, transform .15s ease .05s;
}

.is_pc #post_single .btn_fav .fav:hover,
.is_sp #post_single .btn_fav .fav.touch{
    border: 2px solid #ff8000;
    transition: border .15s ease .05s, background .15s ease .05s;
}

.is_pc #post_single .btn_fav .fav:hover:after,
.is_sp #post_single .btn_fav .fav.touch:after{
    transform: scale(1.1);
    -webkit-transform: scale(1.1);
    transition: opacity .15s ease .05s, transform .15s ease .05s;
    -webkit-transition: opacity .15s ease .05s, transform .15s ease .05s;
}

#post_single .cat_ico{
    margin: 10px 0 15px 0;
}

#post_single .cat_ico p{
    width: 60px;
    height: 18px;
    margin: 0 10px 0 0;
    line-height: 18px;
    text-align: center;
    box-sizing: border-box;
    display: inline-block;
    font-size: 11px;
    color: #fff;
    border-radius: 3px;
}

#post_single .cat_ico p.limited{ background-color: #32b200;}
#post_single .cat_ico p.lottery{ background-color: #ff8000;}


#related_post{
    padding: 20px 10px;
    margin: 0 auto;
    overflow: hidden;
}

#related_post .section_inner{
    width: calc(100% + 10px);
    margin: 0 auto;
    letter-spacing: -.40em;
}

#related_post .section_inner li{
    width: calc(33.333% - 10px);
    margin: 0 10px 10px 0;
    display: inline-block;
    vertical-align: top;
}

#related_post .section_inner li img{
    width: 100%;
}

#related_post .section_inner .btn_store_top{
    margin: 10px 0 0 0;
    padding: 0 0 2px 0;
    border-bottom: 1px solid transparent;
    text-align: right;
    font-size: 13px;
    letter-spacing: .1em;
    position: relative;
    right: 10px;
}

.is_pc #related_post .section_inner .btn_store_top a:hover,
.is_sp #related_post .section_inner .btn_store_top a.touch{
    padding: 0 0 2px 0;
    border-bottom: 1px solid #ff8000;
}


/* --------------------------------------------------
*
    #techo_banner
*
-------------------------------------------------- */
#techo_banner{
    margin: 0 auto;
    padding: 0 0 0 0;
}

#techo_banner ul{
    letter-spacing: -.40em;
}

#techo_banner li{
    margin: 0 0 20px 0;
    padding: 0 20px;
    text-align: center;
}

#techo_banner li img{
    width: 100%;
    max-width: 420px;
}


/* --------------------------------------------------
*
    #product_nav
*
-------------------------------------------------- */
.search_store .search_inner{
/*    display: block !important; */
}

#product_nav{
    width: 100%;
    background-color: #fff;
    border-bottom: 1px solid #aeaeae;
    clear: both;
    position: fixed;
    letter-spacing: -.40em;
    top: 45px;
    left: 0;
    z-index: 3;
}

#product_nav_inner{
    margin: 0 auto;
}

#product_nav .nav_wrap{
    width: 50%;
    display: inline-block;
    vertical-align: top;
}

#product_nav h4{
    padding: 10px 0 10px 10px;
    font-size: 12px;
    letter-spacing: .1em;
/*    border-top: 1px solid #666; */
    position: relative;
    cursor: pointer;
    transition: color .1s ease .0s;
}

#product_nav .on h4{
    background-color: #666;
    color: #fff !important;
    transition: color .0s ease .0s !important;
}

#product_nav h4:hover{
    color: #ff8200;
    transition: color .15s ease .05s;
}

#product_nav h4:after{
    content: '';
    width: 9px;
    height: 100%;
    display: block;
    background-image:url(../images/parts_arrow_btm.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 9px;
    position: absolute;
    top: 0;
    right: 5px;
}

#product_nav h4:after{
    content: '';
    width: 9px;
    height: 5px;
    display: block;
    background-image:url(../images/parts_arrow_btm.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 9px;
    position: absolute;
    top: 15px;
    right: 10px;
    transform-origin: center;
    -webkit-transition: transform .1s ease .0s;
    transition: transform .1s ease .0s;
    -webkit-transition: transform .1s ease .0s;
}

#product_nav .on h4:after{
    width: 12px;
    height: 12px;
    background-size: 12px;
    background-image:url(../images/parts_ico_close.png);
    transform: rotate(-90deg);
    transition: transform .15s ease 0s;
    -webkit-transform: rotate(-90deg);
    -webkit-transition: transform .15s ease 0s;
    top: 10px;
}

#product_nav .search_inner{ display: none;}
#product_nav .search_inner{
    width: 100%;
    background-color: rgba(255, 255, 255, .97);
    padding: 0 0 60px 0;
    overflow-x: hidden;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
    position: absolute;
    top: 33px;
    left: 0;
    z-index: 2;
}

.is_sp #product_nav .search_inner{
    min-height: calc(100vh - 45px);
}

#product_nav .search_inner .cat{
    padding: 15px 10px 0 10px;
    font-size: 12px;
    letter-spacing: .1em;
}

#product_nav .search_inner .cat:last-child{
    padding-bottom: 40px;
}

#product_nav .search_inner .cat h5{
    margin: 0 0 15px 5px;
    color: #ff8000;
}

#product_nav .search_inner .cat ul{
    width: calc(100% + 10px);
    padding: 0 0 20px 0;
    letter-spacing: -.40em;
}

#product_nav .search_inner .cat li{
    width: 100%;
    margin: -1px 10px 0 0;
    display: inline-block;
    vertical-align: top;
    border-top: 1px solid #eaeaea;
    border-bottom: 1px solid #eaeaea;
}

#product_nav .search_inner .cat li a{
    width: 100%;
    min-height: 40px;
    height: auto !important;
    padding: 10px 30px 10px 10px;
    box-sizing: border-box;
    background-image:url(../images/parts_arrow_right.png);
    background-repeat: no-repeat;
    background-position: calc(100% - 10px) center;
    background-size: 5px;
    display: table;
    color: #666;
    letter-spacing: .1em;
    line-height: 1.4em;
    transition: color .1s ease .0s, background .1s ease .0s;
}

#product_nav .search_inner .cat li a span{
    display: table-cell;
    vertical-align: middle;
}

.is_pc #product_nav .search_inner .cat li a:hover,
.is_sp #product_nav .search_inner .cat li a.touch{
    color: #ff8200;
    background-position: calc(100% - 5px) center;
    transition: color .15s ease .05s, background .15s ease .05s;
}


/* --------------------------------------------------
*
    .product_list
*
-------------------------------------------------- */
.product_list{
    clear: both;
    padding: 20px 10px 0 10px;
}

.product_list ul{
    padding: 0 0 0 0;
    width: calc(100% + 10px);
    letter-spacing: -.40em;
}

.product_list li{
    width: calc(50% - 10px);
    margin: 0 10px 30px 0;
    opacity: 0;
    display: inline-block;
    vertical-align: top;
    letter-spacing: normal;
    font-size: 13px;
    position: relative;
    word-wrap: break-word;
}

.product_list li a{
    display: block;
    position: relative;
}

.product_list li .pic{
    margin: 0 0 15px 0;
    background-color: #fff;
    box-sizing: border-box;
    transition: border .1s ease .0s;
    position: relative;
}

.product_list li .pic img{
    width: 100%;
}

.sale_s .product_list li.sold .pic:after{
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    opacity: 1;
    background-color: rgba(171, 171, 171, .5);
    position: absolute;
    bottom: 0;
    left: 0;
    transition: opacity .1s ease .0s;
}

.product_list li .pic span{
    padding: 10px;
    display: block;
    box-sizing: border-box;
}

.product_list li .pic img{
    width: 100% !important;
    height: auto !important;
    opacity: 1 !important;
}

.product_list li .cat{
    position: absolute;
    bottom: 5px;
    left: -5px;
}

.product_list li .cat p{
    width: 60px;
    height: 18px;
    margin: 0 0 5px 0;
    line-height: 18px;
    text-align: center;
    box-sizing: border-box;
    font-size: 11px;
    color: #fff;
    border-radius: 3px;
}

.sale_s .product_list li.sold .cat:after,
.sale_s .product_list li .cat.coming_soon:after{
    content: 'SOLD OUT';
    display: block;
    width: 68px;
    height: 18px;
    margin: 0 0 5px 0;
    line-height: 18px;
    background-color: #666;;
    text-align: center;
    box-sizing: border-box;
    font-size: 11px;
    color: #fff;
    border-radius: 3px;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
}

.sale_s .product_list li.sold .pic.coming_soon:after{
    display: none !important;
}

.sale_s .product_list li .cat.coming_soon:after{
    width: 100px;
    content: 'COMING SOON' !important;
    background-color: #ff8000 !important;
}

.sale_s .product_list li.sold .cat p{
    display: none;
}

.product_list li .cat p.limited{ background-color: #32b200;}
.product_list li .cat p.lottery{ background-color: #ff8000;}

.product_list li h3{
    margin: 0 0 10px 0;
    padding: 0 5px;
    color: #666;
    line-height: 1.6em;
    letter-spacing: .1em;
    font-weight: 500;
    transition: color .1s ease .0s;
}

.product_list .store_name{
    margin: 0 0 3px 0;
    padding: 0 5px;
    color: #666;
    letter-spacing: .05em;
    line-height: 1.7em;
    font-size: 11px;
    transition: color .1s ease .0s;
}

.is_pc .product_list li:hover .store_name,
.is_sp .product_list li.touch .store_name,
.is_pc .product_list li:hover h3,
.is_sp .product_list li.touch h3{
    color: #ff8200;
    transition: color .15s ease .05s;
}

.product_list li .price{
    padding: 0 5px;
    letter-spacing: .05em;
    font-size: 12px;
}

.product_list li .fav{
    width: 17px;
    height: 17px;
    padding: 5px;
    background-image:url(../images/parts_ico_fav_on.png);
    background-repeat: no-repeat;
    background-size: 17px;
    background-position: center;
    position: absolute;
    z-index: 2;
    top: 5px;
    right: 5px;
    transform: scale(1);
    -webkit-transform: scale(1);
    cursor: pointer;
}

.product_list li .fav:after{
    content: '';
    width: 17px;
    height: 17px;
    opacity: 1 !important;
    background-image:url(../images/parts_ico_fav_off.png);
    background-repeat: no-repeat;
    background-size: 17px;
    background-position: center;
    position: absolute;
    top: 5px;
    right: 5px;
    transform: scale(1);
    -webkit-transform: scale(1);
    transition: opacity .1s ease .0s, transform .1s ease .0s;
    -webkit-transition: opacity .1s ease .0s, transform .1s ease .0s;
}

.product_list li .fav.on:after{
    opacity: 0 !important;
    transition: opacity .15s ease .05s, transform .15s ease .05s;
    -webkit-transition: opacity .15s ease .05s, transform .15s ease .05s;
}

.is_pc .product_list li .fav:hover,
.is_sp .product_list li .fav.touch{
    transform: scale(1.1);
    -webkit-transform: scale(1.1);
    transition: opacity .15s ease .05s, transform .15s ease .05s;
    -webkit-transition: opacity .15s ease .05s, transform .15s ease .05s;
}

.is_pc .product_list li .fav:hover:after,
.is_sp .product_list li .fav.touch:after{
    opacity: 0;
    transition: opacity .15s ease .05s, transform .15s ease .05s;
    -webkit-transition: opacity .15s ease .05s, transform .15s ease .05s;
}


/* --------------------------------------------------
*
    #pickup
*
-------------------------------------------------- */
#pickup{
    margin: 0 0 40px 0;
    background-color: #fff;
}

#pickup h2{
    margin: 0 0 40px 0;
    font-size: 24px;
    font-weight: 500;
    letter-spacing: .2em;
    color: #ff8200;
    text-align: center;
}

#pickup .pickup_inner{
    margin: 0 auto;
}

#pickup.product_list ul{
    padding: 0 0 0 0 !important;
}

#pickup.product_list li .pic{
    background-color: #f3f3f3;
}


/* --------------------------------------------------
*
    #section_btm_info
*
-------------------------------------------------- */
#section_btm_info{
    padding: 30px 0 40px 0;
    clear: both;
    background-color: #fff;
}

#section_btm_info br{
    display: inline !important;
}

#section_btm_info .section_inner{
    padding: 0 20px;
    margin: 0 auto;
    letter-spacing: -.40em;
}

#section_btm_info .section_spec,
#section_btm_info .section_notes{
    letter-spacing: .1em;
    vertical-align: top;
    border-bottom: 1px solid #eaeaea;
}

#section_btm_info .section_spec{
    margin: 0 0 40px 0;
}

#section_btm_info h3,
#section_btm_info h4{
    font-size: 15px;
    letter-spacing: .1em;
}

#section_btm_info h3{
    margin: 0 0 20px 0;
}

#section_btm_info li{
    margin: 0 0 -1px 0;
    font-size: 13px;
    letter-spacing: .1em;
    line-height: 1.8em;
}

#section_btm_info h4{
    padding: 10px 30px 10px 10px;
    font-size: 14px;
    letter-spacing: .1em;
    line-height: 1.5em;
    border-top: 1px solid #eaeaea;
    border-bottom: 1px solid #eaeaea;
    position: relative;
    transition: color .1s ease;
}

#section_btm_info .section_notes h4.on,
.is_pc #section_btm_info .section_notes h4:hover,
.is_sp #section_btm_info .section_notes h4.touch{
    color: #ff8000;
    transition: color .15s ease .05s;
    cursor: pointer;
}

#section_btm_info .section_notes h4:after{
    content: '';
    display: block;
    width: 9px;
    height: 5px;
    background-image:url(../images/parts_accordion_arrow_btm.png);
    background-repeat: no-repeat;
    background-size: 9px;
    position: absolute;
    top: calc(50% - 3px);
    right: 15px;
    transform: rotate(0deg);
    transition: transform .15s ease .0s;
}

.is_pc #section_btm_info .section_notes h4:hover:after,
.is_sp #section_btm_info .section_notes h4.touch:after{
    transform: rotate(-90deg);
    transition: transform .15s ease .05s;
}

#section_btm_info .section_notes h4.on:after{
    transform: rotate(-180deg) !important;
    transition: transform .15s ease .0s;
}

#section_btm_info li .t_inner{
    padding: 15px;
}

#section_btm_info li dl{
    
}

#section_btm_info li dt{

}

#section_btm_info li dd{
    margin: 0 0 20px 0;
    padding: 0 15px;
}

#section_btm_info li dd:last-child{
    margin: 0;
}

.section_notes .t_inner{
    display: none;
    overflow: hidden;
}

.section_notes .t_inner a{
    padding-bottom: 2px;
    border-bottom: 1px solid transparent;
}

.is_pc .section_notes .t_inner a:hover,
.is_sp .section_notes .t_inner a.touch{
    border-bottom: 1px solid #ff8000;
}


/*
*
    .search
*
*/

#contents_area.search{
    padding: 35px 0 0 0;
    min-height: 70vh;
}

#contents_area.search .result{
    margin: 0 0 20px 0;
    text-align: center;
}

.is_pc #product_nav .nav_wrap{
    width: calc(50% - 16px);
}

.is_sp #product_nav .nav_wrap{
    width: calc(50% - 14px);
}

#product_nav_inner{

}

#product_nav_inner:after{
    content: '';
    display: block;
    clear: both;
    font-size: 0;
}

.search_ico{
    width: 32px;
    height: 32px;
    background-color: #666;
    background-image:url(../images/parts_ico_search.png);
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: center;
    border: none;
    outline: none;
    vertical-align: top;
    display: inline-block;
    cursor: pointer;
    position: relative;
    transition: background .15s ease .0s;
    position: fixed;
    top: 45px;
    right: 0;
}

.search_form.on .search_ico{
    background-image:url(../images/parts_ico_close.png);
}

.is_pc .search_ico:hover,
.is_sp .search_ico.touch{
    background-color: #555;
    transition: background .15s ease .05s;
}

.search_form{
    width: 100%;
    letter-spacing: -.40em;
    position: fixed;
    right: -100%;
    top: 45px;
    transition: right .25s ease 0s;
}

.search_form.on{
    right: 0;
    transition: right .25s ease 0s;
}

.search_form input[type="text"]{
    width: calc(100% - 32px);
    height: 32px;
    padding: 0 10px;
    display: inline-block;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 32px;
    border: none;
    border-radius: 0;
    vertical-align: top;
    background-color: #fff;
    outline: none;
    transition: background .15s ease .0s;
}

.is_pc .search_form input[type="text"]:hover,
.is_sp .search_form input[type="text"].touch{
    transition: background .15s ease .05s;
}

.search_form input::-webkit-input-placeholder,
.search_form input::-ms-input-placeholder,
.search_form input::-moz-placeholder{
    color: #aaa !important;
    font-weight: normal;
}
:placeholder-shown{ color: #aaa;}
    
.search_form input[type="submit"]{
    width: 32px;
    height: 32px;
    background-color: #666;
    background-image:url(../images/parts_ico_search.png);
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: center;
    border: none;
    outline: none;
    vertical-align: top;
    display: inline-block;
    visibility: hidden;
    cursor: pointer;
    position: relative;
    transition: background .15s ease .0s;
    transform: translate3d(0, 0, 0);
    top: 0;
    right: 0;
}

.search_form input[type="submit"]:hover{
    background-color: #555;
    transition: background .15s ease .05s;
}



/* --------------------------------------------------
*
    #modal
*
-------------------------------------------------- */
#modal{
    width: 100%;
    text-align: center;
    height: 100%;
    visibility: hidden;
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 65535;
}

#modal.off{
    opacity: 0;
    transition: opacity .3s ease;
}

#modal_inner{
    width: auto;
    max-width: auto;
    height: auto;
    margin: 0 auto;
    display: inline-block;
    text-align: center;
    padding: 10px 10px 60px 10px;
    line-height: 0;
    background-color: #fff;
    box-sizing: border-box;
    opacity: 0;
    -ms-filter: "alpha(opacity=0)";
    text-align: left;
    position: relative;
    top: 0;
    z-index: 2;
}

#modal_data{
    height: 100%;
    display: inline-block;
    line-height: 0;
    transition: height .3s ease !important;
}

#modal_data img{
    width: 100%;
    height: auto;
    line-height: 0;
    transform: translate3d(0, 0, 0);
}

#modal .overlay{
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: .5;
    -ms-filter: "alpha(opacity=50)";
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
    cursor: pointer;
}

#modal_data{
    text-align: center;
}

.modal_loader{
    width: 100%;
    height: 100%;
    display: none;
    opacity: 0;
    min-height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 65535;
}

.modal_loader span{
    width: 48px;
    height: 48px;
    display: block;
    background-image:url(../images/img_loader.gif);
    background-repeat: no-repeat;
    background-size: 48px;
    position: absolute;
    top: calc(50% - 24px);
    left: calc(50% - 24px);
}

.btn_nav .disabled{
    visibility: hidden;
}

.btn_close{
    width: 100px;
    display: inline-block;
    font-size: 13px;
    font-weight: bold;
    text-align: center;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: absolute;
    bottom: 15px;
    left: calc(50% - 50px);
}

.btn_close a{
    padding: 0 15px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    background-color: #fff;
    border: 1px solid #ff8000;
    color: #ff8000;
    background-repeat: no-repeat;
    background-size: 29px;
    background-position: 15px center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .btn_close a:hover,
.is_sp .btn_close a.touch{
    opacity: 1 !important;
    background-color: rgba(258, 128, 0, .2);
    background-position: 12px center;
    transition: background .15s ease .05s;
}

.nav_prev{
    display: inline-block;
    font-size: 13px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: absolute;
    bottom: 15px;
    left: calc(5%);
}

.nav_prev a{
    padding: 0 10px 0 35px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    background-color: #fff;
    border: 1px solid #ff8000;
    color: #ff8000;
    background-image:url(../images/parts_ico_dot_arrow_l.png);
    background-repeat: no-repeat;
    background-size: 24px;
    background-position: 10px center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .nav_prev a:hover,
.is_sp .nav_prev a.touch{
    opacity: 1 !important;
    background-color: rgba(208, 220, 229, 1);
    background-position: 12px center;
    transition: background .15s ease .05s;
}

.nav_next{
    display: inline-block;
    font-size: 13px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: absolute;
    bottom: 15px;
    right: calc(5%);
}

.nav_next a{
    padding: 0 35px 0 10px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    background-color: #fff;
    border: 1px solid #ff8000;
    color: #ff8000;
    background-image:url(../images/parts_ico_dot_arrow.png);
    background-repeat: no-repeat;
    background-size: 24px;
    background-position: calc(100% - 10px) center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .nav_next a:hover,
.is_sp .nav_next a.touch{
    opacity: 1 !important;
    background-color: rgba(258, 128, 0, .2);
    background-position: calc(100% - 12px) center;
    transition: background .15s ease .05s;
}


} /* ----- max-width: 640px ----- */
