@charset "utf-8";

/* =====================================================
    調整
===================================================== */
html {
	background-color: transparent !important;
}

/*--帯バナー非表示用--*/
.h_bar, #beltbnr {
	display: none;
}

#specialty {
  overflow: hidden;
}

#specialty a {
  text-decoration: none;
}

#specialty a:hover img {
  opacity: 1 !important;
}

#specialty figure {
  margin: 0;
}

@media only screen and (min-width: 768px) {
  #specialty {
    margin-top: 6px;
  }
}

/*--sticky用--*/
/* html, body, div.wrapper_ {
  overflow: visible !important;
} */

/*--SPのみ表示用--*/
@media only screen and (max-width: 429px) {
  .sp {
    display: block;
  }

  .pc {
    display: none;
  }
}

@media only screen and (min-width: 430px) and (max-width: 767px) {
  .sp {
    display: none;
  }

  .pc {
    display: none;
  }
}

/*--PCのみ表示用--*/
@media only screen and (min-width: 768px) {
  .sp {
    display: none;
  }

  .pc {
    display: block;
  }
}

/* =====================================================
    FONT
===================================================== */
:root {
  --leading-trim: calc((1em - 1lh) / 2);
  --font-size-8: min(1.8604651162790697vw, 8px);
  --font-size-10: min(2.3255813953488373vw, 10px);
  --font-size-12: min(2.7906976744186047vw, 12px);
  --font-size-14: min(3.255813953488372vw, 14px);
  --font-size-16: min(3.7209302325581395vw, 16px);
  --font-size-18: min(4.186046511627907vw, 18px);
  --font-size-20: min(4.651162790697675vw, 20px);
  --font-size-22: min(5.116279069767442vw, 22px);
  --font-size-24: min(5.5813953488372094vw, 24px);
  --font-size-26: min(6.046511627906977vw, 26px);
  --font-size-28: min(6.511627906976744vw, 28px);
  --font-size-30: min(6.976744186046512vw, 30px);
  --font-size-40: min(9.30232558139535vw, 40px);
  --font-size-50: min(11.627906976744185vw, 50px);
  --font-size-60: min(13.953488372093023vw, 60px);
}

@supports not (top: 1lh) {
  :root {
    --leading-trim: 0px;
  }
}

.noto-sans-jp-400 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.noto-sans-jp-700 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.futura-pt-bold {
  font-family: "futura-pt-bold", sans-serif;
  font-weight: 700;
  font-style: normal;
}

/* =====================================================
    BG
===================================================== */
@media only screen and (min-width: 768px) {
  .content {
    background: #f6efdd;
    padding: 60px 0;
  }

  .bg__wrapper {
    width: 100%;
    max-width: 550px;
    margin: 60px auto;
    padding: 30px;
    background: #ffffff;
    border: 1px solid #000000;
    border-radius: 30px;
  }
}

/* =====================================================
    KV
===================================================== */
.kv__inner {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}

/* =====================================================
    LEAD
===================================================== */
.lead__inner {
  width: calc(100% - 30px * 2);
  margin: 30px auto 0;
  background: #ffffff;
}

.lead__inner p {
  font-size: var(--font-size-14);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

@media only screen and (min-width: 768px) {
  .lead__inner {
    width: 100%;
  }
}

/* =====================================================
    MENU
===================================================== */
.menu__inner {
  width: 100%;
  margin: 60px auto;
  text-align: center;
}

.menu__inner h3 {
  font-size: var(--font-size-20);
  line-height: 2;
  color: #8290C8;
  text-align: center;
  margin-block: var(--leading-trim);
}

.menu__inner ul {
  margin: 20px auto 0;
  display: inline-flex;
  justify-content: center;
  align-items: start;
  gap: 30px;
}

.menu__inner li, 
.menu__inner li a {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
}

.menu__inner li:nth-of-type(1) p, 
.menu__inner li:nth-of-type(4) p {
  padding-top: 20px;
  font-size: var(--font-size-10);
  line-height: 2;
  color: #8290C8;
  text-align: center;
  margin-block: var(--leading-trim);
}

.menu__inner li:nth-of-type(2) p {
  line-height: 1.5;
  color: #2AAAE4;
  text-align: center;
  margin-block: var(--leading-trim);
  background: #EAF8FF;
  border: 1px solid #2AAAE4;
  border-radius: 50%;
  width: 100px;
  height: 60px;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  transition: .3s cubic-bezier(0.45, 0, 0.55, 1);
}

.menu__inner li:nth-of-type(3) p {
  line-height: 1.5;
  color: #28BA7D;
  text-align: center;
  margin-block: var(--leading-trim);
  background: #EAFFF6;
  border: 1px solid #28BA7D;
  border-radius: 50%;
  width: 100px;
  height: 60px;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  transition: .3s cubic-bezier(0.45, 0, 0.55, 1);
}

.menu__inner li:nth-of-type(2) a:hover p, 
.menu__inner li:nth-of-type(3) a:hover p {
  background: #ffffff;
}

.menu__inner li:nth-of-type(2) p span:nth-of-type(1), 
.menu__inner li:nth-of-type(3) p span:nth-of-type(1) {
  font-size: var(--font-size-16);
}

.menu__inner li:nth-of-type(2) p span:nth-of-type(2), 
.menu__inner li:nth-of-type(3) p span:nth-of-type(2) {
  font-size: var(--font-size-12);
}

.menu__inner li:nth-of-type(1) div {
  width: 30px;
  margin-top: -10px;
}

.menu__inner li:nth-of-type(2) div {
  width: 100px;
  margin-top: -15px;
}

.menu__inner li:nth-of-type(3) div {
  width: 100px;
  margin-top: -15px;
}

.menu__inner li:nth-of-type(4) div {
  width: 30px;
  margin-top: -10px;
}

/* =====================================================
    MAP
===================================================== */
#route01.map {
  background: #EAF8FF;
  padding: 40px 20px;
}

#route02.map {
  background: #EAFFF6;
  padding: 40px 20px;
}

.map__innner .title__area {
  position: relative;
  text-align: center;
}

.map__innner .title__area h3 {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
}

.map__innner .title__area h3 span:nth-of-type(1) {
  font-size: var(--font-size-24);
  line-height: 1.2;
  text-align: center;
  margin-block: var(--leading-trim);
}

.map__innner .title__area h3 span:nth-of-type(2) {
  padding-top: 10px;
  font-size: var(--font-size-12);
  line-height: 2;
  text-align: center;
  margin-block: var(--leading-trim);
}

#route01 .map__innner .title__area h3 span:nth-of-type(1), 
#route01 .map__innner .title__area h3 span:nth-of-type(2) {
  color: #2AAAE4;
}

#route02 .map__innner .title__area h3 span:nth-of-type(1), 
#route02 .map__innner .title__area h3 span:nth-of-type(2) {
  color: #28BA7D;
}

.map__innner .title__area h4 {
  margin-top: 20px;
  padding: 10px 0;
  font-size: var(--font-size-18);
  line-height: 1;
  text-align: center;
  display: inline-block;
}

#route01 .map__innner .title__area h4 {
  color: #2AAAE4;
  border-top: 1px solid #2AAAE4;
  border-bottom: 1px solid #2AAAE4;
}

#route02 .map__innner .title__area h4 {
  color: #28BA7D;
  border-top: 1px solid #28BA7D;
  border-bottom: 1px solid #28BA7D;
}

#route01 .map__innner .title__area .icon {
  width: 21.53%;
  position: absolute;
  top: -5%;
  left: 5%;
}

#route02 .map__innner .title__area .icon {
  width: 21.53%;
  position: absolute;
  top: 16%;
  left: 5%;
}
.map__innner .txt_area {
  margin-top: 30px;
}

.map__innner .txt_area p {
  font-size: var(--font-size-16);
  line-height: 1.5;
  color: #000000;
  text-align: center;
  margin-block: var(--leading-trim);
}

.map__innner .img__area {
  margin: 30px auto 0;
}

.map__innner .timeline__area {
  margin: 40px auto 0;
  display: flex;
  justify-content: start;
  align-items: start;
}

.map__innner .timeline {
  margin: 7px 20px 0 10px;
}

.map__innner .timeline .time {
  font-size: var(--font-size-16);
  line-height: 2;
  color: #000000;
  text-align: center;
  margin-block: var(--leading-trim);
}

.map__innner .timeline .walk {
  font-size: var(--font-size-10);
  line-height: 2;
  color: #000000;
  text-align: center;
  margin-block: var(--leading-trim);
  position: relative;
  padding: 34px 0;
}

.map__innner .timeline .walk::before, 
.map__innner .timeline .walk::after {
  content: '';
  position: absolute;
  left: 50%;
  width: 1px;
  height: 15px;
  transform: translateX(-50%);
  background-image: linear-gradient(to bottom, #666666 50%, rgba(255, 255, 255, 0) 0%);
  background-size: 1px 3px;
  background-repeat: repeat-y;
  background-position: top;
}

.map__innner .timeline .walk::before {
  top: 10px;
}

.map__innner .timeline .walk::after {
  bottom: 10px;
}

.map__innner .guide .guide-item {
  margin-bottom: 40px;
  display: flex;
  justify-content: start;
  align-items: start;
  gap: 10px;
  position: relative;
}

.map__innner .guide .guide-item .pin {
  width: 30px;
}

.map__innner .guide .guide-item .txt p {
  font-size: var(--font-size-12);
  line-height: 2;
  color: #000000;
  text-align: left;
  margin-block: var(--leading-trim);
}

.map__innner .guide .guide-item .txt h5 {
  font-size: var(--font-size-16);
  line-height: 2;
  color: #000000;
  text-align: left;
  margin-block: var(--leading-trim);
}

.map__innner .guide .guide-item .txt button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  margin-top: 12px;
  padding: 3px 6px;
  background: #8290C8;
  border-radius: 50px;
  border: 1px solid #8290C8;
  cursor: pointer;
  font-size: var(--font-size-10);
  line-height: 1;
  color: #ffffff;
  text-align: left;
}

.map__innner .guide .guide-item .txt button:hover {
  background: #ffffff;
  color: #8290C8;
}

.map__innner .guide .guide-item .txt button:hover .arrow {
  animation: move 0.5s ease-out forwards;
}

@keyframes move {
  0% { transform: translateX(-10px); }
  100% { transform: translateX(0); }
}

#route01 .map__innner .guide .guide-item.guide02 .illust {
  position: absolute;
  top: 5%;
  left: 85%;
  width: 20%;
}

#route01 .map__innner .guide .guide-item.guide03 .illust {
  position: absolute;
  top: 35%;
  left: 77%;
  width: 25%;
}

#route01 .map__innner .guide .guide-item.guide05 .illust {
  position: absolute;
  top: 25%;
  left: 85%;
  width: 20%;
}

#route02 .map__innner .guide .guide-item.guide02 .illust {
  position: absolute;
  top: 5%;
  left: 92%;
  width: 25%;
}

#route02 .map__innner .guide .guide-item.guide03 .illust {
  position: absolute;
  top: 35%;
  left: 85%;
  width: 25%;
}

#route02 .map__innner .guide .guide-item.guide05 .illust {
  position: absolute;
  top: 0;
  left: 90%;
  width: 30%;
}

/* 矢印 */
.arrow {
  position: relative;
  display: inline-block;
  width: 7px;
  height: 1px;
  margin: 1.4px 0;
  border-radius: 9999px;
  background-color: #ffffff;
}

.arrow::before,
.arrow::after {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  right: 0;
  width: 5px;
  height: 1px;
  border-radius: 9999px;
  background-color: #ffffff;
  transform-origin: calc(100% - 0.5px) 50%;
}

.arrow::before {
  transform: rotate(45deg);
}

.arrow::after {
  transform: rotate(-45deg);
}

/* HOVER */
.map__innner .guide .guide-item .txt button:hover .arrow  {
  background-color: #8290C8;
}

.map__innner .guide .guide-item .txt button:hover .arrow::before,
.map__innner .guide .guide-item .txt button:hover .arrow::after {
  background-color: #8290C8;
}

@media only screen and (min-width: 768px) {
  .map__innner .timeline {
    margin: 7px 20px 0 30px;
  }
}

/* =====================================================
    SHOP
===================================================== */
.shop__inner {
  width: 100%;
  margin: 40px auto 0;
}

.shop__logo {
  width: 23.48%;
  margin: 0 auto;
}

.shop__inner h3 {
  padding-top: 40px;
  font-size: var(--font-size-24);
  line-height: 2;
  color: #8290C8;
  text-align: center;
  margin-block: var(--leading-trim);
}

.shop__inner .slide__area {
  width: calc(100% - 20px * 2);
  margin: 30px auto 0;
}

.shop__inner .txt__area {
  width: calc(100% - 30px * 2);
  margin: 30px auto 0;
}

.shop__inner .txt__area p:nth-of-type(1) {
  font-size: var(--font-size-14);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.shop__inner .txt__area p:nth-of-type(2) {
  padding-top: 30px;
  font-size: var(--font-size-12);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.item__inner {
  width: 100%;
  margin: 60px auto 0;
}

.item__inner h4 {
  font-size: var(--font-size-18);
  line-height: 2;
  color: #8290C8;
  text-align: center;
  margin-block: var(--leading-trim);
}

.item__inner .img__area {
  width: calc(100% - 20px * 2);
  margin: 20px auto 0;
}

.item__inner .txt__area {
  width: calc(100% - 30px * 2);
  margin: 30px auto 0;
}

.item__inner .txt__area p {
  font-size: var(--font-size-14);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.item__inner .scroll__area {
  margin-top: 30px;
  display: flex;
  overflow: hidden;
  white-space: nowrap;
}

.item__inner .scroll__area p {
  padding-right: 5px;
  font-size: var(--font-size-16);
  line-height: 2;
  color: #8290C8;
  text-align: left;
  margin-block: var(--leading-trim);
  display: flex;
  justify-content: center;
  align-items: flex-end;
  animation: scroll 10s linear infinite;
}

@keyframes scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

.item__inner .slide__area {
  width: calc(100% - 60px * 2);
  margin: 30px auto 0;
}

/* TOGGLE */
.product-card {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.product-img {
  width: 100%;
  height: 100%;
}

.product-info {
  width: 100%;
  height: 100%;
  padding: 20px;
  background: rgba(0, 0, 0, 50%);
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}

.product-card.is-active .product-info {
  opacity: 1;
}

.product-credit {
  display: flex;
  justify-content: start;
  align-items: center;
  gap: 15px;
}

.product-credit p {
  font-size: var(--font-size-12);
  line-height: 2;
  color: #ffffff;
  text-align: left;
  margin-block: var(--leading-trim);
}

/* 
.product-credit p a {
  color: #ffffff;
}

.product-credit > a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0 10px;
  background: #ffffff;
  border: 1px solid #ffffff;
  border-radius: 50px;
  font-size: var(--font-size-10);
  line-height: 1.5;
  color: #000000;
  text-align: center;
  margin-block: var(--leading-trim);
}

.product-credit > a:hover {
  background: transparent;
  color: #ffffff;
}
 */

.toggle-btn {
  width: 20px;
  height: 20px;
  background: transparent;
  border: none;
  cursor: pointer;
  position: absolute;
  right: 20px;
  bottom: 20px;
}

.toggle-btn span {
  width: 20px;
  height: 1px;
  background: #8290C8;
  transition: .3s ease;
  position: absolute;
  top: 50%;
  left: 50%;
}

.toggle-btn span:nth-child(1) {
  transform: translate(-50%, -50%);
}

.toggle-btn span:nth-child(2) {
  transform: translate(-50%, -50%) rotate(90deg);
}

.product-card.is-active .toggle-btn span {
  background: #ffffff;
}

.product-card.is-active .toggle-btn span:nth-child(1) {
  transform: translate(-50%, -50%) rotate(45deg);
}

.product-card.is-active .toggle-btn span:nth-child(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* =====================================================
    HACHIOJI
===================================================== */
.hachioji__inner {
  width: 100%;
  margin: 80px auto;
  border-top: 1px solid #453085;
}

.hachioji__inner h3 {
  padding-top: 60px;
  font-size: var(--font-size-24);
  line-height: 2;
  color: #453085;
  text-align: center;
  margin-block: var(--leading-trim);
}

.hachioji__inner .txt__area {
  width: calc(100% - 30px * 2);
  margin: 30px auto 0;
}

.hachioji__inner .txt__area p:nth-of-type(1) {
  font-size: var(--font-size-16);
  line-height: 1.5;
  color: #333333;
  text-align: center;
  margin-block: var(--leading-trim);
}

.hachioji__inner .txt__area p:nth-of-type(2) {
  padding-top: 30px;
  font-size: var(--font-size-14);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.hachioji__inner .logo__area {
  width: calc(100% - 30px * 2);
  margin: 30px auto 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.hachioji__inner .logo__area div {
  width: 36.21%;
}

.hachioji__inner .logo__area p {
  font-size: var(--font-size-12);
  line-height: 2;
  color: #453085;
  text-align: left;
  margin-block: var(--leading-trim);
}

.hachioji__inner .logo__area p a {
  color: #453085;
}

.hachioji__inner .link__area {
  width: calc(100% - 30px * 2);
  margin: 30px auto 0;
}

.hachioji__inner .link__area p:nth-of-type(1) {
  font-size: var(--font-size-14);
  line-height: 1.5;
  color: #ffffff;
  text-align: left;
  margin-block: var(--leading-trim);
}

.hachioji__inner .link__area p:nth-of-type(1) span {
  display: inline-block;
  padding: 0 13px;
  background: #453085;
  border-radius: 50px;
}

.hachioji__inner .link__area p:nth-of-type(2) {
  padding-top: 20px;
  font-size: var(--font-size-14);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.hachioji__inner .link__area p:nth-of-type(2) a {
  color: #333333;
  text-decoration: underline !important;
}

.hachioji__inner .link__area p:nth-of-type(2) a:hover {
  text-decoration: none !important;
}

/* =====================================================
    SWIPER
===================================================== */
.swiper-area {
  position: relative;
}

.js-swiper-pagination {
  bottom: -25px !important;
}

.swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin: 0 5px !important;
  background: #ffffff;
  border: 1px solid #8290C8;
  border-radius: 50%;
  opacity: 1;
}

.swiper-pagination-bullet-active {
  background: #8290C8;
}

.swiper-button-next,
.swiper-button-prev {
  background-color: #ffffff;
  border-radius: 50%;
  width: 31px;
  height: 31px;
}

.swiper-button-next::after,
.swiper-button-prev::after {
  content: '';
}

.arrow-next {
  position: relative;
  display: inline-block;
  width: 12px;
  height: 1px;
  margin: 3.6px 0;
  border-radius: 9999px;
}

.arrow-next::before,
.arrow-next::after {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  right: 0;
  width: 9px;
  height: 1px;
  border-radius: 9999px;
  transform-origin: calc(100% - 0.5px) 50%;
}

.arrow-next::before {
  transform: rotate(45deg);
}

.arrow-next::after {
  transform: rotate(-45deg);
}

.arrow-prev {
  position: relative;
  display: inline-block;
  width: 12px;
  height: 1px;
  margin: 5.7px 0;
  border-radius: 9999px;
}

.arrow-prev::before,
.arrow-prev::after {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  left: 0;
  width: 9px;
  height: 1px;
  border-radius: 9999px;
  transform-origin: 0.5px 50%;
}

.arrow-prev::before {
  transform: rotate(45deg);
}

.arrow-prev::after {
  transform: rotate(-45deg);
}

/* SHOP */
.shop__inner .slide__area .swiper {
  border-radius: 10px;
}

.shop__inner .slide__area .swiper-button-next {
  border: 1px solid #8290C8;
  color: #8290C8;
  right: -10px;
}

.shop__inner .slide__area .swiper-button-prev {
  border: 1px solid #8290C8;
  color: #8290C8;
  left: -10px;
}

.shop__inner .slide__area .arrow-next, 
.shop__inner .slide__area .arrow-prev, 
.shop__inner .slide__area .arrow-next::before, 
.shop__inner .slide__area .arrow-next::after, 
.shop__inner .slide__area .arrow-prev::before, 
.shop__inner .slide__area .arrow-prev::after {
  background-color: #8290c8;
}

/* ITEM */
.item__inner .slide__area .swiper-button-next {
  border: 1px solid #8290C8;
  color: #8290C8;
  right: -40px;
}

.item__inner .slide__area .swiper-button-prev {
  border: 1px solid #8290C8;
  color: #8290C8;
  left: -40px;
}

.item__inner .slide__area .arrow-next, 
.item__inner .slide__area .arrow-prev, 
.item__inner .slide__area .arrow-next::before, 
.item__inner .slide__area .arrow-next::after, 
.item__inner .slide__area .arrow-prev::before, 
.item__inner .slide__area .arrow-prev::after {
  background-color: #8290c8;
}

/* MODAL */
.modal__inner .slide__area .swiper {
  border-radius: 10px;
}

.modal__inner .item__inner .slide__area .swiper {
  border-radius: 0;
}

.modal__inner.blue .slide__area .swiper-button-next {
  border: 1px solid #2AAAE4;
  color: #2AAAE4;
  right: -10px;
}

.modal__inner.blue .slide__area .swiper-button-prev {
  border: 1px solid #2AAAE4;
  color: #2AAAE4;
  left: -10px;
}

.modal__inner.blue .slide__area .arrow-next, 
.modal__inner.blue .slide__area .arrow-prev, 
.modal__inner.blue .slide__area .arrow-next::before, 
.modal__inner.blue .slide__area .arrow-next::after, 
.modal__inner.blue .slide__area .arrow-prev::before, 
.modal__inner.blue .slide__area .arrow-prev::after {
  background-color: #2AAAE4;
}

.modal__inner.green .slide__area .swiper-button-next {
  border: 1px solid #28BA7D;
  color: #28BA7D;
  right: -10px;
}

.modal__inner.green .slide__area .swiper-button-prev {
  border: 1px solid #28BA7D;
  color: #28BA7D;
  left: -10px;
}

.modal__inner.green .slide__area .arrow-next, 
.modal__inner.green .slide__area .arrow-prev, 
.modal__inner.green .slide__area .arrow-next::before, 
.modal__inner.green .slide__area .arrow-next::after, 
.modal__inner.green .slide__area .arrow-prev::before, 
.modal__inner.green .slide__area .arrow-prev::after {
  background-color: #28BA7D;
}

.modal__inner.purple .slide__area .swiper-button-next, 
.modal__inner.purple .slide__area .swiper-button-prev {
  border: 1px solid #8290C8;
  color: #8290C8;
}

.modal__inner.purple .shop__inner .slide__area .swiper-button-next {
  right: -10px;
}

.modal__inner.purple .shop__inner .slide__area .swiper-button-prev {
  left: -10px;
}

.modal__inner.purple .item__inner .slide__area .swiper-button-next {
  right: -40px;
}

.modal__inner.purple .item__inner .slide__area .swiper-button-prev {
  left: -40px;
}

.modal__inner.purple .slide__area .arrow-next, 
.modal__inner.purple .slide__area .arrow-prev, 
.modal__inner.purple .slide__area .arrow-next::before, 
.modal__inner.purple .slide__area .arrow-next::after, 
.modal__inner.purple .slide__area .arrow-prev::before, 
.modal__inner.purple .slide__area .arrow-prev::after {
  background-color: #8290C8;
}

/* =====================================================
    MODAL
===================================================== */
html.is-fixed,
body.is-fixed {
  overflow: hidden !important;
}

.modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .4s ease, visibility .4s ease;
  z-index: 99999;
  overflow-y: auto;
}

.modal.is-active {
  opacity: 1;
  visibility: visible;
}

.modal__inner {
  width: min(100%, 600px);
  height: 100%;
  overflow: scroll;
  scrollbar-width: none;
  -ms-overflow-style: none;
  background: #ffffff;
  position: relative;
  transform: translateY(20px);
  transition: transform .4s ease;
}

.modal__inner::-webkit-scrollbar {
  display: none;
}

.modal.is-active .modal__inner {
  transform: translateY(0);
}

.modal__inner .js-close {
  width: 35px;
  height: 35px;
  background: transparent;
  border-radius: 50%;
  cursor: pointer;
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
}

.modal__inner.blue .js-close {
  border: 1px solid #2AAAE4;
}

.modal__inner.green .js-close {
  border: 1px solid #28BA7D;
}

.modal__inner.purple .js-close {
  border: 1px solid #8290C8;
}

.modal__inner .js-close span {
  width: 15px;
  height: 1px;
  position: absolute;
  top: 50%;
  left: 50%;
}

.modal__inner.blue .js-close span {
  background: #2AAAE4;
}

.modal__inner.green .js-close span {
  background: #28BA7D;
}

.modal__inner.purple .js-close span {
  background: #8290C8;
}

.modal__inner .js-close span:nth-child(1) {
  transform: translate(-50%, -50%) rotate(45deg);
}

.modal__inner .js-close span:nth-child(2) {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.modal__inner .ttl__area div {
  width: 40.69%;
  margin: 50px auto 0;
}

.modal__inner .ttl__area h5 {
  padding-top: 30px;
  font-size: var(--font-size-22);
  line-height: 1.5;
  text-align: center;
  margin-block: var(--leading-trim);
}

.modal__inner.blue .ttl__area h5 {
  color: #2AAAE4;
}

.modal__inner.green .ttl__area h5 {
  color: #28BA7D;
}

.modal__inner.purple .ttl__area h5 {
  color: #8290C8;
}

.modal__inner .slide__area {
  width: calc(100% - 20px * 2);
  margin: 30px auto 0;
}

.modal__inner .txt__area {
  width: calc(100% - 30px * 2);
  margin: 30px auto 40px;
}

.modal__inner .txt__area p:nth-of-type(1) {
  font-size: var(--font-size-14);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.modal__inner .txt__area p:nth-of-type(2) {
  padding-top: 30px;
  font-size: var(--font-size-12);
  line-height: 2;
  color: #333333;
  text-align: left;
  margin-block: var(--leading-trim);
}

.modal__inner .txt__area p:nth-of-type(2) a {
  color: #8290C8;
}

/* any */
.modal__inner .shop__inner h3 {
  font-size: var(--font-size-18);
}

.modal__inner .item__inner {
  margin: 60px auto;
}

.modal__inner .item__inner .slide__area {
  width: calc(100% - 60px * 2);
  margin: 30px auto 0;
}

@media only screen and (min-width: 768px) {
  .modal__inner {
    height: 90%;
    border-radius: 12px;
  }

  .modal__inner .ttl__area div {
    width: 29.16%;
  }

  .modal__inner .shop__logo {
    width: 16.66%;
  }
}

/* =====================================================
    ANIMATION
===================================================== */
.kv {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .8s ease, transform .8s ease;
}

.kv.is-show {
  opacity: 1;
  transform: translateY(0);
}

.js-tokotoko1 {
  animation: tokotoko1 1.5s infinite alternate ease-in-out;
}

@keyframes tokotoko1 {
  0% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-1px) rotate(3deg); }
  100% { transform: translateY(0) rotate(0deg); }
}

.js-tokotoko2 {
  animation: tokotoko2 1.5s infinite alternate ease-in-out;
}

@keyframes tokotoko2 {
  0% { transform: translateY(-1px) rotate(3deg); }
  50% { transform: translateY(0) rotate(0deg); }
  100% { transform: translateY(-1px) rotate(3deg); }
}

.js-balloon {
  opacity: 0;
}

.js-balloon.is-active {
  animation: balloon 0.5s ease-in-out forwards;
}

@keyframes balloon {
  0% {
    opacity: 0;
    transform: translateY(50px) scale(0.5);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.js-yurayura {
  animation: yurayura 1s ease-in-out infinite alternate;
}

@keyframes yurayura {
  0% { transform: rotate(-15deg); }
  100% { transform: rotate(15deg); }
}

.js-kurukuru {
  perspective: 1000px;
  animation: kurukuru 2.5s infinite linear;
}

@keyframes kurukuru {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(360deg); }
}

.js-fuwafuwa {
  animation: fuwafuwa 1.5s ease-in-out infinite alternate;
}

@keyframes fuwafuwa {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.2);
  }
}