@charset "utf-8";





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

/* products label */

figure.sold-out:before { background: url(../img/common/label_sold_out_w84.png) no-repeat center; }
figure.photo.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_w84.png) no-repeat center; }
figure.photo.none-handling:before { background: url(../img/common/label_none_handling_w120.png) no-repeat center; }

figure.sold-out:before,
figure.none-handling:before {
  width:  84px;
  height: 46px;
  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 { width: 120px; height: 66px; }



/* .priceOff */

.priceOff {
  width:  36px;
  height: 36px;
  padding-top: 6px;
  font-size: 12px;
}





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

#productWrapper {}
  #productWrapper:after {
    padding-bottom: 2.25em;
    margin-bottom:  2.25em;
    border-bottom: 1px solid #a1a1a1;
    height: 1px;
    display:  block;
    content: "";
    clear: both;
  }

#productWrapper #productMain { float: right; width: 72%; }

#productMain { font-size: 0.9em; }



/* #productInfo */

#productWrapper #productInfo {
  float: left;
  width: 62%;
  min-width: 400px;
}

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

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

#productInfo .productRating {}

#productInfo #productCategory { margin-bottom: 20px; overflow: hidden; }

#productInfo #productCategory li { float: left; margin-right: 10px; }

#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 div.focus {
  border: 2px solid #e03311;
  background: #ffc !important;
  color: #e03311;
  font-weight: bold;
}



/* .firstCart */

#productWrapper #one_cart {
  float: right;
  width: 36%;
  min-width: 200px;
  padding: 1em;
  color: #1a1a1a;
  border: 1px solid #ccc;
  border-top: 6px solid #00a3d9;
  box-sizing: border-box;
  -webkit-border-radius: 0.4em;
     -moz-border-radius: 0.4em;
          border-radius: 0.4em;
}

#productWrapper #one_cart p.announce { font-size: 13px; margin-top: 16px; }

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

#productWrapper .first-cart h2 { margin-bottom: 16px; }

#productWrapper .first-cart p  { margin-bottom: 10px; }

#productWrapper .first-cart .total:after {
  background: url(../img/common/border-first-cart.gif) no-repeat center;
  height: 10px;
  margin: 10px -1em 6px;
  display: block;
  content: "";
}

#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 */

@media screen and (min-width: 1200px){
  #productWrapper .image-block .photo { width: 100%; }

  #productWrapper .image-block ul {
    position: absolute;
      top:     0;
     left: -70px;
  }

  #productWrapper .image-block li {
    width: 54px;
    border: 1px solid #ccc;
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 1199px){
  #productWrapper .image-block .photo { max-width: 240px; position: relative; }

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

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

#productWrapper .image-block { position: relative; display: inline-block; }

#productWrapper .image-block .photo img { width: 100%; max-width: 280px; }

#productWrapper .image-block li img { width: 100%; max-width: 54px; }

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

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



/* #pricsListTable */

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

#pricsListTable caption {
  color: #e03311;
  border-bottom: 2px solid #e03311;
  font-weight: bold;
  text-align: left;
  padding: 6px 10px;
  margin-bottom: 10px;
}
  #pricsListTable caption:before { content: "「さらにお安く」"; }

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

#pricsListTable td {
  border-bottom: 1px solid #ccc;
  padding: 10px 1em;
  display: table-cell;
  vertical-align: middle;
}

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

#pricsListTable td.order { width: 150px; }

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



/* #detailAgain */

#detailAgain #content { width: 780px; margin: 0 auto; }

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

#detailAgain #pricsListTable table { margin-bottom: 0; }





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

/* list common */

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

.listitem a div { margin-bottom: 8px; }
  .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: 100px;
  margin: 0 auto 16px;
  display: block;
  position: relative;
}

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

.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: 14px;
  position: relative;
}

.product-list li {
  display: inline-block;
  vertical-align: top;
  box-sizing: border-box;
}

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

.product-list .list-recommended,
.product-list .list-review { font-size: 0.94em; margin-top: 1em; }

.product-list .list-recommended b,
.product-list .list-review b { margin-bottom: 0.7em; display: inline-block; }
  .product-list li:hover .list-recommended b,
  .product-list li:hover .list-review b { color: #e03311; }

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

#listPage #main .product-list { border-bottom: 1px solid #ddd; margin-bottom: 40px; }

#listPage #main .product-list li { width: 24.4%; padding: 20px 12px; }

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

#listPage .list-lead { 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;
}

.list-refine label { float: left; margin-right: 1em; display: table; }

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

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



/* #watchPage */

#watchPage .product-list { border-bottom: 1px solid #ddd; margin-bottom: 0; }

#watchPage .product-list li { width: 19.4%; padding: 20px 12px; }

#watchPage .product-list li .collect-cart { margin-top: 10px; }

#watchPage .collect-cart-bottom { margin-top: 2.25em; }

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



/* #productWatch */

#productWatch {
  padding: 20px 30px;
  margin-bottom: 2.25em;
  border: 1px solid #a1a1a1;
  box-sizing: border-box;
  -webkit-border-radius: 0.4em;
     -moz-border-radius: 0.4em;
          border-radius: 0.4em;
}

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

#productWatch .product-list li { width: 19.4%; padding: 0 12px; }

#productWatch .collect-cart { padding: 15px 0; }

#productWatch .collect-cart-bottom {}

#productWatch .collect-cart-bottom:before {
  border-top: 1px solid #a1a1a1;
  margin: 0 -30px;
  height: 20px;
  display: block;
  content: "";
}



/* .product-link */

.product-link {
  font-size: 14px;
  margin-bottom: 2.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: 2.25em; 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: 2.55em; }

.product-list.swiper-wrapper {
  margin: 0 2.55em;
  position: relative;
    left: -0.88em;
}

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

.swiper-container .swiper-button-prev, .swiper-button-next {
  background: url(../img/common/arrow_swiper_button.gif) no-repeat !important;
  width:  24px !important;
  height: 24px !important;
  border: 1px solid #a1a1a1;
  -webkit-border-radius: 50%;
     -moz-border-radius: 50%;
          border-radius: 50%;

}

.swiper-container .swiper-button-prev { left: 0 !important; }

.swiper-container .swiper-button-next { right: 0 !important; background-position: 0 -24px !important; }



/* #float-cart */

#float-cart {
  display: none;
  background: #fff;
  width: 200px;
  padding: 16px;
  overflow: hidden;
  box-sizing: border-box;
  border-top: 6px solid #00a3d9;
  z-index: 1000;
  position: fixed;
    bottom: 4%;
     right: 0;
  -webkit-border-bottom-left-radius: 0.3em;
      -moz-border-radius-bottomleft: 0.3em;
          border-bottom-left-radius: 0.3em;
     -webkit-border-top-left-radius: 0.3em;
         -moz-border-radius-topleft: 0.3em;
             border-top-left-radius: 0.3em;
      -webkit-box-shadow: 0 0 3px 1px #888;
         -moz-box-shadow: 0 0 3px 1px #888;
              box-shadow: 0 0 3px 1px #888;
}

#float-cart img { width: 74px; margin: 0 auto 16px; }

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

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

#float-cart button {
  clear: both;
  margin-top: 10px;
  line-height: 30px;
  font-size: 14px;
}
  #float-cart button:after { content: "に入れる"; }




