.join-link-wrap {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.join-link {
  display: block;
}

.join-card {
  position: relative;
  width: 100%;
  height: 235px;
  border-radius: 12px;
  overflow: hidden;
}

.join-card::before {
  content: "";
  position: absolute;
  inset: 0;

  background-image: url('/assets/images/signup/player.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: transform 0.35s ease;
  transform: scale(1); /* 기본 */
  z-index: 0;
}

.join-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 12px;
  border: 3px solid transparent;
  transition: border-color 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.join-card.join-card--scout::before {
  background-image: url('/assets/images/signup/scout.png');
}

/* hover 효과 */
.join-card:hover::before {
  transform: scale(1.08); /* 8% 확대 */
}

.join-card:hover::after {
  border-color: var(--color-primary-400);
}

.join-card.join-card--scout:hover::after {
  border-color: #FFFF78;
}

.join-card > * {
  position: relative;
  z-index: 1;
}

.join-card-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: #fff;
  padding-top: 72px;
  padding-bottom: 102px;
}

.join-card-title {
  color: var(--color-primary-400);
  line-height: 33px;
  margin: 0;
}

.join-card.join-card--scout .join-card-title {
  color: var(--color-secondary-400);
}

.join-card-subtitle {
  color: var(--color-secondary-300);
  line-height: 18px;
  margin: 0;
}

.join-ad-card {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 360px;
  height: 220px;
  background-color: #E5E5E5;
  border-radius: 12px;
  border: 1px solid #CCCCCC;
}

.join-ad-card p {
  font-size: 24px;
  font-weight: 700;
  color: #0F1018;
  line-height: 36px;
  margin: 0;
}

.join-ad-card-pc {
  display: none;
}

/* ========================================
   PC (1024px 이상)
   ======================================== */
@media (min-width: 1024px) {
  .join-link-wrap {
    display: flex;
    flex-direction: row;
    gap: 24px;
  }

  .join-link-wrap .join-link {
    flex: 1;
  }

  .join-ad-card {
    display: none;
  }

  .join-ad-card-pc {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 1440px;
    height: 90px;
    background-color: #E5E5E5;
    border: 1px solid #CCCCCC;
    flex-shrink: 0;
    margin: 0 auto;
  }

  .join-ad-card-pc p {
    font-size: 24px;
    font-weight: 700;
    color: #0F1018;
    line-height: 36px;
    margin: 0;
  }
}