/* utils
---------------------------------------------------*/
:root {
  --drop-shadow: drop-shadow(10px 10px 15px rgba(0, 0, 0, 0.1));
}

@media only screen and (max-width: 768px) {
  :root {
    --drop-shadow: drop-shadow(1.5625vw 1.5625vw 2.34375vw rgba(0, 0, 0, 0.1));
  }
}
/* body
---------------------------------------------------*/
body {
  background: #f9d3e3;
}

sup {
  top: -0.25em;
}

/* wrap */
.wrap {
  width: 100%;
  overflow: hidden;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
}
.wrap img {
  max-width: 100%;
  height: auto;
}

#Footer {
  margin-top: 0;
}

.btn_cart {
  border-color: #e46ea1;
  background-color: #e46ea1;
}

.btn_cart:hover a {
  color: #e46ea1;
}

.btn_cart:hover a span:before {
  background-image: url(../img/icon_cart_on.png);
}

/* hero
---------------------------------------------------*/
#hero {
  position: relative;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}
#hero .inner {
  position: relative;
  width: 100%;
  aspect-ratio: 1300/643;
  margin: 0 auto;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #hero .inner {
    aspect-ratio: 640/653;
  }
}
#hero .inner img {
  width: 100%;
  user-select: none;
  pointer-events: none;
}
#hero .inner .hero-icon {
  position: absolute;
  top: 20.5287713841%;
  left: 23.1538461538%;
  width: 17.5384615385%;
  z-index: 20;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-icon {
    top: 20.78125vw;
    left: 12.34375vw;
    width: 35.625vw;
  }
}
#hero .inner .hero-title {
  position: absolute;
  top: 56.4541213064%;
  left: 20.2307692308%;
  width: 23.3846153846%;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-title {
    top: 56.875vw;
    left: 6.40625vw;
    width: 47.5vw;
  }
}
#hero .inner .hero-bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-bg {
    top: 0;
    bottom: auto;
    width: 100%;
  }
}

/* lead
---------------------------------------------------*/
#lead {
  position: relative;
  background-color: #e46ea1;
  padding-bottom: 4.6153846154vw;
}
@media only screen and (max-width: 768px) {
  #lead {
    padding-bottom: 9.84375vw;
  }
}
#lead::before {
  position: absolute;
  content: "";
  bottom: calc(100% - 10px);
  left: 0;
  width: 100%;
  height: 120px;
  background-color: #e46ea1;
}
#lead::after {
  position: absolute;
  content: "";
  top: calc(100% - 4.6153846154vw);
  left: 50%;
  translate: -50% 0;
  width: 162.0769230769%;
  aspect-ratio: 2107/486;
  background-color: #f9d3e3;
  border-radius: 50%;
}
@media only screen and (max-width: 768px) {
  #lead::after {
    top: calc(100% - 9.84375vw);
    width: 149.21875%;
    aspect-ratio: 955/486;
  }
}
#lead .inner {
  position: relative;
  width: 96%;
  max-width: 1000px;
  text-align: center;
  padding: 22px 0 40px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #lead .inner {
    padding: 2.65625vw 0 5.3125vw;
  }
}
#lead .inner img {
  width: 617px;
  margin-left: -40px;
}
@media only screen and (max-width: 768px) {
  #lead .inner img {
    width: 85vw;
    margin-left: -3.125vw;
  }
}

/* animation */
#lead,
#lead::before {
  background: rgb(228, 110, 161);
  background: linear-gradient(90deg, rgb(249, 211, 227) 0%, rgb(228, 110, 161) 10%, rgb(228, 110, 161) 50%, rgb(228, 110, 161) 50%, rgb(228, 110, 161) 90%, rgb(249, 211, 227) 100%);
  background-size: 0 100%;
  background-repeat: no-repeat;
  background-position: center center;
  opacity: 0;
  transition: background-size 2s, opacity 0.5s;
}

#lead.did,
#lead.did::before {
  opacity: 1;
  background-size: 300% 100%;
}

/* collaboration
---------------------------------------------------*/
#collaboration {
  position: relative;
  z-index: 1;
}
#collaboration .inner {
  position: relative;
  width: 96%;
  max-width: 1000px;
  padding: 0 0 30px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #collaboration .inner {
    padding: 0 0 6.25vw;
  }
}
#collaboration .headline {
  margin-bottom: 47px;
}
@media only screen and (max-width: 768px) {
  #collaboration .headline {
    margin-bottom: 14.84375vw;
  }
}
#collaboration .headline .icon {
  width: 96px;
  margin: -16px auto 21px;
}
@media only screen and (max-width: 768px) {
  #collaboration .headline .icon {
    width: 15vw;
    margin: -1.09375vw auto 3.28125vw;
  }
}
#collaboration .headline .icon img {
  width: 100%;
}
#collaboration .headline .ttl-collaboration {
  text-align: center;
  line-height: 1.35em;
  color: #e46ea1;
  font-size: 31px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 34px;
}
@media only screen and (max-width: 768px) {
  #collaboration .headline .ttl-collaboration {
    font-size: 4.84375vw;
    margin-bottom: 4.84375vw;
  }
}
#collaboration .headline .explain {
  text-align: center;
}
#collaboration .headline .explain p {
  line-height: 1.5em;
  color: #e46ea1;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
  #collaboration .headline .explain p {
    font-size: 3.125vw;
  }
}
#collaboration .headline .explain p:not(:last-of-type) {
  margin-bottom: 0.9em;
}
#collaboration .headline .explain p.note {
  font-size: 12px;
}
@media only screen and (max-width: 768px) {
  #collaboration .headline .explain p.note {
    font-size: 2.1875vw;
  }
}
#collaboration .profile {
  margin-bottom: 77px;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile {
    margin-bottom: 13.90625vw;
  }
}
#collaboration .profile-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 800px;
  background-color: #e46ea1;
  border-radius: 90px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap {
    flex-direction: column;
    width: 87.5vw;
    border-radius: 14.0625vw;
    padding-bottom: 7.8125vw;
  }
}
#collaboration .profile-wrap-photo {
  width: 375px;
  padding: 18px 37px 21px 29px;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap-photo {
    width: 49.375vw;
    padding: 6.40625vw 0 0 0;
    margin-left: 1.71875vw;
  }
}
#collaboration .profile-wrap-photo img {
  width: 100%;
}
#collaboration .profile-wrap-text {
  width: calc(100% - 375px);
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap-text {
    width: 81%;
    margin-top: -0.9375vw;
  }
}
#collaboration .profile-wrap-text .tag {
  position: absolute;
  top: 15px;
  right: -18px;
  width: 303px;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap-text .tag {
    top: -4.84375vw;
    right: -1.71875vw;
    width: 47.34375vw;
  }
}
#collaboration .profile-wrap-text .tag img {
  width: 100%;
}
#collaboration .profile-wrap-text .name {
  width: 361px;
  margin-bottom: 32px;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap-text .name {
    width: 56.40625vw;
    margin-bottom: 3.59375vw;
  }
}
#collaboration .profile-wrap-text .name img {
  width: 100%;
}
#collaboration .profile-wrap-text .txt {
  width: 361px;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap-text .txt {
    width: 100%;
  }
}
#collaboration .profile-wrap-text .txt p {
  line-height: 1.6em;
  color: #fff;
  font-size: 14px;
  letter-spacing: 0.05em;
  font-feature-settings: initial;
}
@media only screen and (max-width: 768px) {
  #collaboration .profile-wrap-text .txt p {
    font-size: 2.8125vw;
  }
}
#collaboration .items .title {
  text-align: center;
  color: #e46ea1;
  line-height: 1.6em;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 50px;
}
@media only screen and (max-width: 768px) {
  #collaboration .items .title {
    font-size: 4.375vw;
    margin-bottom: 8.125vw;
  }
}
#collaboration .items ul.item-list {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list {
    flex-direction: column;
  }
}
#collaboration .items ul.item-list li.ht {
  margin-left: 98px;
  margin-right: 14px;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.ht {
    margin-left: 20.625vw;
    margin-right: auto;
    margin-bottom: 11.5625vw;
  }
}
#collaboration .items ul.item-list li.ht .pkg {
  width: 324px;
  margin-left: 14px;
  margin-bottom: 51px;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.ht .pkg {
    width: 50.625vw;
    margin-left: 2.1875vw;
    margin-bottom: 7.96875vw;
  }
}
#collaboration .items ul.item-list li.ht .eye {
  width: 456px;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.ht .eye {
    width: 72.65625vw;
  }
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.bm {
    margin-left: 20.625vw;
  }
}
#collaboration .items ul.item-list li.bm .pkg {
  position: relative;
  width: 326px;
  margin-left: 14px;
  margin-bottom: 51px;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.bm .pkg {
    width: 50.9375vw;
    margin-left: 2.1875vw;
    margin-bottom: 7.96875vw;
  }
}
#collaboration .items ul.item-list li.bm .pkg .icon {
  position: absolute;
  top: -4px;
  right: -80px;
  width: 130px;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.bm .pkg .icon {
    top: -0.625vw;
    right: -10.46875vw;
    width: 20.3125vw;
  }
}
#collaboration .items ul.item-list li.bm .eye {
  width: 450px;
}
@media only screen and (max-width: 768px) {
  #collaboration .items ul.item-list li.bm .eye {
    width: 72.1875vw;
  }
}
#collaboration .items ul.item-list li img {
  width: 100%;
}
#collaboration .comment {
  margin-top: 50px;
  padding-bottom: 82px;
}
@media only screen and (max-width: 768px) {
  #collaboration .comment {
    margin-top: 10vw;
    padding-bottom: -12.8125vw;
  }
}
#collaboration .comment-wrap {
  position: relative;
  width: 650px;
  background-color: #d7b4c3;
  border-radius: 30px;
  padding: 32px 48px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #collaboration .comment-wrap {
    width: 84.375vw;
    border-radius: 4.6875vw;
    padding: 5.78125vw 7.5vw 6.40625vw;
  }
}
#collaboration .comment-wrap::after {
  position: absolute;
  content: "";
  bottom: -33px;
  left: 394px;
  width: 57px;
  height: 39px;
  clip-path: polygon(21% 0, 0% 100%, 100% 0);
  background-color: #d7b4c3;
}
@media only screen and (max-width: 768px) {
  #collaboration .comment-wrap::after {
    bottom: -5.15625vw;
    left: 52.96875vw;
    width: 8.90625vw;
    height: 6.09375vw;
  }
}
#collaboration .comment-wrap-text p {
  line-height: 1.5em;
  color: #fff;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
  #collaboration .comment-wrap-text p {
    font-size: 3.125vw;
    letter-spacing: 0.05em;
  }
}
#collaboration .comment-wrap-photo {
  position: absolute;
  bottom: -82px;
  left: 50%;
  translate: -50% 0;
  width: 102px;
}
@media only screen and (max-width: 768px) {
  #collaboration .comment-wrap-photo {
    bottom: -12.8125vw;
    width: 15.9375vw;
  }
}
#collaboration .visual {
  position: relative;
  width: 100%;
  overflow: hidden;
}
@media screen and (min-width: 1300px) {
  #collaboration .visual {
    height: 725px;
  }
}
@media only screen and (max-width: 768px) {
  #collaboration .visual {
    height: auto;
  }
}
#collaboration .visual::before, #collaboration .visual::after {
  position: absolute;
  content: "";
  left: 50%;
  translate: -50% 0;
  width: 162.0769230769%;
  aspect-ratio: 2107/486;
  background-color: #f9d3e3;
  border-radius: 50%;
}
@media only screen and (max-width: 768px) {
  #collaboration .visual::before, #collaboration .visual::after {
    width: 149.21875%;
    aspect-ratio: 955/486;
  }
}
#collaboration .visual::before {
  top: calc(100% - 4.0769230769vw);
}
@media only screen and (max-width: 768px) {
  #collaboration .visual::before {
    top: calc(100% - 9.84375vw);
  }
}
#collaboration .visual::after {
  bottom: calc(100% - 4.0769230769vw);
}
@media only screen and (max-width: 768px) {
  #collaboration .visual::after {
    bottom: calc(100% - 9.84375vw);
  }
}
#collaboration .visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#collaboration .heart-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
#collaboration .heart-wrap .heart {
  position: absolute;
}
#collaboration .heart-wrap .heart01 {
  top: 309px;
  right: calc(50% + 259px);
  width: 228px;
}
@media only screen and (max-width: 768px) {
  #collaboration .heart-wrap .heart01 {
    top: 70.78125vw;
    left: -7.1875vw;
    right: auto;
    width: 35.625vw;
  }
}
#collaboration .heart-wrap .heart02 {
  top: 736px;
  left: calc(50% + 370px);
  width: 104px;
}
@media only screen and (max-width: 768px) {
  #collaboration .heart-wrap .heart02 {
    top: 199.53125vw;
    left: 80.46875vw;
    width: 16.09375vw;
  }
}
#collaboration .heart-wrap .heart03 {
  top: 999px;
  right: calc(50% + 376px);
  width: 228px;
}
@media only screen and (max-width: 768px) {
  #collaboration .heart-wrap .heart03 {
    top: 237.65625vw;
    left: 62.8125vw;
    right: auto;
    width: 35.625vw;
  }
}
#collaboration .heart-wrap .heart04 {
  top: 1234px;
  left: calc(50% + 478px);
  width: 228px;
}
@media only screen and (max-width: 768px) {
  #collaboration .heart-wrap .heart04 {
    top: 298.28125vw;
    left: -1.71875vw;
    width: 16.09375vw;
  }
}
#collaboration .heart-wrap .heart05 {
  top: 1393px;
  left: calc(50% + 371px);
  width: 104px;
}
@media only screen and (max-width: 768px) {
  #collaboration .heart-wrap .heart05 {
    top: 432.1875vw;
    left: 61.5625vw;
    width: 35.625vw;
  }
}
#collaboration .heart-wrap .heart img {
  width: 100%;
}

/* recommend
---------------------------------------------------*/
#recommend {
  position: relative;
  z-index: 1;
  /* animate */
}
@media only screen and (max-width: 768px) {
  #recommend::after {
    position: absolute;
    content: "";
    top: calc(100% - 9.84375vw);
    left: 50%;
    translate: -50% 0;
    width: 149.21875%;
    aspect-ratio: 955/486;
    background-color: #fddae0;
    border-radius: 50%;
  }
}
#recommend .inner {
  position: relative;
  width: 96%;
  max-width: 1000px;
  padding: 53px 0 30px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #recommend .inner {
    width: 100%;
    padding: 10vw 0 24.0625vw;
  }
}
#recommend .ttl-recommend {
  text-align: center;
  margin-bottom: 28px;
}
@media only screen and (max-width: 768px) {
  #recommend .ttl-recommend {
    margin-bottom: 3.125vw;
  }
}
#recommend .ttl-recommend img {
  width: 675px;
}
@media only screen and (max-width: 768px) {
  #recommend .ttl-recommend img {
    width: 71.875vw;
  }
}
#recommend .explain {
  text-align: center;
  margin-bottom: 55px;
}
@media only screen and (max-width: 768px) {
  #recommend .explain {
    margin-bottom: 8.59375vw;
  }
}
#recommend .explain p {
  line-height: 1.68em;
  color: #e46ea1;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
  #recommend .explain p {
    font-size: 3.4375vw;
  }
}
#recommend ul.makeup-list {
  display: flex;
  justify-content: center;
  margin-left: -12px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list {
    flex-direction: column;
    margin-left: 0;
  }
}
#recommend ul.makeup-list > li .eye {
  position: relative;
  padding-top: 32px;
  padding-bottom: 48px;
  margin-bottom: 27px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li .eye {
    padding-top: 5vw;
    padding-bottom: 7.34375vw;
    margin-bottom: 4.6875vw;
  }
}
#recommend ul.makeup-list > li .eye-ttl, #recommend ul.makeup-list > li .eye-txt01, #recommend ul.makeup-list > li .eye-txt02 {
  position: absolute;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li .eye-fig img {
    width: 55.15625vw;
  }
}
#recommend ul.makeup-list > li ul.item-list {
  display: flex;
  justify-content: center;
  margin-bottom: 26px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li ul.item-list {
    margin-bottom: 4.0625vw;
  }
}
#recommend ul.makeup-list > li ul.item-list > li a {
  outline: none;
}
#recommend ul.makeup-list > li ul.item-list > li.item01 {
  position: relative;
  margin-right: 50px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li ul.item-list > li.item01 {
    margin-right: 7.5vw;
    margin-bottom: 0;
  }
}
#recommend ul.makeup-list > li ul.item-list > li.item01::after {
  position: absolute;
  content: "";
  top: 38%;
  right: -45px;
  width: 36px;
  aspect-ratio: 1/1;
  background-image: url("../img/icon_cross.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li ul.item-list > li.item01::after {
    right: -7.03125vw;
    width: 5.625vw;
  }
}
#recommend ul.makeup-list > li .tag {
  margin-left: 40px;
  margin-bottom: 8px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li .tag {
    text-align: center;
    margin-left: auto;
    margin-bottom: 1.5625vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li .tag img {
    width: 33.4375vw;
  }
}
#recommend ul.makeup-list > li .name {
  line-height: 1.4em;
  color: #e46ea1;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-left: 40px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li .name {
    text-align: center;
    font-size: 2.5vw;
    margin-left: auto;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr {
    margin-bottom: 8.28125vw;
  }
}
#recommend ul.makeup-list > li.gr .eye {
  width: 371px;
  margin-left: 32px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye {
    width: 57.8125vw;
    margin-left: 22.5vw;
  }
}
#recommend ul.makeup-list > li.gr .eye-ttl {
  top: 0;
  left: 35px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye-ttl {
    left: 5.3125vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye-ttl img {
    width: 44.375vw;
  }
}
#recommend ul.makeup-list > li.gr .eye-txt01 {
  top: 226px;
  left: 81px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye-txt01 {
    top: 35.3125vw;
    left: 12.65625vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye-txt01 img {
    width: 34.375vw;
  }
}
#recommend ul.makeup-list > li.gr .eye-txt02 {
  top: 258px;
  left: 151px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye-txt02 {
    top: 40.3125vw;
    left: 23.59375vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .eye-txt02 img {
    width: 34.375vw;
  }
}
#recommend ul.makeup-list > li.gr .item-list {
  margin-right: 78px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .item-list {
    margin-right: 2.5vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .item-list .item01 img {
    width: 28.59375vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.gr .item-list .item02 img {
    width: 27.5vw;
  }
}
#recommend ul.makeup-list > li.br .eye {
  width: 367px;
  margin-left: 38px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye {
    width: 57.96875vw;
    margin-left: 22.5vw;
  }
}
#recommend ul.makeup-list > li.br .eye-ttl {
  top: 0;
  left: 17px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye-ttl {
    left: 2.65625vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye-ttl img {
    width: 49.53125vw;
  }
}
#recommend ul.makeup-list > li.br .eye-txt01 {
  top: 226px;
  left: 107px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye-txt01 {
    top: 35.3125vw;
    left: 16.71875vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye-txt01 img {
    width: 31.25vw;
  }
}
#recommend ul.makeup-list > li.br .eye-txt02 {
  top: 258px;
  left: 227px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye-txt02 {
    top: 40.3125vw;
    left: 35.46875vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .eye-txt02 img {
    width: 21.875vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .item-list {
    margin-right: 2.8125vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .item-list .item01 img {
    width: 29.21875vw;
  }
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .item-list .item02 img {
    width: 28.28125vw;
  }
}
#recommend ul.makeup-list > li.br .tag,
#recommend ul.makeup-list > li.br .name {
  margin-left: 52px;
}
@media only screen and (max-width: 768px) {
  #recommend ul.makeup-list > li.br .tag,
  #recommend ul.makeup-list > li.br .name {
    margin-left: auto;
  }
}
#recommend ul.makeup-list > li .eye .eye-ttl,
#recommend ul.makeup-list > li .eye .eye-txt01,
#recommend ul.makeup-list > li .eye .eye-txt02 {
  opacity: 0;
  translate: -20% 0;
  transition: opacity 0.5s, translate 0.5s;
}
#recommend ul.makeup-list > li .eye .eye-ttl {
  transition-delay: 0.2s;
}
#recommend ul.makeup-list > li .eye .eye-txt01 {
  transition-delay: 0.4s;
}
#recommend ul.makeup-list > li .eye .eye-txt02 {
  transition-delay: 0.5s;
}
#recommend ul.makeup-list > li .eye.did .eye-ttl,
#recommend ul.makeup-list > li .eye.did .eye-txt01,
#recommend ul.makeup-list > li .eye.did .eye-txt02 {
  opacity: 1;
  translate: 0 0;
}
#recommend .deco-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  #recommend .deco-wrap {
    display: none;
  }
}
#recommend .deco-wrap .deco {
  position: absolute;
}
#recommend .deco-wrap .deco01 {
  top: 180px;
  left: calc(50% + 440px);
  width: 65px;
}
#recommend .deco-wrap .deco02 {
  top: 514px;
  right: calc(50% + 486px);
  width: 65px;
}
#recommend .deco-wrap .deco img {
  width: 100%;
}

/* spec
---------------------------------------------------*/
#spec {
  position: relative;
  background-color: #fddae0;
  z-index: 1;
}
#spec .inner {
  position: relative;
  width: 96%;
  padding: 184px 0 122px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #spec .inner {
    padding: 14.21875vw 0 12.1875vw;
  }
}
#spec .ttl-spec {
  text-align: center;
  margin-bottom: 32px;
}
@media only screen and (max-width: 768px) {
  #spec .ttl-spec {
    margin-bottom: 0;
  }
}
#spec .ttl-spec img {
  width: 847px;
}
@media only screen and (max-width: 768px) {
  #spec .ttl-spec img {
    width: 80.9375vw;
  }
}

/* products-alm
---------------------------------------------------*/
#products-alm {
  position: relative;
  background-color: #fff;
  overflow: hidden;
  z-index: 1;
}
#products-alm::after {
  position: absolute;
  content: "";
  bottom: calc(100% - 4vw);
  left: 50%;
  translate: -50% 0;
  width: 162.0769230769%;
  aspect-ratio: 2107/486;
  background-color: #fddae0;
  border-radius: 50%;
}
@media only screen and (max-width: 768px) {
  #products-alm::after {
    bottom: calc(100% - 9.84375vw);
    width: 149.21875%;
    aspect-ratio: 955/486;
  }
}
#products-alm .inner {
  position: relative;
  width: 96%;
  padding: 158px 0 102px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #products-alm .inner {
    padding: 24.6875vw 0 13.125vw;
  }
}
#products-alm ul.list-products {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 88px;
  width: 96%;
  margin: 0 auto 30px;
}
@media only screen and (max-width: 768px) {
  #products-alm ul.list-products {
    align-items: center;
    flex-direction: column;
    gap: 5.9375vw;
    width: 100%;
    margin: 0 auto 6.25vw;
  }
}
#products-alm ul.list-products li {
  text-align: center;
}
@media only screen and (max-width: 768px) {
  #products-alm ul.list-products li {
    width: 36.25vw;
  }
}
#products-alm ul.list-products li .figure {
  width: 100%;
}
#products-alm ul.list-products li .figure img {
  width: 100%;
}
#products-alm ul.list-products li .color {
  line-height: 1.75em;
  color: #e46ea1;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-top: 21px;
}
@media only screen and (max-width: 768px) {
  #products-alm ul.list-products li .color {
    font-size: 3.75vw;
    margin-top: 3.28125vw;
  }
}
#products-alm ul.list-products li.ht {
  width: 324px;
}
@media only screen and (max-width: 768px) {
  #products-alm ul.list-products li.ht {
    width: 50.625vw;
  }
}
#products-alm ul.list-products li.bm {
  width: 326px;
}
@media only screen and (max-width: 768px) {
  #products-alm ul.list-products li.bm {
    width: 50.9375vw;
  }
}
#products-alm .name {
  text-align: center;
  line-height: 1.5em;
  color: #e46ea1;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
@media only screen and (max-width: 768px) {
  #products-alm .name {
    font-size: 3.125vw;
    margin-bottom: 1.5625vw;
  }
}
#products-alm .price {
  text-align: center;
  line-height: 1.5em;
  color: #e46ea1;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
}
@media only screen and (max-width: 768px) {
  #products-alm .price {
    font-size: 2.8125vw;
    margin-bottom: 5.3125vw;
  }
}
#products-alm .price sub {
  bottom: 0;
  font-size: 0.8em;
}

/* products-dl
---------------------------------------------------*/
#products-dl {
  position: relative;
  background: #F1D4E2;
  background: linear-gradient(180deg, rgb(241, 212, 226) 8%, rgb(243, 243, 243) 100%);
}
#products-dl .inner {
  position: relative;
  width: 96%;
  padding: 98px 0 120px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #products-dl .inner {
    width: 100%;
    padding: 15.3125vw 0 120px;
  }
}
#products-dl .ttl-products {
  text-align: center;
  margin-bottom: 60px;
}
@media only screen and (max-width: 768px) {
  #products-dl .ttl-products {
    margin-bottom: 9.6875vw;
  }
}
#products-dl .ttl-products img {
  width: 385px;
}
@media only screen and (max-width: 768px) {
  #products-dl .ttl-products img {
    width: 60.15625vw;
  }
}
#products-dl ul.list-products {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 110px;
  width: 96%;
  margin: 0 auto 30px;
}
@media only screen and (max-width: 768px) {
  #products-dl ul.list-products {
    gap: 6.5625vw;
    width: 100%;
    margin: 0 auto 4.6875vw;
  }
}
#products-dl ul.list-products li {
  text-align: center;
}
@media only screen and (max-width: 768px) {
  #products-dl ul.list-products li {
    width: 36.25vw;
  }
}
#products-dl ul.list-products li .figure {
  width: 100%;
}
#products-dl ul.list-products li .figure img {
  width: 143px;
}
@media only screen and (max-width: 768px) {
  #products-dl ul.list-products li .figure img {
    width: 22.34375vw;
  }
}
#products-dl ul.list-products li .color {
  line-height: 1.75em;
  color: #e46ea1;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-top: 21px;
}
@media only screen and (max-width: 768px) {
  #products-dl ul.list-products li .color {
    font-size: 3.75vw;
    margin-top: 3.28125vw;
  }
}
#products-dl .name {
  text-align: center;
  line-height: 1.5em;
  color: #e46ea1;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
@media only screen and (max-width: 768px) {
  #products-dl .name {
    font-size: 3.125vw;
    margin-bottom: 1.5625vw;
  }
}
#products-dl .price {
  text-align: center;
  line-height: 1.5em;
  color: #e46ea1;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
}
@media only screen and (max-width: 768px) {
  #products-dl .price {
    font-size: 3.125vw;
    margin-bottom: 5.3125vw;
  }
}
#products-dl .btn_cart a {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 22px;
  font-weight: 400;
  text-indent: 1em;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
  #products-dl .btn_cart a {
    font-size: 3.4375vw;
  }
}
#products-dl .btn_cart a span:before {
  left: -1.5em;
  width: 19px;
  height: 19px;
  background-image: url(../img/icon_blank.png);
}
@media only screen and (max-width: 768px) {
  #products-dl .btn_cart a span:before {
    width: 2.96875vw;
    height: 2.96875vw;
  }
}
#products-dl .btn_cart:hover a span:before {
  background-image: url(../img/icon_blank_on.png);
}

/* spec-type-block
---------------------------------------------------*/
.spec-type-block {
  position: relative;
  width: 96%;
  max-width: 1100px;
  background-color: #fff;
  border-radius: 20px;
  padding: 60px 50px 54px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .spec-type-block {
    width: 93.75vw;
    border-radius: 3.125vw;
    padding: 9.375vw 5.46875vw;
    margin-top: 5.3125vw;
  }
}
.spec-type-block-inner {
  position: relative;
  margin-bottom: 30px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-inner {
    margin-bottom: 6.5625vw;
  }
}
.spec-type-block-inner .title {
  line-height: 1.4em;
  text-align: center;
  color: #e46ea1;
  font-size: 34px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-bottom: 34px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-inner .title {
    line-height: 1.4em;
    font-size: 5.3125vw;
    margin-bottom: 4.21875vw;
  }
}
.spec-type-block-inner .img {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-inner .img {
    width: 108.4375vw;
    max-width: none;
  }
}
.spec-type-block-inner .img img {
  width: 100%;
}
.spec-type-block .function {
  text-align: center;
}
.spec-type-block .function img {
  max-width: 766px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .function img {
    width: 77.8125vw;
  }
}
.spec-type-block .scroll-wrapper {
  position: relative;
}
.spec-type-block .scroll-wrapper .icon {
  position: absolute;
  top: -54px;
  left: 60px;
  width: 142px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scroll-wrapper .icon {
    top: -8.59375vw;
    left: -2.8125vw;
    width: 22.1875vw;
  }
}
.spec-type-block .scroll-wrapper .icon img {
  width: 100%;
}
.spec-type-block .cover {
  position: relative;
  overflow: hidden;
}
.spec-type-block .cover:after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30px;
  background-color: transparent;
  z-index: 99;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .cover:after {
    height: 4.6875vw;
  }
}
.spec-type-block .scrollable {
  overflow: hidden;
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
  -webkit-appearance: none;
  padding-bottom: 0;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scrollable {
    padding-bottom: 4.6875vw;
  }
}
.spec-type-block .scrollable::-webkit-scrollbar {
  display: none;
  -webkit-appearance: none;
}
.spec-type-block .scrollbar {
  display: none;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scrollbar {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background-color: #ddd;
  }
}
.spec-type-block .scrollbar-thumb {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  width: 30px;
  aspect-ratio: 1/1;
  background-color: #ddd;
  border-radius: 50%;
  -webkit-border-radius: 50%;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scrollbar-thumb {
    width: 4.6875vw;
  }
}

/* modal-movie
---------------------------------------------------*/
.modal-movie {
  position: relative;
  padding: 0 62px;
}
@media only screen and (max-width: 768px) {
  .modal-movie {
    padding: 8.75vw 0 0 0;
  }
}
.modal-movie::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 36px;
  aspect-ratio: 1/1;
  background-image: url("../img/icon_close.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
@media only screen and (max-width: 768px) {
  .modal-movie::after {
    width: 5.625vw;
  }
}
.modal-movie video {
  width: 400px;
  pointer-events: auto;
}
@media only screen and (max-width: 768px) {
  .modal-movie video {
    width: 84.375vw;
  }
}

#colorbox {
  pointer-events: none;
}

#cboxLoadingOverlay {
  background: rgba(0, 0, 0, 0.9);
}

#cboxOverlay {
  background: #000;
  opacity: 0.7;
  filter: alpha(opacity=70);
}

#cboxContent {
  margin-top: 0;
  overflow: visible;
  background: transparent;
}

#cboxLoadedContent {
  background: transparent;
  padding: 0;
}

/* animated
---------------------------------------------------*/
.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}
.animated.delay-1s {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}
.animated.delay-2s {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
}
.animated.delay-3s {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}
.animated.delay-4s {
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}
.animated.delay-5s {
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
}
.animated.fast {
  -webkit-animation-duration: 800ms;
  animation-duration: 800ms;
}
.animated.faster {
  -webkit-animation-duration: 500ms;
  animation-duration: 500ms;
}
.animated.slow {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}
.animated.slower {
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
}

@media (print), (prefers-reduced-motion: reduce) {
  .animated {
    -webkit-animation-duration: 1ms !important;
    animation-duration: 1ms !important;
    -webkit-transition-duration: 1ms !important;
    transition-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
  }
}
@keyframes swing {
  20% {
    transform: rotate3d(0, 0, 1, 15deg);
  }
  40% {
    transform: rotate3d(0, 0, 1, -10deg);
  }
  60% {
    transform: rotate3d(0, 0, 1, 5deg);
  }
  80% {
    transform: rotate3d(0, 0, 1, -5deg);
  }
  to {
    transform: rotate3d(0, 0, 1, 0deg);
  }
}
@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.25, 0.85, 0.35, 1);
    animation-timing-function: cubic-bezier(0.25, 0.85, 0.35, 1);
  }
  from {
    opacity: 0;
    transform: translate3d(0, 50%, 0) scaleY(1.6);
  }
  50% {
    opacity: 1;
    transform: translate3d(0, -20px, 0) scaleY(0.9);
  }
  75% {
    transform: translate3d(0, 10px, 0) scaleY(0.95);
  }
  90% {
    transform: translate3d(0, -5px, 0) scaleY(0.985);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}

/*# sourceMappingURL=main.css.map */
