@charset "UTF-8";

#app {
  font-size: 14px;
  overflow: hidden;
}
@media only screen and (max-width: 599px) {
  #app {
    font-size: 11px;
    line-height: 1.6;
  }
}
#app * {
  font-family: "Lato", "Noto Sans JP", sans-serif;
}
#app ._pb0 {
  padding-bottom: 0 !important;
}
#app h2,
#app h3 {
  line-height: 1.6;
}
#app ._serif,
#app #article .article-title span,
#article .article-title #app span,
#app #article .article-title,
#article #app .article-title,
#app #point .point-title span,
#point .point-title #app span,
#app #point .point-title,
#point #app .point-title,
#app #features .features-items-item-text p,
#features .features-items-item-text #app p,
#app #features .features-items-item-text h3 span,
#features .features-items-item-text h3 #app span,
#app #features .features-items-item-text h3,
#features .features-items-item-text #app h3,
#app #features .features-title span,
#features .features-title #app span,
#app #features .features-title,
#features #app .features-title,
#app #reasons .reasons-title span,
#reasons .reasons-title #app span,
#app #reasons .reasons-title,
#reasons #app .reasons-title,
#app #recommend .recommend-title,
#recommend #app .recommend-title,
#app #fv .fv-text p,
#fv .fv-text #app p,
#app #fv .fv-text h2,
#fv .fv-text #app h2,
#app .section-title span,
#faq .faq-title span,
#app #faq .faq-title span,
#faq #app .faq-title span,
#app #service .service-title span,
#service #app .service-title span,
#app #check .check-title span,
#check #app .check-title span,
#app #brand .brand-title span,
#brand #app .brand-title span,
#app #category .category-title span,
#category #app .category-title span,
#app #setGift .setGift-title span,
#setGift #app .setGift-title span,
#app #standardProduct .standardProduct-title span,
#standardProduct #app .standardProduct-title span,
#app #best3 .best3-title span,
#best3 #app .best3-title span,
#app #ranking .ranking-title span,
#ranking #app .ranking-title span,
#app #priceRecommend .priceRecommend-title span,
#priceRecommend #app .priceRecommend-title span,
#app #chooseFromAmount .chooseFromAmount-title span,
#chooseFromAmount #app .chooseFromAmount-title span,
#app #chooseFromBudget .chooseFromBudget-title span,
#chooseFromBudget #app .chooseFromBudget-title span,
#app #kekkon-search .search-title span,
#kekkon-search #app .search-title span,
#app #pickup .pickup-title span,
#pickup #app .pickup-title span,
#app #recommend .pickup-title span,
#recommend #app .pickup-title span,
#app .section-title,
#faq .faq-title,
#app #faq .faq-title,
#faq #app .faq-title,
#app #service .service-title,
#service #app .service-title,
#app #check .check-title,
#check #app .check-title,
#app #brand .brand-title,
#brand #app .brand-title,
#app #category .category-title,
#category #app .category-title,
#app #setGift .setGift-title,
#setGift #app .setGift-title,
#app #standardProduct .standardProduct-title,
#standardProduct #app .standardProduct-title,
#app #best3 .best3-title,
#best3 #app .best3-title,
#app #ranking .ranking-title,
#ranking #app .ranking-title,
#app #priceRecommend .priceRecommend-title,
#priceRecommend #app .priceRecommend-title,
#app #chooseFromAmount .chooseFromAmount-title,
#chooseFromAmount #app .chooseFromAmount-title,
#app #chooseFromBudget .chooseFromBudget-title,
#chooseFromBudget #app .chooseFromBudget-title,
#app #kekkon-search .search-title,
#kekkon-search #app .search-title,
#app #pickup .pickup-title,
#pickup #app .pickup-title,
#app #recommend .pickup-title,
#recommend #app .pickup-title {
  font-family: "Noto Serif JP", serif;
}
#app ._lato {
  font-family: "Lato", serif;
}
#app .section-title,
#faq .faq-title,
#app #faq .faq-title,
#faq #app .faq-title,
#app #service .service-title,
#service #app .service-title,
#app #check .check-title,
#check #app .check-title,
#app #brand .brand-title,
#brand #app .brand-title,
#app #category .category-title,
#category #app .category-title,
#app #setGift .setGift-title,
#setGift #app .setGift-title,
#app #standardProduct .standardProduct-title,
#standardProduct #app .standardProduct-title,
#app #best3 .best3-title,
#best3 #app .best3-title,
#app #ranking .ranking-title,
#ranking #app .ranking-title,
#app #priceRecommend .priceRecommend-title,
#priceRecommend #app .priceRecommend-title,
#app #chooseFromAmount .chooseFromAmount-title,
#chooseFromAmount #app .chooseFromAmount-title,
#app #chooseFromBudget .chooseFromBudget-title,
#chooseFromBudget #app .chooseFromBudget-title,
#app #kekkon-search .search-title,
#kekkon-search #app .search-title,
#app #pickup .pickup-title,
#pickup #app .pickup-title,
#app #recommend .pickup-title,
#recommend #app .pickup-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 25px;
}
@media only screen and (max-width: 599px) {
  #app .section-title,
  #faq .faq-title,
  #app #faq .faq-title,
  #faq #app .faq-title,
  #app #service .service-title,
  #service #app .service-title,
  #app #check .check-title,
  #check #app .check-title,
  #app #brand .brand-title,
  #brand #app .brand-title,
  #app #category .category-title,
  #category #app .category-title,
  #app #setGift .setGift-title,
  #setGift #app .setGift-title,
  #app #standardProduct .standardProduct-title,
  #standardProduct #app .standardProduct-title,
  #app #best3 .best3-title,
  #best3 #app .best3-title,
  #app #ranking .ranking-title,
  #ranking #app .ranking-title,
  #app #priceRecommend .priceRecommend-title,
  #priceRecommend #app .priceRecommend-title,
  #app #chooseFromAmount .chooseFromAmount-title,
  #chooseFromAmount #app .chooseFromAmount-title,
  #app #chooseFromBudget .chooseFromBudget-title,
  #chooseFromBudget #app .chooseFromBudget-title,
  #app #kekkon-search .search-title,
  #kekkon-search #app .search-title,
  #app #pickup .pickup-title,
  #pickup #app .pickup-title,
  #app #recommend .pickup-title,
  #recommend #app .pickup-title {
    font-size: 20px;
  }
}
#app .section-title span,
#faq .faq-title span,
#app #faq .faq-title span,
#faq #app .faq-title span,
#app #service .service-title span,
#service #app .service-title span,
#app #check .check-title span,
#check #app .check-title span,
#app #brand .brand-title span,
#brand #app .brand-title span,
#app #category .category-title span,
#category #app .category-title span,
#app #setGift .setGift-title span,
#setGift #app .setGift-title span,
#app #standardProduct .standardProduct-title span,
#standardProduct #app .standardProduct-title span,
#app #best3 .best3-title span,
#best3 #app .best3-title span,
#app #ranking .ranking-title span,
#ranking #app .ranking-title span,
#app #priceRecommend .priceRecommend-title span,
#priceRecommend #app .priceRecommend-title span,
#app #chooseFromAmount .chooseFromAmount-title span,
#chooseFromAmount #app .chooseFromAmount-title span,
#app #chooseFromBudget .chooseFromBudget-title span,
#chooseFromBudget #app .chooseFromBudget-title span,
#app #kekkon-search .search-title span,
#kekkon-search #app .search-title span,
#app #pickup .pickup-title span,
#pickup #app .pickup-title span,
#app #recommend .pickup-title span,
#recommend #app .pickup-title span {
  font-size: 15px;
  color: #ac9363;
  letter-spacing: 2.25px;
}
@media only screen and (max-width: 599px) {
  #app .section-title span,
  #faq .faq-title span,
  #app #faq .faq-title span,
  #faq #app .faq-title span,
  #app #service .service-title span,
  #service #app .service-title span,
  #app #check .check-title span,
  #check #app .check-title span,
  #app #brand .brand-title span,
  #brand #app .brand-title span,
  #app #category .category-title span,
  #category #app .category-title span,
  #app #setGift .setGift-title span,
  #setGift #app .setGift-title span,
  #app #standardProduct .standardProduct-title span,
  #standardProduct #app .standardProduct-title span,
  #app #best3 .best3-title span,
  #best3 #app .best3-title span,
  #app #ranking .ranking-title span,
  #ranking #app .ranking-title span,
  #app #priceRecommend .priceRecommend-title span,
  #priceRecommend #app .priceRecommend-title span,
  #app #chooseFromAmount .chooseFromAmount-title span,
  #chooseFromAmount #app .chooseFromAmount-title span,
  #app #chooseFromBudget .chooseFromBudget-title span,
  #chooseFromBudget #app .chooseFromBudget-title span,
  #app #kekkon-search .search-title span,
  #kekkon-search #app .search-title span,
  #app #pickup .pickup-title span,
  #pickup #app .pickup-title span,
  #app #recommend .pickup-title span,
  #recommend #app .pickup-title span {
    font-size: 13px;
  }
}
#app .lead {
  font-size: 17px;
  font-weight: 400;
  margin: 41px auto 31px;
}
@media only screen and (max-width: 599px) {
  #app .lead {
    font-size: 14px;
    text-align: center;
    padding: 0 15px;
    margin: 20px auto;
  }
}
#app .linkBtn,
#app .productLink,
#app .otherGiftLink,
#app .otherGiftLink--white,
#app .otherGiftLink--primary,
#app .catalogLink {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  font-size: 14px;
  border-radius: 70px;
}
@media only screen and (max-width: 599px) {
  #app .linkBtn,
  #app .productLink,
  #app .otherGiftLink,
  #app .otherGiftLink--white,
  #app .otherGiftLink--primary,
  #app .catalogLink {
    font-size: 12px;
  }
}
#app .catalogLink {
  border: 1px solid #95c5cb;
  color: #95c5cb;
  background: #fff;
}
#app .catalogLink::before {
  content: "";
  width: 20px;
  height: 17px;
  background: url("../images/common/Icon-detail.svg") no-repeat;
  background-size: 100%;
  margin-right: 6px;
}
#app .otherGiftLink,
#app .otherGiftLink--white,
#app .otherGiftLink--primary {
  position: relative;
  width: 235px;
  background: #ac9363;
  color: #fff;
  margin: 40px auto 0;
}
@media only screen and (max-width: 599px) {
  #app .otherGiftLink,
  #app .otherGiftLink--white,
  #app .otherGiftLink--primary {
    margin-top: 23px;
  }
}
#app .otherGiftLink::before,
#app .otherGiftLink--white::before,
#app .otherGiftLink--primary::before {
  content: "";
  background: url("../images/common/arrow-down-white.svg") no-repeat;
  background-position: center;
  background-size: 10px 6px;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%) rotate(-90deg);
  width: 10px;
  height: 6px;
  pointer-events: none;
}
#app .otherGiftLink--primary {
  background: #de7388;
}
#app .otherGiftLink--white {
  background: #fff;
  color: #333;
  border: 1px solid #323332;
}
#app .otherGiftLink--white::before {
  filter: brightness(0) saturate(100%) invert(19%) sepia(6%) saturate(28%)
    hue-rotate(12deg) brightness(94%) contrast(94%);
}
#app .productLink {
  background: #de7388;
  border: 1px solid #de7388;
  color: #fff;
}
#app .productLink::before {
  content: "";
  width: 24px;
  height: 21px;
  background: url("../images/common/Icon-shopping.svg") no-repeat;
  background-size: 100%;
  margin-right: 10px;
  margin-left: -6px;
}
#app .productItem {
  display: flex;
  flex-direction: column;
}
#app .productItem:nth-child(n + 2) {
  margin-left: 14px;
}
@media only screen and (max-width: 599px) {
  #app .productItem:nth-child(n + 2) {
    margin-left: 0;
  }
}
#app .productItem-wrap {
  display: flex;
  flex-direction: column;
  color: inherit;
}
#app .productItem-image {
  width: 100%;
  min-width: 175px;
  min-height: 175px;
  border-radius: 6px;
}
@media only screen and (max-width: 599px) {
  #app .productItem-image {
    min-width: 110px;
    min-height: 110px;
  }
}
#app .productItem-tag {
  text-align: left;
}
#app .productItem-tag-item {
  display: inline-block;
  font-size: 12px;
  color: #999999;
}
@media only screen and (max-width: 599px) {
  #app .productItem-tag-item {
    font-size: 11px;
  }

  #app .productItem-tag {
    min-height: 36px;
    margin-top: 5px;
  }
}
#app .productItem-price {
  font-size: 16px;
  font-weight: 700;
  color: #333;
  text-align: left;
  margin-bottom: 5px;
}
@media only screen and (max-width: 599px) {
  #app .productItem-price {
    font-size: 14px;
  }
}
#app .productItem-price span {
  font-size: 13px;
}
@media only screen and (max-width: 599px) {
  #app .productItem-price span {
    font-size: 11px;
  }
}
#app .productItem-name {
  text-align: left;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
@media only screen and (max-width: 599px) {
  #app .productItem-name {
    /* min-height: 2.5rem; */
  }
}
#app .productItem-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 30px;
  border-radius: 4px;
  font-size: 14px;
  margin-top: 8px;
  color: #333;
  text-decoration: underline;
}
@media only screen and (max-width: 599px) {
  #app .productItem-btn {
    font-size: 10px;
  }
}

#app .productItem-btn2.otherGiftLink--primary {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 30px;
  border-radius: 4px;
  color: #fff;
  font-size: 14px;
  margin-top: 8px;
}
@media only screen and (max-width: 599px) {
  #app .productItem-btn2.otherGiftLink--primary {
    font-size: 10px;
    height: 25px;
  }
  #app .productItem-btn2.otherGiftLink--primary::before {
    right: 3px;
  }
}

#fv {
  width: 100%;
  height: 450px;
  background: url("../images/fv/fv_pc_a.jpg") no-repeat #f8f8f6;
  background-size: 100%;
  background-position: center;
}
@media only screen and (max-width: 599px) {
  #fv {
    height: auto;
    background: url("../images/fv/fv_sp_a.jpg") no-repeat #f8f8f6;
    background-size: 100%;
    aspect-ratio: 375/286;
  }
}
#fv .fv-inner {
  display: flex;
  max-width: 1120px;
  width: 100%;
  height: 100%;
  margin: auto;
}
@media only screen and (max-width: 599px) {
  #fv .fv-inner {
    position: relative;
  }
}
#fv .fv-text {
  width: 630px;
  margin: auto;
}
@media only screen and (max-width: 599px) {
  #fv .fv-text {
    width: 100%;
    margin: auto 0 0;
    padding: 10px 0;
    background: rgba(255, 255, 255, 0.8);
    position: absolute;
    bottom: 0;
  }
}
#fv .fv-text h1 {
  color: #000;
  font-size: 44px;
  margin-bottom: 10px;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 599px) {
  #fv .fv-text h1 {
    letter-spacing: 4px;
    font-size: 25px;
    margin-bottom: 5px;
  }
}
#fv .fv-text p {
  color: #000;
  font-size: 24px;
  font-weight: 300;
  margin-bottom: 39px;
}
@media only screen and (max-width: 599px) {
  #fv .fv-text p {
    font-size: 14px;
    margin-bottom: 0;
  }
}
#fv .fv-text img {
  width: 85%;
  height: auto;
  margin: 0 auto;
}
@media only screen and (max-width: 599px) {
  #fv .fv-text img {
    width: 85%;
    margin: 5px auto;
  }
}
#fv .fv-text span {
  display: block;
  margin-top: 10px;
  font-size: 11px;
  color: #555555;
}
#fv .fv-text span a {
  color: #555555;
  text-decoration: underline;
}
@media only screen and (max-width: 599px) {
  #fv .fv-text span {
    width: 85%;
    display: inline-block;
    font-size: 10px;
    color: #555;
    text-align: left;
    margin: 0 auto;
  }
}

#pageNav {
  background: #87c7cc;
}
#pageNav .pageNav-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 1120px;
  border-right: 3px solid #fff;
  border-left: 3px solid #fff;
  margin: auto;
}
@media only screen and (max-width: 599px) {
  #pageNav .pageNav-inner {
    border: none;
  }
}
#pageNav .pageNav-item {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 25%;
  height: 60px;
}
@media only screen and (max-width: 599px) {
  #pageNav .pageNav-item {
    height: 48px;
  }
}
#pageNav .pageNav-item::before {
  content: "";
  background: url("../images/common/arrow-down-white.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  width: 15px;
  height: 9px;
  right: 20px;
}
@media only screen and (max-width: 599px) {
  #pageNav .pageNav-item::before {
    width: 10px;
    height: 6px;
    left: 50%;
    bottom: 6px;
    transform: translate(-50%, 0);
    border-width: 1px;
  }
}
#pageNav .pageNav-item:nth-child(n + 2) {
  border-left: 3px solid #fff;
}
@media only screen and (max-width: 599px) {
  #pageNav .pageNav-item:nth-child(n + 2) {
    border-width: 1px;
  }
}
#pageNav .pageNav-item a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  font-weight: 500;
  color: #fff;
  font-size: 18px;
}
@media only screen and (max-width: 599px) {
  #pageNav .pageNav-item a {
    font-size: 13px;
    margin-top: -0.5rem;
  }
}

#tag {
  max-width: 1120px;
  margin: 30px auto 40px;
}
@media only screen and (max-width: 599px) {
  #tag {
    padding: 0 15px;
    margin: 20px auto 44px;
  }
}
#tag .tag-item {
  display: inline-block;
  width: auto;
  min-height: 25px;
  line-height: 25px;
  background: #f5f5f5;
  padding: 0 8px;
  margin: 0 9px 10px;
}
@media only screen and (max-width: 599px) {
  #tag .tag-item {
    margin: 0 7px 10px;
  }
}

#pickup,
#recommend {
  background: url("../images/common/pixta_60479011_M.png") no-repeat;
  background-size: cover;
  padding: 70px 0 80px;
}
@media only screen and (max-width: 599px) {
  #pickup,
  #recommend {
    padding: 40px 0;
  }
}
#pickup .pickup-inner,
#recommend .pickup-inner {
  position: relative;
}
#pickup .pickup-inner::before,
#recommend .pickup-inner::before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower01.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -138px;
  left: -50px;
}
@media only screen and (max-width: 599px) {
  #pickup .pickup-inner::before,
  #recommend .pickup-inner::before {
    background-size: 50%;
    top: -72px;
    left: -20px;
  }
}
#pickup .pickup-lead,
#recommend .pickup-lead {
  margin-bottom: 2em;
}
@media only screen and (max-width: 599px) {
  #recommend .pickup-lead {
    margin-left: 1em;
    margin-right: 1em;
  }
}
#pickup .pickup-items,
#recommend .pickup-items {
  display: flex;
  justify-content: space-between;
  padding: 0 15px;
}
#pickup .pickup-item,
#recommend .pickup-item {
  flex-direction: column;
  width: 365px;
  background: #fff;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.0588235294);
  border-radius: 10px;
  padding: 21px 10px 15px;
}
#pickup .pickup-item.is-pc,
#recommend .pickup-item.is-pc {
  display: flex;
}
@media only screen and (max-width: 599px) {
  #pickup .pickup-item.is-pc,
  #recommend .pickup-item.is-pc {
    display: none;
  }
}
#pickup .pickup-item:nth-child(n + 2),
#recommend .pickup-item:nth-child(n + 2) {
  margin-left: 12px;
}
#pickup .pickup-item-content,
#recommend .pickup-item-content {
  display: flex;
}
#pickup .pickup-item-img,
#recommend .pickup-item-img {
  width: 175px;
  height: 175px;
  flex: 0 0 175px;
  overflow: hidden;
}
#pickup .pickup-item-img img,
#recommend .pickup-item-img img {
  width: 100%;
  height: auto;
}
#pickup .pickup-item-text,
#recommend .pickup-item-text {
  display: flex;
  flex-direction: column;
  margin-left: 8px;
}
#pickup .pickup-item-tag,
#recommend .pickup-item-tag {
  color: #999;
  font-size: 12px;
  text-align: left;
}
#pickup .pickup-item-price,
#recommend .pickup-item-price {
  font-size: 16px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 5px;
}
#pickup .pickup-item-price span,
#recommend .pickup-item-price span {
  font-size: 13px;
}
#pickup .pickup-item-name,
#recommend .pickup-item-name {
  font-size: 12px;
  text-align: left;
}
#pickup .pickup-item-btn,
#recommend .pickup-item-btn {
  display: flex;
  justify-content: center;
  width: 100%;
}
#pickup .pickup-item-btn .catalogLink,
#pickup .pickup-item-btn .productLink,
#recommend .pickup-item-btn .catalogLink,
#recommend .pickup-item-btn .productLink {
  flex: 0 0 145px;
}
#pickup .pickup-item-btn .productLink,
#recommend .pickup-item-btn .productLink {
  margin-left: 16px;
}
#pickup .productItem:nth-child(n + 2),
#recommend .productItem:nth-child(n + 2) {
  margin-left: 8px;
}
#pickup .productItem.is-sp,
#recommend .productItem.is-sp {
  display: none;
}
@media only screen and (max-width: 599px) {
  #pickup .productItem.is-sp,
  #recommend .productItem.is-sp {
    display: flex;
    flex: 0 0 29.33%;
    margin: 0;
  }
}

#kekkon-search {
  margin: 0 auto 80px;
}
@media only screen and (max-width: 599px) {
  #kekkon-search {
    margin: 50px auto 60px;
  }
}
@media only screen and (max-width: 599px) {
  #kekkon-search .search-title {
    margin-bottom: 15px !important;
  }
}
#kekkon-search .search-inner {
  display: flex;
  flex-direction: column;
  width: 860px;
  background: #fafafa;
  padding: 50px 0;
  margin: auto;
}
@media only screen and (max-width: 599px) {
  #kekkon-search .search-inner {
    width: 100%;
    background: none;
    padding: 0;
  }
}
#kekkon-search .search-selector {
  position: relative;
  display: flex;
  width: 302px;
  height: 40px;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.0705882353);
  border: 1px solid #87c7cc;
  border-radius: 5px;
}
@media only screen and (max-width: 599px) {
  #kekkon-search .search-selector {
    width: 80.53%;
  }
  #kekkon-search .search-selector:first-child {
    margin-bottom: 15px;
  }
}
#kekkon-search .search-selector::before {
  content: "";
  background: url("../images/common/arrow-down-white.svg") no-repeat #87c7cc;
  background-position: center;
  background-size: 13px 7px;
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 100%;
  pointer-events: none;
}
#kekkon-search .search-selector:has(select:disabled) {
  background: #fafafa;
}
#kekkon-search .search-selector select {
  width: 100%;
  color: #555;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  border-radius: 5px;
  outline: none;
  padding: 10px 40px 10px 21px;
  cursor: pointer;
}
#kekkon-search .search-selector select:disabled {
  background: #fafafa;
  opacity: 0.7;
  cursor: default;
}
#kekkon-search .search-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 240px;
  height: 40px;
  background: #de7388;
  border-radius: 50px;
  color: #fff;
  font-weight: 500;
  margin: 30px auto 0;
  cursor: pointer;
}
#kekkon-search .search-btn:disabled {
  background: #9f9f9f;
  cursor: default;
}
#kekkon-search .search-btn::before {
  content: "";
  background: url("../images/common/arrow-right-white.svg") no-repeat;
  width: 8px;
  height: 14px;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
}
@media only screen and (max-width: 599px) {
  #kekkon-search .lead p {
    text-align: center;
  }
}
#kekkon-search .selector-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 599px) {
  #kekkon-search .selector-wrap {
    flex-direction: column;
  }
}
#kekkon-search .search-cross {
  margin: 0 14px 0 16px;
}
@media only screen and (max-width: 599px) {
  #kekkon-search .search-cross {
    display: none;
  }
}

#chooseFromBudget {
  background: #f2f2ed;
}
#chooseFromBudget .chooseFromBudget-inner {
  position: relative;
  padding: 50px 0;
}
#chooseFromBudget .chooseFromBudget-inner::before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower02.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  bottom: -130px;
  right: -50px;
}
@media only screen and (max-width: 599px) {
  #chooseFromBudget .chooseFromBudget-inner::before {
    width: 133px;
    height: 80px;
    bottom: -38px;
    right: 0;
  }
}
#chooseFromBudget .chooseFromBudget-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 900px;
  margin: -9px auto;
}
@media only screen and (max-width: 599px) {
  #chooseFromBudget .chooseFromBudget-list {
    width: calc(100% - 30px);
    justify-content: space-between;
  }
}
@media only screen and (max-width: 599px) {
  #chooseFromBudget .chooseFromBudget-list-item {
    width: 47.25%;
  }
  #chooseFromBudget .chooseFromBudget-list-item:nth-child(n + 3) {
    margin-top: 12px;
  }
}
#chooseFromBudget .chooseFromBudget-list-item a {
  position: relative;
  display: block;
  font-size: 16px;
  font-weight: 700;
  color: #555;
  border-radius: 5px;
  background: #e0cda7;
  padding: 11px 32px 11px 22px;
  margin: 9px 8px;
}
@media only screen and (max-width: 599px) {
  #chooseFromBudget .chooseFromBudget-list-item a {
    font-size: 13px;
    padding: 11px 22px 11px 12px;
    margin: 0;
  }
}
#chooseFromBudget .chooseFromBudget-list-item a::before {
  content: "";
  background: url("../images/common/arrow-right-white.svg") no-repeat;
  width: 8px;
  height: 14px;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  filter: brightness(0) saturate(100%) invert(34%) sepia(3%) saturate(12%)
    hue-rotate(345deg) brightness(91%) contrast(91%);
}

#chooseFromAmount .chooseFromAmount-subTitle {
  color: #ac9363;
  font-size: 20px;
  font-weight: 700;
  text-align: left;
  border-bottom: 1px solid;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-subTitle {
    font-size: 16px;
  }
}
#chooseFromAmount .chooseFromAmount-lead {
  font-size: 17px;
  text-align: left;
  margin: 10px 0 30px;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-lead {
    font-size: 13px;
  }
}
#chooseFromAmount .chooseFromAmount-wrap {
  position: relative;
}
#chooseFromAmount .chooseFromAmount-wrap:nth-child(odd) {
  background: #f2f2ed;
  padding-top: 10px;
}
#chooseFromAmount
  .chooseFromAmount-wrap:last-child
  .chooseFromAmount-inner:before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower02.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  bottom: -150px;
  right: 0;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount
    .chooseFromAmount-wrap:last-child
    .chooseFromAmount-inner:before {
    width: 130px;
    height: 80px;
    bottom: -40px;
  }
}
#chooseFromAmount .chooseFromAmount-inner {
  position: relative;
  padding: 60px 0;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-inner {
    padding: 50px 15px;
  }
  #chooseFromAmount .chooseFromAmount-inner:nth-child(2) {
    padding: 0 15px;
  }
}
#chooseFromAmount .chooseFromAmount-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 900px;
  margin: -10px auto;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-list {
    width: 100%;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-list-item {
    width: calc(50% - 5px);
  }
  #chooseFromAmount .chooseFromAmount-list-item:nth-child(n + 3) {
    margin-top: 12px;
  }
}
#chooseFromAmount .chooseFromAmount-list-item a {
  position: relative;
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #ac9363;
  background: #fff;
  border: 1px solid #ac9363;
  border-radius: 70px;
  padding: 12px 32px 11px 20px;
  margin: 10px 25px;
}
#chooseFromAmount .chooseFromAmount-list-item a.sp {
  display: none;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-list-item a {
    font-size: 12px;
    padding: 10px 20px 10px 8px;
    margin: 0;
  }
  #chooseFromAmount .chooseFromAmount-list-item a.pc {
    display: none;
  }
  #chooseFromAmount .chooseFromAmount-list-item a.sp {
    display: block;
  }
}
#chooseFromAmount .chooseFromAmount-list-item a::before {
  content: "";
  background: url("../images/common/arrow-right-white.svg") no-repeat;
  width: 8px;
  height: 14px;
  position: absolute;
  top: 51%;
  right: 15px;
  transform: translateY(-50%) rotate(90deg);
  filter: brightness(0) saturate(100%) invert(63%) sepia(17%) saturate(733%)
    hue-rotate(3deg) brightness(92%) contrast(87%);
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-list-item a::before {
    right: 8px;
  }
}
#chooseFromAmount .chooseFromAmount-contents {
  display: flex;
}
@media only screen and (max-width: 599px) {
  #chooseFromAmount .chooseFromAmount-contents {
    flex-wrap: wrap;
    justify-content: space-between;
  }
  #chooseFromAmount .chooseFromAmount-contents .productItem {
    width: 30%;
    margin: 0;
  }
  #chooseFromAmount .chooseFromAmount-contents .productItem:nth-child(n + 4) {
    margin-top: 25px;
  }
}

#priceRecommend {
  background: url("../images/common/pixta_60479011_M.png") no-repeat;
  background-size: cover;
  padding: 60px 0;
}
#priceRecommend .priceRecommend-list {
  display: flex;
  flex-wrap: wrap;
}
#priceRecommend .priceRecommend-list-item {
  width: calc(50% - 20px);
  background: #fff;
  border-radius: 10px;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1019607843);
  padding: 20px 25px;
}
#priceRecommend .priceRecommend-list-item:nth-child(even) {
  margin-left: 40px;
}
#priceRecommend .priceRecommend-list-item:nth-child(n + 3) {
  margin-top: 40px;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-item {
    width: 100%;
    margin: 0 15px;
  }
  #priceRecommend .priceRecommend-list-item:nth-child(even) {
    margin-left: 15px;
  }
  #priceRecommend .priceRecommend-list-item:nth-child(n + 2) {
    margin-top: 25px;
  }
}
#priceRecommend .priceRecommend-list-contents {
  display: flex;
}
#priceRecommend .priceRecommend-list-title {
  position: relative;
  font-size: 18px;
  font-weight: 700;
  color: #ac9363;
  text-align: left;
  border-bottom: 1px solid;
  padding-bottom: 5px;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-title {
    font-size: 16px;
  }
}
#priceRecommend .priceRecommend-list-title::before {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: -4px;
  left: 0;
  background: #ac9363;
}
#priceRecommend .priceRecommend-list-image {
  width: 230px;
  height: 230px;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-image {
    width: 120px;
    height: 120px;
  }
}
#priceRecommend .priceRecommend-list-text {
  margin-left: 16px;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-text .catalogLink,
  #priceRecommend .priceRecommend-list-text .productLink {
    display: none;
  }
}
#priceRecommend .priceRecommend-list-name {
  text-align: left;
  margin: 10px 0 8px 0;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-name {
    font-size: 13px;
  }
}
#priceRecommend .priceRecommend-list-price {
  text-align: left;
  font-size: 18px;
  font-weight: 700;
  margin: 8px 0 18px 0;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-price {
    font-size: 14px;
  }
}
#priceRecommend .priceRecommend-list-price span {
  font-size: 12px;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list-price span {
    font-size: 11px;
  }
}
#priceRecommend .priceRecommend-list .catalogLink {
  width: 223px;
  margin: 18px auto 12px 0;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list .catalogLink {
    width: 144px;
  }
}
#priceRecommend .priceRecommend-list .productLink {
  width: 223px;
  margin-top: 12px;
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-list .productLink {
    width: 144px;
  }
}
@media only screen and (max-width: 599px) {
  #priceRecommend .priceRecommend-bottom {
    display: flex;
    justify-content: space-between;
  }
  #priceRecommend .priceRecommend-bottom .catalogLink,
  #priceRecommend .priceRecommend-bottom .productLink {
    margin: 0;
  }
}

#ranking {
  padding: 80px 0;
}
#ranking .ranking-list {
  display: flex;
}
@media only screen and (max-width: 599px) {
  #ranking .ranking-list {
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 0 15px;
  }
}
#ranking .productItem {
  position: relative;
}
@media only screen and (max-width: 599px) {
  #ranking .productItem {
    width: 30%;
    margin: 0;
  }
  #ranking .productItem:nth-child(n + 4) {
    margin-top: 25px;
  }
}
#ranking .productItem::before {
  content: attr(data-rank);
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  width: 30px;
  height: 30px;
  background: #d0ddde;
  border-radius: 15px;
  font-size: 20px;
  font-weight: 700;
}
@media only screen and (max-width: 599px) {
  #ranking .productItem::before {
    width: 20px;
    height: 20px;
    font-size: 12px;
  }
}
#ranking .productItem:first-child::before {
  background: #f5d902;
}
#ranking .productItem:nth-child(2)::before {
  background: #c3c3c3;
}
#ranking .productItem:nth-child(3)::before {
  background: #c9a147;
}

#best3 {
  background: url("../images/common/pixta_60479011_M.png") no-repeat;
  background-size: cover;
  padding: 80px 0;
}
@media only screen and (max-width: 599px) {
  #best3 {
    padding: 50px 0;
  }
}
#best3 .best3-inner {
  position: relative;
}
#best3 .best3-inner::before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower03.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -110px;
  right: -140px;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-inner::before {
    background: url("../images/common/flower01.svg") no-repeat;
    background-size: 100%;
    width: 130px;
    height: 80px;
    position: absolute;
    top: -110px;
    left: -16px;
  }
}
#best3 .best3-title {
  margin-bottom: 30px;
}
#best3 .best3-content-title {
  font-size: 19px;
  font-weight: 500;
  color: #555;
  margin-bottom: 10px;
}
#best3 .best3-content-lead {
  width: 910px;
  font-size: 17px;
  text-align: left;
  color: #333;
  margin: auto;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-lead {
    width: 100%;
    font-size: 13px;
  }
}
#best3 .best3-content-wrap {
  background: #fff;
  padding: 50px 70px;
  margin-top: 34px;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-wrap {
    padding: 30px 18px;
  }
}
#best3 .best3-content-wrap .otherGiftLink--primary {
  margin-top: 25px;
}
#best3 .best3-content-items {
  display: flex;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-items {
    flex-direction: column;
  }
}
#best3 .best3-content-item:nth-child(n + 2) {
  margin-left: 40px;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-item:nth-child(n + 2) {
    margin-left: 0;
    margin-top: 15px;
  }
}
#best3 .best3-content-item a {
  color: #333;
}
#best3 .best3-content-item-name {
  font-size: 16px;
  font-weight: 700;
  color: #87c7cc;
  text-align: left;
  min-height: 50px;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-item-name {
    font-size: 15px;
    min-height: auto;
  }
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-item-wrap {
    display: flex;
    align-items: center;
    margin-top: 0.8rem;
  }
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-item-text {
    display: flex;
    flex-direction: column;
  }
}
#best3 .best3-content-item-image {
  width: 235px;
  height: 235px;
  margin: 35px 0 20px;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-item-image {
    width: 40%;
    height: auto;
    margin: 0 5% 0 0;
    flex-basis: 40%;
    flex-shrink: 0;
  }
}
#best3 .best3-content-item-price {
  font-size: 17px;
  color: #555;
  font-weight: 700;
  text-align: left;
  margin-bottom: 10px;
}
@media only screen and (max-width: 599px) {
  #best3 .best3-content-item-price {
    font-size: 14px;
  }
}
#best3 .best3-content-item-price span {
  font-size: 14px;
}
#best3 .best3-content-item-text {
  text-align: left;
}

#standardProduct .standardProduct-inner {
  position: relative;
  padding: 60px 0;
}
#standardProduct .standardProduct-title {
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-content {
    padding: 0 15px;
  }
}
#standardProduct .standardProduct-content:nth-child(n + 2) {
  margin-top: 40px;
}
#standardProduct .standardProduct-subTitle {
  color: #87c7cc;
  font-size: 20px;
  font-weight: 700;
  text-align: left;
  border-bottom: 1px solid;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-subTitle {
    font-size: 15px;
  }
}
#standardProduct .standardProduct-lead {
  font-size: 17px;
  text-align: left;
  margin: 10px 0 20px;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-lead {
    font-size: 13px;
  }
}
#standardProduct .standardProduct-items {
  display: flex;
  margin: 20px;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-items {
    margin: 0;
  }
}
#standardProduct .standardProduct-item {
  display: flex;
}
#standardProduct .standardProduct-item:nth-child(2) {
  margin-left: 60px;
}
#standardProduct .standardProduct-item-image {
  width: 216px;
  height: 216px;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.0784313725);
  margin-right: 34px;
  border-radius: 6px;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-item-image {
    width: 36.27vw;
    height: 36.27vw;
    margin-right: 15px;
  }
}
#standardProduct .standardProduct-item-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#standardProduct .standardProduct-item-name {
  text-align: left;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-item-name {
    font-size: 12px;
  }
}
#standardProduct .standardProduct-item-price {
  font-size: 17px;
  font-weight: 700;
  text-align: left;
  margin: 20px 0;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-item-price {
    font-size: 14px;
  }
}
#standardProduct .standardProduct-item-price span {
  font-size: 14px;
}
#standardProduct .standardProduct-item .otherGiftLink--primary {
  margin: 0;
}
@media only screen and (max-width: 599px) {
  #standardProduct .standardProduct-item .otherGiftLink--primary {
    width: 47.73vw;
  }
}

#setGift {
  background: #f5f5f5;
}
#setGift .setGift-inner {
  position: relative;
  padding: 60px 0;
}
#setGift .setGift-title {
  margin-bottom: 30px;
}
#setGift .setGift-subTitle {
  font-size: 20px;
  font-weight: 700;
  color: #ac9363;
  border-top: 1px solid;
  border-bottom: 1px solid;
  padding: 15px 0;
  margin: 50px auto 30px;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-subTitle {
    font-size: 17px;
  }
}
#setGift .setGift-list {
  display: flex;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-list {
    flex-wrap: wrap;
    justify-content: center;
    padding: 0 15px;
  }
}
#setGift .setGift-list .productItem {
  flex: 1;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-list .productItem {
    flex: 0;
    flex-shrink: 0;
    width: 110px;
    margin-right: calc((100% - 110px * 3) / 2);
  }
  #setGift .setGift-list .productItem:nth-child(3n),
  #setGift .setGift-list .productItem:last-child {
    margin-right: 0;
  }
}
#setGift .setGift-setList {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-setList {
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 0 15px;
  }
}
#setGift .setGift-setList a {
  width: 175px;
  height: 175px;
  box-shadow: 0px 0px 11px rgba(0, 0, 0, 0.1019607843);
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-setList a {
    width: 48%;
    height: auto;
  }
}
#setGift .setGift-setList a:nth-child(n + 2) {
  margin-left: 14px;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-setList a:nth-child(n + 2) {
    margin-left: 0;
  }
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-setList a:nth-child(n + 3) {
    margin-top: 15px;
  }
}
#setGift .setGift-setList a img {
  width: 100%;
  height: auto;
}
#setGift .setGift-lead,
#setGift .setGift-lead--sub {
  font-size: 17px;
  margin: 20px auto 40px;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-lead,
  #setGift .setGift-lead--sub {
    font-size: 13px;
    text-align: left;
    padding: 0 15px;
  }
}
#setGift .setGift-lead--sub {
  margin: 20px auto;
}
#setGift .setGift-example {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 40px auto 50px;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example {
    flex-direction: column;
  }
}
#setGift .setGift-example-wrap {
  display: flex;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-wrap {
    display: flex;
    margin-bottom: 10px;
    padding: 0 13px;
  }
}
#setGift .setGift-example-wrap img {
  width: 209px;
  height: 209px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.0784313725);
  border-radius: 5px;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-wrap img {
    width: 40vw;
    height: auto;
  }
}
.setGift-example-wrap:last-child #setGift .setGift-example-item img {
  width: 314px;
  height: 209px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.0784313725);
  border-radius: 6px;
}
@media only screen and (max-width: 599px) {
  .setGift-example-wrap:last-child #setGift .setGift-example-item img {
    width: 83.73vw;
    height: auto;
  }
}
#setGift .setGift-example-item p {
  font-size: 17px;
  font-weight: 500;
  color: #555;
  margin-top: 23px;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-item p {
    font-size: 14px;
  }
}
#setGift .setGift-example-item p span {
  display: block;
  font-size: 14px;
  font-weight: 300;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-item p span {
    font-size: 12px;
  }
}
#setGift .setGift-example-plus {
  position: relative;
  width: 42px;
  height: 42px;
  background: #87c7cc;
  border-radius: 50%;
  margin: 83px 10px auto;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-plus {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    flex-basis: 30px;
  }
}

#setGift .setGift-example-plus::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 22px;
  height: 3px;
  border-radius: 2px;
  background: #fff;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-plus::before {
    width: 15px;
    height: 2px;
  }
}
#setGift .setGift-example-plus::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  width: 22px;
  height: 3px;
  border-radius: 2px;
  background: #fff;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-plus::after {
    width: 15px;
    height: 2px;
  }
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example > .setGift-example-item {
    width: 70vw;
    margin-top: 10px;
  }

  #setGift .setGift-example > .setGift-example-item img {
    width: 100%;
    height: auto;
  }
}
#setGift .setGift-example-arrow {
  position: relative;
  width: 42px;
  height: 42px;
  background: #87c7cc;
  border-radius: 50%;
  margin: 83px 22px auto;
}
@media only screen and (max-width: 599px) {
  #setGift .setGift-example-arrow {
    width: 30px;
    height: 30px;
    margin: auto;
    transform: rotate(90deg);
  }
}
#setGift .setGift-example-arrow::before {
  content: "";
  background: url("../images/common/arrow-down-white.svg") no-repeat;
  background-position: center;
  background-size: 28px 10px;
  position: absolute;
  top: 50%;
  left: 52%;
  transform: translate(-50%, -50%) rotate(-90deg);
  width: 30px;
  height: 30px;
  pointer-events: none;
}
#setGift .productItem {
  position: relative;
}
@media only screen and (max-width: 599px) {
  #setGift .productItem {
    width: 30%;
    margin: 0;
  }
  #setGift .productItem:nth-child(n + 4) {
    margin-top: 25px;
  }
}
#setGift .productItem::before {
  content: attr(data-rank);
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  width: 30px;
  height: 30px;
  background: #d0ddde;
  border-radius: 15px;
  font-size: 20px;
  font-weight: 700;
}
@media only screen and (max-width: 599px) {
  #setGift .productItem::before {
    width: 20px;
    height: 20px;
    font-size: 12px;
  }
}
#setGift .productItem:first-child::before {
  background: #f5d902;
}
#setGift .productItem:nth-child(2)::before {
  background: #c3c3c3;
}
#setGift .productItem:nth-child(3)::before {
  background: #c9a147;
}

#category .category-inner {
  position: relative;
  padding: 70px 0 0;
}
#category .category-title {
  margin-bottom: 30px;
}
#category .category-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media only screen and (max-width: 599px) {
  #category .category-list {
    padding: 0 15px;
  }
}
#category .category-list-item a {
  color: #555;
}
#category .category-list-item:nth-of-type(-n + 6) {
  width: 160px;
  padding: 0;
  margin-bottom: 28px;
}
@media only screen and (max-width: 599px) {
  #category .category-list-item:nth-of-type(-n + 6) {
    width: 30.5%;
  }
}
#category .category-list-item:nth-of-type(-n + 6) .category-list-item-image {
  width: 160px;
  height: 160px;
}
@media only screen and (max-width: 599px) {
  #category .category-list-item:nth-of-type(-n + 6) .category-list-item-image {
    width: 100%;
    height: auto;
  }
}
#category .category-list-item:nth-of-type(-n + 6) .category-list-item-label {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3em;
  font-size: 19px;
  font-weight: 500;
}
@media only screen and (max-width: 599px) {
  #category .category-list-item:nth-of-type(-n + 6) .category-list-item-label {
    font-size: 12px;
  }
}
#category .category-list-item:nth-child(n + 7) {
  width: 175px;
  height: 58px;
  border: 1px solid #c4b592;
  margin-top: 20px;
}
@media only screen and (max-width: 599px) {
  #category .category-list-item:nth-child(n + 7) {
    width: 48.7%;
    height: 45px;
  }
}
#category .category-list-item:nth-child(n + 7) a {
  display: flex;
  align-items: center;
  padding: 6px;
}
@media only screen and (max-width: 599px) {
  #category .category-list-item:nth-child(n + 7) a {
    padding: 4px;
  }
}
#category .category-list-item:nth-child(n + 7) .category-list-item-image {
  margin-right: 10px;
}
#category .category-list-item-image {
  width: 46px;
  height: 46px;
}
@media only screen and (max-width: 599px) {
  #category .category-list-item-image {
    width: 22.7%;
    height: auto;
  }
}

#brand .brand-inner {
  position: relative;
  padding: 80px 0;
}
@media only screen and (max-width: 599px) {
  #brand .brand-inner {
    padding: 60px 0 32px;
  }
}
#brand .brand-title {
  margin-bottom: 30px;
}
#brand .banner img {
  width: 550px;
  height: 143px;
}
@media only screen and (max-width: 599px) {
  #brand .banner img {
    width: calc(100% - 30px);
    height: auto;
  }
}

#check {
  background: #f5f5f5;
}
#check .check-inner {
  position: relative;
  padding: 80px 0;
}
@media only screen and (max-width: 599px) {
  #check .check-inner {
    padding: 40px 0 50px;
  }
}
#check .check-inner::before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower01.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -65px;
  left: -50px;
}
@media only screen and (max-width: 599px) {
  #check .check-inner::before {
    width: 120px;
    top: -27px;
    left: -18px;
  }
}
#check .check-title {
  margin-bottom: 30px;
}
#check .check-list {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 599px) {
  #check .check-list {
    flex-direction: column;
    padding: 0 15px;
  }
}
#check .check-list a {
  width: 400px;
  height: 96px;
}
@media only screen and (max-width: 599px) {
  #check .check-list a {
    width: 100%;
    height: auto;
  }
}
#check .check-list a:last-child {
  margin-left: 30px;
}
@media only screen and (max-width: 599px) {
  #check .check-list a:last-child {
    margin-top: 32px;
    margin-left: 0;
  }
}
#check .check-list a img {
  width: 100%;
}

#service .service-inner {
  position: relative;
  padding: 70px 0 140px;
}
@media only screen and (max-width: 599px) {
  #service .service-inner {
    padding: 50px 0 60px;
  }
}
#service .service-title {
  margin-bottom: 30px;
}
#service .service-list {
  display: flex;
}
#service .service-list-item {
  width: 350px;
}
@media only screen and (max-width: 599px) {
  #service .service-list-item {
    width: calc(100% - 30px);
    padding: 0 15px;
  }
}
#service .service-list-item:nth-child(n + 2) {
  margin-left: 35px;
}
@media only screen and (max-width: 599px) {
  #service .service-list-item:nth-child(n + 2) {
    margin: 0;
  }
}
#service .service-list-item img {
  width: 100%;
}
#service .service-list-item h3 {
  font-size: 20px;
  font-weight: 500;
  color: #87c7cc;
  margin: 20px 0 13px;
}
@media only screen and (max-width: 599px) {
  #service .service-list-item h3 {
    font-size: 15px;
  }
}
#service .service-list-item p {
  font-size: 16px;
  text-align: left;
}
@media only screen and (max-width: 599px) {
  #service .service-list-item p {
    font-size: 13px;
  }
}
#service .slick-dots li.slick-active button:before {
  color: #87c7cc !important;
}
#service .slick-prev,
#service .slick-next {
  z-index: 1;
}
#service .slick-prev:before,
#service .slick-next:before {
  content: "" !important;
  background: url("../images/service/slider-left.svg") no-repeat;
  background-size: 100%;
  width: 15px;
  height: 40px;
  position: absolute;
  top: 30px;
}
#service .slick-prev:before {
  left: 10px;
}
#service .slick-next:before {
  background: url("../images/service/slider-right.svg") no-repeat;
  background-size: 100%;
  right: 10px;
}
#service .slick-prev {
  left: 0 !important;
}
#service .slick-next {
  right: 0 !important;
}

#recommend {
  background: url("../images/common/pixta_60479011_M.png") no-repeat;
  background-size: cover;
}
#recommend .recommend-inner {
  position: relative;
  padding: 130px 0 92px;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-inner {
    padding: 50px 0 58px;
  }
}
#recommend .recommend-inner::before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower04.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-inner::before {
    display: none;
  }
}
#recommend .recommend-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 34px;
  font-weight: 500;
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-title {
    font-size: 21px;
  }
}
#recommend .recommend-content {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 68px auto 80px;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-content {
    flex-direction: column;
    margin: 28px auto 25px;
  }
}
#recommend .recommend-content img {
  width: 284px;
  height: 284px;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-content img {
    width: 50%;
    height: auto;
  }
}
#recommend .recommend-content-text {
  width: 440px;
  margin-left: 53px;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-content-text {
    width: calc(100% - 30px);
    margin: auto;
  }
}
#recommend .recommend-content-text h3 {
  font-size: 19px;
  font-weight: 500;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-content-text h3 {
    font-size: 15px;
    margin: 24px auto 0;
  }
}
#recommend .recommend-content-text p {
  text-align: left;
  margin: 25px 0 22px;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-content-text p {
    margin: 14px 0 20px;
  }
}
#recommend .recommend-content-text small {
  display: block;
  font-size: 10px;
  text-align: right;
  color: #555;
}
@media only screen and (max-width: 599px) {
  #recommend .recommend-content-text small {
    font-size: 9px;
  }
}

.recommend-movie {
  width: 560px;
  display: block;
  margin: 0 auto;
  position: relative;
}
.recommend-movie img {
  width: 100%;
  height: auto;
}
.recommend-movie::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(../images/recommend/movie-play.svg) no-repeat center
    center/5rem auto;
}
@media only screen and (max-width: 599px) {
  .recommend-movie {
    width: calc(100% - 30px);
    margin: 0 15px;
  }
}

#reasons {
  background: #f8f8f5;
}
#reasons .reasons-inner {
  position: relative;
  padding: 80px 0;
}
#reasons .reasons-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 25px;
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-title {
    font-size: 24px;
  }
}
#reasons .reasons-title span {
  font-size: 15px;
  color: #ac9363;
  letter-spacing: 2.25px;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-title span {
    font-size: 14px;
  }
}
#reasons .reasons-list {
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-list {
    flex-direction: column;
  }
}
#reasons .reasons-list-item {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 345px;
  height: 358px;
  border-radius: 10px;
  padding: 22px 18px 25px;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-list-item {
    width: calc(100% - 30px);
    height: auto;
    margin: 0 auto;
  }
  #reasons .reasons-list-item:nth-child(n + 2) {
    margin-top: 30px;
  }
}
#reasons .reasons-list-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 51px;
  height: 51px;
}
#reasons .reasons-list-item:nth-child(1) {
  background: url(../images/reasons/01.svg) no-repeat #fff;
}
#reasons .reasons-list-item:nth-child(2) {
  background: url(../images/reasons/02.svg) no-repeat #fff;
}
#reasons .reasons-list-item:nth-child(3) {
  background: url(../images/reasons/03.svg) no-repeat #fff;
}
#reasons .reasons-list-item img {
  width: 208px;
  height: 137px;
  margin: 0 auto;
}
#reasons .reasons-list-item dt {
  font-size: 17px;
  font-weight: 500;
  margin: 19px 0 7px;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-list-item dt {
    font-size: 15px;
  }
}
#reasons .reasons-list-item dd {
  text-align: left;
  margin: 0;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-list-item dd {
    font-size: 13px;
  }
}
#reasons .reasons-list-item small {
  display: block;
  font-size: 10px;
  text-align: right;
  margin-top: auto;
}
@media only screen and (max-width: 599px) {
  #reasons .reasons-list-item small {
    font-size: 10px;
  }
}

#features {
  background: url("../images/common/pixta_60479011_M.png") no-repeat;
  background-size: cover;
}
#features .features-inner {
  position: relative;
  padding: 80px 0;
}
@media only screen and (max-width: 599px) {
  #features .features-inner {
    padding: 60px 0 50px;
  }
}
#features .features-inner::before {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower06.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -48px;
  left: -50px;
  transform: translateX(-50%);
}
@media only screen and (max-width: 599px) {
  #features .features-inner::before {
    width: 130px;
    top: -40px;
    left: 40px;
  }
}
#features .features-inner::after {
  content: "";
  width: 273px;
  height: 219px;
  background: url("../images/common/flower05.svg") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -40px;
  right: -310px;
  transform: translateX(-50%);
}
@media only screen and (max-width: 599px) {
  #features .features-inner::after {
    width: 130px;
    top: -50px;
    right: -100px;
  }
}
#features .features-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 25px;
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #features .features-title {
    font-size: 24px;
  }
}
#features .features-title span {
  font-size: 15px;
  color: #ac9363;
  letter-spacing: 2.25px;
}
@media only screen and (max-width: 599px) {
  #features .features-title span {
    font-size: 14px;
  }
}
#features .features-items {
  display: flex;
  flex-direction: column;
}
@media only screen and (max-width: 599px) {
  #features .features-items {
    padding: 0 15px;
  }
}
#features .features-items-item {
  display: flex;
  width: 714px;
  height: 296px;
  background: #fff;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.0705882353);
  padding: 29px 0 29px 0;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item {
    flex-direction: column;
    width: 100%;
    height: auto;
  }
}
#features .features-items-item:nth-child(n + 2) {
  margin-top: 30px;
}
#features .features-items-item:first-child,
#features .features-items-item:last-child {
  padding-right: 20px;
  margin-right: auto;
  margin-left: 18px;
}
#features .features-items-item:first-child .features-items-item-text,
#features .features-items-item:last-child .features-items-item-text {
  margin-left: 42px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item:first-child .features-items-item-text,
  #features .features-items-item:last-child .features-items-item-text {
    margin-left: 24px;
  }
}
#features .features-items-item:first-child .features-items-item-text p,
#features .features-items-item:last-child .features-items-item-text p {
  padding-right: 20px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item:first-child .features-items-item-text p,
  #features .features-items-item:last-child .features-items-item-text p {
    font-size: 13px;
    letter-spacing: 0.8px;
    padding-right: 0;
  }
}
#features .features-items-item:nth-child(2) {
  flex-direction: row-reverse;
  padding-left: 20px;
  margin-left: auto;
  margin-right: 18px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item:nth-child(2) {
    flex-direction: column;
  }
}
#features .features-items-item:nth-child(2) img {
  margin: 0 -18px 0 0;
}
#features .features-items-item:nth-child(2) .features-items-item-text {
  margin-right: 56px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item:nth-child(2) .features-items-item-text {
    margin-right: 24px;
  }
}
#features .features-items-item:nth-child(2) .features-items-item-text p {
  padding-right: 20px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item:nth-child(2) .features-items-item-text p {
    font-size: 13px;
    padding-right: 0;
  }
}
#features .features-items-item img {
  width: 317px;
  height: 238px;
  margin: 0 0 0 -18px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item img {
    width: 89.6vw;
    height: auto;
  }
}
#features .features-items-item-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item-text {
    align-items: flex-start;
  }
}
#features .features-items-item-text h3 {
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  margin-bottom: 20px;
}
@media only screen and (max-width: 599px) {
  #features .features-items-item-text h3 {
    font-size: 17px;
    margin-top: 15px;
  }
}
#features .features-items-item-text h3 span {
  background: linear-gradient(transparent 50%, #ffffd0 50%);
}
#features .features-items-item-text p {
  text-align: left;
}
#features .features-bnr {
  padding: 0 15px;
  margin: 50px auto 0;
}
#features .features-bnr img {
  width: 100%;
  height: auto;
}
#features .features-bnr h3 {
  font-size: 19px;
  font-weight: 500;
  margin: 23px auto 25px;
}
#features .features-bnr h3 span {
  display: block;
  font-size: 15px;
}
#features .features-bnr p {
  font-size: 14px;
  text-align: left;
  letter-spacing: 1.2px;
}

#point .point-inner {
  position: relative;
  padding: 70px 0 140px;
}
@media only screen and (max-width: 599px) {
  #point .point-inner {
    padding: 40px 0;
  }
}
#point .point-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 25px;
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #point .point-title {
    font-size: 24px;
    margin-bottom: 20px;
  }
}
#point .point-title span {
  font-size: 15px;
  color: #ac9363;
  letter-spacing: 2.25px;
}
@media only screen and (max-width: 599px) {
  #point .point-title span {
    font-size: 14px;
  }
}
#point .point-items {
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 599px) {
  #point .point-items {
    flex-direction: column;
    padding: 0 15px;
  }
}
#point .point-items-item {
  width: 336px;
  height: 100px;
}
@media only screen and (max-width: 599px) {
  #point .point-items-item {
    width: 100%;
    height: auto;
  }
  #point .point-items-item:nth-child(n + 2) {
    margin-top: 32px;
  }
}
#point .point-items-item img {
  width: 100%;
  height: auto;
}
#point .point-items-item p {
  text-align: left;
  margin-top: 19px;
}
@media only screen and (max-width: 599px) {
  #point .point-items-item p {
    font-size: 13px;
    letter-spacing: 0.8px;
  }
}
#point .point-items-item p span {
  background: linear-gradient(transparent 50%, #ffffd0 50%);
}

#article {
  background: #fafafa;
}
#article .article-inner {
  position: relative;
  padding: 60px 0;
}
@media only screen and (max-width: 599px) {
  #article .article-inner {
    padding: 40px 0 60px;
  }
}
#article .article-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 25px;
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #article .article-title {
    font-size: 24px;
  }
}
#article .article-title span {
  font-size: 15px;
  color: #ac9363;
  letter-spacing: 2.25px;
}
@media only screen and (max-width: 599px) {
  #article .article-title span {
    font-size: 14px;
  }
}
#article .article-title--logo {
  width: 300px;
  margin: 60px auto 15px;
}
@media only screen and (max-width: 599px) {
  #article .article-title--logo {
    margin: 35px auto 18px;
  }
}
#article .article-contents {
  background: #fff;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.0705882353);
  padding: 54px 66px 70px 114px;
  margin-top: 60px;
}
@media only screen and (max-width: 599px) {
  #article .article-contents {
    padding: 12px 18px 28px;
  }
}
#article .article-content:nth-child(n + 2) {
  margin-top: 30px;
}
#article .article-content {
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 599px) {
  #article .article-content {
    flex-direction: column;
  }
}
#article .article-content a {
  display: block;
  color: #333;
  text-align: left;
}

#article .article-content img {
  margin-right: 54px;
}
@media only screen and (max-width: 599px) {
  #article .article-content img {
    margin-right: 0;
  }
}
#article .article-content dt {
  font-size: 20px;
  font-weight: 700;
  color: #87c7cc;
  margin-bottom: 16px;
  text-align: left;
}
@media only screen and (max-width: 599px) {
  #article .article-content dt {
    font-size: 15px;
    line-height: 1.8;
    letter-spacing: 1px;
    margin: 28px auto 10px;
  }
}
#article .article-content dd {
  font-size: 17px;
  text-align: left;
}
@media only screen and (max-width: 599px) {
  #article .article-content dd {
    font-size: 13px;
    line-height: 1.8;
    letter-spacing: 2px;
  }
}
#article .article-lead {
  font-size: 17px;
}
@media only screen and (max-width: 599px) {
  #article .article-lead {
    font-size: 13px;
  }
}
#article .article .otherGiftLink--white {
  margin-bottom: 25px;
}
@media only screen and (max-width: 599px) {
  #article .article .otherGiftLink--white {
    margin-top: 23px;
  }
}
#article .article-sns {
  display: flex;
  justify-content: center;
  margin-top: 25px;
}
#article .article-sns-item {
  width: 40px;
  height: 40px;
}
#article .article-sns-item:nth-child(n + 2) {
  margin-left: 12px;
}

#faq .faq-inner {
  position: relative;
  padding: 60px 50px;
}
@media only screen and (max-width: 599px) {
  #faq .faq-inner {
    padding: 40px 15px 35px;
  }
}
#faq .faq-title {
  margin-bottom: 30px;
}
#faq .faq-list-item:nth-child(n + 2) {
  margin-top: 20px;
}
#faq .faq-list-item:last-child .faq-list-label {
  border-bottom: none;
}
@media only screen and (max-width: 599px) {
  #faq .faq-list-item:last-child .faq-list-label {
    border-bottom: 1px solid #d3d3d3;
  }
}
#faq .faq-list-input {
  display: none;
}
#faq .faq-list-input:checked + .faq-list-label {
  border-bottom: none;
}
#faq .faq-list-input:checked + .faq-list-label::before {
  transform: rotate(-45deg);
}
#faq .faq-list-input:checked + .faq-list-label + .faq-list-answer {
  height: auto;
  padding: 20px 0;
}
#faq .faq-list-label {
  display: flex;
  position: relative;
  font-size: 17px;
  border-bottom: 1px solid #d3d3d3;
  padding-bottom: 18px;
  cursor: pointer;
}
@media only screen and (max-width: 599px) {
  #faq .faq-list-label {
    font-size: 14px;
    align-items: center;
    text-align: left;
    padding-right: 18px;
  }
}
#faq .faq-list-label::before {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid #555;
  border-right: 2px solid #555;
  position: absolute;
  top: 0.7rem;
  right: 23px;
  transform: rotate(135deg);
  transition: all 0.3s;
}
@media only screen and (max-width: 599px) {
  #faq .faq-list-label::before {
    right: 0;
  }
}
#faq .faq-list-label span {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #87c7cc;
  color: #fff;
  font-size: 15px;
  flex: 0 0 30px;
  margin-right: 10px;
}
@media only screen and (max-width: 599px) {
  #faq .faq-list-label span {
    width: 34px;
    height: 34px;
    font-size: 17px;
    flex: 0 0 34px;
  }
}
#faq .faq-list-answer {
  display: flex;
  height: 0;
  font-size: 17px;
  line-height: 28px;
  text-align: left;
  margin-bottom: 27px;
  overflow: hidden;
  transition: all 0.3s;
}
#faq .faq-list-answer:last-child {
  margin-bottom: 0;
}
@media only screen and (max-width: 599px) {
  #faq .faq-list-answer {
    font-size: 14px;
  }
}
#faq .faq-list-answer span {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #e0cda7;
  color: #fff;
  font-size: 15px;
  flex: 0 0 30px;
  margin-right: 10px;
}
@media only screen and (max-width: 599px) {
  #faq .faq-list-answer span {
    width: 34px;
    height: 34px;
    font-size: 17px;
    flex: 0 0 34px;
  }
}

.media {
  background: rgba(135, 199, 204, 0.3);
  padding: 70px 0;
}
@media only screen and (max-width: 599px) {
  .media {
    padding: 4rem 0;
  }
}

#app .media__title {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  line-height: 1;
  margin-bottom: 30px;
}
@media only screen and (max-width: 599px) {
  #app .media__title {
    margin-bottom: 2rem;
  }
}

#app .media__title span {
  font-family: "Noto Serif JP", serif;
  font-size: 15px;
  font-weight: 400;
  color: #ac9363;
  margin-bottom: 12px;
}
@media only screen and (max-width: 599px) {
  #app .media__title span {
    font-size: 1rem;
    margin-bottom: 1rem;
  }
}

.media__title img {
  width: 352px;
  height: auto;
}
@media only screen and (max-width: 599px) {
  .media__title img {
    width: 80%;
  }
}

.media__articles {
  width: 90%;
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  margin: 0 auto;
  gap: 20px;
}
@media only screen and (max-width: 599px) {
  .media__articles {
    width: auto;
    display: block;
    margin: 0 2rem;
  }
}

.media-article {
  display: block;
  width: 490px;
  padding: 20px;
  background: #fff;
  margin: 0 8px;
  position: relative;
}
@media only screen and (max-width: 599px) {
  .media-article {
    width: auto;
    display: block;
    padding: 1rem;
    margin: 2rem 0 0;
  }
}

.media-article::after {
  content: "";
  position: absolute;
  display: block;
  width: 30px;
  height: 30px;
  background: #87c7cc;
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
  right: 0;
  bottom: 0;
}
@media only screen and (max-width: 599px) {
  .media-article::after {
    width: 2rem;
    height: 2rem;
  }
}

.media-article__thumbnail {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 450px;
  height: 180px;
  margin-bottom: 10px;
}
@media only screen and (max-width: 599px) {
  .media-article__thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 450/180;
    margin-bottom: 1rem;
  }
}

.media-article__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-article__title {
  text-align: left;
  font-weight: 700;
  font-size: 16px;
  color: #333;
  line-height: calc(24 / 16);
}
@media only screen and (max-width: 599px) {
  .media-article__title {
    font-size: 1rem;
  }
}

/* new-arrival */
#new-arrival {
  background: url(../images/new-arrival/bg-02.jpg) no-repeat center center/cover;
  position: relative;
}

@media only screen and (max-width: 599px) {
  #new-arrival {
    background: url(../images/new-arrival/bg-02.jpg) no-repeat center
      center/cover;
    position: relative;
  }
}

#new-arrival::after {
  display: block;
  content: "";
  width: 694px;
  height: 100%;
  background: url(../images/new-arrival/bg-01.jpg) repeat-y top center/100% auto;
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
}

@media only screen and (max-width: 599px) {
  #new-arrival::after {
    width: 85vw;
  }
}

#new-arrival .content-wrap {
  padding: 60px 0;
  position: relative;
  z-index: 2;
}

@media only screen and (max-width: 599px) {
  #new-arrival .content-wrap {
    padding: 10vw 0;
    z-index: 1;
  }
}

#new-arrival .chooseFromBudget-title .sp-only {
  display: none;
}

@media only screen and (max-width: 599px) {
  #new-arrival .chooseFromBudget-title .sp-only {
    display: block;
  }
}

#new-arrival .chooseFromBudget-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 28px;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  margin-bottom: 30px;
}

@media only screen and (max-width: 599px) {
  #new-arrival .chooseFromBudget-title {
    font-size: 1.5rem;
  }
}

#new-arrival .chooseFromBudget-title span {
  color: #b44559;
  font-size: 16px;
}

@media only screen and (max-width: 599px) {
  #new-arrival .chooseFromBudget-title span {
    font-size: 1.1rem;
    font-family: "Noto Serif JP", serif;
  }
}

#new-arrival .lead {
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  font-family: "Noto Sans JP", serif;
  margin-top: 0;
}

@media only screen and (max-width: 599px) {
  #new-arrival .lead {
    width: 85vw;
    font-size: 0.9rem;
    text-align: center;
  }
}

#new-arrival .lead .sp-only {
  display: none;
}

@media only screen and (max-width: 599px) {
  #new-arrival .lead .sp-only {
    display: block;
  }
}

#new-arrival .new-arrival-slider {
  width: calc(280px * 3 + 40px * 2);
  margin: 0 auto;
}

@media only screen and (max-width: 599px) {
  #new-arrival .new-arrival-slider {
    width: 85vw;
  }
}

#new-arrival .item-slide {
  width: 280px;
  background: #fff;
  box-shadow: 0px 5px 20px 0px rgba(141, 79, 88, 0.2);
  padding: 30px 0;
  margin-right: 40px;
  display: flex;
  align-items: center;
  flex-direction: column;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide {
    width: 32vw;
    padding: 5vw 2vw;
    margin-right: 10px;
    height: auto;
  }
}

@media only screen and (max-width: 599px) {
  #new-arrival .slick-track {
    display: flex;
    align-items: stretch;
  }
}

#new-arrival .slick-list {
  padding-bottom: 25px;
}

#new-arrival .item-slide .thumbnail {
  margin-bottom: 10px;
  width: 240px;
  height: 240px;
  border: 1px solid #ccc;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide .thumbnail {
    width: 25vw;
    height: 25vw;
  }
}

#new-arrival .item-slide .thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#new-arrival .item-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-body {
    align-items: flex-start;
  }
}

#new-arrival .item-slide .name {
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide .name {
    font-size: 10px;
    text-align: left;
  }
}

#new-arrival .item-slide .price {
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide .price {
    font-size: 11px;
    text-align: left;
    width: 100%;
  }
}

#new-arrival .item-slide .price span {
  font-size: 16px;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide .price span {
    font-size: 10px;
  }
}

#new-arrival .item-slide .button {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 240px;
  height: 40px;
  border-radius: 20px;
  background: #ac9363;
  margin-top: 20px;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide .button {
    width: 100%;
    height: 25px;
    font-size: 9px;
    margin-top: auto;
  }
}

#new-arrival .item-slide .button img {
  width: 23px;
  height: auto;
  margin-right: 10px;
}

@media only screen and (max-width: 599px) {
  #new-arrival .item-slide .button img {
    width: 5vw;
    margin-right: 5px;
  }
}

#new-arrival .slick-prev,
#new-arrival .slick-next {
  background: none;
  border: none;
  width: 32px;
  height: 50px;
}

#new-arrival .slick-prev::before,
#new-arrival .slick-next::before {
  display: none;
}

@media only screen and (max-width: 599px) {
  #new-arrival .slick-prev,
  #new-arrival .slick-next {
    width: 6vw;
    height: 10vw;
  }
}

#new-arrival .slick-prev {
  top: 40%;
  left: -50px;
  position: absolute;
}
@media only screen and (max-width: 599px) {
  #new-arrival .slick-prev {
    top: 40%;
    left: -7vw;
  }
}

#new-arrival .slick-next {
  top: 40%;
  right: -50px;
  position: absolute;
}
@media only screen and (max-width: 599px) {
  #new-arrival .slick-next {
    top: 40%;
    right: -7vw;
  }
}

#new-arrival .slick-prev img,
.slick-next img {
  width: 100%;
  height: auto;
}

#new-arrival .more-btn {
  width: 250px;
  height: 46px;
  border-radius: 23px;
  background: url(../images/new-arrival/arrow-wh.png) no-repeat right 16px
    center/10px auto;
  background-color: #b44559;
  margin: 30px auto 0;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media only screen and (max-width: 599px) {
  #new-arrival .more-btn {
    margin: 5vw auto 0;
    width: 60vw;
    height: 10vw;
    font-size: 12px;
  }
}

.ribbon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 2.8em;
  margin: 0;
  background: #87c7cc;
  color: #fff;
  border-bottom: 3px solid #fff;
  font-size: 22px;
}
@media only screen and (max-width: 599px) {
  .ribbon {
    height: 4em;
    font-size: 13px;
    border-bottom-width: 1px;
  }
}

.ribbon img {
  width: 3em;
  height: auto;
}

.ribbon span {
  margin-left: 1em;
  display: flex;
  justify-content: center;
  align-items: center;
}

.ribbon small {
  font-size: 13px;
  margin-left: 1em;
}
@media only screen and (max-width: 599px) {
  .ribbon small {
    font-size: 11px;
  }
}

.brand-list {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  margin: 30px auto 48px;
  gap: 20px;
}
@media only screen and (max-width: 599px) {
  .brand-list {
    gap: 10px;
    margin: 30px auto;
    padding: 0 15px;
  }
}

.brand-list a {
  display: block;
  width: 360px;
}
@media only screen and (max-width: 599px) {
  .brand-list a {
    width: calc((100% - 10px) / 2);
  }
}
.brand-list a img {
  width: 100%;
  height: auto;
}
.brand-list a p {
  margin-top: 0.5em;
  font-size: 14px;
  font-weight: 400;
  color: #333;
}
@media only screen and (max-width: 599px) {
  .brand-list a p {
    font-size: 11px;
  }
}

.banner {
  margin: 50px 0 -50px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 599px) {
  .banner {
    margin: 3rem 0 -1rem;
  }
}
.banner a {
  display: block;
  width: 750px;
}
@media only screen and (max-width: 599px) {
  .banner a {
    width: 100%;
  }
}
.banner a img {
  width: 100%;
  height: auto;
}
