/* ==========================================================================
   CONSULTING FORM COMPONENT
   Used in: consulting.html
   Strategic consulting request form (more detailed than contact form)
   ========================================================================== */

.consulting-form-section {
  padding: 6rem 1.5rem;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-90) 100%);
  color: var(--color-bg-light);
}

.consulting-form-section .section-header__label,
.consulting-form-section .section-header__title {
  color: var(--color-bg-light);
}

.consulting-form-section .section-header__title::after {
  background-color: var(--color-secondary-30);
}

.consulting-form-wrapper {
  max-width: 56rem;
  margin: 4rem auto 0;
  background-color: var(--color-bg-light);
  border-radius: 1rem;
  padding: 3rem 2rem;
  box-shadow: 0 1.25rem 2.5rem var(--color-black-15);
}

@media (min-width: 768px) {
  .consulting-form-wrapper {
    padding: 4rem 3rem;
  }
}

.consulting-form__intro {
  text-align: center;
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--color-primary-10);
}

.consulting-form__intro-title {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-text-dark);
  margin-bottom: 0.5rem;
}

.consulting-form__intro-text {
  color: var(--color-primary-60);
  font-size: 1rem;
}

/* Form Grid Layout */
.consulting-form {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.consulting-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .consulting-form__row--two-col {
    grid-template-columns: 1fr 1fr;
  }
}

/* Form Fields */
.consulting-form__group {
  display: flex;
  flex-direction: column;
}

.consulting-form__label {
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-dark);
  margin-bottom: 0.5rem;
}

.consulting-form__label--required::after {
  content: ' *';
  color: #c44;
}

.consulting-form__input,
.consulting-form__select,
.consulting-form__textarea {
  width: 100%;
  padding: 0.875rem 1rem;
  border: 2px solid var(--color-primary-15);
  border-radius: 0.5rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-text-dark);
  background-color: var(--color-bg-light);
  transition: var(--transition);
}

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

.consulting-form__select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='%231a2b3c' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.5rem center;
  background-size: 1.5rem;
  padding-right: 2.5rem;
  cursor: pointer;
}

.consulting-form__textarea {
  min-height: 10rem;
  resize: vertical;
  line-height: 1.5;
}

/* Budget Range */
.consulting-form__budget-options {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .consulting-form__budget-options {
    grid-template-columns: repeat(2, 1fr);
  }
}

.budget-option {
  position: relative;
}

.budget-option__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.budget-option__label {
  display: block;
  padding: 1rem 1.25rem;
  border: 2px solid var(--color-primary-15);
  border-radius: 0.5rem;
  cursor: pointer;
  transition: var(--transition);
  text-align: center;
  font-weight: 600;
  font-size: 0.875rem;
}

.budget-option__input:checked + .budget-option__label {
  border-color: var(--color-primary);
  background-color: var(--color-primary-3);
  color: var(--color-primary);
}

.budget-option__label:hover {
  border-color: var(--color-primary);
}

/* Checkbox Group */
.consulting-form__checkbox-group {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.consulting-form__checkbox {
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid var(--color-primary-30);
  border-radius: 0.25rem;
  cursor: pointer;
  margin-top: 0.125rem;
  flex-shrink: 0;
}

.consulting-form__checkbox:checked {
  accent-color: var(--color-primary);
}

.consulting-form__checkbox-label {
  font-size: 0.875rem;
  color: var(--color-primary-70);
  line-height: 1.5;
}

.consulting-form__checkbox-label a {
  color: var(--color-primary);
  text-decoration: underline;
}

/* Submit Button */
.consulting-form__submit {
  width: 100%;
  padding: 1rem 2rem;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-90) 100%);
  color: var(--color-bg-light);
  border: none;
  border-radius: 0.5rem;
  font-weight: 700;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  cursor: pointer;
  transition: var(--transition);
  margin-top: 1rem;
}

.consulting-form__submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.625rem 1.25rem var(--color-primary-20);
}

.consulting-form__submit:active {
  transform: translateY(0);
}

/* Help Text */
.consulting-form__help {
  font-size: 0.8125rem;
  color: var(--color-primary-50);
  margin-top: 0.25rem;
  font-style: italic;
}

.consulting-form__help--centered {
  text-align: center;
  margin-top: 1rem;
}

/* Textarea Modifiers */
.consulting-form__textarea--large {
  min-height: 6rem;
}
