/* ======================= Contact Us Page Styles ======================= */
.contact-hero {
  margin-top: var(--space-16);
  margin-bottom: var(--space-8);
  text-align: center;
}
.contact-hero .intro {
  font-size: var(--font-lg);
  max-width: 630px;
  margin: var(--space-6) auto 0 auto;
  color: var(--color-gray-200);
}

.contact-section-heading {
  margin-top: 0;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-10);
}
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}
/* Contact info + socials */
.contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  min-width: 0;
}
.contact-list {
  list-style: none;
  margin: 0 0 var(--space-2) 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  color: var(--color-text);
}
.contact-social {
  margin-top: var(--space-2);
}
.contact-social-label {
  font-weight: 600;
  margin-right: var(--space-2);
}
.social-links {
  display: flex;
  gap: var(--space-3);
  padding: 0;
  list-style: none;
  margin: var(--space-2) 0 0 0;
}
.social-links li a {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  background: none;
  color: var(--color-primary);
  font-weight: 500;
}
.social-links li a .icon {
  width: 20px; height: 20px;
  display: inline-block;
}

/* Contact Form */
.contact-form-section {
  min-width: 0;
}
.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.form-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.contact-form label {
  font-weight: 500;
}
.contact-form input,
.contact-form select,
.contact-form textarea {
  margin-top: var(--space-1);
}
.form-consent {
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-sm);
}
.form-status {
  min-height: 1.5em;
  font-size: var(--font-sm);
  color: var(--color-success);
}
.form-status.error {
  color: var(--color-danger);
}

/* Support & FAQ grid */
.contact-support-faq-grid {
  margin-bottom: var(--space-10);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
}
@media (max-width: 900px) {
  .contact-support-faq-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}
.support-info {
  min-width: 0;
}
.support-list {
  margin: var(--space-2) 0 0 0;
  padding: 0 0 0 var(--space-4);
  color: var(--color-text);
}
/* FAQ */
.faq-section details {
  border: 1px solid var(--color-gray-700);
  border-radius: var(--radius);
  margin-bottom: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  transition: border var(--transition);
}
.faq-section details[open] {
  border-color: var(--color-primary);
  background: var(--color-surface);
}
.faq-section summary {
  font-weight: 500;
  color: var(--color-primary);
  cursor: pointer;
  outline: none;
}
.faq-section .faq-answer {
  margin-top: var(--space-2);
  color: var(--color-gray-200);
  font-size: var(--font-sm);
}

/* Career & Partner grid */
.career-partner-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-10);
}
@media (max-width: 900px) {
  .career-partner-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}
.careers-list, .partners-list {
  margin-top: var(--space-2);
  margin-bottom: var(--space-2);
  padding-left: var(--space-4);
  color: var(--color-text);
}
.privacy-short {
  margin-bottom: var(--space-16);
}
@media (max-width: 600px) {
  .card {
    padding: var(--space-4) !important;
  }
  .contact-hero {
    margin-top: var(--space-8);
  }
}
/* Form accessibility tweaks for icons */
input[type="checkbox"] {
  accent-color: var(--color-primary);
}
/* Button full width on mobile */
@media (max-width: 400px) {
  .contact-form button {
    width: 100%;
  }
}
