@charset "utf-8";





/* Product Styles
-------------------------------------------------------------*/

/* products label */

figure.sold-out:before { background: url(../img/common/label_sold_out_w120.png) no-repeat center; }

figure.none-handling:before { background: url(../img/common/label_none_handling_w120.png) no-repeat center; }

figure.sold-out:before,
figure.none-handling:before {
  background-size: 60px;
  width:  60px;
  height: 33px;
  display: block;
  content: "";
  margin: auto;
  position: absolute;
      top: 0;
     left: 0;
    right: 0;
   bottom: 0;
}

figure.photo.sold-out:before,
figure.photo.none-handling:before {
  background-size: 100px;
  width: 100px;
  height: 55px;
}



/* .priceOff */

.priceOff {
  width:  30px;
  height: 30px;
  padding-top: 4px;
  font-size: 10px;
  font-weight: bold;
}





/* Product Styles
-------------------------------------------------------------*/

#productWrapper { margin-bottom: 1.42em; position: relative; }

#productWrapper #productMain { padding-top: 260px; }

#productMain { font-size: 0.9em; }



/* #productInfo */

#productWrapper #productInfo h1 { margin-bottom: 10px; }

#productInfo .company,
#productInfo .offers { display: table; margin-bottom: 10px; }
  #productInfo .offers span:after { content: "～"; }

#productInfo #productCategory { margin: -5px -5px 1em; overflow: hidden; }

#productInfo #productCategory li { float: left; margin: 5px; }

#productInfo #productStock { margin-bottom: 20px; }

#productInfo #productStock span {
  font-size: 1.3em;
  margin-bottom: 8px;
  display: table;
}

#productInfo #productStock span.in-stock { color: #008a00; }
#productInfo #productStock span.none-handling,
#productInfo #productStock span.sold-out { color: #e03311; }

#productInfo #productSwitch p { margin-bottom: 20px; }

#productInfo #productSwitch div {
  border: 1px solid #1a1a1a;
  background: #fff;
  color: #1a1a1a;
  padding: 10px;
  margin-right: 6px;
  font-size: 1em;
  display: inline-block;
  cursor: pointer;
}
  #productInfo #productSwitch div:hover { background: #f7f7f7; }

#productInfo #productSwitch { margin-bottom: 1.88em; }

#productInfo #productSwitch div.focus {
  border: 2px solid #e03311;
  background: #ffc !important;
  color: #e03311;
  font-weight: bold;
}



/* .firstCart */

#productWrapper #one_cart {
  color: #1a1a1a;
  box-sizing: border-box;
  -webkit-border-radius: 0.4em;
     -moz-border-radius: 0.4em;
          border-radius: 0.4em;
}

#productWrapper #one_cart p.announce { text-align: center; margin-top: 16px; }

#productWrapper #one_cart p.announce b { margin-bottom: 10px; display: block; }

#productWrapper .first-cart h2 { margin-bottom: 1.2em; font-weight: bold; }

#productWrapper .first-cart p  { margin-bottom: 1.2em; }

#productWrapper .first-cart .price { margin-left: 6px; }

#productWrapper .first-cart .price + .price { font-size: 12px; }

#productWrapper .first-cart select { font-size: 18px; padding: 4px 30px 4px 10px; }

#productWrapper .first-cart small {
  margin-top: 1em;
  line-height: 1.4;
  color: #666;
  display: inline-block;
}



/* .image-block */

#productWrapper .image-block {
  width: 100%;
  display: inline-block;
  position: absolute;
    top: 0;
}

#productWrapper .image-block .photo { width: 180px; margin: 0 auto 16px; position: relative; }

#productWrapper .image-block .photo img {
  max-width:  180px;
  max-height: 180px;
  margin: 0 auto;
}

#productWrapper .image-block ul {
  margin: 0 auto;
  display: table;
  overflow: hidden;
}

#productWrapper .image-block li {
  float: left;
  width: 40px;
  border: 1px solid #ccc;
  margin: 0 4px;
}

#productWrapper .image-block li img { max-width: 40px; }

#productWrapper .image-block li.focus { border-color: #1a1a1a; }

#productWrapper .image-block li:hover { cursor: pointer; }



/* #pricsListTable */

#pricsListTable { margin: 0 -15px; }

#pricsListTable table {
  width: 100%;
  margin-bottom: 1.88em;
  color: #1a1a1a;
}

#pricsListTable caption {
  color: #e03311;
  border-top: 2px solid #e03311;
  border-bottom: 2px solid #e03311;
  font-weight: bold;
  padding: 8px 10px;
  margin-bottom: 10px;
}

#pricsListTable th {
  font-size: 13px;
  border-bottom: 1px solid #a1a1a1;
  padding-bottom: 10px;
}

#pricsListTable td {
  font-size: 13px;
  border-bottom: 1px solid #ccc;
  padding: 10px 0;
  display: table-cell;
  vertical-align: middle;
}
  #pricsListTable td:first-child { padding-left:  3%; }
  #pricsListTable td:last-child  { padding-right: 3%; }

#pricsListTable s { font-size: 0.9em; }

#pricsListTable td.order { width: 40px; padding-left: 10px; }

#pricsListTable td.order .sold-out {
  color: #e03311;
  border: 1px dashed #e03311;
  padding: 4px;
  text-align: center;
  font-size: 0.88em;
  display: block;
  -webkit-border-radius: 0.5em;
     -moz-border-radius: 0.5em;
          border-radius: 0.5em;
}

#pricsListTable .per { display: none; }



/* #detailAgain */

#detailAgain #productInfo { margin-bottom: 1.25em; }

#detailAgain #pricsListTable table { margin-bottom: 0.88em; }





/* List Styles
-------------------------------------------------------------*/

/* list common */

.listitem a {
  color: #333;
  text-decoration: none;
  display: block;
  overflow: hidden;
  position: relative;
}

.listitem a div { margin-bottom: 10px; }
  .listitem a div:last-child,
  .listitem .rating-score, .listitem .rating-count { margin-bottom: 0; }

.listitem .product-sale, .listitem .product-category, .listitem .product-disease { font-size: 12px; }

.listitem .product-img {
  width: 70px;
  margin: 0 auto 10px;
  display: block;
  position: relative;
}

.listitem .product-img img { width: 70px; }

.listitem a .product-name { color: #039; text-decoration: underline; }
  .listitem a:hover .product-name { color: #c60; text-decoration: none; }

.listitem .price { margin-left: 6px; }

.listitem .rating-score { float: left; display: inline-block; }

.listitem .rating-count { display: inline-block; }

.listitem .sticky {
  width: auto;
  background: #1a1a1a;
  color: #fff;
  padding: 3px 6px;
  font-size: 0.88em;
  z-index: 1;
  position: absolute;
    top: 0;
   left: 0;
}



/* .product-list */

.product-list {
  width: 100%;
  font-size: 0.94em;
  position: relative;
}

.product-list + * { clear: both; }

.product-list .list-recommended p,
.product-list .list-review p {
  line-height: 1.54 !important;
  margin-bottom: 0 !important;
  color: #555;
}

#listPage .list-hits, .list-refine { margin-bottom: 1.15em; overflow: hidden; }

#listPage .list-lead {
  font-size: 0.88em;
  margin-bottom: 1.25em;
  line-height: 1.5;
}

#listPage .list-hits b { font-size: 1.25em; margin: 0 4px; }

#listPage .list-review p {
  padding: 6px;
  border: 1px dashed #a1a1a1;
  -webkit-border-radius: 0.5em;
     -moz-border-radius: 0.5em;
          border-radius: 0.5em;
}

#listPage #main .product-list { margin-bottom: 24px; }

.list-refine label { display: table; }

.list-sort { margin-bottom: 1em; }

.list-refine + .none-result {
  color: #777;
  margin: 3em 0 6em;
  display: inline-block;
}



/* .list-type-length */

.list-type-length {}

.list-type-length li {
  border-bottom: 1px solid #ccc;
  padding: 10px 0;
  margin: 0 -15px;
}

.list-type-length li a { padding: 0 15px; }

.list-type-length li .product-img { float: left; margin: 10px 25px 0 10px !important; }

.list-type-length li .r-column { overflow: hidden; }

.list-type-length .list-recommended,
.list-type-length .list-review { font-size: 13px; margin-top: 1em; }

.list-type-length .list-recommended b,
.list-type-length .list-review b { margin-bottom: 0.7em; display: inline-block; }

.list-refine label { margin: 0.6em 0; }



/* #productWatch */

#productWatch {
  padding: 15px 15px 0;
  margin-bottom: 1.88em;
  border-top: 1px solid #a1a1a1;
  box-sizing: border-box;
}

#productWatch .aside-header:after {
  border-top: 1px solid #a1a1a1;
  margin: 0 -15px;
  height: 8px;
  display: block; content: "";
}

#watchPage .collect-cart-clear { margin: 1.25em auto 0; display: table; }

.collect-cart-bottom { margin-top: 1.88em !important; }

.collect-cart { padding: 6px 0; margin: 10px 0 0 120px; }



/* .product-link */

.product-link {
  font-size: 0.94em;
  margin-bottom: 1.25em;
  overflow: hidden;
}

.product-link a {
  border: 1px solid #00a3d9;
  border-left: 12px solid #00a3d9;
  padding: 1em;
  -webkit-border-radius: 0.4em;
     -moz-border-radius: 0.4em;
          border-radius: 0.4em;
}

.product-link .product-img, .product-view .product-img { float: left; margin: 0 1em 0 0 !important; }
  .product-link .product-img + *, .product-view .product-img + * { overflow: hidden; }

.product-link a:hover { border-color: #c60; }



/* .product-view */

.product-view { margin-bottom: 1.15em; overflow: hidden; }

.product-view div { margin-bottom: 8px; }

.product-view .product-offer { font-size: 13px; }

.product-view a { color: #039; text-decoration: underline; display: inline-block; }
  .product-view a:hover { color: #c60; }



/* .productRelated */

.productRelated { margin-bottom: 1.88em; }

.product-list.swiper-wrapper .swiper-slide { padding-right: 10px; box-sizing: border-box; }

.swiper-container .swiper-button-prev, .swiper-button-next { display: none !important; }



/* #float-cart */

.sticky {
  width: 100%;
  z-index: 1000;
  position: -webkit-sticky;
  position: sticky;
    top: 0;
   left: 0;
}

#float-cart {
  display: none;
  background: #fff;
  position: absolute;
    top: 0;
   left: 0;
  width: 100%;
  padding: 8px 10px;
  overflow: hidden;
  box-sizing: border-box;
  border-bottom: 4px solid #00a3d9;
  z-index: 1000;
  -webkit-border-bottom-right-radius: 0.3em;
   -webkit-border-bottom-left-radius: 0.3em;
      -moz-border-radius-bottomright: 0.3em;
       -moz-border-radius-bottomleft: 0.3em;
          border-bottom-right-radius: 0.3em;
           border-bottom-left-radius: 0.3em;
    -webkit-box-shadow: 0 -1px 4px 2px #888;
       -moz-box-shadow: 0 -1px 4px 2px #888;
            box-shadow: 0 -1px 4px 2px #888;

}

.android #float-cart { position: fixed; }

#float-cart img {
  float: left;
  width: 50px;
  margin-right: 8px;
}

#float-cart dl { float: left; font-size: 13px; }

#float-cart dt { line-height: 1.3; margin-bottom: 4px; }

#float-cart button {
  float: right;
  width: 80px;
  margin-top: 8px;
  line-height: 34px;
  font-size: 15px;
}




