@charset "UTF-8";
.cont__center {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.cont__center > * {
  min-height: 0%;
}

.cont__container {
  box-sizing: content-box !important;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .cont__container {
    max-width: 89.3333333333vw;
  }
}

.modal__close, .artists__box, .link {
  color: inherit;
  transition: opacity 0.3s;
  cursor: pointer;
}
.modal__close:hover, .artists__box:hover, .link:hover {
  opacity: 0.7;
}

/* common:start */
[v-cloak] {
  display: none;
}

@media screen and (max-width: 767px) {
  .pcOnly {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .spOnly {
    display: none !important;
  }
}

html.is-fixed {
  overflow: hidden;
}

body {
  min-width: auto;
}

.cont picture {
  display: block;
}
.cont img {
  pointer-events: none;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .cont img {
    width: 100%;
  }
}
.cont p,
.cont h1,
.cont h2,
.cont h3,
.cont h4,
.cont h5,
.cont h6,
.cont a,
.cont li,
.cont caption,
.cont td,
.cont th,
.cont dt,
.cont dd,
.cont input,
.cont textarea,
.cont select,
.cont address {
  font-family: "Zen Kaku Gothic New", sans-serif !important;
}
.cont *:focus-visible {
  outline: -webkit-focus-ring-color auto 1px;
}

/* common:end */
/* js-fade:start */
:root {
  --fade-translate-x: 0px;
  --fade-translate-y: 0px;
  --fade-duration: 500ms;
}

/* 表示方向 */
.up {
  --fade-translate-y: 50px;
}

.down {
  --fade-translate-y: -50px;
}

.fromLeft {
  --fade-translate-x: -50px;
}

.fromRight {
  --fade-translate-x: 50px;
}

.jsScroll {
  opacity: 0;
  transition-duration: 500ms;
  transition-property: opacity, transform;
  transition-delay: 0ms;
  transform: translate(var(--fade-translate-x), var(--fade-translate-y));
}

.jsScrollIn {
  opacity: 1;
  transform: translate(0, 0);
}

.jsFvHide {
  opacity: 0;
  transition-duration: 0.5s;
  transition-property: opacity, transform;
  transition-delay: 0s;
}
.jsFvHide.jsFvShow {
  opacity: 1;
}

.fade-enter-active {
  transition: opacity 1s;
}
.fade-leave-active {
  transition: opacity 1s;
}
.fade-enter, .fade-leave-to {
  opacity: 0;
}

/* js-fade:end */
/* kv:start */
.kv {
  background-color: #3c1d1a;
}
@media screen and (max-width: 767px) {
  .kv__container {
    max-width: 100%;
  }
}

/* kv:end */
/* lead:start */
.lead {
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/cont_bg.jpg);
  background-repeat: repeat-y;
  background-size: 100%;
  text-align: center;
}
.lead__container {
  padding: 100px 20px 380px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .lead__container {
    padding: 17.4626865672% 0 67.1641791045%;
  }
}
.lead__container::before {
  content: "";
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/lead_img_chocolate.png);
  background-repeat: no-repeat;
  background-size: 100%;
  width: 237px;
  height: 107px;
  position: absolute;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .lead__container::before {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/lead_img_chocolate.png);
    width: 40.5333333333vw;
    height: 18.2666666667vw;
    bottom: 16vw;
  }
}
.lead__container::after {
  content: "";
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/lead_img_onpu.png);
  background-repeat: no-repeat;
  background-size: 100%;
  width: 159px;
  height: 103px;
  visibility: unset;
  animation: floatY 2.5s ease-in-out infinite;
  position: absolute;
  bottom: 218px;
  left: calc(50% + 82px);
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .lead__container::after {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/lead_img_onpu.png);
    width: 26vw;
    height: 16.9333333333vw;
    animation: floatYsp 2.5s ease-in-out infinite;
    bottom: 36.4vw;
    left: calc(50% + 22vw);
  }
}
@keyframes floatY {
  0% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(-15px);
  }
  100% {
    transform: translateX(-50%) translateY(0);
  }
}
@keyframes floatYsp {
  0% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(-10px);
  }
  100% {
    transform: translateX(-50%) translateY(0);
  }
}

/* lead:end */
.artists__container--top, .artists__container {
  background-repeat: repeat-y;
  background-size: 100%;
  text-align: center;
}

.artists__box--coming-soon, .artists__box {
  width: 45.9677419355%;
  max-width: 570px;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-size: cover;
  background-color: unset;
  border: none;
  position: relative;
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon, .artists__box {
    width: 100%;
    max-width: 100%;
    margin-top: 14.9253731343%;
  }
}
.artists__box--coming-soon::before, .artists__box::before {
  content: "";
  background-color: #c2a160;
  border-radius: 2px;
  width: 94.7368421053%;
  height: 4px;
  position: absolute;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 1240px) {
  .artists__box--coming-soon::before, .artists__box::before {
    height: 0.3225806452vw;
    top: 1.2903225806vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon::before, .artists__box::before {
    border-radius: 0.2666666667vw;
    width: 94.0298507463%;
    height: 0.5333333333vw;
    top: 2.1333333333vw;
  }
}
.artists__box--coming-soon:nth-child(odd), .artists__box:nth-child(odd) {
  margin: 0 auto 0 20px;
}
@media screen and (max-width: 1240px) {
  .artists__box--coming-soon:nth-child(odd), .artists__box:nth-child(odd) {
    margin: 0 auto 0 1.6129032258vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon:not(:first-child):nth-child(odd), .artists__box:not(:first-child):nth-child(odd) {
    margin: 14.9253731343% 0 0 0;
  }
}
.artists__box--coming-soon:nth-child(even), .artists__box:nth-child(even) {
  margin: 150px 20px 0 auto;
}
@media screen and (max-width: 1240px) {
  .artists__box--coming-soon:nth-child(even), .artists__box:nth-child(even) {
    margin: 12.0967741935vw 1.6129032258vw 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon:nth-child(even), .artists__box:nth-child(even) {
    margin: 14.9253731343% 0 0 0;
  }
}
.artists__box--coming-soon:nth-child(2), .artists__box:nth-child(2) {
  margin-top: 388px;
}
@media screen and (max-width: 1240px) {
  .artists__box--coming-soon:nth-child(2), .artists__box:nth-child(2) {
    margin-top: 31.2903225806vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon:nth-child(2), .artists__box:nth-child(2) {
    margin-top: 14.9253731343%;
  }
}

/* artists:start */
.artists__container {
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/cont_bg.jpg);
  padding: 100px 0 140px;
}
@media screen and (max-width: 767px) {
  .artists__container {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/cont_bg.jpg);
    padding: 16vw 0 21.3333333333vw;
  }
}
.artists__container--top {
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/cont_bg_brown.jpg);
  padding: 100px 0;
}
@media screen and (max-width: 767px) {
  .artists__container--top {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/cont_bg_brown.jpg);
    padding: 16vw 0;
  }
}
.artists__container--top .artists__box {
  margin: 0;
}
.artists__boxes {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .artists__boxes {
    display: block;
    margin-top: 11.9402985075%;
  }
}
.artists__box {
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/artists_bg_large.png);
  padding: 4.6774193548% 0 1.2903225806%;
}
@media screen and (max-width: 767px) {
  .artists__box {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/artists_bg_large.png);
    padding: 9.7014925373% 0 2.9850746269%;
  }
}
@media screen and (max-width: 767px) {
  .artists__box:first-child {
    margin: 0;
  }
}
.artists__box--coming-soon {
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/artists_bg_small.png);
  padding: 8.5483870968% 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/artists_bg_small.png);
    padding: 18.3582089552% 0;
  }
}
.artists__box--coming-soon::after {
  content: "";
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/artists_img_gosenfu.png);
  background-size: 100%;
  width: 94.7368421053%;
  height: 21px;
  visibility: unset;
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 1240px) {
  .artists__box--coming-soon::after {
    height: 1.6935483871vw;
    bottom: 1.2903225806vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box--coming-soon::after {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/artists_img_gosenfu.png);
    width: 94.0298507463%;
    height: 4vw;
    bottom: 2.1333333333vw;
  }
}
.artists__box-onpu-01 {
  width: 46.3157894737%;
  animation: floatY 2.3s ease-in-out infinite;
  position: absolute;
  top: -153px;
  right: 20px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-01 {
    top: -12.3387096774vw;
    right: 1.6129032258vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-01 {
    width: 30.8955223881%;
    top: -12vw;
    right: 2.6666666667vw;
  }
}
.artists__box-onpu-02 {
  width: 41.9298245614%;
  animation: floatYsecond 2.8s ease-in-out infinite;
  position: absolute;
  top: -115px;
  left: -20px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-02 {
    top: -9.2741935484vw;
    left: -1.6129032258vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-02 {
    width: 28.0597014925%;
    top: -10.6666666667vw;
    left: -5.3333333333vw;
  }
}
.artists__box-onpu-03 {
  width: 48.0701754386%;
  animation: floatY 2.5s ease-in-out infinite;
  position: absolute;
  bottom: -111px;
  right: -20px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-03 {
    bottom: -8.9516129032vw;
    right: -1.6129032258vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-03 {
    width: 32.0895522388%;
    bottom: -10.9333333333vw;
    right: -5.3333333333vw;
  }
}
.artists__box-onpu-04 {
  width: 48.2456140351%;
  animation: floatY 2.3s ease-in-out infinite;
  position: absolute;
  top: -120px;
  left: 40px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-04 {
    top: -9.6774193548vw;
    left: 3.2258064516vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-04 {
    width: 32.0895522388%;
    top: -10.6666666667vw;
    left: 4vw;
  }
}
.artists__box-onpu-05 {
  width: 42.2807017544%;
  animation: floatYsecond 2.8s ease-in-out infinite;
  position: absolute;
  bottom: -128px;
  right: 40px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-05 {
    bottom: -10.3225806452vw;
    right: 3.2258064516vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-05 {
    width: 28.0597014925%;
    bottom: -11.6vw;
    right: 9.3333333333vw;
  }
}
.artists__box-onpu-06 {
  width: 41.9298245614%;
  animation: floatY 2.5s ease-in-out infinite;
  position: absolute;
  bottom: -101px;
  left: 30px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-06 {
    bottom: -8.1451612903vw;
    left: 2.4193548387vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-06 {
    width: 28.0597014925%;
    bottom: -9.3333333333vw;
    left: 6.6666666667vw;
  }
}
.artists__box-onpu-07 {
  width: 48.0701754386%;
  animation: floatYsecond 2.3s ease-in-out infinite;
  position: absolute;
  bottom: -121px;
  right: -20px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-07 {
    bottom: -9.7580645161vw;
    right: -1.6129032258vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-07 {
    width: 32.0895522388%;
    bottom: -12vw;
    right: -5.3333333333vw;
  }
}
.artists__box-onpu-08 {
  width: 48.0701754386%;
  animation: floatY 2.8s ease-in-out infinite;
  position: absolute;
  bottom: -132px;
  left: -20px;
}
@media screen and (max-width: 1240px) {
  .artists__box-onpu-08 {
    bottom: -10.6451612903vw;
    left: -1.6129032258vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-onpu-08 {
    width: 32.0895522388%;
    bottom: -14.6666666667vw;
    left: -5.3333333333vw;
  }
}
.artists__box-number {
  width: 20.350877193%;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .artists__box-number {
    width: 20.8955223881%;
  }
}
.artists__box-img {
  width: 85.9649122807%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .artists__box-img {
    width: 82.0895522388%;
  }
}
.artists__box-name {
  width: 126px;
  margin: 48px 0 45px 44px;
}
@media screen and (max-width: 1240px) {
  .artists__box-name {
    width: 10.1612903226vw;
    margin: 3.8709677419vw 0 3.6290322581vw 3.5483870968vw;
  }
}
@media screen and (max-width: 767px) {
  .artists__box-name {
    width: 23.5820895522%;
    margin: 7.4626865672% 0 7.1641791045% 8.9552238806%;
    height: 4.9333333333vw;
  }
}
.artists__box-txt {
  width: 27.5438596491%;
  position: absolute;
  bottom: 60px;
  right: 45px;
}
@media screen and (max-width: 767px) {
  .artists__box-txt {
    width: 26.1194029851%;
    bottom: 10.1333333333vw;
    right: 8.5333333333vw;
  }
}
.artists__box-txt-coming-soon {
  width: 61.0526315789%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .artists__box-txt-coming-soon {
    width: 64.776119403%;
  }
}
.artists__box-click {
  width: 94.7368421053%;
  margin: 6.6666666667% auto 0;
}
@media screen and (max-width: 767px) {
  .artists__box-click {
    width: 94.0298507463%;
    height: 6.1333333333vw;
    margin-top: 7.4626865672%;
  }
}
.artists__ttl {
  text-align: center;
}
.artists__ttl-top {
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .artists__ttl-top {
    height: 7.3333333333vw;
    margin-bottom: 11.9402985075%;
  }
}
@keyframes floatY {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes floatYsecond {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(15px);
  }
  100% {
    transform: translateY(0);
  }
}

/* artists:end */
/* modal:start */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 999;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  pointer-events: none;
}
.modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.modal.is-open__inner {
  transform: scale(1);
}
.modal__inner {
  background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/cont_bg.jpg);
  background-repeat: no-repeat;
  padding: 60px;
  margin: 0 20px;
  max-width: 920px;
  max-height: 90%;
  overflow-y: scroll;
  box-sizing: border-box;
  position: relative;
  outline: none;
  transition: transform 0.3s ease;
}
@media screen and (max-width: 767px) {
  .modal__inner {
    background-image: url(/products/brand/mchoco/anniversary/melodyofmeiji/images/sp/cont_bg.jpg);
    background-size: 100%;
    padding: 13.6vw 4vw 13.3333333333vw;
    margin: 0 auto;
    max-width: 89.3333333333vw;
  }
}
.modal__close {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  position: absolute;
  top: 20px;
  right: 20px;
}
@media screen and (max-width: 960px) {
  .modal__close {
    width: 4.375vw;
    height: 4.375vw;
    top: 2.0833333333vw;
    right: 2.0833333333vw;
  }
}
@media screen and (max-width: 767px) {
  .modal__close {
    width: 5.6vw;
    height: 5.6vw;
    top: 4vw;
    right: 4vw;
  }
}
.modal__movie {
  max-width: 676px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .modal__movie {
    max-width: 100%;
  }
}
.modal__txt {
  margin-top: 8.75%;
}
@media screen and (max-width: 767px) {
  .modal__txt {
    margin-top: 11.8032786885%;
    height: 7.3333333333vw;
  }
}
.modal__contents {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-top: 4.25%;
}
@media screen and (max-width: 767px) {
  .modal__contents {
    display: block;
    margin-top: 8.1967213115%;
  }
}
.modal__contents-img {
  width: 52.5%;
  margin-top: 0.25%;
}
@media screen and (max-width: 767px) {
  .modal__contents-img {
    width: 90.1639344262%;
    margin: 0 auto;
  }
}
.modal__contents-inner {
  width: 43.75%;
}
@media screen and (max-width: 767px) {
  .modal__contents-inner {
    width: 90.1639344262%;
    margin: 9.8360655738% auto 0;
  }
}
.modal__contents-hdg-inner {
  background-color: #3c1d1a;
  display: inline-block;
  padding: 0 2.8571428571%;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: #fbf5e8;
}
@media screen and (max-width: 960px) {
  .modal__contents-hdg-inner {
    font-size: 2.0833333333vw;
  }
}
@media screen and (max-width: 767px) {
  .modal__contents-hdg-inner {
    padding: 0 2.7272727273%;
    font-size: 3.7333333333vw;
    line-height: 1.5714285714;
  }
}
.modal__contents-hdg-inner:last-child {
  margin-top: 2%;
}
@media screen and (max-width: 767px) {
  .modal__contents-hdg-inner:last-child {
    margin-top: 1.8181818182%;
  }
}
.modal__contents-txt {
  margin-top: 6.2857142857%;
  font-size: 16px;
  font-weight: 500 !important;
  line-height: 1.75;
  letter-spacing: 0.04em;
  color: #351f19;
}
@media screen and (max-width: 767px) {
  .modal__contents-txt {
    margin: 3.6363636364% 0 -1.4545454545%;
    font-size: 3.2vw;
    line-height: 1.6666666667;
  }
}

/* modal:end */