@font-face {
  font-family: "Mainstage Trajan";
  src: url("/Fonts/TrajanPro-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Mainstage Trajan";
  src: url("/Fonts/TrajanPro-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

.homepage-v2-group-card {
  position: relative;
  --homepage-v2-mainstage-font: "Mainstage Trajan", Georgia, serif;
  isolation: isolate;
  overflow: hidden;
  padding: 0;
  border-color: rgba(116, 207, 145, 0.28);
  background:
    linear-gradient(170deg, rgba(20, 24, 35, 0.92), rgba(13, 15, 21, 0.9));
}

.homepage-v2-group-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
  opacity: 0;
  background:
    radial-gradient(circle at 18% 24%, rgba(161, 239, 173, 0.14), transparent 24%),
    radial-gradient(circle at 84% 76%, rgba(79, 190, 142, 0.14), transparent 26%);
  transition: opacity 0.9s ease;
}

.homepage-v2-group-card.is-vines-growing::after,
.homepage-v2-group-card.is-growth-complete::after,
.homepage-v2-group-card.is-shaking::after,
.homepage-v2-group-card.is-falling-away::after,
.homepage-v2-group-card.is-revealed::after {
  opacity: 1;
}

.homepage-v2-group-card__content {
  position: relative;
  z-index: 3;
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  justify-content: space-between;
  min-height: 300px;
  padding: 1rem;
}

.homepage-v2-group-card__crumb {
  transform-origin: center top;
  will-change: transform, opacity, filter, clip-path;
}

.homepage-v2-group-card__crumb--title {
  transform-origin: 12% 24%;
}

.homepage-v2-group-card__crumb--summary {
  transform-origin: 86% 14%;
}

.homepage-v2-group-card__crumb--world {
  transform-origin: 50% 6%;
}

.homepage-v2-group-card__reveal {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: stretch;
  padding: 1rem;
  color: inherit;
  text-decoration: none;
  opacity: 0;
  pointer-events: none;
  transform: scale(1.035);
  transition:
    opacity 1.4s ease,
    transform 2s cubic-bezier(0.2, 0.72, 0.12, 1);
}

.homepage-v2-mainstage-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-rows: auto auto auto;
  align-items: center;
  justify-items: center;
  align-content: center;
  gap: clamp(0.48rem, 2vw, 0.82rem);
  min-height: 100%;
  padding: clamp(1.2rem, 4.6vw, 1.6rem) clamp(0.75rem, 3.2vw, 1.1rem) clamp(0.95rem, 3.4vw, 1.2rem);
  border-radius: 10px;
  border: clamp(0.35rem, 1.7vw, 0.55rem) solid rgba(247, 247, 245, 0.94);
  background:
    radial-gradient(circle at 50% 30%, rgba(255, 255, 255, 0.08), transparent 34%),
    radial-gradient(circle at 50% 76%, rgba(126, 224, 161, 0.08), transparent 36%),
    linear-gradient(180deg, #111314 0%, #050607 58%, #090b0c 100%);
  background-size: cover;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.1),
    inset 0 0 32px rgba(255, 255, 255, 0.035),
    inset 0 -54px 92px rgba(0, 0, 0, 0.5),
    0 22px 42px rgba(0, 0, 0, 0.5);
}

.homepage-v2-mainstage-card::before,
.homepage-v2-mainstage-card::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.homepage-v2-mainstage-card::before {
  inset: clamp(0.22rem, 1vw, 0.35rem);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 6px;
}

.homepage-v2-mainstage-card::after {
  inset: 0;
  background:
    linear-gradient(100deg, transparent 0 42%, rgba(255, 255, 255, 0.08) 48%, transparent 54%),
    radial-gradient(circle at 18% 12%, rgba(255, 255, 255, 0.14), transparent 18%);
  opacity: 0.26;
  mix-blend-mode: screen;
}

.homepage-v2-mainstage-card__title,
.homepage-v2-mainstage-card__logo,
.homepage-v2-mainstage-card__date {
  position: relative;
  z-index: 1;
}

.homepage-v2-mainstage-card__title {
  display: grid;
  gap: clamp(0.24rem, 1vw, 0.38rem);
  width: 100%;
  color: #fff;
  font-family: var(--homepage-v2-mainstage-font);
  font-size: clamp(1.12rem, 3.55vw, 1.72rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
  text-transform: uppercase;
  text-shadow:
    0 0 18px rgba(255, 255, 255, 0.18),
    0 14px 28px rgba(0, 0, 0, 0.78);
}

.homepage-v2-mainstage-card__logo {
  width: min(6.9rem, 43%);
  aspect-ratio: 1;
  object-fit: contain;
  filter:
    drop-shadow(0 0 16px rgba(255, 255, 255, 0.14))
    drop-shadow(0 15px 32px rgba(0, 0, 0, 0.62));
}

.homepage-v2-mainstage-card__date {
  color: rgba(246, 246, 246, 0.82);
  font-family: var(--homepage-v2-mainstage-font);
  font-size: clamp(0.74rem, 1.7vw, 0.96rem);
  font-weight: 400;
  line-height: 1.2;
  text-align: center;
  text-transform: uppercase;
  text-shadow: 0 10px 22px rgba(0, 0, 0, 0.7);
}

.homepage-v2-group-card__vines {
  position: absolute;
  inset: 0;
  z-index: 4;
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.56s ease;
}

.homepage-v2-vine {
  position: absolute;
  display: block;
  pointer-events: none;
  filter:
    drop-shadow(0 0 12px rgba(126, 224, 161, 0.18))
    drop-shadow(0 14px 22px rgba(0, 0, 0, 0.48));
}

.homepage-v2-vine--left,
.homepage-v2-vine--right {
  top: -0.8rem;
  bottom: -0.8rem;
  width: clamp(4.6rem, 24%, 6.4rem);
  background: url("/img/mainstage/vine-climb.svg") center bottom / 100% auto repeat-y;
  opacity: 0;
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
}

.homepage-v2-vine--left {
  left: -1.2rem;
  transform: rotate(-5deg);
}

.homepage-v2-vine--right {
  right: -1.2rem;
  transform: scaleX(-1) rotate(-5deg);
}

.homepage-v2-vine--stem {
  background-position: center bottom;
}

.homepage-v2-vine--leaves {
  width: clamp(4.1rem, 21%, 5.7rem);
  background-position: center calc(100% - 2.2rem);
  opacity: 0;
  filter:
    drop-shadow(0 0 12px rgba(120, 212, 211, 0.16))
    drop-shadow(0 14px 22px rgba(0, 0, 0, 0.45))
    saturate(1.16) brightness(1.12);
}

.homepage-v2-vine--top,
.homepage-v2-vine--bottom {
  left: 50%;
  width: min(25rem, 88%);
  height: clamp(5rem, 32%, 8.2rem);
  background: url("/img/mainstage/vine-hanging.svg") center top / contain no-repeat;
  opacity: 0;
}

.homepage-v2-vine--top {
  top: -1rem;
  transform: translateX(-50%);
  clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
}

.homepage-v2-vine--bottom {
  bottom: -1.4rem;
  transform: translateX(-50%) rotate(180deg);
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
}

.homepage-v2-group-card.is-vines-growing .homepage-v2-group-card__vines,
.homepage-v2-group-card.is-growth-complete .homepage-v2-group-card__vines,
.homepage-v2-group-card.is-shaking .homepage-v2-group-card__vines,
.homepage-v2-group-card.is-falling-away .homepage-v2-group-card__vines,
.homepage-v2-group-card.is-revealed .homepage-v2-group-card__vines {
  opacity: 1;
}

.homepage-v2-group-card.is-vines-growing .homepage-v2-vine--stem,
.homepage-v2-group-card.is-growth-complete .homepage-v2-vine--stem,
.homepage-v2-group-card.is-shaking .homepage-v2-vine--stem,
.homepage-v2-group-card.is-falling-away .homepage-v2-vine--stem,
.homepage-v2-group-card.is-revealed .homepage-v2-vine--stem {
  animation: homepage-v2-grow-vertical 7.2s cubic-bezier(0.16, 0.84, 0.18, 1) forwards;
  opacity: 0.54;
}

.homepage-v2-group-card.is-vines-growing .homepage-v2-vine--leaves {
  animation: homepage-v2-grow-vertical 7.2s 0.8s cubic-bezier(0.16, 0.84, 0.18, 1) forwards;
  opacity: 0.74;
}

.homepage-v2-group-card.is-growth-complete .homepage-v2-vine--leaves,
.homepage-v2-group-card.is-shaking .homepage-v2-vine--leaves,
.homepage-v2-group-card.is-falling-away .homepage-v2-vine--leaves,
.homepage-v2-group-card.is-revealed .homepage-v2-vine--leaves {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  opacity: 0.18;
  transition: opacity 0.9s ease;
}

.homepage-v2-group-card.is-vines-growing .homepage-v2-vine--top,
.homepage-v2-group-card.is-growth-complete .homepage-v2-vine--top,
.homepage-v2-group-card.is-shaking .homepage-v2-vine--top,
.homepage-v2-group-card.is-falling-away .homepage-v2-vine--top,
.homepage-v2-group-card.is-revealed .homepage-v2-vine--top {
  animation: homepage-v2-grow-top 6.4s 0.36s cubic-bezier(0.16, 0.84, 0.18, 1) forwards;
  opacity: 0.36;
}

.homepage-v2-group-card.is-vines-growing .homepage-v2-vine--bottom,
.homepage-v2-group-card.is-growth-complete .homepage-v2-vine--bottom,
.homepage-v2-group-card.is-shaking .homepage-v2-vine--bottom,
.homepage-v2-group-card.is-falling-away .homepage-v2-vine--bottom,
.homepage-v2-group-card.is-revealed .homepage-v2-vine--bottom {
  animation: homepage-v2-grow-bottom 6.4s 0.76s cubic-bezier(0.16, 0.84, 0.18, 1) forwards;
  opacity: 0.26;
}

.homepage-v2-group-card.is-shaking {
  animation: homepage-v2-card-shake-twice 1.45s ease-in-out both;
}

.homepage-v2-group-card.is-falling-away .homepage-v2-group-card__content,
.homepage-v2-group-card.is-revealed .homepage-v2-group-card__content {
  animation: homepage-v2-card-fall-away 1.8s cubic-bezier(0.32, 0.02, 0.84, 0.28) forwards;
  transform-origin: center 12%;
}

.homepage-v2-group-card.is-revealed .homepage-v2-group-card__content {
  pointer-events: none;
}

.homepage-v2-group-card.is-falling-away .homepage-v2-group-card__reveal,
.homepage-v2-group-card.is-revealed .homepage-v2-group-card__reveal {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
}

.homepage-v2-group-card.is-mainstage-ready .homepage-v2-group-card__content,
.homepage-v2-group-card.is-mainstage-ready .homepage-v2-group-card__vines {
  display: none;
}

.homepage-v2-group-card.is-mainstage-ready .homepage-v2-group-card__reveal {
  opacity: 1;
  pointer-events: auto;
  transform: none;
  transition: none;
}

@keyframes homepage-v2-grow-vertical {
  0% {
    clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}

@keyframes homepage-v2-grow-top {
  0% {
    clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}

@keyframes homepage-v2-grow-bottom {
  0% {
    clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}

@keyframes homepage-v2-card-shake-twice {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  8% {
    transform: translate3d(-0.45rem, 0, 0) rotate(-0.8deg);
  }
  16% {
    transform: translate3d(0.5rem, 0, 0) rotate(0.9deg);
  }
  24% {
    transform: translate3d(-0.36rem, 0, 0) rotate(-0.6deg);
  }
  32% {
    transform: translate3d(0.28rem, 0, 0) rotate(0.45deg);
  }
  40%,
  52% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  60% {
    transform: translate3d(-0.42rem, 0, 0) rotate(-0.75deg);
  }
  68% {
    transform: translate3d(0.48rem, 0, 0) rotate(0.85deg);
  }
  76% {
    transform: translate3d(-0.32rem, 0, 0) rotate(-0.55deg);
  }
  84% {
    transform: translate3d(0.22rem, 0, 0) rotate(0.35deg);
  }
}

@keyframes homepage-v2-card-fall-away {
  0% {
    opacity: 1;
    filter: none;
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  24% {
    opacity: 0.94;
    transform: translate3d(0, 0.55rem, 0) rotate(-1.6deg);
  }
  100% {
    opacity: 0;
    filter: blur(2px);
    transform: translate3d(0.4rem, 9rem, 0) rotate(8deg);
  }
}

@media (max-width: 980px) {
  .homepage-v2-group-card__content {
    min-height: 220px;
  }

  .homepage-v2-vine--left,
  .homepage-v2-vine--right {
    width: clamp(3.8rem, 18vw, 5.2rem);
  }

  .homepage-v2-vine--top,
  .homepage-v2-vine--bottom {
    width: min(20rem, 84%);
    height: clamp(4.2rem, 24vw, 6.2rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v2-group-card,
  .homepage-v2-group-card *,
  .homepage-v2-group-card::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.18s !important;
  }

  .homepage-v2-group-card__crumb {
    will-change: auto;
  }

  .homepage-v2-group-card.is-reduced-motion .homepage-v2-group-card__vines {
    display: none;
  }

  .homepage-v2-group-card.is-reduced-motion .homepage-v2-group-card__content {
    opacity: 0;
  }
}
