@charset "UTF-8";
/* ブレイクポイントの定義 */
/*
 * htmlのfont-size用
 */
/*
   * font-size可変用
   */
/* color */
/* font */
.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
}

.clearfix:after {
  clear: both;
}

/* For IE 6/7 (trigger hasLayout) */
.clearfix {
  zoom: 1;
}

/* variable */
i {
  margin: auto 20px;
}

/*---------------------------------------------------------------
common
-------------------------------------------------------------- */
html {
  font-size: 2.7vw;
  scroll-behavior: smooth;
}
@media (min-width: 768px) {
  html {
    font-size: clamp(10px, 1.1vw, 14px);
  }
}

:target {
  scroll-margin-top: 50px;
}

body {
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.4rem;
  line-height: 1.6;
  color: #464141;
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
  text-align: justify;
  text-justify: inter-ideograph;
  position: relative;
}

a,
a:hover,
a:visited {
  color: #464141;
  text-decoration: none;
}

img {
  width: 100%;
  vertical-align: bottom;
}

h1,
h2 {
  font-family: "cooper-black-std", serif;
  line-height: 1;
}

.marquee_list {
  display: flex;
  align-items: center;
  gap: 1.6rem;
  padding: 0;
  width: -moz-fit-content;
  width: fit-content;
  /* animationはJSで制御 */
}
.marquee_list li {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.marquee_list li img {
  width: auto;
}

/* ローディング画面 */
#loading {
  position: fixed;
  inset: 0;
  background: #FFEEF4;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 1;
}
#loading .inner {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
#loading .inner ul.beads {
  position: relative;
  width: 37.5rem;
  height: 37.5rem;
}
#loading .inner ul.beads li {
  position: absolute;
  opacity: 0;
  /* 初期状態を透明にする */
}
#loading .inner ul.beads li:nth-child(1) {
  width: 4rem;
  top: 5.6rem;
  left: 6.3rem;
}
#loading .inner ul.beads li:nth-child(2) {
  width: 5.4rem;
  top: 17.7rem;
  left: 9.7rem;
}
#loading .inner ul.beads li:nth-child(3) {
  width: 6rem;
  top: 14.9rem;
  left: 17.5rem;
}
#loading .inner ul.beads li:nth-child(4) {
  width: 5.6rem;
  top: 10.2rem;
  left: 25.7rem;
}
#loading .inner ul.beads li:nth-child(5) {
  width: 3.7rem;
  top: 27.8rem;
  left: 24.3rem;
}
#loading .inner ul.beads li:nth-child(6) {
  width: 5.3rem;
  top: 4rem;
  left: 18.6rem;
}
#loading .inner ul.beads li:nth-child(7) {
  width: 6.1rem;
  top: 20.5rem;
  left: 26.4rem;
}
#loading .inner ul.beads li:nth-child(8) {
  width: 5.8rem;
  top: 24.7rem;
  left: 5.9rem;
}
#loading .inner ul.beads li:nth-child(9) {
  width: 2.5rem;
  top: 11.3rem;
  left: 13.4rem;
}
#loading .inner ul.beads li:nth-child(10) {
  width: 2.6rem;
  top: 16.1rem;
  left: 3.3rem;
}
#loading .inner ul.beads li:nth-child(11) {
  width: 2.7rem;
  top: 5.2rem;
  left: 28.1rem;
}
#loading .inner ul.beads li:nth-child(12) {
  width: 2.6rem;
  top: 30.6rem;
  left: 14.6rem;
}
#loading .inner ul.beads li:nth-child(13) {
  width: 2.6rem;
  top: 16.1rem;
  left: 32rem;
}
#loading .inner ul.beads li:nth-child(14) {
  width: 2.6rem;
  top: 23.7rem;
  left: 18.6rem;
}
#loading .inner ul.chara {
  margin-top: 2.4rem;
  display: flex;
  gap: 0.8rem;
  align-items: flex-end;
}
#loading .inner ul.chara figure {
  width: 8rem;
  opacity: 0;
}

/*-------------------------------
block
--------------------------------- */
.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .pc {
    display: inherit;
  }
}

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

/* ハンバーガーメニュー (SP) */
.gnavi_btn {
  display: block;
  position: fixed;
  z-index: 9999;
  top: 1.6rem;
  right: 2.8rem;
  width: 5.6rem;
  height: 5.6rem;
  background: #EC91AD;
  border-radius: 50%;
  border: none;
  cursor: pointer;
}
.gnavi_btn span {
  display: block;
  position: absolute;
  left: 50%;
  width: 2.4rem;
  height: 3px;
  background-color: #FFFFFF;
  transform: translateX(-50%);
  transition: 0.3s ease-in-out;
}
.gnavi_btn span:nth-child(1) {
  top: 1.9rem;
}
.gnavi_btn span:nth-child(2) {
  top: 2.6rem;
}
.gnavi_btn span:nth-child(3) {
  top: 3.3rem;
}
.gnavi_btn.is-open span:nth-child(1) {
  top: 2.6rem;
  transform: translateX(-50%) rotate(45deg);
}
.gnavi_btn.is-open span:nth-child(2) {
  opacity: 0;
}
.gnavi_btn.is-open span:nth-child(3) {
  top: 2.6rem;
  transform: translateX(-50%) rotate(-45deg);
}
.gnavi_btn {
  /* 初期状態は非表示 */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}
.gnavi_btn.is-visible {
  opacity: 1;
  visibility: visible;
}
@media screen and (min-width: 768px) {
  .gnavi_btn {
    display: none;
  }
}

@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
/*---------------------------------------------------------------
 navi
-------------------------------------------------------------- */
#wrapper {
  width: 100%;
  margin: 0;
  position: relative;
  z-index: 1;
}
#wrapper::before {
  content: "";
  position: fixed;
  top: -20px;
  left: -20px;
  right: -20px;
  bottom: -20px;
  border: solid 5px;
  background-image: url("../images/bg_img.webp");
  background-position: center center;
  background-size: cover;
  filter: blur(60px);
  z-index: -1;
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  .contents_area {
    display: flex;
    justify-content: center;
  }
}
.contents_area {
  /* ---------- center ---------- */
}
.contents_area .center {
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .contents_area .center {
    width: 37.5rem;
    margin: 5.4rem 0;
    order: 2;
    border-radius: 1.6rem;
    overflow: visible;
  }
}
.contents_area .center .bg_area {
  background: url(../images/bg.webp) #fff;
}
@media screen and (min-width: 768px) {
  .contents_area .center .bg_area {
    border-radius: 1.6rem 1.6rem 0 0;
  }
}
.contents_area .center {
  /*-------------------------------
  main
  --------------------------------- */
}
.contents_area .center .wrap {
  padding-bottom: 8.8rem;
  overflow: hidden;
}
.contents_area .center main {
  width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
  position: relative;
  background: #FFCADC;
}
@media screen and (min-width: 768px) {
  .contents_area .center main {
    border-radius: 1.6rem 1.6rem 0 0;
  }
}
.contents_area .center main .copy {
  position: absolute;
  top: 6.4rem;
  left: 0;
  z-index: 3;
}
.contents_area .center main .copy span {
  padding: 0 0.8rem;
  margin-bottom: 0.4rem;
  background: #FFFFFF;
  color: #464141;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  display: inline-block;
}
.contents_area .center main .main_image {
  width: 100%;
  padding-top: 210.6666666667%;
  aspect-ratio: 375/790;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.contents_area .center main .main_image .slick-list {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.contents_area .center main .main_image .slick-track, .contents_area .center main .main_image .slick-slide > div, .contents_area .center main .main_image .slick-slide {
  height: 100%;
}
.contents_area .center main .main_image li {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: width 0.1s ease, height 0.1s ease;
  /* リサイズ時のカクつきを軽減 */
}
.contents_area .center main .main_image li img {
  margin-bottom: 16rem;
}
.contents_area .center main .main_image .slide-1 {
  background: #FFCADC;
}
.contents_area .center main .main_image .slide-2 {
  background: #B7D9ED;
}
.contents_area .center main h1 {
  position: absolute;
  top: 46.6rem;
  left: 49%;
  transform: translateX(-50%);
  width: 37.5rem;
  padding: 0 5.8rem;
  transition: filter 3s ease;
  z-index: 2;
}
.contents_area .center main h1 img {
  width: 100%;
}
.contents_area .center main h1 .beads li {
  position: absolute;
}
.contents_area .center main h1 .beads li:nth-child(1) {
  top: 6rem;
  left: 2.4rem;
  width: 4.3rem;
}
.contents_area .center main h1 .beads li:nth-child(2) {
  top: 2.4rem;
  right: 1.6rem;
  width: 2.4rem;
}
.contents_area .center main h1 .beads li:nth-child(3) {
  top: 6.4rem;
  right: 2.4rem;
  width: 4.2rem;
}
.contents_area .center main.view-slide-1 h1 {
  filter: drop-shadow(8px 12px 12px #C25A7D);
  filter: drop-shadow(8px 12px 12px rgba(194, 90, 125, 0.7));
}
.contents_area .center main.view-slide-2 h1 {
  filter: drop-shadow(8px 12px 12px #5AA8C2);
  filter: drop-shadow(8px 12px 12px rgba(90, 168, 194, 0.7));
}
.contents_area .center .howto_area {
  width: 200%;
  margin-top: -12rem;
  margin-left: -50%;
  padding: 8.8rem 50%;
  text-align: center;
  background: #FFEEF4;
  border-radius: 100vh;
  position: relative;
  z-index: 2;
}
.contents_area .center .howto_area::before {
  content: "";
  position: absolute;
  top: -2.4rem;
  left: 50%;
  transform: translateX(-50%);
  width: 35.4rem;
  height: 8.2rem;
  background: url(../images/deco_top.webp) no-repeat center/contain;
  filter: drop-shadow(4px 6px 3px #464141);
  filter: drop-shadow(4px 6px 3px rgba(70, 65, 65, 0.1));
}
.contents_area .center .howto_area::after {
  content: "";
  position: absolute;
  bottom: -2.4rem;
  left: 50%;
  transform: translateX(-50%);
  width: 35.4rem;
  height: 8.2rem;
  background: url(../images/deco_btm.webp) no-repeat center/contain;
  filter: drop-shadow(4px 6px 3px #464141);
  filter: drop-shadow(4px 6px 3px rgba(70, 65, 65, 0.1));
}
.contents_area .center .howto_area h2 {
  margin-bottom: 5.6rem;
  font-size: 4.4rem;
  color: #FFFFFF;
  -webkit-text-stroke: 1px #EC91AD;
}
.contents_area .center .howto_area h2 .copy {
  display: inline-block;
  position: relative;
  margin-bottom: 2.4rem;
  padding: 0.8rem 1.6rem;
  background-color: #EC91AD;
  color: #FFFFFF;
  font-size: 1.4rem;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  letter-spacing: 0.1em;
  -webkit-text-stroke: 0;
  border-radius: 1.6rem;
}
.contents_area .center .howto_area h2 .copy::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #EC91AD transparent transparent transparent;
}
.contents_area .center .howto_area h2 .copy .big {
  font-size: 1.6rem;
}
.contents_area .center .howto_area ul.slick-dotted {
  margin-bottom: 3rem;
}
.contents_area .center .howto_area ul .slick-dots {
  position: absolute;
  bottom: -3rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  pointer-events: auto;
  display: flex;
  justify-content: center;
}
.contents_area .center .howto_area ul .slick-dots li {
  width: 1.2rem;
  height: 1.6rem;
  margin: 0;
  padding: 0;
}
.contents_area .center .howto_area ul .slick-dots li button {
  padding: 0;
}
.contents_area .center .howto_area ul .slick-dots li button:before {
  font-size: 0.8rem;
  color: #EC91AD;
  opacity: 0.5;
}
.contents_area .center .howto_area ul .slick-dots li.slick-active {
  display: flex;
  justify-content: center;
  align-items: center;
}
.contents_area .center .howto_area ul .slick-dots li.slick-active button:before {
  color: #EC91AD;
  opacity: 1;
}
.contents_area .center .howto_area ul .slick-arrow {
  z-index: 10;
  background: #FFFFFF;
  width: 3rem;
  height: 3rem;
  border-radius: 100vh;
  top: 45%;
}
.contents_area .center .howto_area ul .slick-arrow::before {
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 1, "wght" 300;
  color: #EC91AD;
  font-size: 4.2rem;
  opacity: 1;
  position: relative;
  top: -0.5rem;
  left: -0.5rem;
}
.contents_area .center .howto_area ul .slick-prev {
  left: 3.2rem;
  top: 45%;
}
.contents_area .center .howto_area ul .slick-prev::before {
  content: "expand_circle_right";
  display: inline-block;
  transform: scaleX(-1);
}
.contents_area .center .howto_area ul .slick-next {
  right: 3.2rem;
}
.contents_area .center .howto_area ul .slick-next::before {
  content: "expand_circle_right";
}
.contents_area .center .howto_area ul li {
  transform: scale(0.9);
  transition: transform 0.3s;
}
.contents_area .center .howto_area ul li.slick-center {
  transform: scale(1);
}
.contents_area .center .howto_area ul li .step {
  padding: 0;
  line-height: 1;
  font-size: 2.6rem;
  font-family: "cooper-black-std", serif;
  color: #EC91AD;
  position: relative;
  z-index: 1;
  margin-bottom: 1.6rem;
}
.contents_area .center .howto_area ul li .step span {
  font-size: 4rem;
}
.contents_area .center .howto_area ul li figure {
  margin-bottom: 1.6rem;
  border: solid 1px #FFCADC;
}
.contents_area .center .howto_area ul li .txt1 {
  font-size: 1.8rem;
  color: #EC91AD;
}
.contents_area .center .howto_area ul li .txt2 {
  font-size: 1.2rem;
  line-height: 150%;
}
.contents_area .center .styling_area {
  width: 100%;
  padding: 0 4.8rem 8.8rem;
  text-align: center;
}
.contents_area .center .styling_area h2 {
  margin-bottom: 5.6rem;
  font-size: 4.4rem;
  color: #EC91AD;
}
.contents_area .center .styling_area h2 .copy {
  display: block;
  margin-bottom: 2.4rem;
  font-size: 1.4rem;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  letter-spacing: 0.1em;
  line-height: 150%;
}
.contents_area .center .styling_area .style > li {
  margin-bottom: 5.6rem;
}
.contents_area .center .styling_area .style > li .img {
  margin-bottom: 2.4rem;
  position: relative;
}
.contents_area .center .styling_area .style > li .img .copy {
  position: absolute;
  top: -1.6rem;
  right: -1.6rem;
  writing-mode: vertical-rl;
  font-feature-settings: initial;
  background: #FFEEF4;
  color: #EC91AD;
  padding: 1.6rem 0.8rem;
  letter-spacing: 0.15em;
  font-weight: 700;
  text-align: center;
}
.contents_area .center .styling_area .style > li .img .theme {
  padding: 0;
  position: absolute;
  top: -2.4rem;
  left: -1.6rem;
  color: #FFFFFF;
  font-family: "cooper-black-std", serif;
  font-size: 7.2rem;
  text-align: left;
  line-height: 1;
  -webkit-text-stroke: 1px #EC91AD;
}
.contents_area .center .styling_area .style > li .img .beads > li {
  position: absolute;
  transform: scale(1.1);
  filter: drop-shadow(4px 6px 3px #464141);
  filter: drop-shadow(4px 6px 3px rgba(70, 65, 65, 0.1));
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_1 {
  top: 18.5rem;
  left: -4.8rem;
  width: 5.4rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_2 {
  top: 28rem;
  right: -5.4rem;
  width: 3.8rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_3 {
  top: 34rem;
  left: -1rem;
  width: 2.4rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_4 {
  top: 10rem;
  right: -2.4rem;
  width: 2.5rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_5 {
  top: 18rem;
  right: -6rem;
  width: 4.2rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_6 {
  top: 32.8rem;
  left: -6.2rem;
  width: 6rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_7 {
  top: 34rem;
  right: -1rem;
  width: 5.8rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_8 {
  top: 34rem;
  left: -5.8rem;
  width: 2.6rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_9 {
  top: 24.5rem;
  left: -2.4rem;
  width: 4.8rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_10 {
  top: 24rem;
  left: -1.4rem;
  width: 2.5rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_11 {
  top: 24rem;
  right: -3.2rem;
  width: 3.8rem;
}
.contents_area .center .styling_area .style > li .img .beads > li.bd_12 {
  top: 30rem;
  left: -6.4rem;
  width: 5.3rem;
}
.contents_area .center .styling_area .style > li .credit {
  text-align: left;
}
.contents_area .center .styling_area .style > li .credit li {
  margin-bottom: 1.6rem;
  position: relative;
}
.contents_area .center .styling_area .style > li .credit li .name {
  width: 70%;
  font-size: 1.1rem;
}
.contents_area .center .styling_area .style > li .credit li .price {
  width: 70%;
  font-size: 1.1rem;
}
.contents_area .center .styling_area .style > li .credit li a {
  width: 25%;
  padding: 0.4rem 1.6rem;
  font-size: 1.2rem;
  color: #FFFFFF;
  position: absolute;
  right: 0;
  top: 0;
  background: #EC91AD;
  display: block;
  text-align: center;
  border-radius: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.contents_area .center .styling_area .style > li .credit li a::before {
  content: "add_shopping_cart";
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 0, "wght" 300;
  font-size: 1.6rem;
  margin-right: 0.4rem;
  line-height: 1;
}
.contents_area .center .styling_area .style > li:nth-child(even) .img .copy {
  top: -1.6rem;
  left: -1.6rem;
  right: auto;
}
.contents_area .center .styling_area .style > li:nth-child(even) .img .theme {
  top: -2.4rem;
  right: -1.6rem;
  left: auto;
}
.contents_area .center .item_area {
  width: 100%;
  padding: 0 1.6rem 0;
  text-align: center;
}
.contents_area .center .item_area h2 {
  margin-bottom: 5.6rem;
  font-size: 4.4rem;
  color: #EC91AD;
}
.contents_area .center .item_area .deco_scroll_wrap {
  width: calc(100% + 3.2rem);
  margin-left: -1.6rem;
  margin-right: -1.6rem;
  overflow: hidden;
  margin-bottom: 5.4rem;
}
.contents_area .center .item_area .deco_scroll {
  width: 154rem;
  display: flex;
  animation: marquee-loop 40s linear infinite;
}
.contents_area .center .item_area .deco_scroll li {
  width: 15.4rem;
  flex-shrink: 0;
}
.contents_area .center .item_area .deco_scroll li img {
  width: 100%;
  height: auto;
  filter: drop-shadow(4px 6px 3px #464141);
  filter: drop-shadow(4px 6px 3px rgba(70, 65, 65, 0.1));
}
.contents_area .center .item_area .notice {
  margin: 0 auto 6.4rem;
  padding: 2.4rem;
  font-size: 1.2rem;
  text-align: left;
  background: #FFEEF4;
  border-radius: 1.6rem;
}
.contents_area .center .item_area .notice h3 {
  font-size: 1.4rem;
  text-align: center;
}
.contents_area .center .item_area .navi {
  width: 100%;
  display: flex;
  gap: 0.8rem;
  justify-content: center;
  margin-bottom: 2.4rem;
}
.contents_area .center .item_area .navi li {
  width: 50%;
}
.contents_area .center .item_area .navi li a {
  width: 100%;
  padding: 0.8rem 1.6rem;
  border-radius: 100vh;
  color: #FFFFFF;
  background: #EC91AD;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.contents_area .center .item_area .navi li a::before {
  content: "expand_circle_down";
  font-family: "Material Symbols Outlined";
  margin-right: 0.4rem;
  font-size: 2rem;
}
.contents_area .center .item_area .navi li:last-child a {
  background: #5BBCEC;
}
.contents_area .center .item_area article {
  width: calc(100% + 3.2rem);
  margin-left: -1.6rem;
  margin-right: -1.6rem;
  padding: 0 0 8.8rem;
}
.contents_area .center .item_area article.item_1 {
  background: #FFCADC;
}
.contents_area .center .item_area article.item_1 .item_slider li {
  background-color: rgba(236, 145, 173, 0.3);
}
.contents_area .center .item_area article.item_2 {
  background: #B7D9ED;
}
.contents_area .center .item_area article.item_2 .item_slider li {
  background-color: rgba(91, 188, 236, 0.3);
}
.contents_area .center .item_area article figure {
  margin-bottom: -0.4rem;
}
.contents_area .center .item_area article h3 {
  margin-bottom: 5.6rem;
  padding: 0 3.2rem;
  text-align: center;
}
.contents_area .center .item_area article h3 .num {
  margin-bottom: 0.8rem;
  font-size: 4.8rem;
  line-height: 1;
  display: block;
  color: #FFFFFF;
  font-family: "cooper-black-std", serif;
}
.contents_area .center .item_area article h3 .num span {
  padding-bottom: 0.4rem;
  font-size: 1.8rem;
  display: inline-block;
  border-bottom: solid 1px;
}
.contents_area .center .item_area article h3 .lead {
  font-size: 1.8rem;
  font-weight: 700;
  color: #464141;
  display: inline;
}
.contents_area .center .item_area article .item_list_area {
  width: 100%;
}
.contents_area .center .item_area article .item_list_area .item_list_main {
  margin: 0 0 3.2rem;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li {
  margin-bottom: 3.2rem;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a {
  width: 100%;
  display: block;
  overflow: hidden;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .image {
  margin-bottom: 1.6rem;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .image.step-scroll {
  display: flex;
  animation: step-scroll 16s ease-in-out infinite;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .image li {
  width: 11.2rem;
  flex-shrink: 0;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .credit {
  line-height: 1.3;
  padding: 0;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .credit .name {
  font-size: 1.3rem;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .credit .price {
  margin-bottom: 0.8rem;
  font-size: 1.7rem;
  letter-spacing: 0;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .credit .price span {
  font-size: 0.9rem;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .credit button {
  margin: 0 auto;
  padding: 0.4rem 1.6rem;
  font-size: 1.2rem;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  color: #464141;
  border-radius: 100vh;
  border: dotted 1px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #FFFFFF;
}
.contents_area .center .item_area article .item_list_area .item_list_main > li a .credit button::before {
  content: "add_shopping_cart";
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 0, "wght" 300;
  font-size: 1.6rem;
  margin-right: 0.4rem;
  line-height: 1;
}
.contents_area .center .item_area article .item_list_area .item_list_sub {
  width: 90%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.contents_area .center .item_area article .item_list_area .item_list_sub.slick-initialized {
  display: block;
  gap: 0;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li {
  padding: 1.6rem 0;
  width: calc((100% - 0.8rem) / 2);
}
.slick-initialized .contents_area .center .item_area article .item_list_area .item_list_sub > li {
  width: auto;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image {
  width: 90%;
  margin: 0 auto 1.6rem;
  position: relative;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image li {
  padding: 0.8rem;
  border-radius: 100vh;
  overflow: hidden;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots {
  position: absolute;
  bottom: -1.4rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  pointer-events: auto;
  display: flex;
  justify-content: center;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots li {
  width: 1.2rem;
  height: 1.6rem;
  margin: 0;
  padding: 0;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots li button {
  padding: 0;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots li button:before {
  font-size: 0.5rem;
  color: #FFFFFF;
  opacity: 0.5;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots li.slick-active {
  display: flex;
  justify-content: center;
  align-items: center;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots li.slick-active button:before {
  color: #FFFFFF;
  opacity: 1;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .image .slick-dots li:only-child {
  display: none;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .credit {
  line-height: 1.3;
  text-align: center;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .credit .name {
  font-size: 1.3rem;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .credit .price {
  margin-bottom: 0.8rem;
  font-size: 1.7rem;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .credit .price span {
  font-size: 0.9rem;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .credit button {
  margin: 0 auto;
  padding: 0.4rem 1.6rem;
  font-size: 1.2rem;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  color: #464141;
  border-radius: 100vh;
  border: dotted 1px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #FFFFFF;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li a .credit button::before {
  content: "add_shopping_cart";
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 0, "wght" 300;
  font-size: 1.6rem;
  margin-right: 0.4rem;
  line-height: 1;
}
.contents_area .center .item_area article .item_list_area .more_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80%;
  margin: 2.4rem auto 0;
  padding: 0.8rem;
  background: #FFCADC;
  color: #464141;
  border: solid 1px;
  border-radius: 100vh;
  font-size: 1.4rem;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  cursor: pointer;
  transition: background-color 0.3s;
  box-shadow: 4px 4px 0 #464141;
}
.contents_area .center .item_area article .item_list_area .more_btn::before {
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;
  font-weight: 300;
  font-style: normal;
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  margin-right: 0.4rem;
}
.contents_area .center .item_area article .item_list_area .more_btn:not(.is-open)::before {
  content: "expand_circle_down";
}
.contents_area .center .item_area article .item_list_area .more_btn.is-open::before {
  content: "expand_circle_up";
}
.contents_area .center .item_area article .item_list_area .more_btn.is-open .close-text {
  display: inline;
}
.contents_area .center .item_area article .item_list_area .more_btn.is-open .open-text {
  display: none;
}
.contents_area .center .item_area article .item_list_area .more_btn .close-text {
  display: none;
}
.contents_area .center .item_area article .item_list_area .item_list_sub > li:nth-child(n+5) {
  display: none;
}
.contents_area .center .item_area article.item_1 .item_list_area::before,
.contents_area .center .item_area article.item_2 .item_list_area::before {
  background: rgba(183, 217, 237, 0.5);
}
.contents_area .center .item_area .copyright {
  padding: 0 1.6rem;
  text-align: center;
  font-weight: 400;
}
.contents_area .center .item_area .copyright figure {
  width: 16rem;
  margin: 0 auto 3.2rem;
}
.contents_area .center .item_area .copyright figure a {
  margin: 0 auto;
  padding: 0;
  display: block;
}
.contents_area .center .item_area .copyright figure a svg path {
  fill: #FFFFFF;
}
.contents_area .center .item_area .copyright small {
  text-align: center;
  font-size: 1rem;
}
.contents_area .center .movie_area {
  width: 100%;
  padding: 8.8rem 4rem;
  text-align: center;
}
.contents_area .center .movie_area h2 {
  margin-bottom: 5.6rem;
  font-size: 4.4rem;
  color: #EC91AD;
}
.contents_area .center .movie_area p {
  font-size: 1.2rem;
  line-height: 180%;
}
.contents_area .center .movie_area .youtube {
  margin: 4rem auto;
  width: 100%;
  max-width: 60rem;
  aspect-ratio: 16/9;
}
.contents_area .center .movie_area .youtube iframe {
  width: 100%;
  height: 100%;
}
.contents_area .center .movie_area a {
  width: 100%;
  padding: 0.8rem 1.6rem;
  border-radius: 100vh;
  color: #FFFFFF;
  background: #EC91AD;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.contents_area .center .movie_area a::before {
  content: "expand_circle_right";
  font-family: "Material Symbols Outlined";
  margin-right: 0.4rem;
  font-size: 2rem;
}
.contents_area .center .concept_area {
  padding: 8.8rem 4rem;
  background: rgba(255, 255, 255, 0.1);
}
.contents_area .center .concept_area .box {
  padding: 8.8rem 3.2rem 6.4rem;
  background: #FFFFFF;
  border-radius: 100vh 100vh 0 0;
  color: #EC91AD;
  text-align: center;
}
.contents_area .center .concept_area .box h2 {
  font-size: 1.8rem;
  line-height: 100%;
  margin-bottom: 3.2rem;
}
.contents_area .center .concept_area .box h3 {
  font-size: 4.8rem;
  line-height: 100%;
}
.contents_area .center .concept_area .box h3 span {
  margin: 1.6rem 0;
  font-size: 1.1rem;
  line-height: 100%;
  display: block;
}
.contents_area .center .concept_area .box p {
  font-size: 1.2rem;
  line-height: 180%;
}
.contents_area .center {
  /* 横スクロール用 */
}
@keyframes marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-1 * var(--marquee-width)));
  }
}
@keyframes marquee-loop {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes step-scroll {
  0% {
    transform: translateX(0rem);
  }
  /* 1枚目 */
  10% {
    transform: translateX(0rem);
  }
  12.5% {
    transform: translateX(-12rem);
  }
  /* 2枚目 */
  22.5% {
    transform: translateX(-12rem);
  }
  25% {
    transform: translateX(-24rem);
  }
  /* 3枚目 */
  35% {
    transform: translateX(-24rem);
  }
  37.5% {
    transform: translateX(-36rem);
  }
  /* 4枚目 */
  47.5% {
    transform: translateX(-36rem);
  }
  50% {
    transform: translateX(-48rem);
  }
  /* 5枚目 */
  60% {
    transform: translateX(-48rem);
  }
  62.5% {
    transform: translateX(-60rem);
  }
  /* 6枚目 */
  72.5% {
    transform: translateX(-60rem);
  }
  75% {
    transform: translateX(-72rem);
  }
  /* 7枚目 */
  85% {
    transform: translateX(-72rem);
  }
  87.5% {
    transform: translateX(-84rem);
  }
  /* 8枚目 */
  97.5% {
    transform: translateX(-84rem);
  }
  100% {
    transform: translateX(-96rem);
  }
  /* ループ（8枚 * 12rem） */
}
.contents_area {
  /* ---------- /center ---------- */
}

/* ---------- left ---------- */
.left_box {
  display: none;
}
@media screen and (min-width: 768px) {
  .left_box {
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc((100% - 37.5rem) / 2);
    position: sticky;
    top: 0;
    order: 1;
  }
}

/* ---------- /left ---------- */
/* ---------- right ---------- */
.right_box {
  display: none;
}
@media screen and (min-width: 768px) {
  .right_box {
    display: flex;
    position: sticky;
    height: 100vh;
    top: 0;
    justify-content: center;
    align-items: center;
    width: calc((100% - 37.5rem) / 2);
    order: 3;
  }
}
.right_box.is-open {
  display: flex;
  position: fixed;
  inset: 0;
  background: #EC91AD;
  z-index: 9998;
  justify-content: center;
  align-items: center;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.3s, visibility 0.3s;
}
.right_box.is-open {
  opacity: 1;
  visibility: visible;
}
.right_box ul.gnavi {
  margin: 2.4rem;
  padding: 6.4rem 4rem 2.4rem;
  border-radius: 100vh 100vh 0 0;
  color: #FFFFFF;
}
.right_box ul.gnavi > li {
  margin-bottom: 1.6rem;
}
.right_box ul.gnavi > li a {
  padding: 0;
  color: #FFFFFF;
  font-size: 1.8rem;
  text-align: center;
  font-family: "cooper-black-std", serif;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  display: block;
}
.right_box ul.gnavi > li a span {
  margin-top: 0.8rem;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-size: 0.9rem;
  display: block;
  letter-spacing: 0.05em;
}

/* ---------- /right ---------- */
/* --------------------------------------------
 footer
-------------------------------------------- */
footer {
  width: 100%;
  padding: 9.6rem 1.6rem;
  text-align: center;
  color: #464141;
  font-weight: 400;
  background: url(../images/bg.webp) #fff;
}
@media screen and (min-width: 768px) {
  footer {
    border-radius: 0 0 1.6rem 1.6rem;
  }
}
footer .f_logo {
  width: 12rem;
  margin: 0 auto;
}
footer .f_logo a {
  margin: 0 auto;
  padding: 0;
  display: block;
}
footer .f_logo a svg path {
  fill: #464141;
}
footer .f_icon {
  margin: 3.2rem auto 1.6rem;
  padding: 0;
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
footer .f_icon li {
  margin: 0 1.2rem;
  padding: 0;
}
footer .f_icon li i {
  margin: 0;
  font-size: 2rem;
  color: #464141;
}
footer small {
  text-align: center;
  font-size: 1rem;
}

/*------------------------------
animation
-------------------------------*/
.invisible {
  transition: opacity 0.5s ease;
  opacity: 0;
}

.visible {
  transition: opacity 0.5s ease;
  opacity: 1;
}/*# sourceMappingURL=style.css.map */