/* Contact Us page-specific styles */

.contact-hero-section {
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-success) 100%);
  color: #fff;
  padding: var(--space-12) 0 var(--space-8) 0;
  margin-bottom: var(--space-8);
}
.contact-hero-section .accent {
  background: transparent;
  color: #fff;
  font-size: var(--font-size-2xl);
  letter-spacing: 1px;
  padding: 0;
}
.contact-hero-section .lead {
  font-size: var(--font-size-lg);
  max-width: 50ch;
  margin-top: var(--space-2);
}

.contact-grid-section {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  padding-bottom: var(--space-12);
}
.contact-grid-section > .card {
  min-width: 0;
}

@media (max-width: 900px) {
  .contact-grid-section {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}

.info-list {
  font-size: var(--font-size-base);
  margin-bottom: var(--space-4);
  line-height: 1.8;
}
.info-list a {
  text-decoration: underline;
  color: var(--color-primary-hover);
}

.business-hours table {
  font-size: var(--font-size-sm);
  line-height: 1.3;
  margin-top: var(--space-2);
}
.business-hours td {
  padding: 2px 12px 2px 0;
  white-space: nowrap;
}

.social-media {
  margin-top: var(--space-4);
}
.social-media .social-list {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-1);
  padding-left: 0;
}
.social-media a {
  background: var(--color-neutral-200);
  border-radius: 50%;
  padding: var(--space-1);
  display: inline-flex;
  align-items: center;
  transition: background var(--transition-normal);
  color: var(--color-primary);
  line-height: 0;
}
.social-media a:hover, .social-media a:focus-visible {
  background: var(--color-primary);
  color: #fff;
}

.contact-form-container form,
.support-services form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.field-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.field-group label {
  font-weight: 600;
  color: var(--color-primary-hover);
}
textarea,
input[type="text"],
input[type="email"] {
  font-size: var(--font-size-base);
  resize: vertical;
}
.form-actions {
  align-items: center;
}
.feedback-message {
  min-height: 1.6em;
  font-size: var(--font-size-sm);
  color: var(--color-success);
  margin-left: var(--space-2);
}
button.button-alt {
  background: var(--color-neutral-200);
  color: var(--color-text);
  box-shadow: var(--shadow-xs);
}
button.button-alt:hover, button.button-alt:focus-visible {
  background: var(--color-neutral-400);
  color: #fff;
}

.divider {
  border: 0;
  border-bottom: 1px solid var(--color-neutral-300);
  margin: var(--space-4) 0;
}

.location-section address {
  font-size: var(--font-size-base);
  font-style: normal;
}
.location-section .location-map {
  margin-top: var(--space-2);
}
.location-section small {
  display: block;
  margin-top: var(--space-1);
  font-size: var(--font-size-xs);
  color: var(--color-neutral-400);
}

.support-services .support-options {
  margin-bottom: var(--space-4);
  padding-left: 0;
  font-size: var(--font-size-base);
  line-height: 1.7;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.testimonials-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.testimonials-list blockquote {
  background: var(--color-neutral-200);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-sm);
  margin: 0;
  padding: var(--space-3) var(--space-4);
}
.testimonials-list footer {
  color: var(--color-primary-hover);
  font-size: var(--font-size-sm);
  font-style: italic;
  margin-top: var(--space-1);
}

/* Extra: visually enhance the main accent on mobile */
@media (max-width: 600px) {
  .contact-hero-section {
    padding: var(--space-8) 0 var(--space-4) 0;
    margin-bottom: var(--space-4);
  }
  .contact-hero-section .accent {
    font-size: var(--font-size-xl);
  }
}
