/* Contact Us page specific styles for BestLineCA */

.contact-page-main {
  margin-top: var(--space-16);
  margin-bottom: var(--space-16);
}
.contact-header {
  margin-bottom: var(--space-10);
  max-width: 720px;
}
.contact-header h1 {
  margin-bottom: var(--space-4);
}
.contact-flex {
  display: flex;
  gap: var(--space-12);
  align-items: flex-start;
  flex-wrap: wrap;
}
.contact-card-section {
  flex: 2 1 350px;
  min-width: 320px;
  max-width: 500px;
}
.contact-info-faq {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  flex: 3 1 320px;
  min-width: 270px;
  max-width: 570px;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.form-field label {
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--space-1);
  font-family: var(--font-family-head);
  font-size: var(--font-size-base);
  letter-spacing: 0.5px;
}
.req-star {
  color: var(--color-danger);
  margin-left: 2px;
  font-size: var(--font-size-sm);
}
.contact-form input,
.contact-form textarea {
  font-size: 1rem;
}
.contact-form textarea {
  min-height: 130px;
  resize: vertical;
}
.contact-form .button {
  margin-top: var(--space-3);
  align-self: flex-end;
}
.contact-success-msg {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  color: var(--color-success);
  background: rgba(86,227,159,0.1);
  font-size: var(--font-size-lg);
  font-family: var(--font-family-head);
  text-align: center;
  box-shadow: var(--shadow-xs);
}

.contact-info {
  margin-bottom: var(--space-6);
}
.contact-info-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.contact-info-list li {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  font-size: var(--font-size-base);
}
.ci-label {
  color: var(--color-primary);
  min-width: 84px;
  font-weight: 700;
}
.ci-value {
  color: var(--color-gray-100);
  word-break: break-word;
}
.contact-info-list a {
  text-decoration: underline;
  color: var(--color-success);
  font-weight: 500;
}
.contact-info-list a:hover,
.contact-info-list a:focus-visible {
  color: var(--color-danger);
}

.contact-faq h2 {
  margin-top: 0;
  margin-bottom: var(--space-4);
}
.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.faq-list dt {
  color: var(--color-primary);
  font-family: var(--font-family-head);
  font-weight: 700;
  font-size: var(--font-size-base);
  margin-bottom: var(--space-1);
}
.faq-list dd {
  color: var(--color-gray-100);
  margin-bottom: var(--space-2);
  margin-left: 0;
  margin-right: 0;
  font-size: var(--font-size-base);
}

@media (max-width: 900px) {
  .contact-flex {
    flex-direction: column;
    gap: var(--space-8);
  }
  .contact-card-section,
  .contact-info-faq {
    max-width: 100%;
    min-width: 0;
  }
}
@media (max-width: 650px) {
  .contact-page-main {
    margin-top: var(--space-8);
    margin-bottom: var(--space-8);
    padding-left: var(--space-1);
    padding-right: var(--space-1);
  }
  .contact-header p {
    font-size: var(--font-size-sm);
  }
}

/* Improve focus ring for button inside form */
.contact-form .button:focus-visible {
  box-shadow: 0 0 0 2.5px var(--color-success);
  outline: none;
}
