.contact-main {
  min-height: 100vh;
  padding: 132px 0 var(--space-20);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0) 280px),
    var(--surface-page);
}

.contact-section {
  padding: var(--space-8) 0 0;
}

.contact-container {
  display: grid;
  justify-items: center;
  gap: var(--space-8);
}

.contact-heading {
  width: min(100%, 720px);
  text-align: center;
}

.contact-eyebrow {
  margin: 0 0 var(--space-3);
  color: var(--color-gray-400);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
}

.contact-heading h1 {
  margin: 0;
  color: var(--color-white);
  font-size: clamp(42px, 7vw, 72px);
  line-height: var(--line-height-heading);
}

.contact-heading p:last-child {
  margin: var(--space-5) auto 0;
  max-width: 640px;
  color: var(--color-gray-300);
  font-size: var(--font-size-lg);
}

.contact-card {
  width: min(100%, 620px);
  padding: var(--space-7);
  border: var(--border-subtle);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    var(--surface-panel);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.055),
    0 28px 80px rgba(0, 0, 0, 0.28);
}

.contact-form {
  display: grid;
  gap: var(--space-5);
}

.contact-field {
  display: grid;
  gap: var(--space-2);
}

.contact-field label {
  color: var(--color-gray-200);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}

.contact-field input,
.contact-field textarea {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  color: var(--color-white);
  background: rgba(5, 5, 5, 0.34);
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
  transition:
    border-color var(--transition-fast),
    background-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.contact-field input {
  min-height: 52px;
  padding: 0 var(--space-4);
}

.contact-field textarea {
  min-height: 184px;
  resize: vertical;
  padding: var(--space-4);
  font: inherit;
  line-height: 1.55;
}

.contact-field input:focus,
.contact-field textarea:focus {
  border-color: rgba(255, 255, 255, 0.26);
  background: rgba(5, 5, 5, 0.46);
  box-shadow:
    var(--focus-ring),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.contact-signed-in {
  margin: 0;
  padding: var(--space-4);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--color-gray-400);
  background: rgba(255, 255, 255, 0.025);
  font-size: var(--font-size-sm);
}

.contact-signed-in span {
  color: var(--color-gray-100);
  font-weight: var(--font-weight-semibold);
}

.contact-alert {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  color: var(--color-gray-100);
  font-size: var(--font-size-md);
  line-height: 1.5;
}

.contact-alert--success {
  border: 1px solid rgba(88, 197, 132, 0.34);
  background: rgba(88, 197, 132, 0.12);
}

.contact-alert--error {
  border: 1px solid rgba(209, 105, 88, 0.34);
  background: rgba(209, 105, 88, 0.12);
}

.contact-submit {
  margin-top: var(--space-1);
}

.contact-direct {
  margin-top: var(--space-5);
}

.contact-socials {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: var(--border-subtle);
}

.contact-social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 38px;
  padding: 0 var(--space-4);
  border: var(--border-subtle);
  border-radius: 999px;
  color: var(--color-gray-300);
  background: rgba(255, 255, 255, 0.02);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  transition:
    border-color var(--transition-fast),
    color var(--transition-fast),
    background-color var(--transition-fast),
    transform var(--transition-fast);
}

.contact-social:hover {
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--color-white);
  background: rgba(255, 255, 255, 0.045);
  transform: translateY(-1px);
}

.contact-social img {
  width: 18px;
  height: 18px;
  opacity: 0.76;
  object-fit: contain;
}

@media (max-width: 720px) {
  .contact-main {
    padding-top: 108px;
  }

  .contact-card {
    padding: var(--space-5);
  }

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

  .contact-heading h1 {
    font-size: 42px;
  }

  .contact-heading p:last-child {
    font-size: var(--font-size-md);
  }

  .contact-socials {
    justify-content: stretch;
  }

  .contact-social {
    flex: 1 1 140px;
  }
}
