@charset "UTF-8";
@media (min-width: 768px) {
  .sp-show {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .pc-show {
    display: none !important;
  }
}
html, body {
  margin: 0;
  padding: 0;
}

body {
  background-size: 100%;
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}

button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none; /* ブラウザ独自のスタイル（立体感など）を解除 */
  background: transparent; /* 背景色を透明に */
  border: none; /* 枠線を消去 */
  padding: 0; /* 内側の余白をゼロに */
  margin: 0; /* 外側の余白をゼロに */
  outline: none; /* クリック時の青い枠などを制御（※注） */
  font: inherit; /* フォント関連を親要素から継承 */
  color: inherit; /* 文字色を親要素から継承 */
  cursor: pointer; /* ボタンだと分かるように指マークにするのが一般的 */
  text-align: inherit; /* テキストの揃えを継承 */
}

img {
  width: 100%;
}

.wrap {
  max-width: 768px;
  margin: 0 auto;
}

.kv {
  background: #f4e248;
  padding: 0 0 5%;
}
.kv .kv_logo {
  width: 22%;
  margin: 0% 0 0 9.6%;
  padding: 8.2% 0 0 0;
}
.kv .chara {
  width: 80%;
  margin: -28.1% 0 0 20%;
  padding: 0 0 0 0;
}
.kv .limited {
  width: 35%;
  margin: -20% 0 0 11.5%;
}
.kv .copyright {
  width: 19%;
  margin: -1.3% 0 0 65.9%;
}
.kv .prd {
  width: 100%;
  margin: 3% auto 0;
}

.sec01 {
  padding: 6.7% 0 0;
  position: relative;
  z-index: 1;
  background: #FFFFDE;
}
.sec01 .main_img {
  width: 52%;
  margin: 1.5% auto 0;
}
.sec01 .catch {
  width: 65%;
  margin: 1.8% 0 5.2% 17.7%;
}

.sec02 {
  padding: 8.7% 0 6.8%;
  background: #005e9d;
  position: relative;
  z-index: 2;
}
.sec02 .title01 {
  width: 51.8%;
  margin: 0% 0 0% 23.3%;
}
.sec02 .title02 {
  width: 26.2%;
  margin: 0.7% 0 6.3% 36.8%;
}
.sec02 .prd_box .prd_set .prd_img.prd_img01 {
  width: 72.7%;
  margin: 0 0 10% 19%;
}
.sec02 .prd_box .prd_set .prd_img.prd_img02 {
  width: 72.7%;
  margin: 0 0 10.6% 14%;
}
.sec02 .prd_box .prd_set .prd_img.prd_img03 {
  width: 54.8%;
  margin: 0 0 10% 18%;
}
.sec02 .prd_box .prd_set .prd_img.prd_img04 {
  width: 53.5%;
  margin: 0 0 10.1% 23%;
}
.sec02 .prd_box .prd_set .prd_img.prd_img05 {
  width: 80%;
  margin: 0 0 10% 10.6%;
}
.sec02 .prd_box ul.prd_set01 {
  width: 85.5%;
  margin: 0 0 0 7.5%;
  gap: 2%;
  display: flex;
  position: relative;
  z-index: 2;
}
.sec02 .prd_box ul.prd_set01 li {
  position: relative;
  z-index: 2;
}
.sec02 .prd_box ul.prd_set02 {
  width: 56.5%;
  margin: 50px 0 0 22%;
  gap: 2%;
  display: flex;
  position: relative;
  z-index: 1;
}
.sec02 .prd_box ul.prd_set02 li {
  position: relative;
  z-index: 2;
}
.sec02 .prd_box ul.prd_set02 li.icon_george {
  position: absolute;
  width: 51.3%;
  left: -38.8%;
  top: 24%;
  z-index: 1;
}
.sec02 .prd_box ul.prd_set02 li.icon_new {
  position: absolute;
  width: 31%;
  right: -9.6%;
  top: 0.6%;
  z-index: 1;
}
.sec02 .sec02_btn01 {
  width: 82%;
  margin: 0% 0 0% 4%;
}
.sec02 .sec02_btn01 .shop_dropdown {
  top: 78%;
}

.sec03 {
  padding: 8.7% 0 0.1%;
  background: #ffffde;
  position: relative;
  z-index: 1;
}
.sec03 .prd_box {
  width: 68.8%;
  margin: -10px 0 6% 13.7%;
  gap: 4%;
  display: flex;
  position: relative;
}
.sec03 .prd_box .prd_main {
  width: 119%;
  margin: 2.7% 0 0% 1.5%;
}
.sec03 .prd_box .prd_set .title01 {
  width: 109%;
  margin: 15.6% 0 0% -3.5%;
}
.sec03 .prd_box .prd_set .title02 {
  width: 115%;
  margin: 4.7% 0 0% -6.5%;
}
.sec03 .prd_box .prd_set .title03 {
  width: 115.7%;
  margin: -0.5% 0 0% -1.2%;
}
.sec03 .prd_box .prd_set .prd_photo ul {
  display: flex;
  gap: 3.7%;
  width: 102.5%;
  margin: 6% 0 0% 2%;
}
.sec03 .sec03_text {
  width: 70%;
  margin: 2.7% 0 5.3% 13.3%;
}
.sec03 .sec03_chara {
  width: 37.5%;
  margin: 0% 0 5.4% 29.3%;
}

.sec04 {
  padding: 8.4% 0 13.6%;
  background: #f4e248;
}
.sec04 .title01 {
  width: 51%;
  margin: 0 0 0 7%;
}
.sec04 .chara {
  width: 45.3%;
  margin: -18.3% 0 0% 52.2%;
}
.sec04 .bb01 {
  width: 40.5%;
  margin: -24.5% 0 0% 9.9%;
}
.sec04 .bb02 {
  width: 40.6%;
  margin: -13.2% 0 0% 46.8%;
}
.sec04 .bb03 {
  width: 40.9%;
  margin: -11.3% 0 0% 10%;
}
.sec04 .bb04 {
  width: 40.5%;
  margin: -14.3% 0 0% 48.2%;
}
.sec04 .title02 {
  width: 51.7%;
  margin: 2.6% 0 0% 26.3%;
}
.sec04 .prdbox ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10%;
  width: 76.5%;
  margin: 3% 0 0% 12.1%;
  justify-content: space-between;
}
.sec04 .prdbox ul li {
  width: 45%;
  margin: 0 0 8.5%;
}
.sec04 .prdbox ul li.single {
  width: 56.3%;
  margin: -4.4% 0 0 26.5%;
}

.sec05 {
  padding: 7% 0 39%;
  background-color: #ffffde;
}
.sec05 .title {
  width: 66.5%;
  margin: 0.1% 0 5.8% 16.7%;
}
.sec05 .photo {
  width: 75.1%;
  margin: 0% 0 7.2% 12.3%;
}
.sec05 .text {
  width: 61.3%;
  margin: 0% 0 5.7% 19.1%;
}
.sec05 .chara {
  width: 48.3%;
  margin: 0% 0 0 21.3%;
}

.footer_prd ul {
  display: flex;
  gap: 4.7%;
  width: 68.7%;
  margin: -33.2% 0 0% 15.5%;
}

.footer {
  margin: -13% 0 0;
  padding: 22.5% 0 13.3%;
  background: #005e9d;
}
.footer .footer_logo {
  width: 39.5%;
  margin: 0 0 0 28.8%;
}
.footer .footerlink {
  width: 90%;
  margin: 0 auto;
  margin-top: 3%;
  text-align: center;
  color: #fff;
}
@media (max-width: 767px) {
  .footer .footerlink {
    font-size: 1em;
  }
}
@media (min-width: 768px) {
  .footer .footerlink {
    font-size: 1.35em;
  }
}
.footer .footerlink span {
  padding: 0 0.8% 0 2%;
  color: #fff;
}
.footer .footerlink a {
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  line-height: 1.7em;
}
.footer .copyright {
  text-align: center;
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  line-height: 1.7em;
  margin-bottom: 10%;
}
@media (max-width: 767px) {
  .footer .copyright {
    font-size: 0.7em;
  }
}
@media (min-width: 768px) {
  .footer .copyright {
    font-size: 1em;
  }
}

.shop_dropdown {
  display: block;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
  position: absolute;
  top: 100%;
  background: #57afb3;
  padding: 8px;
  border-radius: 8px;
  margin-top: 10px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
  z-index: 10;
}
@media (max-width: 767px) {
  .shop_dropdown {
    left: 50%;
    width: 95%;
  }
}
@media (min-width: 768px) {
  .shop_dropdown {
    left: 51%;
    width: 92%;
  }
}
.shop_dropdown::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 10px solid #57afb3;
}
.shop_dropdown.is-open {
  opacity: 1;
  visibility: visible;
}

.shop_list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.shop_list li {
  margin-bottom: 5px;
}
.shop_list li:last-child {
  margin-bottom: 0;
}
.shop_list li a {
  display: block;
  background: #fff;
  color: #d71618;
  text-decoration: none;
  padding: 10px;
  text-align: center;
  font-weight: bold;
  border-radius: 4px;
  transition: opacity 0.2s;
}
.shop_list li a:hover {
  opacity: 0.8;
}

/* 共通設定 */
.reveal {
  opacity: 0;
  /* 変数がなければ空、あればそれを反映しつつ下に30pxずらす */
  transform: var(--original-transform, ) translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
  visibility: hidden;
}

/* 表示時 */
.reveal.active {
  opacity: 1;
  /* 元のtransformを維持したまま、位置だけ0に戻す */
  transform: var(--original-transform, ) translateY(0);
  visibility: visible;
}

/* 3段階のタイミング */
.delay-1 {
  transition-delay: 0.1s;
}

.delay-2 {
  transition-delay: 0.3s;
}

.delay-3 {
  transition-delay: 0.5s;
}

.delay-4 {
  transition-delay: 0.7s;
}

.delay-5 {
  transition-delay: 0.9s;
}

.bg-reveal {
  /* アニメーションの初期状態：左側に隠す */
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.2s cubic-bezier(0.25, 1, 0.5, 1); /* スルスルっと動くイージング */
}

/* クラスがついた時に全表示 */
.bg-reveal.active {
  clip-path: inset(0 0 0 0);
}/*# sourceMappingURL=style.css.map */