@charset "UTF-8";
.intro-animation {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  height: 100svh;
  z-index: 999;
  overflow: hidden;
}
.intro-animation__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.intro-animation__video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
}
.intro-animation__bars {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  display: flex;
}
.intro-animation__bar {
  position: relative;
  background-color: #000000;
  flex: 1;
  padding: 0 1px;
  height: 100%;
  transform: translateY(0);
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.intro-animation__bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 100%;
  width: 1px;
  height: 100%;
  background-color: #000000;
}
.intro-animation__logo-wrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4rem;
  z-index: 3;
}
@media (max-width: 1024px) {
  .intro-animation__logo-wrapper {
    gap: 2.8rem;
  }
}
.intro-animation__logo {
  width: 28rem;
  height: 8.4rem;
  opacity: 0;
}
@media (max-width: 1024px) {
  .intro-animation__logo {
    width: 22rem;
    height: 6.6rem;
  }
}
.intro-animation__logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.intro-animation__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.8rem;
}
.intro-animation__line {
  display: block;
  font-family: "NanumSquareNeo", sans-serif;
  font-size: 4rem;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.16rem;
  color: #ffffff;
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .intro-animation__line {
    font-size: 2.8rem;
  }
}
@media (max-width: 680px) {
  .intro-animation__line {
    font-size: 2.2rem;
  }
}
.intro-animation__progress {
  position: relative;
  width: 48rem;
  height: 0.2rem;
}
@media (max-width: 680px) {
  .intro-animation__progress {
    width: calc(100vw - 7rem);
  }
}
.intro-animation__progress-track {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: #ffffff;
  opacity: 0.2;
}
.intro-animation__progress-bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: #ffffff;
  transform-origin: left center;
}

main.main {
  background-color: #ffffff;
}
main.main .swiper-wrapper {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: row;
}
main.main .main-kv {
  position: relative;
  width: 100%;
  height: 100vh;
  height: 100svh;
  overflow: hidden;
  will-change: transform;
}
main.main .main-kv--media {
  padding-top: 0;
}
@media (max-width: 1024px) {
  main.main .main-kv--media {
    padding-top: 0;
  }
}
main.main .main-kv__row {
  align-items: flex-end;
}
@media (max-width: 1024px) {
  main.main .main-kv__row {
    row-gap: var(--spacing-13, 5.6rem);
  }
}
main.main .main-kv__slider {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
main.main .main-kv__slider--single .main-kv__navigation {
  display: none;
}
@media (max-width: 1024px) {
  main.main .main-kv__slider--single .main-kv__content {
    padding-bottom: 6.2rem;
  }
}
@media (max-width: 680px) {
  main.main .main-kv__slider--single .main-kv__content {
    padding-bottom: 3.4rem;
  }
}
main.main .main-kv__slider .swiper {
  width: 100%;
  height: 100%;
}
main.main .main-kv__slider .image-wrapper {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
main.main .main-kv__slider img,
main.main .main-kv__slider video,
main.main .main-kv__slider picture {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
main.main .main-kv__slide {
  position: relative;
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  pointer-events: none;
}
main.main .main-kv__slide.swiper-slide-active {
  pointer-events: auto;
}
main.main .main-kv__slide--white .main-kv__badge {
  background-color: #ffffff;
  color: #000000;
}
main.main .main-kv__slide--white .main-kv__badge-dot {
  background-color: #000000;
}
main.main .main-kv__slide--white .main-kv__text h2 {
  color: #ffffff;
}
main.main .main-kv__slide--white .main-kv__button {
  border: 1px solid #ffffff;
  color: #ffffff;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .main-kv__slide--white .main-kv__button:hover {
    background-color: #ffffff;
    color: #000000;
  }
  main.main .main-kv__slide--white .main-kv__button:hover .main-kv__button-dot {
    background-color: #000000;
  }
}
main.main .main-kv__slide--white .main-kv__background-gradient {
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.2) 30%, rgba(0, 0, 0, 0.8) 100%);
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.2) 30%, rgba(0, 0, 0, 0.8) 100%);
}
main.main .main-kv__background-gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 40rem;
  background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.2) 30%, rgba(255, 255, 255, 0.8) 100%);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.2) 30%, rgba(255, 255, 255, 0.8) 100%);
  pointer-events: none;
  z-index: 1;
}
@media (max-width: 1024px) {
  main.main .main-kv__background-gradient {
    height: 46rem;
  }
}
@media (max-width: 680px) {
  main.main .main-kv__background-gradient {
    height: 36rem;
  }
}
main.main .main-kv__content {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  padding-bottom: clamp(3.6rem, 2.5vw, 4.8rem);
  z-index: 2;
}
@media (max-width: 1024px) {
  main.main .main-kv__content {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    gap: var(--spacing-10, 3.6rem);
    padding-bottom: calc(clamp(3.6rem, 2.5vw, 4.8rem) + 0.2rem + var(--spacing-9));
  }
}
main.main .main-kv__text {
  max-width: 118.4rem;
}
main.main .main-kv__badge {
  display: inline-flex;
  align-items: center;
  padding-left: var(--spacing-4, 1.2rem);
  padding-right: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-1, 0.4rem);
  padding-bottom: var(--spacing-1, 0.4rem);
  gap: var(--spacing-2, 0.8rem);
  background-color: #000000;
  color: #ffffff;
}
main.main .main-kv__badge-dot {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background-color: #ffffff;
  flex-shrink: 0;
}
main.main .main-kv__buttons {
  display: flex;
  gap: var(--spacing-3, 1rem);
}
main.main .main-kv__button {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-6, 2rem);
  padding-top: var(--spacing-2, 0.8rem);
  padding-bottom: var(--spacing-2, 0.8rem);
  background-color: transparent;
  border: 1px solid #000000;
  cursor: pointer;
  transition: all 0.2s;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .main-kv__button:hover {
    background-color: #000000;
    color: #ffffff;
  }
  main.main .main-kv__button:hover .main-kv__button-dot {
    background-color: #ffffff;
  }
}
main.main .main-kv__navigation {
  position: absolute;
  bottom: 0;
  left: 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  gap: var(--spacing-6, 2rem);
  padding-bottom: clamp(3.6rem, 2.5vw, 4.8rem);
  pointer-events: none;
  z-index: 100;
}
@media (max-width: 1024px) {
  main.main .main-kv__navigation {
    width: 100%;
  }
}
main.main .main-kv__navigation--white .main-kv__progress-item {
  background-color: rgba(255, 255, 255, 0.2);
}
main.main .main-kv__navigation--white .main-kv__progress-bar {
  background-color: #ffffff;
}
main.main .main-kv__progress {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-2, 0.8rem);
}
@media (max-width: 1024px) {
  main.main .main-kv__progress {
    justify-content: flex-start;
  }
}
main.main .main-kv__progress-item {
  position: relative;
  width: 2.4rem;
  height: 0.2rem;
  background-color: rgba(0, 0, 0, 0.2);
  cursor: pointer;
  overflow: hidden;
  transition: width 0.3s ease;
}
main.main .main-kv__progress-item.is-active {
  width: 4.8rem;
}
main.main .main-kv__progress-item.is-animating .main-kv__progress-bar {
  transform: scaleX(1);
  transition: transform var(--autoplay-delay, 8000ms) linear;
}
main.main .main-kv__progress-bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000000;
  transform: scaleX(0);
  transform-origin: left;
  transform-origin: left center;
}
main.main .main-kv__media {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
main.main .main-kv__media img,
main.main .main-kv__media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
main.main .main-kv__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
main.main .main-kv__video--intro {
  z-index: 1;
}
main.main .main-kv__video--loop {
  z-index: 0;
}
main.main .main-kv__video--desktop {
  display: block;
}
@media (max-width: 680px) {
  main.main .main-kv__video--desktop {
    display: none !important;
  }
}
main.main .main-kv__video--mobile {
  display: none;
}
@media (max-width: 680px) {
  main.main .main-kv__video--mobile {
    display: block;
  }
}
main.main .main-kv__bottom {
  position: absolute;
  bottom: clamp(3.6rem, 2.5vw, 4.8rem);
  right: 0;
  width: 100%;
}
@media (max-width: 680px) {
  main.main .main-kv__bottom {
    bottom: 3.2rem;
  }
}
main.main .main-kv__scroll-down {
  display: flex;
  margin-left: auto;
  animation: scroll-arrow-bounce 1.2s ease-in-out infinite;
}
@media (max-width: 1024px) {
  main.main .main-kv__scroll-down {
    width: 3.6rem;
  }
}
@keyframes scroll-arrow-bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(15px);
  }
}
main.main .exhibition {
  position: relative;
  background-color: #ffffff;
  overflow: hidden;
  z-index: 2;
}
main.main .exhibition__title {
  position: relative;
  margin-bottom: -6.4rem;
  line-height: 1;
  z-index: 1;
}
@media (max-width: 1024px) {
  main.main .exhibition__title {
    margin-bottom: var(--spacing-17, 10rem);
  }
}
main.main .exhibition__row {
  align-items: center;
}
@media (max-width: 1024px) {
  main.main .exhibition__row {
    row-gap: var(--spacing-13, 5.6rem);
  }
}
main.main .exhibition__row .image-wrapper {
  aspect-ratio: 1338/836;
}
@media (max-width: 1024px) {
  main.main .exhibition__info {
    order: 2;
  }
}
@media (min-width: 681px) and (max-width: 1024px) {
  main.main .exhibition .exhibition-3-swiper {
    overflow: visible;
  }
}
@media (min-width: 1025px) {
  main.main .exhibition .swiper-wrapper {
    transform: none !important;
  }
}
@media (min-width: 681px) and (max-width: 1024px) {
  main.main .exhibition .swiper-wrapper {
    flex-wrap: nowrap;
  }
}
@media (max-width: 680px) {
  main.main .exhibition .swiper-wrapper {
    transform: none !important;
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
  }
}
@media (min-width: 1025px) {
  main.main .exhibition .swiper-slide {
    width: auto;
  }
  main.main .exhibition .swiper-slide:first-child:nth-last-child(2), main.main .exhibition .swiper-slide:first-child:nth-last-child(2) ~ .swiper-slide {
    flex: 0 0 calc(50% - min(4.8rem, 2.5vw) / 2);
  }
  main.main .exhibition .swiper-slide:first-child:nth-last-child(3), main.main .exhibition .swiper-slide:first-child:nth-last-child(3) ~ .swiper-slide {
    flex: 0 0 calc(33.3333333333% - min(4.8rem, 2.5vw) * 2 / 3);
  }
}
@media (min-width: 681px) and (max-width: 1024px) {
  main.main .exhibition .swiper-slide {
    flex-shrink: 0;
    width: calc((100% + 1.6rem) / 8 * 4 - 1.6rem);
  }
}
@media (max-width: 680px) {
  main.main .exhibition .swiper-slide {
    width: 100%;
  }
}
main.main .exhibition .image-wrapper {
  aspect-ratio: 568/355;
  overflow: hidden;
}
main.main .exhibition .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  background-color: #f5f5f5;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .exhibition .image-wrapper:hover img {
    transform: scale(1.05);
  }
}
main.main .whats-on {
  position: relative;
}
main.main .whats-on__background-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}
main.main .whats-on__background {
  position: sticky;
  top: 0;
  width: 100%;
  height: 100vh;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: opacity 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
}
main.main .whats-on__background.bg1 {
  z-index: 0;
}
main.main .whats-on__background.bg2 {
  z-index: 1;
  margin-top: -100vh;
}
main.main .whats-on__background-gradient {
  position: sticky;
  top: 0;
  width: 100%;
  height: 100vh;
  margin-top: -100vh;
  background: -webkit-linear-gradient(top, #FFF 40%, rgba(255, 255, 255, 0.5) 100%);
  background: linear-gradient(180deg, #FFF 40%, rgba(255, 255, 255, 0.5) 100%);
  pointer-events: none;
  z-index: 2;
  -webkit-backdrop-filter: blur(80px);
  backdrop-filter: blur(80px);
}
main.main .whats-on > .container {
  position: relative;
  z-index: 1;
}
@media (max-width: 1024px) {
  main.main .whats-on__row {
    row-gap: var(--spacing-17, 10rem);
  }
}
main.main .whats-on__sticky {
  position: sticky;
  top: calc(5rem + clamp(9.1rem, 6.6666666667vw, 12.8rem));
  align-self: start;
  height: calc(100vh - (5rem + clamp(9.1rem, 6.6666666667vw, 12.8rem)));
}
@media (max-width: 1024px) {
  main.main .whats-on__sticky {
    position: relative;
    top: 0;
    height: auto;
  }
}
main.main .whats-on .whats-on-card {
  display: block;
}
main.main .whats-on .whats-on-card + .whats-on-card {
  margin-top: var(--spacing-17, 10rem);
}
main.main .whats-on .whats-on-card__info {
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
}
main.main .whats-on .whats-on-card .image-wrapper {
  overflow: hidden;
}
main.main .whats-on .whats-on-card .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 1030/644;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  background-color: #f5f5f5;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .whats-on .whats-on-card .image-wrapper:hover img {
    transform: scale(1.05);
  }
}
main.main .shop {
  position: relative;
  z-index: 1;
  width: 100%;
  padding-top: var(--spacing-21, 16rem);
  padding-bottom: var(--spacing-17, 10rem);
  background-color: #000000;
  overflow: hidden;
}
@media (max-width: 1024px) {
  main.main .shop {
    display: flex;
    flex-direction: column;
    padding-bottom: var(--spacing-21, 16rem);
  }
}
main.main .shop.shop--pre-open .shop__navigation {
  display: none;
}
main.main .shop.shop--pre-open .shop-slider__tag {
  display: none;
}
@media (min-width: 1025px) {
  main.main .shop.shop--pre-open .shop-slider__swiper {
    padding-right: max(6rem, 3.125vw);
  }
}
main.main .shop__background {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 56.7708333333%;
  height: 100%;
  overflow: hidden;
}
@media (max-width: 1024px) {
  main.main .shop__background {
    width: 100%;
  }
}
main.main .shop__background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  main.main .shop__background img {
    height: 96rem;
  }
}
@media (max-width: 680px) {
  main.main .shop__background img {
    height: 46rem;
  }
}
main.main .shop__background-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.6) 60%, #000000 100%);
}
@media (max-width: 1024px) {
  main.main .shop__background-overlay {
    height: 96rem;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 60%, #000000 100%);
  }
}
@media (max-width: 680px) {
  main.main .shop__background-overlay {
    height: 46rem;
  }
}
main.main .shop__container {
  position: relative;
  z-index: 1;
}
main.main .shop__container-content {
  height: 54rem;
}
@media (max-width: 1024px) {
  main.main .shop__container-content {
    height: auto;
    order: 3;
  }
}
main.main .shop__row {
  align-items: flex-end;
}
@media (max-width: 1024px) {
  main.main .shop__row {
    row-gap: 0;
    padding-bottom: var(--spacing-20, 14rem);
    margin-bottom: var(--spacing-20, 14rem);
  }
}
main.main .shop__title {
  color: #ffffff;
}
main.main .shop__content {
  display: flex;
  align-items: flex-end;
  height: 54rem;
}
@media (max-width: 1024px) {
  main.main .shop__content {
    height: auto;
    padding-top: var(--spacing-13, 5.6rem);
    padding-bottom: var(--spacing-13, 5.6rem);
  }
}
main.main .shop__content-intro {
  position: relative;
  color: #ffffff;
  z-index: 2;
}
@media (max-width: 1024px) {
  main.main .shop__content-intro {
    width: 100%;
  }
}
main.main .shop__navigation {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: var(--spacing-6, 2rem);
  margin-top: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  main.main .shop__navigation {
    display: none;
  }
}
main.main .shop__nav-button {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}
main.main .shop__nav-button svg {
  width: 1.4rem;
  height: 2.8rem;
}
main.main .shop__nav-pagination {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
  color: #ffffff;
}
main.main .shop__nav-current {
  opacity: 1;
}
main.main .shop__nav-divider {
  opacity: 1;
}
main.main .shop__nav-total {
  opacity: 0.5;
}
main.main .shop__nav-current, main.main .shop__nav-total {
  font-variant-numeric: tabular-nums;
  display: inline-block;
  min-width: 2ch;
  text-align: right;
}
main.main .shop .shop-slider {
  position: absolute;
  bottom: var(--spacing-17, 10rem);
  left: 50%;
  width: 50vw;
  padding-bottom: calc(2.8rem + var(--spacing-9));
}
@media (max-width: 1024px) {
  main.main .shop .shop-slider {
    position: relative;
    bottom: 0;
    left: unset;
    width: 100%;
    padding: 0 max(4rem, 3.9062vw);
  }
}
@media (max-width: 680px) {
  main.main .shop .shop-slider {
    padding: 0 max(1.6rem, 4.1025vw);
  }
}
main.main .shop .shop-slider__swiper {
  position: relative;
  width: 100%;
  overflow: hidden;
}
@media (max-width: 1024px) {
  main.main .shop .shop-slider__swiper {
    overflow: visible;
  }
}
main.main .shop .shop-slider__wrapper {
  display: flex;
}
main.main .shop .shop-slider__slide {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 54rem;
  height: 54rem;
  flex-shrink: 0;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .shop .shop-slider__slide:hover .shop-slider__tag {
    transform: translateY(0);
  }
}
@media (max-width: 1024px) {
  main.main .shop .shop-slider__slide {
    width: 34.4rem;
    height: 34.4rem;
  }
}
main.main .shop .shop-slider .image-wrapper {
  flex: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
main.main .shop .shop-slider .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-color: #f5f5f5;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .shop .shop-slider .image-wrapper:hover img {
    transform: scale(1.02);
  }
}
main.main .shop .shop-slider__tag {
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translateY(100%);
  display: inline-block;
  width: 100%;
  text-align: center;
  background-color: #ffffff;
  transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  main.main .shop .shop-slider__tag {
    transform: translateY(0);
  }
}
main.main .shop .swiper-pagination {
  position: static;
  margin-top: 2rem;
}
main.main .about__row {
  row-gap: 0;
}
main.main .about__image-group {
  gap: 4.8rem;
  display: flex;
  align-items: flex-end;
  margin-top: calc(-1 * 17rem);
}
@media (max-width: 1024px) {
  main.main .about__image-group {
    gap: var(--spacing-5, 1.6rem);
    margin-top: var(--spacing-18, 12rem);
  }
}
main.main .about__image-item--1 img {
  aspect-ratio: 123/158;
}
main.main .about__image-item--2 img {
  aspect-ratio: 568/730;
}
main.main .about__image-item--3 img {
  aspect-ratio: 200/257;
}
main.main .our-space {
  overflow: hidden;
}
@media (max-width: 1024px) {
  main.main .our-space__swiper {
    overflow: visible;
  }
}
@media (min-width: 1025px) {
  main.main .our-space__wrapper {
    transform: none !important;
  }
}
@media (max-width: 1024px) {
  main.main .our-space__wrapper {
    flex-wrap: nowrap;
  }
}
@media (min-width: 1025px) {
  main.main .our-space__slide {
    width: auto;
    flex: 0 0 calc(33.3333333333% - min(4.8rem, 2.5vw) * 2 / 3);
  }
}
@media (max-width: 1024px) {
  main.main .our-space__slide {
    width: calc((100% + 1.6rem) / 8 * 3 - 1.6rem);
    flex-shrink: 0;
  }
}
@media (max-width: 680px) {
  main.main .our-space__slide {
    width: calc((100% + 1.6rem) / 4 * 3 - 1.6rem);
  }
}
main.main .our-space .image-wrapper {
  aspect-ratio: 344/215;
}
main.main .our-space .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 680px) {
  main.main .info-section__row {
    row-gap: var(--spacing-16, 8rem);
  }
}
main.main .meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
main.main .meta__dot {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background-color: #000000;
}
main.main .meta__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 1.2rem;
  background-color: #000000;
  color: #ffffff;
}
main.main .cta-button {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1.2rem;
  width: fit-content;
  transition: gap 0.3s ease-in-out;
}
main.main .cta-button__indicator {
  width: 1.2rem;
  height: 3rem;
  background-color: #000000;
  flex-shrink: 0;
}
main.main .cta-button__label {
  position: absolute;
  top: 50%;
  left: 6.8rem;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 0.8rem;
  color: #ffffff;
  font-family: var(--font-en);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: -0.04em;
  transition: transform 0.3s ease-in-out;
}
main.main .cta-button__label-back {
  display: flex;
  align-items: center;
  width: 24rem;
  height: 3rem;
  padding: 0 2rem;
  background-color: #000000;
  color: #ffffff;
  transition: width 0.3s ease-in-out;
}
@media (max-width: 1024px) {
  main.main .cta-button__label-back {
    width: 18rem;
    font-size: 1.6rem;
  }
}
main.main .cta-button__icon {
  transform: translateX(-0.8rem);
  opacity: 0;
  transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  main.main .cta-button:hover {
    gap: 0;
    transition-delay: 0.1s;
  }
  main.main .cta-button:hover .cta-button__label-back {
    width: calc(24rem + 2.4rem);
    transition-delay: 0.1s;
  }
  main.main .cta-button:hover .cta-button__label {
    transform: translate(-48px, -50%);
    transition-delay: 0.15s;
  }
  main.main .cta-button:hover .cta-button__icon {
    transform: translateX(0);
    opacity: 1;
  }
}
main.main .cta-button--white .cta-button__indicator,
main.main .cta-button--white .cta-button__label-back {
  background-color: #ffffff;
}
main.main .cta-button--white .cta-button__label {
  color: #000000;
}

.component-exhibition-info__label {
  width: fit-content;
  background: #000000;
  padding: 0.3rem var(--spacing-4, 12);
  color: #ffffff;
}
.component-exhibition-info__title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.component-exhibition-info__date {
  line-height: 1.4;
  letter-spacing: -0.04em;
}

.page-exhibition-list .exhibition-filter__wrap {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.page-exhibition-list .exhibition-filter__swiper {
  width: 100%;
  overflow: hidden;
}
.page-exhibition-list .exhibition-filter__swiper .swiper-wrapper {
  display: flex;
}
.page-exhibition-list .exhibition-filter__swiper .swiper-slide {
  width: auto;
  margin-right: var(--spacing-7);
}
.page-exhibition-list .exhibition-filter__btn {
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-exhibition-list .exhibition-filter__btn.is-active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-exhibition-list .search-bar--exhibition {
    width: 100%;
  }
}
.page-exhibition-list .exhibition-list {
  display: block;
}
.page-exhibition-list .exhibition-list__dropdown {
  width: 26rem;
}
@media (max-width: 1024px) {
  .page-exhibition-list .exhibition-list__dropdown {
    width: 100%;
  }
}
.page-exhibition-list .exhibition-list__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  align-self: stretch;
  gap: var(--spacing-20, 14rem);
}
.page-exhibition-list .exhibition-list__content[data-status=closed] {
  gap: 0;
}
.page-exhibition-list .exhibition-list__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-20, 14rem);
  column-gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-list .exhibition-list__items {
    grid-template-columns: 1fr;
  }
}
.page-exhibition-list .exhibition-list__item {
  display: flex;
  flex-direction: column;
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
@media (max-width: 1024px) {
  .page-exhibition-list .exhibition-list__item {
    width: 100%;
  }
}
.page-exhibition-list .exhibition-list__thumbnail {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.page-exhibition-list .exhibition-list__thumbnail picture,
.page-exhibition-list .exhibition-list__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-exhibition-list .exhibition-list__thumbnail:hover img {
    transform: scale(1.05);
  }
}
@media (max-width: 1024px) {
  .page-exhibition-list .exhibition-list__thumbnail {
    height: auto;
    aspect-ratio: 179/112;
  }
}
.page-exhibition-list .exhibition-list__info-label {
  width: fit-content;
  background: #000000;
  padding: 0.3rem var(--spacing-4, 12);
  color: #ffffff;
}
.page-exhibition-list .exhibition-list__info-title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-exhibition-list .exhibition-list__info-date {
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-exhibition-list .exhibition-list__scheduled-item {
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.page-exhibition-list .exhibition-list__scheduled-thumbnail {
  width: 100%;
  height: 67.5rem;
  overflow: hidden;
}
.page-exhibition-list .exhibition-list__scheduled-thumbnail picture,
.page-exhibition-list .exhibition-list__scheduled-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  object-position: top;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-exhibition-list .exhibition-list__scheduled-thumbnail:hover img {
    transform: scale(1.05);
  }
}
@media (max-width: 1024px) {
  .page-exhibition-list .exhibition-list__scheduled-thumbnail {
    height: auto;
    aspect-ratio: 179/112;
  }
}
.page-exhibition-list .exhibition-list__closed-page-items {
  width: 100%;
}
.page-exhibition-list .exhibition-list__closed-items-row {
  width: 100%;
  column-gap: var(--spacing-12, 4.8rem);
  align-items: start;
}
@media (max-width: 1024px) {
  .page-exhibition-list .exhibition-list__closed-items-row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-16, 8rem);
  }
}
.page-exhibition-list .exhibition-list__closed-item {
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.page-exhibition-list .exhibition-list__closed-thumbnail {
  height: 100%;
  width: 100%;
  overflow: hidden;
}
.page-exhibition-list .exhibition-list__closed-thumbnail picture,
.page-exhibition-list .exhibition-list__closed-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-exhibition-list .exhibition-list__closed-thumbnail:hover img {
    transform: scale(1.05);
  }
}

.page-exhibition-detail .main__kv-image {
  aspect-ratio: 16/6;
  align-self: stretch;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .main__kv-image {
    height: auto;
    aspect-ratio: 358/430;
  }
}
.page-exhibition-detail .main__kv-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  object-position: bottom;
}
.page-exhibition-detail .main__title-wrapper {
  padding-left: max(6rem, 3.125vw);
  overflow: hidden;
  position: relative;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .main__title-wrapper {
    padding-left: max(4rem, 3.9062vw);
  }
}
@media (max-width: 680px) {
  .page-exhibition-detail .main__title-wrapper {
    padding-left: max(1.6rem, 4.1025vw);
  }
}
.page-exhibition-detail .main__title {
  display: inline-flex;
  white-space: nowrap;
  will-change: transform;
  animation: scrollText 30s linear infinite;
}
.page-exhibition-detail .main__title-text {
  padding-right: max(6rem, 3.125vw);
}
.page-exhibition-detail .main__title[data-lang=ko] {
  font-family: var(--font-ko);
  font-weight: 900;
  font-size: clamp(8.1rem, 5.9375vw, 11.4rem);
  letter-spacing: -0.03em;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .main__title[data-lang=ko] {
    font-size: max(5.7rem, 7.91vw);
  }
}
@keyframes scrollText {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.page-exhibition-detail .main__date {
  text-align: center;
  border-bottom: 1.5px solid #000000;
}
.page-exhibition-detail .body--1 {
  line-height: 1.75;
  letter-spacing: -0.04em;
}
.page-exhibition-detail .body--2 {
  line-height: 1;
  letter-spacing: -0.04em;
}
.page-exhibition-detail .body--bold {
  font-weight: 700;
}
.page-exhibition-detail .exhibition-detail-tabs__swiper {
  width: 100%;
  overflow: hidden;
}
.page-exhibition-detail .exhibition-detail-tabs__swiper .swiper-wrapper {
  display: flex;
  justify-content: center;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-tabs__swiper .swiper-wrapper {
    justify-content: flex-start;
  }
}
.page-exhibition-detail .exhibition-detail-tabs__swiper .swiper-slide {
  width: auto;
}
.page-exhibition-detail .exhibition-detail-tabs__swiper .swiper-slide:first-child {
  margin-left: var(--spacing-7, 2.4rem);
}
.page-exhibition-detail .exhibition-detail-tabs__swiper .swiper-slide {
  margin-right: var(--spacing-7, 2.4rem);
}
.page-exhibition-detail .exhibition-detail-tabs__buttons {
  display: flex;
}
.page-exhibition-detail .exhibition-detail-tabs__btn {
  color: #000000;
  border: 1px solid #000000;
  background-color: #ffffff;
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-exhibition-detail .exhibition-detail-tabs__btn.is-active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
.page-exhibition-detail .exhibition-detail-common__title-wrapper {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-6, 2rem);
}
.page-exhibition-detail .exhibition-detail-overview__header-row {
  align-items: center;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-overview__header-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-15, 7.2rem);
  }
}
.page-exhibition-detail .exhibition-detail-overview__header-image {
  aspect-ratio: 568/757;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-overview__header-image {
    width: 100%;
    aspect-ratio: 358/477;
  }
}
.page-exhibition-detail .exhibition-detail-overview__header-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.page-exhibition-detail .exhibition-detail-overview__info-item {
  display: flex;
  align-items: flex-start;
  align-self: stretch;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-overview__info-item {
    padding: var(--spacing-4) 0;
    gap: var(--spacing-8, 2.8rem);
  }
}
.page-exhibition-detail .exhibition-detail-overview__info-label {
  min-width: 10.6rem;
  font-weight: 800;
  line-height: 1.75;
  letter-spacing: -0.04em;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-overview__info-label {
    min-width: 8rem;
  }
}
.page-exhibition-detail .exhibition-detail-overview__info-value {
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: -0.04em;
}
.page-exhibition-detail .exhibition-detail-artist__row {
  align-items: center;
}
.page-exhibition-detail .exhibition-detail-artist__item {
  position: relative;
  border-bottom: 1.5px solid #000000;
  cursor: pointer;
  overflow: hidden;
}
.page-exhibition-detail .exhibition-detail-artist__background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 0;
  opacity: 0;
}
.page-exhibition-detail .exhibition-detail-artist__background picture,
.page-exhibition-detail .exhibition-detail-artist__background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.page-exhibition-detail .exhibition-detail-artist__item-header {
  position: relative;
  display: flex;
  justify-content: space-between;
  padding: var(--spacing-8) var(--spacing-6);
  color: #000000;
  z-index: 10;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-artist__item-header {
    flex-direction: column;
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-exhibition-detail .exhibition-detail-artist__item-title-group {
  display: flex;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-artist__item-title-group {
    justify-content: space-between;
  }
}
.page-exhibition-detail .exhibition-detail-artist__item-number {
  width: 29.5833333333vw;
  max-width: 56.8rem;
}
.page-exhibition-detail .exhibition-detail-artist__item-number--hidden {
  visibility: hidden;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-artist__item-number--hidden {
    display: none;
  }
}
.page-exhibition-detail .exhibition-detail-artist__item-name {
  text-align: right;
  position: relative;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-artist__item-name {
    text-align: right;
  }
}
.page-exhibition-detail .exhibition-detail-artist__item-description-wrapper {
  position: relative;
  display: flex;
  margin: 0 var(--spacing-6);
  overflow: hidden;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-artist__item-description-wrapper {
    margin-left: var(--spacing-6);
  }
}
.page-exhibition-detail .exhibition-detail-artist__item-description {
  padding-top: var(--spacing-12);
  padding-bottom: 3rem;
  flex: 1;
  color: #000000;
  z-index: 10;
}
.page-exhibition-detail .exhibition-detail-artworks {
  overflow: hidden;
}
.page-exhibition-detail .exhibition-detail-artworks__navigation {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-5, 1.6rem);
}
.page-exhibition-detail .exhibition-detail-artworks__navigation-prev {
  width: 3.4rem;
  height: 2.6rem;
  color: #dddddd;
  cursor: pointer;
}
.page-exhibition-detail .exhibition-detail-artworks__navigation-prev.is-active {
  color: #000000;
}
.page-exhibition-detail .exhibition-detail-artworks__navigation-next {
  width: 3.4rem;
  height: 2.6rem;
  color: #dddddd;
  cursor: pointer;
}
.page-exhibition-detail .exhibition-detail-artworks__navigation-next.is-active {
  color: #000000;
}
.page-exhibition-detail .exhibition-detail-artworks__navigation svg {
  width: 100%;
  height: 100%;
}
.page-exhibition-detail .exhibition-detail-artworks__swiper {
  overflow: visible;
}
.page-exhibition-detail .exhibition-detail-artworks__swiper-wrapper {
  display: flex;
}
.page-exhibition-detail .exhibition-detail-artworks__slide {
  width: 41.4rem;
  margin-right: var(--spacing-12, 4.8rem);
  display: flex;
  flex-direction: column;
}
.page-exhibition-detail .exhibition-detail-artworks__slide:last-child {
  margin-right: 0;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-artworks__slide {
    width: 31.4rem;
    margin-right: var(--spacing-5, 1.2rem);
  }
}
.page-exhibition-detail .exhibition-detail-artworks__image-wrapper {
  width: 100%;
}
.page-exhibition-detail .exhibition-detail-artworks__image-wrapper img {
  display: block;
  width: 100%;
  height: auto;
  pointer-events: none;
}
.page-exhibition-detail .exhibition-detail-artworks__caption {
  color: #787878;
  letter-spacing: -0.04em;
  line-height: 1.4;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-programs__row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-16, 8rem);
  }
}
.page-exhibition-detail .exhibition-detail-programs__item {
  cursor: pointer;
}
.page-exhibition-detail .exhibition-detail-programs__image {
  aspect-ratio: 722/429;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-programs__image {
    height: auto;
    aspect-ratio: 179/106;
  }
}
.page-exhibition-detail .exhibition-detail-programs__image picture, .page-exhibition-detail .exhibition-detail-programs__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-press {
    padding-bottom: 16rem;
  }
}
.page-exhibition-detail .exhibition-detail-press__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-8, 2.8rem);
}
.page-exhibition-detail .exhibition-detail-sponsor__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-sponsor__items {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
}
.page-exhibition-detail .exhibition-detail-sponsor__logo {
  aspect-ratio: 722/240;
}
.page-exhibition-detail .exhibition-detail-sponsor__logo picture,
.page-exhibition-detail .exhibition-detail-sponsor__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.page-exhibition-detail .exhibition-detail-partnership__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-exhibition-detail .exhibition-detail-partnership__items {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
}
.page-exhibition-detail .exhibition-detail-partnership__logo {
  aspect-ratio: 722/240;
}
.page-exhibition-detail .exhibition-detail-partnership__logo picture,
.page-exhibition-detail .exhibition-detail-partnership__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.page-exhibition-detail .editor-area h4 {
  font-family: var(--font-ko);
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.79);
}
@media (max-width: 680px) {
  .page-exhibition-detail .editor-area h4 {
    font-size: calc(max(2.8rem, 2.93vw) * 0.79);
  }
}
.page-exhibition-detail .editor-area h5 {
  font-family: var(--font-ko);
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.58);
}
@media (max-width: 680px) {
  .page-exhibition-detail .editor-area h5 {
    font-size: calc(max(2.8rem, 2.93vw) * 0.58);
  }
}
.page-exhibition-detail .editor-area p {
  font-family: var(--font-ko);
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: -0.04em;
  font-size: calc(clamp(1.34rem, 0.8333vw, 1.6rem) * 1.25);
}
@media (max-width: 680px) {
  .page-exhibition-detail .editor-area p {
    font-size: calc(max(1.34rem, 1.3671vw) * 1.25);
  }
}
.page-exhibition-detail .editor-area ul {
  list-style-type: disc;
  padding-left: 2em;
}
.page-exhibition-detail .editor-area ul li {
  font-family: var(--font-ko);
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: -0.04em;
  font-size: calc(clamp(1.34rem, 0.8333vw, 1.6rem) * 1.125);
}
@media (max-width: 680px) {
  .page-exhibition-detail .editor-area ul li {
    font-size: calc(max(1.34rem, 1.3671vw) * 1.125);
  }
}
.page-exhibition-detail .editor-area b,
.page-exhibition-detail .editor-area strong {
  font-weight: 650;
}
.page-exhibition-detail .editor-area h4 {
  margin-bottom: var(--spacing-9, 3.2rem);
}
.page-exhibition-detail .editor-area h5 {
  margin-bottom: var(--spacing-6, 2rem);
}
.page-exhibition-detail .editor-area ul + ul {
  margin-top: var(--spacing-6, 2rem);
}
.page-exhibition-detail .editor-area ul + h5 {
  margin-top: var(--spacing-9, 3.2rem);
}

.audio-guide-main__header {
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.audio-guide-main__header-content {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid #000000;
  gap: var(--spacing-14, 6.4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.audio-guide-main__header-tab {
  display: flex;
  align-items: center;
}
.audio-guide-main__swiper {
  width: 100%;
  overflow: hidden;
}
.audio-guide-main__swiper .swiper-wrapper {
  display: flex;
  flex-wrap: wrap;
}
.audio-guide-main__swiper .swiper-slide {
  width: auto;
}
.audio-guide-main__tab-buttons {
  display: flex;
  gap: var(--spacing-7, 2.4rem);
}
.audio-guide-main__tab-button {
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.audio-guide-main__tab-button.is-active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
.audio-guide-main__content {
  display: none;
}
.audio-guide-main__content.is-active {
  display: block;
}
.audio-guide-main__search {
  padding-bottom: var(--spacing-11, 4rem);
}
.audio-guide-main__search-wrap {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .audio-guide-main__search-wrap {
    flex-direction: column;
    align-items: stretch;
  }
}
.audio-guide-main__dropdown {
  width: 26rem;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .audio-guide-main__dropdown {
    width: 100%;
  }
}
@media (max-width: 1024px) {
  .audio-guide-main__search-input {
    width: 100%;
  }
}
.audio-guide-main__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-17, 10rem);
  padding-top: var(--spacing-12, 4.8rem);
  padding-bottom: var(--spacing-12, 4.8rem);
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid #c6c6c6;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.audio-guide-main__item:first-child {
  padding-top: 0;
}
@media (hover: hover) and (pointer: fine) {
  .audio-guide-main__item:hover .audio-guide-main__arrow {
    width: 6.8rem;
    opacity: 1;
    margin-left: 0;
  }
}
@media (max-width: 1024px) {
  .audio-guide-main__item {
    flex-direction: column;
    align-items: flex-start;
    transition: none;
    gap: var(--spacing-13, 5.6rem);
  }
}
.audio-guide-main__thumbnail {
  width: 49.4rem;
  height: 30.9rem;
  flex-shrink: 0;
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1), height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (max-width: 1024px) {
  .audio-guide-main__thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 358/224;
    transition: none;
  }
}
.audio-guide-main__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.audio-guide-main__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-2, 0.8rem);
}
.audio-guide-main__arrow {
  flex-shrink: 0;
  width: 0;
  height: 5.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  overflow: hidden;
  margin-left: calc(var(--spacing-17) * -1);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.audio-guide-main__arrow svg {
  width: 6.8rem;
  height: 5.2rem;
  flex-shrink: 0;
  color: #000000;
}
@media (max-width: 1024px) {
  .audio-guide-main__arrow {
    display: none;
  }
}
.audio-guide-main__pagination {
  padding-top: var(--spacing-18, 12rem);
}
@media (max-width: 1024px) {
  .audio-guide-main__pagination {
    padding-top: var(--spacing-11, 4rem);
  }
}

.audio-guide-detail__header {
  padding-top: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .audio-guide-detail__header {
    padding-top: var(--spacing-17, 10rem);
  }
}
.audio-guide-detail__header-content {
  border-bottom: 1px solid #000000;
}
.audio-guide-detail__content {
  padding-top: var(--spacing-18, 12rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .audio-guide-detail__content {
    padding-top: var(--spacing-9, 3.2rem);
    padding-bottom: var(--spacing-16, 8rem);
  }
}
.audio-guide-detail__sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .audio-guide-detail__sidebar {
    gap: 0;
  }
}
.audio-guide-detail__list {
  border: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .audio-guide-detail__list {
    border: none;
  }
}
.audio-guide-detail__list-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
  padding: var(--spacing-5, 1.6rem);
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) {
  .audio-guide-detail__list-item:hover {
    background-color: #f5f5f5;
  }
}
@media (max-width: 1024px) {
  .audio-guide-detail__list-item {
    padding-left: 0;
    padding-right: 0;
  }
}
.audio-guide-detail__thumbnail {
  flex: 1;
  flex-shrink: 0;
}
.audio-guide-detail__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.audio-guide-detail__info {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.audio-guide-detail__detail {
  max-height: 94.2rem;
  border: 1px solid #dddddd;
  display: flex;
  padding-right: 1.6rem;
}
@media (max-width: 1024px) {
  .audio-guide-detail__detail {
    display: none;
  }
}
.audio-guide-detail__detail-inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  max-height: 100%;
  padding-right: calc(var(--spacing-9) - 2rem);
}
.audio-guide-detail__detail-inner::-webkit-scrollbar {
  width: 0.4rem;
}
.audio-guide-detail__detail-inner::-webkit-scrollbar-track {
  background: #f2f2f2;
  margin: 1.7rem 0;
}
.audio-guide-detail__detail-inner::-webkit-scrollbar-thumb {
  background: #000000;
}
.audio-guide-detail__image-caption-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-13, 5.6rem);
}
.audio-guide-detail__image-wrap {
  display: flex;
  justify-content: center;
}
.audio-guide-detail__image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.audio-guide-detail__player {
  background-color: #000000;
}
.audio-guide-detail__player-inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  padding: var(--spacing-9) var(--spacing-8) var(--spacing-11) var(--spacing-9);
}
.audio-guide-detail__play-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 5.4rem;
  height: 5.4rem;
  cursor: pointer;
}
.audio-guide-detail__play-btn svg {
  width: 100%;
  height: 100%;
  color: #ffffff;
}
.audio-guide-detail__icon-play, .audio-guide-detail__icon-pause {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.audio-guide-detail__icon-play--desktop, .audio-guide-detail__icon-pause--desktop {
  display: block;
}
@media (max-width: 1024px) {
  .audio-guide-detail__icon-play--desktop, .audio-guide-detail__icon-pause--desktop {
    display: none;
  }
}
.audio-guide-detail__icon-play--mobile, .audio-guide-detail__icon-pause--mobile {
  display: none;
}
@media (max-width: 1024px) {
  .audio-guide-detail__icon-play--mobile, .audio-guide-detail__icon-pause--mobile {
    display: flex;
  }
}
.audio-guide-detail__player-info {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.audio-guide-detail__section-title {
  color: #ffffff;
}
.audio-guide-detail__time-remaining {
  color: #ffffff;
}
.audio-guide-detail__progress {
  height: 0.4rem;
  background-color: rgba(217, 217, 217, 0.3);
  margin: 0 var(--spacing-9) var(--spacing-9);
}
.audio-guide-detail__progress-bar {
  height: 100%;
  background-color: #d9d9d9;
  transition: width 0.1s linear;
}
.audio-guide-detail__bottom-sheet {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  pointer-events: none;
  visibility: hidden;
}
@media (max-width: 1024px) {
  .audio-guide-detail__bottom-sheet {
    display: block;
  }
}
.audio-guide-detail__bottom-sheet.is-open {
  pointer-events: auto;
  visibility: visible;
}
.audio-guide-detail__bottom-sheet.is-open .audio-guide-detail__bottom-sheet-overlay {
  opacity: 1;
}
.audio-guide-detail__bottom-sheet.is-open .audio-guide-detail__bottom-sheet-container {
  transform: translateY(0);
}
.audio-guide-detail__bottom-sheet-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.4);
  opacity: 0;
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
.audio-guide-detail__bottom-sheet-container {
  display: flex;
  flex-direction: column;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  max-height: calc(100% - 7.4rem);
  background-color: #ffffff;
  border-radius: 1.6rem 1.6rem 0 0;
  transform: translateY(100%);
  transition: transform 0.73s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  will-change: transform;
}
.audio-guide-detail__bottom-sheet-header {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.6rem;
}
.audio-guide-detail__bottom-sheet-handle {
  width: 6.4rem;
  height: 0.6rem;
  background-color: #d9d9d9;
  border-radius: 0.8rem;
}
.audio-guide-detail__bottom-sheet-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  position: relative;
}
.audio-guide-detail__bottom-sheet-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  width: 2.4rem;
  height: 1.6rem;
  transform: translateY(-50%);
  color: #000000;
}
.audio-guide-detail__bottom-sheet-nav-btn--prev {
  left: 0;
}
.audio-guide-detail__bottom-sheet-nav-btn--next {
  right: 0;
}
.audio-guide-detail__bottom-sheet-nav-btn svg {
  width: 0.8rem;
  height: 1.4rem;
}
.audio-guide-detail__bottom-sheet-nav-btn:disabled {
  opacity: 0.3;
}
.audio-guide-detail__bottom-sheet-section-title {
  flex: 1;
  text-align: center;
  padding: 0 var(--spacing-9);
}
.audio-guide-detail__bottom-sheet-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow-y: auto;
  border: 1px solid #dddddd;
  gap: var(--spacing-11, 4rem);
}
.audio-guide-detail__bottom-sheet-fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 16rem;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #ffffff 60%);
  pointer-events: none;
  z-index: 5;
}
.audio-guide-detail__bottom-sheet-image-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  padding: 0 var(--spacing-16);
}
.audio-guide-detail__bottom-sheet-image-wrap img {
  width: 100%;
  height: auto;
  object-fit: cover;
}
.audio-guide-detail__bottom-sheet-description {
  margin-bottom: 12rem;
}
.audio-guide-detail__bottom-sheet-player {
  position: absolute;
  bottom: var(--spacing-6);
  left: var(--spacing-6);
  right: var(--spacing-6);
  background-color: #000000;
  border-radius: 0;
  z-index: 10;
}
.audio-guide-detail__bottom-sheet-player-inner {
  display: flex;
  align-items: center;
  padding: var(--spacing-6) var(--spacing-8);
  gap: var(--spacing-5, 1.6rem);
}
.audio-guide-detail__bottom-sheet-play-btn {
  width: 2.2rem;
  height: 2.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.audio-guide-detail__bottom-sheet-play-btn svg {
  width: 100%;
  height: 100%;
  color: #ffffff;
}
.audio-guide-detail__bottom-sheet-player-title {
  flex: 1;
  color: #ffffff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.audio-guide-detail__bottom-sheet-player-time {
  flex-shrink: 0;
  color: #ffffff;
}
.audio-guide-detail__bottom-sheet-progress {
  height: 0.4rem;
  background-color: rgba(217, 217, 217, 0.3);
  margin: 0 var(--spacing-8) var(--spacing-6);
}
.audio-guide-detail__bottom-sheet-progress-bar {
  height: 100%;
  background-color: #d9d9d9;
  transition: width 0.1s linear;
}

.page-shop-list {
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-shop-list {
    overflow: hidden;
  }
}
@media (min-width: 1025px) {
  .page-shop-list__sidebar {
    position: sticky;
    top: calc(clamp(9.1rem, 6.6666666667vw, 12.8rem) + var(--spacing-8));
    min-width: 32.4rem;
    align-self: flex-start;
  }
}
@media (max-width: 1024px) {
  .page-shop-list__sidebar {
    display: flex;
    flex-direction: column;
  }
}
@media (max-width: 1024px) {
  .page-shop-list .mobile-column {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
}
.page-shop-list .shop-main-section + .shop-main-section {
  margin-top: var(--spacing-24, 20rem);
}
.page-shop-list .shop-main-title {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.page-shop-list .shop-main-top-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.page-shop-list .shop-main-top-slider .image-wrapper {
  position: relative;
  width: 100%;
  height: 50.2rem;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-top-slider .image-wrapper {
    height: 43rem;
  }
}
.page-shop-list .shop-main-top-slider .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-shop-list .shop-main-top-slider .image-wrapper::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.2) 0%, transparent 100%);
  pointer-events: none;
}
.page-shop-list .shop-main-top-slider__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding-left: var(--spacing-12, 4.8rem);
  padding-right: var(--spacing-12, 4.8rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  color: #ffffff;
  z-index: 2;
}
.page-shop-list .shop-main-top-slider__cta {
  margin-bottom: 0.8rem;
}
.page-shop-list .shop-main-top-slider__progress {
  position: absolute;
  bottom: var(--spacing-9, 3.2rem);
  left: var(--spacing-12, 4.8rem);
  display: flex;
  gap: var(--spacing-2, 0.8rem);
  z-index: 10;
}
.page-shop-list .shop-main-top-slider__progress-item {
  position: relative;
  width: 2.4rem;
  height: 0.2rem;
  background-color: rgba(255, 255, 255, 0.2);
  cursor: pointer;
  overflow: hidden;
  transition: width 0.3s ease;
}
.page-shop-list .shop-main-top-slider__progress-item.is-active {
  width: 4.8rem;
}
.page-shop-list .shop-main-top-slider__progress-item.is-animating .shop-main-top-slider__progress-bar {
  transform: scaleX(1);
  transition: transform var(--autoplay-delay, 5000ms) linear;
}
.page-shop-list .shop-main-top-slider__progress-bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  transform: scaleX(0);
  transform-origin: left center;
}
.page-shop-list .shop-main-top-slider--single .top-slider__pagination {
  display: none;
}
.page-shop-list .shop-head {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
  margin-bottom: var(--spacing-8, 2.8rem);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-head {
    order: 2;
    margin-bottom: 0;
    margin-top: var(--spacing-16, 8rem);
  }
}
.page-shop-list .shop-head__cart {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6rem;
  height: 6rem;
  flex-shrink: 0;
}
.page-shop-list .shop-head__cart svg {
  width: 3.2rem;
  height: 3.2rem;
}
.page-shop-list .shop-head__cart-count {
  position: absolute;
  right: 0.9rem;
  bottom: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  background-color: #ff3b30;
  border-radius: 50%;
  font-size: 1.2rem;
  font-weight: 780;
  color: #ffffff;
  line-height: 1;
  letter-spacing: -0.04em;
}
.page-shop-list .shop-main.is-hidden,
.page-shop-list .shop-list.is-hidden {
  display: none;
}
.page-shop-list .shop-main-new__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 680px) {
  .page-shop-list .shop-main-new__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
.page-shop-list .shop-main-exhibition__content {
  position: relative;
  width: 100%;
  overflow: hidden;
  min-height: 44.5rem;
}
.page-shop-list .shop-main-exhibition .image-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 44.5rem;
}
.page-shop-list .shop-main-exhibition .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 44.5rem;
}
.page-shop-list .shop-main-exhibition__text {
  position: absolute;
  left: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: var(--spacing-11, 4rem);
  padding-left: var(--spacing-12, 4.8rem);
  padding-bottom: var(--spacing-12, 4.8rem);
  padding-right: 37rem;
  z-index: 2;
}
@media (max-width: 1360px) {
  .page-shop-list .shop-main-exhibition__text {
    padding-right: 27rem;
  }
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-exhibition__text {
    padding-right: var(--spacing-12, 4.8rem);
  }
}
.page-shop-list .shop-main-exhibition__info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
  color: #ffffff;
}
.page-shop-list .shop-main-exhibition__btn {
  width: 20rem;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-exhibition__btn {
    width: 16rem;
  }
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-exhibition__desc {
    display: none;
  }
}
.page-shop-list .shop-main-exhibition__slider-pc {
  position: absolute;
  top: 0;
  right: 0;
  padding-right: var(--spacing-14, 6.4rem);
  width: min(35rem, 18.2291666667vw);
  height: 100%;
  z-index: 3;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-exhibition__slider-pc {
    display: none;
  }
}
.page-shop-list .shop-main-exhibition__slider-pc .swiper {
  width: 100%;
  height: 100%;
  padding-top: var(--spacing-14, 6.4rem);
  padding-bottom: var(--spacing-14, 6.4rem);
}
.page-shop-list .shop-main-exhibition__slider-pc .swiper-wrapper {
  flex-direction: column;
}
.page-shop-list .shop-main-exhibition__slider-pc .swiper-slide {
  height: auto !important;
  padding-bottom: var(--spacing-13, 5.6rem);
}
.page-shop-list .shop-main-exhibition__slider-pc .swiper-slide:last-child {
  padding-bottom: 0;
}
.page-shop-list .shop-main-exhibition__slider-pc .swiper-scrollbar {
  position: absolute;
  right: 2rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.4rem;
  height: 22.4rem;
  background-color: rgba(242, 242, 242, 0.2);
  border-radius: 0;
}
.page-shop-list .shop-main-exhibition__slider-pc .swiper-scrollbar .swiper-scrollbar-drag {
  width: 100%;
  background-color: #ffffff;
  border-radius: 0;
}
.page-shop-list .shop-main-exhibition__slider-mo {
  display: none;
  margin-top: var(--spacing-8, 2.8rem);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-exhibition__slider-mo {
    display: block;
  }
}
.page-shop-list .shop-main-exhibition__slider-mo .swiper {
  overflow: visible;
}
.page-shop-list .shop-main-exhibition__slider-mo .swiper-slide {
  width: 15rem;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-exhibition__slider-mo .swiper-slide {
    width: 21.97265625vw;
  }
}
@media (max-width: 680px) {
  .page-shop-list .shop-main-exhibition__slider-mo .swiper-slide {
    width: 38.4615384615vw;
  }
}
.page-shop-list .shop-main-exhibition__slider-mo .shop-item__image {
  margin-bottom: var(--spacing-7, 2.4rem);
}
.page-shop-list .shop-main-exclusive__boxes {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 680px) {
  .page-shop-list .shop-main-exclusive__boxes {
    flex-direction: column;
  }
}
.page-shop-list .exclusive-hero {
  position: relative;
  flex-shrink: 0;
  flex: 1;
  aspect-ratio: 1/1;
}
@media (max-width: 1024px) {
  .page-shop-list .exclusive-hero {
    width: 100%;
    aspect-ratio: 661/661;
  }
}
.page-shop-list .exclusive-hero a {
  display: block;
  width: 100%;
  height: 100%;
}
.page-shop-list .exclusive-hero__image {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.page-shop-list .exclusive-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-list .exclusive-hero:hover .page-shop-list .exclusive-hero__image img {
  transform: scale(1.05);
}
.page-shop-list .exclusive-hero__banner {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #643204;
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-8, 2.8rem);
  padding-left: var(--spacing-11, 4rem);
  padding-right: var(--spacing-11, 4rem);
}
.page-shop-list .exclusive-hero__banner p {
  color: #ffffff;
}
.page-shop-list .exclusive-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-5, 1.6rem);
  flex: 1;
}
.page-shop-list .exclusive-grid__item {
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
}
.page-shop-list .exclusive-grid__item a {
  display: block;
  width: 100%;
  height: 100%;
}
.page-shop-list .exclusive-grid__image {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background-color: #f5f5f5;
}
.page-shop-list .exclusive-grid__image img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: auto;
  max-height: 110%;
  object-fit: contain;
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-list .exclusive-grid__item:hover .page-shop-list .exclusive-grid__image img {
  transform: translate(-50%, -50%) scale(1.05);
}
.page-shop-list .exclusive-grid__info {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #ffffff;
  padding: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.35s cubic-bezier(0.215, 0.61, 0.355, 1);
  z-index: 1;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-shop-list .exclusive-grid__item:hover:hover .exclusive-grid__info {
    transform: translateY(0);
  }
}
.page-shop-list .exclusive-grid__brand {
  color: #000000;
}
.page-shop-list .exclusive-grid__name {
  color: #000000;
}
.page-shop-list .shop-main-explore__content {
  position: relative;
  display: flex;
  gap: var(--spacing-5, 1.6rem);
  min-height: 44.5rem;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-explore__content {
    flex-direction: column;
  }
}
.page-shop-list .shop-main-explore .image-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 44.5rem;
}
.page-shop-list .shop-main-explore .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 44.5rem;
}
.page-shop-list .shop-main-explore .image-dim {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.15);
}
.page-shop-list .shop-main-explore__box {
  position: absolute;
  left: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--spacing-9, 3.2rem);
  min-width: 48rem;
  padding: var(--spacing-12, 4.8rem);
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-explore__box {
    min-width: auto;
  }
}
.page-shop-list .shop-main-explore__text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-shop-list .shop-main-explore__desc {
  line-height: 1.4;
}
.page-shop-list .shop-main-banner {
  display: flex;
  align-items: stretch;
  background-color: #000000;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-banner {
    flex-direction: column;
    align-items: flex-start;
  }
}
.page-shop-list .shop-main-banner__text {
  display: flex;
  flex-direction: column;
  min-width: 60%;
  height: 100%;
  padding: var(--spacing-12, 4.8rem);
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-banner__text {
    width: 100%;
  }
}
.page-shop-list .shop-main-banner__cta {
  display: flex;
  flex-wrap: wrap;
  margin-top: var(--spacing-11, 4rem);
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-banner__cta .button {
    flex: 1;
    min-width: auto;
  }
}
.page-shop-list .shop-main-banner .image-wrapper {
  flex: 1;
  display: flex;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-main-banner .image-wrapper {
    flex: auto;
    width: 100%;
    height: max(20rem, 29.4117647059vw);
  }
}
.page-shop-list .shop-main-banner .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-shop-list .shop-list {
  padding-top: var(--spacing-16, 8rem);
}
.page-shop-list .shop-list__header {
  display: flex;
  flex-direction: column;
  padding-left: var(--spacing-7, 2.4rem);
  margin-bottom: var(--spacing-3, 1rem);
  gap: var(--spacing-17, 10rem);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-list__header {
    padding-left: 0;
    margin-bottom: var(--spacing-3, 1rem);
  }
}
.page-shop-list .shop-list__header .headline {
  height: clamp(5.7rem, 4.1666vw, 9rem);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-list__header .headline {
    height: max(4.8rem, 5.5664vw);
  }
}
.page-shop-list .shop-list__header .headline[data-lang=en] {
  font-family: var(--font-en);
}
.page-shop-list .shop-list__header .headline[data-lang=ko] {
  font-family: var(--font-ko);
  font-size: calc(clamp(5.7rem, 4.1666vw, 8rem) * 0.7);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-list__header .headline[data-lang=ko] {
    font-size: calc(max(4rem, 5.5664vw) * 0.7);
  }
}
.page-shop-list .shop-list__filter {
  position: relative;
}
.page-shop-list .shop-list__filter .dropdown__trigger {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  background: none;
  border: none;
  cursor: pointer;
}
.page-shop-list .shop-list__filter .dropdown__icon {
  width: 2.8rem;
  height: 2.8rem;
}
@media (max-width: 1024px) {
  .page-shop-list .shop-list__filter .dropdown__icon {
    width: 2.4rem;
    height: 2.4rem;
  }
}
.page-shop-list .shop-list__filter .dropdown__menu {
  position: absolute;
  top: 100%;
  right: 0;
  width: 13.6rem;
  background-color: #ffffff;
  border: 1px solid #000000;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.8rem);
  transition: opacity 0.2s cubic-bezier(0.215, 0.61, 0.355, 1), transform 0.2s cubic-bezier(0.215, 0.61, 0.355, 1), visibility 0.2s;
  z-index: 1000;
}
.page-shop-list .shop-list__filter .dropdown__item {
  padding: 0.8rem;
}
.page-shop-list .shop-list__filter .dropdown__item.is-active .dropdown__option {
  font-weight: 700;
}
.page-shop-list .shop-list__filter .dropdown__option {
  display: block;
  width: 100%;
  padding: 0.6rem 0.8rem;
  border: none;
  text-align: left;
  cursor: pointer;
  transition: background-color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-shop-list .shop-list__filter .dropdown__option:hover {
    background-color: #f5f5f5;
  }
}
.page-shop-list .shop-list__filter.is-open .dropdown__icon {
  transform: rotate(180deg);
}
.page-shop-list .shop-list__filter.is-open .dropdown__menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.page-shop-list .shop-list__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-5, 1.6rem);
  row-gap: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-shop-list .shop-list__grid {
    grid-template-columns: repeat(2, 1fr);
    row-gap: var(--spacing-11, 4rem);
  }
}

.page-shop-detail {
  padding-top: calc(clamp(9.1rem, 6.6666666667vw, 12.8rem) + var(--spacing-16));
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-shop-detail {
    padding-top: calc(7.4rem + var(--spacing-16));
  }
}
@media (max-width: 1024px) {
  .page-shop-detail .shop-detail__left {
    order: 2;
  }
}
@media (max-width: 1024px) {
  .page-shop-detail .shop-detail__right {
    order: 1;
    position: relative;
    top: unset;
  }
}
.page-shop-detail .product-gallery {
  display: flex;
}
@media (max-width: 1024px) {
  .page-shop-detail .product-gallery {
    flex-direction: column-reverse;
    gap: 0;
  }
}
.page-shop-detail .product-gallery--pc {
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-shop-detail .product-gallery--pc {
    display: none;
  }
}
.page-shop-detail .product-gallery--pc .product-gallery__image {
  flex: 1;
}
.page-shop-detail .product-gallery--pc .product-gallery__image .image-wrapper {
  width: 100%;
  height: 69.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f5f5f5;
}
.page-shop-detail .product-gallery--pc .product-gallery__image .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (min-width: 1025px) {
  .page-shop-detail .product-gallery--mo {
    display: none;
  }
}
.page-shop-detail .product-gallery--mo .product-gallery__swiper {
  width: 100%;
  aspect-ratio: 1/1;
}
.page-shop-detail .product-gallery--mo .product-gallery__image {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background-color: #f5f5f5;
}
.page-shop-detail .product-gallery--mo .product-gallery__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.page-shop-detail .product-gallery--mo .product-gallery__pagination {
  position: absolute;
  right: 1.4rem;
  bottom: 1.4rem;
  display: flex;
  justify-content: center;
  gap: 0.3rem;
  padding: 0.3rem 0.6rem 0.2rem;
  background-color: rgba(0, 0, 0, 0.24);
  color: #ffffff;
  z-index: 2;
}
.page-shop-detail .product-gallery-thumbs {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 16rem;
  height: 69.6rem;
  flex-shrink: 0;
  overflow: hidden;
}
.page-shop-detail .product-gallery-thumbs__nav {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  color: #ffffff;
  background-color: #000000;
  transition: opacity 0.2s ease;
}
.page-shop-detail .product-gallery-thumbs__nav:disabled {
  opacity: 0.3;
}
.page-shop-detail .product-gallery-thumbs__nav--up {
  top: 1rem;
}
.page-shop-detail .product-gallery-thumbs__nav--down {
  bottom: 1rem;
}
.page-shop-detail .product-gallery-thumbs__nav.swiper-button-disabled {
  opacity: 0.3;
}
.page-shop-detail .product-gallery-thumbs__swiper {
  flex: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.page-shop-detail .product-gallery-thumbs .swiper-slide {
  height: 16rem !important;
  width: 16rem !important;
  cursor: pointer;
  border: 1px solid transparent;
  transition: border-color 0.2s ease;
}
.page-shop-detail .product-gallery-thumbs .swiper-slide.is-active {
  border-color: #000000;
}
.page-shop-detail .product-gallery-thumbs .swiper-slide .image-wrapper {
  aspect-ratio: 1/1;
  background-color: #f5f5f5;
}
.page-shop-detail .product-gallery-thumbs .swiper-slide .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-shop-detail .product-detail__info {
    width: 100%;
  }
}
.page-shop-detail .product-detail__divider {
  width: 100%;
  height: 1px;
  background-color: #dddddd;
  border: none;
  margin-top: var(--spacing-9, 3.2rem);
  margin-bottom: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-shop-detail .product-detail__divider {
    margin-top: var(--spacing-7, 2.4rem);
    margin-bottom: var(--spacing-7, 2.4rem);
  }
}
.page-shop-detail .product-info-selection {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
.page-shop-detail .product-info-selection__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
  color: #000000;
}
.page-shop-detail .product-info-selection__name {
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-8, 2.8rem);
}
.page-shop-detail .product-info-selection__divider {
  width: 1px;
  height: 1.2rem;
  background-color: #dddddd;
}
.page-shop-detail .product-info-selection__price {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  column-gap: var(--spacing-2, 0.8rem);
}
.page-shop-detail .product-info-selection__discount-rate {
  color: #FF3B30;
}
.page-shop-detail .product-info-selection__original-price {
  display: block;
  width: 100%;
  color: #dddddd;
  text-decoration: line-through;
}
.page-shop-detail .product-info-desc {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
  padding-top: var(--spacing-8, 2.8rem);
}
.page-shop-detail .product-info-desc__spec span {
  display: block;
}
.page-shop-detail .product-info-order {
  padding-top: var(--spacing-13, 5.6rem);
}
.page-shop-detail .product-info-order__options {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  border-bottom: 2px solid #000000;
}
.page-shop-detail #selectedOptionsContainer {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-shop-detail .product-selected-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-8, 2.8rem);
}
.page-shop-detail .product-selected-option__row {
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-1, 0.4rem);
}
.page-shop-detail .product-selected-option__name {
  color: #000000;
}
.page-shop-detail .product-selected-option__price {
  color: #000000;
  text-align: right;
}
.page-shop-detail .quantity-selector-wrapper {
  display: flex;
  gap: var(--spacing-3, 1rem);
}
.page-shop-detail .quantity-selector {
  display: flex;
  align-items: center;
  border: 1px solid #dddddd;
}
.page-shop-detail .quantity-selector__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  padding: 0;
  border: none;
  background-color: #ffffff;
  cursor: pointer;
  color: #000000;
  transition: background-color 0.2s ease;
}
@media (max-width: 1024px) {
  .page-shop-detail .quantity-selector__btn {
    width: 2.8rem;
    height: 2.8rem;
  }
}
.page-shop-detail .quantity-selector__btn:disabled {
  color: #dddddd;
}
.page-shop-detail .quantity-selector__btn--minus {
  border-right: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-shop-detail .quantity-selector__btn--minus svg {
    width: 2.1rem;
    height: 2.1rem;
  }
}
.page-shop-detail .quantity-selector__btn--plus {
  border-left: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-shop-detail .quantity-selector__btn--plus svg {
    width: 2.1rem;
    height: 2.1rem;
  }
}
.page-shop-detail .quantity-selector__btn--remove svg {
  width: 2rem;
  height: 2rem;
}
@media (max-width: 1024px) {
  .page-shop-detail .quantity-selector__btn--remove svg {
    width: 1.8rem;
    height: 1.8rem;
  }
}
.page-shop-detail .quantity-selector__value {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  color: #000000;
}
@media (max-width: 1024px) {
  .page-shop-detail .quantity-selector__value {
    width: 2.8rem;
    height: 2.8rem;
  }
}
.page-shop-detail .product-info-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.page-shop-detail .product-info-total__value {
  color: #FF3B30;
}
.page-shop-detail .product-info-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-4, 1.2rem);
}
.page-shop-detail .product-info-cta .button {
  flex: 1;
  min-width: auto;
}
.page-shop-detail .product-tabs {
  margin-top: var(--spacing-18, 12rem);
}
.page-shop-detail .product-tabs__nav {
  display: flex;
  border-bottom: 2px solid #dddddd;
}
.page-shop-detail .product-tabs__tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: 0;
  padding-right: 0;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  background: none;
  cursor: pointer;
  color: #dddddd;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.page-shop-detail .product-tabs__tab:hover {
  color: #000000;
}
.page-shop-detail .product-tabs__tab.is-active {
  color: #000000;
  border-bottom-color: #000000;
}
.page-shop-detail .product-tabs__count {
  color: #dddddd;
  font-style: normal;
  transition: color 0.2s ease;
}
.is-active .page-shop-detail .product-tabs__count, .product-tabs__tab:hover .page-shop-detail .product-tabs__count {
  color: #000000;
}
.page-shop-detail .product-tabs__panel {
  display: none;
  padding-top: var(--spacing-15, 7.2rem);
}
@media (max-width: 1024px) {
  .page-shop-detail .product-tabs__panel {
    padding-top: var(--spacing-11, 4rem);
  }
}
.page-shop-detail .product-tabs__panel.is-active {
  display: block;
}
.page-shop-detail .product-tabs__intro {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
  margin-bottom: var(--spacing-11, 4rem);
}
.page-shop-detail .product-tabs__info-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-15, 7.2rem);
  margin-bottom: var(--spacing-13, 5.6rem);
  border-bottom: 1px solid #000000;
}
.page-shop-detail .product-tabs__info-item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
}
.page-shop-detail .product-tabs__policy {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-15, 7.2rem);
  padding-bottom: var(--spacing-15, 7.2rem);
  margin-bottom: var(--spacing-13, 5.6rem);
  border-bottom: 1px solid #000000;
}
.page-shop-detail .product-tabs__policy-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-shop-detail .product-tabs__policy-list {
  padding-left: 3rem;
  list-style-type: disc;
}
.page-shop-detail .product-tabs__policy-list li {
  line-height: 1.6;
  margin-bottom: 0.2rem;
}
.page-shop-detail .product-tabs__policy-list li:last-child {
  margin-bottom: 0;
}
.page-shop-detail .product-tabs__qa-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-2, 0.8rem);
  margin-bottom: var(--spacing-6, 2rem);
}
.page-shop-detail .product-tabs__qa-title-wrap {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-shop-detail .product-tabs__qa-count {
  color: #FF3B30;
}
.page-shop-detail .product-tabs__qa-write-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem 0;
  border-bottom: 1px solid #000000;
  color: #000000;
  transition: opacity 0.2s ease;
}
.page-shop-detail .product-tabs__qa-list {
  display: flex;
  flex-direction: column;
}
.page-shop-detail .product-tabs__qa-item {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.page-shop-detail .product-tabs__qa-item--answered {
  background-color: transparent;
}
.page-shop-detail .product-tabs__qa-item--answered.is-open {
  background-color: #f2f2f2;
}
.page-shop-detail .product-tabs__qa-item-question {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-shop-detail .product-tabs__qa-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-3, 1rem);
}
.page-shop-detail .product-tabs__qa-item-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-shop-detail .product-tabs__qa-item-divider {
  width: 1px;
  height: 1.2rem;
  background-color: #dddddd;
}
.page-shop-detail .product-tabs__qa-item-date {
  text-align: right;
  flex: 1;
}
.page-shop-detail .product-tabs__qa-item-content {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-shop-detail .product-tabs__qa-item-content p {
  margin: 0;
  flex: 1;
}
.page-shop-detail .product-tabs__qa-item-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
  flex-shrink: 0;
}
.page-shop-detail .product-tabs__qa-action-btn {
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
  color: #000000;
  transition: opacity 0.2s ease;
}
.page-shop-detail .product-tabs__qa-action-btn:hover {
  opacity: 0.7;
}
.page-shop-detail .product-tabs__qa-item-answer {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
  border-top: 1px solid #dddddd;
  visibility: hidden;
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), padding 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), margin 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), visibility 0s 0.4s;
}
.page-shop-detail .product-tabs__qa-item-answer .badge {
  width: fit-content;
}
.page-shop-detail .product-tabs .product-tabs__qa-item.is-open .product-tabs__qa-item-answer {
  visibility: visible;
  max-height: 500px;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  margin-top: var(--spacing-6, 2rem);
  opacity: 1;
  transition: max-height 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), padding 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), margin 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), visibility 0s 0s;
}
.page-shop-detail .product-tabs__qa-answer-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
.page-shop-detail .product-tabs__qa-answer-content p {
  margin: 0;
}
.page-shop-detail .product-tabs__qa-answer-prefix {
  margin-right: var(--spacing-1, 0.4rem);
}
.page-shop-detail .product-tabs__qa-answer-date {
  color: #000000;
}
.page-shop-detail .product-tabs__qa-lock-icon {
  width: 3.2rem;
  height: 3.2rem;
  flex-shrink: 0;
  color: #000000;
}

.page-shop-cart {
  position: relative;
}
@media (min-width: 1024px) {
  .page-shop-cart .shop-lnb {
    display: none;
  }
}
@media (max-width: 1024px) {
  .page-shop-cart .shop-lnb {
    position: sticky;
    top: 7.4rem;
    display: flex;
  }
}
.page-shop-cart .cart-content {
  position: relative;
  width: 100%;
  padding-top: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-content {
    padding-top: 0;
  }
}
.page-shop-cart .shop-title {
  position: relative;
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-15, 7.2rem);
}
.page-shop-cart .cart-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-6, 2rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-section__header {
    flex-wrap: wrap;
    flex-direction: row;
    align-items: center;
  }
}
.page-shop-cart .cart-section__title {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}
.page-shop-cart .cart-section__header-tablet {
  display: none;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-section__header-tablet {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: var(--spacing-6, 2rem);
    padding-top: var(--spacing-4, 1.2rem);
    padding-bottom: var(--spacing-4, 1.2rem);
    border-bottom: 1px solid #dddddd;
  }
}
.page-shop-cart .cart-section__select-all {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}
.page-shop-cart .cart-section__delete-actions {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.page-shop-cart .cart-section__delete-button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  color: #000000;
}
.page-shop-cart .cart-section__delete-button:hover {
  text-decoration: underline;
}
.page-shop-cart .cart-section__all-delete-button {
  position: relative;
}
.page-shop-cart .cart-section__all-delete-button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -10px;
  transform: translateY(-50%);
  width: 0.1rem;
  height: 1.2rem;
  background-color: #dddddd;
}
.page-shop-cart .cart-table {
  width: 100%;
}
.page-shop-cart .cart-table__header {
  display: flex;
  align-items: center;
  height: 6.4rem;
  border-bottom: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-table__header {
    display: none;
  }
}
.page-shop-cart .cart-table__body {
  display: flex;
  flex-direction: column;
}
.page-shop-cart .cart-table__col {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.page-shop-cart .cart-table__col--checkbox {
  width: 4.5vw;
  min-width: 6.4rem;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-table__col--checkbox {
    width: 4.8rem;
    min-width: auto;
  }
}
.page-shop-cart .cart-table__col--info {
  flex-direction: column;
  flex: 1;
  text-align: left;
}
.page-shop-cart .cart-table__col--info--flex-start {
  align-items: flex-start;
}
.page-shop-cart .cart-table__col--option, .page-shop-cart .cart-table__col--price, .page-shop-cart .cart-table__col--total {
  width: clamp(12rem, 8.3333333333vw, 16rem);
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-table__col--option, .page-shop-cart .cart-table__col--price, .page-shop-cart .cart-table__col--total {
    display: none;
  }
}
.page-shop-cart .cart-table__col--price span.label--3, .page-shop-cart .cart-table__col--total span.label--3 {
  font-weight: 720;
}
.page-shop-cart .cart-table__col--action {
  width: max(12rem, 8.3333333333vw, 16rem);
  flex-shrink: 0;
  flex-direction: column;
  gap: var(--spacing-2, 0.8rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-table__col--action {
    display: none;
  }
}
.page-shop-cart .cart-item {
  position: relative;
  display: flex;
  align-items: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item {
    flex-direction: column;
    align-items: stretch;
    padding-top: var(--spacing-6, 2rem);
    padding-bottom: var(--spacing-6, 2rem);
    gap: var(--spacing-6, 2rem);
  }
}
.page-shop-cart .cart-item__top-row {
  display: none;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }
}
.page-shop-cart .cart-item__delete-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.8rem;
  height: 1.8rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.page-shop-cart .cart-item__delete-button svg {
  width: 1.8rem;
  height: 1.8rem;
}
@media (min-width: 1024px) {
  .page-shop-cart .cart-item__delete-tablet {
    display: none;
  }
}
.page-shop-cart .cart-item__product {
  display: flex;
  align-items: center;
  gap: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__product {
    gap: var(--spacing-5, 1.6rem);
    align-items: flex-start;
  }
}
.page-shop-cart .cart-item__image {
  position: relative;
  width: 13.2rem;
  height: 13.2rem;
  flex-shrink: 0;
  background-color: #f5f5f5;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__image {
    width: 8rem;
    height: 8rem;
  }
}
.page-shop-cart .cart-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-shop-cart .cart-item__image .tax-deduction-badge {
  position: absolute;
  left: 0;
  bottom: 0;
}
.page-shop-cart .cart-item__detail {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1, 0.4rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__detail {
    gap: var(--spacing-11, 4rem);
  }
}
.page-shop-cart .cart-item__info-name {
  font-weight: 720;
}
.page-shop-cart .cart-item__option {
  display: flex;
  align-items: center;
  gap: var(--spacing-4, 1.2rem);
  color: #000000;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__option {
    gap: var(--spacing-2, 0.8rem);
  }
}
.page-shop-cart .cart-item__price-tablet {
  display: none;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__price-tablet {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-top: var(--spacing-2, 0.8rem);
  }
}
.page-shop-cart .cart-item__quantity {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  margin-top: var(--spacing-2, 0.8rem);
  border: 1px solid #dddddd;
  width: fit-content;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__quantity {
    justify-content: flex-start;
  }
}
.page-shop-cart .cart-item__qty-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border: none;
  background-color: #ffffff;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__qty-button {
    width: 2.4rem;
    height: 2.4rem;
  }
}
.page-shop-cart .cart-item__qty-button:hover {
  background-color: #f5f5f5;
}
.page-shop-cart .cart-item__qty-button--minus {
  border-right: 1px solid #dddddd;
}
.page-shop-cart .cart-item__qty-button--plus {
  border-left: 1px solid #dddddd;
}
.page-shop-cart .cart-item__qty-button svg {
  width: 2.4rem;
  height: 2.4rem;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__qty-button svg {
    width: 1.4rem;
    height: 1.4rem;
  }
}
.page-shop-cart .cart-item__qty-value {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border: none;
  background-color: #ffffff;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__qty-value {
    width: 2.4rem;
    height: 2.4rem;
  }
}
.page-shop-cart .cart-item__actions-tablet {
  display: none;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item__actions-tablet {
    display: flex;
    gap: var(--spacing-3, 1rem);
    width: 100%;
    margin-top: var(--spacing-6, 2rem);
  }
  .page-shop-cart .cart-item__actions-tablet .button {
    flex: 1;
  }
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item .cart-table__col--action,
  .page-shop-cart .cart-item .cart-table__col--option,
  .page-shop-cart .cart-item .cart-table__col--price,
  .page-shop-cart .cart-item .cart-table__col--total {
    display: none;
  }
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item .cart-table__col--checkbox {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-item .cart-table__col--info {
    width: 100%;
  }
}
.page-shop-cart .cart-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-actions {
    display: none;
  }
}
.page-shop-cart .cart-summary {
  width: 100%;
}
.page-shop-cart .cart-summary__header {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 6.4rem;
  border-bottom: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-summary__header {
    display: none;
  }
}
.page-shop-cart .cart-summary__body {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-summary__body {
    flex-direction: column;
    align-items: stretch;
    border-bottom: none;
    padding: 0;
  }
}
.page-shop-cart .cart-summary__col {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-summary__col {
    display: none;
  }
}
.page-shop-cart .cart-summary__col--total {
  color: #FF3B30;
}
.page-shop-cart .cart-summary__operator {
  width: 3.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-summary__operator {
    display: none;
  }
}
.page-shop-cart .cart-summary__row-tablet {
  display: none;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-summary__row-tablet {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-summary__row-tablet-total {
    padding-top: 1.6rem;
  }
}
.page-shop-cart .cart-summary__label {
  color: #000000;
}
.page-shop-cart .cart-summary__value {
  color: #000000;
}
.page-shop-cart .cart-summary__value--total {
  color: #FF3B30;
}
.page-shop-cart .cart-order {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
  padding-left: var(--spacing-21, 16rem);
  padding-right: var(--spacing-21, 16rem);
  padding-bottom: var(--spacing-21, 16rem);
  margin-top: var(--spacing-17, 10rem);
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-order {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background-color: #ffffff;
    margin-top: var(--spacing-8, 2.8rem);
    padding-top: var(--spacing-3, 1rem);
    padding-left: max(1.6rem, 4.1025vw);
    padding-right: max(1.6rem, 4.1025vw);
    padding-bottom: 5.2rem;
    gap: var(--spacing-3, 1rem);
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  }
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-order--unfixed {
    position: static;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 5.2rem;
  }
}
.page-shop-cart .cart-order .button {
  flex: 1;
}
@media (max-width: 1024px) {
  .page-shop-cart .cart-order .button {
    min-width: 14rem;
  }
}
.page-shop-cart .checkbox {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.page-shop-cart .checkbox__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.page-shop-cart .checkbox__input:checked + .checkbox__box {
  background-color: #000000;
  border-color: #000000;
}
.page-shop-cart .checkbox__input:checked + .checkbox__box::after {
  opacity: 1;
}
.page-shop-cart .checkbox__box {
  position: relative;
  width: 2.2rem;
  height: 2.2rem;
  border: 1px solid #dddddd;
  background-color: #fafafa;
  transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-cart .checkbox__box::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1.2rem;
  height: 1rem;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='10' viewBox='0 0 12 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 5L4.5 8.5L11 1.5' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-cart .tax-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.8rem;
  background-color: #E91E63;
  color: #ffffff;
  border-radius: 0.3rem;
  font-size: 1.2rem;
  font-weight: 700;
  white-space: nowrap;
  margin-left: 0.8rem;
  vertical-align: middle;
}
.page-shop-cart .tax-badge.tax-free {
  background-color: #E91E63;
}
.page-shop-cart .sold-out-badge {
  display: inline-block;
  background: #FF3B30;
  color: #ffffff;
  padding: 0.4rem 1rem;
  border-radius: 0.5rem;
  font-size: 1.2rem;
  font-weight: 700;
  margin-left: 0.8rem;
}
.page-shop-cart .stock-info {
  font-size: 1.2rem;
  color: #787878;
  margin-top: 0.5rem;
}
.page-shop-cart .stock-info--sold-out {
  color: #FF3B30;
}
.page-shop-cart .cart-item--sold-out {
  opacity: 0.6;
}

@media (max-width: 1024px) {
  .shop-lnb {
    position: fixed;
    top: var(--header-height);
    width: 100%;
    margin-left: calc(-1 * max(4rem, 3.9062vw));
    margin-right: calc(-1 * max(4rem, 3.9062vw));
    background-color: #ffffff;
    border-top: 1px solid #eeeeee;
    border-bottom: 1px solid #eeeeee;
    z-index: 10;
    transition: top 0.3s ease-in-out, transform 0.3s ease-in-out;
  }
  body:has(.header-sticky) .shop-lnb {
    top: clamp(6.383rem, 4.6875vw, 9rem);
  }
  body:has(.header-hidden) .shop-lnb {
    transform: translateY(calc(-100% - var(--header-height)));
  }
}
@media (max-width: 680px) {
  .shop-lnb {
    margin-left: calc(-1 * max(1.6rem, 4.1025vw));
    margin-right: calc(-1 * max(1.6rem, 4.1025vw));
  }
}
.shop-lnb__list {
  display: flex;
  flex-direction: column;
}
@media (max-width: 1024px) {
  .shop-lnb__list {
    flex-direction: row;
    gap: 3.2rem;
    justify-content: center;
    overflow-x: auto;
    padding-left: max(4rem, 3.9062vw);
    padding-right: max(4rem, 3.9062vw);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .shop-lnb__list::-webkit-scrollbar {
    display: none;
  }
}
@media (max-width: 680px) {
  .shop-lnb__list {
    justify-content: flex-start;
    padding-left: max(1.6rem, 4.1025vw);
    padding-right: max(1.6rem, 4.1025vw);
  }
}
.shop-lnb__item {
  border-bottom: 1px solid #000000;
}
@media (max-width: 1024px) {
  .shop-lnb__item {
    flex-shrink: 0;
    border-bottom: none;
  }
}
.shop-lnb__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.6rem 0 1.8rem;
}
@media (max-width: 1024px) {
  .shop-lnb__link {
    height: 6.3rem;
    padding: 0;
  }
}
.shop-lnb__link span {
  line-height: 1;
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .shop-lnb__link svg {
    display: none;
  }
}
.shop-lnb__accordion-trigger {
  width: 100%;
  border: none;
  background: none;
  cursor: pointer;
  color: #000000;
}
.shop-lnb__icon-vertical {
  transform-origin: center;
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.shop-lnb__item.is-open {
  border-bottom: 1px solid #000000;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media (max-width: 1024px) {
  .shop-lnb__item.is-open {
    gap: 0;
  }
}
.shop-lnb__item.is-open .shop-lnb__icon-vertical {
  transform: rotate(90deg);
}
@media (max-width: 1024px) {
  .shop-lnb__item.is-open .shop-lnb__submenu-list {
    opacity: 1;
    visibility: visible;
  }
}
@media (max-width: 1024px) {
  .shop-lnb__item.is-open.submenu-hidden .shop-lnb__submenu-list {
    opacity: 0;
    visibility: hidden;
  }
}
.shop-lnb__submenu {
  height: 0;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .shop-lnb__submenu-list {
    display: flex;
    justify-content: center;
    gap: var(--spacing-6);
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    padding: 1.4rem max(4rem, 3.9062vw);
    background: #ffffff;
    border-bottom: 1px solid #eeeeee;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s cubic-bezier(0.215, 0.61, 0.355, 1), visibility 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  .shop-lnb__submenu-list::-webkit-scrollbar {
    display: none;
  }
}
@media (max-width: 680px) {
  .shop-lnb__submenu-list {
    padding: 1.4rem max(1.6rem, 4.1025vw);
    justify-content: flex-start;
  }
}
.shop-lnb__submenu-item {
  padding-bottom: var(--spacing-3);
}
@media (max-width: 1024px) {
  .shop-lnb__submenu-item {
    flex-shrink: 0;
    padding-bottom: 0;
    white-space: nowrap;
  }
}
.shop-lnb__submenu-item:last-child {
  padding-bottom: 1.6rem;
}
@media (max-width: 1024px) {
  .shop-lnb__submenu-item:last-child {
    padding-bottom: 0;
  }
}
.shop-lnb__submenu-link {
  display: block;
  transition: color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.page-shop-order {
  position: relative;
  padding-bottom: var(--spacing-21, 16rem);
}
@media (min-width: 1024px) {
  .page-shop-order .shop-lnb {
    display: none;
  }
}
@media (max-width: 1024px) {
  .page-shop-order .shop-lnb {
    position: sticky;
    top: 7.4rem;
    display: flex;
  }
}
.page-shop-order .shop-order__container {
  position: relative;
}
@media (max-width: 1024px) {
  .page-shop-order .shop-order__row {
    row-gap: 4rem;
  }
}
.page-shop-order .shop-title {
  position: relative;
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-15, 7.2rem);
}
.page-shop-order .order-payment {
  border: 1px solid #dddddd;
  background-color: #ffffff;
  position: sticky;
  top: calc(clamp(9.1rem, 6.6666666667vw, 12.8rem) + 2rem);
}
@media (max-width: 1024px) {
  .page-shop-order .order-payment {
    position: static;
    padding-top: 0;
    border: none;
  }
}
.page-shop-order .order-payment__header {
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-shop-order .order-payment__header {
    padding-left: 0;
    padding-right: 0;
  }
}
.page-shop-order .order-payment__body {
  padding: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  display: flex;
  flex-direction: column;
}
@media (max-width: 1024px) {
  .page-shop-order .order-payment__body {
    padding-left: 0;
    padding-right: 0;
  }
}
.page-shop-order .order-payment__prices {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
.page-shop-order .order-payment__price-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-shop-order .order-payment__price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-4, 1.2rem);
  row-gap: 0.4rem;
}
@media (max-width: 1024px) {
  .page-shop-order .order-payment__price-row {
    row-gap: 0.2rem;
  }
}
.page-shop-order .order-payment__price-row--coupon {
  flex-direction: column;
  align-items: flex-start;
}
.page-shop-order .order-payment__price-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-4, 1.2rem);
  width: 100%;
}
.page-shop-order .order-payment__coupon-name {
  color: #787878;
}
.page-shop-order .order-payment__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--spacing-9, 3.2rem);
}
.page-shop-order .order-payment__total-price {
  color: #FF3B30;
}
.page-shop-order .order-payment__agreement {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding-top: var(--spacing-13, 5.6rem);
  padding-bottom: var(--spacing-13, 5.6rem);
}
.page-shop-order .order-payment__checkbox-main {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
  cursor: pointer;
}
.page-shop-order .order-payment__agreement-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
.page-shop-order .order-payment__agreement-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}
.page-shop-order .order-payment__link {
  color: #787878;
  text-decoration: underline;
  transition: color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-order .order-payment__link:hover {
  color: #000000;
}
.page-shop-order .order-payment__submit-button {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-10, 3.6rem);
  padding-bottom: var(--spacing-10, 3.6rem);
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-5, 1.6rem);
  background-color: #000000;
  color: #ffffff;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-order .order-payment__submit-button:hover {
  opacity: 0.9;
}
.page-shop-order .order-shipping {
  margin-bottom: var(--spacing-21, 16rem);
}
.page-shop-order .order-shipping__title {
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-shop-order .order-shipping__tabs {
  display: flex;
  margin-top: var(--spacing-11, 4rem);
  margin-bottom: var(--spacing-11, 4rem);
}
.page-shop-order .order-shipping__tab {
  min-width: 19.3rem;
}
@media (max-width: 1024px) {
  .page-shop-order .order-shipping__tab {
    flex: 1;
    min-width: auto;
  }
}
.page-shop-order .order-shipping__tab:first-child {
  border-right: none;
}
.page-shop-order .order-shipping__tab--active {
  background-color: #000000;
}
.page-shop-order .order-shipping__tab--active span {
  color: #ffffff;
}
.page-shop-order .order-shipping__form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  max-width: 56.8rem;
}
@media (max-width: 1024px) {
  .page-shop-order .order-shipping__form {
    max-width: 100%;
  }
}
.page-shop-order .order-shipping__field {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
}
.page-shop-order .order-shipping__label {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
}
.page-shop-order .order-shipping__required {
  color: #FF3B30;
}
.page-shop-order .order-shipping__input {
  width: 100%;
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-5, 1.6rem);
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-5, 1.6rem);
  border: 1px solid #dddddd;
  background-color: #ffffff;
  transition: border-color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.page-shop-order .order-shipping__input::placeholder {
  color: #c6c6c6;
}
.page-shop-order .order-shipping__input:focus {
  outline: none;
}
.page-shop-order .order-shipping__input--zipcode {
  flex: 1;
}
.page-shop-order .order-shipping__address-row {
  display: flex;
  align-items: stretch;
  gap: var(--spacing-3, 1rem);
}
.page-shop-order .order-shipping__button-search {
  min-width: fit-content;
  flex-shrink: 0;
  height: auto;
}
.page-shop-order .order-products__title {
  margin-bottom: var(--spacing-9, 3.2rem);
}
.page-shop-order .order-products__header {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-5, 1.6rem);
  border-top: 2px solid #000000;
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__header {
    border-bottom: none;
  }
  .page-shop-order .order-products__header .order-products__col {
    display: none;
  }
}
.page-shop-order .order-products__col--info {
  flex: 1;
}
.page-shop-order .order-products__col--qty {
  width: 16rem;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__col--qty {
    display: none;
  }
}
.page-shop-order .order-products__col--qty span {
  font-weight: 720;
}
.page-shop-order .order-products__col--price {
  width: 16rem;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__col--price {
    display: none;
  }
}
.page-shop-order .order-products__col--price span {
  font-weight: 720;
}
.page-shop-order .order-products__list {
  display: flex;
  flex-direction: column;
}
.page-shop-order .order-products__item {
  display: flex;
  align-items: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
.page-shop-order .order-products__product {
  display: flex;
  gap: var(--spacing-9, 3.2rem);
}
.page-shop-order .order-products__thumb {
  width: 13.2rem;
  height: 13.2rem;
  flex-shrink: 0;
  background-color: #eeeeee;
}
.page-shop-order .order-products__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__thumb {
    width: 8rem;
    height: 8rem;
  }
}
.page-shop-order .order-products__detail {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--spacing-1, 0.4rem);
}
.page-shop-order .order-products__mobile-info {
  display: none;
  align-items: center;
  gap: var(--spacing-3, 1rem);
  margin-top: var(--spacing-2, 0.8rem);
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__mobile-info {
    display: flex;
  }
}
.page-shop-order .order-products__coupon {
  display: flex;
  align-items: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  background-color: #f2f2f2;
  border-bottom: 1px solid #dddddd;
  gap: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__coupon {
    padding-left: var(--spacing-6, 2rem);
    padding-right: var(--spacing-6, 2rem);
    flex-direction: column;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: var(--spacing-8, 2.8rem);
  }
}
.page-shop-order .order-products__coupon-badge {
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__coupon-badge {
    padding: 0;
  }
}
.page-shop-order .order-products__coupon-name {
  flex: 1;
}
.page-shop-order .order-products__coupon-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__coupon-info {
    width: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex: 1;
    flex-direction: column;
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-shop-order .order-products__coupon-discount {
  color: #FF3B30;
  width: 16rem;
  flex-shrink: 0;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-shop-order .order-products__coupon-discount {
    width: auto;
    text-align: left;
  }
}

.page-shop-complete {
  position: relative;
  padding-bottom: var(--spacing-21, 16rem);
}
.page-shop-complete .shop-complete__container {
  padding-top: var(--spacing-21, 16rem);
}
.page-shop-complete .order-complete {
  border: 1px solid #dddddd;
  background-color: #ffffff;
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-shop-complete .order-complete__container {
  max-width: 64.8rem;
  margin: 0 auto;
}
.page-shop-complete .order-complete__header {
  padding-top: var(--spacing-13, 5.6rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  text-align: center;
}
.page-shop-complete .order-complete__message {
  padding-bottom: var(--spacing-11, 4rem);
  text-align: center;
}
.page-shop-complete .order-complete__body {
  padding-top: var(--spacing-7, 2.4rem);
}
.page-shop-complete .order-complete__info-section {
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
}
.page-shop-complete .order-complete__info-row {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__info-row {
    padding-top: var(--spacing-3, 1rem);
    padding-bottom: var(--spacing-3, 1rem);
  }
}
.page-shop-complete .order-complete__info-label {
  flex-shrink: 0;
  width: 9rem;
  color: #000000;
}
.page-shop-complete .order-complete__info-value {
  flex: 1;
  color: #787878;
}
.page-shop-complete .order-complete__section {
  padding-bottom: var(--spacing-13, 5.6rem);
}
.page-shop-complete .order-complete__section:last-of-type {
  padding-bottom: var(--spacing-13, 5.6rem);
}
.page-shop-complete .order-complete__section-title {
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
}
.page-shop-complete .order-complete__product-header {
  display: flex;
  align-items: center;
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-5, 1.6rem);
  border-bottom: 1px solid #000000;
  text-align: center;
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product-header {
    display: none;
  }
}
.page-shop-complete .order-complete__product-col--info {
  flex: 1;
}
.page-shop-complete .order-complete__product-col--qty {
  width: 13rem;
  text-align: center;
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product-col--qty {
    display: none;
  }
}
.page-shop-complete .order-complete__product-col--price {
  width: 13rem;
  text-align: center;
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product-col--price {
    display: none;
  }
}
.page-shop-complete .order-complete__product-list {
  display: flex;
  flex-direction: column;
}
.page-shop-complete .order-complete__product-item {
  display: flex;
  align-items: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product-item {
    flex-direction: column;
    align-items: flex-start;
  }
}
.page-shop-complete .order-complete__product {
  display: flex;
  gap: var(--spacing-6, 2rem);
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product {
    gap: var(--spacing-5, 1.6rem);
    width: 100%;
  }
}
.page-shop-complete .order-complete__product-thumb {
  flex-shrink: 0;
  width: 11rem;
  height: 11rem;
  background-color: #f5f5f5;
}
.page-shop-complete .order-complete__product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product-thumb {
    width: 8rem;
    height: 8rem;
  }
}
.page-shop-complete .order-complete__product-detail {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--spacing-1, 0.4rem);
}
.page-shop-complete .order-complete__product-name {
  color: #000000;
}
.page-shop-complete .order-complete__product-option, .page-shop-complete .order-complete__product-unit-price {
  color: #000000;
}
.page-shop-complete .order-complete__product-mobile-info {
  display: none;
  gap: var(--spacing-3, 1rem);
  margin-top: var(--spacing-5, 1.6rem);
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__product-mobile-info {
    display: flex;
  }
}
.page-shop-complete .order-complete__summary-table {
  margin-top: var(--spacing-9, 3.2rem);
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__summary-table {
    display: none;
  }
}
.page-shop-complete .order-complete__summary-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  gap: var(--spacing-6, 2rem);
  border-bottom: 1px solid #000000;
  text-align: center;
}
.page-shop-complete .order-complete__summary-body {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
.page-shop-complete .order-complete__summary-col {
  flex: 1;
  text-align: center;
}
.page-shop-complete .order-complete__summary-col--total {
  color: #FF3B30;
}
.page-shop-complete .order-complete__summary-sign {
  flex-shrink: 0;
  width: 2rem;
  text-align: center;
}
.page-shop-complete .order-complete__summary-mobile {
  display: none;
  margin-top: var(--spacing-9, 3.2rem);
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__summary-mobile {
    display: block;
  }
}
.page-shop-complete .order-complete__summary-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
}
.page-shop-complete .order-complete__summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.page-shop-complete .order-complete__summary-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--spacing-5, 1.6rem);
}
.page-shop-complete .order-complete__total-price {
  color: #FF3B30;
}
.page-shop-complete .order-complete__buttons {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
  margin-top: var(--spacing-7, 2.4rem);
}
.page-shop-complete .order-complete__btn {
  flex: 1;
  min-width: 26rem;
}
@media (max-width: 680px) {
  .page-shop-complete .order-complete__btn {
    min-width: 14rem;
  }
}

.inquiry__intro {
  position: sticky;
  top: calc(clamp(9.1rem, 6.6666666667vw, 12.8rem) + var(--spacing-20));
}
@media (max-width: 1024px) {
  .inquiry__intro {
    position: static;
  }
}
.inquiry__intro-label {
  width: fit-content;
  display: flex;
  background: #000000;
  padding: var(--spacing-1) var(--spacing-2);
  justify-content: center;
  align-items: center;
  color: #ffffff;
  gap: var(--spacing-3, 1rem);
}
.inquiry__forms-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
}
.inquiry__form-label-required {
  color: #FF3B30;
}
.inquiry__form-input {
  width: 100%;
  padding: 1.4rem var(--spacing-5);
  border: 1.5px solid #dddddd;
}
.inquiry__form-input::placeholder {
  color: #dddddd;
}
.inquiry__form-textarea {
  width: 100%;
  height: 20.2rem;
  padding: 1.4rem var(--spacing-5);
  border: 1.5px solid #dddddd;
}
.inquiry__form-textarea::placeholder {
  color: #dddddd;
}
.inquiry__submit-button .button__label {
  line-height: 1;
}
@media (max-width: 1024px) {
  .inquiry__row {
    display: flex;
    flex-direction: column;
  }
}

@media (max-width: 1024px) {
  .page-inquiry__row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-13, 5.6rem);
  }
}

.page-inquiry-b2b .body--bold {
  font-weight: 700;
}
.page-inquiry-b2b__title {
  border-bottom: 1.5px solid #000000;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__row {
    display: flex;
    flex-direction: column;
  }
}
.page-inquiry-b2b__catalog {
  display: flex;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__catalog {
    flex-direction: column;
  }
}
.page-inquiry-b2b__catalog-image {
  flex: 1;
  width: auto;
  min-height: 25.6rem;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__catalog-image {
    width: 100%;
    min-height: 0;
  }
}
.page-inquiry-b2b__catalog-image img {
  width: 100%;
  height: 100%;
  aspect-ratio: 360/256;
  object-fit: cover;
}
.page-inquiry-b2b__catalog-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  background: #f2f2f2;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__catalog-content {
    height: auto;
    padding: var(--spacing-8, 2.8rem);
  }
}
.page-inquiry-b2b__process {
  width: 100%;
}
.page-inquiry-b2b__process-steps {
  display: flex;
  flex-direction: column;
}
.page-inquiry-b2b__steps-content {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__steps-content {
    flex-direction: column;
    gap: var(--spacing-15, 7.2rem);
  }
}
.page-inquiry-b2b__steps-content-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__steps-content-row--first {
    width: 100%;
  }
  .page-inquiry-b2b__steps-content-row--first .page-inquiry-b2b__step-item:last-child {
    padding-right: 0;
  }
  .page-inquiry-b2b__steps-content-row--first .page-inquiry-b2b__step-item:last-child::after {
    display: none;
  }
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__steps-content-row--last {
    width: 100%;
  }
}
.page-inquiry-b2b__steps-content-row--last .page-inquiry-b2b__step-item::after {
  display: none;
}
.page-inquiry-b2b__step-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  gap: var(--spacing-2, 0.8rem);
  min-width: 0;
  flex: 1;
  position: relative;
}
.page-inquiry-b2b__step-item::after {
  content: "";
  position: absolute;
  top: 1rem;
  left: calc(var(--spacing-16) * 0.5);
  width: calc(100% + var(--spacing-16));
  height: 0;
  border-top: 1px dashed #000000;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__step-item::after {
    left: 50%;
  }
}
.page-inquiry-b2b__step-item--hidden {
  display: none;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__step-item--hidden {
    display: flex;
    visibility: hidden;
  }
}
.page-inquiry-b2b__step-circle {
  width: 2rem;
  height: 2rem;
  background-color: #000000;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  margin-bottom: var(--spacing-5, 1.6rem);
}
.page-inquiry-b2b__step-number {
  font-family: var(--font-ko);
  font-weight: 800;
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: -0.04em;
  color: #ffffff;
}
.page-inquiry-b2b__step-title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
  color: #000000;
  white-space: nowrap;
}
.page-inquiry-b2b__step-desc {
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.04em;
  color: #000000;
  text-align: center;
}
.page-inquiry-b2b__consultation-item {
  display: flex;
  gap: 1.2rem;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__consultation-item {
    padding-top: 0;
  }
}
.page-inquiry-b2b__consultation-label {
  min-width: 9rem;
  font-weight: 700;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__consultation-label {
    min-width: 7rem;
    padding: var(--spacing-4) 0;
  }
}
.page-inquiry-b2b__consultation-value {
  flex: 1;
  color: #787878;
  word-break: break-word;
  padding-bottom: 2.1rem;
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__consultation-value {
    padding: var(--spacing-3) 0 1.6rem;
  }
}
.page-inquiry-b2b__forms-grid-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  row-gap: var(--spacing-11, 4rem);
  column-gap: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-inquiry-b2b__forms-grid-wrapper {
    grid-template-columns: 1fr;
  }
}
.page-inquiry-b2b__forms-flex-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
}

.page-privacy .privacy-header__title {
  color: #000000;
  text-align: center;
}
.page-privacy .privacy-notice {
  background-color: #f5f5f5;
}
.page-privacy .privacy-notice__text {
  color: #000000;
}
.page-privacy .privacy-notice__text p {
  margin: 0;
}
.page-privacy .privacy-content .container-boxed-m {
  margin: 0 auto;
  padding: 0 var(--spacing-15, 6rem);
  max-width: 118.4rem;
}
@media (max-width: 1024px) {
  .page-privacy .privacy-content .container-boxed-m {
    padding: 0 var(--spacing-11, 3.2rem);
  }
}
@media (max-width: 680px) {
  .page-privacy .privacy-content .container-boxed-m {
    padding: 0 var(--spacing-6, 1.6rem);
  }
}
.page-privacy .privacy-items {
  display: flex;
  flex-direction: column;
}
.page-privacy .privacy-item {
  display: flex;
  flex-direction: column;
}
.page-privacy .privacy-item__header {
  display: flex;
  flex-direction: column;
}
.page-privacy .privacy-item__title {
  color: #000000;
}
.page-privacy .privacy-item__subtitle {
  color: #000000;
}
.page-privacy .privacy-item__subtitle p {
  margin: 0;
}
.page-privacy .privacy-item__content {
  display: flex;
  flex-direction: column;
}
.page-privacy .privacy-item__footer {
  color: #000000;
}
.page-privacy .privacy-item__footer p {
  margin: 0;
}
.page-privacy .privacy-list-item {
  display: flex;
  flex-direction: column;
}
.page-privacy .privacy-list-item__title {
  margin: 0;
  padding: 0;
  color: #000000;
  list-style-type: decimal;
}
.page-privacy .privacy-list-item__title li {
  margin-left: 2rem;
}
.page-privacy .privacy-list-item__desc {
  margin: 0;
  padding: 0;
  color: #000000;
  list-style-type: disc;
}
.page-privacy .privacy-list-item__desc li {
  margin-left: 3rem;
}
.page-privacy .privacy-list-item__bullet {
  margin: 0;
  padding: 0;
  color: #000000;
  list-style-type: disc;
}
.page-privacy .privacy-list-item__bullet li {
  margin-left: 3rem;
}
.page-privacy .privacy-list-item__text {
  padding-left: 3rem;
  color: #000000;
}
.page-privacy .privacy-table {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.page-privacy .privacy-table__table {
  border-bottom: 1px solid #e0e0e0;
  width: 100%;
  border-collapse: collapse;
}
.page-privacy .privacy-table__table thead tr th {
  padding: var(--spacing-5, 1.6rem);
  border-right: 1px solid #ffffff;
  background-color: #000000;
  color: #ffffff;
  text-align: center;
}
.page-privacy .privacy-table__table thead tr th:last-child {
  border-right: none;
}
.page-privacy .privacy-table__table tbody tr td {
  padding: var(--spacing-5, 1.6rem);
  border: 1px solid #e0e0e0;
  border-bottom: none;
  background-color: #ffffff;
  color: #000000;
  text-align: center;
}
.page-privacy .privacy-table__table tbody tr td:last-child {
  border-right: none;
}
.page-privacy .privacy-table__note {
  margin: 0;
  color: #767676;
  text-align: right;
}
.page-privacy .privacy-history {
  display: flex;
  gap: var(--spacing-3, 1rem);
  align-items: stretch;
}
@media (max-width: 1024px) {
  .page-privacy .privacy-history {
    align-items: flex-start;
    flex-direction: column;
  }
}
@media (max-width: 1024px) {
  .page-privacy .custom-dropdown {
    width: 100%;
  }
}
.page-privacy .custom-dropdown__trigger {
  width: 34rem;
}
.page-privacy .button {
  padding: 2rem 1.6rem;
  min-width: 10rem;
}
@media (max-width: 1024px) {
  .page-privacy .button {
    padding: 1.6rem;
    width: 8rem;
  }
}
.page-privacy .container-boxed-m {
  margin: 0 auto;
  padding: 0 var(--spacing-15, 6rem);
  max-width: 118.4rem;
}
@media (max-width: 1024px) {
  .page-privacy .container-boxed-m {
    padding: 0 var(--spacing-11, 3.2rem);
  }
}
@media (max-width: 680px) {
  .page-privacy .container-boxed-m {
    padding: 0 var(--spacing-6, 1.6rem);
  }
}

@counter-style circled-numbers {
  system: fixed;
  symbols: "①" "②" "③" "④" "⑤" "⑥" "⑦" "⑧" "⑨" "⑩" "⑪" "⑫" "⑬" "⑭" "⑮" "⑯" "⑰" "⑱" "⑲" "⑳";
  suffix: " ";
}
.page-terms {
  padding-top: var(--header-height);
}

.terms-header__title {
  color: #000000;
  text-align: center;
}

.terms-content .container-boxed-m {
  margin: 0 auto;
  padding: 0 var(--spacing-15, 6rem);
  max-width: 118.4rem;
}
@media (max-width: 1024px) {
  .terms-content .container-boxed-m {
    padding: 0 var(--spacing-11, 3.2rem);
  }
}
@media (max-width: 680px) {
  .terms-content .container-boxed-m {
    padding: 0 var(--spacing-6, 1.6rem);
  }
}

.terms-items {
  display: flex;
  flex-direction: column;
}

.terms-article {
  display: flex;
  flex-direction: column;
}
.terms-article__title {
  color: #000000;
}
.terms-article__content {
  color: #000000;
}
.terms-article__content p {
  margin: 0;
}
.terms-article__content p.sp-mt-5 {
  margin-top: var(--spacing-5, 1.6rem);
}

.terms-list {
  margin: 0;
  padding: 0;
}
.terms-list--ordered {
  list-style-type: decimal;
}
.terms-list--ordered > li {
  margin-bottom: 0;
  margin-left: 2rem;
  line-height: 1.6;
}
.terms-list--ordered > li:last-child {
  margin-bottom: 0;
}
.terms-list--unordered {
  list-style-type: disc;
}
.terms-list--unordered > li {
  margin-bottom: 0;
  margin-left: 3rem;
  line-height: 1.6;
}
.terms-list--unordered > li:last-child {
  margin-bottom: 0;
}
.terms-list--alpha {
  list-style-type: none;
  counter-reset: alpha-counter;
  margin: 0;
  padding: 0;
  margin-top: 0.4rem;
}
.terms-list--alpha > li {
  counter-increment: alpha-counter;
  position: relative;
  margin-bottom: 0;
  padding-left: 2rem;
  line-height: 1.6;
}
.terms-list--alpha > li::before {
  content: counter(alpha-counter, circled-numbers);
  position: absolute;
  left: 0;
}
.terms-list--alpha > li:last-child {
  margin-bottom: 0;
}

.terms-history {
  display: flex;
  gap: var(--spacing-3, 1rem);
  align-items: stretch;
}
@media (max-width: 1024px) {
  .terms-history {
    align-items: flex-start;
    flex-direction: column;
  }
}
@media (max-width: 1024px) {
  .terms-history .custom-dropdown {
    width: 100%;
  }
}
.terms-history .custom-dropdown__trigger {
  width: 34rem;
}
.terms-history .button {
  padding: var(--spacing-6) var(--spacing-5);
  min-width: 10rem;
}
@media (max-width: 1024px) {
  .terms-history .button {
    width: 8rem;
  }
}
.terms-history .button--m {
  height: auto;
}
.terms-history .button__label {
  line-height: 1;
}

.page-cctv {
  padding-top: var(--header-height);
}

.cctv-header__title {
  color: #000000;
  text-align: center;
}

.cctv-notice {
  background-color: #f5f5f5;
}
.cctv-notice__text {
  color: #000000;
}
.cctv-notice__text p {
  margin: 0;
}

.cctv-content .container-boxed-m {
  margin: 0 auto;
  padding: 0 var(--spacing-15, 6rem);
  max-width: 118.4rem;
}
@media (max-width: 1024px) {
  .cctv-content .container-boxed-m {
    padding: 0 var(--spacing-11, 3.2rem);
  }
}
@media (max-width: 680px) {
  .cctv-content .container-boxed-m {
    padding: 0 var(--spacing-6, 1.6rem);
  }
}

.cctv-items {
  display: flex;
  flex-direction: column;
}

.cctv-item {
  display: flex;
  flex-direction: column;
}
.cctv-item__header {
  display: flex;
  flex-direction: column;
}
.cctv-item__title {
  color: #000000;
}
.cctv-item__subtitle {
  color: #000000;
}
.cctv-item__subtitle p {
  margin: 0;
}
.cctv-item__content {
  display: flex;
  flex-direction: column;
}
.cctv-item__desc {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2, 0.6rem);
  color: #000000;
}
.cctv-item__desc p {
  margin: 0;
}
.cctv-item__footer {
  color: #000000;
}
.cctv-item__footer p {
  margin: 0;
}

.cctv-list-item {
  display: flex;
  flex-direction: column;
}
.cctv-list-item__title {
  margin: 0;
  padding: 0;
  color: #000000;
  list-style-type: decimal;
}
.cctv-list-item__title li {
  margin-left: 2rem;
}
.cctv-list-item__desc {
  margin: 0;
  padding: 0;
  color: #000000;
  list-style-type: disc;
}
.cctv-list-item__desc li {
  margin-left: 3rem;
}
.cctv-list-item__bullet {
  margin: 0;
  padding: 0;
  color: #000000;
  list-style-type: disc;
}
.cctv-list-item__bullet li {
  margin-left: 3rem;
}
.cctv-list-item__text {
  padding-left: 3rem;
  color: #000000;
}

.cctv-history {
  display: flex;
  gap: var(--spacing-3, 1rem);
  align-items: stretch;
}
@media (max-width: 1024px) {
  .cctv-history {
    align-items: flex-start;
    flex-direction: column;
  }
}
.cctv-history .custom-dropdown {
  width: 34rem;
}
@media (max-width: 1024px) {
  .cctv-history .custom-dropdown {
    width: 100%;
  }
}
.cctv-history .button {
  padding: var(--spacing-6) var(--spacing-5);
  min-width: 10rem;
}
@media (max-width: 1024px) {
  .cctv-history .button {
    width: 8rem;
  }
}
.cctv-history .button--m {
  height: auto;
}
.cctv-history .button__label {
  line-height: 1;
}

.page-press__search-bar {
  width: 34rem;
  margin-left: auto;
}
@media (max-width: 1024px) {
  .page-press__search-bar {
    width: 100%;
  }
}
.page-press .press-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-press .press-list {
    grid-template-columns: 1fr;
  }
}
.page-press .press-list__item {
  display: flex;
  flex-direction: column;
}
.page-press .press-list__thumbnail {
  width: 100%;
  aspect-ratio: 568/355.32;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .page-press .press-list__thumbnail {
    aspect-ratio: 358/223.95;
  }
}
.page-press .press-list__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-press__button .button__label {
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.58);
  line-height: 1;
}
@media (max-width: 680px) {
  .page-press__button .button__label {
    font-size: calc(max(2.8rem, 2.93vw) * 0.58);
  }
}

.page-press-view .page-header__info-wrapper {
  border-bottom: 1px solid #000000;
}
.page-press-view .page-header__share-icon {
  width: 3.2rem;
  height: 3.2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.page-press-view .page-header__share-icon svg {
  width: 100%;
  height: 100%;
}
@media (max-width: 1024px) {
  .page-press-view .article-view__container {
    padding-top: var(--spacing-16, 8rem);
  }
}
@media (max-width: 1024px) {
  .page-press-view .article-view__row {
    display: block;
  }
}
.page-press-view .article-view__image-wrapper {
  width: 100%;
  aspect-ratio: 8/3;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .page-press-view .article-view__image-wrapper {
    aspect-ratio: 179/112;
  }
}
.page-press-view .article-view__image-wrapper picture, .page-press-view .article-view__image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-press-view .article-view__button-wrapper {
  text-align: center;
}
.page-press-view .article-view__button-wrapper .button__label {
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.58);
  line-height: 1;
}
@media (max-width: 680px) {
  .page-press-view .article-view__button-wrapper .button__label {
    font-size: calc(max(2.8rem, 2.93vw) * 0.58);
  }
}

@media (max-width: 1024px) {
  .page-sponsor .row {
    display: flex;
    flex-direction: column;
  }
}
.page-sponsor .page-header__headline-wrapper {
  text-align: center;
}
.page-sponsor .sponsor-intro__image {
  width: 100%;
  aspect-ratio: 1184/739.6;
}
@media (max-width: 1024px) {
  .page-sponsor .sponsor-intro__image {
    aspect-ratio: 358/223.63;
  }
}
.page-sponsor .sponsor-intro__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-sponsor .sponsor-intro__row {
    gap: var(--spacing-12, 4.8rem);
  }
}
.page-sponsor .sponsor-intro__text-wrapper {
  background: #f5f5f5;
  padding: var(--spacing-7, 2.4rem);
}
.page-sponsor .sponsor-intro__banner-title {
  line-height: 1.4;
}
.page-sponsor .sponsor-partners__headline-wrapper {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-6, 2rem);
}
@media (max-width: 1024px) {
  .page-sponsor .sponsor-partners__image-row {
    gap: var(--spacing-5, 1.6rem);
  }
}

.page-membership-guide__title-extra-bold {
  font-weight: 800;
}
.page-membership-guide__kv-container {
  position: relative;
}
@media (max-width: 1024px) {
  .page-membership-guide__kv-container {
    background: linear-gradient(180deg, #111 0%, #000 100%);
  }
}
.page-membership-guide .key-visual {
  width: 100%;
  overflow: hidden;
}
.page-membership-guide .key-visual__inner {
  width: 100%;
}
@media (max-width: 1024px) {
  .page-membership-guide .key-visual__inner {
    margin-bottom: 0;
  }
}
.page-membership-guide .key-visual__headline {
  color: #ffffff;
  margin-bottom: 17.8125vw;
}
@media (max-width: 1024px) {
  .page-membership-guide .key-visual__headline {
    margin-bottom: 17.96878vw;
  }
}
@media (max-width: 680px) {
  .page-membership-guide .key-visual__headline {
    margin-bottom: var(--spacing-21);
  }
}
.page-membership-guide .key-visual__image-wrapper-desktop {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.page-membership-guide .key-visual__image-wrapper-desktop img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-membership-guide .key-visual__image-wrapper-desktop {
    display: none;
  }
}
.page-membership-guide .key-visual__image-wrapper-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .page-membership-guide .key-visual__image-wrapper-mobile {
    display: block;
    width: 56.642vw;
    margin: 0 auto;
    box-shadow: -4px 0 20px 0 rgba(0, 0, 0, 0.4);
  }
}
@media (max-width: 680px) {
  .page-membership-guide .key-visual__image-wrapper-mobile {
    width: 65.388vw;
  }
}
.page-membership-guide .key-visual__image-wrapper-mobile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-membership-guide .key-visual__content {
    padding-top: 21.4rem;
  }
}
@media (max-width: 680px) {
  .page-membership-guide .key-visual__content {
    padding-top: var(--spacing-22, 18.4rem);
  }
}
.page-membership-guide .key-visual__description {
  color: #ffffff;
}
.page-membership-guide .key-visual__buttons {
  display: flex;
  width: 100%;
  gap: var(--spacing-3, 1rem);
}
.page-membership-guide .key-visual__buttons .button {
  min-width: 0;
  flex: 1;
}
@media (max-width: 1024px) {
  .page-membership-guide .key-visual__buttons .button {
    width: 17.5rem;
    flex: none;
  }
}
@media (max-width: 680px) {
  .page-membership-guide .key-visual__buttons .button {
    flex: 1;
  }
}
.page-membership-guide .membership-benefits__number {
  font-weight: 700;
}
@media (max-width: 1024px) {
  .page-membership-guide .membership-benefits__row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-16, 8rem);
  }
}
@media (max-width: 1024px) {
  .page-membership-guide .membership-benefits__row.sp-pt-12 {
    padding-top: var(--spacing-16, 8rem);
  }
}
@media (max-width: 1024px) {
  .page-membership-guide .membership-benefits__item {
    margin-top: 0;
  }
}
@media (max-width: 1024px) {
  .page-membership-guide .membership-benefits__item--large {
    width: 32rem;
  }
}
@media (max-width: 1024px) {
  .page-membership-guide .membership-benefits__item--small {
    width: 28rem;
    margin-left: auto;
  }
}
.page-membership-guide .membership-benefits__image--large {
  aspect-ratio: 361/226;
}
.page-membership-guide .membership-benefits__image--small {
  aspect-ratio: 8/5;
}
.page-membership-guide .partner-discounts {
  background: #f5f5f5;
}
@media (max-width: 1024px) {
  .page-membership-guide .partner-discounts__row {
    display: flex;
    flex-direction: column;
  }
}
.page-membership-guide .partner-discounts__items-wrapper {
  display: flex;
  flex-direction: column;
}
.page-membership-guide .partner-discounts__item {
  display: flex;
  border-top: 1px solid #000000;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-membership-guide .partner-discounts__item {
    flex-direction: column;
  }
}
.page-membership-guide .partner-discounts__image {
  aspect-ratio: 8/5;
  flex: 4;
}
.page-membership-guide .partner-discounts__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-membership-guide .partner-discounts__contents-inner {
  flex: 3;
}
.page-membership-guide .partner-discounts__label {
  width: fit-content;
  background: #000000;
  padding: 0.3rem var(--spacing-3);
  font-weight: 400;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-membership-guide .partner-discounts__label {
    line-height: 1.4;
  }
}
.page-membership-guide .partner-discounts__description {
  word-break: keep-all;
}
.page-membership-guide .partner-discounts__caption {
  color: #787878;
  font-weight: 400;
}
.page-membership-guide .bottom-cta {
  background: #000000;
}
.page-membership-guide .bottom-cta__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 1024px) {
  .page-membership-guide .bottom-cta__inner {
    grid-template-columns: 1fr;
  }
}
.page-membership-guide .bottom-cta__card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--spacing-12, 4.8rem);
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
  min-height: 33rem;
}
.page-membership-guide .bottom-cta__card:first-child {
  border-right: 1px solid #ffffff;
}
@media (max-width: 1024px) {
  .page-membership-guide .bottom-cta__card:first-child {
    border-right: none;
  }
}
@media (max-width: 1024px) {
  .page-membership-guide .bottom-cta__card {
    min-height: 28rem;
  }
}
.page-membership-guide .bottom-cta__card-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-membership-guide .bottom-cta__card-title {
  color: #ffffff;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-guide .bottom-cta__card-desc {
  color: #ffffff;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
}
.page-membership-guide .bottom-cta__card-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20rem;
  width: fit-content;
  padding: 1.6rem;
  background: transparent;
  color: #ffffff;
  border: 1px solid #ffffff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
  cursor: pointer;
  transition: all 0.2s ease;
}
.page-membership-guide .bottom-cta__join-inner {
  display: flex;
  padding: var(--spacing-12) var(--spacing-9);
  border-bottom: 1px solid #ffffff;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-membership-guide .bottom-cta__join-inner {
    flex-direction: column;
    gap: var(--spacing-12, 4.8rem);
  }
}
.page-membership-guide .bottom-cta__join-card-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-membership-guide .bottom-cta__card-contacts {
  color: #ffffff;
}
.page-membership-guide .bottom-cta__join-image-wrapper {
  width: 62rem;
  aspect-ratio: 620/340;
}
@media (max-width: 1024px) {
  .page-membership-guide .bottom-cta__join-image-wrapper {
    width: 100%;
  }
}
.page-membership-guide .bottom-cta__join-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-membership-join .page-header {
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-14, 6.4rem);
}
.page-membership-join .membership-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-membership-join .membership-list {
    grid-template-columns: 1fr;
    gap: var(--spacing-16, 8rem);
  }
}
.page-membership-join .membership-item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-14, 6.4rem);
}
.page-membership-join .membership-item__card {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  align-items: center;
  width: 100%;
}
.page-membership-join .membership-item__visual {
  position: relative;
  width: 100%;
  max-width: 36rem;
  aspect-ratio: 360/458;
  overflow: hidden;
}
.page-membership-join .membership-item__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-membership-join .membership-item__name {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
  text-align: center;
}
.page-membership-join .membership-item__plan {
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: var(--spacing-14, 6.4rem);
}
.page-membership-join .membership-item__plan-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
.page-membership-join .membership-item__plan-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
}
.page-membership-join .membership-item__divider {
  width: 100%;
  height: 2px;
  background: #000000;
}
.page-membership-join .membership-item__divider--light {
  height: 1px;
  background: #dddddd;
}
.page-membership-join .membership-item__price-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-5, 1.6rem);
}
.page-membership-join .membership-item__price-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-4, 1.2rem);
}
.page-membership-join .membership-item__price {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .membership-item__period {
  color: #787878;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .membership-item__people-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-4, 1.2rem);
}
.page-membership-join .membership-item__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 1rem;
  background: #000000;
  color: #ffffff;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .membership-item__icons {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
}
.page-membership-join .membership-item__icon {
  width: 3.6rem;
  height: 3.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-membership-join .membership-item__icon svg, .page-membership-join .membership-item__icon img {
  width: 2.6rem;
  height: 2.8rem;
}
.page-membership-join .membership-item__icon-plus {
  width: 1.4rem;
  height: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.page-membership-join .membership-item__icon-plus::before, .page-membership-join .membership-item__icon-plus::after {
  content: "";
  position: absolute;
  background: #000000;
}
.page-membership-join .membership-item__icon-plus::before {
  width: 1.4rem;
  height: 0.2rem;
}
.page-membership-join .membership-item__icon-plus::after {
  width: 0.2rem;
  height: 1.4rem;
}
.page-membership-join .membership-item__benefits {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-5, 1.6rem);
}
.page-membership-join .membership-item__benefits-title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .membership-item__benefits-list {
  color: #787878;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
  padding-left: 2.7rem;
  margin: 0;
  list-style-type: disc;
}
.page-membership-join .membership-item__benefits-list li {
  margin-bottom: 0;
}
.page-membership-join .membership-item__benefits-list li::marker {
  color: #787878;
}
.page-membership-join .membership-item__actions {
  display: flex;
  margin-top: auto;
  gap: var(--spacing-3, 1rem);
  width: 100%;
}
.page-membership-join .membership-item__actions .button {
  min-width: auto;
  flex: 1;
}
.page-membership-join .gift-registration {
  margin-top: var(--spacing-20, 14rem);
}
.page-membership-join .gift-registration__header {
  width: 100%;
  height: 2px;
  background: #000000;
  margin-bottom: var(--spacing-16, 8rem);
}
.page-membership-join .gift-registration__title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .gift-registration__info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
}
.page-membership-join .gift-registration__section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-membership-join .gift-registration__section-title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .gift-registration__section-list {
  color: #787878;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
  padding-left: 2.7rem;
  margin: 0;
  list-style-type: disc;
}
.page-membership-join .gift-registration__section-list li {
  margin-bottom: 0;
}
.page-membership-join .refund-info {
  margin-top: var(--spacing-16, 8rem);
}
.page-membership-join .refund-info__divider {
  width: 100%;
  height: 1px;
  background: #dddddd;
  margin-bottom: var(--spacing-11, 4rem);
}
.page-membership-join .refund-info__box {
  display: flex;
  gap: var(--spacing-16, 8rem);
  padding: var(--spacing-12, 4.8rem);
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  background: #f5f5f5;
}
@media (max-width: 1024px) {
  .page-membership-join .refund-info__box {
    flex-direction: column;
    gap: var(--spacing-7, 2.4rem);
  }
}
.page-membership-join .refund-info__title {
  flex-shrink: 0;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .refund-info__content {
  flex: 1;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
}
.page-membership-join .refund-info__content p {
  margin: 0;
}
.page-membership-join .bottom-cta {
  margin-top: var(--spacing-20, 14rem);
  background: #000000;
}
.page-membership-join .bottom-cta__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 1024px) {
  .page-membership-join .bottom-cta__inner {
    grid-template-columns: 1fr;
  }
}
.page-membership-join .bottom-cta__card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--spacing-12, 4.8rem);
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
  min-height: 33rem;
}
.page-membership-join .bottom-cta__card:first-child {
  border-right: 1px solid #ffffff;
}
@media (max-width: 1024px) {
  .page-membership-join .bottom-cta__card:first-child {
    border-right: none;
  }
}
@media (max-width: 1024px) {
  .page-membership-join .bottom-cta__card {
    min-height: 28rem;
  }
}
.page-membership-join .bottom-cta__card-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-membership-join .bottom-cta__card-title {
  color: #ffffff;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join .bottom-cta__card-desc {
  color: #ffffff;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
}
.page-membership-join .bottom-cta__card-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20rem;
  width: fit-content;
  padding: 1.6rem;
  background: transparent;
  color: #ffffff;
  border: 1px solid #ffffff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
  cursor: pointer;
  transition: all 0.2s ease;
}

.page-notice-list .page-header__headline {
  text-align: center;
}
.page-notice-list .page-header__button {
  min-width: auto;
  width: fit-content;
  height: auto;
  padding: var(--spacing-3) var(--spacing-5);
}
.page-notice-list .page-header__button.active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
.page-notice-list .page-header__button .button__label {
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.79);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
@media (max-width: 680px) {
  .page-notice-list .page-header__button .button__label {
    font-size: calc(max(2.8rem, 2.93vw) * 0.79);
  }
}
.page-notice-list .notice-list--event {
  display: none;
}
.page-notice-list .notice-list__search-bar {
  width: 34rem;
  margin-left: auto;
}
@media (max-width: 1024px) {
  .page-notice-list .notice-list__search-bar {
    width: 100%;
  }
}
@media (max-width: 1024px) {
  .page-notice-list .notice-list .row {
    display: flex;
    flex-direction: column;
  }
}
.page-notice-list .notice-list__item {
  border-bottom: 1px solid #000000;
}
.page-notice-list .notice-list__link {
  display: flex;
  text-decoration: none;
  color: inherit;
}
.page-notice-list .notice-list__title {
  flex: 1;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.page-notice-view .page-header__date {
  border-bottom: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-notice-view .row {
    display: flex;
    flex-direction: column;
  }
}
.page-notice-view .notice-detail__button-wrapper {
  text-align: center;
}
.page-notice-view .notice-detail__button {
  width: 26rem;
  min-width: auto;
}
@media (max-width: 1024px) {
  .page-notice-view .notice-detail__button {
    width: 21rem;
  }
}
.page-notice-view .notice-detail__button .button__label {
  font-family: var(--font-ko);
  letter-spacing: -0.04em;
  line-height: 1;
  font-size: calc(clamp(1.34rem, 0.8333vw, 1.6rem) * 1.125);
}
@media (max-width: 680px) {
  .page-notice-view .notice-detail__button .button__label {
    font-size: calc(max(1.34rem, 1.3671vw) * 1.125);
  }
}

.page-membership-join-2 {
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 {
    padding-top: var(--spacing-14, 6.4rem);
    padding-bottom: var(--spacing-16, 8rem);
  }
}
.page-membership-join-2 .page-header__tabs {
  display: flex;
  gap: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .page-header__tabs {
    flex-direction: column;
    gap: var(--spacing-3, 1rem);
  }
}
.page-membership-join-2 .page-header__tab {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 6.5rem;
  padding-left: var(--spacing-6, 2rem);
  padding-right: var(--spacing-6, 2rem);
  border: 1.5px solid #000000;
  background: transparent;
  transition: all 0.2s ease;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .page-header__tab {
    height: 5.2rem;
  }
}
.page-membership-join-2 .page-header__tab .title {
  font-weight: 700;
  color: #000000;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-membership-join-2 .page-header__tab:hover {
    background: #f5f5f5;
  }
}
.page-membership-join-2 .page-header__tab--active {
  background: #000000;
  border-color: #000000;
}
.page-membership-join-2 .page-header__tab--active .title {
  color: #ffffff;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-membership-join-2 .page-header__tab--active:hover {
    background: #000000;
  }
}
.page-membership-join-2 .membership-filter__wrap {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.page-membership-join-2 .membership-filter__swiper {
  width: 100%;
  overflow: hidden;
}
.page-membership-join-2 .membership-filter__swiper .swiper-wrapper {
  display: flex;
}
.page-membership-join-2 .membership-filter__swiper .swiper-slide {
  width: auto;
  margin-right: var(--spacing-7, 2.4rem);
}
.page-membership-join-2 .membership-filter__btn {
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-membership-join-2 .membership-filter__btn.is-active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
.page-membership-join-2 .join-content {
  display: flex;
  gap: var(--spacing-12, 4.8rem);
  padding-top: var(--spacing-18, 12rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .join-content {
    flex-direction: column;
  }
}
.page-membership-join-2 .join-content__left {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
  min-width: 0;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .join-content__left {
    gap: 0;
  }
}
.page-membership-join-2 .join-content__right {
  width: 56.8rem;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .join-content__right {
    width: 100%;
  }
}
.page-membership-join-2 .info-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 10.9rem;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-membership-join-2 .info-section__title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .info-section__link {
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
  line-height: 1;
  border-bottom: 1px solid #000000;
}
.page-membership-join-2 .info-section__body {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  padding: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .info-section__body {
    padding: var(--spacing-7, 2.4rem);
    padding-left: 0;
    padding-right: 0;
  }
}
.page-membership-join-2 .info-section__options {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  padding: var(--spacing-13, 5.6rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-top: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .info-section__options {
    padding: var(--spacing-9, 3.2rem);
    padding-left: 0;
    padding-right: 0;
    padding-bottom: var(--spacing-18, 12rem);
  }
}
.page-membership-join-2 .info-row {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
}
.page-membership-join-2 .info-row--align-center {
  align-items: center;
}
.page-membership-join-2 .info-row--align-top {
  align-items: flex-start;
}
.page-membership-join-2 .info-row__label {
  width: 9rem;
  flex-shrink: 0;
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-5, 1.6rem);
}
.page-membership-join-2 .info-row__value {
  flex: 1;
  color: #787878;
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-5, 1.6rem);
}
.page-membership-join-2 .info-row__dropdown-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.page-membership-join-2 .info-row__dropdown {
  max-width: 30rem;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .info-row__dropdown {
    max-width: 100%;
  }
}
.page-membership-join-2 .info-row__hint {
  color: #787878;
}
.page-membership-join-2 .quantity-selector {
  display: flex;
  align-items: center;
}
.page-membership-join-2 .quantity-selector__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid #dddddd;
  background-color: #ffffff;
  cursor: pointer;
}
.page-membership-join-2 .quantity-selector__button--minus {
  border-right: none;
}
.page-membership-join-2 .quantity-selector__button--plus {
  border-left: none;
}
.page-membership-join-2 .quantity-selector__icon {
  font-size: 1.6rem;
  line-height: 1;
  color: #000000;
  user-select: none;
}
.page-membership-join-2 .quantity-selector__value {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid #dddddd;
  background-color: #ffffff;
  font-weight: 700;
  color: #000000;
}
.page-membership-join-2 .option-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
  align-items: flex-start;
}
.page-membership-join-2 .option-group__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1, 0.4rem);
  min-width: 0;
}
.page-membership-join-2 .option-group__title {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .option-group__desc {
  color: #787878;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .option-group__btn-wrap {
  padding-top: var(--spacing-5, 1.6rem);
}
.page-membership-join-2 .address-section {
  width: 100%;
  display: flex;
  flex-direction: column;
  padding-left: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .address-section {
    padding-left: 0;
  }
}
.page-membership-join-2 .address-section__title {
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .address-section__radio-group {
  display: flex;
  gap: var(--spacing-11, 4rem);
}
.page-membership-join-2 .address-section__input-group {
  max-width: 56.8rem;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8, 2.8rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .address-section__input-group {
    max-width: 100%;
  }
}
.page-membership-join-2 .address-section__inputs {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
.page-membership-join-2 .address-section__row {
  display: flex;
  gap: var(--spacing-3, 1rem);
}
.page-membership-join-2 .address-section__zip {
  width: 100%;
}
.page-membership-join-2 .address-section__button {
  min-width: auto;
  height: auto;
}
.page-membership-join-2 .input-box {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .input-box {
    flex-direction: column;
  }
}
.page-membership-join-2 .input-box .input-field__recipient-name {
  width: 40%;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .input-box .input-field__recipient-name {
    width: 100%;
  }
}
.page-membership-join-2 .input-box .input-field__recipient-phone {
  flex: 1;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .input-box .input-field__recipient-phone {
    width: 100%;
  }
}
@media (min-width: 1024px) {
  .page-membership-join-2 .payment-box {
    position: sticky;
    top: calc(clamp(9.1rem, 6.6666666667vw, 12.8rem) + 2.4rem);
    border: 1px solid #dddddd;
  }
}
@media (max-width: 1024px) {
  .page-membership-join-2 .payment-box--pc {
    display: none;
  }
}
@media (min-width: 1024px) {
  .page-membership-join-2 .payment-box--mo {
    display: none;
  }
}
.page-membership-join-2 .payment-box__header {
  padding: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .payment-box__header {
    padding-left: 0;
    padding-right: 0;
    border-top: 1px solid #dddddd;
    border-bottom: none;
  }
}
.page-membership-join-2 .payment-box__body {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-13, 5.6rem);
  padding: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-membership-join-2 .payment-box__body {
    padding-left: 0;
    padding-right: 0;
    padding-top: 1.2rem;
    padding-bottom: 0;
  }
}
.page-membership-join-2 .payment-box__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-1, 0.4rem);
}
@media (min-width: 1024px) {
  .page-membership-join-2 .payment-box__total-label {
    font-weight: 800;
  }
}
.page-membership-join-2 .payment-box__total-price {
  color: #FF3B30;
}
.page-membership-join-2 .payment-box__agreement {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-membership-join-2 .payment-box__agreement-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
.page-membership-join-2 .payment-box__agreement-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}
.page-membership-join-2 .payment-box__agreement-link {
  color: #787878;
  text-decoration: underline;
  transition: color 0.2s ease;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-membership-join-2 .payment-box__agreement-link:hover {
    color: #000000;
  }
}
.page-membership-join-2 .join-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-15, 7.2rem);
  margin-top: var(--spacing-13, 5.6rem);
  padding-top: var(--spacing-13, 5.6rem);
  border-top: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-membership-join-2 .join-info {
    margin-top: var(--spacing-16, 8rem);
    padding-top: var(--spacing-13, 5.6rem);
  }
}
.page-membership-join-2 .join-info__section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8, 2.8rem);
}
.page-membership-join-2 .join-info__title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .join-info__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-membership-join-2 .join-info__group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2, 0.8rem);
}
.page-membership-join-2 .join-info__subtitle {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .join-info__list {
  margin: 0;
  padding-left: 3rem;
  list-style-type: disc;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.04em;
}
.page-membership-join-2 .join-info__list li {
  margin-bottom: 0;
}
.page-membership-join-2 .join-info__list li::marker {
  color: #000000;
}
.page-membership-join-2 .terms-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8, 2.8rem);
}
.page-membership-join-2 .terms-content__title {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.04em;
  color: #000000;
}
.page-membership-join-2 .terms-content__text {
  max-height: 40rem;
  overflow-y: auto;
  line-height: 1.4;
  letter-spacing: -0.04em;
  color: #000000;
  padding-right: var(--spacing-4, 1.2rem);
}
.page-membership-join-2 .terms-content__text::-webkit-scrollbar {
  width: 0.4rem;
}
.page-membership-join-2 .terms-content__text::-webkit-scrollbar-track {
  background: #f2f2f2;
}
.page-membership-join-2 .terms-content__text::-webkit-scrollbar-thumb {
  background: #000000;
}
.page-membership-join-2 .terms-content__text p {
  margin-bottom: 0;
}
.page-membership-join-2 .terms-content__text p + p {
  margin-top: 0.4rem;
}
.page-membership-join-2 .terms-content__text p strong {
  display: block;
  margin-top: var(--spacing-6, 2rem);
  font-weight: 700;
}
.page-membership-join-2 [data-radio-hint] {
  display: none;
}
.page-membership-join-2 [data-radio-hint][data-radio-hint-active=true] {
  display: block;
}
.page-membership-join-2 .radio-group {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-11, 4rem);
  row-gap: 1rem;
}

.page-membership-complete {
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-membership-complete {
    padding-bottom: var(--spacing-16, 8rem);
  }
}
.page-membership-complete .complete-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  border: 1px solid #dddddd;
  padding-top: var(--spacing-13, 5.6rem);
  padding-bottom: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-membership-complete .complete-box__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--spacing-7, 2.4rem);
}
.page-membership-complete .complete-box__card {
  display: flex;
  justify-content: center;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-membership-complete .complete-box__card-img {
  width: 16rem;
  height: auto;
  object-fit: contain;
}
.page-membership-complete .complete-box__info-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding-top: var(--spacing-7, 2.4rem);
}
.page-membership-complete .complete-box__info {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 64.8rem;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
}
.page-membership-complete .complete-box__info-row {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
}
.page-membership-complete .complete-box__info-label {
  width: 12rem;
  flex-shrink: 0;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-membership-complete .complete-box__info-label {
    width: 9.4rem;
  }
}
.page-membership-complete .complete-box__info-value {
  flex: 1;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-membership-complete .complete-box__info-value--date {
    display: inline-block;
  }
}
.page-membership-complete .complete-box__buttons {
  display: flex;
  width: 100%;
  gap: var(--spacing-5, 1.6rem);
  padding-top: var(--spacing-5, 1.6rem);
  margin-top: var(--spacing-7, 2.4rem);
}
.page-membership-complete .complete-box__buttons .button {
  flex: 1;
  min-width: 0;
}

.page-about-arch {
  --z-bg: 1;
  --z-image: 10;
  --z-content: 20;
  --z-arrow: 30;
  --z-container: 30;
  --z-headline: 40;
}
.page-about-arch .arch-kv {
  position: relative;
  width: 100%;
  height: 100vh;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv {
    height: 100svh;
  }
}
.page-about-arch .arch-kv .container {
  height: 100%;
}
.page-about-arch .arch-kv__arrow {
  position: absolute;
  right: 0;
  bottom: 6rem;
  width: 5.2rem;
  height: 6.8rem;
  z-index: var(--z-arrow);
  opacity: 0;
  color: #000000;
  animation: arrow-bounce 1.2s ease-in-out infinite;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__arrow {
    bottom: 3.2rem;
    width: 4.8rem;
    height: 3.6rem;
  }
}
.page-about-arch .arch-kv__arrow svg {
  width: 100%;
  height: 100%;
}
@keyframes arrow-bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(15px);
  }
}
.page-about-arch .arch-kv__bg {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: var(--z-bg);
  transition: opacity 0.5s ease;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__bg {
    height: 100svh;
  }
}
.page-about-arch .arch-kv__sequence {
  display: block;
  width: 100%;
  height: 100%;
}
.page-about-arch .arch-kv__intro-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 2;
}
.page-about-arch .arch-kv__intro-video.hidden {
  display: none;
}
@media (max-width: 680px) {
  .page-about-arch .arch-kv__intro-video--desktop {
    display: none;
  }
}
.page-about-arch .arch-kv__intro-video--mobile {
  display: none;
}
@media (max-width: 680px) {
  .page-about-arch .arch-kv__intro-video--mobile {
    display: block;
  }
}
.page-about-arch .arch-kv__scroll-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  z-index: 1;
}
@media (max-width: 680px) {
  .page-about-arch .arch-kv__scroll-video--desktop {
    display: none;
  }
}
.page-about-arch .arch-kv__scroll-video--mobile {
  display: none;
}
@media (max-width: 680px) {
  .page-about-arch .arch-kv__scroll-video--mobile {
    display: block;
  }
}
.page-about-arch .arch-kv__content {
  position: sticky;
  top: 0;
  z-index: var(--z-content);
  height: 100vh;
  margin-top: -100vh;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__content {
    height: 100svh;
    margin-top: -100svh;
  }
}
.page-about-arch .arch-kv__section {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.page-about-arch .arch-kv__section--1 {
  opacity: 0;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__section--1 {
    padding-top: calc(var(--spacing-20) + 7.4rem);
    justify-content: flex-start;
  }
}
@media (max-width: 370px) {
  .page-about-arch .arch-kv__section--1 .arch-kv__headline {
    font-size: 6.8rem;
  }
}
.page-about-arch .arch-kv__section--2 {
  opacity: 0;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__section--2 {
    align-items: end;
  }
}
.page-about-arch .arch-kv__section--3 {
  opacity: 0;
}
.page-about-arch .arch-kv__section--4 {
  opacity: 0;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__section--4 {
    align-items: flex-start;
  }
}
.page-about-arch .arch-kv__section--5 {
  opacity: 0;
  justify-content: flex-start;
  padding-top: calc(var(--spacing-8) + clamp(9.1rem, 6.6666666667vw, 12.8rem));
  color: #ffffff;
}
.page-about-arch .arch-kv__section--5 .arch-kv__arrow--section5 {
  position: absolute;
  right: 0;
  bottom: 6rem;
  opacity: 0;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__section--5 .arch-kv__arrow--section5 {
    bottom: 3.2rem;
  }
}
.page-about-arch .arch-kv__headline {
  word-break: break-word;
}
.page-about-arch .arch-kv__slogan-center {
  text-align: center;
  padding-left: 10%;
}
.page-about-arch .arch-kv__slogan {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-kv__slogan {
    flex-direction: column;
    gap: var(--spacing-2, 0.8rem);
  }
}
.page-about-arch .arch-architect {
  position: relative;
  background-color: #000000;
  height: 100vh;
  height: 100svh;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-architect {
    height: auto;
  }
}
.page-about-arch .arch-architect__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 56.25vw;
  aspect-ratio: 1/1;
  height: 100%;
  z-index: var(--z-image);
  pointer-events: none;
}
.page-about-arch .arch-architect__image picture, .page-about-arch .arch-architect__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-architect__image {
    position: relative;
    width: 100%;
    height: auto;
    aspect-ratio: 380/480;
  }
}
.page-about-arch .arch-architect__image::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 10.3645833333vw;
  height: 100%;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, #000 100%);
}
@media (max-width: 1024px) {
  .page-about-arch .arch-architect__image::after {
    top: auto;
    bottom: 0;
    width: 100%;
    height: 4.8rem;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #000 100%);
  }
}
.page-about-arch .arch-architect .container {
  position: relative;
  z-index: var(--z-container);
  height: 100%;
}
.page-about-arch .arch-architect__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
}
.page-about-arch .arch-architect__headline--desktop {
  display: block;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-architect__headline--desktop {
    display: none;
  }
}
.page-about-arch .arch-architect__headline--tablet {
  display: none;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-architect__headline--tablet {
    display: block;
    position: absolute;
    top: var(--spacing-13);
    left: max(4rem, 3.9062vw);
    z-index: var(--z-headline);
  }
}
@media (max-width: 680px) {
  .page-about-arch .arch-architect__headline--tablet {
    left: max(1.6rem, 4.1025vw);
  }
}
.page-about-arch .arch-design__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-design__grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-15, 7.2rem);
  }
}
.page-about-arch .arch-design__item {
  display: flex;
  flex-direction: column;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-design__item {
    flex-direction: column-reverse;
    gap: var(--spacing-8, 2.8rem);
  }
}
.page-about-arch .arch-design__item + .arch-design__item .arch-design__content {
  border-left: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-design__item + .arch-design__item .arch-design__content {
    border: 0;
  }
}
.page-about-arch .arch-design__content {
  min-height: 20.0520833333vw;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding: var(--spacing-6, 2rem);
}
@media (max-width: 1024px) {
  .page-about-arch .arch-design__content {
    padding: 0;
  }
}
@media (max-width: 1360px) {
  .page-about-arch .arch-design__content .br {
    display: none;
  }
}
.page-about-arch .arch-design__subtitle {
  display: flex;
  align-items: center;
}
.page-about-arch .arch-design__subtitle::before {
  content: "";
  position: relative;
  display: inline-block;
  width: 0.5em;
  height: 0.2rem;
  background-color: #000000;
  margin-right: var(--spacing-1, 0.4rem);
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight .--desktop {
    display: none;
  }
}
.page-about-arch .arch-highlight .--tablet {
  display: none;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight .--tablet {
    display: block;
  }
}
.page-about-arch .arch-highlight__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-17, 10rem);
}
.page-about-arch .arch-highlight__row {
  align-items: center;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight__row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-9, 3.2rem);
  }
}
.page-about-arch .arch-highlight__row:nth-child(1) .arch-highlight__col {
  align-self: stretch;
}
.page-about-arch .arch-highlight__row:nth-child(1) .arch-highlight__col.--left {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
}
.page-about-arch .arch-highlight__row:nth-child(1) .arch-highlight__col.--left .arch-highlight__image {
  width: 18.75vw;
}
.page-about-arch .arch-highlight__row:nth-child(1) .arch-highlight__col.--left.--d .arch-highlight__text {
  margin-top: auto;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight__row:nth-child(1) .arch-highlight__col:nth-child(1) .arch-highlight__image:nth-child(1) {
    width: 44.6927374302%;
  }
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight__row:nth-child(1) .arch-highlight__col:nth-child(1) .arch-highlight__image:nth-child(2) {
    width: 72.625698324%;
    margin-top: 1.6rem;
    margin-left: auto;
  }
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight__row:nth-child(2) .arch-highlight__image {
    width: 89.3854748603%;
  }
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight__row:nth-child(3) {
    flex-direction: column-reverse;
  }
}
.page-about-arch .arch-highlight__row:nth-child(3) .arch-highlight__col.--right {
  padding-left: 2.1875vw;
}
@media (max-width: 1024px) {
  .page-about-arch .arch-highlight__row:nth-child(3) .arch-highlight__image {
    margin-left: auto;
    width: 72.625698324%;
  }
}
.page-about-arch .arch-space {
  overflow: hidden;
  background-color: #000000;
}
.page-about-arch .arch-space__button .button__label {
  font-size: clamp(1.34rem, 0.8333vw, 1.6rem);
  line-height: 1;
}
@media (max-width: 680px) {
  .page-about-arch .arch-space__button .button__label {
    font-size: max(1.34rem, 1.3671vw);
  }
}
.page-about-arch .arch-space__rolling {
  display: flex;
  white-space: nowrap;
  margin-top: var(--spacing-16, 8rem);
}
.page-about-arch .arch-space__rolling-list {
  display: flex;
  flex-shrink: 0;
  white-space: nowrap;
  gap: var(--spacing-12, 4.8rem);
  padding-right: var(--spacing-12, 4.8rem);
  animation: rolling 40s linear infinite;
  transform: translateX(-25%);
}
.page-about-arch .arch-space__rolling-list li {
  flex-shrink: 0;
  width: clamp(24rem, 22.9166666667vw, 44rem);
}
@keyframes rolling {
  0% {
    transform: translateX(-25%);
  }
  100% {
    transform: translateX(-125%);
  }
}

/* ==========================================================================
    About Museum Page Styles
   ========================================================================== */
/* ==========================================================================
    Hero Section
   ========================================================================== */
.museum-hero__image {
  width: 100%;
  aspect-ratio: 1800/675;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .museum-hero__image {
    aspect-ratio: 358/430;
  }
}
.museum-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
  Vision Section
========================================================================== */
@media (max-width: 1024px) {
  .museum-vision {
    padding-top: var(--spacing-21, 16rem);
  }
}
@media (max-width: 1024px) {
  .museum-vision .row {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
}
@media (max-width: 1024px) {
  .museum-vision__header {
    flex-direction: column;
    gap: var(--spacing-16);
  }
}
@media (max-width: 1024px) {
  .museum-vision__title {
    margin-bottom: var(--spacing-16, 8rem);
  }
}
.museum-vision__gallery-item-group {
  display: contents;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item-group {
    display: flex;
    gap: var(--spacing-4, 1.2rem);
  }
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item-group--2 {
    flex-direction: row-reverse;
    padding-top: var(--spacing-4, 1.2rem);
  }
}
.museum-vision__gallery-item {
  overflow: hidden;
}
.museum-vision__gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.museum-vision__gallery-item--1 {
  margin-top: auto;
  margin-bottom: 3.8rem;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--1 {
    margin-bottom: 0;
  }
}
.museum-vision__gallery-item--1 img {
  aspect-ratio: 200/257;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--1 img {
    aspect-ratio: 74/95;
  }
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--2 {
    margin-bottom: 4.3rem;
  }
}
.museum-vision__gallery-item--2 img {
  height: auto;
  aspect-ratio: 568/730;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--2 img {
    aspect-ratio: 193/248;
  }
}
.museum-vision__gallery-item--3 img {
  aspect-ratio: 123/158;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--3 img {
    aspect-ratio: 60/77;
  }
}
.museum-vision__gallery-item--4 {
  margin-top: auto;
  margin-bottom: 15.8rem;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--4 {
    margin-bottom: 7rem;
  }
}
.museum-vision__gallery-item--4 img {
  aspect-ratio: 200/257;
}
@media (max-width: 1024px) {
  .museum-vision__gallery-item--4 img {
    aspect-ratio: 74/95;
  }
}
.museum-vision__gallery-quote {
  margin-top: 34rem;
  display: flex;
  flex-direction: column;
  color: #787878;
  gap: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .museum-vision__gallery-quote {
    margin-top: auto;
    gap: var(--spacing-12, 4.8rem);
  }
}

/* ==========================================================================
   Who We Are Section
   ========================================================================== */
@media (max-width: 1024px) {
  .museum-whoweare {
    padding: var(--spacing-21) 0;
  }
}
@media (max-width: 1024px) {
  .museum-whoweare .row {
    display: flex;
    flex-direction: column-reverse;
    gap: 0;
  }
}
.museum-whoweare__text-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.museum-whoweare__title {
  margin-bottom: 4rem;
}
@media (max-width: 1024px) {
  .museum-whoweare__title {
    margin: var(--spacing-16) 0;
  }
}
.museum-whoweare__image {
  flex-shrink: 0;
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
.museum-whoweare__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
    MI Section (Dark Theme)
   ========================================================================== */
.museum-mi {
  background-color: #000000;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .museum-mi .row {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
}
.museum-mi__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .museum-mi__content {
    padding-bottom: var(--spacing-16);
  }
}
.museum-mi__download-btn {
  width: 20rem;
}
@media (max-width: 1024px) {
  .museum-mi__download-btn {
    width: 16rem;
    min-width: 14rem;
  }
}
.museum-mi__logos {
  display: flex;
  gap: var(--spacing-6);
}
@media (max-width: 1024px) {
  .museum-mi__logos {
    flex-direction: column;
  }
}
.museum-mi__logo-box {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(32rem, 16.6666666667vw);
  border: 1px solid rgba(255, 255, 255, 0.4);
}
@media (max-width: 1024px) {
  .museum-mi__logo-box {
    flex: auto;
    height: 13.1rem;
  }
}
.museum-mi__logo-box .museum-mi__logo-img {
  width: min(32.4rem, 16.875vw);
}
@media (max-width: 1024px) {
  .museum-mi__logo-box .museum-mi__logo-img {
    width: 17.5rem;
  }
}

/* ==========================================================================
   Explore More Section
   ========================================================================== */
@media (max-width: 1024px) {
  .museum-explore {
    padding: var(--spacing-21) 0;
  }
}
@media (max-width: 1024px) {
  .museum-explore__grid {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-6, 2rem);
  }
}
.museum-explore .explore-card {
  display: flex;
  align-items: center;
  border-bottom: 1px solid #000000;
  padding-bottom: var(--spacing-9, 3.2rem);
  gap: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .museum-explore .explore-card {
    flex-direction: column;
    flex: 1;
  }
}
.museum-explore .explore-card__image {
  width: 18.6rem;
  aspect-ratio: 93/61;
  overflow: hidden;
}
.museum-explore .explore-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .museum-explore .explore-card__image {
    width: 100%;
    aspect-ratio: 171/112;
  }
}
.museum-explore .explore-card__content {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
}
.museum-explore .explore-card__title-wrapper {
  display: flex;
  justify-content: space-between;
}
.museum-explore .explore-card__title {
  color: #000000;
  margin: 0;
}
.museum-explore .explore-card__icon {
  opacity: 0;
  transform: translateX(-10px);
  transition: all 0.3s cubic-bezier(1, 0, 0, 1);
}
@media (max-width: 1024px) {
  .museum-explore .explore-card__icon {
    display: none;
  }
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .museum-explore .explore-card:hover .explore-card__icon {
    transform: translateX(0);
    opacity: 1;
  }
}

/* ==========================================================================
    Architecture CTA Section
   ========================================================================== */
.museum-architecture {
  position: relative;
}
@media (max-width: 1024px) {
  .museum-architecture .row {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
}
.museum-architecture__bg {
  position: absolute;
  inset: 0;
}
.museum-architecture__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.museum-architecture__bg-desktop {
  display: block;
}
@media (max-width: 680px) {
  .museum-architecture__bg-desktop {
    display: none;
  }
}
.museum-architecture__bg-mobile {
  display: none;
}
@media (max-width: 680px) {
  .museum-architecture__bg-mobile {
    display: block;
  }
}
.museum-architecture__overlay {
  position: relative;
  z-index: 1;
  height: 100%;
}
.museum-architecture__content {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: var(--spacing-12);
}
.museum-architecture__text {
  color: #ffffff;
  margin-top: 20.8rem;
  margin-bottom: var(--spacing-12);
}
@media (max-width: 1024px) {
  .museum-architecture__text {
    margin-top: 18rem;
  }
}
.museum-architecture__button {
  margin-bottom: 20.8rem;
}
@media (max-width: 1024px) {
  .museum-architecture__button {
    margin-bottom: 17.9rem;
    width: 21rem;
  }
}
.museum-architecture__button .button__label {
  font-size: calc(clamp(1.34rem, 0.8333vw, 1.6rem) * 1.125);
}
@media (max-width: 680px) {
  .museum-architecture__button .button__label {
    font-size: calc(max(1.34rem, 1.3671vw) * 1.125);
  }
}

.page-booking-list {
  padding-top: clamp(9.1rem, 6.6666666667vw, 12.8rem);
  padding-bottom: var(--spacing-21, 16rem);
}
.page-booking-list .exhibition-filter__wrap {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.page-booking-list .exhibition-filter__swiper {
  width: 100%;
  overflow: hidden;
}
.page-booking-list .exhibition-filter__swiper .swiper-wrapper {
  display: flex;
  gap: var(--spacing-7, 2.4rem);
}
.page-booking-list .exhibition-filter__swiper .swiper-slide {
  width: auto;
}
.page-booking-list .exhibition-filter__buttons {
  display: flex;
  gap: var(--spacing-7, 2.4rem);
}
.page-booking-list .exhibition-filter__btn {
  display: flex;
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-booking-list .exhibition-filter__btn.is-active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
.page-booking-list .booking-list-header__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding-top: var(--spacing-11, 4rem);
  border-top: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list-header__wrap--programs {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-5, 1.6rem);
  }
}
.page-booking-list .booking-list-header__count {
  font-weight: 700;
}
.page-booking-list .booking-list-header__count-num {
  color: #FF3B30;
}
.page-booking-list .booking-list__filter {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  width: 100%;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list__filter {
    flex-direction: column;
    align-items: stretch;
  }
}
.page-booking-list .booking-list__filter-dropdowns {
  display: flex;
  flex: 1;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
.page-booking-list .booking-list__filter-dropdowns .custom-dropdown {
  width: 13.5416666667vw;
  min-width: 18rem;
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list__filter-dropdowns .custom-dropdown {
    flex: 1;
    width: auto;
    min-width: 0;
  }
}
.page-booking-list .booking-list .search-bar--exhibition .search-bar__input-group {
  width: 47.8rem;
  height: 6rem;
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list .search-bar--exhibition .search-bar__input-group {
    width: 100%;
    height: auto;
  }
}
.page-booking-list .booking-list .search-bar--exhibition .search-bar__input {
  width: 100%;
}
.page-booking-list .booking-list__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list__items {
    gap: var(--spacing-20, 14rem);
  }
}
.page-booking-list .booking-list__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-17, 10rem);
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list__item {
    flex-direction: column;
    align-items: stretch;
    gap: 3rem;
  }
}
.page-booking-list .booking-list__thumbnail {
  position: relative;
  width: 36.4583333333vw;
  min-height: 30rem;
  max-width: 70rem;
  aspect-ratio: 700/438;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .page-booking-list .booking-list__thumbnail {
    width: 100%;
    max-width: 100%;
    min-height: auto;
  }
}
.page-booking-list .booking-list__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-booking-list .booking-list__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.page-booking-list .booking-list__info {
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 1024px) {
  .page-booking-list .booking-list__title {
    padding-top: var(--spacing-2, 0.8rem);
  }
}
.page-booking-list .booking-list__details {
  display: flex;
  flex-direction: column;
}
.page-booking-list .booking-list__detail-row {
  display: flex;
  align-items: flex-start;
  padding-top: 0.2rem;
  padding-bottom: 0.2rem;
  gap: var(--spacing-5, 1.6rem);
}
@media (min-width: 1024px) {
  .page-booking-list .booking-list__detail-row {
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
  }
}
.page-booking-list .booking-list__detail-label {
  flex-shrink: 0;
  width: 8rem;
  font-weight: 800;
}
@media (max-width: 680px) {
  .page-booking-list .booking-list__detail-label {
    width: 6rem;
  }
}
.page-booking-list .booking-list__detail-value {
  flex: 1;
  font-weight: 400;
}
.page-booking-list .booking-pagination .pagination {
  justify-content: center;
}
.page-booking-list .booking-thumbnail-badges {
  position: absolute;
  top: 1.6rem;
  left: 1.6rem;
  display: flex;
  gap: var(--spacing-3, 1rem);
}
.page-booking-list .booking-thumbnail-badges .booking-thumbnail-badge {
  background-color: #000000;
  color: #ffffff;
  font-weight: 700;
  padding: 0.4rem 1.2rem;
  white-space: nowrap;
}

.page-booking-detail {
  padding-top: clamp(9.1rem, 6.6666666667vw, 12.8rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-booking-detail {
    padding-top: 7.4rem;
  }
}
.page-booking-detail .booking-detail {
  padding-top: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-detail__right {
    order: 1;
  }
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-detail__bottom {
    width: 100%;
    order: 3;
  }
}
.page-booking-detail .booking-info {
  padding-bottom: var(--spacing-17, 10rem);
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-info {
    padding-bottom: var(--spacing-13, 5.6rem);
  }
}
.page-booking-detail .booking-info__image {
  width: 100%;
  aspect-ratio: 568/726;
  background-color: #f2f2f2;
}
.page-booking-detail .booking-info__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-booking-detail .booking-info__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding-top: var(--spacing-9, 3.2rem);
  gap: var(--spacing-7, 2.4rem);
}
.page-booking-detail .booking-info__title {
  padding-bottom: var(--spacing-2, 0.8rem);
}
.page-booking-detail .booking-info__meta {
  display: flex;
  flex-direction: column;
}
.page-booking-detail .booking-info__row {
  display: flex;
  gap: 2.8rem;
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
}
.page-booking-detail .booking-info__row--top {
  align-items: flex-start;
}
.page-booking-detail .booking-info__label {
  width: 8rem;
  flex-shrink: 0;
  font-weight: 780;
}
.page-booking-detail .booking-info__value {
  flex: 1;
  font-weight: 450;
}
.page-booking-detail .booking-info__hours {
  display: flex;
  gap: 1rem;
}
.page-booking-detail .booking-info__hours span:first-child {
  flex-shrink: 0;
}
.page-booking-detail .booking-info-caution {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-13, 5.6rem);
  gap: var(--spacing-15, 7.2rem);
  border-top: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-info-caution {
    border-top: none;
    margin-top: var(--spacing-9, 3.2rem);
  }
}
.page-booking-detail .booking-info-caution__section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-booking-detail .booking-info-caution__title {
  font-weight: 800;
}
.page-booking-detail .booking-info-caution__list {
  list-style: disc;
  padding-left: 3rem;
}
.page-booking-detail .booking-menu {
  border: 1px solid #dddddd;
}
.page-booking-detail .booking-menu__tabs {
  display: flex;
}
.page-booking-detail .booking-menu__tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1.6rem;
  height: 8.2rem;
  background-color: #ffffff;
  border: 1px solid #000000;
  color: #000000;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-menu__tab {
    height: 5.6rem;
  }
}
.page-booking-detail .booking-menu__tab:first-child {
  border-right: none;
}
.page-booking-detail .booking-menu__tab.is-active {
  background-color: #000000;
  color: #ffffff;
}
.page-booking-detail .booking-menu__section {
  display: flex;
  flex-direction: column;
}
.page-booking-detail .booking-menu__section.is-open .booking-menu__button {
  padding-top: var(--spacing-11, 4rem);
}
.page-booking-detail .booking-menu__submit {
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-13, 5.6rem);
  padding-top: var(--spacing-11, 4rem);
  transition: padding-top 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-booking-detail .booking-menu__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 10rem;
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-menu__header {
    height: 7.6rem;
  }
}
.page-booking-detail .booking-menu__toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  background: none;
  border: none;
  cursor: pointer;
}
.page-booking-detail .booking-menu__toggle svg {
  width: 2.4rem;
  height: 2.4rem;
}
@media (max-width: 1024px) {
  .page-booking-detail .booking-menu__toggle svg {
    width: 2rem;
    height: 2rem;
  }
}
.page-booking-detail .booking-menu__content {
  overflow: hidden;
  height: 0;
}
.page-booking-detail .booking-menu__content-inner {
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
}
.page-booking-detail .timeslot-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-5, 1.6rem);
}
.page-booking-detail .timeslot-grid .button {
  min-width: auto;
}
.page-booking-detail .visitor-options {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--spacing-11, 4rem);
}
.page-booking-detail .visitor-options__list {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-booking-detail .visitor-option {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--spacing-8, 2.8rem);
}
.page-booking-detail .visitor-option__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding-top: 0.3rem;
}
@media (max-width: 1024px) {
  .page-booking-detail .visitor-option__info {
    gap: 0.2rem;
  }
}
.page-booking-detail .visitor-option__header {
  display: flex;
  justify-content: space-between;
  font-weight: 680;
}
.page-booking-detail .visitor-option__desc {
  color: #787878;
  font-weight: 450;
}
.page-booking-detail .booking-summary {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
}
.page-booking-detail .booking-summary__visitors {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
}
.page-booking-detail .booking-summary__visitors-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
}
.page-booking-detail .booking-summary__visitor-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: #000000;
}
.page-booking-detail .booking-summary__visitor-type {
  flex-shrink: 0;
}
.page-booking-detail .booking-summary__visitor-count {
  flex-shrink: 0;
}
.page-booking-detail .booking-summary__total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  gap: 0.4rem;
}
.page-booking-detail .booking-summary__total-label {
  flex: 1;
  color: #000000;
}
.page-booking-detail .booking-summary__total-value {
  flex-shrink: 0;
  color: #FF3B30;
}
.page-booking-detail .quantity-selector {
  display: flex;
  align-items: center;
}
.page-booking-detail .quantity-selector__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid #dddddd;
  background-color: #ffffff;
  cursor: pointer;
}
.page-booking-detail .quantity-selector__button--minus {
  border-right: none;
}
.page-booking-detail .quantity-selector__button--plus {
  border-left: none;
}
.page-booking-detail .quantity-selector__icon {
  font-size: 1.6rem;
  line-height: 1;
  color: #000000;
  user-select: none;
}
.page-booking-detail .quantity-selector__value {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid #dddddd;
  background-color: #ffffff;
  font-weight: 700;
  color: #000000;
}
.page-booking-detail .calendar_wrap {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8, 2.8rem);
  padding: 2.8645833333vw 5.4166666667vw;
}
@media (max-width: 680px) {
  .page-booking-detail .calendar_wrap {
    padding: 3.2rem 1.6rem;
    gap: 1.8rem;
  }
}
.page-booking-detail .calendar_top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-booking-detail .calendar_nav-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 9.8958333333vw;
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_nav-wrapper {
    gap: 9.765625vw;
  }
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_nav-wrapper {
    gap: 10rem;
  }
}
.page-booking-detail .calendar_nav {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  background: none;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s ease;
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_nav {
    width: 1.8rem;
    height: 1.8rem;
  }
}
.page-booking-detail .calendar_nav:hover {
  opacity: 0.7;
}
.page-booking-detail .calendar_nav:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.page-booking-detail .calendar_nav svg {
  width: 3rem;
  height: 3rem;
  color: #FF3B30;
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_nav svg {
    width: 1.8rem;
    height: 1.8rem;
  }
}
.page-booking-detail .calendar_month {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 6rem;
}
.page-booking-detail .calendar_month-text {
  font-weight: 800;
}
.page-booking-detail .calendar_year {
  font-weight: 400;
}
.page-booking-detail .calendar_cont {
  padding-bottom: var(--spacing-3, 1rem);
}
.page-booking-detail .calendar_cont table {
  width: 100%;
  border-collapse: collapse;
}
.page-booking-detail .calendar_cont thead th {
  padding: 1.2rem 0;
  text-align: center;
  font-weight: 800;
  color: rgba(120, 120, 120, 0.5);
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_cont thead th {
    padding: 0.8rem 0;
  }
}
.page-booking-detail .calendar_cont tbody tr td {
  text-align: center;
  vertical-align: middle;
  height: 3.125vw;
  padding: 0.625vw 0;
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_cont tbody tr td {
    height: 4.8rem;
    padding: 0.6rem 0;
  }
}
.page-booking-detail .calendar_cont tbody tr td a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6rem;
  height: 6rem;
  margin: 0 auto;
  text-decoration: none;
  color: #000000;
  font-weight: 700;
  border-radius: 50%;
  transition: all 0.2s ease;
}
@media (max-width: 1024px) {
  .page-booking-detail .calendar_cont tbody tr td a {
    width: 3.6rem;
    height: 3.6rem;
  }
}
.page-booking-detail .calendar_cont tbody tr td.pick_day a {
  background-color: #FF3B30;
  color: #ffffff;
}
.page-booking-detail .calendar_cont tbody tr td.past_day a {
  color: #c6c6c6;
  pointer-events: none;
  cursor: default;
}
.page-booking-detail .calendar_cont tbody tr td.closed_day a {
  color: #c6c6c6;
  pointer-events: none;
  cursor: default;
}
.page-booking-detail .calendar_cont tbody tr td.select_day a {
  cursor: pointer;
}
.page-booking-detail .booking-thumbnail-badges {
  display: flex;
  gap: var(--spacing-3, 1rem);
}
.page-booking-detail .booking-thumbnail-badges .booking-thumbnail-badge {
  background-color: #000000;
  color: #ffffff;
  font-weight: 700;
  padding: 0.4rem 1.2rem;
  white-space: nowrap;
}
.page-booking-detail .booking-checkbox-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
.page-booking-detail .booking-checkbox-group .booking-checkbox-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}

.page-booking-reservation {
  padding-top: clamp(9.1rem, 6.6666666667vw, 12.8rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-booking-reservation {
    padding-top: 7.4rem;
  }
}
.page-booking-reservation .booking-reservation {
  padding-top: var(--spacing-16, 8rem);
}
.page-booking-reservation .booking-reservation__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-booking-reservation .reservation-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
  background-color: #ffffff;
}
.page-booking-reservation .reservation-section__header--with-button {
  gap: 1rem;
}
.page-booking-reservation .reservation-section__edit-button {
  padding: 1rem 0;
  border-bottom: 1px solid #000000;
}
.page-booking-reservation .reservation-section__edit-button span {
  line-height: 1;
  font-weight: 700;
}
.page-booking-reservation .reservation-section__body {
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  background-color: #ffffff;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-section__body {
    padding-left: var(--spacing-0, 0rem);
    padding-right: var(--spacing-0, 0rem);
  }
}
.page-booking-reservation .reservation-info {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.page-booking-reservation .reservation-info__row {
  display: flex;
  gap: 1.6rem;
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__row {
    gap: 1.2rem;
  }
}
.page-booking-reservation .reservation-info__label {
  flex-shrink: 0;
  width: 9rem;
  padding: 1.2rem 0;
  font-weight: 700;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__label {
    width: 8.8rem;
    padding: 0.8rem 0;
  }
}
.page-booking-reservation .reservation-info__value {
  flex: 1;
  padding: 1.2rem 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__value {
    padding: 0.8rem 0;
  }
}
.page-booking-reservation .reservation-info__event {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding-bottom: 0.9rem;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__event {
    padding-bottom: 0.8rem;
  }
}
.page-booking-reservation .reservation-info__event-title {
  padding: 0.9rem 0;
  font-weight: 800;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__event-title {
    padding: 0.7rem 0;
  }
}
.page-booking-reservation .reservation-info__event-date, .page-booking-reservation .reservation-info__event-venue {
  padding: 0.2rem 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__event-date, .page-booking-reservation .reservation-info__event-venue {
    padding: 0.1rem 0;
  }
}
.page-booking-reservation .reservation-info__visitors {
  flex: 1;
}
.page-booking-reservation .reservation-info__visitor-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 0;
  gap: 1rem;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__visitor-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.4rem;
    padding: 0.8rem 0;
  }
}
.page-booking-reservation .reservation-info__visitor-type {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: #787878;
}
.page-booking-reservation .reservation-info__visitor-divider {
  font-size: 0.8rem;
  color: #787878;
}
.page-booking-reservation .reservation-info__visitor-price {
  text-align: right;
  color: #000000;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-info__visitor-price {
    text-align: left;
  }
}
.page-booking-reservation .reservation-notice {
  border-top: 1px solid #dddddd;
  padding-top: var(--spacing-7, 2.4rem);
  margin-top: var(--spacing-7, 2.4rem);
}
.page-booking-reservation .reservation-notice__list {
  list-style: disc;
  padding-left: 2.4rem;
  color: #787878;
}
.page-booking-reservation .reservation-additional__desc {
  margin-bottom: var(--spacing-11, 4rem);
}
.page-booking-reservation .reservation-additional__participants {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
.page-booking-reservation .reservation-additional__consent {
  display: flex;
  align-items: center;
  gap: 1.6rem;
  margin-top: var(--spacing-11, 4rem);
  padding-top: var(--spacing-9, 3.2rem);
  border-top: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-booking-reservation .reservation-additional__consent {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.8rem;
  }
}
.page-booking-reservation .reservation-additional__terms-link {
  color: #787878;
  text-decoration: underline;
  text-underline-offset: 0.3rem;
  transition: color 0.2s ease-out;
}
.page-booking-reservation .reservation-additional__terms-link:hover {
  color: #000000;
}
.page-booking-reservation .participant-info {
  display: flex;
  flex-direction: column;
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
.page-booking-reservation .participant-info:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.page-booking-reservation .participant-info__title {
  padding: 1.4rem 0;
  font-weight: 700;
}
.page-booking-reservation .participant-info__fields {
  display: flex;
  gap: var(--spacing-10, 3.6rem);
}
@media (max-width: 1024px) {
  .page-booking-reservation .participant-info__fields {
    flex-direction: column;
    gap: var(--spacing-7, 2.4rem);
  }
}
.page-booking-reservation .participant-info__field {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
.page-booking-reservation .participant-info__label {
  flex-shrink: 0;
  font-weight: 700;
  min-width: 9rem;
}
@media (max-width: 1024px) {
  .page-booking-reservation .participant-info__label {
    min-width: 8rem;
  }
}
.page-booking-reservation .participant-info__radio-group {
  display: flex;
  gap: var(--spacing-9, 3.2rem);
}
.page-booking-reservation .payment-summary {
  border: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-booking-reservation .payment-summary {
    border: none;
    border-top: 1px solid #dddddd;
  }
}
.page-booking-reservation .payment-summary__header {
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-booking-reservation .payment-summary__header {
    padding-left: 0;
    padding-right: 0;
    border-bottom: none;
  }
}
.page-booking-reservation .payment-summary__body {
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
@media (max-width: 1024px) {
  .page-booking-reservation .payment-summary__body {
    padding-left: 0;
    padding-right: 0;
    padding-top: 0;
  }
}
.page-booking-reservation .payment-summary__prices {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  margin-bottom: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-booking-reservation .payment-summary__price-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.2rem;
}
.page-booking-reservation .payment-summary__price-label {
  flex: 1;
  font-weight: 700;
}
.page-booking-reservation .payment-summary__price-value {
  font-weight: 700;
}
.page-booking-reservation .payment-summary__total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.4rem;
  padding-bottom: var(--spacing-13, 5.6rem);
}
@media (max-width: 1024px) {
  .page-booking-reservation .payment-summary__total {
    padding-bottom: var(--spacing-9, 3.2rem);
  }
}
.page-booking-reservation .payment-summary__total-label {
  flex: 1;
  font-weight: 800;
}
.page-booking-reservation .payment-summary__total-value {
  font-weight: 800;
  color: #FF3B30;
}
.page-booking-reservation .payment-summary__notices {
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-11, 4rem);
}
@media (max-width: 1024px) {
  .page-booking-reservation .payment-summary__notices {
    padding-left: 0;
    padding-right: 0;
  }
}
.page-booking-reservation .payment-summary__notice {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
  padding-top: var(--spacing-11, 4rem);
  border-top: 1px solid #000000;
}
.page-booking-reservation .payment-summary__notice:first-child {
  border-top: 1px solid #000000;
}
.page-booking-reservation .payment-summary__notice:not(:first-child) {
  border-top: none;
}
@media (max-width: 1024px) {
  .page-booking-reservation .payment-summary__notice {
    border: none;
    border-top: 1px solid #dddddd;
  }
}
.page-booking-reservation .payment-summary__notice-title {
  font-weight: 800;
}
.page-booking-reservation .payment-summary__notice-list {
  list-style: disc;
  padding-left: 3rem;
}
.page-booking-reservation .payment-summary__notice-list li {
  margin-bottom: 0;
}

.page-booking-complete {
  padding-top: clamp(9.1rem, 6.6666666667vw, 12.8rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-booking-complete {
    padding-top: 7.4rem;
  }
}
.page-booking-complete .booking-complete {
  padding-top: var(--spacing-11, 4rem);
}
.page-booking-complete .booking-complete__header {
  padding-top: var(--spacing-17, 10rem);
  padding-bottom: var(--spacing-16, 8rem);
  text-align: center;
}
@media (max-width: 1024px) {
  .page-booking-complete .booking-complete__header {
    padding-top: var(--spacing-14, 6.4rem);
    padding-bottom: var(--spacing-12, 4.8rem);
  }
}
.page-booking-complete .booking-complete__card {
  border: 1px solid #dddddd;
  background-color: #ffffff;
  padding-bottom: var(--spacing-7, 2.4rem);
}
.page-booking-complete .booking-complete__notices {
  border-top: 1px solid #000000;
  padding-top: var(--spacing-13, 5.6rem);
  margin-top: var(--spacing-16, 8rem);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-15, 7.2rem);
}
@media (max-width: 1024px) {
  .page-booking-complete .booking-complete__notices {
    padding-top: var(--spacing-11, 4rem);
    gap: var(--spacing-12, 4.8rem);
  }
}
.page-booking-complete .complete-card__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
  text-align: center;
  gap: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-card__header {
    padding-left: var(--spacing-5, 1.6rem);
    padding-right: var(--spacing-5, 1.6rem);
  }
}
.page-booking-complete .complete-card__notice {
  color: #787878;
}
.page-booking-complete .complete-card__image {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  background-color: #ffffff;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-card__image {
    padding-top: var(--spacing-9, 3.2rem);
    padding-bottom: var(--spacing-9, 3.2rem);
  }
}
.page-booking-complete .complete-card__image img {
  max-width: 100%;
  height: auto;
  max-height: 32.6rem;
  object-fit: contain;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-card__image img {
    max-height: 20rem;
  }
}
.page-booking-complete .complete-card__section {
  width: 100%;
}
.page-booking-complete .complete-card__section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
.page-booking-complete .complete-card__print-button {
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid #000000;
  cursor: pointer;
}
.page-booking-complete .complete-card__section-body {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  background-color: #ffffff;
}
.page-booking-complete .complete-card__buttons {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
  padding-top: var(--spacing-5, 1.6rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-booking-complete .complete-card__buttons .button {
  flex: 1;
  min-width: auto;
}
.page-booking-complete .complete-info {
  display: flex;
  flex-direction: column;
}
.page-booking-complete .complete-info__row {
  display: flex;
  gap: 1.6rem;
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-info__row {
    gap: 1.2rem;
  }
}
.page-booking-complete .complete-info__label {
  flex-shrink: 0;
  width: 9rem;
  display: flex;
  align-items: center;
  padding: 1.2rem 0;
  font-weight: 700;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-info__label {
    width: 8.8rem;
    padding: 0.8rem 0;
  }
}
.page-booking-complete .complete-info__value {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 1.2rem 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-info__value {
    padding: 0.8rem 0;
  }
}
.page-booking-complete .complete-info__event {
  flex: 1;
  flex-direction: column;
  padding: 0.4rem 0 0.9rem;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-info__event {
    padding-bottom: 0.8rem;
  }
}
.page-booking-complete .complete-info__event-title {
  padding: 0.9rem 0;
  font-weight: 800;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-info__event-title {
    padding: 0.7rem 0;
  }
}
.page-booking-complete .complete-info__event-date, .page-booking-complete .complete-info__event-venue {
  padding: 0.2rem 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-info__event-date, .page-booking-complete .complete-info__event-venue {
    padding: 0.1rem 0;
  }
}
.page-booking-complete .complete-notice {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-notice {
    gap: var(--spacing-5, 1.6rem);
  }
}
.page-booking-complete .complete-notice__title {
  color: #000000;
}
.page-booking-complete .complete-notice__list {
  list-style: disc;
  padding-left: 3rem;
  margin: 0;
  color: #000000;
}
@media (max-width: 1024px) {
  .page-booking-complete .complete-notice__list {
    padding-left: 2.4rem;
  }
}
.page-booking-complete .complete-notice__list li {
  margin-bottom: 0;
}
.page-booking-complete .complete-notice__list li:not(:last-child) {
  margin-bottom: 0.2rem;
}

.page-qrcode {
  background-color: #ffffff;
}
.page-qrcode .qrcode-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 6.8rem);
  min-height: calc(100svh - 6.8rem);
}
.page-qrcode .qrcode-header {
  position: sticky;
  top: 0;
  display: flex;
  align-items: center;
  height: 6.8rem;
  text-align: center;
  background-color: #ffffff;
  z-index: 999;
}
.page-qrcode .qrcode-code {
  display: flex;
  justify-content: center;
}
.page-qrcode .qrcode-swiper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-5, 1.6rem);
}
.page-qrcode .qrcode-swiper__container {
  max-width: 29.4rem;
  overflow: hidden;
}
.page-qrcode .qrcode-swiper__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.6rem;
  height: 2.2rem;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
}
.page-qrcode .qrcode-swiper__nav svg {
  width: 100%;
  height: 100%;
}
.page-qrcode .qrcode-swiper__nav.swiper-button-disabled {
  color: #c6c6c6;
  cursor: not-allowed;
}
.page-qrcode .qrcode-ticket {
  border: 1.5px solid #000000;
  background-color: #ffffff;
}
.page-qrcode .qrcode-ticket__notice {
  background-color: #000000;
  padding-top: var(--spacing-2, 0.8rem);
  padding-bottom: var(--spacing-2, 0.8rem);
  text-align: center;
}
.page-qrcode .qrcode-ticket__notice p {
  color: #ffffff;
}
.page-qrcode .qrcode-ticket__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: var(--spacing-9, 3.2rem);
  gap: var(--spacing-9, 3.2rem);
}
.page-qrcode .qrcode-ticket__qr {
  width: 14rem;
  height: 14rem;
}
.page-qrcode .qrcode-ticket__qr img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.page-qrcode .qrcode-ticket__qr--inactive {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-3, 1rem);
  padding: var(--spacing-5, 1.6rem);
  background-color: #f5f5f5;
  text-align: center;
}
.page-qrcode .qrcode-ticket__qr--inactive p {
  color: #787878;
}
.page-qrcode .qrcode-ticket__timer {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #000000;
}
.page-qrcode .qrcode-ticket__timer .qrcode-ticket__countdown {
  font-weight: 800;
}
.page-qrcode .qrcode-ticket__info {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  padding-left: var(--spacing-7, 2.4rem);
  padding-right: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-8, 2.8rem);
  border-bottom: 2px solid #000000;
  width: calc(100% - 4.8rem);
  text-align: center;
}
.page-qrcode .qrcode-ticket__info > p {
  font-weight: 800;
}
.page-qrcode .qrcode-ticket__details {
  padding-top: var(--spacing-8, 2.8rem);
  padding-left: var(--spacing-7, 2.4rem);
  padding-right: var(--spacing-7, 2.4rem);
  text-align: center;
}
.page-qrcode .qrcode-ticket__title {
  padding-bottom: var(--spacing-6, 2rem);
  font-weight: 700;
}
.page-qrcode .qrcode-ticket__reservation {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-3, 1rem);
}
.page-qrcode .qrcode-ticket__reservation-num {
  color: #787878;
}
.page-qrcode .qrcode-ticket__action {
  display: flex;
  align-items: center;
  padding-left: var(--spacing-7, 2.4rem);
  padding-right: var(--spacing-7, 2.4rem);
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-6, 2rem);
  gap: 1rem;
}
.page-qrcode .qrcode-ticket__action .button {
  flex: 1;
  min-width: auto;
}
.page-qrcode .qrcode-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-1, 0.4rem);
}

.page-guest-reservation {
  padding-top: clamp(9.1rem, 6.6666666667vw, 12.8rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-guest-reservation {
    padding-top: 7.4rem;
  }
}

.guest-reservation__header {
  padding-top: var(--spacing-17, 10rem);
  padding-bottom: var(--spacing-16, 8rem);
  text-align: center;
}
.guest-reservation__header-desc {
  line-height: 1.75;
}
.guest-reservation__section + .guest-reservation__section {
  margin-top: var(--spacing-12, 4.8rem);
}
.guest-reservation__section--form {
  margin-top: var(--spacing-12, 4.8rem);
}
.guest-reservation__section-header {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
}
.guest-reservation__section-header--border {
  border-bottom: 2px solid #000000;
}
.guest-reservation__agreement-box {
  background-color: #f5f5f5;
  padding-left: var(--spacing-4, 1.2rem);
  padding-right: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
}
.guest-reservation__agreement-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-0, 0rem);
  list-style-type: none;
  padding-left: 2rem;
  line-height: 1.4;
}
.guest-reservation__agreement-list li {
  position: relative;
}
.guest-reservation__agreement-list li::before {
  content: "";
  position: absolute;
  left: -1.2rem;
  top: 1rem;
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background-color: #000000;
}
.guest-reservation__agreement-options {
  display: flex;
  gap: var(--spacing-11, 4rem);
  padding-top: var(--spacing-6, 2rem);
}
@media (max-width: 680px) {
  .guest-reservation__agreement-options {
    gap: var(--spacing-7, 2.4rem);
  }
}
.guest-reservation__form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-13, 5.6rem);
}
.guest-reservation__form-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.guest-reservation__form-group:has(.input-field) {
  gap: var(--spacing-4, 1.2rem);
}
.guest-reservation__form-group > .input-field__label {
  margin-bottom: 0;
}
.guest-reservation__form-hint {
  color: #787878;
}
.guest-reservation__form-label-wrap {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
}
.guest-reservation__form-required {
  color: #FF3B30;
}
.guest-reservation__form-radios {
  display: flex;
  gap: var(--spacing-11, 4rem);
}
@media (max-width: 680px) {
  .guest-reservation__form-radios {
    gap: var(--spacing-7, 2.4rem);
  }
}
.guest-reservation__auth-fields {
  display: none;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.guest-reservation__auth-fields.is-active {
  display: flex;
}
.guest-reservation__email-row {
  display: flex;
  gap: var(--spacing-3, 1rem);
  align-items: stretch;
}
.guest-reservation__email-input {
  flex: 1;
}
.guest-reservation__email-button {
  flex-shrink: 0;
  min-width: 12rem;
  height: auto;
}
.guest-reservation__verify-input {
  display: flex;
  align-items: center;
  width: 18.6rem;
  border: 0.15rem solid #dddddd;
  padding-left: var(--spacing-5, 1.6rem);
  padding-right: var(--spacing-5, 1.6rem);
  padding-top: 1.4rem;
  padding-bottom: 1.4rem;
  background-color: #ffffff;
}
@media (max-width: 680px) {
  .guest-reservation__verify-input {
    padding-top: 1.2rem;
    padding-bottom: 1.2rem;
  }
}
.guest-reservation__verify-input input {
  flex: 1;
  min-width: 0;
  border: none;
  outline: none;
  background: transparent;
  padding: 0;
}
.guest-reservation__verify-input input::placeholder {
  color: #dddddd;
}
.guest-reservation__verify-timer {
  color: #FF3B30;
  margin-left: var(--spacing-2, 0.8rem);
  margin-right: var(--spacing-2, 0.8rem);
  white-space: nowrap;
}
.guest-reservation__verify-confirm {
  color: #787878;
  background: transparent;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  padding: 0;
}
.guest-reservation__submit {
  display: flex;
  justify-content: center;
  margin-top: var(--spacing-13, 5.6rem);
}
.guest-reservation__submit .button {
  min-width: 20rem;
}

.page-guest-reservation-list {
  padding-top: clamp(9.1rem, 6.6666666667vw, 12.8rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-guest-reservation-list {
    padding-top: 7.4rem;
  }
}

.guest-reservation-list__header {
  padding-top: var(--spacing-17, 10rem);
  padding-bottom: var(--spacing-16, 8rem);
  text-align: center;
}
@media (max-width: 1024px) {
  .guest-reservation-list__header {
    padding-top: var(--spacing-14, 6.4rem);
    padding-bottom: var(--spacing-12, 4.8rem);
  }
}
.guest-reservation-list__tabs {
  padding-bottom: var(--spacing-16, 8rem);
}
.guest-reservation-list__tab-buttons {
  display: flex;
  width: 100%;
}
.guest-reservation-list__tab-button {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border: 1px solid #000000;
  background-color: #ffffff;
  cursor: pointer;
  transition: background-color 0.2s, color 0.2s;
}
.guest-reservation-list__tab-button--active {
  background-color: #000000;
}
.guest-reservation-list__tab-button--active span {
  color: #ffffff;
}
.guest-reservation-list__content.is-hidden {
  display: none;
}
.guest-reservation-list__date-group + .guest-reservation-list__date-group {
  margin-top: var(--spacing-16, 8rem);
}
.guest-reservation-list__date {
  margin-bottom: var(--spacing-7, 2.4rem);
}
.guest-reservation-list__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.guest-reservation-list__reservation-no {
  display: flex;
  align-items: center;
  gap: var(--spacing-4, 1.2rem);
  padding-left: var(--spacing-7, 2.4rem);
  padding-right: var(--spacing-7, 2.4rem);
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  background-color: #f5f5f5;
  margin-bottom: var(--spacing-5, 1.6rem);
}
.guest-reservation-list__pagination {
  padding-top: var(--spacing-20, 14rem);
  display: flex;
  justify-content: center;
}

[class^=page-member] .login-util {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
[class^=page-member] .login-util__right {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing-5) * 2);
}
[class^=page-member] .login-util__right .login-button:first-child {
  position: relative;
}
[class^=page-member] .login-util__right .login-button:first-child::after {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(-1 * var(--spacing-5));
  transform: translateY(-50%);
  width: 1px;
  height: 1.3rem;
  background-color: #000000;
}
[class^=page-member] .login-cta__signup {
  display: flex;
  gap: var(--spacing-4);
}
[class^=page-member] .login-cta__signup .button {
  min-width: auto;
  flex: 1;
}
[class^=page-member] .login-sns {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-5, 1.6rem);
  flex-wrap: wrap;
}
[class^=page-member] .login-sns__buttons {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
  flex: 1;
  max-width: 36.8rem;
}
@media (max-width: 1360px) {
  [class^=page-member] .login-sns__buttons {
    max-width: auto;
    width: 100%;
  }
}
[class^=page-member] .login-sns__button {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 8rem;
  min-width: 6rem;
  aspect-ratio: 1/1;
  flex: 1;
}
@media (max-width: 1360px) {
  [class^=page-member] .login-sns__button {
    width: auto;
    height: auto;
    flex: 1;
  }
}
[class^=page-member] .login-sns__button img {
  width: 4rem;
  height: 4rem;
}
[class^=page-member] .login-sns__button--kakao {
  background-color: #ffdf00;
}
[class^=page-member] .login-sns__button--naver {
  background-color: #21b500;
}
[class^=page-member] .login-sns__button--apple {
  background-color: #000000;
}
[class^=page-member] .login-sns__button--google {
  background-color: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.1);
}
[class^=page-member] .find-box {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
[class^=page-member] .input-field-box {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
[class^=page-member] .member-title {
  border-bottom: 2px solid #000000;
}
[class^=page-member] .member-buttons {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
}
[class^=page-member] .member-buttons .button {
  flex: 1;
  min-width: auto;
}
[class^=page-member] .terms-agree__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
[class^=page-member] .terms-agree__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-2, 0.8rem);
}
[class^=page-member] .terms-agree__link {
  color: #787878;
  text-decoration: underline;
  text-underline-offset: 3px;
}
[class^=page-member] .login-guest-reservation__divider {
  position: relative;
  text-align: center;
  margin: 0;
}
[class^=page-member] .login-guest-reservation__divider::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 1px;
  background-color: #dddddd;
}
[class^=page-member] .login-guest-reservation__divider-text {
  position: relative;
  display: inline-block;
  background-color: #ffffff;
  padding-left: var(--spacing-4, 1.2rem);
  padding-right: var(--spacing-4, 1.2rem);
  color: #787878;
}
[class^=page-member] .login-guest-reservation__button {
  width: 100%;
}
[class^=page-member] .login-guest-reservation__notice {
  text-align: center;
  color: #787878;
}

.page-member-join__form {
  display: flex;
  flex-direction: column;
}
.page-member-join__fields {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-11, 4rem);
}
.page-member-join__field {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
.page-member-join__field--with-btn .input-field {
  flex: 1;
  min-width: 0;
}
.page-member-join__action-button {
  flex-shrink: 0;
  min-width: 0;
}
.page-member-join__email-group {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
.page-member-join__email-input {
  flex: 1;
  min-width: 0;
}
.page-member-join__email-at {
  flex-shrink: 0;
  padding-bottom: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-member-join__email-at {
    padding-bottom: var(--spacing-3, 1rem);
  }
}
.page-member-join__email-domain {
  flex: 1;
  min-width: 0;
}
.page-member-join__domain-dropdown button {
  justify-content: space-between;
}
.page-member-join__minor-group {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
}
.page-member-join__minor-field {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-4, 1.2rem);
}
.page-member-join__minor-label {
  display: flex;
  align-items: center;
  color: #000000;
}
.page-member-join__required-mark {
  color: red;
  margin-left: 0.2rem;
}
.page-member-join__minor-dropdown {
  width: 100%;
}
.page-member-join__minor-dropdown .custom-dropdown__trigger {
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  padding-left: 0;
  padding-right: 0;
}
.page-member-join__minor-dropdown .custom-dropdown__icon {
  width: 4rem;
  height: 2.8rem;
}
.page-member-join__consent-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}

.mypage-lnb {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  width: 20rem;
}
@media (max-width: 1024px) {
  .mypage-lnb--desktop {
    display: none;
  }
}
.mypage-lnb__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-12, 4.8rem);
}
.mypage-lnb__item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.mypage-lnb__submenu {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.mypage-lnb__submenu-item {
  width: 100%;
}
.mypage-lnb__submenu-link {
  display: flex;
  align-items: center;
  color: #787878;
  transition: color 0.2s ease;
  gap: var(--spacing-1, 0.4rem);
}
.mypage-lnb__submenu-link:hover {
  color: #000000;
}
.mypage-lnb__submenu-link.is-active {
  color: #000000;
}
.mypage-lnb__submenu-link--arrow .mypage-lnb__arrow {
  flex-shrink: 0;
  width: 1.4rem;
  height: 1.8rem;
}
.mypage-lnb__submenu-link--arrow .mypage-lnb__arrow svg {
  width: 100%;
  height: 100%;
}
.mypage-lnb--desktop .mypage-lnb__arrow {
  display: none;
}
.mypage-lnb--desktop .mypage-lnb__submenu-link--arrow .mypage-lnb__arrow {
  display: block;
}

.mypage-lnb-dropdown {
  display: none;
}
@media (max-width: 1024px) {
  .mypage-lnb-dropdown {
    display: flex;
    flex-direction: column;
    width: 100%;
    background-color: #ffffff;
  }
  .mypage-lnb-dropdown.is-open {
    position: fixed;
    top: 7.4rem;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 998;
    overflow-y: auto;
    padding: 0 max(1.6rem, 4.1025vw);
  }
}
.mypage-lnb-dropdown__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #000000;
  background: transparent;
  cursor: pointer;
}
.mypage-lnb-dropdown.is-open .mypage-lnb-dropdown__header {
  position: sticky;
  top: 0;
  background-color: #ffffff;
  z-index: 1;
}
.mypage-lnb-dropdown__icon {
  width: 2.8rem;
  height: 2.8rem;
  color: #000000;
  transition: transform 0.3s ease;
  transform: rotate(180deg);
}
.mypage-lnb-dropdown.is-open .mypage-lnb-dropdown__icon {
  transform: rotate(0deg);
}
.mypage-lnb-dropdown__content {
  display: none;
}
.mypage-lnb-dropdown.is-open .mypage-lnb-dropdown__content {
  display: block;
}
.mypage-lnb-dropdown__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-12, 4.8rem);
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-20, 14rem);
}
.mypage-lnb-dropdown__item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.mypage-lnb-dropdown__submenu {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
  padding-left: var(--spacing-4, 1.2rem);
}
.mypage-lnb-dropdown__submenu-item {
  width: 100%;
}
.mypage-lnb-dropdown__submenu-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  color: #787878;
  transition: color 0.2s ease;
}
.mypage-lnb-dropdown__submenu-link:hover {
  color: #000000;
}
.mypage-lnb-dropdown__submenu-link.is-active {
  color: #000000;
}
.mypage-lnb-dropdown__arrow {
  flex-shrink: 0;
  width: 1.8rem;
  height: 1.8rem;
}
.mypage-lnb-dropdown__arrow svg {
  width: 100%;
  height: 100%;
}

.page-mypage-tickets-list {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-tickets-list__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-16, 8rem);
}
.page-mypage-tickets-list__date-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-tickets-list__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}

.page-mypage-programs-list {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-programs-list__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-16, 8rem);
}
.page-mypage-programs-list__date-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-programs-list__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}

.page-mypage-programs-cancel {
  padding-bottom: var(--spacing-21, 16rem);
}
.page-mypage-programs-cancel__content {
  margin-top: var(--spacing-16, 8rem);
  border: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__content {
    margin-top: var(--spacing-0, 0rem);
  }
}
.page-mypage-programs-cancel__header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
  text-align: center;
}
.page-mypage-programs-cancel__image {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 32.6rem;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-programs-cancel__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.page-mypage-programs-cancel__section {
  width: 100%;
}
.page-mypage-programs-cancel__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-9, 3.2rem);
  gap: var(--spacing-3, 1rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__section-header {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-programs-cancel__print-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid #000000;
  cursor: pointer;
}
.page-mypage-programs-cancel__section-body {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-mypage-programs-cancel__button-wrapper {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
  padding-top: var(--spacing-5, 1.6rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__button-wrapper {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-programs-cancel__cancel-button, .page-mypage-programs-cancel__qr-button {
  flex: 1;
  min-width: 0;
}
.page-mypage-programs-cancel__info {
  display: flex;
  flex-direction: column;
}
.page-mypage-programs-cancel__info-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__info-row {
    align-items: flex-start;
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-programs-cancel__info-row--program {
  align-items: flex-start;
}
.page-mypage-programs-cancel__info-row--program .page-mypage-programs-cancel__info-value {
  color: #000000;
}
.page-mypage-programs-cancel__info-label {
  flex-shrink: 0;
  width: 9rem;
  height: 5.6rem;
  display: flex;
  align-items: center;
  font-size: 1.8rem;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__info-label {
    width: 8.8rem;
    height: auto;
    padding: var(--spacing-3) 0;
  }
}
.page-mypage-programs-cancel__info-value-wrap {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding-bottom: var(--spacing-3, 1rem);
  padding-top: 0.4rem;
}
.page-mypage-programs-cancel__info-value {
  flex: 1;
  padding: var(--spacing-4) 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__info-value {
    padding: var(--spacing-3) 0;
  }
}
.page-mypage-programs-cancel__info-value-wrap .page-mypage-programs-cancel__info-value {
  padding: 0.9rem 0;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__info-value-wrap .page-mypage-programs-cancel__info-value {
    padding: 0.7rem 0;
  }
}
.page-mypage-programs-cancel__info-sub {
  color: #787878;
  padding: var(--spacing-1) 0;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__info-sub {
    padding: 0;
  }
}
.page-mypage-programs-cancel__guide-content {
  border-top: 1px solid #000000;
  margin-top: var(--spacing-15, 7.2rem);
  padding-top: var(--spacing-13, 5.6rem);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-15, 7.2rem);
}
.page-mypage-programs-cancel__guide-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-mypage-programs-cancel__guide-list {
  list-style-type: disc;
  padding-left: 2.2rem;
}
@media (max-width: 1024px) {
  .page-mypage-programs-cancel__guide-list {
    padding-left: 2rem;
  }
}

.page-mypage-programs-detail {
  padding-bottom: var(--spacing-21, 16rem);
}
.page-mypage-programs-detail__content {
  margin-top: var(--spacing-16, 8rem);
  border: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__content {
    margin-top: var(--spacing-0, 0rem);
  }
}
.page-mypage-programs-detail__header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
  text-align: center;
}
.page-mypage-programs-detail__image {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 32.6rem;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-programs-detail__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.page-mypage-programs-detail__section {
  width: 100%;
}
.page-mypage-programs-detail__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-9, 3.2rem);
  gap: var(--spacing-3, 1rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__section-header {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-programs-detail__print-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid #000000;
  cursor: pointer;
}
.page-mypage-programs-detail__section-body {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-mypage-programs-detail__button-wrapper {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
  padding-top: var(--spacing-5, 1.6rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__button-wrapper {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-programs-detail__cancel-button, .page-mypage-programs-detail__qr-button {
  flex: 1;
  min-width: 0;
}
.page-mypage-programs-detail__info {
  display: flex;
  flex-direction: column;
}
.page-mypage-programs-detail__info-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__info-row {
    align-items: flex-start;
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-programs-detail__info-row--program {
  align-items: flex-start;
}
.page-mypage-programs-detail__info-row--program .page-mypage-programs-detail__info-value {
  color: #000000;
}
.page-mypage-programs-detail__info-label {
  flex-shrink: 0;
  width: 9rem;
  height: 5.6rem;
  display: flex;
  align-items: center;
  font-size: 1.8rem;
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__info-label {
    width: 8.8rem;
    height: auto;
    padding: var(--spacing-3) 0;
  }
}
.page-mypage-programs-detail__info-value-wrap {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding-bottom: var(--spacing-3, 1rem);
  padding-top: 0.4rem;
}
.page-mypage-programs-detail__info-value {
  flex: 1;
  padding: var(--spacing-4) 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__info-value {
    padding: var(--spacing-3) 0;
  }
}
.page-mypage-programs-detail__info-value-wrap .page-mypage-programs-detail__info-value {
  padding: 0.9rem 0;
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__info-value-wrap .page-mypage-programs-detail__info-value {
    padding: 0.7rem 0;
  }
}
.page-mypage-programs-detail__info-sub {
  color: #787878;
  padding: var(--spacing-1) 0;
}
.page-mypage-programs-detail__guide-content {
  border-top: 1px solid #000000;
  margin-top: var(--spacing-15, 7.2rem);
  padding-top: var(--spacing-13, 5.6rem);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-15, 7.2rem);
}
.page-mypage-programs-detail__guide-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-mypage-programs-detail__guide-list {
  list-style-type: disc;
  padding-left: 2.2rem;
}
@media (max-width: 1024px) {
  .page-mypage-programs-detail__guide-list {
    padding-left: 2rem;
  }
}
.page-mypage-programs-detail__program-detail-button {
  width: 20rem;
}

.page-mypage-shop-order-detail {
  position: relative;
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-shop-order-detail .order-detail__page-title {
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-15, 7.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__page-title {
    padding-top: var(--spacing-12, 4.8rem);
    padding-bottom: var(--spacing-11, 4rem);
  }
}
.page-mypage-shop-order-detail .order-detail__section-title-group {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-2, 0.8rem);
}
.page-mypage-shop-order-detail .order-detail__section-count {
  color: #000000;
}
.page-mypage-shop-order-detail .order-detail__text-btn {
  position: relative;
  color: #000000;
  background: none;
  border: none;
  cursor: pointer;
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
}
.page-mypage-shop-order-detail .order-detail__text-btn::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #000000;
}
.page-mypage-shop-order-detail .order-detail__section-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: var(--spacing-6, 2rem);
}
.page-mypage-shop-order-detail .order-detail__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-mypage-shop-order-detail .order-detail__product-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-shop-order-detail .order-detail__product-date {
  color: #000000;
}
.page-mypage-shop-order-detail .order-detail__payment-details {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-top: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__payment-details {
    padding-left: 0;
    padding-right: 0;
  }
}
.page-mypage-shop-order-detail .order-detail__payment-row {
  display: flex;
  justify-content: space-between;
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
}
.page-mypage-shop-order-detail .order-detail__payment-label {
  color: #000000;
}
.page-mypage-shop-order-detail .order-detail__payment-value {
  color: #787878;
  text-align: right;
}
.page-mypage-shop-order-detail .order-detail__payment-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-9, 3.2rem);
  border-top: 2px solid #000000;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__payment-total {
    padding-left: var(--spacing-0, 0rem);
    padding-right: var(--spacing-0, 0rem);
  }
}
.page-mypage-shop-order-detail .order-detail__payment-total-label {
  color: #000000;
}
.page-mypage-shop-order-detail .order-detail__payment-total-value {
  color: #FF3B30;
  text-align: right;
}
.page-mypage-shop-order-detail .reservation-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
  background-color: #ffffff;
}
.page-mypage-shop-order-detail .reservation-section__header--with-button {
  gap: 1rem;
}
.page-mypage-shop-order-detail .reservation-section__header-title {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-mypage-shop-order-detail .reservation-section__edit-button {
  padding: 1rem 0;
  border-bottom: 1px solid #000000;
}
.page-mypage-shop-order-detail .reservation-section__edit-button span {
  line-height: 1;
  font-weight: 700;
}
.page-mypage-shop-order-detail .reservation-section__body {
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  background-color: #ffffff;
}
.page-mypage-shop-order-detail .reservation-section__body + .reservation-section__body {
  border-top: 1px solid #000000;
}
.page-mypage-shop-order-detail .reservation-section__body--dropdown {
  padding-left: var(--spacing-0, 0rem);
  padding-right: var(--spacing-0, 0rem);
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-section__body {
    padding-left: var(--spacing-0, 0rem);
    padding-right: var(--spacing-0, 0rem);
  }
}
.page-mypage-shop-order-detail .reservation-section__sub-header {
  margin-bottom: var(--spacing-7, 2.4rem);
}
.page-mypage-shop-order-detail .reservation-info {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.page-mypage-shop-order-detail .reservation-info__row {
  display: flex;
  gap: 1.6rem;
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__row {
    gap: 1.2rem;
  }
}
.page-mypage-shop-order-detail .reservation-info__row--align-between {
  justify-content: space-between;
}
.page-mypage-shop-order-detail .reservation-info__row--align-between .reservation-info__label {
  width: auto;
}
.page-mypage-shop-order-detail .reservation-info__row--align-between .reservation-info__value {
  flex: 0;
}
.page-mypage-shop-order-detail .reservation-info__label {
  flex-shrink: 0;
  width: 9rem;
  padding: 1.2rem 0;
  font-weight: 700;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__label {
    width: 8.8rem;
    padding: 0.8rem 0;
  }
}
.page-mypage-shop-order-detail .reservation-info__value {
  flex: 1;
  padding: 1.2rem 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__value {
    padding: 0.8rem 0;
  }
}
.page-mypage-shop-order-detail .reservation-info__event {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding-bottom: 0.9rem;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__event {
    padding-bottom: 0.8rem;
  }
}
.page-mypage-shop-order-detail .reservation-info__event-title {
  padding: 0.9rem 0;
  font-weight: 800;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__event-title {
    padding: 0.7rem 0;
  }
}
.page-mypage-shop-order-detail .reservation-info__event-date, .page-mypage-shop-order-detail .reservation-info__event-venue {
  padding: 0.2rem 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__event-date, .page-mypage-shop-order-detail .reservation-info__event-venue {
    padding: 0.1rem 0;
  }
}
.page-mypage-shop-order-detail .reservation-info__visitors {
  flex: 1;
}
.page-mypage-shop-order-detail .reservation-info__visitor-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 0;
  gap: 1rem;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__visitor-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.4rem;
    padding: 0.8rem 0;
  }
}
.page-mypage-shop-order-detail .reservation-info__visitor-type {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: #787878;
}
.page-mypage-shop-order-detail .reservation-info__visitor-divider {
  font-size: 0.8rem;
  color: #787878;
}
.page-mypage-shop-order-detail .reservation-info__visitor-price {
  text-align: right;
  color: #000000;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .reservation-info__visitor-price {
    text-align: left;
  }
}
.page-mypage-shop-order-detail .order-detail__cancel-summary {
  display: flex;
  width: 100%;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__cancel-summary {
    flex-direction: column;
  }
}
.page-mypage-shop-order-detail .order-detail__cancel-summary-left,
.page-mypage-shop-order-detail .order-detail__cancel-summary-right {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.page-mypage-shop-order-detail .order-detail__cancel-summary-left .reservation-section__body,
.page-mypage-shop-order-detail .order-detail__cancel-summary-right .reservation-section__body {
  flex: 1;
  border-top: 1px solid #000000;
}
.page-mypage-shop-order-detail .order-detail__cancel-summary-left .order-detail__payment-total,
.page-mypage-shop-order-detail .order-detail__cancel-summary-right .order-detail__payment-total {
  border-top: 2px solid #000000;
}
.page-mypage-shop-order-detail .order-detail__cancel-summary-left .reservation-section__body {
  border-right: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__cancel-summary-left .reservation-section__body {
    border-right: none;
  }
}
.page-mypage-shop-order-detail .order-detail__cancel-summary-left .order-detail__payment-total {
  border-right: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__cancel-summary-left .order-detail__payment-total {
    border-right: none;
  }
}
.page-mypage-shop-order-detail .order-detail__button-wrapper {
  display: flex;
  justify-content: center;
}
.page-mypage-shop-order-detail .order-detail__pickup-method {
  display: flex;
  gap: var(--spacing-7, 2.4rem);
  align-items: center;
}
@media (max-width: 1024px) {
  .page-mypage-shop-order-detail .order-detail__pickup-method {
    gap: var(--spacing-5, 1.6rem);
  }
}
.page-mypage-shop-order-detail .order-detail__policy-link {
  display: block;
  text-decoration: underline;
  text-underline-offset: 0.2rem;
  margin-top: var(--spacing-1, 0.4rem);
}
.page-mypage-shop-order-detail .reservation-section__body--no-border {
  border-bottom: none;
}
.page-mypage-shop-order-detail [data-radio-hint] {
  display: none;
}
.page-mypage-shop-order-detail [data-radio-hint][data-radio-hint-active=true] {
  display: block;
}

.page-mypage-info-profile {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-info-profile__info-list {
  display: flex;
  flex-direction: column;
}
.page-mypage-info-profile__info-item {
  padding: var(--spacing-7) 0;
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-info-profile__info-item:first-child {
    padding-top: 0;
  }
}
.page-mypage-info-profile__row {
  display: flex;
  gap: var(--spacing-12, 4.8rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-info-profile__row {
    gap: var(--spacing-9, 3.2rem);
  }
}
.page-mypage-info-profile__row-item {
  flex: 1;
  min-width: 0;
}
.page-mypage-info-profile__sns-section {
  padding-top: var(--spacing-11, 4rem);
}
.page-mypage-info-profile__sns-content {
  display: flex;
  gap: var(--spacing-17, 10rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-profile__sns-content {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-9, 3.2rem);
  }
}
.page-mypage-info-profile__sns-list {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-info-profile__sns-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-mypage-info-profile__sns-icon {
  width: 8rem;
  height: 8rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-mypage-info-profile__sns-icon img {
  width: 4rem;
  height: 4rem;
}
.page-mypage-info-profile__sns-icon--kakao {
  background-color: #FFDF00;
}
.page-mypage-info-profile__sns-icon--naver {
  background-color: #21B500;
}
.page-mypage-info-profile__sns-icon--apple {
  background-color: #000000;
}
.page-mypage-info-profile__sns-icon--google {
  background-color: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.page-mypage-info-profile__buttons {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
  margin-top: var(--spacing-16, 8rem);
}
.page-mypage-info-profile__button {
  flex: 1;
  min-width: 0;
}

.page-mypage-info-edit {
  padding-bottom: var(--spacing-20, 14rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-edit .mypage-lnb-dropdown {
    display: none;
  }
}
.page-mypage-info-edit__mobile-header {
  display: none;
}
@media (max-width: 1024px) {
  .page-mypage-info-edit__mobile-header {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: var(--spacing-8, 2.8rem);
    margin-bottom: var(--spacing-8, 2.8rem);
  }
}
.page-mypage-info-edit__back-button {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 2.4rem;
  height: 2.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000000;
}
.page-mypage-info-edit__back-button svg {
  width: 100%;
  height: 100%;
}
.page-mypage-info-edit__mobile-title {
  text-align: center;
}
.page-mypage-info-edit__form {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-edit__form {
    padding-top: var(--spacing-0, 0rem);
  }
}
.page-mypage-info-edit__field {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-info-edit__email-input {
  flex: 1;
}
.page-mypage-info-edit__email-group {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
.page-mypage-info-edit__email-at {
  flex-shrink: 0;
  padding-bottom: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-edit__email-at {
    padding-bottom: var(--spacing-3, 1rem);
  }
}
.page-mypage-info-edit__email-domain {
  flex: 1;
  min-width: 0;
}
.page-mypage-info-edit__domain-dropdown button {
  justify-content: space-between;
}
.page-mypage-info-edit__address-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-info-edit__address-group .page-mypage-info-edit__field {
  padding-bottom: var(--spacing-0, 0rem);
}
.page-mypage-info-edit__address-group .page-mypage-info-edit__field:last-child {
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-info-edit__action-button {
  flex-shrink: 0;
  min-width: 0;
}
.page-mypage-info-edit__minor-group {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-info-edit__minor-field {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-4, 1.2rem);
}
.page-mypage-info-edit__minor-label {
  display: flex;
  align-items: center;
  color: #000000;
}
.page-mypage-info-edit__required-mark {
  color: red;
  margin-left: 0.2rem;
}
.page-mypage-info-edit__minor-dropdown {
  width: 100%;
}
.page-mypage-info-edit__minor-dropdown .custom-dropdown__trigger {
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  padding-left: 0;
  padding-right: 0;
}
.page-mypage-info-edit__minor-dropdown .custom-dropdown__icon {
  width: 4rem;
  height: 2.8rem;
}
.page-mypage-info-edit__consent-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-info-edit__buttons {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
  margin-top: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-edit__buttons {
    margin-top: var(--spacing-11, 4rem);
  }
}
.page-mypage-info-edit__submit-button, .page-mypage-info-edit__cancel-button {
  flex: 1;
  min-width: 0;
}

.page-mypage-info-withdraw {
  padding-bottom: var(--spacing-20, 14rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw .mypage-lnb-dropdown {
    display: none;
  }
}
.page-mypage-info-withdraw .input-field__textarea::placeholder {
  color: #787878;
}
.page-mypage-info-withdraw__mobile-header {
  display: none;
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw__mobile-header {
    display: flex;
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: var(--spacing-8, 2.8rem);
    margin-bottom: var(--spacing-8, 2.8rem);
  }
}
.page-mypage-info-withdraw__back-button {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 2.4rem;
  height: 2.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000000;
}
.page-mypage-info-withdraw__back-button svg {
  width: 100%;
  height: 100%;
}
.page-mypage-info-withdraw__mobile-title {
  text-align: center;
}
.page-mypage-info-withdraw__form {
  display: flex;
  flex-direction: column;
}
.page-mypage-info-withdraw__header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw__header {
    display: none;
  }
}
.page-mypage-info-withdraw__notice-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-info-withdraw__notice-box {
  background-color: #f2f2f2;
  padding: var(--spacing-9, 3.2rem);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw__notice-box {
    padding: var(--spacing-6, 2rem);
  }
}
.page-mypage-info-withdraw__notice-list {
  list-style-type: disc;
  padding-left: 2.2rem;
}
.page-mypage-info-withdraw__notice-retention {
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  color: #787878;
  list-style: none;
}
.page-mypage-info-withdraw__notice-retention li::before {
  content: "-";
  margin-right: 0.4rem;
}
.page-mypage-info-withdraw__divider {
  width: 100%;
  height: 1px;
  background-color: #dddddd;
}
.page-mypage-info-withdraw__reason-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-info-withdraw__reason-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-info-withdraw__reason-other {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-info-withdraw__reason-textarea {
  margin-left: 3.2rem;
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw__reason-textarea {
    margin-left: 0;
  }
}
.page-mypage-info-withdraw__buttons {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
  margin-top: var(--spacing-16, 8rem);
}
.page-mypage-info-withdraw__submit-button, .page-mypage-info-withdraw__cancel-button {
  flex: 1;
  min-width: 0;
}

.page-mypage-info-withdraw-complete__content {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  width: fit-content;
  margin: 0 auto;
}
.page-mypage-info-withdraw-complete__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw-complete__header {
    gap: var(--spacing-5, 1.6rem);
  }
}
.page-mypage-info-withdraw-complete__icon-box {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #000000;
  padding: var(--spacing-4, 1.2rem);
}
.page-mypage-info-withdraw-complete__icon {
  display: block;
  width: 4.8rem;
  height: 4.8rem;
  color: #000000;
}
.page-mypage-info-withdraw-complete__icon svg {
  width: 100%;
  height: 100%;
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw-complete__icon {
    width: 3.2rem;
    height: 3.2rem;
  }
}
.page-mypage-info-withdraw-complete__message {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
  text-align: center;
}
.page-mypage-info-withdraw-complete__description {
  color: #787878;
}
.page-mypage-info-withdraw-complete__buttons {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw-complete__buttons {
    width: 100%;
  }
}
@media (max-width: 1024px) {
  .page-mypage-info-withdraw-complete__button {
    flex: 1;
    min-width: 0;
  }
}

.page-mypage-info-coupons {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-info-coupons__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-bottom: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__header {
    display: none;
  }
}
.page-mypage-info-coupons__shop-link {
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
  border-bottom: 1px solid #000000;
}
.page-mypage-info-coupons__shop-link-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__shop-link-mobile {
    display: flex;
    justify-content: flex-end;
    padding-top: var(--spacing-4, 1.2rem);
  }
  .page-mypage-info-coupons__shop-link-mobile a {
    padding-top: var(--spacing-4, 1.2rem);
    padding-bottom: var(--spacing-4, 1.2rem);
    border-bottom: 1px solid #000000;
  }
}
.page-mypage-info-coupons__content {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-12, 4.8rem);
}
.page-mypage-info-coupons__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-info-coupons__list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.page-mypage-info-coupons__list-header--used {
  justify-content: flex-start;
}
.page-mypage-info-coupons__count {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
}
.page-mypage-info-coupons__coupon-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-info-coupons__coupon-item {
  display: flex;
  background-color: #f2f2f2;
  border: 1px solid #000000;
  cursor: pointer;
}
.page-mypage-info-coupons__coupon-bar {
  width: 1rem;
  background-color: #000000;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__coupon-bar {
    width: 0.8rem;
  }
}
.page-mypage-info-coupons__coupon-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-right: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__coupon-content {
    padding: var(--spacing-6, 2rem);
  }
}
.page-mypage-info-coupons__coupon-name {
  padding-top: var(--spacing-5, 1.6rem);
  padding-bottom: var(--spacing-2, 0.8rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__coupon-name {
    padding-top: var(--spacing-2, 0.8rem);
  }
}
.page-mypage-info-coupons__coupon-info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-2, 0.8rem);
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__coupon-info {
    gap: var(--spacing-1, 0.4rem);
  }
}
.page-mypage-info-coupons__coupon-condition {
  color: #787878;
}
.page-mypage-info-coupons__coupon-divider {
  width: 1px;
  height: 1.3rem;
  background-color: #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-info-coupons__coupon-divider {
    margin-left: 0.4rem;
  }
}

.page-mypage-membership-profile {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-membership-profile__status-container {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
.page-mypage-membership-profile__status-title {
  display: flex;
  align-items: center;
}
.page-mypage-membership-profile__more-button {
  width: 26rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-profile__more-button {
    width: 21rem;
  }
}

.page-mypage-membership-join {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-membership-join__header {
  display: flex;
  flex-direction: column;
}
.page-mypage-membership-join__divider {
  width: 100%;
  height: 2px;
  background-color: #000000;
}
.page-mypage-membership-join__status-title {
  display: flex;
  align-items: center;
}
.page-mypage-membership-join__card-container {
  display: flex;
  align-items: stretch;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__card-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-9, 3.2rem);
  }
}
.page-mypage-membership-join__card-wrapper {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  width: 36rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__card-wrapper {
    width: 100%;
    padding: var(--spacing-12) 5.2rem;
  }
}
.page-mypage-membership-join__card-button {
  min-width: 0;
}
.page-mypage-membership-join__details {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--spacing-9, 3.2rem);
  padding-left: var(--spacing-16, 8rem);
  padding-right: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__details {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
    gap: var(--spacing-7, 2.4rem);
    padding-top: var(--spacing-9, 3.2rem);
    padding-bottom: var(--spacing-9, 3.2rem);
    padding-left: var(--spacing-9, 3.2rem);
    padding-right: var(--spacing-9, 3.2rem);
    background-color: #ffffff;
  }
}
.page-mypage-membership-join__buttons {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
}
.page-mypage-membership-join__button {
  flex: 1;
  min-width: 0;
}
.page-mypage-membership-join__application {
  display: flex;
  flex-direction: column;
}
.page-mypage-membership-join__application-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--spacing-6, 2rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__application-header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
}
.page-mypage-membership-join__list-header {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 6.4rem;
  border-bottom: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-header {
    display: none;
  }
}
.page-mypage-membership-join__list-header-item {
  width: 16rem;
  flex-shrink: 0;
  text-align: center;
}
.page-mypage-membership-join__list-header-item--info {
  flex: 1;
  width: auto;
}
.page-mypage-membership-join__list-item {
  display: flex;
  align-items: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-item {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--spacing-9, 3.2rem);
  }
}
.page-mypage-membership-join__list-item-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-9, 3.2rem);
  flex: 1;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-item-info {
    flex: 0 0 auto;
    gap: var(--spacing-9, 3.2rem);
  }
}
.page-mypage-membership-join__list-item-thumb {
  width: 13.2rem;
  height: 13.2rem;
  flex-shrink: 0;
  background-color: #f5f5f5;
  padding: 1.8rem var(--spacing-8);
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-item-thumb {
    width: 8rem;
    height: 8rem;
    padding: 1.1rem 1.7rem;
  }
}
.page-mypage-membership-join__list-item-text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1, 0.4rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-item-text {
    gap: var(--spacing-2, 0.8rem);
  }
}
.page-mypage-membership-join__list-item-cell {
  width: 16rem;
  flex-shrink: 0;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-item-cell {
    display: none;
  }
}
.page-mypage-membership-join__list-item-meta {
  display: none;
}
@media (max-width: 1024px) {
  .page-mypage-membership-join__list-item-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-3, 1rem);
    margin-top: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-membership-join__list-item-meta-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}
.page-mypage-membership-join__list-item-meta-divider {
  width: 1px;
  height: 1.3rem;
  background-color: #000000;
}
.page-mypage-membership-join__status--cancel {
  color: #FF0000;
}
.page-mypage-membership-join__info-box {
  background-color: #f5f5f5;
  padding: var(--spacing-11) var(--spacing-12);
}
.page-mypage-membership-join__info-text {
  white-space: nowrap;
}
.page-mypage-membership-join .info-mypage {
  padding-top: 0;
}

.page-mypage-membership-orders-list {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-membership-orders-list__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-16, 8rem);
}
.page-mypage-membership-orders-list__list--inquiry {
  gap: var(--spacing-6, 2rem);
}
.page-mypage-membership-orders-list__date-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-membership-orders-list__date-group--inquiry {
  gap: 0;
}
.page-mypage-membership-orders-list__date-title--underline {
  border-bottom: 2px solid #000000;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
}
.page-mypage-membership-orders-list__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-mypage-membership-orders-list__items--inquiry {
  gap: 0;
}
.page-mypage-membership-orders-list__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-14, 6.4rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-0, 0rem);
  }
}
.page-mypage-membership-orders-list__item-details {
  display: flex;
  align-items: center;
  gap: var(--spacing-9, 3.2rem);
  flex: 1;
  min-width: 0;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-details {
    width: 100%;
  }
}
.page-mypage-membership-orders-list__item-image {
  flex-shrink: 0;
}
.page-mypage-membership-orders-list__item-thumb {
  width: 26rem;
  height: 19.3rem;
  background-color: #f5f5f5;
  padding: 3rem 7.8rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-thumb {
    width: 13rem;
    height: 19.3rem;
    padding: 4.9rem 2.7rem;
  }
}
.page-mypage-membership-orders-list__item-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
  flex: 1;
  min-width: 0;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-info {
    gap: var(--spacing-0, 0rem);
  }
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-name {
    padding-bottom: var(--spacing-3);
  }
}
.page-mypage-membership-orders-list__item-name--cancel {
  padding: var(--spacing-3) 0;
}
.page-mypage-membership-orders-list__item-info-rows {
  display: flex;
  flex-direction: column;
}
.page-mypage-membership-orders-list__item-info-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-mypage-membership-orders-list__item-info-divider {
  width: 1px;
  height: 1.3rem;
  background-color: #000000;
}
.page-mypage-membership-orders-list__item-price {
  width: 16rem;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-price {
    display: none;
  }
}
.page-mypage-membership-orders-list__item-action {
  width: 12rem;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-action {
    display: none;
  }
}
.page-mypage-membership-orders-list__detail-button {
  min-width: 12rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__detail-button {
    width: 100%;
    min-width: 0;
  }
}
.page-mypage-membership-orders-list__item-mobile-price-info {
  display: none;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-mobile-price-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1, 0.4rem);
    margin-top: var(--spacing-6, 2rem);
  }
}
.page-mypage-membership-orders-list__item-mobile-price-info-amount--cancel {
  color: #FF0000;
}
.page-mypage-membership-orders-list__item-mobile-price-info-note {
  color: #000000;
}
.page-mypage-membership-orders-list__item-mobile-action {
  display: none;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-mobile-action {
    display: block;
    width: 100%;
    padding-top: var(--spacing-5, 1.6rem);
  }
}
.page-mypage-membership-orders-list__item-mobile-bottom {
  display: none;
}
.page-mypage-membership-orders-list__item-mobile-price {
  font-weight: 500;
}
.page-mypage-membership-orders-list__item-mobile-price--cancel {
  color: #FF0000;
}
.page-mypage-membership-orders-list__item-mobile-price-area {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1, 0.4rem);
}
.page-mypage-membership-orders-list__item-status {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
}
.page-mypage-membership-orders-list__item-status-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-1, 0.4rem);
  padding-bottom: var(--spacing-1, 0.4rem);
  padding-left: var(--spacing-2, 0.8rem);
  padding-right: var(--spacing-2, 0.8rem);
  border: 1px solid #000000;
}
.page-mypage-membership-orders-list__item-status-label--cancel {
  border-color: #FF0000;
  color: #FF0000;
}
.page-mypage-membership-orders-list__item-price--cancel {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1, 0.4rem);
  align-items: center;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-price--cancel {
    display: none;
  }
}
.page-mypage-membership-orders-list__item-price--cancel .page-mypage-membership-orders-list__item-price-amount {
  color: #FF0000;
}
.page-mypage-membership-orders-list__item-price-note {
  color: #000000;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-list__item-price-note {
    text-align: left;
  }
}

.page-mypage-membership-gift {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-mypage-membership-gift__container {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
.page-mypage-membership-gift__form-container {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5, 1.6rem);
}
.page-mypage-membership-gift__input-row {
  display: flex;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-gift__input-row {
    flex-direction: column;
    gap: var(--spacing-6, 2rem);
  }
}
.page-mypage-membership-gift__input {
  flex: 1;
  min-width: 0;
}
.page-mypage-membership-gift__submit-button {
  min-width: 26rem;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-mypage-membership-gift__submit-button {
    width: 100%;
    min-width: 0;
  }
}
.page-mypage-membership-gift__info-list {
  list-style-type: disc;
  padding-left: 2.2rem;
  color: #787878;
}

.page-mypage-membership-orders-detail {
  padding-bottom: var(--spacing-21, 16rem);
}
.page-mypage-membership-orders-detail__content {
  margin-top: var(--spacing-16, 8rem);
  border: 1px solid #dddddd;
}
.page-mypage-membership-orders-detail__header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
  text-align: center;
}
.page-mypage-membership-orders-detail__image {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-membership-orders-detail__image .membership-card {
  width: 25.6rem;
  height: 32.6rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-detail__image .membership-card {
    width: 25.4rem;
    height: 32.4rem;
  }
}
.page-mypage-membership-orders-detail__section {
  width: 100%;
}
.page-mypage-membership-orders-detail__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-9, 3.2rem);
  gap: var(--spacing-3, 1rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-detail__section-header {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-membership-orders-detail__receipt-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid #000000;
  cursor: pointer;
}
.page-mypage-membership-orders-detail__section-body {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-mypage-membership-orders-detail__button-wrapper {
  display: flex;
  justify-content: center;
  padding-top: var(--spacing-5, 1.6rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-7, 2.4rem);
}
.page-mypage-membership-orders-detail__cancel-button {
  min-width: 26rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-detail__cancel-button {
    min-width: 21rem;
  }
}
.page-mypage-membership-orders-detail__info {
  display: flex;
  flex-direction: column;
}
.page-mypage-membership-orders-detail__info-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-detail__info-row {
    align-items: flex-start;
  }
}
.page-mypage-membership-orders-detail__info-row--program .page-mypage-membership-orders-detail__info-value {
  color: #000000;
  font-weight: 800;
  padding: var(--spacing-3) 0;
}
.page-mypage-membership-orders-detail__info-label {
  flex-shrink: 0;
  width: 12.4rem;
  font-weight: 700;
  font-size: 1.8rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-detail__info-label {
    width: 9.4rem;
    padding: var(--spacing-4) 0;
  }
}
.page-mypage-membership-orders-detail__info-value {
  flex: 1;
  padding: var(--spacing-4) 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-detail__info-value {
    padding: var(--spacing-3) 0;
  }
}

.page-mypage-membership-return-pickup {
  padding-bottom: var(--spacing-21, 16rem);
}
.page-mypage-membership-return-pickup__content {
  margin-top: var(--spacing-16, 8rem);
  border: 1px solid #dddddd;
}
.page-mypage-membership-return-pickup__header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__header {
    padding-left: var(--spacing-7, 2.4rem);
    padding-right: var(--spacing-7, 2.4rem);
  }
}
.page-mypage-membership-return-pickup__image {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-membership-return-pickup__image .membership-card {
  width: 25.6rem;
  height: 32.6rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__image .membership-card {
    width: 25.4rem;
    height: 32.4rem;
  }
}
.page-mypage-membership-return-pickup__section {
  width: 100%;
}
.page-mypage-membership-return-pickup__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-9, 3.2rem);
  gap: var(--spacing-3, 1rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__section-header {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-membership-return-pickup__receipt-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid #000000;
  cursor: pointer;
}
.page-mypage-membership-return-pickup__section-body {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__section-body {
    padding-left: var(--spacing-9, 3.2rem);
    padding-right: var(--spacing-9, 3.2rem);
  }
}
.page-mypage-membership-return-pickup__info {
  display: flex;
  flex-direction: column;
}
.page-mypage-membership-return-pickup__info-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__info-row {
    align-items: flex-start;
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-membership-return-pickup__info-row--program .page-mypage-membership-return-pickup__info-value {
  color: #000000;
  font-weight: 800;
  padding: var(--spacing-3) 0;
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__info-row--program .page-mypage-membership-return-pickup__info-value {
    padding: var(--spacing-2) 0;
  }
}
.page-mypage-membership-return-pickup__info-label {
  flex-shrink: 0;
  width: 12.4rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__info-label {
    width: 9.4rem;
    padding: var(--spacing-4) 0;
  }
}
.page-mypage-membership-return-pickup__info-value {
  flex: 1;
  padding: var(--spacing-4) 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-membership-return-pickup__info-value {
    padding: var(--spacing-3) 0;
  }
}
.page-mypage-membership-return-pickup__info-value--refund {
  color: #FF0000;
}

.page-mypage-membership-orders-cancel {
  padding-bottom: var(--spacing-21, 16rem);
}
.page-mypage-membership-orders-cancel__content {
  margin-top: var(--spacing-16, 8rem);
  border: 1px solid #dddddd;
}
.page-mypage-membership-orders-cancel__header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
  text-align: center;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__header {
    padding-left: var(--spacing-7, 2.4rem);
    padding-right: var(--spacing-7, 2.4rem);
  }
}
.page-mypage-membership-orders-cancel__image {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
}
.page-mypage-membership-orders-cancel__image .membership-card {
  width: 25.6rem;
  height: 32.6rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__image .membership-card {
    width: 25.4rem;
    height: 32.4rem;
  }
}
.page-mypage-membership-orders-cancel__section {
  width: 100%;
}
.page-mypage-membership-orders-cancel__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-9, 3.2rem);
  gap: var(--spacing-3, 1rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__section-header {
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-membership-orders-cancel__receipt-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid #000000;
  cursor: pointer;
}
.page-mypage-membership-orders-cancel__section-body {
  padding-top: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-7, 2.4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
.page-mypage-membership-orders-cancel__info {
  display: flex;
  flex-direction: column;
}
.page-mypage-membership-orders-cancel__info-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__info-row {
    align-items: flex-start;
    gap: var(--spacing-4, 1.2rem);
  }
}
.page-mypage-membership-orders-cancel__info-row--program .page-mypage-membership-orders-cancel__info-value {
  color: #000000;
  font-weight: 800;
  padding: var(--spacing-3) 0;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__info-row--program .page-mypage-membership-orders-cancel__info-value {
    padding: var(--spacing-2) 0;
  }
}
.page-mypage-membership-orders-cancel__info-label {
  flex-shrink: 0;
  width: 12.4rem;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__info-label {
    width: 9.4rem;
    padding: var(--spacing-4) 0;
  }
}
.page-mypage-membership-orders-cancel__info-value {
  flex: 1;
  padding: var(--spacing-4) 0;
  color: #787878;
}
@media (max-width: 1024px) {
  .page-mypage-membership-orders-cancel__info-value {
    padding: var(--spacing-3) 0;
  }
}
.page-mypage-membership-orders-cancel__info-value--cancelled {
  color: #FF0000;
}

.page-mypage-shop-list {
  padding-bottom: var(--spacing-20, 14rem);
}

.mypage-items-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  padding-left: var(--spacing-7, 2.4rem);
  padding-right: var(--spacing-7, 2.4rem);
  margin-bottom: var(--spacing-5, 1.6rem);
  background-color: #f5f5f5;
  color: #787878;
}
.mypage-items-head__left {
  display: flex;
  align-items: center;
  gap: var(--spacing-4, 1.2rem);
}
.mypage-items-head__right {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
.mypage-items-head__right .mypage-order-button--cancel, .mypage-items-head__right .mypage-order-button--detail {
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (max-width: 1024px) {
  .mypage-order-button--pc {
    display: none;
  }
}
.mypage-order-button--mobile {
  margin-top: var(--spacing-5, 1.6rem);
}
@media (min-width: 1024px) {
  .mypage-order-button--mobile {
    display: none;
  }
}

.mypage-order-notice {
  padding-top: var(--spacing-11, 4rem);
  border-top: 1px solid #dddddd;
}
.mypage-order-notice__box {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  padding-left: var(--spacing-12, 4.8rem);
  padding-right: var(--spacing-12, 4.8rem);
  background-color: #f5f5f5;
}

.gift-info {
  width: 100%;
}
.gift-info--desktop {
  display: block;
}
@media (max-width: 1024px) {
  .gift-info--desktop {
    display: none;
  }
}
.gift-info--mobile {
  display: none;
}
@media (max-width: 1024px) {
  .gift-info--mobile {
    display: block;
  }
}
.gift-info__table {
  width: 100%;
  border-collapse: collapse;
}
.gift-info__header-row {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 5.6rem;
  border-bottom: 1px solid #000000;
  text-align: center;
}
.gift-info__header-cell {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100%;
  text-align: center;
  font-weight: 700;
}
.gift-info__header-cell:last-child, .gift-info__header-cell:nth-last-child(2) {
  flex: 0 0 13.5rem;
  width: 13.5rem;
}
.gift-info__body-row {
  display: flex;
  align-items: center;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
.gift-info__body-cell {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-weight: 700;
  word-break: break-all;
}
.gift-info__body-cell:last-child, .gift-info__body-cell:nth-last-child(2) {
  flex: 0 0 13.5rem;
  width: 13.5rem;
}
.gift-info__body-cell--button {
  display: flex;
  align-items: center;
  justify-content: center;
}
.gift-info__body-cell--button .button {
  min-width: 12rem;
}
.gift-info__card {
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 1px solid #dddddd;
}
.gift-info__card:first-child {
  padding-top: 0;
}
.gift-info__card-content {
  display: flex;
  align-items: center;
  gap: var(--spacing-6, 2rem);
  width: 100%;
}
.gift-info__card-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  min-width: 0;
}
.gift-info__card-rows {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2, 0.8rem);
}
.gift-info__card-row {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-4, 1.2rem);
}
.gift-info__card-label {
  flex-shrink: 0;
  font-weight: 700;
}
.gift-info__card-value {
  flex: 1;
  min-width: 0;
  word-break: break-all;
  font-weight: 700;
}
.gift-info__card-buttons {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2, 0.8rem);
}
.gift-info__card-button {
  min-width: 10rem;
  width: 12rem;
}

.page-membership-renewal {
  padding-top: var(--spacing-18, 12rem);
  padding-bottom: var(--spacing-21, 16rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal {
    padding-top: var(--spacing-12, 4.8rem);
    padding-bottom: var(--spacing-16, 8rem);
  }
}
.page-membership-renewal .renewal-content {
  display: flex;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal .renewal-content {
    flex-direction: column;
  }
}
.page-membership-renewal .renewal-content__left {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
  min-width: 0;
}
@media (max-width: 1024px) {
  .page-membership-renewal .renewal-content__left {
    gap: 0;
  }
}
.page-membership-renewal .renewal-content__right {
  width: 56.8rem;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-membership-renewal .renewal-content__right {
    width: 100%;
  }
}
.page-membership-renewal .info-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 10.9rem;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-membership-renewal .info-section__header--no-link {
  min-height: auto;
}
.page-membership-renewal .info-section__title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-renewal .info-section__link {
  padding-top: var(--spacing-3, 1rem);
  padding-bottom: var(--spacing-3, 1rem);
  line-height: 1;
  border-bottom: 1px solid #000000;
}
.page-membership-renewal .info-section__body {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-0, 0rem);
  padding: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal .info-section__body {
    padding: var(--spacing-7, 2.4rem);
    padding-left: 0;
    padding-right: 0;
  }
}
.page-membership-renewal .info-row {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal .info-row {
    gap: var(--spacing-3, 1rem);
  }
}
.page-membership-renewal .info-row--align-center {
  align-items: center;
}
.page-membership-renewal .info-row--align-top {
  align-items: flex-start;
}
.page-membership-renewal .info-row__label {
  width: 9rem;
  flex-shrink: 0;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal .info-row__label {
    width: 8.8rem;
  }
}
.page-membership-renewal .info-row__value {
  flex: 1;
  color: #787878;
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal .info-row__value {
    padding-top: var(--spacing-3, 1rem);
    padding-bottom: var(--spacing-2, 0.8rem);
  }
}
.page-membership-renewal .info-row__value-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding-bottom: var(--spacing-3, 1rem);
}
.page-membership-renewal .info-row__dropdown-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding-bottom: var(--spacing-3, 1rem);
}
.page-membership-renewal .info-row__dropdown {
  max-width: 26rem;
}
@media (max-width: 1024px) {
  .page-membership-renewal .info-row__dropdown {
    max-width: 100%;
  }
}
.page-membership-renewal .info-row__dropdown--renewal {
  width: 26rem;
}
@media (max-width: 1024px) {
  .page-membership-renewal .info-row__dropdown--renewal {
    width: 100%;
  }
}
.page-membership-renewal .info-row__hint {
  color: #787878;
}
@media (min-width: 1024px) {
  .page-membership-renewal .payment-box {
    position: sticky;
    top: calc(clamp(9.1rem, 6.6666666667vw, 12.8rem) + 2.4rem);
    border: 1px solid #dddddd;
  }
}
@media (max-width: 1024px) {
  .page-membership-renewal .payment-box--pc {
    display: none;
  }
}
.page-membership-renewal .payment-box--mo {
  margin-top: var(--spacing-8, 2.8rem);
}
@media (min-width: 1024px) {
  .page-membership-renewal .payment-box--mo {
    display: none;
  }
}
.page-membership-renewal .payment-box__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-9, 3.2rem);
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-membership-renewal .payment-box__header {
    padding-left: 0;
    padding-right: 0;
    padding-top: var(--spacing-5, 1.6rem);
    padding-bottom: var(--spacing-5, 1.6rem);
    border-top: 1px solid #f5f5f5;
    border-bottom: none;
  }
}
.page-membership-renewal .payment-box__toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
}
@media (max-width: 1024px) {
  .page-membership-renewal .payment-box__toggle {
    width: 1.7rem;
    height: 1.7rem;
  }
}
.page-membership-renewal .payment-box__toggle svg {
  width: 100%;
  height: 100%;
}
.page-membership-renewal .payment-box__body {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-13, 5.6rem);
  padding: var(--spacing-11, 4rem);
  padding-left: var(--spacing-9, 3.2rem);
  padding-right: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-membership-renewal .payment-box__body {
    padding-left: 0;
    padding-right: 0;
    padding-top: 0.4rem;
    padding-bottom: 0;
    gap: var(--spacing-8, 2.8rem);
  }
}
.page-membership-renewal .payment-box__price-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
}
.page-membership-renewal .payment-box__price-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
@media (max-width: 1024px) {
  .page-membership-renewal .payment-box__price-list {
    gap: var(--spacing-4, 1.2rem);
    padding-bottom: var(--spacing-0, 0rem);
    border-bottom: none;
  }
}
.page-membership-renewal .payment-box__price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-3, 1rem);
}
.page-membership-renewal .payment-box__price-label {
  flex: 1;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-renewal .payment-box__price-value {
  flex-shrink: 0;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-renewal .payment-box__price-value--discount {
  color: #FF3B30;
}
.page-membership-renewal .payment-box__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-1, 0.4rem);
}
.page-membership-renewal .payment-box__total-label {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
@media (max-width: 1024px) {
  .page-membership-renewal .payment-box__total-label {
    font-weight: 700;
  }
}
.page-membership-renewal .payment-box__total-price {
  color: #FF3B30;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-renewal .join-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-15, 7.2rem);
  margin-top: var(--spacing-13, 5.6rem);
  padding-top: var(--spacing-13, 5.6rem);
  border-top: 1px solid #000000;
}
@media (max-width: 1024px) {
  .page-membership-renewal .join-info {
    margin-top: var(--spacing-13, 5.6rem);
    padding-top: var(--spacing-13, 5.6rem);
  }
}
.page-membership-renewal .join-info__section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
}
.page-membership-renewal .join-info__title {
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
}
.page-membership-renewal .join-info__list {
  margin: 0;
  padding-left: 2.7rem;
  list-style-type: disc;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: -0.04em;
}
.page-membership-renewal .join-info__list li {
  margin-bottom: 0;
}
.page-membership-renewal .join-info__list li::marker {
  color: #000000;
}

@media (max-width: 1024px) {
  .mypage-title {
    display: none;
  }
}

.mypage-line-title {
  border-bottom: 2px solid #000000;
}

.mypage-content {
  margin-left: calc(-1 * min(4.8rem, 2.5vw));
}
@media (max-width: 1024px) {
  .mypage-content {
    margin-left: 0;
  }
}

@media (max-width: 1024px) {
  .mypage-lnb-row {
    row-gap: var(--spacing-13, 5.6rem);
  }
}

.mypage-filter {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .mypage-filter {
    gap: var(--spacing-9, 3.2rem);
  }
}
.mypage-filter__tabs {
  display: flex;
  width: 100%;
}
.mypage-filter__tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 26rem;
  padding: 2rem 1.6rem;
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (max-width: 1024px) {
  .mypage-filter__tab {
    min-width: 14rem;
    padding: 1.6rem;
  }
}
.mypage-filter__tab.is-active {
  background-color: #000000;
  color: #ffffff;
}
.mypage-filter__controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .mypage-filter__controls {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
}
.mypage-filter__months {
  display: flex;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .mypage-filter__months {
    width: 100%;
  }
}
.mypage-filter__month-btn {
  width: 14rem;
  transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
  min-width: 0;
}
@media (max-width: 1024px) {
  .mypage-filter__month-btn {
    flex: 1;
  }
}
.mypage-filter__month-btn.is-active {
  background-color: #000000;
  color: #ffffff;
}
.mypage-filter__date-search {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-6, 2rem);
}
@media (max-width: 1024px) {
  .mypage-filter__date-search {
    width: 100%;
  }
}
.mypage-filter__date-range {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .mypage-filter__date-range {
    flex: 1;
    min-width: 0;
  }
}
.mypage-filter__date-input {
  position: relative;
  display: flex;
  align-items: center;
  width: 17rem;
  border-bottom: 1px solid #000000;
  padding: 0 var(--spacing-1) var(--spacing-4);
}
@media (max-width: 1024px) {
  .mypage-filter__date-input {
    flex: 1;
    width: auto;
    min-width: 0;
  }
}
.mypage-filter__date-field {
  flex: 1;
  min-width: 0;
  border: none;
  cursor: pointer;
}
.mypage-filter__calendar-button {
  position: relative;
  width: 2.4rem;
  height: 2.4rem;
  cursor: pointer;
  flex-shrink: 0;
}
.mypage-filter__calendar-button svg {
  width: 100%;
  height: 100%;
}
.mypage-filter__date-picker {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 1;
}
.mypage-filter__date-picker::-webkit-calendar-picker-indicator {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.mypage-filter__date-separator {
  flex-shrink: 0;
}
.mypage-filter__search-button {
  width: 14rem;
  min-width: 0;
}
@media (max-width: 1024px) {
  .mypage-filter__search-button {
    flex-shrink: 0;
    width: 8rem;
  }
}

.page-mypage-main {
  padding-bottom: var(--spacing-21, 16rem);
}

.mypage-profile-card {
  display: flex;
  width: 100%;
  border-top: 1px solid #000000;
  border-bottom: 1px solid #000000;
  margin-bottom: var(--spacing-14, 6.4rem);
}
@media (max-width: 1024px) {
  .mypage-profile-card {
    flex-direction: column;
    border-top: none;
  }
}
.mypage-profile-card__user {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--spacing-11, 4rem);
  min-height: 22rem;
}
@media (max-width: 1024px) {
  .mypage-profile-card__user {
    min-height: auto;
    padding-top: var(--spacing-11, 4rem);
    padding-bottom: var(--spacing-8, 2.8rem);
    padding-left: var(--spacing-8, 2.8rem);
    padding-right: var(--spacing-8, 2.8rem);
    padding-top: 0;
  }
}
.mypage-profile-card__user-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3, 1rem);
}
.mypage-profile-card__user-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mypage-profile-card__email {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #000000;
  color: #ffffff;
  border-radius: 10rem;
  padding-left: var(--spacing-4, 1.2rem);
  padding-right: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-1, 0.4rem);
  padding-bottom: var(--spacing-1, 0.4rem);
}
.mypage-profile-card__logout {
  color: #787878;
  text-decoration: none;
  border-bottom: 1px solid #787878;
  transition: color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.mypage-profile-card__logout:hover {
  color: #000000;
  border-color: #000000;
}
.mypage-profile-card__greeting {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
}
.mypage-profile-card__links {
  display: flex;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .mypage-profile-card__links {
    margin-top: var(--spacing-8, 2.8rem);
  }
}
.mypage-profile-card__link {
  color: #000000;
  text-decoration: none;
  transition: opacity 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.mypage-profile-card__link:hover {
  opacity: 0.7;
}
.mypage-profile-card__divider {
  width: 1px;
  height: 1.3rem;
  background-color: #000000;
}
.mypage-profile-card__stats {
  display: flex;
  align-items: center;
  gap: var(--spacing-11, 4rem);
  padding: var(--spacing-11, 4rem);
  border-left: 1px solid #000000;
  width: 45rem;
}
@media (max-width: 1024px) {
  .mypage-profile-card__stats {
    width: 100%;
    border-left: none;
    gap: var(--spacing-8, 2.8rem);
    padding-top: var(--spacing-11, 4rem);
    padding-bottom: var(--spacing-11, 4rem);
    padding-left: var(--spacing-8, 2.8rem);
    padding-right: var(--spacing-8, 2.8rem);
  }
}
.mypage-profile-card__stat {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
  min-width: 14.5rem;
}
@media (max-width: 1024px) {
  .mypage-profile-card__stat {
    flex: 1;
    flex-direction: row;
    align-items: center;
    min-width: auto;
  }
}
.mypage-profile-card__stat-icon {
  width: 4.8rem;
  height: 4.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1024px) {
  .mypage-profile-card__stat-icon {
    width: 4rem;
    height: 4rem;
  }
}
.mypage-profile-card__stat-icon svg {
  width: 100%;
  height: 100%;
}
.mypage-profile-card__stat-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2, 0.8rem);
}
.mypage-profile-card__stat-label {
  display: flex;
  align-items: center;
  gap: var(--spacing-1, 0.4rem);
  color: #000000;
  text-decoration: none;
  transition: opacity 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.mypage-profile-card__stat-label:hover {
  opacity: 0.7;
}
.mypage-profile-card__stat-label svg {
  width: 1.4rem;
  height: 1.8rem;
}
.mypage-profile-card__stat-value {
  font-weight: 800;
}
@media (max-width: 1024px) {
  .mypage-profile-card__stat-value {
    display: none;
  }
}
.mypage-profile-card__stat-value span {
  font-weight: 800;
}
.mypage-profile-card__stat-divider {
  width: 1px;
  height: 14rem;
  background-color: #787878;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .mypage-profile-card__stat-divider {
    height: 100%;
    min-height: 4rem;
  }
}

.page-programs-list .programs-list {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-programs-list .programs-list__tab-buttons {
  display: flex;
  align-items: center;
  gap: var(--spacing-7, 2.4rem);
  padding-bottom: var(--spacing-11, 4rem);
  border-bottom: 1px solid #000000;
}
.page-programs-list .programs-list__tab-button {
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
}
.page-programs-list .programs-list__tab-button.is-active {
  background-color: #000000;
  color: #ffffff;
}
.page-programs-list .programs-list__filter {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  gap: var(--spacing-5, 1.6rem);
  padding-top: var(--spacing-11, 4rem);
}
@media (max-width: 1024px) {
  .page-programs-list .programs-list__filter {
    flex-direction: column;
    align-items: stretch;
  }
}
.page-programs-list .programs-list__filter-dropdowns {
  display: flex;
  flex: 1;
  align-items: center;
  gap: var(--spacing-5, 1.6rem);
}
.page-programs-list .programs-list__filter-dropdowns .custom-dropdown {
  width: 13.5416666667vw;
  min-width: 18rem;
}
@media (max-width: 1024px) {
  .page-programs-list .programs-list__filter-dropdowns .custom-dropdown {
    flex: 1;
    width: auto;
    min-width: 0;
  }
}
.page-programs-list .programs-list .search-bar--exhibition .search-bar__input-group {
  width: 47.8rem;
  height: 6rem;
}
@media (max-width: 1024px) {
  .page-programs-list .programs-list .search-bar--exhibition .search-bar__input-group {
    width: 100%;
    height: auto;
  }
}
.page-programs-list .programs-list .search-bar--exhibition .search-bar__input {
  width: 100%;
}
.page-programs-list .programs-list__programs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-20, 14rem);
  column-gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-programs-list .programs-list__programs {
    grid-template-columns: 1fr;
  }
}
.page-programs-list .programs-list__program-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
.page-programs-list .programs-list__thumbnail {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.page-programs-list .programs-list__thumbnail picture, .page-programs-list .programs-list__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.page-programs-list .programs-list__status {
  position: absolute;
  top: var(--spacing-6);
  left: var(--spacing-6);
  background-color: #ffffff;
  padding: var(--spacing-2) var(--spacing-6);
}
.page-programs-list .programs-list__status--done {
  background-color: #c6c6c6;
}
.page-programs-list .programs-list__info {
  display: flex;
  flex-direction: column;
}
.page-programs-list .programs-list__tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-programs-list .programs-list__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 3.2rem;
  padding-left: var(--spacing-4, 1.2rem);
  padding-right: var(--spacing-4, 1.2rem);
}
@media (max-width: 680px) {
  .page-programs-list .programs-list__tag {
    height: 2.6rem;
  }
}
.page-programs-list .programs-list__tag--fill {
  background-color: #000000;
  color: #ffffff;
}
.page-programs-list .programs-list__tag--line {
  background-color: transparent;
  border: 1px solid #000000;
  color: #000000;
}

.page-programs-detail .programs-detail__hero {
  width: 100%;
}
.page-programs-detail .programs-detail__kv-image {
  width: 100%;
}
@media (max-width: 1024px) {
  .page-programs-detail .programs-detail__kv-image {
    aspect-ratio: 358/430;
  }
}
.page-programs-detail .programs-detail__kv-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-programs-detail .programs-detail__title-section {
  position: relative;
}
.page-programs-detail .programs-detail__main-title {
  text-align: center;
}
.page-programs-detail .programs-detail__date {
  text-align: center;
}
.page-programs-detail .programs-detail__divider {
  height: 2px;
  background-color: #000000;
}
.page-programs-detail .programs-detail__tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-2, 0.8rem);
}
.page-programs-detail .programs-detail__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 3.2rem;
  padding-left: var(--spacing-4, 1.2rem);
  padding-right: var(--spacing-4, 1.2rem);
}
@media (max-width: 680px) {
  .page-programs-detail .programs-detail__tag {
    height: 2.6rem;
  }
}
.page-programs-detail .programs-detail__tag--fill {
  background-color: #000000;
  color: #ffffff;
}
.page-programs-detail .programs-detail__tag--line {
  background-color: transparent;
  border: 1px solid #000000;
  color: #000000;
}
.page-programs-detail .programs-detail__info {
  width: 100%;
}
.page-programs-detail .programs-detail__subtitle {
  line-height: 1.2;
}
.page-programs-detail .programs-detail__info-grid {
  display: flex;
  gap: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-programs-detail .programs-detail__info-grid {
    flex-direction: column;
    gap: 0;
  }
}
.page-programs-detail .programs-detail__info-column {
  flex: 1;
  min-width: 0;
}
.page-programs-detail .programs-detail__info-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-12, 4.8rem);
  padding: var(--spacing-3) 0;
}
@media (max-width: 1024px) {
  .page-programs-detail .programs-detail__info-item {
    gap: var(--spacing-8, 2.8rem);
  }
}
.page-programs-detail .programs-detail__info-label {
  width: 10.6rem;
  flex-shrink: 0;
  line-height: 1.75;
}
@media (max-width: 1024px) {
  .page-programs-detail .programs-detail__info-label {
    width: 8rem;
  }
}
.page-programs-detail .programs-detail__info-value {
  flex: 1;
  line-height: 1.75;
}
.page-programs-detail .programs-detail__action {
  display: flex;
}
.page-programs-detail .programs-detail__content {
  width: 100%;
}
.page-programs-detail .programs-detail__section {
  width: 100%;
}
.page-programs-detail .programs-detail__section-title {
  font-weight: 800;
}
.page-programs-detail .programs-detail__description {
  line-height: 1.75;
}
.page-programs-detail .programs-detail__guide-item {
  width: 100%;
}
.page-programs-detail .programs-detail__guide-title {
  font-weight: 800;
}
.page-programs-detail .programs-detail__guide-list {
  list-style: disc;
  padding-left: 3rem;
  line-height: 1.75;
}
.page-programs-detail .programs-detail__guide-list li {
  margin-bottom: 0;
}
.page-programs-detail .programs-detail__exhibition {
  width: 100%;
  overflow: hidden;
}
.page-programs-detail .programs-detail__exhibition-row {
  display: flex;
  justify-content: space-between;
}
.page-programs-detail .programs-detail__exhibition-title {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-6, 2rem);
}
.page-programs-detail .programs-detail__exhibition-navigation {
  display: flex;
  justify-content: flex-end;
  gap: 1.6rem;
}
.page-programs-detail .programs-detail__exhibition-navigation.is-hidden {
  visibility: hidden;
  pointer-events: none;
}
.page-programs-detail .programs-detail__exhibition-navigation-prev {
  width: 3.4rem;
  height: 2.6rem;
  color: #dddddd;
  cursor: pointer;
}
.page-programs-detail .programs-detail__exhibition-navigation-prev.is-active {
  color: #000000;
}
.page-programs-detail .programs-detail__exhibition-navigation-next {
  width: 3.4rem;
  height: 2.6rem;
  color: #dddddd;
  cursor: pointer;
}
.page-programs-detail .programs-detail__exhibition-navigation-next.is-active {
  color: #000000;
}
.page-programs-detail .programs-detail__exhibition-navigation svg {
  width: 100%;
  height: 100%;
}
.page-programs-detail .programs-detail__exhibition-swiper {
  overflow: visible;
}
.page-programs-detail .programs-detail__exhibition-slide {
  display: flex;
  flex-direction: column;
}
.page-programs-detail .programs-detail__exhibition-card {
  display: block;
  width: 100%;
}
.page-programs-detail .programs-detail__exhibition-image {
  aspect-ratio: 722/429;
  width: 100%;
  overflow: hidden;
}
.page-programs-detail .programs-detail__exhibition-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-programs-detail .programs-detail__exhibition-image:hover img {
    transform: scale(1.05);
  }
}
.page-programs-detail .programs-detail__exhibition-name {
  font-weight: 800;
  line-height: 1.4;
}

.page-programs-detail .editor-area h4 {
  font-family: var(--font-ko);
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.79);
}
@media (max-width: 680px) {
  .page-programs-detail .editor-area h4 {
    font-size: calc(max(2.8rem, 2.93vw) * 0.79);
  }
}
.page-programs-detail .editor-area h5 {
  font-family: var(--font-ko);
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.04em;
  font-size: calc(clamp(3rem, 1.9791vw, 3.8rem) * 0.58);
}
@media (max-width: 680px) {
  .page-programs-detail .editor-area h5 {
    font-size: calc(max(2.8rem, 2.93vw) * 0.58);
  }
}
.page-programs-detail .editor-area p {
  font-family: var(--font-ko);
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: -0.04em;
  font-size: calc(clamp(1.34rem, 0.8333vw, 1.6rem) * 1.25);
}
@media (max-width: 680px) {
  .page-programs-detail .editor-area p {
    font-size: calc(max(1.34rem, 1.3671vw) * 1.25);
  }
}
.page-programs-detail .editor-area ul {
  list-style-type: disc;
  padding-left: 2em;
}
.page-programs-detail .editor-area ul li {
  font-family: var(--font-ko);
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: -0.04em;
  font-size: calc(clamp(1.34rem, 0.8333vw, 1.6rem) * 1.125);
}
@media (max-width: 680px) {
  .page-programs-detail .editor-area ul li {
    font-size: calc(max(1.34rem, 1.3671vw) * 1.125);
  }
}
.page-programs-detail .editor-area b,
.page-programs-detail .editor-area strong {
  font-weight: 650;
}
.page-programs-detail .editor-area h4 {
  margin-bottom: var(--spacing-9, 3.2rem);
  margin-top: var(--spacing-9, 3.2rem);
}
.page-programs-detail .editor-area h5 {
  margin-bottom: var(--spacing-6, 2rem);
  margin-top: var(--spacing-6, 2rem);
}
.page-programs-detail .editor-area ul + ul {
  margin-top: var(--spacing-6, 2rem);
}
.page-programs-detail .editor-area ul + h5 {
  margin-top: var(--spacing-9, 3.2rem);
}

.page-visit-info {
  padding-bottom: var(--spacing-20, 14rem);
}
.page-visit-info .row {
  row-gap: 0;
}
.page-visit-info .table__table-content thead tr th,
.page-visit-info .table__table-content tbody tr td {
  padding: var(--spacing-4) 1.6rem;
}
.page-visit-info .table__table-content thead tr th {
  border-color: #dddddd;
}
.page-visit-info__hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-visit-info__hero-content {
  display: flex;
  flex-direction: column;
  background-color: #f5f5f5;
  padding-top: var(--spacing-17, 10rem);
  padding-bottom: var(--spacing-17, 10rem);
  padding-left: var(--spacing-21, 16rem);
  padding-right: var(--spacing-21, 16rem);
  margin-left: calc(-1 * min(4.8rem, 2.5vw));
}
@media (max-width: 1024px) {
  .page-visit-info__hero-content {
    padding: var(--spacing-13, 5.6rem);
    margin-left: 0;
    margin-top: -1.6rem;
  }
}
@media (max-width: 680px) {
  .page-visit-info__hero-content {
    margin-top: -1.6rem;
  }
}
.page-visit-info__hero-title-wrapper {
  border-bottom: 1px solid #dddddd;
}
.page-visit-info__hero-hours-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
}
.page-visit-info__hero-hours {
  display: flex;
  gap: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .page-visit-info__hero-hours {
    flex-direction: column;
  }
}
.page-visit-info__hero-hours-item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1, 0.4rem);
}
.page-visit-info__hero-hours-time {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-1, 0.4rem);
}
.page-visit-info__list li {
  position: relative;
  padding-left: 2rem;
}
.page-visit-info__list li::before {
  content: "-";
  position: absolute;
  left: 0;
  top: 0;
}
.page-visit-info__list li + li {
  margin-top: var(--spacing-1, 0.4rem);
}
.page-visit-info__divider {
  height: 1px;
  background-color: #dddddd;
  margin-top: var(--spacing-16, 8rem);
  margin-bottom: var(--spacing-16, 8rem);
}
.page-visit-info__transport-divider {
  height: 1px;
  background-color: #dddddd;
  margin-top: var(--spacing-14, 6.4rem);
  margin-bottom: var(--spacing-14, 6.4rem);
}
.page-visit-info__notes-list {
  list-style: none;
}
.page-visit-info__notes-list li {
  padding-left: 16px;
}
@media (max-width: 1024px) {
  .page-visit-info__section-title {
    margin-bottom: var(--spacing-9, 3.2rem);
  }
}
.page-visit-info__address-info {
  display: flex;
  flex-direction: column;
}
.page-visit-info__address-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-2, 0.8rem);
}
.page-visit-info__address-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.8rem;
  height: 2.8rem;
  margin-top: 2px;
}
@media (max-width: 1024px) {
  .page-visit-info__address-icon {
    width: 2.4rem;
    height: 2.4rem;
  }
}
.page-visit-info__address-icon svg {
  width: 100%;
  height: 100%;
}
.page-visit-info__map {
  height: 57.9rem;
}
@media (max-width: 680px) {
  .page-visit-info__map {
    height: 20.1rem;
  }
}
.page-visit-info__transport-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-7, 2.4rem);
}
@media (max-width: 1024px) {
  .page-visit-info__transport-header {
    margin-bottom: var(--spacing-9, 3.2rem);
  }
}
.page-visit-info__transport-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 7.2rem;
  height: 7.2rem;
  background-color: #000000;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .page-visit-info__transport-icon {
    width: 6.4rem;
    height: 6.4rem;
  }
}
.page-visit-info__transport-icon svg {
  color: #ffffff;
  width: 4.4rem;
  height: 4.4rem;
}
@media (max-width: 1024px) {
  .page-visit-info__transport-icon svg {
    width: 3.8rem;
    height: 3.8rem;
  }
}

.page-faq {
  padding-bottom: var(--spacing-0, 0rem);
}
.page-faq .faq-filter__wrap {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.page-faq .faq-filter__swiper {
  width: 100%;
  overflow: hidden;
}
.page-faq .faq-filter__swiper .swiper-wrapper {
  display: flex;
}
.page-faq .faq-filter__swiper .swiper-slide {
  width: auto;
  margin-right: var(--spacing-7, 2.4rem);
}
.page-faq .faq-filter__swiper .swiper-slide:last-child {
  margin-right: 0;
}
.page-faq .faq-filter__buttons {
  display: flex;
}
.page-faq .faq-filter__btn {
  border: 1px solid #000000;
  background-color: #ffffff;
  color: #000000;
  cursor: pointer;
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-faq .faq-filter__btn.is-active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .page-faq .faq-filter__btn:hover:not(.is-active) {
    background-color: #f5f5f5;
  }
}
.page-faq .faq-filter__divider {
  width: 100%;
  height: 1px;
  background-color: #000000;
  margin-top: var(--spacing-11, 4rem);
}
.page-faq .faq-list__content {
  display: none;
}
.page-faq .faq-list__content.is-active {
  display: block;
}
.page-faq .faq-list__pagination {
  display: flex;
  justify-content: center;
}
.page-faq .faq-accordion {
  display: flex;
  flex-direction: column;
}
.page-faq .faq-accordion__item {
  border-bottom: 1px solid #000000;
}
.page-faq .faq-accordion__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  gap: var(--spacing-5, 1.6rem);
  color: #000000;
}
.page-faq .faq-accordion__question:focus {
  outline: none;
}
.page-faq .faq-accordion__question-text {
  display: flex;
  align-items: flex-start;
  flex: 1;
  gap: var(--spacing-4, 1.2rem);
}
.page-faq .faq-accordion__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.8rem;
  height: 3.8rem;
  will-change: transform;
}
.page-faq .faq-accordion__icon svg {
  width: 100%;
  height: 100%;
}
@media (max-width: 1024px) {
  .page-faq .faq-accordion__icon {
    width: 2.8rem;
    height: 2.8rem;
  }
}
.page-faq .faq-accordion__answer {
  overflow: hidden;
  background-color: #f5f5f5;
  will-change: height, opacity;
}
.page-faq .faq-accordion__answer-inner {
  display: flex;
  border-top: 1px solid #000000;
}
.page-faq .faq-accordion__answer-text {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-4, 1.2rem);
}
.page-faq .faq-inquiry__wrap {
  display: flex;
  width: 100%;
}
@media (max-width: 1024px) {
  .page-faq .faq-inquiry__wrap {
    flex-direction: column;
  }
}
.page-faq .faq-inquiry__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 50%;
  min-height: 40rem;
  padding-left: var(--spacing-18, 12rem);
  padding-right: var(--spacing-18, 12rem);
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-16, 8rem);
  background-color: #000000;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-faq .faq-inquiry__content {
    width: 100%;
    min-height: auto;
    padding-left: var(--spacing-6, 2rem);
    padding-right: var(--spacing-6, 2rem);
  }
}
.page-faq .faq-inquiry__info {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.page-faq .faq-inquiry__image {
  width: 50%;
  min-height: 40rem;
}
@media (max-width: 1024px) {
  .page-faq .faq-inquiry__image {
    width: 100%;
    min-height: 27rem;
    height: 27rem;
  }
}
.page-faq .faq-inquiry__image picture,
.page-faq .faq-inquiry__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-visit-museum-info__divider {
  height: 1px;
  background-color: #dddddd;
  margin-top: var(--spacing-16, 8rem);
  margin-bottom: var(--spacing-16, 8rem);
}
@media (max-width: 1024px) {
  .page-visit-museum-info__divider {
    display: none;
  }
}
@media (max-width: 1024px) {
  .page-visit-museum-info__floor-section {
    margin-bottom: var(--spacing-16, 8rem);
  }
}
.page-visit-museum-info__floor-section-row {
  row-gap: var(--spacing-14, 6.4rem);
}
@media (max-width: 1024px) {
  .page-visit-museum-info__floor-section-row {
    row-gap: var(--spacing-0, 0rem);
  }
}
@media (max-width: 1024px) {
  .page-visit-museum-info__floor-section-title {
    margin-bottom: var(--spacing-9, 3.2rem);
  }
}
@media (max-width: 1024px) {
  .page-visit-museum-info__legend {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--spacing-5, 1.6rem);
    margin-top: var(--spacing-14, 6.4rem);
    margin-bottom: var(--spacing-9, 3.2rem);
  }
  .page-visit-museum-info__legend--one-item {
    grid-template-columns: 1fr;
  }
}
.page-visit-museum-info__legend-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-4, 1.2rem);
  padding-bottom: var(--spacing-4, 1.2rem);
  border-top: 1px solid #dddddd;
}
.page-visit-museum-info__legend-item:last-child {
  border-bottom: 1px solid #dddddd;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__legend-item:nth-last-child(-n+2) {
    border-bottom: 1px solid #dddddd;
  }
}
.page-visit-museum-info__map {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.page-visit-museum-info__map img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__map {
    margin-top: var(--spacing-9, 3.2rem);
  }
}
.page-visit-museum-info__facilities-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facilities-header--desktop {
    display: none;
  }
}
.page-visit-museum-info__facilities-header--mobile {
  display: none;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facilities-header--mobile {
    display: flex;
  }
}
.page-visit-museum-info__facilities-nav {
  display: flex;
  align-items: center;
  gap: 1.6rem;
}
.page-visit-museum-info__nav-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.4rem;
  height: 2.6rem;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__nav-button {
    width: 2.6rem;
    height: 2rem;
  }
}
.page-visit-museum-info__nav-button svg {
  width: 100%;
  height: 100%;
  color: #000000;
}
.page-visit-museum-info__nav-button.swiper-button-disabled {
  opacity: 0.3;
  cursor: default;
}
.page-visit-museum-info__facility-item {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-5, 1.6rem);
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facility-item {
    grid-template-columns: repeat(2, 1fr);
    row-gap: var(--spacing-15, 7.2rem);
  }
}
.page-visit-museum-info__facility-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-3, 1rem);
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facility-info {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-1, 0.4rem);
  }
}
.page-visit-museum-info__info-text {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.page-visit-museum-info__facility-divider {
  width: 1px;
  height: 1.3rem;
  background-color: #000000;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facility-divider {
    display: none;
  }
}
.page-visit-museum-info__facility-title {
  margin-bottom: 0.6rem;
}
.page-visit-museum-info__facility-image {
  position: relative;
  width: 100%;
  height: 23.1rem;
}
@media (max-width: 680px) {
  .page-visit-museum-info__facility-image {
    height: 11.1rem;
  }
}
.page-visit-museum-info__facility-image img {
  aspect-ratio: 16/10;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-visit-museum-info__facility-content {
  display: flex;
  flex-direction: column;
}
.page-visit-museum-info__outlink-text-container {
  display: flex;
  gap: var(--spacing-3, 1rem);
}
.page-visit-museum-info__text-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4, 1.2rem);
}
.page-visit-museum-info__outlink {
  flex-shrink: 0;
  width: 2.7rem;
  height: 2.7rem;
  border-radius: 50%;
  background-color: #f5f5f5;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__outlink {
    width: 2rem;
    height: 2rem;
  }
}
.page-visit-museum-info__outlink svg {
  color: #000000;
  width: 1.8rem;
  height: 1.8rem;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__outlink svg {
    width: 1.1rem;
    height: 1.1rem;
  }
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facilities-swiper--desktop {
    display: none;
  }
}
.page-visit-museum-info__facilities-swiper--mobile {
  display: none;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__facilities-swiper--mobile {
    display: flex;
  }
}
.page-visit-museum-info__facilities-swiper--mobile .swiper-slide {
  width: 43%;
}
.page-visit-museum-info__banner-wrapper {
  position: relative;
}
.page-visit-museum-info__banner-image {
  height: 55.9rem;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__banner-image {
    height: 100%;
  }
}
.page-visit-museum-info__banner-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-height: 55.9rem;
  min-height: 50rem;
}
.page-visit-museum-info__banner-content {
  position: absolute;
  bottom: var(--spacing-12, 4.8rem);
  left: var(--spacing-12, 4.8rem);
  display: flex;
  flex-direction: column;
  color: #ffffff;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__banner-content {
    right: var(--spacing-12, 4.8rem);
  }
}
.page-visit-museum-info__banner-title {
  word-break: break-word;
}
.page-visit-museum-info__banner-button {
  width: 20rem;
  min-width: 0;
}
@media (max-width: 1024px) {
  .page-visit-museum-info__banner-button {
    width: 16rem;
  }
}

.page-inquiry {
  padding-bottom: var(--spacing-0, 0rem);
}
.page-inquiry .inquiry-form__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--spacing-9, 3.2rem);
  padding-bottom: var(--spacing-9, 3.2rem);
  border-bottom: 2px solid #000000;
}
.page-inquiry .inquiry-form__required {
  color: #FF3B30;
}
.page-inquiry .inquiry-form__divider {
  width: 100%;
  height: 1px;
  background-color: #000000;
}
.page-inquiry .inquiry-form__group {
  display: flex;
  flex-direction: column;
}
.page-inquiry .inquiry-form__group label {
  font-weight: 700;
  line-height: 1.4;
  font-size: 1.5rem;
}
@media (max-width: 680px) {
  .page-inquiry .inquiry-form__group label {
    font-size: 1.25rem;
  }
}
.page-inquiry .inquiry-form__label {
  display: flex;
  align-items: center;
}
.page-inquiry .inquiry-form__input {
  width: 100%;
}
.page-inquiry .inquiry-form__input .custom-dropdown {
  width: 26rem;
}
@media (max-width: 1024px) {
  .page-inquiry .inquiry-form__input .custom-dropdown {
    width: 100%;
  }
}
.page-inquiry .inquiry-form__file {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 1024px) {
  .page-inquiry .inquiry-form__file {
    flex-direction: column;
    align-items: stretch;
  }
}
.page-inquiry .inquiry-form__file .input-field {
  flex: 1;
  max-width: 44rem;
}
@media (max-width: 1024px) {
  .page-inquiry .inquiry-form__file .input-field {
    max-width: 100%;
  }
}
.page-inquiry .inquiry-form__file .input-field__input {
  background-color: #ffffff;
  cursor: default;
}
.page-inquiry .inquiry-form__file-notice {
  color: #787878;
}
.page-inquiry .inquiry-form__file-notice li {
  position: relative;
  padding-left: 1.2rem;
}
.page-inquiry .inquiry-form__file-notice li::before {
  content: "•";
  position: absolute;
  left: 0;
}
.page-inquiry .inquiry-form__agreement {
  display: flex;
  align-items: center;
}
.page-inquiry .inquiry-form__submit {
  display: flex;
  justify-content: center;
}

.page-footer-contact__headline {
  text-align: center;
}
.page-footer-contact__options {
  row-gap: var(--spacing-9, 3.2rem);
}
.page-footer-contact__content-wrapper {
  display: flex;
}
@media (max-width: 1024px) {
  .page-footer-contact__content-wrapper {
    flex-direction: column-reverse;
  }
}
.page-footer-contact__image-wrapper {
  width: 50%;
  aspect-ratio: 592/381;
}
@media (max-width: 1024px) {
  .page-footer-contact__image-wrapper {
    width: 100%;
  }
}
.page-footer-contact__image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-footer-contact__content {
  width: 50%;
  background-color: #f5f5f5;
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-16, 8rem);
  padding-bottom: var(--spacing-16, 8rem);
  padding-left: var(--spacing-12, 4.8rem);
  padding-right: var(--spacing-12, 4.8rem);
}
@media (max-width: 1024px) {
  .page-footer-contact__content {
    width: 100%;
  }
}
.page-footer-contact__button {
  width: 20rem;
}
@media (max-width: 680px) {
  .page-footer-contact__button {
    width: 16rem;
  }
}
.page-footer-contact__email-content-wrapper {
  border: 1px solid #dddddd;
  display: flex;
  align-items: center;
}
@media (max-width: 1024px) {
  .page-footer-contact__email-content-wrapper {
    flex-direction: column;
    align-items: flex-start;
  }
}
.page-footer-contact__email-content {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--spacing-4, 1.2rem);
  padding-top: var(--spacing-11, 4rem);
  padding-bottom: var(--spacing-11, 4rem);
  padding-left: var(--spacing-12, 4.8rem);
  padding-right: var(--spacing-12, 4.8rem);
}
.page-footer-contact__divider {
  width: 1px;
  height: 6.5rem;
  flex-shrink: 0;
  background-color: #dddddd;
}
@media (max-width: 1024px) {
  .page-footer-contact__divider {
    width: calc(100% - var(--spacing-12) * 2);
    height: 1px;
    margin: 0 auto;
  }
}
.page-footer-contact__email {
  cursor: pointer;
}

.page-contact-complete__wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page-contact-complete__headline {
  padding: var(--spacing-13) 32px var(--spacing-11);
}
.page-contact-complete__body {
  text-align: center;
}
.page-contact-complete__button {
  width: 26rem;
}

.page-footer-sitemap__title {
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 2px solid #000000;
  font-weight: 720;
}
.page-footer-sitemap__row {
  row-gap: var(--spacing-14, 6.4rem);
}
.page-footer-sitemap__link-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--spacing-6, 2rem);
  padding-bottom: var(--spacing-6, 2rem);
  border-bottom: 2px solid #000000;
}
.page-footer-sitemap__submenu {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6, 2rem);
  margin-top: var(--spacing-11, 4rem);
}
.page-footer-sitemap__link {
  font-weight: 580;
}
.page-footer-sitemap__arrow-icon {
  width: 3.4rem;
  height: 3.4rem;
}
@media (max-width: 1024px) {
  .page-footer-sitemap__arrow-icon {
    width: 2.6rem;
    height: 2.6rem;
  }
}
.page-footer-sitemap__arrow-icon i, .page-footer-sitemap__arrow-icon svg {
  width: 100%;
  height: 100%;
}

.page-error__container {
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-error__content {
  gap: var(--spacing-14, 6.4rem);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page-error__logo img {
  width: 100%;
  object-fit: contain;
}
.page-error__buttons {
  display: flex;
  justify-content: center;
  width: 100%;
  gap: var(--spacing-4, 1.2rem);
}
@media (max-width: 680px) {
  .page-error__buttons .button {
    flex: 1;
    min-width: 0;
  }
}

.body--v1 {
  --v1-gutter: max(6rem, 3.125vw);
}
@media (max-width: 1024px) {
  .body--v1 {
    --v1-gutter: max(4rem, 3.9062vw);
  }
}
@media (max-width: 680px) {
  .body--v1 {
    --v1-gutter: max(1.6rem, 4.1025vw);
  }
}
@media (min-width: 1024px) {
  .body--v1 .gnb-header .container__boxed--xl {
    max-width: 100%;
  }
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__logo-img {
  filter: brightness(0) invert(1);
  transition: filter 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__menu-toggle-text {
  color: #ffffff;
  transition: color 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__status-text {
  color: #ffffff;
  transition: color 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__divider {
  background-color: #ffffff;
  transition: background-color 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__lang-btn,
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__lang-current {
  color: #ffffff;
  transition: color 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__lang-arrow svg path {
  fill: #ffffff;
  transition: fill 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__menu-text {
  color: #ffffff;
  transition: color 0.25s ease;
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__menu-text::after {
  background-color: #ffffff;
  transition: background-color 0.25s ease, width 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.body--v1 .gnb-header.gnb-header--transparent .gnb-header__menu-icon svg path {
  stroke: #ffffff;
  transition: stroke 0.25s ease;
}
@media (min-width: 1024px) {
  .body--v1 .footer .container__boxed--xl {
    max-width: 100%;
  }
}
.body--v1 .intro-animation {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1024px) {
  .body--v1 .intro-animation {
    justify-content: flex-start;
  }
}
.body--v1 .intro-animation__text-wrapper {
  z-index: 20;
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.8rem;
}
.body--v1 .intro-animation__text-line {
  color: #ffffff;
  opacity: 0;
  filter: blur(1.6rem);
}
.body--v1 .intro-animation__text-line--2 {
  overflow: hidden;
}
.body--v1 .main-kv__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.05);
  pointer-events: none;
  z-index: 1;
}
.body--v1 .main-kv__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.body--v1 .main-kv__video--desktop {
  display: block;
}
@media (max-width: 680px) {
  .body--v1 .main-kv__video--desktop {
    display: none !important;
  }
}
.body--v1 .main-kv__video--mobile {
  display: none;
}
@media (max-width: 680px) {
  .body--v1 .main-kv__video--mobile {
    display: block;
  }
}
.body--v1 .main-kv__headline {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  color: #ffffff;
  z-index: 2;
}
.body--v1 .main-kv__headline-inner {
  opacity: 0;
}
.body--v1 .main-kv__bottom {
  z-index: 2;
}
.body--v1 .v1-about {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  background-color: #000000;
  display: flex;
  overflow: hidden;
}
@media (max-width: 680px) {
  .body--v1 .v1-about {
    flex-direction: column-reverse;
    height: auto;
  }
}
.body--v1 .v1-about__text {
  flex: 1 1 50%;
  min-width: 0;
  padding: 0 var(--v1-gutter);
}
@media (max-width: 680px) {
  .body--v1 .v1-about__text {
    flex: 1 1 100%;
    padding-top: var(--spacing-20, 14rem);
    padding-bottom: var(--spacing-25, 24rem);
  }
}
.body--v1 .v1-about__desc {
  color: #ffffff;
  opacity: 0;
}
.body--v1 .v1-about__image-wrapper {
  flex: 1 1 50%;
  min-width: 0;
  height: 100%;
  overflow: hidden;
  clip-path: inset(100% 0 0 0);
  position: relative;
}
@media (max-width: 680px) {
  .body--v1 .v1-about__image-wrapper {
    flex: 1 1 100%;
    width: 100%;
  }
}
.body--v1 .v1-about__image-wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 8rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 100%);
  pointer-events: none;
}
@media (max-width: 1024px) {
  .body--v1 .v1-about__image-wrapper::after {
    height: 6rem;
  }
}
.body--v1 .v1-about__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 680px) {
  .body--v1 .v1-about__image {
    height: 43.9rem;
  }
}
.body--v1 .v1-about__credit {
  position: absolute;
  right: max(6rem, 3.125vw);
  bottom: var(--spacing-7, 2.4rem);
  padding-left: max(6rem, 3.125vw);
  color: #ffffff;
  opacity: 0.8;
  z-index: 2;
}
@media (max-width: 1024px) {
  .body--v1 .v1-about__credit {
    bottom: var(--spacing-6, 2rem);
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-about__credit {
    right: var(--spacing-6, 2rem);
    padding-left: var(--spacing-6, 2rem);
  }
}
.body--v1 .v1-building-wrapper {
  position: relative;
  height: 570vh;
  height: 570lvh;
  z-index: 1;
}
.body--v1 .v1-building {
  position: sticky;
  top: 0;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  overflow: hidden;
}
.body--v1 .v1-building__front {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  z-index: 1;
  pointer-events: none;
}
.body--v1 .v1-building__back {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 100vh;
  height: 100lvh;
}
.is-ios .body--v1 .v1-building__back {
  height: 100dvh;
}
.body--v1 .v1-building__back-content {
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 100%;
}
@media (max-width: 1024px) {
  .body--v1 .v1-building__back-content {
    align-items: flex-start;
  }
}
@media (min-width: 1025px) {
  .body--v1 .v1-building__back-content--mobile {
    display: none;
  }
}
@media (max-width: 1024px) {
  .body--v1 .v1-building__back-content--desktop {
    display: none;
  }
}
.body--v1 .v1-building__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.body--v1 .v1-building__bg picture {
  height: 100%;
}
.body--v1 .v1-building__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.body--v1 .v1-building__bg-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.body--v1 .v1-building__bg-img--default {
  z-index: 2;
}
.body--v1 .v1-building__bg-img--over {
  z-index: 1;
}
.body--v1 .v1-building__container {
  width: 100%;
}
@media (min-width: 1024px) {
  .body--v1 .v1-building__container .container__boxed--xl {
    max-width: 256rem;
  }
}
.body--v1 .v1-building__text {
  padding: 0 var(--v1-gutter);
  opacity: 0;
  z-index: 2;
}
.body--v1 .v1-building__desc {
  color: #ffffff;
}
.body--v1 .v1-building__back-content--desktop .v1-location-layer__image {
  visibility: hidden;
  aspect-ratio: 568/700;
  width: 100%;
  max-height: 70vh;
  max-height: 70lvh;
}
.body--v1 .v1-building__back-content--desktop .v1-location-layer__headline {
  text-align: right;
  opacity: 0;
}
.body--v1 .v1-building__back-content--desktop .v1-location-layer__desc .title {
  opacity: 0;
}
[lang=en] .body--v1 .v1-building__back-content--desktop .v1-location-layer__desc .title {
  font-weight: 400;
}
.body--v1 .v1-building__back-content--desktop .v1-location-layer__desc {
  position: relative;
}
.body--v1 .v1-building__back-content--desktop .v1-location-layer__lottie {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50vw;
  height: 3.8020833333vw;
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__image {
  width: 100%;
  visibility: hidden;
}
@media (max-width: 1024px) {
  .body--v1 .v1-building__back-content--mobile .v1-location-layer__image {
    height: 78.125vw;
    max-height: 50vh;
    max-height: 50lvh;
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-building__back-content--mobile .v1-location-layer__image {
    height: 26rem;
    max-height: auto;
  }
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__image .image-wrapper {
  width: 100%;
  height: 100%;
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__image .image-wrapper picture, .body--v1 .v1-building__back-content--mobile .v1-location-layer__image .image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__wrapper {
  display: flex;
  padding: 0 var(--v1-gutter);
  padding-top: var(--spacing-12, 4.8rem);
  gap: var(--spacing-9, 3.2rem);
}
@media (max-width: 1024px) {
  .body--v1 .v1-building__back-content--mobile .v1-location-layer__wrapper {
    padding-top: 8vh;
  }
  [lang=en] .body--v1 .v1-building__back-content--mobile .v1-location-layer__wrapper {
    padding-top: 4vh;
    gap: var(--spacing-8, 2.8rem);
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-building__back-content--mobile .v1-location-layer__wrapper {
    flex-direction: column;
  }
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__item {
  flex: 1;
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__headline {
  opacity: 0;
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__headline p:first-child {
  padding-bottom: var(--spacing-3, 1rem);
}
@media (max-width: 680px) {
  [lang=en] .body--v1 .v1-building__back-content--mobile .v1-location-layer__headline p:first-child {
    padding-bottom: 0;
  }
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__desc .title {
  opacity: 0;
}
[lang=en] .body--v1 .v1-building__back-content--mobile .v1-location-layer__desc .title {
  font-weight: 400;
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-building__back-content--mobile .v1-location-layer__desc .title {
    font-size: 1.6rem;
  }
  [lang=en] .body--v1 .v1-building__back-content--mobile .v1-location-layer__desc .title {
    font-size: 1.2rem;
  }
}
.body--v1 .v1-building__back-content--mobile .v1-location-layer__lottie {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  max-height: 7.3rem;
}
.body--v1 .v1-wilmotte-cubism-wrapper {
  position: relative;
  height: 400vh;
  height: 400lvh;
  margin-top: -100vh;
  margin-top: -100lvh;
  z-index: 2;
}
.body--v1 .v1-combined-sticky {
  position: sticky;
  top: 0;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  overflow: hidden;
  background-color: #ffffff;
}
.body--v1 .v1-cubism {
  width: 100%;
  height: 100%;
  background-color: #000000;
  overflow: hidden;
}
.body--v1 .v1-cubism__container {
  position: relative;
  width: 100%;
  height: 100%;
}
.body--v1 .v1-cubism__image {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: min(1rem, 0.5208333333vw);
  will-change: transform;
  opacity: 0;
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__image {
    gap: min(0.8rem, 0.78125vw);
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__image {
    gap: 0.8rem;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__image {
    gap: 0.8rem;
  }
}
.body--v1 .v1-cubism__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.body--v1 .v1-cubism__image--1 {
  width: min(20.8333333333vw, 40rem);
  top: min(4.1666666667vw, 8rem);
  left: 0;
}
.body--v1 .v1-cubism__image--1 img {
  aspect-ratio: 400/267;
}
@media (min-width: 1025px) and (min-aspect-ratio: 174/100), (min-width: 1025px) and (max-width: 1360px) {
  .body--v1 .v1-cubism__image--1 {
    width: min(16.6666666667vw, 32rem);
    top: min(3.3333333333vw, 6.4rem);
  }
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__image--1 {
    width: 27.34375vw;
    right: 7.8125vw;
    top: 7.8125vw;
  }
  .body--v1 .v1-cubism__image--1 .v1-cubism__credit {
    order: -1;
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__image--1 {
    width: 14rem;
    top: 2rem;
    left: 0;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__image--1 {
    width: 14rem;
    top: 2rem;
    left: 0;
  }
}
.body--v1 .v1-cubism__image--2 {
  width: min(25vw, 48rem);
  top: 0;
  right: min(11.1458333333vw, 21.4rem);
}
.body--v1 .v1-cubism__image--2 img {
  aspect-ratio: 480/352;
}
@media (min-width: 1025px) and (min-aspect-ratio: 174/100), (min-width: 1025px) and (max-width: 1360px) {
  .body--v1 .v1-cubism__image--2 {
    width: min(20vw, 38.4rem);
  }
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__image--2 {
    width: 33.203125vw;
    left: auto;
    right: 15.625vw;
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__image--2 {
    width: 18rem;
    left: auto;
    right: 1.6rem;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__image--2 {
    width: 18rem;
    left: auto;
    right: 1.6rem;
  }
}
.body--v1 .v1-cubism__image--3 {
  flex-direction: column-reverse;
  width: min(17.7083333333vw, 34rem);
  bottom: min(1.0416666667vw, 2rem);
  left: calc(8.33% + min(6.25vw, 12rem));
}
.body--v1 .v1-cubism__image--3 img {
  aspect-ratio: 1/1;
}
@media (min-width: 1025px) and (min-aspect-ratio: 174/100), (min-width: 1025px) and (max-width: 1360px) {
  .body--v1 .v1-cubism__image--3 {
    width: min(14.1666666667vw, 27.2rem);
  }
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__image--3 {
    width: 27.34375vw;
    left: 15.625vw;
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__image--3 {
    width: 12rem;
    bottom: 2rem;
    left: 4rem;
    right: auto;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__image--3 {
    width: 14rem;
    bottom: 2rem;
    left: 4rem;
    right: auto;
  }
}
.body--v1 .v1-cubism__image--4 {
  width: min(17.7083333333vw, 34rem);
  bottom: min(5.2083333333vw, 10rem);
  right: min(6.25vw, 12rem);
}
.body--v1 .v1-cubism__image--4 img {
  aspect-ratio: 340/367;
}
@media (min-width: 1025px) and (min-aspect-ratio: 174/100), (min-width: 1025px) and (max-width: 1360px) {
  .body--v1 .v1-cubism__image--4 {
    width: min(14.1666666667vw, 27.2rem);
    bottom: min(4.1666666667vw, 8rem);
  }
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__image--4 {
    width: 27.34375vw;
    top: auto;
    right: 5.859375vw;
    left: auto;
    right: 3.90625vw;
  }
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__image--4 {
    width: 10rem;
    bottom: 4rem;
    left: auto;
    right: 1.6rem;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__image--4 {
    width: 14rem;
    bottom: 4rem;
    left: auto;
    right: 1.6rem;
  }
}
.body--v1 .v1-cubism__credit {
  color: #787878;
  text-align: right;
  font-size: 0.8rem;
  opacity: 0.8;
  padding-left: 1.5em;
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__credit {
    font-size: 0.6rem;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__credit {
    font-size: 0.8rem;
  }
}
.body--v1 .v1-cubism__credit b {
  font-weight: 700;
}
.body--v1 .v1-cubism__credit em {
  font-style: italic;
}
.body--v1 .v1-cubism__credit--top {
  order: -1;
}
.body--v1 .v1-cubism__text-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.body--v1 .v1-cubism__text {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 0 var(--v1-gutter);
  opacity: 0;
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__text {
    align-items: flex-start;
  }
}
.body--v1 .v1-cubism__caption {
  color: #ffffff;
}
.body--v1 .v1-cubism__desc {
  color: #ffffff;
}
.body--v1 .v1-cubism__desc-sub {
  font-size: 1rem;
  color: #787878;
  line-height: 1.4;
  opacity: 0.8;
}
@media (max-width: 1024px) {
  .body--v1 .v1-cubism__desc-sub {
    font-size: 0.8rem;
  }
}
.body--v1 .v1-cubism__text--2 .v1-cubism__desc {
  width: clamp(45rem, 29.5833333333vw, 56.8rem);
}
@media (max-width: 680px) {
  .body--v1 .v1-cubism__text--2 .v1-cubism__desc {
    width: 100%;
  }
}
@media (min-width: 681px) and (max-width: 1024px) and (orientation: landscape) {
  .body--v1 .v1-cubism__text--2 .v1-cubism__desc {
    width: 100%;
  }
}
.body--v1 .v1-direction {
  position: relative;
  overflow: hidden;
}
.body--v1 .v1-direction__text {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 0 var(--v1-gutter);
  padding-top: var(--spacing-20, 14rem);
  color: #ffffff;
}
.body--v1 .v1-direction__address {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
}
.body--v1 .v1-direction__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
}
.body--v1 .v1-links {
  position: relative;
  width: 100%;
  height: max(44rem, 22.9166666667vw);
  background-color: #000000;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1024px) {
  .body--v1 .v1-links {
    height: auto;
  }
}
.body--v1 .v1-links__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  flex: 1;
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
}
@media (max-width: 1024px) {
  .body--v1 .v1-links__grid {
    grid-template-columns: 1fr;
  }
}
.body--v1 .v1-links__item {
  position: relative;
  display: flex;
  flex-direction: column;
  border-right: 1px solid #ffffff;
  overflow: hidden;
}
.body--v1 .v1-links__item:last-child {
  border-right: none;
}
@media (max-width: 1024px) {
  .body--v1 .v1-links__item {
    border-right: none;
    border-bottom: 1px solid #ffffff;
    min-height: 26.8rem;
  }
  .body--v1 .v1-links__item:last-child {
    border-bottom: none;
  }
}
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
  .body--v1 .v1-links__item:hover .v1-links__bg-img {
    transform: scale(1.1);
  }
}
.body--v1 .v1-links__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.body--v1 .v1-links__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}
@media (max-width: 1024px) {
  .body--v1 .v1-links__bg-img--object-bottom {
    object-position: center 80%;
  }
}
.body--v1 .v1-links__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-7, 2.4rem);
  padding-top: var(--spacing-11, 4rem);
  padding-left: var(--spacing-11, 4rem);
  padding-right: var(--spacing-11, 4rem);
}
@media (max-width: 1024px) {
  .body--v1 .v1-links__content {
    padding-left: var(--spacing-6, 2rem);
  }
}
.body--v1 .v1-links__content .cta-button {
  margin-top: auto;
}
.body--v1 .v1-links__title {
  color: #ffffff;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.body--v1 .v1-marquee {
  position: relative;
  width: 100%;
  background-color: #000000;
  padding: 0.8rem 0;
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid #ffffff;
  overflow: hidden;
}
.body--v1 .v1-marquee__track {
  display: flex;
  width: max-content;
  --marquee-translate: -50%;
  animation: v1-marquee 20s linear infinite;
}
.body--v1 .v1-marquee__content {
  display: flex;
  align-items: center;
  gap: 4rem;
  padding-right: 4rem;
}
@media (max-width: 1024px) {
  .body--v1 .v1-marquee__content {
    gap: 2rem;
    padding-right: 2rem;
  }
}
.body--v1 .v1-marquee__text {
  color: #ffffff;
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .body--v1 .v1-marquee__text {
    font-size: 3.6rem;
  }
}
.body--v1 .v1-marquee__divider {
  width: 1.4rem;
  height: 5.6rem;
  background-color: #ffffff;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .body--v1 .v1-marquee__divider {
    width: 0.8rem;
    height: 3.2rem;
  }
}
@keyframes v1-marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(var(--marquee-translate, -50%));
  }
}

.page-coming-soon {
  position: relative;
  height: 100vh;
}
.page-coming-soon__background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.page-coming-soon__background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-coming-soon__container {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-14, 6.4rem);
  color: #ffffff;
}
.page-coming-soon__content {
  gap: var(--spacing-11, 4rem);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page-coming-soon__divider {
  width: 8rem;
  height: 1px;
  background-color: #ffffff;
  opacity: 0.2;
}
.page-coming-soon__logo {
  width: 20rem;
}
@media (max-width: 1024px) {
  .page-coming-soon__logo {
    width: 18rem;
  }
}
@media (max-width: 680px) {
  .page-coming-soon__logo {
    width: 16rem;
  }
}
.page-coming-soon__logo img {
  width: 100%;
  object-fit: contain;
}