.contact-hero-layout {
  align-items: center;
}

.contact-hero-card-wrapper {
  max-width: 480px;
  margin-left: auto;
}

.contact-summary-card {
  height: 100%;
}

.small-text {
  font-size: var(--font-size-sm);
}

.contact-grid-main {
  align-items: flex-start;
  gap: var(--space-8);
}

.contact-aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact-details-card h2,
.contact-office-card h3,
.contact-hours-card h2,
.contact-accessibility-card h2,
.contact-faq-card h2,
.contact-newsletter-card h3 {
  font-size: var(--font-size-lg);
}

.contact-link-strong {
  font-weight: 600;
}

.contact-phone {
  font-size: var(--font-size-lg);
  font-weight: 600;
}

.form-field-group {
  margin-bottom: var(--space-4);
}

.contact-office-card,
.contact-hours-card,
.contact-accessibility-card,
.contact-faq-card,
.contact-newsletter-card {
  margin-top: var(--space-3);
}

.contact-hours-list {
  margin: 0;
}

.contact-hours-row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--gray-200);
}

.contact-hours-row:last-child {
  border-bottom: none;
}

.contact-hours-row dt {
  font-weight: 600;
}

.contact-hours-row dd {
  margin: 0;
  text-align: right;
}

.contact-faq-item {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--gray-200);
}

.contact-faq-item:last-of-type {
  border-bottom: none;
}

.contact-faq-item summary {
  cursor: pointer;
  font-weight: 600;
}

.contact-faq-item summary::-webkit-details-marker {
  display: none;
}

.contact-faq-item summary::before {
  content: "+";
  display: inline-block;
  margin-right: var(--space-2);
  font-weight: 600;
}

.contact-faq-item[open] summary::before {
  content: "–";
}

.contact-faq-item p {
  margin-top: var(--space-2);
}

.contact-engagement {
  max-width: 960px;
}

.contact-engagement-grid {
  align-items: center;
  gap: var(--space-8);
}

.newsletter-form-row {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.newsletter-form-row .input {
  flex: 1 1 auto;
}

@media (max-width: 768px) {
  .contact-hero-card-wrapper {
    margin-top: var(--space-6);
    max-width: 100%;
  }

  .contact-grid-main,
  .contact-grid-secondary,
  .contact-engagement-grid {
    gap: var(--space-6);
  }

  .contact-hours-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .contact-hours-row dd {
    text-align: left;
  }

  .newsletter-form-row {
    flex-direction: column;
  }

  .newsletter-form-row .btn {
    width: 100%;
    justify-content: center;
  }
}
