@charset "UTF-8";
/** ============================================================
 * CMS用追加
 * ========================================================== */
.bootstrap a{
  color: #272727;
}
.bootstrap a:hover,
.bootstrap a:focus{
  color: #bc2739;
  text-decoration: none;
}
.bootstrap a.oval-link{
  text-decoration: none;
}
.bootstrap a.oval-link--border--red{
  color: #bc2739;
}
.bootstrap a.oval-link--red{
  background: #bc2739;
}
.bootstrap .text-underline{
  text-decoration: underline!important;
  transition: all 0.25s;
}
.bootstrap .text-underline:hover,
.bootstrap .text-underline:focus {
  color: #bc2739;
  text-decoration: none!important;
}
.bootstrap img{
  vertical-align: bottom;
}
.bootstrap h1,
.bootstrap h2,
.bootstrap h3,
.bootstrap ul,
.bootstrap ol,
.bootstrap p{
  margin-bottom: 0;
}
.node__content{
  margin-top: 0;
}


/** ============================================================
 * 共通
 * ========================================================== */
/* ブロック */
.content-inner {
  max-width: 1200px;
}
.content-block{
  margin: 60px 0;
}

/* 見出し系 */
.content-heading{
  font-size: 32px!important;
  font-weight: 900!important;
  text-align: center;
}

/* ブロック上線 */
.content-block--top-border{
  position: relative;
  padding-top: 60px;
}
.content-block--top-border::before{
  content: "";
  display: inline-block;
  width: 100%;
  max-width: 1200px;
  height: 1px;
  background: #707070;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.content-block--top-border--sp{
  padding-top: 0;
}
.content-block--top-border--sp::before{
  display: none;
}

/* テキスト系 */
.intro-text{
  margin: 16px 0 0;
  line-height: 2em;
  text-align: center;
}
.indent-text{
  margin-left: 1rem;
  text-indent: -1rem;
}

/* ボタン */
.link-block{
  margin: 40px 0 0;
}
.bootstrap a.oval-link{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 500px;
  min-height: 70px;
  margin: 0 auto;
  font-size: 24px;
}
.link-block .oval-link + .oval-link{
  margin-top: 40px;
}
.oval-link--red::after,
.oval-link--border--red::after{
  width: 24px;
  height: 24px;
}
.oval-link--red::after{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_arrow-wt-r.webp) no-repeat center / contain;
}
.bootstrap a.oval-link--border--red{
  width: 380px;
  font-size: 20px;
}
.oval-link--border--red::after{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_arrow-rd-r.webp) no-repeat center / contain;
}


@media screen and (max-width: 768px) {
  /* 見出し系 */
  .content-heading{
    font-size: 24px!important;
  }

  /* ブロック上線 */
  .content-block--top-border::before{
    width: calc(100% - 48px);
  }
  .content-block--top-border--sp{
    padding-top: 60px;
  }
  .content-block--top-border--sp::before{
    display: inline-block;
  }

  /* テキスト系 */
  .intro-text{
    text-align: left;
  }

  /* ボタン */
  .bootstrap a.oval-link{
    width: 100%;
    min-height: 63px;
    font-size: 16px;
  }
  .link-block .oval-link + .oval-link{
    margin-top: 24px;
  }
  .oval-link--red::after,
  .oval-link--border--red::after{
    width: 14px;
    height: 14px;
  }
  .oval-link--border--red{
    width: 100%;
  }

}


/** ============================================================
 * MV
 * ========================================================== */
/* 赤背景 注意書き */
.top-caution{
  padding: 18px 20px;
  background: #BC2739;
  color: #fff;
  text-align: center;
}
.top-caution__text{
  font-size: 28px;
  font-weight: 600;
}
.top-caution__note{
  font-size: 14px;
}

/* MVエリア */
.content-block.mv{
  margin: 0;
}
.content-block.mv .content-inner{
  width: auto;
  max-width: unset;
}
.content-block.mv .content-inner img{
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  /* 赤背景 注意書き */
  .top-caution{
    padding: 16px 20px;
  }
  .top-caution__text{
    font-size: 20px;
  }

  /* MVエリア */
  .content-block.mv{
    margin: 0;
  }
  .content-block.mv .content-inner{
    padding: 0;
  }

}



/** ============================================================
 * 一部ドコモビジネスポイントが失効します
 * ========================================================== */
.content-block.expiration{
  margin: 0;
  padding: 60px 0;
  background: #F7F4EF;
  text-align: center;
}

/* 見出し */
.expiration-heading{
  position: relative;
  display: inline-block;
  padding: 0 90px;
}
.expiration-heading::before,
.expiration-heading::after{
  content: "";
  position: absolute;
  top: 4px;
  display: inline-block;
  width: 70px;
  height: 118px;
}
.expiration-heading::before{
  left: 0;
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/expiration_heading-l-pc.webp) no-repeat center / contain;
}
.expiration-heading::after{
  right: 0;
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/expiration_heading-r-pc.webp) no-repeat center / contain;
}

.expiration-heading__date{
  color: #BC2739;
  font-size: 27px;
  font-weight: 700;
}
.expiration-heading__date span{
  font-size: 46px;
}
.expiration-heading__text{
  font-size: 27px;
  font-weight: 700;
}

/* 赤枠ブロック */
.expiration-box{
  width: 920px;
  margin: 22px auto 0;
  padding: 30px;
  border: 3px solid #BC2739;
  border-radius: 12px;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .25);
  background: #fff;
}
.expiration-box__heading{
  position: relative;
  display: inline-block;
  padding-left: 34px;
  color: #BC2739;
  font-size: 20px!important;
  font-weight: 700!important;
}
.expiration-box__heading::before{
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: inline-block;
  width: 24px;
  height: 24px;
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_caution.webp) no-repeat center / contain;
}
.expiration-box__text{
  margin: 23px 0 0!important;
}
.expiration-box__text + .expiration-box__text{
  margin-top: 1.5em!important;
}
.point-text{
  font-weight: bold;
}
.point-text--red{
  background: rgba(203, 0, 50, .1);
  color: #BC2739;
}
.expiration-box__point{
  display: inline-block;
  margin: 20px 0 0!important;
  padding: 12px 20px;
  border: 1px solid #B8B8B8;
  border-radius: 10px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .content-block.expiration{
    padding: 40px 0;
  }

  /* 見出し */
  .expiration-heading{
    padding: 0 32px;
  }
  .expiration-heading::before,
  .expiration-heading::after{
    width: 36px;
    height: 117px;
  }
  .expiration-heading::before{
    left: -25px;
    background: url(/sites/default/files/media/office-products/lp-point-useup/image/expiration_heading-l-sp.webp) no-repeat center / contain;
  }
  .expiration-heading::after{
    right: -25px;
    background: url(/sites/default/files/media/office-products/lp-point-useup/image/expiration_heading-r-sp.webp) no-repeat center / contain;
  }

  .expiration-heading__date{
    font-size: 17px;
  }
  .expiration-heading__date span{
    font-size: 26px;
  }
  .expiration-heading__text{
    font-size: 24px;
  }

  /* 赤枠ブロック */
  .expiration-box{
    width: 100%;
    padding: 30px 22px;
  }
  .expiration-box__text{
    text-align: left;
  }
  .expiration-box__point{
    display: block;
  }
}


/** ============================================================
 * 商品一覧
 * ========================================================== */
.bestseller-heading{
  text-align: center;
}
.bestseller-heading .content-heading{
  margin-top: 2px;
}

/* 絞り込み用ボタン一覧 */
.filter-list{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  width: 920px;
  margin: 40px auto 0;
}
.filter-button{
  padding: 9px 41px;
  border: none;
  border-radius: 100vh!important;
  background: #F3F3F3;
  font-size: 16px!important;
  font-weight: 700!important;
  cursor: pointer;
}
.filter-button:hover{
  opacity: .7;
}
.filter-button.is-select{
  background: #272727;
  color: #fff;
  font-weight: 600;
	pointer-events: none;
}
.filter-icon span{
  position: relative;
  display: inline-block;
}
.filter-icon span::before{
  content: "";
  display: inline-block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.filter-icon--daily span{
  padding-left: 32px;
}
.filter-icon--daily span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_daily-off.webp) no-repeat center / contain;
  width: 24px;
  height: 24px;
}
.filter-icon--daily.is-select{
  background: #2D6A2D;
}
.filter-icon--daily.is-select span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_daily-on.webp) no-repeat center / contain;
}

.filter-icon--food span{
  padding-left: 35px;
}
.filter-icon--food span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_food-off.webp) no-repeat center / contain;
  width: 27px;
  height: 24px;
}
.filter-icon--food.is-select{
  background: #227093;
}
.filter-icon--food.is-select span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_food-on.webp) no-repeat center / contain;
}

.filter-icon--stationery span{
  padding-left: 32px;
}
.filter-icon--stationery span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_stationery-off.webp) no-repeat center / contain;
  width: 24px;
  height: 24px;
}
.filter-icon--stationery.is-select{
  background: #C25E00;
}
.filter-icon--stationery.is-select span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_stationery-on.webp) no-repeat center / contain;
}

.filter-icon--pc span{
  padding-left: 37px;
}
.filter-icon--pc span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_pc-off.webp) no-repeat center / contain;
  width: 29px;
  height: 24px;
}
.filter-icon--pc.is-select{
  background: #5D6D7E;
}
.filter-icon--pc.is-select span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_pc-on.webp) no-repeat center / contain;
}

.filter-icon--electronics span{
  padding-left: 32px;
}
.filter-icon--electronics span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_electronics-off.webp) no-repeat center / contain;
  width: 24px;
  height: 24px;
}
.filter-icon--electronics.is-select{
  background: #1A365D;
}
.filter-icon--electronics.is-select span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_electronics-on.webp) no-repeat center / contain;
}

.filter-icon--furniture span{
  padding-left: 34px;
}
.filter-icon--furniture span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_furniture-off.webp) no-repeat center / contain;
  width: 26px;
  height: 24px;
}
.filter-icon--furniture.is-select{
  background: #6D4C41;
}
.filter-icon--furniture.is-select span::before{
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_furniture-on.webp) no-repeat center / contain;
}


/* 一覧 */
.product-list{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 40px 0 0!important;
}
.product-list__item{
  position: relative;
  display: flex;
  flex-direction: column;
  width: calc((100% - 36px) / 4);
  padding: 30px 16px 44px;
  border-radius: 16px;
  background: #fff;
  box-shadow: 6px 6px 20px 0 rgba(39, 39, 39, .2);
}
.product-list__image{
  text-align: center;
}
.product-list__image img{
  width: 140px;
  object-fit: contain;
}
.product-list__detail{
  margin: 12px 0 0;
}

/* 左上タグ */
.product-list__tag{
  position: absolute;
  top: -5px;
  left: -5px;
  display: inline-block;
  padding: 4px 6px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
}
.product-list__tag::before{
  content: "";
  position: absolute;
  bottom: -6px;
  left: 0;
  display: inline-block;
  border-top: 6px solid #333;
  border-left: 5px solid transparent;
}
.product-list__tag--daily{
  background: #2D6A2D;
}
.product-list__tag--food{
  background: #227093;
}
.product-list__tag--stationery{
  background: #C25E00;
}
.product-list__tag--pc{
  background: #5D6D7E;
}
.product-list__tag--electronics{
  background: #1A365D;
}
.product-list__tag--furniture{
  background: #6D4C41;
}


/* 商品コード装飾 */
.bootstrap .product-code {
  display: flex;
  align-items: center;
}
.bootstrap .product-code__name,
.bootstrap .product-code__num{
  display: flex;
  align-items: center;
  min-height: 28px;
}

.bootstrap .product-code__name {
  color: #FFF;
  font-size: 12px;
  line-height: 1;
  padding: 2px 5px;
  background-color: #666;
  border: 2px solid #666;
  border-radius: 4px 0 0 4px;
}
.bootstrap .product-code__num {
  color: #666;
  font-size: 14px;
  line-height: 1;
  padding: 2px 5px;
  background-color: #FFF;
  border: 2px solid #666;
  border-radius: 0 4px 4px 0;
}


/* タイトル以降 */
.product-list__title{
  margin: 16px 0 0!important;
  font-size: 18px!important;
  font-weight: bold!important;
  line-height: 1.3!important;
}
.product-list__price{
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  margin: 16px 0 0;
}
.product-list__price-item .price{
  font-size: 20px;
  font-weight: bold;
}
.product-list__price-item .fee{
  margin-left: 4px;
  font-size: 12px;
}
.product-list__discount{
  padding: 2px 8px;
  background: #c03;
  color: #fff;
}
.product-list__price-item--before{
  position: relative;
}
.product-list__price-item--before::before{
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  display: inline-block;
  width: 100%;
  height: 2px;
  background: #000;
}
.product-list__price-item--after{
  position: relative;
  padding-left: 30px;
}
.product-list__price-item--after .price{
  color: #cc0033;
}
.product-list__price-item--after::before{
  content: "";
  position: absolute;
  top: 50%;
  left: 9px;
  transform: translateY(-50%);
  display: inline-block;
  width: 14px;
  height: 14px;
  background: url(/sites/default/files/media/office-products/lp-point-useup/image/icon_arrow-bk-r.webp) no-repeat center / 100%;
}

.card__label-wrap{
  margin-top: auto;
}
.ranking-label{
  display: inline-block;
  margin: 16px 0 0;
  padding: 2px 6px;
  background: rgba(203, 0, 50, .1);
  color: #BC2739;
  font-size: 12px;
  font-weight: 700;
}



@media screen and (max-width: 768px) {
  /* 絞り込み用ボタン一覧 */
  .filter-list{
    align-items: center;
    flex-direction: column;
    width: 100%;
    margin-top: 24px;
  }
  .filter-button{
    width: 100%;
  }


  /* 一覧 */
  .product-list{
    gap: 20px 10px;
    margin-top: 64px!important;
  }
  .product-list__item{
    width: calc(50% - 5px);
    padding: 30px 12px 24px;
  }
  .product-list__image img{
    width: 60px;
  }

  /* 左上タグ */
  .product-list__tag{
    padding: 5px 6px;
    font-size: 10px;
  }


  /* 商品コード装飾 */
  .bootstrap .product-code__name,
  .bootstrap .product-code__num{
    min-height: 21px;
    font-size: 9px;
  }


  /* タイトル以降 */
  .product-list__title{
    margin-top: 16px!important;
    font-size: 11px!important;
  }
  .product-list__price{
    margin-top: 16px;
  }
  .product-list__price-item .price{
    font-size: 14px;
  }
  .product-list__price-item .fee{
    font-size: 8px;
  }
  .product-list__discount{
    font-size: 11px;
  }
  .product-list__price-item--after{
    padding-left: 12px;
  }
  .product-list__price-item--after::before{
    top: calc((1em * 1.7 - 10px) / 2);
    left: 0;
    transform: unset;
    width: 10px;
    height: 10px;
  }

  .ranking-label{
    margin-top: 12px;
    font-size: 10px;
  }

  .bestseller .link-block{
    margin-top: 24px;
  }


}



/** ============================================================
 * 商品の検索方法
 * ========================================================== */
.content-block.search picture{
  display: block;
  padding: 20px;
  margin: 40px 0 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .content-block.search picture{
    margin-top: 20px;
  }
}


/** ============================================================
 * ドコモビジネスポイントでオフィス用品を購入する方法
 * ========================================================== */
.flow-block{
  padding: 60px;
  border-radius: 20px;
  background: #BC2739;
}
.flow-block .content-heading{
  color: #fff;
}
.flow-block .intro-text{
  margin: 12px 0 0;
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
.flow-block .intro-text a{
  color: #fff;
  text-decoration: underline;
}
.flow-block .intro-text a:hover{
  opacity: .7;
}
.flow-list{
  display: flex;
  gap: 22px;
  margin: 40px 0 0!important;
}
.flow-list__item{
  position: relative;
  width: calc((100% - 66px) / 4);
  padding: 24px 18px;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .25);
}
.flow-list__item + .flow-list__item::before{
  content: "";
  position: absolute;
  top: 50%;
  left: -15px;
  transform: translateY(-50%);
  display: inline-block;
  border-top: 15px solid transparent;
  border-bottom: 15px solid transparent;
  border-left: 10px solid #fff;
  opacity: .5;
}
.flow-list__step{
  color: #BC2739;
  font-size: 24px;
  font-weight: 900;
  text-align: center;
}
.flow-list__image{
  margin: 10px 0 0!important;
  text-align: center;
}
.flow-list__title{
  margin: 10px 0 0!important;
  font-size: 18px;
  font-weight: 900;
  text-align: center;
}
.flow-list__text{
  margin: 10px 0 0!important;
}
@media screen and (max-width: 768px) {
  .flow-block{
    padding: 30px 24px;
  }
  .flow-block .intro-text{
    font-size: 16px;
  }
  .flow-list{
    flex-direction: column;
    gap: 30px;
  }
  .flow-list__item{
    width: 100%;
    padding: 24px 22px 46px;
  }
  .flow-list__item + .flow-list__item::before{
    top: -19px;
    left: 50%;
    transform: translate(-50%, 0);
    border-top: 10px solid #fff;
    border-right: 15px solid transparent;
    border-left: 15px solid transparent;
    border-bottom: none;
  }
  .flow .link-block{
    margin-top: 60px;
  }
}