@charset "UTF-8";
:root {
  --clip: 100%;
}
body {
  background: #fff100;
}
img {
  vertical-align: bottom !important;
}
/* loading -------------------- */
.l-loading {
  visibility: visible;
  z-index: 999;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #ffcc00;
  text-align: center;
  -webkit-clip-path: circle(var(--clip) at 50% 50%);
  clip-path: circle(var(--clip) at 50% 50%);
  opacity: 1;
}
.l-loading_bg {
  -webkit-animation: rotateLoop 10s linear infinite;
  animation: rotateLoop 10s linear infinite;
}
.l-loading_logo_img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8.05271vw;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.l-loading_logo_img_wrapper {
  visibility: hidden;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 19.76574vw;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  opacity: 0;
}
/* kv -------------------- */
.l-kv_wrap {
  position: relative;
  display: flow-root;
  overflow: hidden;
  background: #ffd100 url("../img/l-kv_bg_pc.jpg") no-repeat bottom center / cover;
}
.l-kv_wrap img {
  display: block;
  width: 100%;
  height: auto;
}
.p-kv_copySet {
  position: relative;
  z-index: 2;
  width: 53.99%;
  margin: 1.54% auto 0 15.59%;
}
.p-kv_copy01 {
  display: block;
  width: 85.9%;
  margin: 1.08% 0 0 4%;
}
.p-kv_copy02 {
  display: block;
  width: 100%;
  margin-inline: auto;
}
.p-kv_txt01 {
  position: absolute;
  top: 0;
  right: 0;
  width: 9.11%;
  margin: 1.28% 3.22% 0;
}
.p-kv_txt01 span {
  position: relative;
  display: block;
}
.p-kv_txt01 img {
  position: relative;
  z-index: 2;
  display: block;
}
.p-kv_txt01 span::before {
  content: "";
  position: absolute;
  z-index: 1;
  left: 0;
  width: 100%;
  height: 9vw;
  background: url("../img/l-kv_txt04_steam.png") no-repeat top left / contain;
}
.p-kv_txt02 {
  position: absolute;
  z-index: 2;
  top: 0;
  right: 0;
  width: 20.31%;
  margin: 22.36% -3% 0 0;
}
.p-kv_guinness {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 12.74%;
  margin: 11.09% 0 0 3.22%;
  pointer-events: none;
}
.p-kv_img {
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  width: 37.3%;
  margin: 1.46% 3.26% 0 0;
}
.p-kv_notes {
  position: relative;
  z-index: 2;
  width: 36.68%;
  margin: 1.5% 3% .88%;
}
/* kv animation -------------------- */
@media screen and (max-width: 767px) {
  .l-kv_wrap {
    background: #ffd100 url("/img/l-kv_bg.jpg") no-repeat bottom center / cover;
  }
  .p-kv_copySet {
    width: 82.9%;
    margin: 2.1% auto 0;
  }
  .p-kv_copy01 {
    margin: -.5% 0 0 4%;
  }
  .p-kv_guinness {
    width: 21%;
    margin: 88% 0 0 5%;
  }
  .p-kv_txt01 {
    width: 15.0%;
    margin: 73.5% 5.2% 0;
  }
  .p-kv_txt02 {
    width: 40%;
    margin: 91.36% -4% 0 0;
  }
  .p-kv_img {
    width: 60%;
    margin: 64.6% 19% 0 0;
    transform: rotate(-3.4deg);
  }
  .p-kv_notes {
    width: 100%;
    margin: 68% auto 0;
  }
  /* kv animation sp -------------------- */
}
.l-product {
  position: relative;
  z-index: 2;
  padding-top: 5.85652vw;
  background: #ffcc00;
  overflow: hidden;
  border-top: 5px solid #000;
}
.l-product.is-none .l-product_img_wrapper {
  visibility: hidden;
  -webkit-transform: translate(-100%, 0);
  transform: translate(-100%, 0);
  opacity: 0;
}
.l-product_wrapper {
  margin: 0 auto -2.56223vw;
}
.l-product_ttl {
  display: block;
  z-index: 1;
  position: relative;
  width: 16.54466vw;
  margin: 0 auto;
}
.l-product_ttl_sub {
  z-index: 1;
  position: absolute;
  top: 7.54026vw;
  right: 4.61201vw;
  width: 16.10542vw;
}
.l-product_btn_link {
  position: relative;
  bottom: -1.61054vw;
  margin: 0 auto;
}
.l-product_slider_wrapper {
  width: 62.95754vw;
  margin: 0 0 0 auto;
  padding-top: 2.92826vw;
  padding-bottom: 6.58858vw;
  padding-left: 2.92826vw;
  overflow-x: hidden;
}
.l-product_slider_wrapper .swiper {
  overflow: visible;
}
.l-product_slider_wrapper .swiper-slide {
  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;
  width: 20.4978vw;
}
.l-product_slider_wrapper .swiper-slide[data-size="small"] .l-product_slider_item_img {
  -webkit-transform: scale(0.47);
  transform: scale(0.47);
}
.l-product_slider_wrapper .swiper-slide[data-size="large"] .l-product_slider_item_img {
  -webkit-transform: scale(0.6);
  transform: scale(0.6);
}
.l-product_slider_wrapper .swiper-slide .l-product_slider_item {
  position: relative;
}
.l-product_slider_wrapper .swiper-slide .l-product_slider_item_img {
  -webkit-backface-visibility: hidden;
  max-height: 20.4978vw;
  -webkit-transform: scale(0.5);
  transform: scale(0.5);
  backface-visibility: hidden;
  -webkit-transition: -webkit-transform .5s;
  transition: -webkit-transform .5s;
  transition: transform .5s;
  transition: transform .5s, -webkit-transform .5s;
  will-change: transform;
}
.l-product_slider_wrapper .swiper-slide-active {
  visibility: visible;
  margin-right: 0 !important;
  opacity: 1;
}
.l-product_slider_wrapper .swiper-slide-active.is-none {
  visibility: hidden;
  opacity: 0;
}
.l-product_slider_wrapper .swiper-slide-prev {
  visibility: hidden;
  z-index: 1;
  opacity: 0;
}
.l-product_slider_wrapper .swiper-wrapper {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: auto;
}
.l-product_slider_wrapper .swiper-controller {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  top: -2.19619vw;
  left: -16.10542vw;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 37.84773vw;
}
.l-product_slider_wrapper .swiper-slide-active .l-product_slider_item {
  z-index: 1;
  opacity: 1;
}
.l-product_slider_wrapper .swiper-slide-active .l-product_slider_item_img {
  -webkit-backface-visibility: hidden;
  max-height: 20.4978vw;
  -webkit-transform: scale(var(--slideScale));
  transform: scale(var(--slideScale));
  backface-visibility: hidden;
}
.l-product_slider_wrapper .swiper-slide-active[data-size="small"] .l-product_slider_item_img {
  -webkit-transform: scale(var(--slideScale));
  transform: scale(var(--slideScale));
}
.l-product_slider_wrapper .swiper-slide-active[data-size="small"] .l-product_btn_link {
  bottom: -1.31772vw;
}
.l-product_slider_wrapper .swiper-slide-active[data-size="large"] .l-product_slider_item_img {
  -webkit-transform: scale(var(--slideScale));
  transform: scale(var(--slideScale));
}
.l-product_slider_wrapper .swiper-slide-active[data-size="large"] .l-product_btn_link {
  bottom: -1.24451vw;
}
.l-product_slider_wrapper .swiper-button-prev {
  z-index: 1;
  position: relative;
  width: 4.39239vw;
  height: 4.39239vw;
  cursor: pointer;
}
.l-product_slider_wrapper .swiper-button-prev img {
  position: absolute;
  top: 1.61054vw;
  left: 1.1713vw;
  width: 1.75695vw;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
.l-product_slider_wrapper .swiper-button-prev::before {
  display: inline-block;
  visibility: initial;
  position: absolute;
  left: 0;
  width: 4.39239vw;
  height: 4.39239vw;
  border: 2px solid #000;
  border-radius: 50%;
  background: #fff100;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  content: "";
}
.l-product_slider_wrapper .swiper-button-next {
  z-index: 1;
  position: relative;
  width: 4.39239vw;
  height: 4.39239vw;
  cursor: pointer;
}
.l-product_slider_wrapper .swiper-button-next img {
  position: absolute;
  top: 1.61054vw;
  left: 1.46413vw;
  width: 1.75695vw;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.l-product_slider_wrapper .swiper-button-next::before {
  display: inline-block;
  visibility: initial;
  position: absolute;
  left: 0;
  width: 4.39239vw;
  height: 4.39239vw;
  border: 2px solid #000;
  border-radius: 50%;
  background: #fff100;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  content: "";
}
.l-product_slider_img {
  display: block;
  margin: 0 auto;
}
.l-product_slider_img_wrapper {
  width: min(10.981vw, 15rem);
  margin-right: min(4.392vw, 6rem);
}
.l-product_slider_content {
  width: min(10.981vw, 15rem);
}
.l-product_slider_prev {
  position: absolute;
  top: min(11.347vw, 15.5rem);
  left: max(-2.196vw, -3rem);
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
}
.l-product_slider_prev::before {
  display: block;
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
  border-radius: 50%;
  background: #d82a17;
  content: "";
  cursor: pointer;
  -webkit-transition: background 0.4s, opacity 0.4s, visibility 0.4s;
  transition: background 0.4s, opacity 0.4s, visibility 0.4s;
}
.l-product_slider_prev::after {
  display: inline-block;
  visibility: initial;
  z-index: 1;
  position: absolute;
  top: min(1.611vw, 2.2rem);
  left: min(0.878vw, 1.2rem);
  width: min(2.343vw, 3.2rem);
  height: min(0.878vw, 1.2rem);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  background: url(/img/common/p-arrow_btn_white_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  cursor: pointer;
}
.l-product_slider_next {
  position: absolute;
  top: min(11.347vw, 15.5rem);
  right: min(13.909vw, 19rem);
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
}
.l-product_slider_next::before {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
  border-radius: 50%;
  background: #d82a17;
  content: "";
  cursor: pointer;
  -webkit-transition: background 0.4s, opacity 0.4s, visibility 0.4s;
  transition: background 0.4s, opacity 0.4s, visibility 0.4s;
}
.l-product_slider_next::after {
  display: inline-block;
  visibility: initial;
  position: absolute;
  top: min(1.83vw, 2.5rem);
  right: min(1.098vw, 1.5rem);
  width: min(2.343vw, 3.2rem);
  height: min(1.171vw, 1.6rem);
  background: url(/img/common/p-arrow_btn_white_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  cursor: pointer;
}
.l-product_btn_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  visibility: hidden;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0;
}
.l-product_btn_wrapper {
  margin-top: min(4.392vw, 6rem);
  text-align: right;
}
.l-product_bg {
  display: inline-block;
  visibility: initial;
  z-index: 0;
  position: absolute;
  top: -35vw;
  left: -7%;
  width: 114vw;
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-animation: rotateLoop 40s linear infinite;
  animation: rotateLoop 40s linear infinite;
  content: '';
  will-change: transform;
}
.l-product_img_wrapper {
  display: inline-block;
  visibility: visible;
  visibility: initial;
  z-index: 0;
  position: absolute;
  top: -6.58858vw;
  left: -16.83748vw;
  width: 67.93558vw;
  height: 39.53148vw;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  opacity: 1;
  -webkit-transition: opacity 0.4s, visibility 0.4s, -webkit-transform 0.4s;
  transition: opacity 0.4s, visibility 0.4s, -webkit-transform 0.4s;
  transition: opacity 0.4s, visibility 0.4s, transform 0.4s;
  transition: opacity 0.4s, visibility 0.4s, transform 0.4s, -webkit-transform 0.4s;
  will-change: tramsform, opacity, visibility, background;
}
.l-product_chara {
  position: absolute;
  top: 34.041vw;
  right: 12.4451vw;
  width: 15.37335vw;
}
.l-product_chara_img {
  -webkit-transform: scale(0) translateY(100%);
  transform: scale(0) translateY(100%);
}
.l-product_chara.is-active .l-product_chara_img {
  -webkit-animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
/* cm -------------------- */
.l-cm {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  overflow: hidden;
  background: #efd639;
  border-top: 5px solid #000;
  border-bottom: 5px solid #000;
  box-sizing: border-box;
}
.l-cm_wrapper {
  overflow: hidden;
  position: relative;
  background: #ffea01 url("../img/l-cm_bg01_pc.jpg") no-repeat top center / 100% auto;
}
.l-cm_wrapper img {
  display: block;
  width: 100%;
  height: auto;
}
.l-cm_wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 22vw;
  height: 22vw;
  margin: 0 0 0 16.2vw;
  background: url("/img/l-cm_img01.png") no-repeat top left / 100% auto;
}
.l-cm_wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 15.5vw;
  height: 22vw;
  margin: 0 17.2vw 0 0;
  background: url("/img/l-cm_img02.png") no-repeat top left / 100% auto;
}
.p-cm_balloon::before {
  content: "";
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 12.5vw;
  height: 17vw;
  margin: 83% 0 0 1.5%;
  background: url("../img/l-cm_character01.png") no-repeat top left / contain;
}
.p-cm_balloon::after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  width: 8vw;
  height: 21vw;
  margin: 78% 4.5% 0 0;
  background: url("../img/l-cm_character02.png") no-repeat top left / contain;
  transform: rotate(5deg);
}
.p-cm_txt01 {
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  width: 24.6vw;
  margin: 12.65% 0 0 auto;
}
.p-cm_txt02 {
  position: absolute;
  top: 0;
  left: 0;
  width: 25.51vw;
  margin: 10.7% auto 0 0;
}
@media screen and (max-width: 767px) {
  .l-cm {
    border-top-width: 2px;
    border-bottom-width: 2px;
  }
  .l-cm_wrapper {
    background: #ffea01 url("/img/l-cm_bg01.jpg") no-repeat top center / 100% auto;
  }
  .l-cm_wrapper::before {
    width: 69.8vw;
    height: 69.8vw;
    margin: -.8vw 0 0 -9.8vw;
  }
  .l-cm_wrapper::after {
    width: 47.5vw;
    height: 45.5vw;
    margin: 0 -2vw 0 0;
  }
  .p-cm_balloon {
    position: relative;
    z-index: 1;
    margin: 6% auto;
    padding: 16.5% 0 24%;
    background: url("/img/l-cm_balloon.png") no-repeat top center / 100% auto;
  }
  .p-cm_txt01, .p-cm_txt02 {
    position: relative;
    width: 100%;
    margin: 0 auto;
  }
  .p-cm_txt02 {
    margin: 1% auto;
  }
  .p-cm_balloon::before {
    width: 31vw;
    height: 41vw;
    margin: 49% 0 0 9.5%;
  }
  .p-cm_balloon::after {
    width: 17.8vw;
    height: 48vw;
    margin: 47% 14% 0 0;
    transform: rotate(0);
  }
}
.l-cm_top {
  position: relative;
  z-index: 2;
  border-top: 5px solid #000;
}
.l-cm_top::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 13.3vw;
  height: 19vw;
  margin: 0 0 0 3.5%;
  background: url("/img/l-cm_cup01.png") no-repeat top left / contain;
}
.l-cm_top::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 13.3vw;
  height: 19vw;
  margin: 0 1.5% 0 0;
  background: url("/img/l-cm_cup01.png") no-repeat top left / contain;
}
@media screen and (max-width: 767px) {
  .l-cm_top::before {
    width: 34.3vw;
    height: 49vw;
    margin: 97% 0 0 1.5%;
  }
  .l-cm_top::after {
    width: 34.3vw;
    height: 49vw;
    margin: 97% -3.5% 0 0;
  }
}
.l-cm_ttl {
  position: relative;
  z-index: 2;
  width: 7.06%;
  margin: 0 auto;
  padding: 4.5vw 0 4.7vw;
}
@media screen and (max-width: 767px) {
  .l-cm_top_img_01 {
    width: 12.4vw;
    height: auto;
    position: absolute;
    left: 3.2%;
    top: 11%;
    transform: rotate(-28deg);
  }
}
.l-cm_top_youtube {
  position: relative;
  z-index: 2;
  width: min(100%, 74.7vw);
  margin: 0 auto;
  aspect-ratio: 16 / 9.15;
  border: .71vw solid #000;
  border-radius: .4em;
}
@media screen and (max-width: 767px) {
  .l-cm_top_youtube {
    margin: 0 auto;
    border: 1.2vw solid #000;
  }
}
.l-cm_top_youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: #000;
}
.l-cm_top_youtube_btn_list_link {
  display: flex;
  position: relative;
  align-items: center;
  transform-origin: 0% 0%;
  padding: 1.2vw 2vw;
  box-sizing: border-box;
  background: #fff;
  border: 3px solid #000;
  border-radius: 3em;
  -webkit-box-shadow: 0px 4px 0px 0px #000;
  box-shadow: 0px 4px 0px 0px #000;
  -webkit-transition: width 0.5s cubic-bezier(0.19, 1, 0.22, 1), min-height 0.5s cubic-bezier(0.19, 1, 0.22, 1), border-radius 0.5s cubic-bezier(0.19, 1, 0.22, 1), background 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: width 0.5s cubic-bezier(0.19, 1, 0.22, 1), min-height 0.5s cubic-bezier(0.19, 1, 0.22, 1), border-radius 0.5s cubic-bezier(0.19, 1, 0.22, 1), background 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.l-cm_top_youtube_btn_list_link.is-active {
  background: #ffb800;
  pointer-events: none;
  padding: 1.2vw 2vw;
  border-radius: 3vw;
}
.l-cm_top_youtube_btn_list_link.is-active::before {
  display: inline-block;
  visibility: initial;
  position: absolute;
  top: -0.73206vw;
  left: 50%;
  width: 1.46413vw;
  height: 0.73206vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background: url(/img/p-triangle_black.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
}
.l-cm_top_youtube_btn_list_link span {
  display: block;
  margin: 0 auto;
}
.l-cm_top_youtube_btn_list_link svg {
  display: block;
  width: 100%;
  height: auto;
}
.l-cm_top_youtube_btn_list_wrapper {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  column-gap: 1.5vw;
  width: fit-content;
  margin: 3vw auto 2.7vw;
}
.l-cm_top_youtube_btn_list {
  width: 30%;
}
.l-cm_top_youtube_btn_list:has(.is-active) {
  width: 39%;
}
.l-cm_top_youtube_btn_list img {
  display: block;
  width: 64%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .l-cm_top_youtube_btn_list_wrapper {
    margin: 5.5vw auto 5vw;
  }
  .l-cm_top_youtube_btn_list:has(.is-active) {
    width: 34%;
  }
  .l-cm_top_youtube_btn_list_link {
    padding: 2.2vw 2vw;
  }
  .l-cm_top_youtube_btn_list_link.is-active {
    padding: 3.6vw 2vw;
  }
}
.l-cm_plan {
  position: relative;
  z-index: 3;
}
.l-cm_plan_wrapper {
  position: relative;
}
.l-cm_plan_wrapper.is-active::before {
  visibility: visible;
  -webkit-animation: left_anime 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  animation: left_anime 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  opacity: 1;
}
.l-cm_plan_list {
  position: relative;
  width: calc(33% - 1rem);
}
.l-cm_plan_list img {
  width: 90%;
  height: auto;
  margin: -5% auto 0;
}
.l-cm_plan_list button {
  display: block;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.l-cm_plan_list .l-cm_arrow {
  content: "";
  display: block;
  position: absolute;
  bottom: -1.25vw;
  left: 50%;
  width: 2.56223vw;
  height: 2.56223vw;
  background: #fff;
  transform: translateX(-50%);
  border: .2vw solid #000;
  border-radius: 50%;
}
.l-cm_plan_list .l-cm_arrow > span {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
}
.l-cm_plan_list.is-active::after {
  background: #000;
}
.l-cm_plan_list.is-active .l-cm_plan_list_accordion {
  background: #ffb800;
}
.l-cm_plan_list_wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 50.8vw;
  margin: 0 auto .3%;
}
.l-cm_plan_list_wrapper::after {
  display: block;
  width: calc(33% - 1rem);
  content: "";
}
.l-cm_plan_list_accordion {
  position: relative;
  height: 5.49048vw;
  margin-bottom: 2.45vw;
  border: 3px solid #000;
  border-radius: 0.73206vw;
  background: #fff100;
  -webkit-box-shadow: 0 3px 0 0 #000;
  box-shadow: .2vw .3vw 0 0 #000;
  cursor: pointer;
}
.l-cm_arrow > span::before, .l-cm_arrow > span::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 60%;
  height: 3px;
  border-radius: .7vw;
  background: #000;
  transition: .2s;
}
.l-cm_arrow > span::before {
  transform: translate(-50%, -50%);
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.l-cm_arrow > span::after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
  transform: translate(-50%, -50%) rotate(90deg);
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.l-cm_plan_list.is-active .l-cm_arrow {
  background: #000;
}
.l-cm_plan_list.is-active .l-cm_arrow > span::before, .l-cm_plan_list.is-active .l-cm_arrow > span::after {
  background: #fff;
}
.l-cm_plan_list.is-active .l-cm_arrow > span::after {
  -webkit-transform: translate(-50%, -50%) rotate(0deg);
  transform: translate(-50%, -50%) rotate(0deg);
}
.l-cm_plan_list_accordion_img {
  width: 80%;
}
.l-cm_plan_list_txt_wrapper {
  position: relative;
  z-index: 2;
  width: 72.47438vw;
  margin: 0 auto 1.5%;
  padding: 1.7% 3.1%;
  box-sizing: border-box;
  font-size: 1.7vw;
  line-height: 1.5;
  text-align: left;
  background: #fff;
  border-radius: 1em;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
.l-cm_plan_list_txt_wrapper p + p {
  margin-top: 1em;
}
.l-cm_plan_list_txt_wrapper span {
  display: inline-block;
}
.l-cm_plan_list_txt_wrapper small {
  display: block;
  margin-top: 1.4em;
  font-size: .8em;
}
.p-cm_plan_ttl {
  position: relative;
  width: 27%;
  margin: 2% auto 3%;
}
.l-cm_img {
  position: relative;
}
.l-cm_plan01 {
  padding-bottom: 14.5%;
  background: #ffc309 url("/img/l-cm_plan01_img.jpg") no-repeat bottom right / 76% auto;
}
.l-cm_plan02 {
  padding-bottom: 11%;
  background: #ffc309 url("/img/l-cm_plan02_img.jpg") no-repeat bottom right / 47% auto;
}
.l-cm_plan03 {
  padding-bottom: 11%;
  background: #ffc309 url("/img/l-cm_plan03_img.jpg") no-repeat bottom right / 55% auto;
}
.p-cm_bottom {
  position: relative;
  z-index: 1;
  margin-top: 7vw;
}
.p-cm_bottomChara {
  position: relative;
  background: #ffea00;
  background: linear-gradient(#ffea00 20%, #ffb500 60%, #ffb500);
}
.p-cm_guinness {
  width: 49.6%;
  margin: 1% auto;
}
.p-cm_txt03 {
  width: 85.3%;
  margin: 2.9% auto .8%;
}
.p-cm_notes {
  width: 85.3%;
  margin: 0 auto;
  font-size: 1.15vw;
  text-align: right;
}
.p-cm_chara {
  position: absolute;
  z-index: 4;
  bottom: 0;
  left: 31.7%;
  width: 36.16%;
  margin: 0 auto 2%;
}
.p-cm_desk {
  position: relative;
  z-index: 4;
  width: 74.63%;
  margin: 33.9% auto -1px;
}
.p-cm_pkg01 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 5.8vw;
  margin: 15.5% 0 0 7%;
  transform: rotate(-57deg);
}
.p-cm_pkg02 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 3.8vw;
  margin: 22.5% 0 0 18%;
  transform: rotate(7deg);
}
.p-cm_pkg03 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 3.8vw;
  margin: 16.5% 0 0 27%;
  transform: rotate(50deg);
}
.p-cm_pkg04 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 3.8vw;
  margin: 22.6% 0 0 37.4%;
  transform: rotate(-62deg);
}
.p-cm_pkg05 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 3.4vw;
  margin: 14.2% 0 0 52.8%;
  transform: rotate(83deg);
}
.p-cm_pkg06 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 4.8vw;
  margin: 18.8% 0 0 62.6%;
  transform: rotate(7deg);
}
.p-cm_pkg07 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 3.2vw;
  margin: 17.5% 0 0 75%;
  transform: rotate(-121deg);
}
.p-cm_pkg08 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 3.6vw;
  margin: 20.8% 0 0 85.2%;
  transform: rotate(-68deg);
}
.p-cm_pkg09 {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 5vw;
  margin: 14.1% 0 0 90.5%;
  transform: rotate(-67deg);
}
.p-cm_pkgSet01 {
  position: absolute;
  z-index: 3;
  bottom: 0;
  left: 0;
  width: 100%;
  margin: 0 0 -16%;
}
.p-cm_pkgSet02 {
  position: absolute;
  z-index: 2;
  bottom: 0;
  left: 0;
  width: 100%;
  margin: 0 0 5.5%;
}
@media screen and (max-width: 767px) {
  .l-cm_img {
    margin-top: -20%;
  }
  .p-cm_guinness {
    width: 98.6%;
    margin: 5% auto 6.5%;
  }
  .p-cm_txt03 {
    width: 100%;
    margin: 2.9% auto 4%;
  }
  .p-cm_notes {
    width: 79%;
    font-size: 2.4vw;
  }
  .p-cm_chara {
    left: 20.7%;
    width: 58.16%;
    margin: 0 auto 11%;
  }
  .p-cm_desk {
    width: 100%;
    margin: 64.9% auto -1px;
  }
  .p-cm_pkg01 {
    width: 12vw;
    margin: 2.5% 0 0 -2%;
    transform: rotate(10deg);
  }
  .p-cm_pkg02 {
    width: 9vw;
    margin: 47.5% 0 0 4.2%;
    transform: rotate(-65deg);
  }
  .p-cm_pkg03 {
    width: 9vw;
    margin: 56.9% 0 0 17.2%;
    transform: rotate(-121deg);
  }
  .p-cm_pkg04 {
    width: 9vw;
    margin: 44.9% 0 0 33.2%;
    transform: rotate(20deg);
  }
  .p-cm_pkg05 {
    width: 9vw;
    margin: 64% 0 0 47%;
    transform: rotate(137deg);
  }
  .p-cm_pkg06 {
    width: 8vw;
    margin: 4.9% 0 0 90.2%;
    transform: rotate(71deg);
  }
  .p-cm_pkg07 {
    width: 8vw;
    margin: 56% 0 0 86.2%;
    transform: rotate(-72deg);
  }
  .p-cm_pkg08 {
    width: 8vw;
    margin: 46% 0 0 69.2%;
    transform: rotate(-35deg);
  }
  .p-cm_pkg09 {
    width: 8vw;
    margin: 45.9% 0 0 69.2%;
    transform: rotate(-30deg);
  }
  .p-cm_pkgSet01 {
    margin-bottom: -13%;
  }
  .p-cm_pkgSet02 {
    margin-bottom: 21.5%;
  }
}
/* cm animation -------------------- */
.l-cm_top_img_01 {
  animation: topImg01 1s .5s linear infinite;
  transform-origin: center bottom;
}
@keyframes topImg01 {
  0% {
    transform: scale(1, 1) translate(0, 10%);
  }
  15% {
    transform: scale(1.5, .5) translate(0, 20%);
  }
  20% {
    transform: scale(1, 1) translate(0, -5%);
  }
  25% {
    transform: scale(1, 1) translate(0, -10%);
  }
  100% {
    transform: scale(1, 1) translate(0, 10%);
  }
}
@keyframes bgTxt {
  0% {
    transform: translate(0, 0);
  }
  5% {
    transform: translate(-1%, 0);
  }
  10% {
    transform: translate(1%, 0);
  }
  15% {
    transform: translate(-1%, 0);
  }
  20% {
    transform: translate(1%, 0);
  }
  25% {
    transform: translate(-1%, 0);
  }
  30% {
    transform: translate(0, 0);
  }
  35% {
    transform: translate(-1%, 0);
  }
  40% {
    transform: translate(1%, 0);
  }
  45% {
    transform: translate(-1%, 0);
  }
  50% {
    transform: translate(1%, 0);
  }
  55% {
    transform: translate(-1%, 0);
  }
  60% {
    transform: translate(0, 0);
  }
  65% {
    transform: translate(-1%, 0);
  }
  70% {
    transform: translate(1%, 0);
  }
  75% {
    transform: translate(-1%, 0);
  }
  80% {
    transform: translate(1%, 0);
  }
  85% {
    transform: translate(-1%, 0);
  }
  90% {
    transform: translate(1%, 0);
  }
  95% {
    transform: translate(-1%, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}
/* cm line ---------- */
.l-cm_line {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 14.3%;
  overflow: hidden;
  background: #fff100;
}
.l-cm_line img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}
.l-cm_line > div {
  position: absolute;
  top: 0;
  width: 18.4%;
}
.l-cm_line > div:nth-child(1) {
  z-index: 2;
  top: -3.2%;
  left: -3.7%;
  transform: rotate(-23deg);
  animation: linePkg01 6s infinite;
}
.l-cm_line > div:nth-child(2) {
  z-index: 1;
  top: -28%;
  left: 15.2%;
  transform: rotate(23deg);
  animation: linePkg02 10s infinite;
}
.l-cm_line > div:nth-child(3) {
  z-index: 1;
  top: -4%;
  left: 33%;
  animation: linePkg03 6s infinite;
}
.l-cm_line > div:nth-child(4) {
  top: 7%;
  left: 51.5%;
  transform: rotate(-18.5deg);
  animation: linePkg04 6s infinite;
}
.l-cm_line > div:nth-child(5) {
  z-index: 1;
  top: -5%;
  left: 69%;
  transform: rotate(48deg);
  animation: linePkg05 10s infinite;
}
.l-cm_line > div:nth-child(6) {
  top: -59%;
  left: 86.5%;
  animation: linePkg06 14s infinite;
}
@keyframes linePkg01 {
  0% {
    top: -3.2%;
    transform: rotate(-23deg);
  }
  50% {
    top: 10%;
    transform: rotate(50deg);
  }
  100% {
    top: -3.2%;
    transform: rotate(-23deg);
  }
}
@keyframes linePkg02 {
  0% {
    top: -28%;
    transform: rotate(23deg);
  }
  50% {
    top: 20%;
    transform: rotate(0);
  }
  100% {
    top: -28%;
    transform: rotate(23deg);
  }
}
@keyframes linePkg03 {
  0% {
    top: -4%;
  }
  25% {
    top: 40%;
  }
  90% {
    top: -40%;
  }
  100% {
    top: -4%;
  }
}
@keyframes linePkg04 {
  0% {
    top: 7%;
    transform: rotate(-18.5deg);
  }
  40% {
    top: -20%;
    transform: rotate(20deg);
  }
  100% {
    top: 7%;
    transform: rotate(-18.5deg);
  }
}
@keyframes linePkg05 {
  0% {
    top: -5%;
    transform: rotate(48deg);
  }
  70% {
    top: 15%;
    transform: rotate(-48deg);
  }
  100% {
    top: -5%;
    transform: rotate(48deg);
  }
}
@keyframes linePkg06 {
  0% {
    top: -59%;
    transform: scale(1, 1);
  }
  30% {
    top: -10%;
    transform: scale(1.2, 1.2);
  }
  100% {
    top: -59%;
    transform: scale(1, 1);
  }
}
@media screen and (max-width: 767px) {
  .l-cm_line {
    padding-top: 26%;
  }
  .l-cm_line > div {
    width: 19%;
  }
  .l-cm_line > div:nth-child(1) {
    top: 28.8%;
    left: -4.5%;
    transform: rotate(-23deg);
    animation: linePkgSp01 6s infinite;
  }
  .l-cm_line > div:nth-child(2) {
    top: 15%;
    left: 14.2%;
    transform: rotate(23deg);
    animation: linePkgSp02 10s infinite;
  }
  .l-cm_line > div:nth-child(3) {
    top: 28%;
    left: 33%;
    animation: linePkgSp03 6s infinite;
  }
  .l-cm_line > div:nth-child(4) {
    top: 35%;
    left: 53%;
    transform: rotate(-18.5deg);
    animation: linePkgSp04 6s infinite;
  }
  .l-cm_line > div:nth-child(5) {
    top: 28%;
    left: 70.5%;
    transform: rotate(48deg);
    animation: linePkgSp05 10s infinite;
  }
  .l-cm_line > div:nth-child(6) {
    top: -2%;
    left: 89.5%;
    animation: linePkgSp06 14s infinite;
  }
}
@keyframes linePkgSp01 {
  0% {
    top: 28.8%;
    transform: rotate(-23deg);
  }
  50% {
    top: -10%;
    transform: rotate(50deg);
  }
  100% {
    top: 28.8%;
    transform: rotate(-23deg);
  }
}
@keyframes linePkgSp02 {
  0% {
    top: 15%;
    transform: rotate(23deg);
  }
  25% {
    top: 20%;
    transform: rotate(73deg);
  }
  50% {
    top: 40%;
    transform: rotate(-20deg);
  }
  100% {
    top: 15%;
    transform: rotate(23deg);
  }
}
@keyframes linePkgSp03 {
  0% {
    top: 28%;
    transform: rotate(0);
  }
  50% {
    top: -10%;
    transform: rotate(150deg);
  }
  100% {
    top: 28%;
    transform: rotate(360deg);
  }
}
@keyframes linePkgSp04 {
  0% {
    top: 35%;
    transform: rotate(-18.5deg);
  }
  40% {
    top: -20%;
    transform: rotate(20deg);
  }
  70% {
    top: 10%;
    transform: rotate(270deg);
  }
  100% {
    top: 35%;
    transform: rotate(-18.5deg);
  }
}
@keyframes linePkgSp05 {
  0% {
    top: 28%;
    transform: rotate(48deg);
  }
  70% {
    top: 15%;
    transform: rotate(-48deg);
  }
  100% {
    top: 28%;
    transform: rotate(48deg);
  }
}
@keyframes linePkgSp06 {
  0% {
    top: -2%;
    transform: scale(1, 1);
  }
  30% {
    top: -10%;
    transform: scale(1.2, 1.2);
  }
  100% {
    top: -2%;
    transform: scale(1, 1);
  }
}
/* l-campaign ---------- */
.l-campaign {
  position: relative;
  padding-top: 2vw;
  overflow: hidden;
  border-bottom: 3px solid #000;
  background: #ffae00;
}
.l-campaign_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding-left: 7.54026vw;
  overflow: hidden;
}
.l-campaign_left_ttl {
  z-index: 4;
  position: relative;
  width: 21.96193vw;
}
.l-campaign_left_ttl_img {
  width: 100%;
  height: auto;
}
.l-campaign_left_ttl_chara {
  z-index: 1;
  position: relative;
  left: -0.73206vw;
  width: 12.4451vw;
  margin: 1.46413vw auto 0;
}
.l-campaign_left_ttl_chara_img {
  width: 100%;
  height: auto;
}
.l-campaign_slider_wrapper {
  position: relative;
  width: 70.27818vw;
  margin: 0 0 0 auto;
  padding-left: 2.92826vw;
  overflow: hidden;
}
.l-campaign_slider_wrapper .swiper {
  overflow: visible;
}
.l-campaign_slider_wrapper .swiper-slide {
  width: 38.79941vw;
  margin-right: 9.51684vw;
}
.l-campaign_slider_wrapper .swiper-controller {
  gap: 35.87116vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
  position: absolute;
  top: 50%;
  left: -38.72621vw;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.l-campaign_slider_wrapper .swiper-controller.is-none {
  display: none;
}
.l-campaign_slider_wrapper .swiper-slide-active .l-product_slider_item {
  z-index: 1;
  opacity: 1;
}
.l-campaign_slider_wrapper .swiper-slide-active .l-product_slider_item_img {
  -webkit-backface-visibility: hidden;
  -webkit-transform: scale(var(--slideScale)) translateZ(0);
  transform: scale(var(--slideScale)) translateZ(0);
  backface-visibility: hidden;
}
.l-campaign_slider_wrapper .swiper-button-prev {
  z-index: 1;
  position: relative;
  width: 4.39239vw;
  height: 4.39239vw;
  cursor: pointer;
}
.l-campaign_slider_wrapper .swiper-button-prev img {
  position: absolute;
  top: 1.61054vw;
  left: 1.1713vw;
  width: 1.75695vw;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
.l-campaign_slider_wrapper .swiper-button-prev::before {
  display: inline-block;
  visibility: initial;
  position: absolute;
  left: 0;
  width: 4.39239vw;
  height: 4.39239vw;
  border: 2px solid #000;
  border-radius: 50%;
  background: #fff100;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  content: "";
}
.l-campaign_slider_wrapper .swiper-button-next {
  z-index: 1;
  position: relative;
  width: 4.39239vw;
  height: 4.39239vw;
  cursor: pointer;
}
.l-campaign_slider_wrapper .swiper-button-next img {
  position: absolute;
  top: 1.61054vw;
  left: 1.46413vw;
  width: 1.75695vw;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.l-campaign_slider_wrapper .swiper-button-next::before {
  display: inline-block;
  visibility: initial;
  position: absolute;
  left: 0;
  width: 4.39239vw;
  height: 4.39239vw;
  border: 2px solid #000;
  border-radius: 50%;
  background: #fff100;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  content: "";
}
.l-campaign_slider_img {
  display: block;
  margin: 0 auto;
}
.l-campaign_slider_img_wrapper {
  width: min(10.981vw, 15rem);
  margin-right: min(4.392vw, 6rem);
}
.l-campaign_slider_item {
  display: block;
  position: relative;
  padding: 1.31772vw 1.31772vw 0 1.31772vw;
  border: 2px solid #000;
  border-radius: 1.46413vw;
  background: #fff;
}
.l-campaign_slider_item_img {
  border-radius: 0.73206vw;
}
.l-campaign_slider_txt {
  font-size: 1.02489vw;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.5;
  text-align: left;
}
.l-campaign_slider_prev {
  position: absolute;
  top: min(11.347vw, 15.5rem);
  left: max(-2.196vw, -3rem);
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
}
.l-campaign_slider_prev::before {
  display: block;
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
  border-radius: 50%;
  background: #d82a17;
  content: "";
  cursor: pointer;
  -webkit-transition: background 0.4s, opacity 0.4s, visibility 0.4s;
  transition: background 0.4s, opacity 0.4s, visibility 0.4s;
}
.l-campaign_slider_prev::after {
  display: inline-block;
  visibility: initial;
  z-index: 1;
  position: absolute;
  top: min(1.611vw, 2.2rem);
  left: min(0.878vw, 1.2rem);
  width: min(2.343vw, 3.2rem);
  height: min(0.878vw, 1.2rem);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  background: url(/img/common/p-arrow_btn_white_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  cursor: pointer;
}
.l-campaign_slider_next {
  position: absolute;
  top: min(11.347vw, 15.5rem);
  right: min(13.909vw, 19rem);
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
}
.l-campaign_slider_next::before {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: min(4.392vw, 6rem);
  height: min(4.392vw, 6rem);
  border-radius: 50%;
  background: #d82a17;
  content: "";
  cursor: pointer;
  -webkit-transition: background 0.4s, opacity 0.4s, visibility 0.4s;
  transition: background 0.4s, opacity 0.4s, visibility 0.4s;
}
.l-campaign_slider_next::after {
  display: inline-block;
  visibility: initial;
  position: absolute;
  top: min(1.83vw, 2.5rem);
  right: min(1.098vw, 1.5rem);
  width: min(2.343vw, 3.2rem);
  height: min(1.171vw, 1.6rem);
  background: url(/img/common/p-arrow_btn_white_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  cursor: pointer;
}
.l-campaign_btn_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  bottom: -1.24451vw;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 auto;
  cursor: pointer;
}
.l-campaign_chara_top_img {
  visibility: hidden;
  position: absolute;
  top: 8.347vw;
  left: 39.23865vw;
  width: 12.07906vw;
  height: auto;
  opacity: 0;
}
.l-campaign_chara_top_img.is-active {
  visibility: visible;
  -webkit-animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  opacity: 1;
}
.l-campaign_chara_bottom {
  z-index: 1;
  position: relative;
}
.l-campaign_chara_bottom_img {
  visibility: hidden;
  position: absolute;
  bottom: -4.1vw;
  width: 13.17716vw;
  height: auto;
  opacity: 0;
}
.l-campaign_chara_bottom_img.is-active {
  visibility: visible;
  -webkit-animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  opacity: 1;
}
.l-campaign_scroll_slider {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 0;
  position: absolute;
  bottom: -1rem;
}
.l-campaign_scroll_slider_img {
  min-width: 75rem;
  margin-left: -2px;
  -webkit-animation: loop 20s linear infinite;
  animation: loop 20s linear infinite;
  will-change: transform;
}
.l-kanzen_wrapper {
  position: relative;
}
.l-kanzen_top {
  position: relative;
  height: 20vw;
  background: #0f0964;
}
.l-kanzen_wrapper {
  position: relative;
}
.l-kanzen_top::before, .l-kanzen_top::after {
  content: '';
  display: inline-block;
  visibility: initial;
  position: absolute;
  z-index: 2;
  top: 50%;
  width: 16.17862vw;
  height: 16.17862vw;
  background: url(/img/l-kanzen_item_02.png) no-repeat top left;
  background-size: contain;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.l-kanzen_top::before {
  left: 10.98097vw;
  animation: doki .8s infinite;
}
.l-kanzen_top::after {
  right: 8.93119vw;
  animation: doki .8s infinite .4s;
}
@keyframes doki {
  0% {
    transform: translateY(-50%) scale(1, 1);
  }
  50% {
    transform: translateY(-50%) scale(.7, .7);
  }
  100% {
    transform: translateY(-50%) scale(1, 1);
  }
}
.l-kanzen_top_ttl {
  width: 43vw;
  margin: 0 auto;
  padding-top: 2.5vw;
}
.l-kanzen_bottom {
  position: relative;
  padding-top: 15vw;
  padding-bottom: 1.5vw;
  overflow: hidden;
  background: #fef302;
}
.l-kanzen_bottom_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 49.78038vw;
  margin: 0 auto 2.19619vw;
}
.l-kanzen_bottom_item_img {
  z-index: 2;
  position: relative;
  width: 20.4978vw;
}
.l-kanzen_bottom_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 22vw;
  margin: 0 auto;
  margin-bottom: 1.46413vw;
  padding: 1em;
  border-radius: 2.92826vw;
  background: #0f0964;
  -webkit-box-shadow: 0 .73206vw 0 0 #bfb700;
  box-shadow: 0 .53206vw 0 0 #bfb700;
  color: #fff100;
  font-size: 1.31772vw;
  font-weight: 500;
  letter-spacing: .08em;
  line-height: 1.33333;
  text-align: center;
}
.l-kanzen_bottom_txt {
  z-index: 2;
  position: relative;
  margin-top: 2.19619vw;
  color: #0f0964;
  font-size: 1.02489vw;
  font-weight: 700;
}
.l-kanzen_bottom_chara {
  position: absolute;
}
.l-kanzen_bottom_chara.is-left_top {
  top: 0;
  left: 0;
}
.l-kanzen_bottom_chara_wrapepr {
  position: absolute;
  width: 100%;
  height: 68rem;
}
.l-kanzen_bottom_chara_main {
  z-index: 1;
  position: absolute;
  top: 21vw;
  left: 50%;
  width: 27.08638vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.l-kanzen_bottom_chara_img {
  z-index: 0;
  position: absolute;
  will-change: animation, transform;
}
.l-kanzen_bottom_chara_img.is-left_top {
  top: -5.12445vw;
  left: 13.17716vw;
  width: 18.30161vw;
}
.l-kanzen_bottom_chara_img.is-left_top.is-active {
  -webkit-animation: move_left 15s linear infinite;
  animation: move_left 15s linear infinite;
}
.l-kanzen_bottom_chara_img.is-left_middle {
  top: 8.78477vw;
  left: -10.98097vw;
  width: 34.041vw;
}
.l-kanzen_bottom_chara_img.is-left_middle.is-active {
  -webkit-animation: move_right 20s linear infinite;
  animation: move_right 20s linear infinite;
}
.l-kanzen_bottom_chara_img.is-left_bottom {
  bottom: 3.66032vw;
  left: 1.46413vw;
  width: 13.90922vw;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.l-kanzen_bottom_chara_img.is-left_bottom.is-active {
  -webkit-animation: move_right 10s linear infinite;
  animation: move_right 10s linear infinite;
}
.l-kanzen_bottom_chara_img.is-right_top {
  top: -8.05271vw;
  right: 13.17716vw;
  width: 25.62225vw;
}
.l-kanzen_bottom_chara_img.is-right_top.is-active {
  -webkit-animation: move_left 25s linear infinite;
  animation: move_left 25s linear infinite;
}
.l-kanzen_bottom_chara_img.is-right_middle {
  top: 10.2489vw;
  right: -4.39239vw;
  width: 16.83748vw;
}
.l-kanzen_bottom_chara_img.is-right_middle.is-active {
  -webkit-animation: move_left 17s linear infinite;
  animation: move_left 17s linear infinite;
}
.l-kanzen_bottom_chara_img.is-right_bottom {
  right: 11.71303vw;
  bottom: -2.19619vw;
  width: 21.22987vw;
  -webkit-transform: rotate(-12deg);
  transform: rotate(-12deg);
}
.l-kanzen_bottom_chara_img.is-right_bottom.is-active {
  -webkit-animation: move_right 12s linear infinite;
  animation: move_right 12s linear infinite;
}
.l-sns {
  position: relative;
  padding-top: 13.17716vw;
  padding-bottom: 16.10542vw;
  overflow: hidden;
}
.l-sns_wrapper {
  width: 50%;
  margin: 0 auto 0 0;
}
.l-sns_list_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  top: 13.17716vw;
  left: calc(50% + 10.2vw);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 10.2489vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.l-sns_list_link {
  width: 3.73353vw;
  padding-top: 0.1rem;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .l-sns_list:nth-child(2) .l-sns_list_link {
    width: 3.2vw;
  }
}
.l-sns_bg {
  display: inline-block;
  visibility: initial;
  z-index: 0;
  position: absolute;
  top: -44vw;
  left: -9%;
  width: 118vw;
  background: #ffcc00;
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-animation: rotateLoop 40s linear infinite;
  animation: rotateLoop 40s linear infinite;
  content: '';
  will-change: transform;
}
.l-sns_chara_img {
  visibility: hidden;
  position: absolute;
  bottom: 0;
  left: calc(50% - 21.2vw);
  width: 27.81845vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  opacity: 0;
}
.l-sns_chara_img.is-active {
  visibility: visible;
  -webkit-animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
  opacity: 1;
}
.l-pg_top_btn {
  visibility: hidden;
  z-index: 9;
  position: fixed;
  right: 1.0981vw;
  bottom: 1.46413vw;
  width: 6.58858vw;
  height: 7.32064vw;
  text-align: center;
  opacity: 0;
  -webkit-transition: visibility 0.5s, -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: visibility 0.5s, -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), visibility 0.5s;
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), visibility 0.5s, -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.l-pg_top_btn.is-active {
  visibility: visible;
  -webkit-animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  animation: bound 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  opacity: 1;
}
.l-pg_top_btn_img {
  z-index: 1;
  position: relative;
  width: 5.49048vw;
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.l-pg_top_btn_link {
  display: block;
  display: inline-block;
  visibility: initial;
  position: absolute;
  left: 0;
  width: 100%;
  overflow: hidden;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
}
.l-pg_top_btn_link::after {
  display: inline-block;
  visibility: initial;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 5.85652vw;
  height: 5.85652vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-radius: 50%;
  background: #000;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
}
.l-pg_top_btn_txt_img {
  z-index: 1;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 3.14788vw;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (max-width: 47.9735em) {
  .l-loading_logo_img {
    width: 8rem;
  }
  .l-loading_logo_img_wrapper {
    display: block;
    width: 17rem;
  }
  .l-product {
    padding-top: 4rem;
    padding-bottom: 3rem;
    border-top-width: 2px;
  }
  .l-product.is-none .l-product_img_wrapper {
    -webkit-transform: translate(-50%, 100%);
    transform: translate(-50%, 100%);
  }
  .l-product_ttl {
    width: 14.4rem;
  }
  .l-product_ttl_sub {
    top: 5rem;
    right: 0;
    width: 8.6rem;
  }
  .l-product_btn_link {
    bottom: -2.6rem;
  }
  .l-product_slider_wrapper {
    position: relative;
    top: -2.5rem;
    width: 100%;
    margin: 0 auto;
    padding-top: 0;
    padding-top: 4.4rem;
    padding-bottom: 7.2rem;
    padding-left: 0;
  }
  .l-product_slider_wrapper .swiper-slide {
    width: 100%;
  }
  .l-product_slider_wrapper .swiper-slide[data-size="small"] .l-product_slider_item_img {
    -webkit-transform: scale(0.39);
    transform: scale(0.39);
  }
  .l-product_slider_wrapper .swiper-slide[data-size="large"] .l-product_slider_item_img {
    -webkit-transform: scale(0.48);
    transform: scale(0.48);
  }
  .l-product_slider_wrapper .swiper-slide .l-product_slider_item_img {
    max-height: 19.3rem;
    -webkit-transform: scale(0.44);
    transform: scale(0.44);
  }
  .l-product_slider_wrapper .swiper-slide-active {
    margin-right: 0;
  }
  .l-product_slider_wrapper .swiper-slide-prev {
    visibility: visible;
    width: 9.2rem;
    opacity: 1;
  }
  .l-product_slider_wrapper .swiper-slide-next {
    width: 9.2rem;
  }
  .l-product_slider_wrapper .swiper-controller {
    gap: 0;
    top: -4.5rem;
    left: 0;
    width: 100%;
  }
  .l-product_slider_wrapper .swiper-slide-active .l-product_slider_item {
    position: relative;
  }
  .l-product_slider_wrapper .swiper-slide-active .l-product_slider_item_img {
    max-height: 19.3rem;
    -webkit-transform: scale(var(--slideScale));
    transform: scale(var(--slideScale));
  }
  .l-product_slider_wrapper .swiper-slide-active[data-size="small"] .l-product_slider_item_img {
    -webkit-transform: scale(var(--slideScale));
    transform: scale(var(--slideScale));
  }
  .l-product_slider_wrapper .swiper-slide-active[data-size="small"] .l-product_btn_link {
    bottom: -2rem;
  }
  .l-product_slider_wrapper .swiper-slide-active[data-size="large"] .l-product_slider_item_img {
    -webkit-transform: scale(var(--slideScale));
    transform: scale(var(--slideScale));
  }
  .l-product_slider_wrapper .swiper-slide-active[data-size="large"] .l-product_btn_link {
    bottom: -.2rem;
  }
  .l-product_slider_wrapper .swiper-button-prev {
    position: absolute;
    top: -3rem;
    left: -2.2rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_wrapper .swiper-button-prev img {
    top: 1.8rem;
    left: 2.3rem;
    width: 1.3rem;
  }
  .l-product_slider_wrapper .swiper-button-prev::before {
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_wrapper .swiper-button-next {
    position: absolute;
    top: -3rem;
    right: -2.2rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_wrapper .swiper-button-next img {
    top: 1.8rem;
    left: .9rem;
    width: 1.3rem;
  }
  .l-product_slider_wrapper .swiper-button-next::before {
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_content {
    width: 16rem;
    max-width: 16rem;
    margin-right: 1rem;
  }
  .l-product_slider_prev {
    top: 8.9rem;
    left: -1.5rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_next {
    top: 8.9rem;
    right: 1.5rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_btn_wrapper {
    margin-top: 4rem;
  }
  .l-product_bg {
    top: -23vw;
    left: -45%;
    width: 187vw;
  }
  .l-product_img_wrapper {
    top: auto;
    bottom: -29rem;
    left: 50%;
    width: 38.5rem;
    height: 50rem;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }
  .l-product_chara {
    display: none;
  }
  .l-cm_ttl {
    width: 6.4rem;
    padding: 16vw 0;
  }
  .l-cm_top {
    border-top-width: 2px;
    padding-bottom: 38%;
  }
  .l-cm_top_youtube {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    padding-top: 55.75%;
    border: 5px solid #000;
    border-radius: 0;
  }
  .l-cm_top_youtube_btn_list_link.is-active {
    border-radius: 3rem;
  }
  .l-cm_top_youtube_btn_list_link.is-active::before {
    top: -.7rem;
    width: 1.1rem;
    height: 1.1rem;
  }
  .l-cm_plan_list {
    width: calc(33% - .6rem);
  }
  .l-cm_plan_list .l-cm_arrow {
    bottom: auto;
    width: 3rem;
    height: 3rem;
    border-width: 2px;
  }
  .l-cm_plan_list_wrapper {
    width: 100%;
    padding: 0 1.5rem;
    margin-bottom: 4%;
  }
  .l-cm_plan_list_accordion {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 7.1rem;
    margin-bottom: 2rem;
    border-radius: 1rem;
  }
  .l-cm_plan_list_accordion_img {
    width: 8.4rem;
    height: auto;
  }
  .l-cm_plan_list_txt_wrapper {
    width: 34.5rem;
    font-size: 1em;
  }
  .l-cm_plan_list_txt_wrapper.is-intention::before {
    bottom: 23.5rem;
  }
  .l-cm_plan_list_txt_wrapper.is-another_story::before {
    bottom: 10.5rem;
  }
  .p-cm_plan_ttl {
    width: 58%;
    margin: 4% auto 6%;
  }
  .l-cm_plan01 {
    padding-bottom: 24%;
    background: #ffc309 url("/img/l-cm_plan01_img.jpg") no-repeat bottom right / 100% auto;
  }
  .l-cm_plan02 {
    padding-bottom: 60%;
    background: #ffc309 url("/img/l-cm_plan02_img.jpg") no-repeat bottom right / 70% auto;
  }
  .l-cm_plan03 {
    padding-bottom: 48%;
    background: #ffc309 url("/img/l-cm_plan03_img.jpg") no-repeat bottom right / 100% auto;
  }
  .l-campaign {
    position: relative;
    padding-top: 4rem;
  }
  .l-campaign::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60vw;
    background: #FFCC00;
  }
  .l-campaign_wrapper {
    display: block;
    padding-left: 0;
  }
  .l-campaign_left_ttl {
    width: 20rem;
    height: 8.3rem;
    margin: 0 auto;
  }
  .l-campaign_left_ttl_chara {
    position: absolute;
    top: 2.4rem;
    left: 1rem;
    width: 7.7rem;
  }
  .l-campaign_slider_wrapper {
    position: initial;
    width: 100%;
    padding-top: 2rem;
  }
  .l-campaign_slider_wrapper.is-center {
    padding-left: 0;
  }
  .l-campaign_slider_wrapper.is-center .swiper-slide {
    margin: auto;
  }
  .l-campaign_slider_wrapper .swiper-slide {
    width: 30.5rem;
    margin: 0 auto;
  }
  .l-campaign_slider_wrapper .swiper-controller {
    gap: 0;
    top: 50%;
    left: 0;
    width: 100%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .l-campaign_slider_wrapper .swiper-slide-active .l-product_slider_item {
    position: relative;
  }
  .l-campaign_slider_wrapper .swiper-button-prev {
    position: absolute;
    top: -1rem;
    left: -3.2rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_wrapper .swiper-button-prev img {
    top: 1.8rem;
    left: 2.3rem;
    width: 1.3rem;
  }
  .l-campaign_slider_wrapper .swiper-button-prev::before {
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_wrapper .swiper-button-next {
    position: absolute;
    top: -1rem;
    right: -2.2rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_wrapper .swiper-button-next img {
    top: 1.8rem;
    left: .9rem;
    width: 1.3rem;
  }
  .l-campaign_slider_wrapper .swiper-button-next::before {
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_item {
    padding: .9rem .9rem 0 .9rem;
    border-radius: 1rem;
  }
  .l-campaign_slider_item_img {
    border-radius: 1rem;
  }
  .l-campaign_slider_txt {
    font-size: 1.4rem;
  }
  .l-campaign_slider_prev {
    top: 8.9rem;
    left: -1.5rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_next {
    top: 8.9rem;
    right: 1.5rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_chara_bottom_img {
    z-index: 1;
    right: -1.5rem;
    bottom: -6rem;
    width: 15rem;
  }
  .l-campaign_scroll_slider_img {
    min-width: 38.3rem;
    margin-left: -1px;
    -webkit-animation: loop 20s linear infinite;
    animation: loop 20s linear infinite;
  }
  .l-kanzen_top {
    height: 18.5rem;
  }
  .l-kanzen_top::before, .l-kanzen_top::after {
    display: none;
  }
  .l-kanzen_top_ttl {
    width: 35.6rem;
    padding-top: 3rem;
  }
  .l-kanzen_bottom {
    padding-top: 11.2rem;
    padding-bottom: 1.2rem;
  }
  .l-kanzen_bottom_item {
    width: 100%;
    margin-bottom: 3.3rem;
    padding: 0 1.5rem;
  }
  .l-kanzen_bottom_item_img {
    width: 15.5rem;
  }
  .l-kanzen_bottom_btn {
    width: 28rem;
    border-radius: 4rem;
    -webkit-box-shadow: 0 .5rem 0 0 #bfb700;
    box-shadow: 0 .5rem 0 0 #bfb700;
    font-size: 1.5rem;
  }
  .l-kanzen_bottom_txt {
    margin-top: 2rem;
    font-size: 1.2rem;
  }
  .l-kanzen_bottom_chara_main {
    top: 17.2rem;
    width: 24rem;
  }
  .l-sns {
    padding-top: 4rem;
    padding-bottom: 23.7rem;
  }
  .l-sns_list_wrapper {
    top: 4rem;
    left: 50%;
    width: 18.3rem;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
  .l-sns_list_link {
    width: 4rem;
  }
  .l-sns_bg {
    top: -46vw;
    left: -53%;
    width: 200vw;
  }
  .l-sns_chara_img {
    left: 29%;
    width: 22.5rem;
  }
  .l-pg_top_btn {
    right: 1rem;
    bottom: 1rem;
    width: 5.5rem;
    height: 8rem;
    overflow: hidden;
  }
  .l-pg_top_btn_img {
    top: 1rem;
    width: 7rem;
  }
  .l-pg_top_btn_link {
    width: 5rem;
    height: 7rem;
    overflow: visible;
  }
  .l-pg_top_btn_link::after {
    width: 4.7rem;
    height: 4.7rem;
  }
  .l-pg_top_btn_txt_img {
    bottom: -.4rem;
    width: 3rem;
  }
  .l-campaign_scroll_slider {
    top: 15%;
  }
}
@media screen and (max-width: 75em) {
  .l-product_slider_prev::before {
    top: 1rem;
  }
  .l-product_slider_prev::after {
    top: clamp(2.1rem, 2.734vw, 2.5rem);
  }
  .l-product_slider_next::before {
    top: 1rem;
  }
  .l-product_slider_next::after {
    top: clamp(2.4rem, 3.125vw, 2.8rem);
  }
  .l-campaign_slider_prev::before {
    top: 1rem;
  }
  .l-campaign_slider_prev::after {
    top: clamp(2.1rem, 2.734vw, 2.5rem);
  }
  .l-campaign_slider_next::before {
    top: 1rem;
  }
  .l-campaign_slider_next::after {
    top: clamp(2.4rem, 3.125vw, 2.8rem);
  }
}
@media screen and (max-width: 75em) and (max-width: 47.9735em) {
  .l-product_slider_prev::before {
    top: 0;
    left: 0;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_prev::after {
    top: 1.7rem;
    left: 0.8rem;
    width: 2.6rem;
    height: 0.8rem;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
  .l-product_slider_next::before {
    top: 0;
    right: 0rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-product_slider_next::after {
    top: 1.9rem;
    right: 0.9rem;
    width: 2.6rem;
    height: 0.8rem;
  }
  .l-campaign_slider_prev::before {
    top: 0;
    left: 0;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_prev::after {
    top: 1.7rem;
    left: 0.8rem;
    width: 2.6rem;
    height: 0.8rem;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
  .l-campaign_slider_next::before {
    top: 0;
    right: 0rem;
    width: 4.5rem;
    height: 4.5rem;
  }
  .l-campaign_slider_next::after {
    top: 1.9rem;
    right: 0.9rem;
    width: 2.6rem;
    height: 0.8rem;
  }
  .l-campaign_chara_top_img {
    display: block;
    top: 2rem;
    right: 1rem;
    left: auto;
    width: 9rem;
  }
}
@media screen and (max-width: 47.9735em) and (max-width: 23.375em) {
  .l-sns_list_link {
    padding-top: .3rem;
  }
}
@media (hover: hover) {
  .l-product_slider_prev:hover::before {
    background: #222;
  }
  .l-product_slider_next:hover::before {
    background: #222;
  }
  .l-campaign_slider_prev:hover::before {
    background: #222;
  }
  .l-campaign_slider_next:hover::before {
    background: #222;
  }
  .l-pg_top_btn_link:hover .l-pg_top_btn_img {
    -webkit-transform: translateY(3rem);
    transform: translateY(3rem);
  }
}
/* animation
------------------------------ */
/* kv */
.l-kv_wrap, .p-kv_copy01, .p-kv_copy02, .p-kv_img, .p-kv_txt01, .p-kv_txt02 {
  opacity: 0;
}
.is-aniAact .l-kv_wrap {
  animation: zoom01 .3s forwards .6s;
}
.is-aniAact .p-kv_copy01 {
  animation: kvCopy01 .2s forwards .2s;
}
.is-aniAact .p-kv_copy02 {
  animation: kvCopy02 .2s forwards .4s;
}
.is-aniAact .p-kv_img {
  animation: fadeUp01 .15s forwards .6s;
}
.is-aniAact .p-kv_img img {
  animation: kvImg 1s infinite;
}
.is-aniAact .p-kv_txt01 {
  animation: fade .2s forwards .8s;
}
.is-aniAact .p-kv_txt01 span {
  animation: yakan .2s infinite;
}
@keyframes yakan {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(5deg);
  }
  100% {
    transform: rotate(0);
  }
}
.is-aniAact .p-kv_txt01 span:before {
  animation: shu .2s infinite;
}
@keyframes shu {
  0% {
    transform: translate(0, 0)
  }
  50% {
    transform: translate(-5px, -10px)
  }
  100% {
    transform: translate(0, 0)
  }
}
.is-aniAact .p-kv_txt02 {
  animation: fade .2s forwards;
}
.is-aniAact .p-kv_txt02 img {
  animation: kvTxt02 .8s infinite;
}
@keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes zoom01 {
  0% {
    opacity: 0;
    transform: scale(0, 0);
  }
  82% {
    opacity: 1;
    transform: scale(1.6, 1.6);
  }
  100% {
    opacity: 1;
    transform: scale(1, 1);
  }
}
@keyframes kvCopy01 {
  0% {
    opacity: 0;
    transform: scale(0, 0);
  }
  80% {
    opacity: 1;
    transform: scale(1.5);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes kvCopy02 {
  0% {
    opacity: 0;
    transform: translateY(-100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeUp01 {
  0% {
    opacity: 0;
    transform: translateX(100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes kvImg {
  0% {
    transform: translateY(5px);
  }
  1% {
    transform: translateY(0);
  }
  4% {
    transform: translateY(5px);
  }
  6% {
    transform: translateY(0);
  }
  94% {
    transform: translateY(0);
  }
  95% {
    transform: translateY(-5px);
  }
  98% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-5px);
  }
}
@keyframes kvTxt01 {
  0% {
    transform: rotate(0) scale(1);
  }
  30% {
    transform: rotate(8deg) scale(.8);
  }
  50% {
    transform: rotate(0) scale(1);
  }
  70% {
    transform: rotate(-8deg) scale(.8);
  }
  100% {
    transform: rotate(0) scale(1);
  }
}
@keyframes kvTxt02 {
  0% {
    transform: scale(1, 1);
  }
  50% {
    transform: scale(.7, .7);
  }
  100% {
    transform: scale(1, 1);
  }
}
.l-cm_top::before {
  animation: zoom02 .8s infinite linear alternate;
}
.l-cm_top::after {
  animation: zoom02 .6s infinite linear alternate;
}
@keyframes zoom02 {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
.p-cm_txt01 {
  animation: buru .1s infinite linear alternate;
}
.p-cm_txt02 {
  animation: buru .15s infinite linear alternate;
}
@media screen and (max-width: 767px) {
  .p-cm_balloon {
    animation: buru .15s infinite linear alternate;
  }
  .p-cm_txt01, .p-cm_txt02 {
    animation: none;
  }
}
@keyframes buru {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
  100% {
    transform: translateY(0);
  }
}
.l-cm_wrapper::before {
  animation: yoko01 1s infinite;
}
@keyframes yoko01 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, 5px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.l-cm_wrapper::after {
  animation: yoko02 1.4s infinite;
}
@keyframes yoko02 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}
.p-cm_balloon::before {
  animation: yoko03 1.4s infinite;
}
@keyframes yoko03 {
  0% {
    transform: translate(0, 0);
  }
  40% {
    transform: translate(20px, -5px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.p-cm_balloon::after {
  animation: yoko04 .2s infinite;
}
@keyframes yoko04 {
  0% {
    transform: translate(0, 0);
  }
  40% {
    transform: translate(5px, 10px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.p-cm_pkg01 {
  animation: pkg01 5s infinite;
}
@media screen and (max-width: 767px) {
  .p-cm_pkg01 {
    animation: pkg01sp 5s infinite;
  }
}
@keyframes pkg01 {
  0% {
    transform: translate(0, 300%);
  }
  30% {
    transform: translate(-200%, -400%);
  }
  50% {
    transform: translate(0, 0);
  }
  80% {
    transform: translate(0, 300%);
  }
  100% {
    transform: translate(0, 300%);
  }
}
@keyframes pkg01sp {
  0% {
    transform: translate(0, 600%);
  }
  30% {
    transform: translate(200%, -100%);
  }
  80% {
    transform: translate(100%, 600%);
  }
  100% {
    transform: translate(0, 600%);
  }
}
.p-cm_pkg02 {
  animation: pkg02 4s infinite;
}
@keyframes pkg02 {
  0% {
    transform: translate(0, 300%);
  }
  60% {
    transform: translate(0, 0);
  }
  70% {
    transform: translate(0, -500%);
  }
  80% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(0, 300%);
  }
}
.p-cm_pkg03 {
  animation: pkg03 8s infinite;
}
@keyframes pkg03 {
  0% {
    transform: translate(0, 300%);
  }
  20% {
    transform: translate(300%, -500%);
  }
  70% {
    transform: translate(300%, 500%);
  }
  100% {
    transform: translate(0, 300%);
  }
}
.p-cm_pkg04 {
  animation: pkg04 8s infinite;
}
@keyframes pkg04 {
  0% {
    transform: translate(0, 300%);
  }
  20% {
    transform: translate(-300%, -200%);
  }
  70% {
    transform: translate(-300%, 500%);
  }
  100% {
    transform: translate(0, 300%);
  }
}
.p-cm_pkg05 {
  animation: pkg05 3s infinite;
}
@media screen and (max-width: 767px) {
  .p-cm_pkg05 {
    animation: pkg05sp 3s infinite;
  }
}
@keyframes pkg05 {
  0% {
    transform: translate(0, 300%);
  }
  20% {
    transform: translate(-50%, -100%);
  }
  100% {
    transform: translate(0, 300%);
  }
}
@keyframes pkg05sp {
  0% {
    transform: translate(0, 300%);
  }
  20% {
    transform: translate(-200%, -300%);
  }
  100% {
    transform: translate(0, 300%);
  }
}
.p-cm_pkg06 {
  animation: pkg06 4s infinite;
}
@media screen and (max-width: 767px) {
  .p-cm_pkg06 {
    animation: pkg06sp 4s infinite;
  }
}
@keyframes pkg06 {
  0% {
    transform: translate(0, 100%);
  }
  20% {
    transform: translate(100%, -100%);
  }
  100% {
    transform: translate(100%, 300%);
  }
}
@keyframes pkg06sp {
  0% {
    transform: translate(0, 800%);
  }
  20% {
    transform: translate(-100%, -100%);
  }
  100% {
    transform: translate(-100%, 800%);
  }
}
.p-cm_pkg07 {
  animation: pkg07 2s infinite;
}
@keyframes pkg07 {
  0% {
    transform: translate(0, 500%);
  }
  20% {
    transform: translate(0, -500%);
  }
  100% {
    transform: translate(0, 500%);
  }
}
.p-cm_pkg08 {
  animation: pkg08 5s infinite;
}
@keyframes pkg08 {
  0% {
    transform: translate(0, 500%);
  }
  20% {
    transform: translate(300%, -500%);
  }
  100% {
    transform: translate(0, 500%);
  }
}
.p-cm_pkg09 {
  animation: pkg09 5s infinite;
}
@media screen and (max-width: 767px) {
  .p-cm_pkg09 {
    animation: pkg09sp 5s infinite;
  }
}
@keyframes pkg09 {
  0% {
    transform: translate(0, 500%);
  }
  20% {
    transform: translate(-1000%, -300%);
  }
  70% {
    transform: translate(-1300%, 500%);
  }
  100% {
    transform: translate(0, 500%);
  }
}
@keyframes pkg09sp {
  0% {
    transform: translate(0, 500%);
  }
  20% {
    transform: translate(-500%, -300%);
  }
  70% {
    transform: translate(-700%, 500%);
  }
  100% {
    transform: translate(0, 500%);
  }
}
.p-cm_pkg01 img {
  animation: pkg 5s infinite;
}
.p-cm_pkg02 img {
  animation: pkg 6s infinite;
}
.p-cm_pkg03 img {
  animation: pkgR 3.2s infinite;
}
.p-cm_pkg04 img {
  animation: pkg 2.4s infinite;
}
.p-cm_pkg05 img {
  animation: pkgR 2.2s infinite;
}
.p-cm_pkg06 img {
  animation: pkg 1.8s infinite;
}
.p-cm_pkg07 img {
  animation: pkg 1.5s infinite;
}
.p-cm_pkg08 img {
  animation: pkgR 2.3s infinite;
}
.p-cm_pkg09 img {
  animation: pkgR 1.6s infinite;
}
@keyframes pkg {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(180deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes pkgR {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(-180deg);
  }
  100% {
    transform: rotate(-360deg);
  }
}
.p-cm_pkgSet01 {
  animation: pkgSet01 .8s infinite;
}
.p-cm_pkgSet02 {
  animation: pkgSet01 .7s infinite;
}
@keyframes pkgSet01 {
  0% {
    transform: translateY(0);
  }
  20% {
    transform: translateY(10px);
  }
  35% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(5px);
  }
  45% {
    transform: translateY(0);
  }
  60% {
    transform: translateY(5px);
  }
  80% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
  }
}