@charset "UTF-8";
.lp-sparkling {
  background-color: #f5f7f8;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
}
@media (min-width: 768px) {
  .lp-sparkling {
    max-width: 2000px;
    min-width: 1280px;
    margin: 0 auto;
  }
}

.l-wrapper {
  padding-top: 15.3846vw;
}
@media screen and (min-width: 768px) {
  .l-wrapper {
    padding-top: 11.0677vw;
  }
}
@media screen and (min-width: 1024px) {
  .l-wrapper {
    padding-top: 83px;
  }
}

.c-container {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.c-container.-padding {
  padding-left: 5.3333333333vw;
  padding-right: 5.3333333333vw;
}
@media (max-width: 767px) {
  .c-container.-padding-sp-0 {
    padding-left: 0;
    padding-right: 0;
  }
}
@media (min-width: 768px) {
  .c-container.-padding, .c-container.-padding-pc {
    padding-left: 152px;
    padding-right: 152px;
    width: 1280px;
  }
}

.c-sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4vw;
  margin-top: 40px;
}
@media (min-width: 768px) {
  .c-sns {
    gap: 20px;
  }
}
.c-sns-facebook {
  width: 7.4666666667vw;
}
.c-sns-facebook .icon {
  fill: #fff;
}
@media (min-width: 768px) {
  .c-sns-facebook {
    width: 35px;
  }
}
.c-sns-x {
  width: 6.9333333333vw;
}
.c-sns-x .icon {
  fill: #fff;
}
@media (min-width: 768px) {
  .c-sns-x {
    width: 33px;
  }
}
.c-sns-instagram {
  width: 7.4666666667vw;
}
.c-sns-instagram .icon {
  fill: #fff;
}
@media (min-width: 768px) {
  .c-sns-instagram {
    width: 35px;
  }
}

.p-mv {
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.p-mv-bg {
  width: 100%;
  /* object-position: 50%; */
  /* object-fit: contain; */
  /* object-fit: cover; */
  /* height: auto; */
  /* height: calc(100vh - 15.3846vw - 14.666666666vw);
  height: calc(100svh - 15.3846vw - 14.666666666vw); */
  height: calc(490 / 375 * 100vw);
  /* background-image: url(../img/mv_sp.png);
  background-size: cover;
  background-position: center; */
  position: relative;
}
@media (min-width: 768px) {
  .p-mv-bg {
    /* object-fit: cover; */
    width: 100%;
    height: 695px;
    /* height: calc(100vh - 84px - 55px); */
    /* background-image: url(../img/mv_pc.png); */
    /* background-image: none;  */
    
  }
}

@media (max-width: 767px) {
  .p-mv-bg {
  position: relative;
  }

  .p-mv-bg::before {
    content: "";
    background-image: url(../img/mv_sp.jpg?20250614);
    background-size: cover;
    background-position: center;
    position: absolute;
    top: -1px;
    right: 0;
    bottom: -2px;
    left: 0;
    animation: moveMVBG 30s ease-in-out infinite;
  }

  .p-mv-bg::after {
    content: "";
    /* width: 100%;
    height: 100%; */
    background-color: #000018;
    opacity: 0.3;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    pointer-events: none;
  }
}

@keyframes moveMVBG {
  0% {
      background-position: 0% 0%;
  }

  50% {
      background-position: 100% 100%;
  }
  100% {
      background-position: 0% 0%;
  }
}

.p-mv-title {
  /* padding-top: 26vw;
  margin-left: 4.8vw; */
  position: absolute;
  top: calc(-16 / 375 * 100vw);
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: fit-content;
  height: fit-content;
      z-index: 1;
}
.p-mv-title img {
  width: 71.733333333vw;
}
@media (min-width: 768px) {
  .p-mv-title {
    top: 0;
    /* padding-top: 37px;
    padding-right: 15px;
    margin: 0 auto; */
  }
  .p-mv-title img {
    width: 595px;
  }
}

.p-mv-copy01 {
  /* padding-top: 26vw;
  margin-left: 4.8vw; */
  height: fit-content;
  /* position: absolute;
  top: 16vw;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto; */
      position: absolute;
    top: 9vw;
    right: 0;
    left: 0;
    margin: auto;
      z-index: 1;
}
.p-mv-copy01 img {
  width: 57.066666666vw;
  display: block;
  margin: auto;
}
@media (min-width: 768px) {
  .p-mv-copy01 {
    position: absolute;
    top: 0;
    /* right: 67px; */
            right: calc(50% - 590px);
    bottom: 0;
    left: initial;
    /* margin: auto; */
    /* left: 0; */
  }
  .p-mv-copy01 img {
    width: 30px;
  }
}

.p-mv-copy02 {
  height: fit-content;
  /* padding-top: 26vw;
  margin-left: 4.8vw; */
  position: absolute;
  right: 0;
  bottom: 11vw;
  left: 0;
  margin: auto;
      z-index: 1;
}
.p-mv-copy02 img {
  width: 64vw;
  display: block;
  margin: auto;
}
@media (min-width: 768px) {
  .p-mv-copy02 {
    /* position: absolute; */
    top: 0;
    /* left: 43px; */
    left: calc(50% - 630px);
    right: initial;
    bottom: 0;
    /* margin: auto; */
  }
  .p-mv-copy02 img {
    width: 81px;
  }
}

.p-mv-date {
  /* text-align: center; */
  /* margin-top: -1.3333333333vw;
  padding-bottom: 9.8666666667vw; */
    position: absolute;
  /* top: 0; */
  right: 0;
  bottom: 5vw;
  left: 0;
  margin: auto;
  width: fit-content;
  height: fit-content;
      z-index: 1;
}
.p-mv-date img {
  width: 46.933333333vw;
}
@media (min-width: 768px) {
  .p-mv-date {
    /* margin-top: 0;
    margin-left: -10px;
    padding-bottom: 42px; */
      bottom: 125px;
  }
  .p-mv-date img {
    width: 353px;
  }
}

.p-mv-bg02 {
  position: absolute;
  z-index: 1;
  top: calc(-16 / 375 * 100vw);
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 93.6vw;
  height: fit-content;
  mix-blend-mode: lighten;
}

.p-mv-bg02-before {
  position: absolute;
  z-index: 1;
  top: calc(-16 / 375 * 100vw);
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 93.6vw;
  height: fit-content;
}

.p-mv-video {
  /* position: absolute;
  top: 84px;
  max-height: 695px;
  width: max-content;
      left: 50%;
    transform: translateX(-50%); */
    position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
  margin: auto;
	overflow: hidden;
  /* max-height: 695px; */
}

.p-mv-video video {
position: absolute;
	top: 50%;
	left: 50%;
	object-fit: cover;
	transform: translate(-50%, -50%);
	width: 100%;
	height: 100%;
}

.p-purchase {
  background: #00ae91;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  width: 100%;
  height: 14.666666666vw;
  position: relative;
  max-width: 2000px;
  z-index: 1;
}
@media (min-width: 768px) {
  .p-purchase {
    height: 55px;
  }
}
.p-purchase::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -1px;
  bottom: 0;
  background: #000040;
  -webkit-transition: 500ms ease;
  transition: 500ms ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
}

@media (min-width: 768px) {
  .p-purchase:hover::after {
    opacity: 0;
  }
  .p-purchase:hover .p-purchase-inner {
    color: #fff;
  }
}
.p-purchase-inner {
  color: #fff;
  /* font-family: "Noto Sans JP", sans-serif; */
  font-size: 3.7333333333vw;
  letter-spacing: 0.175em;
  z-index: 1;
  line-height: calc(17 / 14);
  /* font-weight: 500; */
}
@media (min-width: 768px) {
  .p-purchase-inner {
    font-size: 18px;
    letter-spacing: 0.16em;
  }
}

@media (max-width: 767px) {
  .p-purchase-small {
    font-size: 2.986666666vw;
  }
}

.p-purchase.fixed {
  position: fixed;
  top: 0;
  z-index: 10;
}

.p-lead-container {
  position: relative;
}

.p-lead-container::before {
  content: "";
  background-image: url(../img/lead_bg.jpg?20250614);
  background-size: cover;
  background-position: center;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  animation: moveMVBG 30s ease-in-out infinite;
}

@media (min-width: 768px) {
  .p-lead-container::before {
    background-size: 120% 120%;
  }
}

.p-lead-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-top: 5vw;
  padding-bottom: 18vw;
  position: relative;
}
@media (min-width: 768px) {
  .p-lead-flex {
    padding-top: 0;
    padding-bottom: 90px;
  }
}

.p-lead {
  text-align: center;
  font-size: 3.7333333333vw;
  letter-spacing: 0.14em;
  line-height: 2;
  padding-top: 18.1333333333vw;
  padding-bottom: 6.1333333333vw;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 1;
}
@media (min-width: 768px) {
  .p-lead {
    font-size: 18px;
    letter-spacing: 0.2em;
    line-height: calc(46 / 18);
    padding-top: 89px;
    padding-bottom: 88px;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}

.p-lead-flex .c-sns {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
@media (min-width: 768px) {
  .p-lead-flex .c-sns {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-top: 0;
  }
}

.p-lead-movie {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  /* gap: 1.8666666667vw; */
  gap: 0;
  margin-top: -5px;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 2;
}
@media (min-width: 768px) {
  .p-lead-movie {
    /* -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row; */
    /* gap: 50px; */
    margin-top: 91px;
    padding-left: 0;
    padding-right: 0;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}
.p-lead-movie__youtube {
  /* width: 85.3333333333vw; */
  width: 100%;
  height: 100%;
  margin: 0 auto;
  aspect-ratio: 1.7777777778;
}
.p-lead-movie__youtube iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 1.7777777778;
}
@media (min-width: 768px) {
  .p-lead-movie__youtube {
    width: 840px;
  }
}
.p-lead-movie__text {
  /* font-size: 10px; */
  font-size: 2.666vw;
  font-weight: 500;
  line-height: 1;
  text-align: right;
  margin-top: 4px;
  letter-spacing: 0.1em;
}
@media (min-width: 768px) {
  .p-lead-movie__text {
    font-size: 12px;
    margin: 8px auto 0;
    width: 840px;
  }
}

.p-sec01 {
  position: relative;
  /* margin-top: 9.3333333333vw; */
  padding-top: 13vw;
  /* padding-bottom: 16vw; */
  /* background-image: url(../img/gallery-bg_sp.png); */
  background-size: contain;
  background-position: bottom;
  padding-bottom: 100px;
}
@media (min-width: 768px) {
  .p-sec01 {
    padding-top: 70px;
    padding-bottom: 190px;
    /* background-image: url(../img/gallery-bg_pc.png); */
  }
}

.p-sec01::before {
  content: "";
  background-image: url(../img/exhibition_bg.jpg?20250614);
  background-size: cover;
  background-position: center;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  animation: moveMVBG 60s ease-in-out infinite;
}

@media (min-width: 768px) {
  .p-sec01::before {
    background-size: 120% 120%;
  }
}









.p-sec01::after {
  content: "";
  display: block;
  width: 100%;
  /* height: 2.6666666667vw; */
  height: 8vw;
  background-image: url(../img/border_sp.svg);
  background-size: cover;
  position: absolute;
  top: 32vw;
  left: 0;
  z-index: 2;
}
@media (min-width: 768px) {
  .p-sec01::after {
    background-image: url(../img/border_pc.svg);
    height: 30px;
      top: 165px;
  }
}

.p-sec01-heading {
  position: relative;
  /* display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 5.3333333333vw; */
}
@media (min-width: 768px) {
  .p-sec01-heading {
    /* -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 24px; */
  }
}

/* .p-sec01-number {
  width: 40.5333333333vw;
  margin-left: -0.5333333333vw;
  margin-top: -7.4666666667vw;
}
@media (min-width: 768px) {
  .p-sec01-number {
    width: 430px;
    margin-left: -65px;
    margin-top: -69px;
  }
} */

.p-sec01-title {
  width: 48.5333333333vw;
      display: block;  
    margin: auto;
  /* margin-top: 10.1333333333vw; */
  /* margin-left: 4vw; */
}
@media (min-width: 768px) {
  .p-sec01-title {
    width: 323px;
    /* margin-top: 37px;
    margin-right: 29px; */
  }
}

.p-sec01-kv {
  background-image: url(../img/sec01-kv_sp.png);
  background-size: contain;
  height: 80vw;
  position: relative;
}
@media (min-width: 768px) {
  .p-sec01-kv {
    background-image: url(../img/sec01-kv_pc.png);
    background-size: cover;
    background-position: center;
    height: 600px;
  }
}
.p-sec01-kv__text {
  /* font-size: 10px; */
  font-size: 2.666vw;
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
  line-height: 1;
  position: absolute;
  right: 4vw;
  bottom: 3.5vw;
  color: #1200FF;
  letter-spacing: 0.1em;
}
@media (min-width: 768px) {
  .p-sec01-kv__text {
    /* position: relative; */
    width: 976px;
    margin: auto;
    color: #B6FF00;
    font-size: 12px;
    text-align: right;
    right: 0;
    left: 0;
    bottom: -16px;
  }
}

.p-sec01-info-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-top: 3.4666666667vw;
}
@media (min-width: 768px) {
  .p-sec01-info-flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    /* -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; */
    padding-top: 63px;
    padding-left: 2px;
  }

  .p-sec01-info-flex.-second {
    padding-top: 143px;
  }
}

@media (min-width: 768px) {
  .p-sec01-info {
    width: 580px;
    margin-left: 70px;
  }

  .p-sec01-info-flex.-second .p-sec01-info {
    width: 830px;
    margin: 0 auto;
  }
}

.p-sec01-place {
  font-size: 3.7333333333vw;
  letter-spacing: 0.15em;
  line-height: 1.5714285714;
  text-align: center;
}
@media (min-width: 768px) {
  .p-sec01-place {
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: left;
  }
}

.p-sec01-place__sp {
  font-size: 3.7333333333vw;
  letter-spacing: 0.15em;
  line-height: 1.5714285714;
  text-align: left;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  height: min-content;
  left: 8vw;
  width: 52vw;
}

.p-sec01-exhibition {
  position: relative;
}

@media (min-width: 768px) {
  .p-sec01-exhibition {
    width: 996px;
  }

  .p-sec01-exhibition:first-child {
    margin-top: 190px;
  }

  .p-sec01-exhibition:not(:first-child) {
    margin-top: 168px;
  }
}

.p-sec01-subtitle {
  /* margin-left: -5.3333333333vw;
  margin-right: -5.3333333333vw; */
  /* margin-top: 2.9333333333vw; */
  /* margin-top: 2vw; */
}
@media (min-width: 768px) {
  .p-sec01-subtitle {
    /* margin-left: 0;
    margin-right: 0;
    margin-top: 5px; */
    display: flex;
    position: relative;
    margin-bottom: 50px;
  }

  .p-sec01-subtitle.-second {
    margin-bottom: 78px;
  }

  .p-sec01-subtitle.-third {
    margin-bottom: 70px;
  }
}

.p-sec01-subtitle-num {
  width: 90px;
  margin: 26.666666666vw auto 0;
}
@media (min-width: 768px) {
  .p-sec01-subtitle-num {
    width: 90px;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
}
@media (max-width: 767px) {
  .p-sec01-subtitle-num {
    display: block;
  }

  .p-sec01-subtitle-num.-first {
      margin-top: 37.333333333vw;
  }
}

.p-sec01-subtitle-text {
  padding-left: 3.2vw;
  padding-right: 3.2vw;
  font-size: 4.8vw;
  letter-spacing: 0.1em;
  line-height: 2;
  margin-top: 10vw;
  /* margin-top: 6vw; */
  text-align: center;
}
@media (min-width: 768px) {
  .p-sec01-subtitle-text {
    padding-left: 100px;
    padding-right: 100px;
    font-size: 24px;
    line-height: 2;
    letter-spacing: 0.2em;
    /* margin-top: 23px; */
    margin: auto;
  }
}

@media (max-width: 767px) {
  .p-sec01-subtitle-text {
    margin-bottom: 40px;
  }
}

.p-sec01-text-box {
  display: flex;
  margin-top: 8vw;
}

@media (min-width: 768px) {
  .p-sec01-text-box {
  margin-top: 50px;
}
}

.p-sec01-text-left {
  width: 8vw;
  display: block;
  height: auto;
  background-image: url(../img/exhibition_left01_sp.png);
  background-size: cover;
  background-repeat: no-repeat;
  margin: 5vw 0;
  position: relative;
}

.p-sec01-text-left.-second {
  background-image: url(../img/exhibition_left02_sp.png);
}

.p-sec01-text-left.-third {
  background-image: url(../img/exhibition_left03_sp.png);
}

.p-sec01-text-left.-fourth {
  background-image: url(../img/exhibition_left04_sp.png);
}

@media (min-width: 768px) {
  .p-sec01-text-left {
    width: 90px;
      /* content: ""; */
    background-image: url(../img/exhibition_left01.png);
  /* display: block;
  height: auto;
  background-image: url(../img/exhibition_left01.png);
  background-size: cover;
  background-repeat: no-repeat; */
  /* position: absolute;
  top: 0;
  left: 0; */
    margin: 10px 0;
    /* border-top: 1px solid #fff;
    border-bottom: 1px solid #fff; */
  }

    .p-sec01-text-left.-second {
      background-image: url(../img/exhibition_left02.png);
    }

    .p-sec01-text-left.-third {
      background-image: url(../img/exhibition_left03.png);
    }

    .p-sec01-text-left.-fourth {
      background-image: url(../img/exhibition_left04.png);
    }
}

.p-sec01-text-left::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: -5vw;
  left: 0;
  /* z-index: 2; */
}
@media (min-width: 768px) {
.p-sec01-text-left::before {
      top: -10px;
  }
}

.p-sec01-text-left::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  bottom: -5vw;
  left: 0;
  /* z-index: 2; */
}
@media (min-width: 768px) {
.p-sec01-text-left::after {
      bottom: -10px;
  }
}

.p-sec01-text-right {
  width: 8vw;
  display: block;
  height: auto;
  background-image: url(../img/exhibition_right01_sp.png);
  background-size: cover;
  background-repeat: no-repeat;
  margin: 5vw 0;
      position: relative;
}

.p-sec01-text-right.-second {
  background-image: url(../img/exhibition_right02_sp.png);
}

.p-sec01-text-right.-third {
  background-image: url(../img/exhibition_right03_sp.png);
}

.p-sec01-text-right.-fourth {
  background-image: url(../img/exhibition_right04_sp.png);
}

@media (min-width: 768px) {
  .p-sec01-text-right {
    width: 90px;
      /* content: ""; */
  display: block;
  /* width: 100%; */
  height: auto;
  background-image: url(../img/exhibition_right01.png);
  background-size: cover;
  background-repeat: no-repeat;
  /* position: absolute;
  top: 0;
  left: 0; */
  margin: 10px 0;
      /* border-top: 1px solid #fff;
    border-bottom: 1px solid #fff; */

  }

  .p-sec01-text-right.-second {
    background-image: url(../img/exhibition_right02.png);
  }

  .p-sec01-text-right.-third {
    background-image: url(../img/exhibition_right03.png);
  }

  .p-sec01-text-right.-fourth {
    background-image: url(../img/exhibition_right04.png);
  }
}


.p-sec01-text-right::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: -5vw;
  left: 0;
  /* z-index: 2; */
}
@media (min-width: 768px) {
.p-sec01-text-right::before {
  top: -10px;
  }
}

.p-sec01-text-right::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  bottom: -5vw;
  left: 0;
  /* z-index: 2; */
}
@media (min-width: 768px) {
.p-sec01-text-right::after {
  bottom: -10px;
  }
}

.p-sec01-text {
  /* padding-left: 3.2vw;
  padding-right: 3.2vw; */
  font-size: 3.7333333333vw;
  letter-spacing: 0.12em;
  line-height: 2;
  /* margin-top: 8.5333333333vw; */
  /* margin-top: 6vw; */
  position: relative;
  width: calc(100% - 16vw);
  padding: 5.333333333vw;
}
@media (min-width: 768px) {
  .p-sec01-text {
    /* padding-left: 133px;
    padding-right: 133px; */
    padding: 40px 53px;
    font-size: 19px;
    line-height: calc(36 / 19);
    /* margin-top: 23px; */
    /* 710 */
    width: calc(100% - 180px);
  }
}

.p-sec01-text .p-sec01-text__block:not(:first-child) {
  display: block;
  margin-top: 13.333333333vw;
  position: relative;
}

  .p-sec01-text .p-sec01-text__block:not(:first-child)::before {
      content: "";
    display: block;
      width: 100%;
  height: 1px;
  background-color: #fff;
    position: absolute;
  top: -6.666666666vw;
  }

@media (min-width: 768px) {
  .p-sec01-text .p-sec01-text__block:not(:first-child) {
    /* display: block; */
    margin-top: 80px;
    /* position: relative; */
  }

  .p-sec01-text .p-sec01-text__block:not(:first-child)::before {
      /* content: "";
    display: block;
      width: 100%;
  height: 1px;
  background-color: #fff;
    position: absolute; */
  top: -40px;
  }
}

.p-sec01-text::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  /* z-index: 2; */
  width: calc(100% - 10.666666666vw);
}
@media (min-width: 768px) {
  .p-sec01-text::before {
    width: calc(100% - 106px);
  }
}

.p-sec01-text::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  /* z-index: 2; */
    width: calc(100% - 10.666666666vw);
}
@media (min-width: 768px) {
  .p-sec01-text::after {
    width: calc(100% - 106px);
  }
}

  .p-sec01-image {
    margin-top: 8vw;
  }

@media (min-width: 768px) {
  .p-sec01-image {
    margin-top: 50px;
  }
}

.p-sec01-explanation {
  background-image: url(../img/exhibition_img02-03-bg_sp.png);
        background-size: 100% 100%;
      background-repeat: no-repeat;
            padding: 2.666666666vw;
            margin-top: 8vw
}

@media (min-width: 768px) {
  .p-sec01-explanation {
    display: flex;
      background-image: url(../img/exhibition_img02-03-bg.png);
      /* background-size: cover; */
      padding: 60px 60px 50px;
      margin-top: 50px;
      gap: 30px;
  }
}

@media (min-width: 768px) {
    .p-sec01-explanation-img {
        width: 380px;
        /*    height: fit-content;*/
        height: auto;
        object-fit: contain;
    }
}

@media (max-width: 767px) {
  .p-sec01-explanation-box {
    background-color: #140034;
    padding: 8vw 10.666666666vw 14vw;
  }
}

.p-sec01-explanation-title {
    font-size: 4.8vw;
  line-height: calc(28 / 18);
      letter-spacing: 0.1em;
          /* padding: 10px 0 40px; */
          padding-bottom: 8vw;
      border-bottom: 1px solid #fff;
}

@media (min-width: 768px) {
  .p-sec01-explanation-title {
    font-size: 24px;
    line-height: calc(38 / 24);
    padding: 10px 0 40px;
    letter-spacing: 0.2em;
        /* border-bottom: 1px solid #fff; */
  }
}

@media (max-width: 767px) {
  .p-sec01-explanation-title {
    text-align: center;
  }
}

.p-sec01-explanation-text {
      font-size: 3.733333333vw;
    line-height: calc(30 / 14);
    letter-spacing: 0.06em;
            margin-top: 5.333333333vw;
}

@media (min-width: 768px) {
  .p-sec01-explanation-text {
    font-size: 16px;
    line-height: calc(30 / 16);
            margin-top: 20px;
  }
}

.p-sec01-note {
  font-size: calc(14 / 375 * 100vw);
  line-height: 2;
  /* letter-spacing: 0.05em; */
  letter-spacing: 0.1em;
  /* margin-top: 8vw; */
  font-family: "Noto Serif JP", serif;
  text-align: center;
}
@media (min-width: 768px) {
  .p-sec01-note {
    font-size: 14px;
    line-height: calc(27 / 14);
    /* margin-top: 50px; */
      text-align: right;
  }
}

.p-sec01-spot {
  text-align: center;
  margin-top: 10.1333333333vw;
  margin-bottom: 10.4vw;
  display: none;
}
@media (min-width: 768px) {
  .p-sec01-spot {
    margin-top: 0;
    margin-bottom: 0;
    display: block;
  }
}
.p-sec01-spot__img {
  width: 50.6666666667vw;
}
@media (min-width: 768px) {
  .p-sec01-spot__img {
    width: 250px;
    margin-right: 10px;
    margin-top: 30px;
  }
}

.p-sec01-spot__sp {
  text-align: center;
  margin-top: 4vw;
  /* margin-bottom: 10.4vw; */
  margin-left: -5.3333333333vw;
  margin-right: -5.3333333333vw;
  position: relative;
}
@media (min-width: 768px) {
  .p-sec01-spot__sp {
    display: none;
  }
}
.p-sec01-spot-img__sp {
  width: 100vw;
}

.p-sec01-gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8vw;
  margin-top: 12vw;
}
@media (min-width: 768px) {
  .p-sec01-gallery {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 20px;
    margin-top: 45px;
  }

  .p-sec01-gallery.-second {
    width: 830px;
    margin: 43px auto 0;
  }
}

.p-sec01-gallery-caption {
  font-size: 3.2vw;
  letter-spacing: 0.18em;
  line-height: 1.4166666667;
  text-align: center;
  margin-top: 1.6vw;
}
@media (min-width: 768px) {
  .p-sec01-gallery-caption {
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: 0.15em;
    margin-top: 10px;
  }
}

/* @media (min-width: 768px) {
  .p-sec01-btn img {
    width: ;
    display: block;
    margin: 160px auto 0;
  }

    .p-sec01-btn img:hover {
      background-image: url(../img/btn_hover.);
      background-repeat: no-repeat;
    }
} */


.p-sec01-btn {
  width: 82.666666666vw;
  display: block;
  margin: 26vw auto 0;
  background-image: url(../img/btn.svg);
  position: relative;
      height: 12.8vw;
}
@media (min-width: 768px) {
  .p-sec01-btn {
    width: 350px;
    margin:160px auto 0;
    height: 55px;
    background-size: contain;
    background-repeat: no-repeat;
  }

  .p-sec01-btn:hover {
    background-image: url(../img/btn_hover.svg);
  }
}


.p-sec02 {
  position: relative;
  /* margin-top: 26.6666666667vw; */
  margin-top: 9vw;
  padding-bottom: 16vw;
  /* background-image: url(../img/gallery-bg_sp.png); */
  background-size: contain;
  background-position: bottom;
}
@media (min-width: 768px) {
  .p-sec02 {
    margin-top: 153px;
    padding-bottom: 95px;
    /* background-image: url(../img/gallery-bg_pc.png); */
  }
}
.p-sec02::before {
  content: "";
  display: block;
  width: 100%;
  /* height: 2.6666666667vw; */
  height: 1.5vw;
  background-image: url(../img/border_sp.svg);
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
@media (min-width: 768px) {
  .p-sec02::before {
    background-image: url(../img/border_pc.svg);
    height: 10px;
  }
}

.p-sec02-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 6.4vw;
}
@media (min-width: 768px) {
  .p-sec02-heading {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 17px;
    margin-right: -22px;
  }
}

.p-sec02-number {
  width: 40.5333333333vw;
  margin-left: -0.5333333333vw;
  margin-top: -7.4666666667vw;
}
@media (min-width: 768px) {
  .p-sec02-number {
    width: 425px;
    margin-left: 0;
    margin-top: -69px;
  }
}

.p-sec02-title {
  width: 37.0666666667vw;
  margin-top: 9.6vw;
  margin-left: 9.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec02-title {
    width: 504px;
    margin-top: 78px;
    margin-left: 9px;
  }
}

.p-sec02-kv {
  background-image: url(../img/sec02-kv_sp.png);
  background-size: contain;
  height: 80vw;
}
@media (min-width: 768px) {
  .p-sec02-kv {
    background-image: url(../img/sec02-kv_pc.png);
    background-size: cover;
    background-position: center;
    height: 600px;
  }
}

.p-sec02-info-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-top: 3.4666666667vw;
}
@media (min-width: 768px) {
  .p-sec02-info-flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    /* -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; */
    padding-top: 63px;
    padding-left: 2px;
  }
}

@media (min-width: 768px) {
  .p-sec02-info {
    width: 580px;
    margin-left: 70px
  }
}

.p-sec02-place {
  font-size: 3.7333333333vw;
  letter-spacing: 0.15em;
  line-height: 1.5714285714;
  text-align: center;
}
@media (min-width: 768px) {
  .p-sec02-place {
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: left;
  }
}

.p-sec02-place__sp {
  font-size: 3.7333333333vw;
  letter-spacing: 0.15em;
  line-height: 1.5714285714;
  text-align: left;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  height: min-content;
  left: 8vw;
  width: 52vw;
}

.p-sec02-subtitle {
  margin-left: -5.3333333333vw;
  margin-right: -5.3333333333vw;
  /* margin-top: 2.9333333333vw; */
  margin-top: 2vw;
}
@media (min-width: 768px) {
  .p-sec02-subtitle {
    margin-left: 0;
    margin-right: 0;
    margin-top: 5px;
  }
}

.p-sec02-text {
  padding-left: 3.2vw;
  padding-right: 3.2vw;
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 2;
  margin-top: 8.5333333333vw;
}
@media (min-width: 768px) {
  .p-sec02-text {
    padding-left: 0;
    padding-right: 0;
    font-size: 20px;
    line-height: 1.9;
    letter-spacing: 0.06em;
    margin-top: 23px;
  }
}

.p-sec02-spot {
  text-align: center;
  margin-top: 10.1333333333vw;
  margin-bottom: 10.4vw;
}
@media (min-width: 768px) {
  .p-sec02-spot {
    margin-top: 0;
    margin-bottom: 0;
  }
}
.p-sec02-spot__img {
  width: 50.6666666667vw;
}
@media (min-width: 768px) {
  .p-sec02-spot__img {
    width: 250px;
    margin-right: 10px;
    margin-top: 30px;
  }
}

.p-sec02-spot__sp {
  text-align: center;
  margin-top: 2vw;
  /* margin-bottom: 10.4vw; */
  margin-left: -5.3333333333vw;
  margin-right: -5.3333333333vw;
  position: relative;
}
@media (min-width: 768px) {
  .p-sec02-spot__sp {
    display: none;
  }
}
.p-sec02-spot-img__sp {
  width: 100vw;
}

.p-sec02-schedule {
  margin-top: 12vw;
}

@media (min-width: 768px) {
  .p-sec02-schedule {
    margin: 76px 112px 0 113px;
  }
}

/* @media (min-width: 768px) {
  .p-sec02-schedule-bg {
    background: url(../img/sec02-schedule-bg_pc.png) no-repeat;
    background-size: contain;
    background-position: bottom center;
  }
} */

.p-sec02-schedule-text {
  background-image: url(../img/sec02-schedule-bg_sp.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: top center;
  margin-bottom: 1.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec02-schedule-text {
    /* background: none; */
    background-image: url(../img/sec02-schedule-bg_pc.png);
    /* border: 1px solid #001cf5; */
    /* border-bottom: none; */
    margin-bottom: 4px;
  }
}
.p-sec02-schedule-text p {
  font-size: 3.7333333333vw;
  letter-spacing: 0.2em;
  line-height: 1.5714285714;
  text-align: center;
  padding: 2.1333333333vw;
}
@media (min-width: 768px) {
  .p-sec02-schedule-text p {
    font-size: 20px;
    line-height: 1.45;
    padding: 14px;
  }
}

.p-sec02-schedule-note {
  /* padding-left: 3.2vw;
  padding-right: 3.2vw; */
  font-size: 3.2vw;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 1.6666666667;
  margin-top: 6.4vw;
  margin-bottom: 12.5333333333vw;
  font-family: "Noto Serif JP", serif;
}
@media (min-width: 768px) {
  .p-sec02-schedule-note {
    padding-left: 0;
    padding-right: 0;
    font-size: 14px;
    letter-spacing: 0.07em;
    line-height: 1.5714285714;
    margin-top: 13px;
    margin-bottom: 0;
  }
}

.p-sec02-gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4vw;
}
@media (min-width: 768px) {
  .p-sec02-gallery {
    display: grid;
    gap: 20px;
    margin-top: 70px;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 328px 328px;
  }
}

@media (min-width: 768px) {
  .p-sec02-gallery-pic01 {
    grid-column: 1/2;
    grid-row: 1/3;
  }
}

@media (min-width: 768px) {
  .p-sec02-gallery-pic03 {
    grid-column: 2/3;
    grid-row: 2/3;
  }
}

.p-sec02-gallery-caption {
  font-size: 3.2vw;
  letter-spacing: 0.18em;
  line-height: 1.4166666667;
  text-align: center;
  margin-top: 1.6vw;
}
@media (min-width: 768px) {
  .p-sec02-gallery-caption {
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.15em;
    margin-top: 10px;
  }
}

.p-sec03 {
  /* padding-top: 23.4666666667vw; */
  padding-top: 9vw;
}
@media (min-width: 768px) {
  .p-sec03 {
    padding-top: 100px;
  }
}

.p-sec03-heading {
  font-size: 4.8vw;
  letter-spacing: 0.15em;
  line-height: 1.4444444444;
  text-align: center;
  background-image: url(../img/sec03-title_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top center;
  height: 26.9333333333vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 13.3333333333vw;
  padding: 0 10.6666666667vw;
  color: #fff;
}
@media (min-width: 768px) {
  .p-sec03-heading {
    background-image: url(../img/sec03-title_pc.png);
    width: 978px;
    height: 92px;
    font-size: 24px;
    line-height: 1.5833333333;
    margin-inline: auto;
    margin-bottom: 100px;
    padding: 0 60px;
  }
}

.p-sec03-subtitle {
  position: relative;
  margin-left: -5.3333333333vw;
  margin-right: -5.3333333333vw;
  padding: 0 5.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec03-subtitle {
    margin-left: 0;
    margin-right: 0;
    padding: 0 44px;
  }
}
.p-sec03-subtitle-inner {
  background-color: #00FFFF;
  color: #1200FF;
  font-size: 4.5333333333vw;
  letter-spacing: 0.15em;
  line-height: 1.5294117647;
  min-height: 20vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  padding-top: 3.2vw;
  padding-bottom: 2.9333333333vw;
  padding-left: 2.6666666667vw;
  padding-right: 2.6666666667vw;
}
@media (min-width: 768px) {
  .p-sec03-subtitle-inner {
    font-size: 22px;
    line-height: 1.7272727273;
    min-height: 50px;
    padding-top: 6px;
    padding-bottom: 6px;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.p-sec03-subtitle::after {
  content: "";
  width: 100%;
  height: 0.2666666667vw;
  background: #00FFFF;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media (min-width: 768px) {
  .p-sec03-subtitle::after {
    height: 1px;
  }
}

/* .p-sec03-content01 {
  margin-bottom: 13.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec03-content01 {
    margin-bottom: 48px;
  }
} */

.p-sec03-content02 {
  margin-bottom: 13.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec03-content02 {
    margin-bottom: 98px;
  }
}

.p-sec03-content03 {
  margin-top: 20vw;
}
@media (min-width: 768px) {
  .p-sec03-content03 {
    margin-top: 100px;
  }
}

.p-sec03-text {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: center;
  margin-top: 11.4666666667vw;
  margin-bottom: 11.2vw;
  /* padding: 0 2.6666666667vw; */
  color: #fff;
}
@media (min-width: 768px) {
  .p-sec03-text {
    font-size: 20px;
    line-height: 1.7;
    margin-top: 56px;
    margin-bottom: 62px;
    max-width: 663px;
    margin-inline: auto;
    padding: 0;
  }
}
.p-sec03-text02 {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: center;
  margin-top: 9vw;
  margin-bottom: 11.2vw;
  /* padding: 0 2.6666666667vw; */
  color: #fff;
}
@media (min-width: 768px) {
  .p-sec03-text02 {
    font-size: 20px;
    line-height: 1.7;
    margin-top: 50px;
    margin-bottom: 63px;
    max-width: 663px;
    margin-inline: auto;
    padding: 0;
  }
}
.p-sec03-text03 {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 2;
  /* text-align: center; */
  margin-top: 7vw;
  margin-bottom: 11.2vw;
  /* padding: 0 2.6666666667vw; */
  color: #fff;
}
@media (min-width: 768px) {
  .p-sec03-text03 {
    font-size: 20px;
    line-height: 1.7;
    margin-top: 30px;
    margin-bottom: 72px;
    max-width: 663px;
    margin-inline: auto;
    padding: 0;
  }
}
.p-sec03-text.-justify {
  text-align: justify;
}
@media (min-width: 768px) {
  .p-sec03-text.-justify {
    line-height: 1.9;
  }
}

@media (min-width: 768px) {
  .p-sec03-menu-flex {
    padding: 0 44px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 30px;
  }
}

.p-sec03-menu-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  /* gap: 2.6666666667vw; */
  gap: 5vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-img {
    width: 408px;
    gap: 32px;
  }
}

.p-sec03-menu-second .p-sec03-menu-img {
  gap: 3vw;
  margin-top: 3vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-second .p-sec03-menu-img {
    gap: 32px;
    margin-top: 0;
  }
}

.p-sec03-menu-second .p-sec03-menu-list {
  margin-top: 5vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-second .p-sec03-menu-list {
    margin-top: 0;
  }
}

.p-sec03-menu-caption {
  font-size: 3.2vw;
  letter-spacing: 0.08em;
  line-height: 1.6666666667;
  margin-top: 1.8666666667vw;
  /* margin-bottom: 6.6666666667vw; */
  color: #fff;
  font-family: "Noto Serif JP", serif;
}
@media (min-width: 768px) {
  .p-sec03-menu-caption {
    font-size: 12px;
    line-height: 1.5714285714;
    letter-spacing: 0.1em;
    margin-top: 6px;
    margin-bottom: 0;
  }
}

.p-sec03-menu-heading {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 1.5714285714;
  background-image: url(../img/sec03-subtitle_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top center;
  height: 14.6666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  color: #fff;
}
@media (min-width: 768px) {
  .p-sec03-menu-heading {
    font-size: 18px;
    line-height: 1.6666666667;
    background-image: url(../img/sec03-subtitle_pc.png);
    height: 72px;
  }
}

.p-sec03-menu-list {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 1.5714285714;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 8vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-list {
    margin-top: 15px;
  }

  .p-sec03-menu-first .p-sec03-menu-list {
    flex-direction: row;
    justify-content: space-between;
  }

  .p-sec03-menu-second .p-sec03-menu-list {
    flex-direction: row;
    justify-content: space-between;
  }
}

.p-sec03-menu-item {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 1.5714285714;
  /* width: 68%; */
  width: 100%;
  /* border-bottom: 0.2666666667vw solid #001cf5; */
  /* padding-left: 4vw; */
  padding-top: 2vw;
  /* padding-bottom: 3.2vw; */
  color: #fff;
}
.p-sec03-menu-item:first-child {
  /* border-top: 0.2666666667vw solid #fff; */
  border-top: 0.5vw solid #fff;
}
@media (min-width: 768px) {
  .p-sec03-menu-item:first-child {
    border-width: 1px;
  }

  .p-sec03-menu-second .p-sec03-menu-item:first-child {
    border-top: none;
  }

  .p-sec03-menu-first .p-sec03-menu-item {
    width: 60%;
    padding: 20px 0;
    border-bottom: 1px solid #fff;
  }

  .p-sec03-menu-second .p-sec03-menu-item {
    width: 60%;
    padding: 20px 0;
    border-bottom: 1px solid #fff;
  }
}

@media (min-width: 768px) {
  .p-sec03-menu-item {
    font-size: 18px;
    line-height: 1.6666666667;
    letter-spacing: 0.15em;
    border-width: 1px;
    padding-left: 17px;
    padding-top: 12px;
    padding-bottom: 4px;
  }
}
.p-sec03-menu-item.-item03 {
  padding-top: 2.6666666667vw;
  padding-bottom: 4.5333333333vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-item.-item03 {
    padding-top: 19px;
    padding-bottom: 21px;
  }
}
.p-sec03-menu-item span {
  font-size: 2.9333333333vw;
  letter-spacing: 0.07em;
}
@media (min-width: 768px) {
  .p-sec03-menu-item span {
    font-size: 14px;
  }
}

.p-sec03-menu-price {
  /* width: 32%; */
  width: 100%;
  text-align: right;
  /* border-bottom: 0.2666666667vw solid #fff; */
  border-bottom: 0.5vw solid #fff;
  /* padding-left: 9.8666666667vw; */
  /* display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; */
  padding-bottom: 1vw;
  color: #fff;
  letter-spacing: 0.09em;
}
@media (min-width: 768px) {
  .p-sec03-menu-price {
    border-width: 1px;
    padding-left: 52px;
    font-size: 18px;
    padding-bottom: 10px;
  }

  .p-sec03-menu-first .p-sec03-menu-price {
    width: 40%;
    padding: 20px 0;
    /* margin-top: auto; */
    border-top: 1px solid #fff;
    display: flex;
    align-items: end;
    justify-content: flex-end;
  }

  .p-sec03-menu-second .p-sec03-menu-price {
    width: 40%;
    padding: 20px 0;
  }

  .p-sec03-menu-second .p-sec03-menu-price.-price02 {
    margin-top: auto;
  }
}
.p-sec03-menu-price.-price01 img, .p-sec03-menu-price.-price03 img {
  height: 3.7333333333vw;
  width: auto;
}
@media (min-width: 768px) {
  .p-sec03-menu-price.-price01 img, .p-sec03-menu-price.-price03 img {
    height: 17px;
  }
}
.p-sec03-menu-price.-price02 img {
  height: 3.2vw;
  width: auto;
}
@media (min-width: 768px) {
  .p-sec03-menu-price.-price02 img {
    height: 15px;
  }
}

.p-sec03-menu-date {
  font-size: 3.7333333333vw;
  letter-spacing: 0.06em;
  line-height: 1.5714285714;
  text-align: center;
  /* border-bottom: 0.2666666667vw solid #001cf5; */
  padding-left: 4vw;
  padding-top: 4.5333333333vw;
  padding-bottom: 5.6vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-date {
    font-size: 18px;
    line-height: 1.5;
    border-width: 1px;
    padding-left: 0;
    padding-top: 25px;
    padding-bottom: 30px;
  }
}

.p-sec03-menu-note {
  background-color: #e5e8fe;
  font-size: 3.7333333333vw;
  letter-spacing: 0.15em;
  line-height: 1.4285714286;
  /* border-bottom: 0.2666666667vw solid #001cf5; */
  padding-left: 4vw;
  padding-top: 4.5333333333vw;
  padding-bottom: 3.4666666667vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-note {
    font-size: 18px;
    line-height: 1.5;
    border-width: 1px;
    padding-left: 17px;
    padding-top: 13px;
    padding-bottom: 15px;
  }
}
.p-sec03-menu-text {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 2;
  margin-top: 5vw;
  margin-bottom: 7vw;
  /* padding: 0 2.6666666667vw; */
  color: #fff;
}
@media (min-width: 768px) {
  .p-sec03-menu-text {
    font-size: 20px;
    line-height: 1.66666666667;
    margin-top: 15px;
    margin-bottom: 0;
    max-width: 663px;
    margin-inline: auto;
    padding: 0;
    letter-spacing: 0.07em;
  }
}

.p-sec03-menu-btn01 {
  width: 80vw;
  display: block;
  margin: 8vw auto 0;
}
@media (min-width: 768px) {
  .p-sec03-menu-btn01 {
    width: 340px;
    margin: 0 0 0 auto;
    height: 60px;
    background-image: url(../img/sec03-btn01_pc.png);
    background-size: contain;
    background-repeat: no-repeat;
  }

  .p-sec03-menu-btn01:hover {
    background-image: url(../img/sec03-btn01_pc_hover.png);
  }
}

.p-sec03-menu-btn02__sp {
  width: 80vw;
  display: block;
  margin: 13vw auto 0;
}

.p-sec03-menu-btn02__pc {
  width: 340px;
  margin-left: auto;
  display: block;
  height: 60px;
  background-image: url(../img/sec03-btn02_pc.png);
  background-size: contain;
  background-repeat: no-repeat;
}
.p-sec03-menu-btn02__pc:hover {
  background-image: url(../img/sec03-btn02_pc_hover.png);
}

.p-sec03-menu-second {
  margin-top: 18vw;
}
@media (min-width: 768px) {
  .p-sec03-menu-second {
    margin-top: 100px;
  }
}

@media (min-width: 768px) {
  .p-sec03-menu-right {
    width: 450px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
}

.p-sec03-spotify {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 13.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec03-spotify {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 0;
    max-width: 663px;
    margin-inline: auto;
    padding-top: 10px;
  }
}

.p-sec03-spotify-img {
  width: 66.6666666667vw;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .p-sec03-spotify-img {
    width: 250px;
    margin: 0;
  }
}

.p-sec03-spotify-btn {
  width: 72vw;
  min-height: 14.9333333333vw;
  background-color: #e7b136;
  color: #000;
  font-size: 2.9333333333vw;
  line-height: 1.5454545455;
  letter-spacing: 0.075em;
  border-radius: 7.4666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4.8vw;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media (min-width: 768px) {
  .p-sec03-spotify-btn {
    width: 360px;
    min-height: 90px;
    font-size: 18px;
    line-height: 1.4444444444;
    gap: 19px;
  }
}

.p-spotify-icon {
  width: 8.8vw;
  margin-top: 1.3333333333vw;
}
@media (min-width: 768px) {
  .p-spotify-icon {
    width: 50px;
    margin-top: 3px;
  }
}
.p-spotify-icon .icon {
  fill: #000;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

@media (min-width: 768px) {
  .p-sec03-spotify-btn:hover {
    background-color: #001cf5;
    color: #fff;
  }
  .p-sec03-spotify-btn:hover .p-spotify-icon .icon {
    fill: #fff;
  }
}

.p-sec03-recode-title {
  width: 100%;
  display: block;
}
@media (min-width: 768px) {
  .p-sec03-recode-title {
    margin-top: 4px;
  }
}

@media (min-width: 768px) {
  .p-sec03-recode-flex {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    padding: 0 44px;
  }

  .p-sec03-recode-flex__right {
    width: 450px;
  }
}


.p-sec03-photoPlan-flex {
  margin-top: 12.2666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 13.3333333333vw;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-flex {
    padding: 0 44px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 30px;
    padding-left: 170px;
    margin-top: 56px;
  }
}

.p-sec03-photoPlan-img {
  width: 66.6666666667vw;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-img {
    width: 250px;
    margin: 0;
  }
}

.p-sec03-recode-img {
  width: 66.6666666667vw;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .p-sec03-recode-img {
    width: 408px;
    margin: 0;
  }
}

.p-sec03-photoPlan-heading {
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  line-height: 1.5714285714;
  background-image: url(../img/sec03-subtitle_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top center;
  height: 14.6666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-heading {
    font-size: 18px;
    line-height: 1.6666666667;
    background-image: url(../img/sec03-subtitle_pc.png);
    height: 72px;
    width: 450px;
  }
}

.p-sec03-photoPlan-note {
  font-size: 3.2vw;
  letter-spacing: 0.08em;
  padding: 0 2.6666666667vw;
  margin-top: -5.3333333333vw;
}
.p-sec03-photoPlan-note.-note02 {
  padding-bottom: 1.6vw;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-note.-note02 {
    padding-bottom: 9px;
  }
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-note {
    font-size: 14px;
    line-height: 1.5714285714;
    letter-spacing: 0.1em;
    padding: 0;
    margin-top: -30px;
    max-width: 663px;
    margin-inline: auto;
  }
}

.p-sec03-photoPlan-date {
  font-size: 4.8vw;
  line-height: 1.8888888889;
  letter-spacing: 0.1em;
  text-align: center;
  padding-top: 8vw;
  padding-bottom: 8vw;
}
.p-sec03-photoPlan-date span {
  font-size: 14px;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-date {
    font-size: 20px;
    line-height: 1.7;
    padding-top: 22px;
    padding-bottom: 28px;
    width: 450px;
  }
  .p-sec03-photoPlan-date span {
    font-size: 20px;
  }
}

.p-sec03-photoPlan-price-wrap {
  position: relative;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-price-wrap {
    width: 450px;
  }
}
.p-sec03-photoPlan-price-wrap::after {
  content: "";
  width: 100%;
  height: 0.2666666667vw;
  background: #001cf5;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-price-wrap::after {
    height: 1px;
  }
}

.p-sec03-photoPlan-price {
  font-size: 5.8666666667vw;
  line-height: 1.5454545455;
  letter-spacing: 0.1em;
  text-align: center;
  padding-top: 8vw;
  padding-bottom: 12.8vw;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-price {
    font-size: 26px;
    line-height: 1.1538461538;
    padding-top: 38px;
    padding-bottom: 54px;
  }
}

.p-sec03-photoPlan-btn {
  width: 72vw;
  min-height: 14.9333333333vw;
  background-color: #e7b136;
  color: #001cf5;
  font-size: 3.7333333333vw;
  line-height: 1.2142857143;
  letter-spacing: 0.1em;
  border-radius: 7.4666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-inline: auto;
  margin-top: 13.3333333333vw;
  margin-bottom: 23.2vw;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media (min-width: 768px) {
  .p-sec03-photoPlan-btn {
    width: 630px;
    min-height: 90px;
    font-size: 22px;
    line-height: 1.3636363636;
    letter-spacing: 0.16em;
    margin-top: 95px;
    margin-bottom: 129px;
  }
}

@media (min-width: 768px) {
  .p-sec03-photoPlan-btn:hover {
    background-color: #001cf5;
    color: #fff;
  }
}
.p-info {
  margin-top: 40vw;
  /* margin-bottom: 13.3333333333vw; */
  position: relative;
  border-bottom: 1px solid #fff;
    background-image: url(../img/infomation_bg_sp.png?20250613);
    background-size: cover;
    background-repeat: no-repeat;
}

.p-info::before {
  content: "";
  display: block;
  width: 24vw;
  /* height: 2.6666666667vw; */
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

.p-info::after {
  content: "";
  display: block;
  width: 24vw;
  /* height: 2.6666666667vw; */
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
}

@media (min-width: 768px) {
  .p-info {
    /* margin-top: 200px;
    margin-bottom: 100px; */
    background-image: url(../img/infomation_bg.png?20250613);
    /* background-size: cover;
    background-repeat: no-repeat; */
    /* background-position: top center; */
    width: 840px;
    margin: 160px auto 0;
  }

  .p-info::before {
    /* content: "";
    display: block; */
    width: 230px;
    /* height: 2.6666666667vw; */
    /* height: 1px;
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2; */
  }

  .p-info::after {
    /* content: "";
    display: block; */
    width: 230px;
    /* height: 2.6666666667vw; */
    /* height: 1px;
    background-color: #fff;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2; */
  }
}

.p-info-heading {
  width: 34.4vw;
      position: absolute;
    top: -4.266666666vw;
    left: 0;
    right: 0;
    margin: auto;
}

@media (min-width: 768px) {
  .p-info-heading {
    width: 297px;
    /* position: absolute; */
    top: -36px;
    /* left: 0;
    right: 0;
    margin: auto; */
  }
}

.p-info-inner {
  padding: 20vw 8vw 18vw;
}
@media (min-width: 768px) {
  .p-info-inner {
    padding: 80px;
  }
}

.p-info-subtitle {
  font-size: 4.266666666vw;
  letter-spacing: 0.06em;
  line-height: 2;
  /* line-height: 1.24;
  display: inline-block;
  border-bottom: 0.2666666667vw solid #B6FF00;
  margin-bottom: 2.1333333333vw;
  padding-bottom: 0.5vw; */
  position: relative;
}
@media (min-width: 768px) {
  .p-info-subtitle {
    font-size: 18px;
    /* border-width: 1px; */
    line-height: calc(50 / 18);
    /* letter-spacing: 0.1em; */
    /* margin-bottom: 11px;
    padding-bottom: 2px; */
  }
}
.p-info-subtitle:nth-child(n+2) {
  margin-top: 8.2666666667vw;
}
@media (min-width: 768px) {
  .p-info-subtitle:nth-child(n+2) {
    margin-top: 30px;
  }
}

.p-info-subtitle::before {
  content: "";
    background: radial-gradient(circle farthest-side, #fff, #fff 60%, transparent 60%, transparent);
    background-size: 3px 3px;
    content: '';
    display: inline-block;
    height: 3px;
    width: 30.666666666vw;
    position: absolute;
    left: 0;
    bottom: -3vw;
}

@media (min-width: 768px) {
  .p-info-subtitle::before {
    width: 170px;
    bottom: -1px;
        background-size: 4px 4px;
        height: 4px;
  }
}

.p-info-text {
  font-size: 4.266666666vw;
  line-height: 2;
  letter-spacing: 0.1em;
      margin-top: 5.333333333vw;
}
@media (min-width: 768px) {
  .p-info-text {
    font-size: 18px;
    line-height: calc(30 / 18);
    margin-top: 6px;
  }
}

.p-info-list {
  margin-top: 2.1333333333vw;
}
@media (min-width: 768px) {
  .p-info-list {
    margin-top: 3px;
  }
}
.p-info-list li {
  font-size: 3.7333333333vw;
  line-height: 1.7857142857;
  letter-spacing: 0.1em;
  margin-bottom: 2.1333333333vw;
}
@media (min-width: 768px) {
  .p-info-list li {
    font-size: 22px;
    line-height: 1.5909090909;
    margin-bottom: 7px;
  }
}
.p-info-list li::before {
  content: "●";
}

.p-info-note {
  font-size: 4.266666666vw;
  line-height: 2;
  /* letter-spacing: 0.05em; */
      letter-spacing: 0.1em;
  margin-top: 8vw;
  font-family: "Noto Serif JP", serif;
}
@media (min-width: 768px) {
  .p-info-note {
    font-size: 14px;
    line-height: calc(27 / 14);

    margin-top: 50px;
  }
}

.p-footer {
  background-color: #56eaef;
  padding-top: 8vw;
  padding-bottom: 24vw;
}
@media (min-width: 768px) {
  .p-footer {
    padding-top: 70px;
    padding-bottom: 165px;
  }
}
.p-footer__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-footer-logo {
  width: 57.6vw;
  fill: #000;
}
@media (min-width: 768px) {
  .p-footer-logo {
    width: 420px;
  }
}

.p-banner {
  padding: 100px 0;
}
@media (min-width: 768px) {
  .p-banner {
    padding: 250px 0;
  }
}

/* creators */
.p-creators__bg {
  width: 100%;
  /* background-image: url(../img/bg_creators_sp.jpg); */
  /* background-image: url(../img/bg_creators_pc.jpg); */
  /* background-size: cover;
  background-position: top center; */
  padding-bottom: calc(100 / 375 * 100vw);
  position: relative;
}

.p-creators__bg::before {
  content: "";
  background-image: url(../img/bg_creators.jpg?20250614);
  background-size: cover;
  background-position: center;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  animation: moveMVBG 30s ease-in-out infinite;
}

@media (min-width: 768px) {
  .p-creators__bg::before {
    background-size: 120% 120%;
  }
}


@media (min-width: 768px) {
  .p-creators__bg {
    /* background-image: url(../img/bg_creators_pc.jpg); */
    padding-bottom: 200px;
  }
}

.p-creators__heading {
  display: block;
  width: calc(170 / 375 * 100vw);
  margin: 0 auto;
  padding-top: calc(45 / 375 * 100vw);
  padding-bottom: calc(30 / 375 * 100vw);
  position: relative;
}

@media (min-width: 768px) {
  .p-creators__heading {
    width: 282px;
    padding-top: 66px;
    padding-bottom: 25px;
  }
}

.p-creators__sec {
  position: relative;
  padding-top: calc(30 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-creators__sec {
    padding-top: 30px;
  }
}

.p-creators__sec::before {
  content: "";
  display: block;
  width: 100%;
  height: calc(30 / 375 * 100vw);
  background-image: url(../img/creators_border_sp.svg);
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

@media (min-width: 768px) {
  .p-creators__sec::before {
    height: 30px;
    background-image: url(../img/creators_border_pc.svg);
  }
}

.p-creators__evala,
.p-creators__abstract {
  position: relative;
  background: #9D7283;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.2) 0%, rgba(126, 59, 56, 0.6) 50%, rgba(0, 0, 54, 0.6) 100%);
  padding-left: calc(27 / 375 * 100vw);
  padding-right: calc(27 / 375 * 100vw);
  padding-bottom: calc(50 / 375 * 100vw);
  margin-top: calc(75 / 375 * 100vw);
}

.p-creators__abstract {
  margin-top: calc(90 / 375 * 100vw);
}

@media (min-width: 768px) {
.p-creators__evala,
.p-creators__abstract {
    width: 100%;
    max-width: 840px;
    border-bottom: 1px solid #fff;
    padding: 0 0 90px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 202px;
  }

  .p-creators__abstract {
    margin-top: 150px;
  }
}

.p-creators__evala-heading,
.p-creators__abstract-heading {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  position: relative;
  top: calc(-1 *(18 / 375 * 100vw));
  z-index: 2;
}

@media (min-width: 768px) {
  .p-creators__evala-heading,
  .p-creators__abstract-heading {
    top: -29px;
  }
}

.p-creators__evala-heading-img {
  width: calc(82 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-creators__evala-heading-img {
    width: 128px;
  }
}

.p-creators__evala-heading::before,
.p-creators__evala-heading::after,
.p-creators__abstract-heading::before,
.p-creators__abstract-heading::after {
  content: "";
  display: block;
  width: calc(75 / 375 * 100vw);
  height: 1px;
  background-color: #fff;
}

@media (min-width: 768px) {
  .p-creators__evala-heading::before,
  .p-creators__evala-heading::after,
  .p-creators__abstract-heading::before,
  .p-creators__abstract-heading::after {
    width: 280px;
  }
}

.p-creators__abstract-heading-img {
  width: calc(242 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-creators__abstract-heading-img {
    width: 383px
  }
}

.p-creators__abstract-heading::before,
.p-creators__abstract-heading::after {
  width: calc(25 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-creators__abstract-heading::before,
  .p-creators__abstract-heading::after {
    width: 150px;
  }
}

.p-creators__evala-title,
.p-creators__abstract-title {
  font-size: calc(16 / 375 * 100vw);
  letter-spacing: 0.1em;
  text-align: center;
  border-bottom: 1px solid #fff;
  padding-bottom: calc(30 / 375 * 100vw);
  margin-top: calc(18 / 375 * 100vw);
  margin-bottom: calc(49 / 375 * 100vw);
}

.p-creators__abstract-title {
  margin-top: 0;
}

@media (min-width: 768px) {
  .p-creators__evala-title,
  .p-creators__abstract-title {
    font-size: 20px;
    padding-bottom: 45px;
    margin-top: 10px;
    margin-bottom: 90px;
  }
}

@media (min-width: 768px) {
  .p-creators__evala-inner,
  .p-creators__abstract-inner {
    padding-left: 150px;
    padding-right: 150px;
  }
}

.p-creators__evala-text,
.p-creators__abstract-text {
    font-size: calc(14 / 375 * 100vw);
    line-height: 2.143;
    margin-top: calc(30 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-creators__evala-text,
  .p-creators__abstract-text {
    font-size: 16px;
    line-height: 1.875;
    margin-top: 45px;
  }
}

.p-creators__btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(28/ 375 * 100vw);
  margin-top: calc(42 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-creators__btn {
    flex-direction: row;
    justify-content: space-between;
    gap: 0px;
    margin-top: 45px;
  }
}

.p-creators__btn-img01 {
  width: calc(251 / 375 * 100vw);
  height: calc(50 / 375 * 100vw);
  background-image: url(../img/official_btn_01.svg);
}

@media (min-width: 768px) {
.p-creators__btn-img01 {
    width: 250px;
    height: 50px;
  }

.p-creators__btn-img01:hover {
    background-image: url(../img/official_btn_hover.svg);
  }
}

.p-creators__btn-img02 {
  width: calc(251 / 375 * 100vw);
    height: calc(50 / 375 * 100vw);
    background-image: url(../img/instagram_btn_01.svg);
}

@media (min-width: 768px) {
.p-creators__btn-img02 {
    width: 250px;
    height: 50px;
  }
.p-creators__btn-img02:hover {
    background-image: url(../img/instagram_btn_hover.svg);
  }
}


.p-creators__btn-img03 {
  width: calc(251 / 375 * 100vw);
    height: calc(50 / 375 * 100vw);
  background-image: url(../img/official_btn_02.svg);
}

@media (min-width: 768px) {
.p-creators__btn-img03 {
    width: 250px;
        height: 50px;
      }
      
  .p-creators__btn-img03:hover {
    background-image: url(../img/official_btn_hover.svg);
  }
}

.p-creators__btn-img04 {
  width: calc(251 / 375 * 100vw);
  height: calc(50 / 375 * 100vw);
  background-image: url(../img/instagram_btn_02.svg);
}

@media (min-width: 768px) {
  .p-creators__btn-img04 {
    width: 250px;
        height: 50px;
  }

  .p-creators__btn-img04:hover {
    background-image: url(../img/instagram_btn_hover.svg);
  }
}


/* special */
.p-special__bg {
  width: 100%;
  /* background-image: url(../img/bg_special_sp.jpg);
  background-size: cover;
  background-position: top center; */
  padding-bottom: calc(71 / 375 * 100vw);
  position: relative;
}

@media (min-width: 768px) {
  .p-special__bg {
    /* background-image: url(../img/bg_special_pc.jpg); */
    padding-bottom: 200px;
  }
}

.p-special__bg::before {
  content: "";
  background-image: url(../img/bg_special.jpg?20250614);
  background-size: cover;
  background-position: center;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  animation: moveMVBG 30s ease-in-out infinite;
}

@media (min-width: 768px) {
  .p-special__bg::before {
    background-size: 120% 120%;
  }
}

.p-special__heading {
  display: block;
  width: calc(284 / 375 * 100vw);
  margin: 0 auto;
  padding-top: calc(45 / 375 * 100vw);
  padding-bottom: calc(30 / 375 * 100vw);
  position: relative;
}

@media (min-width: 768px) {
  .p-special__heading {
    width: 454px;
    padding-top: 66px;
    padding-bottom: 25px;
  }
}

.p-special__sec {
  position: relative;
  padding-top: calc(30 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-special__sec {
    padding-top: 30px;
  }
}

.p-special__sec::before {
  content: "";
  display: block;
  width: 100%;
  height: calc(30 / 375 * 100vw);
  background-image: url(../img/special_border_sp.svg);
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

@media (min-width: 768px) {
  .p-special__sec::before {
    height: 30px;
    background-image: url(../img/special_border_pc.svg);
  }
}

@media (min-width: 768px) {
  .p-special__inner {
    width: 100%;
    max-width: 840px;
    margin-left: auto;
    margin-right: auto;
  }
}

.p-special__title {
  width: 100%;
  height: calc(182 / 375 * 100vw);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: calc(18 / 375 * 100vw);
  line-height: 2;
  letter-spacing: 0.2em;
  text-align: center;
  background-image: url(../img/title_special_sp.png);
  background-size: cover;
  background-position: center;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  margin-top: calc(67 / 375 * 100vw);
  position: relative;
  z-index: 1;
}

.p-special__title::before {
  content: "";
  display: block;
}

@media (min-width: 768px) {
  .p-special__title {
    height: 150px;
    font-size: 20px;
    background-image: url(../img/title_special_pc.png);
    margin-top: 180px;
  }
}

.p-special__title span span {
  display: none;
}

@media (min-width: 768px) {
  .p-special__title span span {
    display: inline;
  }
}

.p-special__text {
  font-size: calc(14 / 375 * 100vw);
  line-height: 2.143;
  letter-spacing: 0.1em;
  text-align: center;
  padding-top: calc(50 / 375 * 100vw);
  padding-bottom: calc(45 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-special__text {
    font-size: 18px;
    line-height: 2;
    padding-top: 45px;
    padding-bottom: 60px;
  }
}

.p-special__content {
  background: #9D7283;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.1) 0%, rgba(126, 59, 56, 0.6) 50%, rgba(0, 0, 54, 0.6) 100%);
  padding-top: calc(182 / 375 * 100vw);
  margin-top: calc(-1 * (182 / 375 * 100vw));
  margin-left: calc(27 / 375 * 100vw);
  margin-right: calc(27 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-special__content {
    padding-top: 0;
    padding-left: 32px;
    padding-right: 32px;
    margin: 0;
  }
}

.p-special__title01-pc,
.p-special__title01-sp {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000000;
  font-size: calc(18 / 375 * 100vw);
  line-height: 1.556;
  text-align: center;
  background-image: url(../img/title_special_01_sp.jpg);
  background-size: cover;
  background-position: center;
  padding: calc(23 / 375 * 100vw) calc(10 / 375 * 100vw);
  margin-bottom: calc(30 / 375 * 100vw);
}

.p-special__title01-pc {
  display: none !important;
}

@media (min-width: 768px) {
  .p-special__title01-pc {
    display: flex !important;
    font-size: 18px;
    background-image: url(../img/title_special_01_pc.jpg);
    padding: 23px 10px 33px;
    margin-bottom: 30px;
  }

  .p-special__title01-sp {
    display: none !important;
  }
}

.p-special__title02 {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: calc(18 / 375 * 100vw);
  line-height: 1.556;
  letter-spacing: 0.2em;
  text-align: center;
  background-image: url(../img/title_special_02_sp.png);
  background-size: cover;
  background-position: center;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  padding: calc(16 / 375 * 100vw) calc(10 / 375 * 100vw);
  margin-bottom: calc(25 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-special__title02 {
    font-size: 18px;
    line-height: 2;
    background-image: url(../img/title_special_02_pc.png);
    padding: 10px 10px 16px;
    margin-bottom: 25px;
  }
}

.p-special__title02.-adjustment01 {
  margin-top: calc(47 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-special__title02.-adjustment01 {
    margin-top: 27px;
  }
}

.p-special__text01 {
  font-size: calc(14 / 375 * 100vw);
  line-height: 2.143;
  letter-spacing: 0.1em;
}

@media (min-width: 768px) {
  .p-special__text01 {
    font-size: 16px;
    line-height: 1.875;
  }
}

.p-special__price {
  width: calc(250 / 375 * 100vw);
  margin-top: calc(35 / 375 * 100vw);
  margin-left: auto;
}

@media (min-width: 768px) {
  .p-special__price {
    width: 260px;
    margin-top: 25px;
  }
}

.p-special__price-text {
  display: block;
  font-size: calc(12 / 375 * 100vw);
  line-height: 1.75;
  margin-top: calc(10 / 375 * 100vw);
  text-align: right;
}

@media (min-width: 768px) {
  .p-special__price-text {
    font-size: 14px;
    line-height: 1.5;
    margin-top: 10px;
  }
}

@media (min-width: 768px) {
  .p-special__box-item {
    display: flex;
    justify-content: space-between;
  }
}

.p-special__box-item:nth-child(2) {
  border-bottom: 1px solid #fff;
  margin-top: calc(85 / 375 * 100vw);
  padding-bottom: calc(50 / 375 * 100vw);
}

@media (min-width: 768px) {
  .p-special__box-item:nth-child(2) {
    margin-top: 95px;
    padding-bottom: 100px;
  }
}

@media (min-width: 768px) {
  .p-special__box-item-img {
    width: 370px;
  }
}

.p-special__box-item-caption {
  font-size: calc(14 / 375 * 100vw);
  line-height: 2;
  /* letter-spacing: 0.05em; */
  letter-spacing: 0.1em;
  margin: calc(2 / 375 * 100vw) 0 calc(6 / 375 * 100vw);
  font-family: "Noto Serif JP", serif;
}
@media (min-width: 768px) {
  .p-special__box-item-caption {
    font-size: 14px;
    line-height: calc(27 / 14);
    margin: 6px 0 0;
  }
}

@media (min-width: 768px) {
  .p-special__box-item-content {
    width: 380px;
  }
}

.p-special__sec .c-sns {
  margin-top: 70px;
}

@media (min-width: 768px) {
  .p-special__sec .c-sns {
    margin-top: 100px;
  }
}

.bold {
  font-weight: 700;
}

.under {
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-color: #fff;
  text-decoration-thickness: 1px;
}

/* effect-fade */
.swiper-container-fade.swiper-container-free-mode .swiper-slide {
    transition-timing-function: ease-out;
}
.swiper-container-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity;
}
.swiper-container-fade .swiper-slide .swiper-slide {
    pointer-events: none;
}
.swiper-container-fade .swiper-slide-active, .swiper-container-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto;
}
.swiper-fade .swiper-slide {
    transition-property: opacity !important;
}
