/* ============================================
   CONTACT FORM COMPONENT
   - Form inputs, labels, textareas
   - Select dropdown
   - Checkbox consent
   - Submit button
   ============================================ */

.contact-form {
  padding: 0;
  max-width: 100%;
}

/* Form Group */
.contact-form__group {
  margin-bottom: 1.75rem;
}

/* Labels */
.contact-form__group .label,
.label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 0.625rem;
  color: var(--color-text);
}

/* Input Fields */
.contact-form__input,
.contact-form__textarea {
  width: 100%;
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  padding: 0.875rem 1.25rem;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  color: var(--color-text);
  transition: all 0.3s ease;
  font-family: var(--font-sans);
  line-height: 1.5;
}

.contact-form__input:focus,
.contact-form__textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-5);
}

.contact-form__input::placeholder,
.contact-form__textarea::placeholder {
  color: var(--color-text-light);
  opacity: 0.6;
}

/* Textarea */
.contact-form__textarea {
  resize: vertical;
  min-height: 140px;
  line-height: 1.6;
}

/* Select */
.contact-form__input[type="file"] {
  padding: 0.75rem 1.25rem;
  cursor: pointer;
  font-size: 0.875rem;
}

select.contact-form__input {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%231A2B3C' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.25rem center;
  padding-right: 3rem;
}

/* Small text */
.contact-form__group small,
.contact-form__helper-text {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  color: var(--color-text-light);
}

/* Submit Button */
.contact-form__submit {
  width: 100%;
  margin-top: 1rem;
}

/* Checkbox Label */
.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  cursor: pointer;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-text);
}

.checkbox-label input[type="checkbox"] {
  margin-top: 0.25rem;
  width: 1.125rem;
  height: 1.125rem;
  border-radius: 0.25rem;
  border: 1px solid var(--color-border);
  cursor: pointer;
  flex-shrink: 0;
  accent-color: var(--color-primary);
}

.checkbox-label span {
  flex: 1;
}

.checkbox-label a {
  text-decoration: underline;
  color: var(--color-primary);
  transition: opacity 0.3s ease;
}

.checkbox-label a:hover {
  opacity: 0.7;
}

/* Form Message */
.contact-form__message {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  display: none;
}

.contact-form__message--success {
  display: block;
  background-color: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.contact-form__message--error {
  display: block;
  background-color: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

/* Legacy class support */
.form-group {
  margin-bottom: 1.75rem;
}

.form-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 0.625rem;
  color: var(--color-text);
}

.form-input,
.form-textarea,
.form-select {
  width: 100%;
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  padding: 0.875rem 1.25rem;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  color: var(--color-text);
  transition: all 0.3s ease;
  font-family: var(--font-sans);
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-5);
}
