@charset "utf-8";
/* CSS Document */

/******************** detail ********************/
#detail{
  box-sizing: border-box;
  margin: 20px 0;
}

#detail p{
  line-height: 3em;
  margin-top:20px;
}

#detail h3{
  background: #CCCCCC;
  border-radius: 5px;
  box-sizing: border-box;
  color: #000000;
  font-size: 125%;
  font-weight: bold;
  margin-bottom: 15px;
  padding: 16px 10px;
  width: 100%;
}

#detail h3 span{
  font-size: 14px;
  margin-left: 1em;  
}

@media screen and (max-width:640px){
  #detail h3{
    font-size: 16px;
    padding: 12px 10px;
  }
}

#detail .item_img{
  float: left;
  margin: 0 15px 20px 0;
  width: 300px;
  height: auto;
  overflow: hidden;
}

#detail .item_img a > img{
  width: 300px;
  height: auto;
}


#detail .item_name h2 a{
  color: #f55287;
  font-size: 125%;
  font-weight: bold;
  margin-bottom: 15px;
}

#detail .item_name p{
  line-height: 1.5em;
  margin: 15px 0;
}

#detail .item_point{
  clear: left;
  margin: 0 0 20px;
}

#detail .item_point p{
  background: #fb99b9;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  font-size: 125%;
  font-weight: bold;
  padding: 16px 10px;
  width: 100%;
}

#detail .item_point ul li{
  box-sizing: border-box;
  border-bottom: dotted 1px #CCCCCC;
  color: #553540;
  font-size: 125%;
  padding: 15px 15px 15px 65px;
  position:relative;
}

#detail .item_point ul li:before{
  content:"\00a0";
  display: block;
  border: solid 20px #CC0000;
  border-radius: 20px;
  -moz-border-radius: 20px;
  -webkit-border-radius: 20px;
  height: 0;
  width: 0;
  position: absolute;
  left: 15px;
  top: 40%;
  margin-top: -15px;
}

#detail .item_point ul li:after{
  content:"\00a0";
  display:block;
  width: 6px;
  height: 15px; 
  border: solid #fff;
  border-width: 0 5px 5px 0;
  position:absolute;
  left: 30px;
  top: 40%;
  margin-top: -7px;  
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}

#detail .item_img_detail{
  margin: 20px 0 0;
  overflow: hidden;
}

#detail .item_img_detail ul li{
   float: left;
   margin-right: 14px;
   width: 244px;
}

#detail .item_img_detail ul li:last-child{
  margin-right: 0;
}


@media screen and (min-width:641px) and (max-width: 800px){
  #detail{
    box-sizing: border-box;
    width: 100%;
    margin: 10px auto;
    padding: 0 10px;
  }

  #detail .item_img{
    margin-right: 10px;
    width: 30%;
    height: auto;
    box-sizing: border-box;
  }

  #detail .item_img > a img{
    width: 100%;
    height: auto;
  }

  #detail .item_name img{
    width: auto; /*400px;*/
    height: auto;
  }

  #detail .item_point ul li{
    margin-top: 5px;
  }

  #detail .item_point ul li:first-child{
    margin-top: 0;
  }

  #detail .item_img_detail ul li{
    margin-right: 2%;
    width: 32%;
  }

  #detail .item_img_detail ul li img{
    width: 100%;
  }

  #detail .item_name p{
    margin: 10px 0;
  }
}

@media screen and (max-width:640px){
  #detail{
    box-sizing: border-box;
    width: 100%;
    margin: 10px auto;
    padding: 0 10px;
  }

  #detail .item_img{
    margin-right: 10px;
    width: 40%;
    height: auto;
    box-sizing: border-box;
  }

  #detail .item_img > a img{
    width: 100%;
    height: auto;
  }

  #detail .item_name h2{
    font-size: 100%;
  }

  #detail .item_name img{
    width: auto;
    height: auto;
  }

  #detail .item_img_detail ul li{
    margin-right: 2%;
    max-width: 48%;
    width: 32%;
  }

  #detail .item_img_detail ul li img{
    width: 100%;
  }

  #detail .item_point p{
    font-size: 100%;
    padding: 12px 10px;
    margin-top: 10px;
  }
  #detail .item_name p{
    font-size: 14px;
    margin: 0;
  }

  #detail .item_point ul li{
    font-size: 113%;
    margin-top: 5px;
    padding: 10px 15px 10px 55px;
  }

  #detail .item_point ul li:first-child{
   margin-top: 0;
  }

  #detail .item_point ul li:before{
    border: solid 15px #CC0000;
    border-radius: 15px;
    -moz-border-radius: 15px;
    -webkit-border-radius: 15px;
    left: 15px;
    top: 40%;
    margin-top: -15px;
  }

  #detail .item_point ul li:after{
    width: 6px;
    height: 15px; 
    border-width: 0 4px 4px 0;
    left: 25px;
    top: 40%;
    margin-top: -12px;  
  }
}


#detail .item_condition{
  padding: 30px 0;
  width: 100%;
}

#detail .item_condition ul{
  background: #eee;
  border: solid 1px #ccc;
  box-sizing: border-box;
  color: #553540;
  display:-webkit-box;
	display:-moz-box;
	display:-webkit-flexbox;
	display:-moz-flexbox;
	display:-ms-flexbox;
	display:-webkit-flex;
	display:-moz-flex;
	display:flex;
  -webkit-box-lines:multiple;
  -moz-box-lines:multiple;
  -webkit-flex-wrap:wrap;
  -moz-flex-wrap:wrap;
  -ms-flex-wrap:wrap;
  flex-wrap:wrap;
  font-size: 88%;
  overflow: hidden;
  width: 100%;
}

#detail .item_condition li{
  border-right: solid 1px #ccc;
  box-sizing: border-box;
  line-height: 1.4;
  padding: 12px 5px;
}

#detail .item_condition li:nth-child(2n+1){
  font-weight: bold;
  width: 18%;
}

#detail .item_condition li:nth-child(even){
  background: #fff;
  width: 32%;
}

#detail .item_condition li:nth-child(n + 5) {
  border-top: solid 1px #ccc;
}

#detail .item_condition li:nth-child(4n){
  border-right: none;
}

@media screen and (min-width: 481px) and (max-width: 800px){
  #detail .item_condition li:nth-child(2n+1){
    width: 20%;
  }

  #detail .item_condition li:nth-child(even){
    width: 30%;
  }

  #detail .item_condition{
    padding: 20px 0;
  }
}

@media screen and (max-width: 480px){
  #detail .item_condition li:nth-child(2n+1){
    width: 20%;
  }

  #detail .item_condition li:nth-child(even){
    width: 30%;
  }

  #detail .item_condition ul{
    font-size: 12px;
  }

  #detail .item_condition{
    padding: 10px 0;
  }
}

/**/

#detail .other_shop{
  width: 100%;
}

#detail .other_shop p:not(.txt){
  background: #fb99b9;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  font-size: 125%;
  font-weight: bold;
  margin: 40px 0 20px;
  padding: 16px 10px;
  width: 100%;
}


#detail .other_shop ul{
  background: #fdd8e4;
  border: solid 2px #fb99b9;
  box-sizing: border-box;
  color: #553540;
  font-size: 86%;
  margin-top: 10px;
  overflow: hidden;
  width: 100%;
}

#detail .other_shop li{
  float: left;
  border-right: solid 2px #fb99b9;
  box-sizing: border-box;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  height:45px;
}

#detail .other_shop li:nth-child(2n+1){
  font-weight: bold;
  width: 20%;
}

#detail .other_shop li:nth-child(even){
  background: #fff;
  width: 30%;
}

#detail .other_shop li:nth-child(n + 5) {
  border-top: solid 2px #fb99b9;
}

#detail .other_shop li:last-child,
#detail .other_shop li:nth-child(4n){
  border-right: none;
}

@media screen and (min-width: 481px) and (max-width: 800px){
  #detail .other_shop li:nth-child(2n+1){
    font-size: 10px;
  }

  #detail .other_shop li:nth-child(even){
    font-size: 10px;
  }
}

@media screen and (max-width: 480px){
  #detail .other_shop p:not(.txt){
    font-size: 100%;
    line-height: 1.2em;
    padding: 12px 10px;
  }

  #detail .other_shop li:nth-child(2n+1){
    font-size: 10px;
  }

  #detail .other_shop li:nth-child(even){
    font-size: 10px;
  }

  #detail .other_shop ul{
    font-size: 88%;
  }
}


/**** 購入ボタン ****/

div.koushiki{
	margin-top:30px;
	margin-bottom:30px;
	text-align:center;
}

.cart_btn {
  border: solid 1px #ad86f4;
  background: #7518c3;
  background: -webkit-gradient(linear, left top, left bottom, from(#ad86f4), to(#7518c3));
  background: -moz-linear-gradient(top,  #ad86f4,  #7518c3);
  box-sizing: border-box;
  cursor: pointer;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  font-size: 200%;
  font-weight: bold;
  text-shadow: 0 1px 1px rgba(0,0,0,.3);
  -webkit-border-radius: 5px; 
  -moz-border-radius: 5px;
  border-radius: 5px;
  -webkit-box-shadow: 0 1px 2px rgba(0,0,0,.2);
  -moz-box-shadow: 0 1px 2px rgba(0,0,0,.2);
  box-shadow: 0 1px 2px rgba(0,0,0,.2);
  text-align: center;
  position: relative;
  margin: 0 auto 20px;
  padding: 1em 0;
  width: 90%;
  height: 57px;
}

.cart_btn a::after{
  content: "";
  background: url('/common/img/cart.png') no-repeat;
  background-size: contain;
  position: absolute;
  right: 0;
  top: 0.3em;
  width: 65px;
  height: 45px;
}

.cart_btn a{
  color: #fff;
  margin-left: -5%;
  padding: 3em 0;
  width: 100%;
}

@media screen and (min-width:641px) and (max-width:800px){
  .cart_btn {
    font-size: 163%;
    width: 100%;
  }
}

@media screen and (min-width:481px) and (max-width:640px){
  .cart_btn {
    font-size: 150%;
    width: 100%;
  }

  .cart_btn a::after{
    width: 60px;
    height: 40px;
  }
}

@media screen and (max-width:480px){
  .cart_btn {
    font-size: 125%;
    width: 100%;
  }

  .cart_btn a::after{
    width: 40px;
    height: 30px;
  }
}

/**** 定期購入ボタン ****/
.cart_btn_regular {
  border: solid 1px #d3f173;
  background: #9dcc1e;
  background: -webkit-gradient(linear, left top, left bottom, from(#d3f173), to(#9dcc1e));
  background: -moz-linear-gradient(top,  #d3f173,  #9dcc1e);
  box-sizing: border-box;
  cursor: pointer;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  font-size: 200%;
  font-weight: bold;
  text-shadow: 0 1px 1px rgba(0,0,0,.3);
  -webkit-border-radius: 5px; 
  -moz-border-radius: 5px;
  border-radius: 5px;
  -webkit-box-shadow: 0 1px 2px rgba(0,0,0,.2);
  -moz-box-shadow: 0 1px 2px rgba(0,0,0,.2);
  box-shadow: 0 1px 2px rgba(0,0,0,.2);
  position: relative;
  margin: 0 auto;
  padding: 1em 0;
  width: 90%;
  height: 80px;
}

.cart_btn_regular a::after{
  content: "";
  background: url('/common/img/cart_regular.png') no-repeat;
  background-size: contain;
  position: absolute;
  right: 0;
  top: 5px;
  width: 73px;
  height: 70px;
}

.cart_btn_regular a{
  color: #fff;
  padding: 3em 0;
  margin-left: -1em;
  text-align: center;
  width: 100%;
}

.cart_btn_regular + p{
  font-size: 100%;
  text-align: center;
  margin: 5px 0 25px !important;
}

@media screen and (min-width:641px) and (max-width:800px){
  .cart_btn_regular {
    font-size: 163%;
    width: 100%;
  }
}

@media screen and (min-width:481px) and (max-width:640px){
  .cart_btn_regular {
    font-size: 150%;
    width: 100%;
  }

  .cart_btn_regular a::after{
    width: 60px;
    height: 90px;
  }
}

@media screen and (max-width:480px){
  .cart_btn_regular {
    font-size: 125%;
    width: 100%;
  }

  .cart_btn_regular a::after{
    background: none;
  }
}




#detail .item_review p:not(.disclaimer){
  background: #fb99b9;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  font-size: 125%;
  font-weight: bold;
  margin-top: 40px;
  padding: 16px 10px;
  width: 100%;
}

#detail .item_review ul li{
  box-sizing: border-box;
  border-bottom: solid 1px #ffc6d9;
  padding: 15px;
  overflow: hidden;
  width: 100%;
}

#detail .item_review .review_img{
  float: left;
  margin-right: 15px;
  width: 150px;
  height: 150px;
}

#detail .item_review .review_info span:not(.score){
  color: #553540;
  display: block;
  font-size: 100%;
}

#detail .item_review .review_info span:nth-of-type(1){
  font-size: 113%;
  margin-bottom: 1em;
}

#detail .item_review .review_info span:nth-of-type(3){
  font-size: 88%;
  line-height: 1.4em;
  margin-top: 1em;
}

#detail .item_review p.disclaimer{
  font-size: 64%;
  margin: 1em 0 2em;
}

@media screen and (max-width: 640px){
  #detail .item_review .review_img{
    margin-right: 10px;
    width: 30%;
    height: auto;
  }

  #detail .item_review .review_img img{
    width: 100%;
    height: auto;
  }

  #detail .item_review p:not(.disclaimer){
    font-size: 100%;
    padding: 12px 10px;
  }

  #detail .item_review ul li{
    padding: 10px 0;
  }

  #detail .item_review .review_info span:nth-of-type(1){
    margin-bottom: 0.5em;
  }

  #detail .item_review .review_info span:nth-of-type(3){
    margin-top: 0.5em;
  }

}

#detail .other_item p:not(.trim){
  background: #fb99b9;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  font-size: 125%;
  font-weight: bold;
  margin-top: 40px;
  padding: 16px 10px;
  width: 100%;
}

#detail .other_item ul{
  margin: 15px 0 30px;
  overflow: hidden;
  width: 100%;
  height: auto;
}

#detail .other_item ul li{
  float: left;
  margin-right: calc(40px / 3);
  width: 170px;
}

#detail .other_item ul li a{
  color: #553540;
}

#detail .other_item ul li:last-child{
  margin-right: 0;
}

#detail .other_item .item_name{
  font-size: 100%;
  font-weight: bold;
  line-height: 1.2em;
  display: block;
  margin: 7px 0;
}

#detail .other_item .item_summary{
  font-size: 75%;
  line-height: 1.5em;
  overflow : hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

#detail .other_item .trim{
  width: 180px;
  height: 120px;
  overflow: hidden;
}
@media screen and (min-width:641px) and (max-width: 800px){
  #detail .other_item ul li{
    margin-right: 1%;
    width: 24%;
  }

  #detail .other_item .trim{
    width: 100%;
    height: 120px;
  }
}

@media screen and (max-width:640px){
  #detail .other_item p:not(.trim){
    font-size: 100%;
    line-height: 1.2em;
    padding: 12px 10px;
  }

  #detail .other_item ul li{
    margin-right: 2%;
    width: 48%;
  }

  #detail .other_item ul li:nth-of-type(2){
    margin-right: 0;
  }
 
  #detail .other_item .trim{
    width: 100%;
    height: 120px;
  }

  #detail .other_item .item_name{
    font-size: 88%;
    height: 2.5em;
    overflow : hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
}

.glitter {
  overflow: hidden;
}
.glitter:before {
  content: "";
  background-image: -webkit-linear-gradient(
    130deg,
    rgba(255,255,255,0) 20%, 
    rgba(255,255,255,0.5) 50%, /*透明度を調整して光沢を作ります*/
    rgba(255,255,255,0) 80%
  );
  background-image: linear-gradient(
    130deg,
    rgba(255,255,255,0) 20%,
    rgba(255,255,255,0.5) 50%,
    rgba(255,255,255,0) 80%
  );
  width: 200%;
  height: 200%;
  position: absolute; /*ボタンの左上方向にはみ出させて配置*/
  top: -100%; 
  left: -200%;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  animation: shiny 3s infinite linear;
  -webkit-animation: shiny 3s infinite linear;
  -moz-animation: shiny 3s infinite linear;
}

@keyframes shiny {
    0% {
        left: -50%;
    }
    20% {
        left: 120%;
    }
    100% {
        left: 120%;
    }
}
@-webkit-keyframes shiny {
    0% {
        left: -50%;
    }
    20% {
        left: 120%;
    }
    100% {
        left: 120%;
    }
}
@-moz-keyframes shiny {
    0% {
        left: -50%;
    }
    20% {
        left: 120%;
    }
    100% {
        left: 120%;
    }
}

/******* コンテンツ追加分 ******/
#detail .secret,
#detail .ingredients,
#detail .feature{
  margin: 0 0 30px;
}

@media screen and (max-width:640px){
  #detail .secret,
  #detail .ingredients,
  #detail .feature{
    margin: 0 0 20px;
  }
}

/* secret */
#detail .secret h3 span{
  font-size: 34px;
  position: relative;
  top: 3px;
  left: 3px;
}

#detail .secret p{
  margin: 15px 0 20px;
}

@media screen and (max-width:780px){
  #detail .secret p img{
    width: 100%;
    height: auto;
  }
}

@media screen and (max-width:640px){
  #detail .secret h3 span{
    font-size: 24px;
    top: 2px;
  }
}

/* practice */
@media screen and (max-width:780px){
  #detail .practice p img{
    width: 100%;
    height: auto;
  }
}

#detail .item_mounting img{
  width: 100%;
  height: auto;
}

/* ingredients */
#detail .ingredients dl{
  margin: 0 0 20px;
}

#detail .ingredients dt{
  font-size: 125%;
  font-weight: bold;
  margin-bottom: 7px;
}

#detail .ingredients dd{
  line-height: 1.4;
  margin-bottom: 15px;
}

#detail .ingredients dl.img_on dd{
  min-height: 167px;
  padding-left: 215px;
  position: relative;
}

#detail .ingredients dl.img_on dd img{
  height: auto;
  position: absolute;
  top: 0;
  left: 0;
  width: 200px;
}

@media screen and (max-width: 640px){
  #detail .ingredients dt{
    font-size: 16px;
  }
  
  #detail .ingredients dd{
    font-size: 14px;
  }
}

@media screen and (max-width: 480px){
  #detail .ingredients dl.img_on dd{
    min-height: 90px;
    padding-left: 100px;
  }

  #detail .ingredients dl.img_on dd img{
    width: 90px;
  }
}

/* feature */
#detail .feature h4{
  font-weight: bold;
  line-height: 1.2;
  margin-bottom: 10px;
}

#detail .feature p{
  line-height: 1.2;
  margin: 0 0 1em;
}

#detail .feature div.img_on{
  margin-bottom: 20px;
  overflow: hidden;
}

#detail .feature div.img_on p:nth-of-type(1){
  float: right;
  margin: 0 0 15px 15px;
}

@media screen and (max-width: 640px){
  #detail .feature p{
    font-size: 14px;
  }
  
  #detail .feature div.img_on p:nth-of-type(1){
    width: 40%;
  }

  #detail .feature div.img_on p:nth-of-type(1) img{
    height: auto;
    width: 100%;
  }
}


/*おすすめ5選*/
#recommendlist {
  display: block;
  font-size: 14px;
  margin: 0 0 20px;
  width: 100%;
}

#recommendlist h2 {
  background: #CC0000;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  font-size: 125%;
  font-weight: bold;
  margin: 40px 0 20px;
  padding: 16px 10px;
  width: 100%;
}

#recommendlist table {
  border-collapse: collapse;
  border: solid 1px #000;
  width: 100%;
}

#recommendlist thead th {
  border: solid 1px #000;
  padding: 10px;
  text-align: center;
  vertical-align: middle;
}

#recommendlist td {
  border: solid 1px #000;
  box-sizing: border-box;
  text-align: center;
  padding: 10px 7px;
  width: 18%;
}

#recommendlist tr:nth-of-type(1) {
  font-weight: bold;
}

#recommendlist table tr.evaluate {
  font-size:72px;
}

#recommendlist table tr.link a{
  background: #21b704;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: 12px;
  padding: 10px 0;
  text-decoration: none;
}

#recommendlist table tr.link a:hover{
  opacity: .7;
}

#recommendlist tbody th:nth-of-type(1) {
  border: solid 1px #000;
  box-sizing: border-box;
  font-size: 14px;
  font-weight: bold;
  text-align: left;
  padding: 10px 7px;
  vertical-align: top;
  width: 120px;
}

#recommendlist span.very_good {
  color: #ff0000;
}

#recommendlist span.good {
  color: #ffc000;
}

#recommendlist span.not_bad {
  color: #00b0f0;
}

@media screen and (max-width: 640px){
  #recommendlist {
    display: none;
  }
}

/***** sp用フッター固定ボタン *****/

.sp_fixbtn{
  position: fixed;
  bottom: 0px;
  left: 0px;
  background-color: rgba(0,0,0,0.5);
  box-sizing: border-box;
  text-align:center;
  padding:4px 5px;
  width:100%;
}

.sp_fixbtn img{
  border: solid 4px #3d3d3d;
  border-radius: 80px;
  box-sizing: border-box;
  width: 100%;
}

/***** youtube用 *****/
.ifr {
  position: relative;
  height: 0;
  padding: 30px 0 56.25%;
  margin: 0 0 20px;
  overflow: hidden;
}

.ifr iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/***** メンズデリーモボタン *****/
.mens_delemo{
  box-sizing: border-box;
  margin: 40px 0;
  padding: 0 10px;
  text-align: center;
  width: 100%;
}

.mens_delemo p img{
  width: 100%;
}

@media screen and (max-width: 800px){
  .mens_delemo img {
    width: 100% !important;
  }
}
