/* Contact — form layout */
.contact-layout {
  display: grid;
  gap: var(--space-10);
  align-items: start;
  padding-bottom: var(--space-12);
}

@media (min-width: 900px) {
  .contact-layout {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: var(--space-12);
  }
}

.contact-aside {
  position: sticky;
  top: calc(var(--nav-height) + var(--space-4));
}

.contact-aside p {
  margin: 0 0 var(--space-4);
  max-width: 28rem;
}

.contact-form-panel {
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-subtle);
  background: var(--color-surface);
  padding: var(--space-6);
  box-shadow: var(--shadow-soft);
}

[data-theme="dark"] .contact-form-panel {
  background: var(--color-surface);
  box-shadow: var(--shadow-elevated);
}

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

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

@media (min-width: 520px) {
  .contact-form-grid--split {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.contact-form-actions {
  margin-top: var(--space-2);
}

.contact-form-actions .btn {
  width: 100%;
}

@media (min-width: 480px) {
  .contact-form-actions .btn {
    width: auto;
  }
}
