.intro-text {
  font-size: var(--body-large-size);
  color: var(--secondary-text);
  line-height: var(--body-large-height);
  margin-bottom: var(--spacing-xxxl);
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.contact-info {
  margin-top: var(--spacing-xl);
  text-align: center;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  background-color: var(--surface);
  padding: var(--spacing-xxxl);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-md);
}

.developer-info {
  background-color: var(--alternate);
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-md);
  margin-bottom: var(--spacing-xxxl);
  border-left: 4px solid var(--primary-text);
}

.developer-info p {
  margin: var(--spacing-sm) 0;
  font-size: var(--body-large-size);
}

.info-label {
  font-size: var(--label-large-size);
  font-weight: var(--label-large-weight);
  color: var(--secondary-text);
  display: inline;
  margin-right: var(--spacing-sm);
}

.info-value {
  font-size: var(--body-large-size);
  font-weight: var(--body-large-weight);
  color: var(--primary-text);
  display: inline;
}

.section-title {
  font-family: var(--font-family-headings);
  font-size: var(--headline-medium-size);
  font-weight: var(--headline-medium-weight);
  color: var(--primary-text);
  margin-top: var(--spacing-xl);
  margin-bottom: var(--spacing-lg);
  text-align: left;
}

.section-description {
  font-size: var(--body-medium-size);
  color: var(--secondary-text);
  line-height: var(--body-medium-height);
  margin-bottom: var(--spacing-lg);
  text-align: left;
}

.form-section {
  text-align: left;
  margin-top: var(--spacing-xl);
}

.reason-buttons {
  display: flex;
  gap: var(--spacing-md);
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-bottom: var(--spacing-lg);
}

.reason-btn {
  padding: var(--spacing-md) var(--spacing-lg);
  background-color: var(--alternate);
  color: var(--primary-text);
  border: 2px solid var(--alternate);
  border-radius: var(--border-radius-sm);
  font-size: var(--label-medium-size);
  font-weight: var(--label-medium-weight);
  cursor: pointer;
  transition: all var(--transition-fast);
  flex: 1;
  min-width: 180px;
}

.reason-btn:hover {
  background-color: var(--surface);
  border-color: var(--primary-text);
}

.reason-btn.active {
  background-color: var(--secondary);
  border-color: var(--tertiary);
  color: var(--primary);
  font-weight: 600;
}

.form-group {
  margin-bottom: var(--spacing-lg);
}

.form-label {
  display: block;
  font-size: var(--label-large-size);
  font-weight: var(--label-large-weight);
  color: var(--primary-text);
  margin-bottom: var(--spacing-sm);
  text-align: left;
}

.topic-select {
  width: 100%;
  padding: var(--spacing-md);
  background-color: var(--primary-background);
  color: var(--primary-text);
  border: 2px solid var(--alternate);
  border-radius: var(--border-radius-sm);
  font-size: var(--body-medium-size);
  font-family: var(--font-family-body);
  cursor: pointer;
  transition: border-color var(--transition-fast);
}

.topic-select:focus {
  outline: none;
  border-color: var(--primary-text);
}

.message-textarea {
  width: 100%;
  min-height: 180px;
  padding: var(--spacing-md);
  background-color: var(--primary-background);
  color: var(--primary-text);
  border: 2px solid var(--alternate);
  border-radius: var(--border-radius-sm);
  font-size: var(--body-medium-size);
  font-family: var(--font-family-body);
  resize: vertical;
  transition: border-color var(--transition-fast);
}

.message-textarea:focus {
  outline: none;
  border-color: var(--primary-text);
}

.message-textarea::placeholder {
  color: var(--secondary-text);
}

.button-container {
  text-align: center;
  margin-top: var(--spacing-xxxl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--alternate);
}

@media (max-width: 768px) {
  .contact-info {
    padding: var(--spacing-xl);
  }

  .reason-buttons {
    flex-direction: column;
  }

  .reason-btn {
    width: 100%;
  }
}

/* Animation de chargement */
.loading-dots {
  display: inline-block;
  animation: loadingPulse 1.5s ease-in-out infinite;
}

@keyframes loadingPulse {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}

.info-value.error {
  color: var(--error);
}
