@charset "utf-8";

.fw_bold {
  font-weight: bold;
}

.fc_red {
  color: #df0202;
}
.fc_pink {
  color: #f78490;
}

.fs_16 {
  font-size: 16px;
}
.fs_18 {
  font-size: 18px;
}
.fs_20 {
  font-size: 20px;
}
.fs_24 {
  font-size: 24px;
}
.fs_26 {
  font-size: 26px;
}
.fs_30 {
  font-size: 30px;
}

.alignc {
  text-align: center;
}

.img_w100 {
  width: 100%;
}

.txtd_uline {
  border-bottom: 1px solid #adadad;
}

.txtd_uline:hover {
  text-decoration: none;
}
.txtd_uline_red {
  border-bottom: 2px solid #df0202;
}

.marT60 {
  margin-top: 60px;
}

.shadow_box {
  box-shadow: 0 0 5px 0 rgba(74, 27, 26, 0.11);
}

.shadow_btn {
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.3);
}

.no-indent {
  text-indent: 0;
}

@media screen and (min-width: 1024px) {
  .br_narrow {
    display: none;
  }
}

/* #contents {
  padding-top: 45px; } */

#contents {
  padding-top: 0;
}
#contents .breadcrumb {
  padding-top: 45px;
}

#regularly {
  padding-bottom: 80px;
  font-size: 16px;
}

#regularly .page-width.w1140 {
  max-width: 1180px;
}

@media screen and (min-width: 1320px) {
  #welcome .page-width.w1140 {
    max-width: 1140px;
  }
}

.bg_white {
  padding: 30px 40px 70px;
  background: #fff;
  border-radius: 5px;
  box-shadow: 0 0 3px 0 rgba(59, 41, 0, 0.11);
}

.page_title {
  position: relative;
  padding: 13px 0;
  margin-bottom: 30px;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
.page_title:before,
.page_title:after {
  position: absolute;
  left: 0;
  right: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  margin: auto;
  border-top: 1px solid #d2c5b8;
  border-bottom: 1px solid #fff;
}
.page_title:before {
  top: 0;
}
.page_title:after {
  bottom: 0;
}

.att {
  font-size: 14px;
  font-weight: normal !important;
  margin-top: 5px;
}

.fluid {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
}

@media screen and (min-width: 1024px) {
  .fluid_wide {
    display: -webkit-box; /*Android4.3*/
    display: -moz-box; /*Firefox21*/
    display: -ms-flexbox; /*IE10*/
    display: -webkit-flex;
    display: flex;
  }
}

/* __________ btn __________ */
.delayed_btn {
  width: 375px;
  height: 85px;
  position: relative;
  display: block;
  color: #fff !important;
  box-shadow: 0 3px 3px 0 rgba(12, 2, 5, 0.25);
  border-radius: 6px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  padding: 15px 30px 25px 30px;
}

.delayed_btn:before {
  position: absolute;
  top: 50%;
  right: 12px;
  display: block;
  content: "";
  width: 0;
  height: 0;
  margin-top: -5px;
  border-style: solid;
  border-width: 14px 9px 0px 9px;
  border-color: #fff transparent transparent transparent;
}

.delayed_btn.btn_brown {
  margin: 16px auto 0;

  background: #c2a882;
}
.delayed_btn.btn_brown.marT30 {
  margin: 30px auto 0;
}

/* ===============================================================
おトクな割引購入・サービスについて
=============================================================== */
.regularly_popular_area {
  box-shadow: 0 0 10px 0 rgba(74, 47, 26, 0.11);
}

.regularlye_about .fluid_txt {
  width: calc(100% - 250px);
}

.regularly_about h3 {
  margin-bottom: 5px;
  font-size: 30px;
  font-weight: bold;
}

.regularly_popular_desc {
  font-size: 22px;
  font-weight: bold;
}
.ribbon_header {
  background: #c7a77e;
  display: inline-block;
  padding: 6px 20px;
  color: #fff;
  font-weight: bold;
  transform: translate(50px, 30px) rotate(-3deg);
}

.regularly_about h4.stripe {
  height: 55px;
  color: #fff;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  line-height: 55px;
}
.regularly_about h4.stripe_pink {
  background: repeating-linear-gradient(
    90deg,
    #f78490,
    #f78490 32px,
    #f895a0 0,
    #f895a0 64px
  );
}
.regularly_about h4.stripe_pink:before,
.regularly_about h4.stripe_pink:after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 16px 5px 0 0;
  border-color: #fff transparent transparent transparent;
  vertical-align: middle;
}
.regularly_about h4.stripe_pink:before {
  margin-right: 5px;
  transform: rotate(-45deg);
}
.regularly_about h4.stripe_pink:after {
  margin-left: 5px;
  transform: rotate(35deg);
}
.regularly_about h4.stripe_yellow {
  margin-bottom: 0;
  background: repeating-linear-gradient(
    90deg,
    #ebad00,
    #ebad00 32px,
    #eeb924 0,
    #eeb924 64px
  );
}

@media screen and (max-width: 1023px) {
  .regularly_about h4.stripe_yellow {
    height: auto;
    padding: 15px 0;
    line-height: 1.4;
  }
}

.welcome_recommend {
  text-align: center;
  margin-top: 20px;
  padding: 30px 40px;
  display: flex;
  justify-content: space-around;
  background: #faf5e6;
}
.welcome_recommend li {
  position: relative;
  display: inline-block;
  font-size: 21px;
  font-weight: bold;
  padding-left: 40px;
  text-align: left;
}

.welcome_recommend li .icon_check {
  display: inline-block;
  width: 36px;
  height: 36px;
  background-image: url(/regularly/img/icon_check.png);
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  left: -10px;
  top: 50%;
  transform: translateY(-50%);
}

.welcome_teiki_wrap {
  display: flex;
  justify-content: space-between;
}

.welcome_teiki_wrap dl {
  flex: 0 0 auto;
  width: 33%;
}
.welcome_teiki_wrap dl dd img {
  width: 100%;
  max-width: 305px;
}
.welcome_teiki_wrap dt {
  background: #df0202;
  padding: 24px 20px;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 27px;
  margin: 10px auto 50px;
  border-radius: 10px;
  position: relative;
}
.welcome_teiki_wrap dt::after {
  content: "";
  display: block;
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: 20px 15px 0px 15px;
  border-color: #DF0202 transparent transparent transparent;
  position: absolute;
  right: 0px;
  left: 0px;
  bottom: -25px;
  margin: auto;
  transform: translateY(-50%);
}
.welcome_teiki_wrap dd {
  text-align: center;
}
.welcome_teiki_wrap dd .fluid_img {
  width: 23%;
  min-width: 62px;
}

.welcome_teiki_wrap .fluid {
  -webkit-align-items: center;
  align-items: center;
}

@media screen and (max-width: 1139px) {

  .welcome_teiki_wrap dl:first-of-type,
  .welcome_teiki_wrap dl:last-of-type {
    width: 33%;
    max-width: 522px;
  }

}

@media screen and (min-width: 1140px) {
  .welcome_teiki_wrap {
    display: -ms-flexbox; /*IE10*/
    display: -webkit-flex;
    display: flex;
    -ms-flex-pack: justify; /*IE*/
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .welcome_teiki_wrap dl {
    margin: 0;
  }
  .welcome_teiki_wrap dl + dl {
    margin-left: 10px;
  }
}

/*regularly*/
.desc_to_btn {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.07;
  text-align: center;
  margin-top: 50px;
}

/* ===============================================================
通常価格の10%OFF！しかも送料無料！
=============================================================== */
.discount_contents_desc img {
  width: 160px;
  height: 160px;
}

.discount h3 {
  padding: 12px 0;
  color: #fff;
  background: #e88a92;
  font-size: 22px;
  font-weight: bold;
}

.discount img {
  position: absolute;
  top: 20px;
}

.discount .imgbox {
  width: 180px;
  background: #fff;
}

.discount_contents_desc {
  position: relative;
}

.discount_contents_desc p {
  font-size: 20px;
  padding: 10px;
  margin-left: 180px;
  vertical-align: middle;
}

.bg_yellow {
  background: #faf5e7;
}

.ten_percent_discount {
  position: relative;
  font-weight: bold;
  margin-top: 20px;
  line-height: 40px;
}

.price_after_discount::before {
  content: "10%OFF";
  width: 114px;
  height: 36px;
  line-height: 36px;
  white-space: nowrap;
  color: #fff;
  background: #df0202;
  left: -140px;
  text-align: center;
  font-weight: bold;
  letter-spacing: 2px;
  padding: 0 0 0 4px;
}

.price_after_discount::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent transparent #df0202;
  border-width: 18px;
  left: -26px;
}

.price_after_discount::before,
.price_after_discount::after {
  display: block;
  font-size: 22px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}

.price_after_discount {
  position: absolute;
  color: #df0202;
  left: 400px;
  display: inline-block;
  font-size: 28px;
  font-weight: bold;
  line-height: 36px;
}

.price_after_discount + .product_price_tax {
  position: absolute;
  left: 490px;
}

.product_price_tax {
  color: #df0202;
  font-size: 16px;
}

.subscription_contents_box {
  padding: 30px 40px;
}

.subscription_contents_box p {
  margin-bottom: 1em;
}

.discount_contents_box {
  margin-bottom: 25px;
}

.new-line {
  display: none;
}

.discaount_pery {
  line-height: 40px;
  margin-top: 30px;
}

@media screen and (max-width: 930px) {
  .new-line,
  .price_after_discount {
    display: block;
  }
  .ten_percent_discount {
    margin-bottom: 10px;
    height: 115px;
  }
  .price_after_discount {
    left: 210px;
    margin-top: 20px;
    margin-bottom: 30px;
  }
  .discaount_pery {
    margin-top: 20px;
  }
}

/* ===============================================================
お届けを1ヵ月遅らせることができる、1ヵ月お休み制度
=============================================================== */
.delayed dt {
  margin-top: 30px;
  text-indent: -1em;
}

.delayed dl {
  margin-top: 20px;
}

#delayed a:hover.txtd_uline {
  border-color: #de0202;
}
/* ===============================================================
定期お届けコースを購入する
=============================================================== */
.subscriptions_product_left img {
  width: 160px;
  height: 160px;
}

.subscriptions_category_box {
  background: #fff;
  box-shadow: 0 0 3px 0 rgba(59, 41, 0, 0.11);
  border: 5px solid #fff;
  margin-bottom: 35px;
  padding: 25px 30px;
}

.subscriptions_category_desc {
  position: relative;
}

.subscriptions_category_desc img {
  position: absolute;
  top: 0;
  left: 0;
}

.subscriptions_category_desc_right {
  position: relative;
  height: 250px;
  padding: 10px 0 60px 320px;
}

.subscriptions_category_box ul {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: 10px;
}

.subscriptions_category_box li {
  width: 500px;
  font-weight: bold;
  margin-right: 2%;
  margin-bottom: 10px;
}

.subscriptions_category_box li:before {
  display: inline-block;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #df0202;
  vertical-align: middle;
}

.subscriptions_category_desc_btn {
  width: 370px;
  height: 50px;
  color: #fff;
  text-align: center;
  line-height: 50px;
  position: absolute;
  bottom: 70px;
  right: 0;
  cursor: pointer;
}

.subscriptions_category_desc_btn:after {
  position: absolute;
  top: 50%;
  right: 10px;
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: -4px;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #fff;
}

@media screen and (max-width: 1000px) {
  .subscriptions_category_desc_btn {
    bottom: 15px;
    width: 290px;
    height: 45px;
  }
  .subscriptions_category_desc_right {
    padding-top: 0;
  }
  .subscriptions_category_desc_right h3 {
    font-size: 26px;
  }
  .subscriptions_category_desc_right p {
    font-size: 16px;
  }
}

.ff_desc {
  background: #e0d5c6;
}

.ff_desc .subscriptions_category_desc_btn {
  background: #b99a6f;
}

.subscriptions_bg_white {
  padding: 15px;
  background: #fff;
}

.av_desc {
  background: #d3dff2;
}

.av_desc .subscriptions_category_desc_btn {
  background: #81a6e1;
}

.nc_desc {
  background: #f6dfbe;
}

.nc_desc .subscriptions_category_desc_btn {
  background: #e2ab5e;
}

/*-----------------------------------------------------*/
.subscriptions_items h3 {
  color: #fff;
  font-size: 24px;
  margin-top: 60px;
  margin-bottom: 30px;
  padding: 12px 30px;
  font-weight: bold;
}

.subscriptions_items .ff {
  background: #b99a6f;
}

.subscriptions_items .av {
  background: #81a6e1;
}

.subscriptions_items .nc {
  background: #e2ab5e;
}

.subscriptions_product_box {
  position: relative;
  padding-bottom: 25px;
  margin-bottom: 25px;
}

.subscriptions_category_desc_btn a:link,
.subscriptions_category_desc_btn a:visited {
  color: #fff;
}

.subscriptions_product_left {
  position: absolute;
  top: 30px;
  left: 30px;
}

.subscriptions_product_right {
  margin-left: 180px;
  margin-bottom: 20px;
}

.subscriptions_product_right h4 {
  text-indent: -0.5em;
}

.subscriptions_product_right h4 span {
  padding-left: 0.5em;
  white-space: nowrap;
}

.subscriptions_product_right kerning {
  letter-spacing: -2px;
}

.product_detail_btn {
  display: block;
  width: 160px;
  height: 40px;
  line-height: 40px;
  background: #ece1d0;
  border-radius: 5px;
  text-align: center;
  font-weight: bold;
  margin: 10px auto 30px;
  position: relative;
}

.product_detail_btn:after {
  position: absolute;
  top: 50%;
  right: 5px;
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: -4px;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #c9aa79;
}

.subscriptions_course {
  color: #fff;
  background: #e88a92;
  font-size: 18px;
  font-weight: bold;
  padding: 10px 15px;
  margin: 25px 0 15px;
}

.product_price,
.cartIn_quantity,
.free_shipping,
.cartIn_btn_image {
  display: inline-block;
}

.product_price_left {
  width: 270px;
}

.cartIn_quantity {
  margin-right: 35px;
}

.cartIn_quantity-select {
  position: relative;
  display: inline-block;
  vertical-align: bottom;
  padding-right: 5px;
  margin: 0 5px;
  width: 70px;
  height: 30px;
  border: 1px solid #ddd6ca;
  font-size: 18px;
  line-height: 30px;
  text-align: right;
}

.cartIn_quantity-select select {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  cursor: pointer;
}

.cartIn_quantity-select:after {
  content: "▼";
  font-size: 14px;
  color: #d0ba9d;
  margin-left: 10px;
}

.free_shipping {
  border: 2px solid #df0202;
  padding: 5px 3px;
  position: relative;
  width: 110px;
  text-align: center;
}

.subscriptions_course_price span {
  padding-left: 10px;
}
.subscriptions_course_price .product_price_tax {
  padding-left: 0;
}

.cartIn_btn_image {
  background: url(/regularly/img/cartin_btn.png) no-repeat;
  position: relative;
  left: 30px;
  top: 18px;
  width: 206px;
  height: 44px;
  cursor: pointer;
}

.soldout {
  background: url(/regularly/img/soldout.png) no-repeat;
  position: relative;
  left: 30px;
  top: 18px;
  width: 206px;
  height: 44px;
  cursor: default;
}

@media screen and (max-width: 880px) {
  .cartIn_quantity {
    display: block;
  }
  .subscriptions_course_price {
    margin-bottom: 10px;
  }
}
.new_line740,
.new_line750,
.new_line850,
.new_line890,
.new_line980,
.new_line1070,
.new_line1090,
.new_line1150,
.new_line1170 {
  display: none;
}

@media screen and (max-width: 1170px) {
  .new_line1170 {
    display: block;
  }
  .subscriptions_product_right h4 {
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 740px) {
  .new_line740 {
    display: block;
  }
}

@media screen and (max-width: 750px) {
  .new_line750 {
    display: block;
  }
}

@media screen and (max-width: 850px) {
  .new_line850 {
    display: block;
  }
}

@media screen and (max-width: 890px) {
  .new_line890 {
    display: block;
  }
}

@media screen and (max-width: 980px) {
  .new_line980 {
    display: block;
  }
}

@media screen and (max-width: 1070px) {
  .new_line1070 {
    display: block;
  }
}

@media screen and (max-width: 1090px) {
  .new_line1090 {
    display: block;
  }
}

@media screen and (max-width: 1150px) {
  .new_line1150 {
    display: block;
  }
}

@media screen and (max-width: 1320px) {
  .note_postage1 {
    margin-top: 50px;
  }
}

/*--------------------------------------------------------------------------------*/
.note_postage1 {
  font-size: 14px;
  font-weight: normal;
  margin-top: 30px;
}

.note_postage1 a:hover {
  border-color: #de0202;
}

.note_postage1 dt {
  color: #df0202;
  font-weight: bold;
}
.note_postage2 {
  background: #fffdf1;
  font-size: 18px;
  border: 2px solid #df0202;
  padding: 5px;
  text-align: center;
  margin-top: 35px;
}

.note_postage2 span {
  color: #df0202;
  font-size: 24px;
  margin-right: 30px;
}

.note_postage2 a:before {
  display: inline-block;
  content: "";
  width: 0;
  height: 0;
  margin-right: 5px;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #df0202;
  vertical-align: middle;
}
.dsp_hid {
  visibility: hidden;
}

@media screen and (max-width: 1330px) {
  .note_postage1 {
    margin-top: 20px;
  }
}

@media screen and (max-width: 1080px) {
  .note_postage2 a {
    display: block;
  }
}
@media screen and (max-width: 880px) {
  .note_postage2 span {
    display: block;
  }
}
