.page--join {
  align-items: stretch;
}

.contact-body {
  display: flex;
  flex-direction: column;
  gap: clamp(32px, 6vh, 72px);
}

.contact-shell {
  position: relative;
  display: grid;
  grid-template-columns: minmax(340px, 1.05fr) minmax(260px, 0.85fr);
  gap: clamp(32px, 6vw, 60px);
  padding: clamp(40px, 7vw, 72px);
  border-radius: 36px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 48px 82px rgba(41, 16, 72, 0.32);
  overflow: hidden;
  isolation: isolate;
  backdrop-filter: blur(22px);
}

.contact-shell::before {
  content: '';
  position: absolute;
  inset: -20% -10% 55% -15%;
  background: radial-gradient(circle at top left, rgba(255, 222, 92, 0.55), rgba(255, 155, 35, 0));
  pointer-events: none;
  z-index: -1;
}

.contact-shell::after {
  content: '';
  position: absolute;
  inset: 55% -30% -25% 30%;
  background: radial-gradient(circle at center, rgba(200, 130, 255, 0.3), rgba(200, 130, 255, 0));
  pointer-events: none;
  z-index: -1;
}

.contact-shell__main {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 4vw, 32px);
  justify-content: center;
  max-width: 620px;
}

.contact-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 16px;
  border-radius: 999px;
  background: rgba(41, 16, 72, 0.08);
  border: 1px solid rgba(41, 16, 72, 0.12);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.18em;
  color: rgba(27, 18, 56, 0.82);
}

.contact-shell__main h1 {
  margin: 0;
  font-size: clamp(42px, 6vw, 60px);
  color: #1b1238;
}

.contact-lead,
.contact-sub {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: 1.9;
  color: rgba(27, 18, 56, 0.85);
  text-transform: none;
  letter-spacing: 0.04em;
}

.contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(18px, 4vw, 30px);
  margin-top: clamp(12px, 3vw, 20px);
}

.contact-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: clamp(20px, 4vw, 28px);
  border-radius: 26px;
  background: rgba(41, 16, 72, 0.08);
  border: 1px solid rgba(41, 16, 72, 0.16);
  box-shadow: 0 24px 48px rgba(20, 9, 42, 0.22);
}

.contact-card--email {
  background: linear-gradient(150deg, rgba(255, 240, 190, 0.92), rgba(255, 145, 22, 0.78));
  border-color: rgba(255, 255, 255, 0.55);
  color: #1b1238;
  box-shadow: 0 28px 54px rgba(255, 145, 22, 0.28);
}

.contact-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.contact-card__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.2em;
  font-weight: 700;
  color: rgba(27, 18, 56, 0.72);
}

.contact-card__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.contact-card__value {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: #1b1238;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0.02em;
  word-break: break-word;
}

.contact-card__value:hover,
.contact-card__value:focus-visible {
  color: #341c6c;
  text-decoration: underline;
}

.contact-card__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  padding: 12px 22px;
  border-radius: 16px;
  border: none;
  background: linear-gradient(135deg, #ffde5c, #ff9204);
  color: #291048;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--duration-fast) var(--easing-primary),
    box-shadow var(--duration-fast) var(--easing-primary);
}

.contact-card__action:hover,
.contact-card__action:focus-visible {
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 20px 36px rgba(41, 16, 72, 0.28);
}

.contact-card__note {
  margin: 0;
  font-size: var(--font-size-xs);
  line-height: 1.8;
  color: rgba(27, 18, 56, 0.72);
  text-transform: none;
  letter-spacing: 0.04em;
}

.contact-footnote {
  margin-top: clamp(12px, 3vw, 20px);
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  color: rgba(27, 18, 56, 0.6);
}

.contact-shell__aside {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 4vw, 28px);
  align-items: center;
  justify-content: center;
}

.contact-art {
  position: relative;
  width: min(380px, 100%);
  border-radius: 30px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.6);
  border: 3px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 40px 80px rgba(20, 9, 42, 0.32);
}

.contact-art img {
  display: block;
  width: 100%;
  height: auto;
}

.contact-art--primary {
  transform: rotate(-4deg);
}

.contact-art--secondary {
  width: min(260px, 70%);
  transform: rotate(8deg) translateX(18px);
  align-self: flex-end;
  box-shadow: 0 28px 60px rgba(20, 9, 42, 0.28);
}

@media (max-width: 1200px) {
  .contact-shell {
    grid-template-columns: minmax(320px, 1fr) minmax(240px, 0.8fr);
  }
}

@media (max-width: 1024px) {
  .contact-shell {
    grid-template-columns: 1fr;
    padding: clamp(32px, 8vw, 58px);
  }

  .contact-shell__main {
    align-items: center;
    text-align: center;
  }

  .contact-grid {
    width: 100%;
  }

  .contact-card__action {
    align-self: center;
  }

  .contact-shell__aside {
    flex-direction: row;
    justify-content: center;
  }

  .contact-art--primary,
  .contact-art--secondary {
    transform: none;
  }

  .contact-art--secondary {
    width: min(220px, 60%);
  }
}

@media (max-width: 640px) {
  .contact-shell {
    padding: clamp(24px, 10vw, 40px);
  }

  .contact-grid {
    grid-template-columns: 1fr;
  }

  .contact-card {
    text-align: left;
  }

  .contact-shell__aside {
    flex-direction: column;
    gap: 18px;
  }

  .contact-art {
    width: 100%;
  }
}
