/* --------------------------
          蜈ｱ騾�
-------------------------- */
#bca {
  color: #3d3027;
}

.font-petrona {
  font-family: 'Petrona', serif !important;
}

main a:hover {
  text-decoration: none;
}

.icon__bca {
  position: absolute;
}

.font-capitalize {
  text-transform: capitalize;
}

#bca .li-block {
  width: 920px;
  min-height: 402px;
}

#bca .li-block .img {
  width: 457px;
}

#bca .li-block .name-and-price,
.torio-item__item .name-and-price {
  margin: 25px 0px 0px;
}

#bca .li-block .btn-list {
  margin: 0 auto;
}

#bca .li-block .btn-list .btn a,
.torio-item__item .btn-list .btn a {
  width: 210px;
  padding: 17px 0 19px;
}

#bca .hs .li-block h3,
#bca .bs .li-block h3,
#bca .li-block h3 {
  font-size: 3rem;
}

.butterfly-obj1,
.butterfly-obj2 {
  width: 75px;
  position: absolute;
}

.butterfly-obj1 {
  top: 197px;
  left: 181px;
}

.butterfly-obj2 {
  top: 842px;
  right: 90px;
  transform: scale(-1, 1);
}

.side-obj1,
.side-obj2 {
  position: absolute;
}

.side-obj1 {
  width: 7.5vw;
  right: 0;
}

.side-obj2 {
  width: 6.7vw;
  left: 0;
}

.side-obj-rel1,
.side-obj-rel2 {
  transform: scale(-1, 1);
}

.side-obj-rel1 {
  right: inherit;
  left: 0;
}

.side-obj-rel2 {
  left: inherit;
  right: 0;
}

.hs .side-obj1 {
  top: 85vw;
}

.hs .side-obj2 {
  top: 136vw;
}

.bs .side-obj1 {
  top: 88vw;
}

.bs .side-obj2 {
  top: 140vw;
}

.rfc .side-obj1 {
  top: 75vw;
}

.rfc .side-obj2 {
  top: 102vw;
}

/* --------------------------
            kv
-------------------------- */
.kv {
  background-image: url(../../images/special_contents/BestCosmeAward/20251201/bg_kv.jpg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

.kv__inner {
  width: 816px;
  margin: 0 auto;
  padding: 100px 0 90px;
}

.kv__en-title {
  width: 739px;
  margin: 0 auto;
}

#bca .kv h1 {
  width: fit-content;
  font-size: 2.6rem;
  margin: 23px auto 0;
  position: relative;
  top: 0;
  left: 0;
}

.kv__ja-title::before,
.kv__ja-title::after,
.torio__title::before,
.torio__title::after {
  content: "";
  width: 33px;
  height: 35px;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
}

.kv__ja-title::before,
.torio__title::before {
  background-image: url(../../images/special_contents/BestCosmeAward/20251201/obj_title_l.svg);
  left: -40px;
}

.kv__ja-title::after,
.torio__title::after {
  background-image: url(../../images/special_contents/BestCosmeAward/20251201/obj_title_r.svg);
  right: -40px;
}

.kv__text {
  font-size: 2.6rem;
  line-height: 1.5;
  font-feature-settings: "palt";
  text-align: center;
  margin-top: 40px;
}

.kv__notes {
  font-size: 1.2rem;
  font-feature-settings: "palt";
  line-height: 1;
  margin-top: 26px;
}

/* --------------------------
          nav
-------------------------- */
.nav__list {
  width: 816px;
  display: flex;
  column-gap: 18px;
  margin-top: 35px;
}

#bca .mlead ul li.n1,
#bca .mlead ul li.n2,
#bca .mlead ul li.n3,
#bca .mlead ul li.n4 {
  width: 260px;
}

.nav__item {
  width: 260px;
  height: 130px;
  background-image: url(../../images/special_contents/BestCosmeAward/20241212/bg_nav.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  position: relative;
}

.nav-item__wrapper {
  display: flex;
  padding-top: 25px;
}

.nav-img__wrapper {
  /* width: 105px; */
  margin: 0 auto;
}

.nav-img {
  margin: 0 auto;
}

.nav-hs__img {
  width: 72px;
  padding-top: 13px;
}

.nav-bs__img {
  width: 64px;
  padding-top: 10px;
}

.nav-rfc__img {
  width: 32px;
}

.nav-fp__img {
  width: 72px;
  padding-top: 13px;
}

.nav-text__wrapper {
  width: 160px;
}

.nav-text__wrapper figure {
  width: 140px;
  position: relative;
}

.label__nav {
  width: 140px;
}

.label__text {
  width: 100%;
  color: #fff;
  font-size: 1.4rem;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

.label__text--large {
  font-size: 2.2rem;
}

.nav-item__name {
  width: 140px;
  text-align: center;
  margin-top: 9px;
}

.arrow__nav {
  width: 20px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 15px;
}

.section__obj {
  width: 418px;
  margin: 0 auto;
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
}

.section__bg {
  width: 1357px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}

.contents__inner {
  position: relative;
  z-index: 20;
}

.common__catch {
  font-size: 3rem;
  font-feature-settings: "palt";
  line-height: 1;
  text-align: center;
  margin-top: 40px;
}

.common__catch--small {
  display: block;
  font-size: 2rem;
  margin-bottom: 25px;
}

#bca .hs,
#bca .fp,
#bca .bs {
  border-top: none;
  padding: 100px 0 93px;
}

#bca .hs:before,
#bca .fp:before,
#bca .bs:before,
#bca .hs:after,
#bca .fp:after,
#bca .bs:after {
  display: none;
}

#bca .li-block .text {
  line-height: 1.2;
  padding: 20px 0 0;
}

#bca .li-block .text2 {
  padding: 20px 0 0;
}

#bca .li-block .type {
  margin: 26px auto 0;
}

sup {
  font-size: 1.2rem;
  vertical-align: super;
}

/* --------------------------
      ヘッドスクラブ
-------------------------- */
#bca .hs {
  background-color: #d6f0f7;
}

.t-award {
  position: relative;
}

.award-label__text {
  width: 100%;
  color: #fff;
  font-size: 2.8rem;
  text-align: center;
  position: absolute;
  /* top: 0; */
  /* left: 50%; */
  /* transform: translateX(-50%); */
  top: 55%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

.award-label__text--large {
  font-size: 3.8rem;
}

.item-img__wrapper {
  position: relative;
}

.icon__bc-head {
  width: 77px;
  top: 19px;
  left: 20px;
}

.icon__maquia {
  width: 86px;
  top: 24px;
  left: 91px;
}

/* --------------------------
        ボディスクラブ
-------------------------- */
#bca .bs {
  background-color: #e4e2f4;
}

#bca .bs .li-block {
  padding: 55px 0 0;
}

#bca .bs .fp-obj3 {
  margin: 0;
  padding: 0;
  position: absolute;
  top: 565px;
  ;
  right: 0px;
  width: 123px;
  transform: scale(-1, 1);
}

#bca .bs .fp-obj4 {
  margin: 0;
  padding: 0;
  position: absolute;
  top: 690px;
  left: 0px;
  width: 150px;
  transform: scale(-1, -1);
}

/* --------------------------
      フェイスポリッシャー
-------------------------- */
.icon__bc-emblem {
  width: 100px;
  top: 25px;
  left: 13px;
}

#bca .fp {
  background-color: #d4e3f5;
}

#bca .fp.fp--cla {
  background-color: #f0eade;
}

#bca .fp .li-block .li-in {
  padding-top: 0;
}

#bca .fp--ref .li-block .li-in {
  margin-right: 70px;
}

#bca .fp .li-block h3.name-cla,
#bca .fp.fp--cla .li-block .text2 {
  color: #a4915d;
}

#bca .fp .li-block .type {
  width: 212px;
}

#bca .fp--cla .li-block .type {
  width: 311px;
}

#bca .fp .li-block .type .fragrance__item {
  width: 82px;
}

#bca .fp .li-block .type .type__item {
  width: 119px;
}

#bca .fp--cla .li-block .type .fragrance__item {
  width: 100px;
}

#bca .fp--cla .li-block .type .type__item {
  width: 201px;
}

#bca .fp .li-block .type li span.t1 {
  background-color: #629aca;
  border: none;
}

#bca .fp .li-block .type li span.t2 {
  border: none;
}

#bca .fp .li-block .type li span.t1-type {
  background-color: #fff;
  border: 1px solid #629aca;
  color: #629aca;
}

#bca .fp--cla .li-block .type li span.t1 {
  background-color: #a4915d;
  border: none;
}

#bca .fp--cla .li-block .type li span.t2 {
  border: none;
}

#bca .fp--cla .li-block .type li span.t1-type {
  background-color: #fff;
  border: 1px solid #a4915d;
  color: #a4915d;
}

#bca .fp--cla .li-block .btn-list .btn a {
  background-color: #a4915d;
}

.icon__voce {
  width: 81px;
  position: absolute;
  top: 23px;
  left: 23px;
}

#bca .ih-notes {
  margin: 32px auto 0;
  padding: 0px;
  width: 912px;
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: -0.02em;
}

.voce__notes {
  /* width: 912px; */
  font-size: 0.8rem;
  text-align: center;
  position: absolute;
  top: 144px;
  left: 19px;
  font-weight: bold;
}

/* ---------------- */
.recipe {
  margin: 0px;
  padding: 225px 0px 100px;
  background-image: url(../../images/special_contents/New_BodyScrub/20240301/bg_sr.jpg);
  background-repeat: repeat-x;
  background-size: 100% 100%;
}

.recipe h2 {
  padding: 0;
  background-image: none;
  color: #a69968;
  font-size: 5.6rem;
  font-weight: 600;
  text-align: center;
}

.recipe .recipe-obj1 {
  margin: 0;
  padding: 0;
  position: absolute;
  top: 68px;
  left: 0px;
  width: 576px;
  z-index: 10;
}

.recipe .recipe-lead {
  margin: 0px;
  padding: 30px 0px 0px;
  font-size: 2.6rem;
  line-height: 1;
  color: #3b6d7b;
  text-align: center;
}

.recipe .recipe-type {
  margin: 50px auto 0px;
  padding: 0px;
  width: 1040px;
  height: 693px;
  position: relative;
}

.recipe .recipe-type .recipe-type-block {
  margin: 0px;
  padding: 0px;
  position: relative;
}

.recipe .recipe-type .recipe-type-block.rtb1 {
  width: 410px;
  position: absolute;
  top: 0px;
  left: 90px;
}

.recipe .recipe-type .recipe-type-block.rtb2 {
  width: 410px;
  position: absolute;
  top: 65px;
  right: 83px;
}

.recipe .recipe-type .recipe-type-block.rtb3 {
  width: 410px;
  position: absolute;
  bottom: 0px;
  left: 160px;
}

.recipe .recipe-type .recipe-type-block .recipe-type-img {
  margin: 0px;
  padding: 0px;
}

.recipe .recipe-type .recipe-type-block h3 {
  margin: 0px;
  padding: 0px;
  font-size: 6rem;
  line-height: 1;
  font-weight: 700;
  color: #3b6d7b;
  width: 410px;
}

.recipe .recipe-type .recipe-type-block.rtb1 h3 {
  position: absolute;
  bottom: -34px;
  left: -28px;
}

.recipe .recipe-type .recipe-type-block.rtb2 h3 {
  position: absolute;
  bottom: -39px;
  left: 100px;
}

.recipe .recipe-type .recipe-type-block.rtb3 h3 {
  position: absolute;
  top: 120px;
  left: 380px;
}

.recipe .recipe-type .recipe-type-block .recipe-type-text {
  margin: 0px;
  padding: 0px;
  font-size: 2.2rem;
  line-height: 1.3;
  font-weight: 600;
  color: #675341;
  width: 410px;
}

.recipe .recipe-type .recipe-type-block .recipe-type-text sup {
  font-size: 1.2rem;
  vertical-align: super;
}

.recipe .recipe-type .recipe-type-block.rtb1 .recipe-type-text {
  position: absolute;
  bottom: -92px;
  left: -28px;
}

.recipe .recipe-type .recipe-type-block.rtb2 .recipe-type-text {
  position: absolute;
  bottom: -97px;
  left: 100px;
}

.recipe .recipe-type .recipe-type-block.rtb3 .recipe-type-text {
  position: absolute;
  top: 178px;
  left: 380px;
}

.recipe .recipe-type .recipe-type-notes {
  margin: 0px;
  padding: 0px;
  font-size: 1.2rem;
  line-height: 1;
  color: #675341;
  position: absolute;
  bottom: 0px;
  right: 0px;
}

.recipe .recipe-type .r1,
.recipe .recipe-type .r2,
.recipe .recipe-type .r3,
.recipe .recipe-type .r4 {
  opacity: 0;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px);
}

.recipe .recipe-type.loaded .r1,
.recipe .recipe-type.loaded .r2,
.recipe .recipe-type.loaded .r3,
.recipe .recipe-type.loaded .r4 {
  opacity: 1;
  -webkit-transform: translate(0);
  -ms-transform: translate(0);
  transform: translate(0);

  -webkit-transition: opacity .5s linear, -webkit-transform 1.25s cubic-bezier(.19, 1, .22, 1);
  transition: opacity .5s linear, -webkit-transform 1.25s cubic-bezier(.19, 1, .22, 1);
  -o-transition: opacity .5s linear, transform 1.25s cubic-bezier(.19, 1, .22, 1);
  transition: opacity .5s linear, transform 1.25s cubic-bezier(.19, 1, .22, 1);
  transition: opacity .5s linear, transform 1.25s cubic-bezier(.19, 1, .22, 1), -webkit-transform 1.25s cubic-bezier(.19, 1, .22, 1);
}

.recipe .recipe-type.loaded .rtb1.r1 {
  -webkit-transition-delay: .4s;
  -o-transition-delay: .4s;
  transition-delay: .4s;
}

.recipe .recipe-type.loaded .rtb1 .r2 {
  -webkit-transition-delay: .8s;
  -o-transition-delay: .8s;
  transition-delay: .8s;
}

.recipe .recipe-type.loaded .rtb1 .r3 {
  -webkit-transition-delay: 1.2s;
  -o-transition-delay: 1.2s;
  transition-delay: 1.2s;
}

.recipe .recipe-type.loaded .rtb1 .r4 {
  -webkit-transition-delay: 1.6s;
  -o-transition-delay: 1.6s;
  transition-delay: 1.6s;
}


.recipe .recipe-type.loaded .rtb2.r1 {
  -webkit-transition-delay: 2s;
  -o-transition-delay: 2s;
  transition-delay: 2s;
}

.recipe .recipe-type.loaded .rtb2 .r2 {
  -webkit-transition-delay: 2s;
  -o-transition-delay: 2s;
  transition-delay: 2s;
}

.recipe .recipe-type.loaded .rtb2 .r3 {
  -webkit-transition-delay: 2.4s;
  -o-transition-delay: 2.4s;
  transition-delay: 2.4s;
}

.recipe .recipe-type.loaded .rtb2 .r4 {
  -webkit-transition-delay: 2.8s;
  -o-transition-delay: 2.8s;
  transition-delay: 2.8s;
}


.recipe .recipe-type.loaded .rtb3.r1 {
  -webkit-transition-delay: 3.2s;
  -o-transition-delay: 3.2s;
  transition-delay: 3.2s;
}

.recipe .recipe-type.loaded .rtb3 .r2 {
  -webkit-transition-delay: 3.2s;
  -o-transition-delay: 3.2s;
  transition-delay: 3.2s;
}

.recipe .recipe-type.loaded .rtb3 .r3 {
  -webkit-transition-delay: 3.6s;
  -o-transition-delay: 3.6s;
  transition-delay: 3.6s;
}

.recipe .recipe-type.loaded .rtb3 .r4 {
  -webkit-transition-delay: 4s;
  -o-transition-delay: 4s;
  transition-delay: 4s;
}

.recipe .renewal {
  margin: 130px auto 0;
  padding: 0px;
  width: 1040px;
  position: relative;
}

.recipe .recipe-obj2 {
  margin: 0;
  padding: 0;
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  -webkit- transform: translateX(-50%);
  width: 195px;
  z-index: 10;
}

.recipe .recipe-obj3 {
  margin: 0;
  padding: 0;
  position: absolute;
  bottom: -28px;
  left: 50%;
  transform: translateX(-50%);
  -webkit- transform: translateX(-50%);
  width: 195px;
  z-index: 10;
}

.recipe .renewal .renewal-frame {
  margin: 0;
  padding: 50px 0px;
  width: 100%;
  background-color: #FFF;
  border-top: 7px solid #a79968;
  border-bottom: 7px solid #a79968;
  position: relative;
  z-index: 20;
}

.recipe .renewal .renewal-frame h3 {
  margin: 0;
  padding: 0px 0 20px;
  color: #a69968;
  font-size: 5.4rem;
  line-height: 1;
  font-weight: 600;
  text-align: center;
  background-image: url(../../images/special_contents/New_BodyScrub/20240301/t_bg1.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 60px auto;
}

.recipe .renewal .renewal-block {
  margin: 0px;
  padding: 0px;
  position: relative;
}

.recipe .renewal .renewal-block.rb1 {
  margin: 35px 0 0;
}

.recipe .renewal .renewal-block.rb2 {
  margin: 60px 0 0;
}

.recipe .renewal .renewal-block h4 {
  margin: 0px auto;
  padding: 0px;
  position: relative;
  text-align: center;
  width: 563px;
  height: 41px;
  display: table;
  background-image: url(../../images/special_contents/New_BodyScrub/20240301/label_renewal.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

.recipe .renewal .renewal-block h4 .rel {
  margin: 0px;
  padding: 0px;
  display: table-cell;
  vertical-align: middle;

  color: #FFF;
  font-size: 2.8rem;
  line-height: 1;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.recipe .renewal .renewal-block h4 .rel sup {
  font-size: 1.5rem;
  vertical-align: super;
}

.recipe .renewal .renewal-block h4 .new {
  display: inline-block;
  margin: 0px;
  padding: 4px 0px;
  width: 60px;
  box-sizing: border-box;
  font-size: 1.8rem;
  line-height: 1;
  background-color: #FFF;
  border-radius: 12px;
  color: #ef8760;
  font-weight: 700;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  -webkit- transform: translateY(-50%);
  left: 0px;
}

.recipe .renewal .renewal-block h4 .ib {
  display: inline-block;
  padding: 0px 0 0 74px;
  position: relative;
}

.recipe .renewal .renewal-block ul {
  margin: 40px 0px 0px 380px;
  padding: 0px;
  font-size: 1.8rem;
  line-height: 1;
}

.recipe .renewal .renewal-block ul li {
  margin: 12px 0px 0px;
  padding: 0px 0 0 18px;
  position: relative;
}

.recipe .renewal .renewal-block ul li sup {
  font-size: 1.2rem;
  vertical-align: super;
}

.recipe .renewal .renewal-block ul li:before {
  margin: 0px;
  padding: 0px;
  content: "";
  width: 7px;
  height: 7px;
  background-color: #806b39;
  border-radius: 50%;
  position: absolute;
  top: 6px;
  left: 0px;
}

.recipe .renewal-img {
  margin: 0;
  padding: 0;
  position: absolute;
  top: -59px;
  left: -64px;
  width: 430px;
  z-index: 10;
}

.recipe .renewal .renewal-block .renewal-oil {
  width: 636px;
  margin: 24px auto 0px;
  padding: 0px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.recipe .renewal .renewal-block .renewal-oil-block {
  width: 212px;
  margin: 0px;
  padding: 0px;
  position: relative;
}

.recipe .renewal .renewal-block .renewal-oil-block .oil-from {
  margin: 0px;
  padding: 0px;
  font-size: 1.6rem;
  line-height: 1;
  text-align: center;
}

.recipe .renewal .renewal-block .renewal-oil-block .oil-name {
  margin: 6px 0px 0px;
  padding: 0px;
  font-size: 2.2rem;
  line-height: 1;
  text-align: center;
  letter-spacing: -0.05em;
}

.recipe .renewal .renewal-block .renewal-oil-block .oil-name sup {
  font-size: 1.2rem;
  vertical-align: super;
}

.recipe .renewal .renewal-block .renewal-oil-block .oil-img {
  margin: 17px 0px 0px;
  padding: 0px;
  text-align: center;
  position: relative;
  z-index: 20;
}

.recipe .renewal .renewal-block .renewal-oil-block.oil1 .oil-img img {
  width: 157px;
  padding: 10px 0px 0px;
}

.recipe .renewal .renewal-block .renewal-oil-block.oil2 .oil-img img {
  width: 152px;
  padding: 15px 0px 0px;
}

.recipe .renewal .renewal-block .renewal-oil-block.oil3 .oil-img img {
  width: 162px;
  padding: 6px 0px 0px;
}

.recipe .renewal .renewal-block .renewal-oil-block .oil-type {
  position: absolute;
  top: 65px;
  right: -5px;
  width: 107px;
  height: 107px;
  background-color: #efead8;
  border-radius: 50%;
  z-index: 10;
  padding: 0px;
  box-sizing: border-box;
}

.recipe .renewal .renewal-block .renewal-oil-block .oil-type .type-text {
  width: 100%;
  font-size: 1.8rem;
  line-height: 1.1;
  margin-top: 0px;

  position: absolute;
  display: inline-block;
  left: 0px;
  top: 51%;
  -webkit-transform: translateY(-51%);
  transform: translateY(-51%);
  text-align: center;
  letter-spacing: 0.05em;
  color: #675341;
}

.recipe .renewal .renewal-notes {
  margin: 10px 0 0px;
  padding: 0px 0 0 100px;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: -0.05em;
}


#bca .item-beg-wrapper {
  margin: 36px auto 0;
  padding: 0px;
  width: 953px;
  position: relative;
}

#bca .item-beg {
  margin: 0 auto;
  padding: 80px 245px 0px 0px;
  width: 953px;
  height: 344px;
  box-sizing: border-box;
  background-image: url(../../images/special_contents/HeadScrub/20230816/frame_ref.png);
  background-repeat: no-repeat;
  position: relative;
}

#bca .item.rel .item-beg {
  background-image: url(../../images/special_contents/HeadScrub/20230816/frame_rel.png);
  background-repeat: no-repeat;
}

#bca .item.rep .item-beg {
  background-image: url(../../images/special_contents/HeadScrub/20230816/frame_rep.png);
  background-repeat: no-repeat;
}

#bca .item-beg.sak {
  padding: 60px 245px 0px 0px;
}

#bca .item-beg h3 {
  font-size: 3rem;
  line-height: 1;
  text-align: center;
  color: #008b6b;
  margin: 0px;
  padding: 0px 0px 30px;
  background-image: url(../../images/special_contents/HeadScrub/20230816/t_beg.png);
  background-repeat: no-repeat;
  background-position: center bottom;
}

#bca .item-beg.sak h3 {
  line-height: 1.2;
  padding: 0px 0px 20px;
}

#bca .item-beg .beg-img {
  position: absolute;
  top: 62px;
  right: 136px;
}

#bca .item-beg.sct .beg-img {
  position: absolute;
  top: 63px;
  right: 130px;
}

#bca .item-beg.hsd .beg-img {
  position: absolute;
  top: 63px;
  right: 180px;
}

#bca .item-beg.hhck .beg-img {
  position: absolute;
  top: 50px;
  right: 120px;
}

#bca .item-beg.sak .beg-img {
  position: absolute;
  top: 130px;
  right: 100px;
}

#bca .item-beg .limited {
  position: absolute;
  top: 12px;
  right: -38px;
  width: 80px;
  height: 80px;
  background-color: #a89968;
  border-radius: 50%;
  z-index: 15;
  padding: 3px;
  box-sizing: border-box;
}

#bca .item-beg.hsd .limited {
  top: 0px;
  right: -88px;
}

#bca .item-beg.hhck .limited {
  top: -10px;
  right: -20px;
}

#bca .item-beg.sak .limited {
  top: -85px;
  right: -20px;
}

#bca .item-beg .limited .limited-in {
  width: 100%;
  height: 100%;
  display: block;
  border: 1px solid #FFF;
  border-radius: 50%;
  box-sizing: border-box;
}

#bca .item-beg .limited .ltext {
  width: 100%;
  font-size: 1.8rem;
  line-height: 1.1;
  margin-top: 0px;

  position: absolute;
  display: inline-block;
  left: 0px;
  top: 51%;
  -webkit-transform: translateY(-51%);
  transform: translateY(-51%);
  text-align: center;
  letter-spacing: 0.05em;
  color: #FFF;
}

#bca .item-beg .name-and-price {
  margin: 25px 0px 0px;
  padding: 0px;
  display: block;
  text-align: center;
}

#bca .item-beg h4 {
  margin: 0px;
  padding: 0px;
  font-size: 1.4rem;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: normal;
}

#bca .item-beg .price {
  margin: 0px;
  padding: 0px;
  font-size: 1.4rem;
  line-height: 1.5;
  font-weight: 400;
}

#bca .item-beg .btn-list {
  margin: 25px auto 0px;
  padding: 0px;
  width: 402px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#bca .item-beg .btn-list .btn {
  padding: 0px;
}

#bca .item-beg .btn-list .btn a {
  margin: 0px;
  padding: 14px 0px;
  text-align: center;
  color: #FFF;
  font-size: 1.2rem;
  line-height: 1;
  text-decoration: none;
  position: relative;
  display: inline-block;
  background: #008b6b;
  width: 194px;
  cursor: pointer;
}

#bca .item-beg .btn-list .btn a span svg {
  margin: 0px;
  padding: 0px;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 23px;
  transform: translateY(-50%);
  -webkit- transform: translateY(-50%);
  font-size: 1rem;
}

#bca .item-beg .bcs {
  margin: 25px auto 0px;
  padding: 0px;
  width: 402px;
  text-align: center;
}

#bca .item-beg .bbg {
  margin: 0px;
  padding: 14px 0px;
  text-align: center;
  font-size: 1.2rem;
  line-height: 1;
  text-decoration: none;
  position: relative;
  display: inline-block;
  background: #FFF;
  width: 194px;
  border: 1px solid #008b6b;
}

#bca .how-to-use {
  margin: 72px auto 0;
}

#bca .hs .how-to-use .how-to-use-more h3 {
  background-image: none;
}

.detail-how-to {
  line-height: 1;
  text-align: center;
  margin-top: 16px;
}

.detail-how-to a {
  color: #9d8749;
  font-size: 1.6rem;
  font-feature-settings: "palt";
  text-decoration: underline;
}

/* -------------------
        LINE
------------------- */
#bca .c-footer {
  border-top: none;
}

#bca .line {
  background-color: #fff;
  padding: 75px 0 74px;
  position: relative;
  z-index: 30;
}

#bca .line-in {
  width: 590px;
  height: 250px;
  background-image: url(../../images/special_contents/archive/20251128/frame_line.jpg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 59px 0 0;
  position: relative;
}

#bca .line h2 {
  margin: 0px;
  padding: 0px;
  font-size: 2.6rem;
  line-height: 1;
  text-align: center;
}

#bca .line .text {
  font-size: 1.4rem;
  text-align: center;
  margin-top: 18px;
}

#bca .line .btn {
  text-align: center;
  margin-top: 21px;
  padding: 0;
}

#bca .line .btn a {
  margin: 0px;
  padding: 26px 0px 0px 70px;
  text-align: center;
  color: #FFF;
  font-size: 2rem;
  line-height: 1;
  text-decoration: none;
  position: relative;
  display: inline-block;
  background: #00b900;
  width: 272px;
  height: 70px;
  border-radius: 10px;
  box-sizing: border-box;
  font-weight: 600;
}

#bca .line .btn a:before {
  content: "";
  background: url(../../images/special_contents/HolidayCollection/20211014/icon_line.png) no-repeat center center;
  background-size: 50px auto;
  margin: 0px;
  padding: 0px;
  border-right: 1px solid #009e00;
  width: 70px;
  height: 70px;
  position: absolute;
  left: 0px;
  top: 0px;
}

#bca .all-notes {
  text-align: left;
  margin: 0px auto;
  padding: 0px 0px 30px;
  font-size: 1rem;
  line-height: 1;
  width: 1030px;
}

/* ------------------------------
        The Collection
------------------------------ */
.collection-banner {
  background-color: #f4efe5;
  position: relative;
}

.collection-banner__inner {
  padding: 69px 0 90px;
}

.banner-title__obj {
  width: 284px;
  line-height: 1;
  margin: 23px auto 0;
}

.collection-banner__title {
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.collection__banner {
  width: 856px;
  margin: 33px auto 0;
}

.collection__banner-first {
  margin-top: 55px;
}

/* how to use */
.how-to-use,
.prescription {
  margin: 44px auto 0;
  width: 946px;
  position: relative;
}

.how-to-use-in,
.prescription-in {
  margin: 0;
  padding: 0px;
  position: relative;
}

.how-to-use-in h4,
.prescription-in h4 {
  margin: 0px;
  padding: 0px;
  text-align: center;
}

.how-to-use-in h4 a,
.prescription-in h4 a {
  padding: 10px 0px;
  font-size: 2.6rem;
  line-height: 1;
  font-weight: 600;
  display: block;
  position: relative;
  text-decoration: none;
  background-color: #433a31;
  color: #FFF;
  font-style: italic;
}

.how-to-use .how-to-use-in h4 a .ja {
  font-size: 2rem;
}

.how-to-use .how-to-use-in h4 a .icon,
.prescription-in h4 a .icon {
  font-size: 3.2rem;
  line-height: 1;
  font-style: normal;
  text-decoration: none;
  position: absolute;
  top: 50%;
  right: 288px;

  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  font-weight: 400;
  display: inline-block;
}

.how-to-use .how-to-use-in h4 a .plus {
  display: block;
}

.how-to-use .how-to-use-in h4 a .minus {
  display: none;
}

.how-to-use.open .how-to-use-in h4 a .plus {
  display: none;
}

.how-to-use.open .how-to-use-in h4 a .minus {
  display: block;
}

#bca .how-to-use-more {
  padding: 0px 0px 60px;
  display: none;
  margin: 0px;
  width: 100%;
  background-color: #FFF;
  position: relative;
  border-bottom: 2px solid #ab9152;
}

#bca .fp--cla .how-to-use-more {
  padding-top: 90px;
}

.how-to-use-more .howto-head {
  margin: 0;
  padding: 0px 0px 0px 95px;
  position: relative;
}

.how-to-use-more h5 {
  margin: 0px;
  padding: 0px 0px 20px;
  font-size: 5.5rem;
  line-height: 0.9;
  text-align: center;
  font-weight: 600;
  background-image: url(../../images/special_contents/FacePolisher/20230519/t_howto.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  width: 322px;
  font-style: italic;
  position: relative;
}

.how-to-use-more h5 .t1 {
  display: block;
  color: #9c8743;
  font-size: 3.3rem;
}

.how-to-use-more h5 .t2 {
  display: block;
  color: #433a31;
}

.how-to-use-more .howto-head .howto-img {
  position: absolute;
  top: -53px;
  left: 477px;
}

.how-to-use-more .howto-body {
  width: 812px;
  margin: 60px auto 0;
  padding: 0px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.how-to-use-more .howto-body .howto-detail {
  margin: 0px;
  padding: 0px;
  width: 404px;
}

.how-to-use-more .howto-body .howto-detail h6 {
  text-align: center;
  font-size: 2rem;
  line-height: 1;
  font-weight: 600;
  margin: 0px;
  padding: 0px;
  letter-spacing: -0.05em;
  color: #9c8743;
  height: 62px;
  box-sizing: border-box;
}

.how-to-use-more .howto-body .howto-detail.d2 h6 {
  padding: 15px 0 0;
}

.how-to-use-more .howto-body .howto-detail h6 span {
  margin: 0px;
  padding: 0px 13px;
  display: inline-block;
  font-size: 2rem;
  position: relative;
}

.how-to-use-more .howto-body .howto-detail.d1 h6 span {
  padding: 0px 35px;
  line-height: 1.3;
}

.how-to-use-more .howto-body .howto-detail.d2 h6 span {
  padding: 0px 25px;
}

.how-to-use-more .howto-body .howto-detail.d2 h6.fm span {
  line-height: 2;
}

.how-to-use-more .howto-body .howto-detail h6 span:before {
  content: "";
  width: 6px;
  height: 24px;
  background-image: url(../../images/special_contents/FacePolisher/20231226/kakko_l2.svg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
}

.how-to-use-more .howto-body .howto-detail h6 span:after {
  content: "";
  width: 6px;
  height: 24px;
  background-image: url(../../images/special_contents/FacePolisher/20231226/kakko_r2.svg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: 0px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
}

.how-to-use-more .howto-body .howto-detail.d1 h6 span:before {
  content: "";
  width: 6px;
  height: 41px;
  background-image: url(../../images/special_contents/FacePolisher/20231226/kakko_l.svg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
}

.how-to-use-more .howto-body .howto-detail.d1 h6 span:after {
  content: "";
  width: 6px;
  height: 41px;
  background-image: url(../../images/special_contents/FacePolisher/20231226/kakko_r.svg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: 0px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
}

.how-to-use-more .howto-body .howto-detail .text1 {
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.6;
  font-weight: 600;
  margin: 0px;
  padding: 0px;
  letter-spacing: -0.05em;
}

.how-to-use-more .howto-body .howto-detail .use {
  text-align: center;
  margin: 20px auto 0px;
  padding: 25px 0px 30px;
  width: 342px;
  background-color: #f8f7f2;
}

.how-to-use-more .howto-body .howto-detail h7 {
  text-align: center;
  margin: 0px auto;
  padding: 0px;
  width: 280px;
  position: relative;
  display: flex;
  align-items: center;
  font-size: 1.2rem;
  line-height: 1;
  font-weight: 600;
}

.how-to-use-more .howto-body .howto-detail h7:before,
.how-to-use-more .howto-body .howto-detail h7:after {
  border-top: 1px solid #9c8743;
  content: "";
  flex-grow: 1;
}

.how-to-use-more .howto-body .howto-detail h7:before {
  margin-right: 14px;
}

.how-to-use-more .howto-body .howto-detail h7:after {
  margin-left: 14px;
}

.how-to-use-more .howto-body .howto-detail .text2 {
  text-align: center;
  margin: 0px;
  padding: 12px 0px 0px;
  color: #9c8743;
  font-size: 1.4rem;
  line-height: 1.5;
}

.how-to-use-more .notes {
  width: 750px;
  margin: 0px auto;
  padding: 23px 0px 0px;
  font-size: 1.1rem;
  line-height: 1;
}

#bca .fp .how-to-use .how-to-use-more h3 {
  margin: 35px auto 0;
  padding: 0 0 10px;
  width: 465px;
  font-weight: 600;
  text-align: center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center bottom;
  letter-spacing: -0.02em;
}

#bca .bs .how-to-use-more {
  padding-top: 50px;
}

#bca .bs .how-to-use .how-to-use-more .htu-detail {
  margin-top: 30px;
}

#bca .bs .how-to-use .how-to-use-more .htu-detail .detail {
  width: 405px;
}

#bca .bs .how-to-use .how-to-use-more h3 {
  width: 405px;
  background-image: none;
  font-size: 25px;
  margin-top: 0;
}

#bca .bs .how-to-use .how-to-use-more h3.how-to__title {
  background-image: url(../../images/special_contents/BestCosmeAward/20251201/how_to_line.png);
}

.how-to__list {
  text-align: left;
  padding: 0 8px 20px;
}

.how-to__item {
  font-size: 1.6rem;
  font-feature-settings: "palt";
  text-align: left;
  margin-top: 11px;
}

.method-text {
  padding-top: 20px;
  text-align: left;
}

/* チューブ */
.torio-item {
  background-color: #fffefa;
}

.torio-item__inner {
  padding: 80px 0;
}

.torio__title {
  width: fit-content;
  font-size: 6.8rem;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  margin: 15px auto 0;
  position: relative;
}

.torio__label {
  width: 470px;
  margin: 0 auto;
}

.torio-item__text {
  font-size: 2rem;
  line-height: 1.4;
  text-align: center;
  margin-top: 10px;
}

.torio-item-slider {
  width: 972px;
  background-color: #fff;
  box-shadow: 0 0 50px 0 rgba(22, 144, 145, 0.2);
  margin: 57px auto 0;
  padding: 73px 0 69px;
  position: relative;
}

.torio-item-slider::before,
.torio-item-slider::after {
  display: inline-block;
  content: "";
  width: 100%;
  height: 18px;
  background-image: url(../../images/special_contents/HolidayCollection2025/20251002/item_lineup_line_frame.png);
  background-size: contain;
  position: absolute;
}

.torio-item-slider::before {
  top: 0;
}

.torio-item-slider::after {
  bottom: 0;
}

.torio-item__list {
  width: 850px;
  margin: 0 auto;
}

.torio-item__item {
  width: 285px;
}

.torio-item__catch {
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.2;
  padding: 0px;
  text-align: center;
}

.torio__img {
  width: 200px;
  height: 200px;
  margin: 0 auto;
  position: relative;
}

.torio-item__item .name-and-price {
  font-size: 1.4rem;
  text-align: center;
  margin: 10px 0px 0px;
}

.btn--cart {
  text-align: center;
  margin: 15px auto 0;
}

.torio-item__btn--cart a {
  width: 165px;
  padding: 17px 0 19px;
  text-align: center;
  color: #FFF;
  font-size: 1.4rem;
  line-height: 1.4rem;
  text-decoration: none;
  position: relative;
  display: inline-block;
  background: #9e894e;
  cursor: pointer;
}

.torio-item__btn--cart a svg {
  font-size: 1rem;
  right: -20px;
}

.slick-dots {
  margin: 49px auto 0;
}

.slick-dots li button {
  display: block;
  line-height: 0;
  width: 10px;
  height: 10px;
  background: #a2d3d3;
  color: transparent;
  font-size: 0;
  outline: none;
  padding: 0;
  border-radius: 0%;
  transform: rotate(45deg);
}

.slick-dots>li.slick-active>button::before,
.slick-dots>li>button::before {
  background-color: transparent;
}

.slick-dots .slick-active button,
.slick-dots li button:hover {
  background: #169091;
}

.slick-dots>li:not(:first-of-type) {
  margin-left: 15px;
}

.slick-arrow.slick-prev::after,
.slick-arrow.slick-next::after {
  display: none;
}

.torio-item-slider .torio-item-prev,
.torio-item-slider .torio-item-next {
  background-repeat: no-repeat;
  background-position: 0px 0px;
  background-size: 100% 100%;
  transition: unset;
  border-width: 0px;
  border-style: none;
  opacity: 1;
}

.torio-item-slider .torio-item-prev {
  left: -18px;
  background-image: url(../../images/special_contents/HolidayCollection2025/20251002/step_arrow_prev.svg);
}

.torio-item-slider .torio-item-next {
  right: -18px;
  background-image: url(../../images/special_contents/HolidayCollection2025/20251002/step_arrow_next.svg);
}