/* ************************************************
*  product_detail_page
* ************************************************ */

#zoomer {
    text-align: center;
}

/* お気に入り */
button.detail__favBtn {
    font-size: 16px;
    border-radius: 5px;
    color: #000 !important;
    font-weight: bold;
    text-align: center;
    background-color: #fff;
    border: 1px solid #000;
    padding: 0 15px;
    line-height: 56px;
    height: 56px;
    text-decoration: none;
    margin: -20px 0 30px;
    width: 100%;
  display: -ms-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

button.detail__favBtn.is-added {
  color: #000 !important;
  border: 1px solid #f2f2f2;
  background: #f2f2f2;
}

button.detail__favBtn:after {
  content:"お気に入りに追加する";
}
button.detail__favBtn.is-added:after {
  content:"お気に入りを解除する";
}
form[name="product_form"] {
    margin-bottom: 60px;
}
@media screen and (max-width:767px){
	form[name="product_form"] {
	    margin-bottom: 40px;
	}
}


@media screen and (max-width:991px){
  
  #productDetail{
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .product_images{
    max-width: 100%;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    margin-bottom: 40px;
  }
  .product_detail_area{
    max-width: 100%;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
  }
}
#itemName {
    font-size: 24px;
    font-weight: bold;
    line-height: 36px;
    margin-bottom: 20px;
}
@media (max-width: 767px) {
  #itemName {
    font-size: 16px;
  }
}

#option_area1 {
    margin-bottom:15px;
    }

#option_area1 h3,
#option_area2 h3{
    margin-bottom:5px;
    font-size:18px;
}
#option_area2 {
    padding:10px;
    }
.op1{
    margin-bottom:10px;
    }
.op2{
    margin-bottom:10px;
    }
.op2_ttl {
    font-weight:bold;
    color:#666666;
    margin-bottom:5px;
    }
.stock_comment {
    font-size:12px;
    color:#dd0000;
    }
#option_table {
    line-height:1;
    }
#option_table table{
    border-top:1px solid #999;
    border-right:1px solid#999;
    width:100%;
    }
#option_table table th {
    text-align:left;
    background:#eeeeee;
    border-left:1px solid #999;
    border-bottom:1px solid #999;
    font-size:14px;
    font-weight:normal;
    width:30%;
    padding:5px;
    }
#option_table table td {
    text-align:right;
    color:#dd0000;
    background:#ffffff;
    border-bottom:1px solid #999;
    font-size:14px;
    font-weight:bold;
    width:70%;
    padding:5px;
    line-height:1.2;
    }
div#box_together .zoom__title {
    margin-bottom: 30px;
}

.price{
  font-weight: bold;
}


h2.product_name {
  margin-bottom: 0.8em;
  font-size: 18px;
}
h3.zoom__title{
  font-size:14px;
  font-weight:bold;
  border-bottom:solid 1px #ddd;
}

.product_form{
  margin: 0 0 62px;
}

.product_detail_area {
  position: relative;
  width: 100%;
}


.product_images div img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height:auto;
  border: 1px solid #ddd;margin:auto;
}
.product_images div p.detail {
  margin-top: 10px;
  line-height: 20px;
}

.add_cart {
  clear: right;
  float: right;
  overflow: hidden;
  width: 42%;
}

table.add_cart_table {
  margin-bottom: 10px;
  width: 100%;
  /* border-left: solid 1px #ccc; */
  table-layout:fixed;

}
table.add_cart_table th {
  overflow: hidden;
  padding: 5px 0 ;
  width: 28%;
  text-align: left;
  font-size: 12px;
  vertical-align: middle;
}
table.add_cart_table td {
/*  overflow: hidden;*/
  padding: 5px 0;
  width: 55%;
  text-align: left;
  vertical-align: middle;
}

#productNumWrap{
  width: 30px;
}

/* オプション */
table.add_cart_table td input {
  padding: 5px 8px !important;
  border-radius: 5px;
  border: 1px solid #dfdfdf;
  font-size: 12px;
  line-height: 1 !important;
  height: auto !important;
  width: 30px;
}
.optionSelect{
  margin-bottom: 10px;
}
.optionSelect span{
  display: inline-block;
  margin-right: 5px;

}
.optionSelect select {
  padding: 5px 8px !important;
  border-radius: 5px;
  border: 1px solid #dfdfdf;
}

.productNum__changeWrap{

}

.productNum__changeWrap {
  width: 15px;
  margin-left: 5px;
}
.productNum__changeWrap a {
  display: block;
  margin: 5px 0;
}

table#option_tbl {
  margin-bottom: 20px;
  width: calc(100% - 1px);
}
table#option_tbl th,
table#option_tbl td.none {
  background: whiteSmoke;
}
table#option_tbl th,
table#option_tbl td {
  padding: 10px;
  border: 1px solid #ccc;
  text-align: center;
  vertical-align: middle;
}
table#option_tbl th {
  background: whiteSmoke;
}
table#option_tbl td div input {
  margin-bottom: 5px;
}

ul.option_price {
  margin: 0 0 20px 0;
}
ul.option_price li {
  list-style-type: none;
}

.option_box{
  clear: both;
  width: 100%;
  overflow: hidden;
  font-size:12px;
}
@media (max-width: 767px) {
  .option_box{
  font-size:10px;
}
}

table td.pur_block{
  margin: 0 5px 0 0;
  width: auto;
  white-space: normal;
}

.button_area input {
  width: 100%;
}

.product_description {
  clear: both;
  word-wrap: break-word;
  font-size: 14px;
  line-height: 24px;
}
@media screen and (max-width:767px){
  .product_description {
    font-size: 12px;
    line-height: 20px;
  }
}

.product_image_extra {
  margin-bottom: 20px;
  text-align: center;
}
.product_image_extra img.item {
  margin-bottom: 20px;
}

.product_link_area {
  margin: 20px 0 0;
  padding: 20px 0 0;
  border-top: #ccc solid 1px;
}
.product_link_area div.twitter {
  float: left;
 margin-right: 10px;
}
.product_link_area div.pinterest {
  float: left;
  margin-right: 30px;
}
.product_link_area div.fb-like {
  float: left;
  width: 100px;
}
.product_link_area ul.other_link {
  clear: both;
  padding-top:20px;
}
.product_link_area ul.other_link li {
  margin-bottom: 5px;
  list-style: none;
  vertical-align: middle;
  line-height: 24px;
}
.product_link_area ul.other_link li i{
  vertical-align: middle;
}

.share{
  margin: 15px 0 0;
  list-style: none;
}
.share li{
  display: inline-block;
  float: left;
  margin: 0 10px 10px 0;
  max-width: 125px;
}
.calamel-link{
  margin-top: 10px;
}

#tb_cap_tb{
  margin-top: 20px;
}

.tb {
  padding-top: 10px;
  padding-bottom: 10px;
  border-top: 1px solid #CCC;
}
#tb_stitle {
  margin-bottom: 20px;
}

.tb_date, .tb_title, .tb_body, .tb_state {
  margin-bottom: 5px;
}



.stockCell,.stockCell center{
  text-align: left;
  display: inline-block;
}

.product_detail_area .sold_out {
    text-align: center;
    background: #f2f2f2;
    font-size: 16px;
    border-radius: 5px;
    color: #1b1b1b !important;
    font-weight: bold;
    text-align: center;
    padding: 0 15px;
    line-height: 56px;
    height: 56px;
    text-decoration: none;
    margin: 0px 0 15px;
}
br.clear {
    clear: both;
}

.ranking,
#box_together,
#box_recommend{
  margin-bottom:40px;
}

#detail__productImage .detailSlider{
  opacity: 0;
}

.detailSlider img {
    width: auto;
}

/*
  詳細itemTag
*/
.itemTag_area {
  margin-bottom: 20px;
}
.itemTag {
  display: inline-block;
  border: 1px solid;
  border-radius: 10px;
  padding: 3px 20px;
  font-size: 12px;
  margin: 0 2px;
}

#itemName,
.price {
  font-weight: 500;
}
#itemName {
  margin-bottom: 10px;
}
.price {
}
.itemPriceArea {
  padding-bottom: 30px;
}
.itemPriceArea .price{
  font-weight: bold;
  font-size: 24px;
}
@media (max-width: 767px) {
  .itemPriceArea .price{
    font-size: 20px;
  }
}
.quantity,
.quantity > dd > span {
  display: flex;
}
.quantity {
  align-items:center;
}
.quantityTitle {
  padding-right:14px;
  display: inline-block;
}
a.quantity-down,
a.quantity-up {
  border: 1px solid;
  display: inline-block;
  padding: 6px 10px;
  border: 1px solid #ccc;
  background: #efefef;
  color: #000;
  line-height: 1.6;
}
.quantity input {
  display: inline-block;
  border: 1px solid #ccc;
  border-right: 0px;
  border-left: 0px;
  width: 80px;
  text-align: center;
  line-height: 1.6;
}

.cell_2 > div,
.cell_2 > label {
  display: inline-block !important;
  cursor: pointer;
}
table#option_tbl th {
  font-weight: 500;
}
.cell_2 > div {
  margin-right: 2px;
}
.itemCartTitle {
  font-size: 16px;
  font-weight: 400;
  margin: 20px 0;
}

button.detail__cartBtn {
    cursor: pointer;
    transition: 0.2s;
    border-radius: 0;
    background-color: #1b1b1b;
    color: #f2f2f2 !important;
}

button#basketBtn.detail__cartBtn {
    border-color: #1b1b1b;
    background-color: #1b1b1b;
    color: #f2f2f2 !important;
}

button.detail__cartBtn:hover,
a.detail__contactBtn:hover {
  opacity: 0.8;
  transition: 0.2s;
}


.product_link_area {
  border-top: none;
  margin: 0;
  padding: 0;
}

.product_link_area ul.other_link li {
  line-height: 14px;
}
.product_link_area ul.other_link li > a {
  font-size: 14px;
}
.product_link_area ul.other_link li > a > i{
  font-size: 18px;
}

table.add_cart_table tr{
  border-bottom: 1px solid #ccc;
}
table.add_cart_table th {
  width: 15%;
  font-weight: normal;
  font-size: 14px;
  padding: 15px 0;
  line-height: 2;
}
table.add_cart_table td {
  width: 75%;
  font-size: 14px;
  padding: 15px 0;
  line-height: 2;
}

#productDetail button, #productDetail a {
    font-weight: 400;
}


/*画像の横幅を100%にしてレスポンシブ化*/
li.slick-slide img{
  width:100%;
	height: auto;
	vertical-align: bottom;/*画像の下にできる余白を削除*/
}

/*メイン画像下に余白をつける*/

.gallery{
	margin:0 0 5px 0;
}

.gallery li{
list-style:none;
}



/*矢印の設定*/

/*戻る、次へ矢印の位置*/
.slick-prev, 
.slick-next {
    position: absolute;/*絶対配置にする*/
	z-index: 3;
    top: 42%;
    cursor: pointer;/*マウスカーソルを指マークに*/
    outline: none;/*クリックをしたら出てくる枠線を消す*/
    border-top: 2px solid #ccc;/*矢印の色*/
    border-right: 2px solid #ccc;/*矢印の色*/
    height: 25px;
    width: 25px;
}

.slick-prev {/*戻る矢印の位置と形状*/
    left:2.5%;
    transform: rotate(-135deg);
}

.slick-next {/*次へ矢印の位置と形状*/
    right:2.5%;
    transform: rotate(45deg);
}

/*選択するサムネイル画像の設定*/

.choice-btn div.slick-track {
    width: 100% !important;
}

.choice-btn li{
	cursor: pointer;
	outline: none;
	background:#333;
	width: calc(100% / 3) !important;
	list-style:none;
}

.choice-btn li img{
	opacity: 0.4;/*選択されていないものは透過40%*/
}

.choice-btn li.slick-current img{
	opacity: 1;/*選択されているものは透過しない*/
}
@media screen and (min-width:992px){
.productDetail_box{
  display: -ms-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;

}

.product_images{
  max-width: 50%;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
          flex: 0 0 50%;
}
.product_detail_area{
  max-width: calc(50% - 40px);
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(50% - 40px);
          flex: 0 0 calc(50% - 40px);
  margin: 30px 0 0;
}
  
 section.product_description {
  margin: 60px auto;
  max-width: 700px;
}
  
 div#productDetail {
   margin: 0 auto;
   width:965px;
}
  
}

button#basketBtn span {
  font-size: 18px;
}
  .itemPriceArea .price {
  font-family: "游明朝",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro","ＭＳ 明朝",serif;
}