/**
 * Contact Form Section Styles
 *
 * @package wbl
 */

/* ================================================================
   CONTACT FORM SECTION
   ================================================================ */

.contact-content {
  padding: var(--spacing-xxl) 0;
  background-color: var(--color-white);
}

.contact-form {
  background-color: var(--color-white);
  border-radius: var(--radius-large);
  padding: var(--spacing-xl);
  box-shadow: var(--shadow-light);
  border: 1px solid rgba(115, 53, 16, 0.1);
}

.contact-form__header {
  margin-bottom: var(--spacing-xl);
  text-align: center;
}

.contact-form__title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  margin-bottom: var(--spacing-sm);
}

.contact-form__description {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  line-height: var(--line-height-body);
}

.contact-form__content {
  width: 100%;
}

/* ================================================================
   FORM STYLES
   ================================================================ */

.contact-form__form {
  width: 100%;
}

.contact-form__fields {
  display: grid;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-xl);
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.contact-form__label {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.contact-form__required {
  color: var(--color-error);
  font-size: var(--font-size-body);
}

.contact-form__input,
.contact-form__textarea,
.contact-form__select {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 2px solid rgba(115, 53, 16, 0.2);
  border-radius: var(--radius-medium);
  font-size: var(--font-size-body);
  font-family: inherit;
  background-color: var(--color-white);
  color: var(--color-text-primary);
  transition: all var(--transition-medium);
}

.contact-form__input:focus,
.contact-form__textarea:focus,
.contact-form__select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(115, 53, 16, 0.1);
}

.contact-form__input:hover,
.contact-form__textarea:hover,
.contact-form__select:hover {
  border-color: var(--color-primary);
}

.contact-form__textarea {
  resize: vertical;
  min-height: 120px;
}

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

/* ================================================================
   FORM VALIDATION STYLES
   ================================================================ */

.contact-form__field--error .contact-form__input,
.contact-form__field--error .contact-form__textarea,
.contact-form__field--error .contact-form__select {
  border-color: var(--color-error);
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.contact-form__field--success .contact-form__input,
.contact-form__field--success .contact-form__textarea,
.contact-form__field--success .contact-form__select {
  border-color: var(--color-success);
  box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.1);
}

.contact-form__error-message {
  font-size: var(--font-size-small);
  color: var(--color-error);
  margin-top: var(--spacing-xs);
}

.contact-form__success-message {
  font-size: var(--font-size-small);
  color: var(--color-success);
  margin-top: var(--spacing-xs);
}

/* ================================================================
   FORM ACTIONS
   ================================================================ */

.contact-form__actions {
  text-align: center;
}

.contact-form__submit {
  min-width: 200px;
  padding: var(--spacing-sm) var(--spacing-xl);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  border: none;
  border-radius: var(--radius-medium);
  cursor: pointer;
  transition: all var(--transition-medium);
  position: relative;
  overflow: hidden;
}

.contact-form__submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.contact-form__submit:not(:disabled):hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-heavy);
}

/* ================================================================
   SHORTCODE FORM INTEGRATION
   ================================================================ */

.contact-form__shortcode {
  width: 100%;
}

/* Fluent Forms Styles */
.contact-form__shortcode .ff-el-form-check-container,
.contact-form__shortcode .ff-el-form-group {
  margin-bottom: var(--spacing-lg);
}

.contact-form__shortcode .ff-el-form-control {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 2px solid rgba(115, 53, 16, 0.2);
  border-radius: var(--radius-medium);
  font-size: var(--font-size-body);
  font-family: inherit;
  background-color: var(--color-white);
  color: var(--color-text-primary);
  transition: all var(--transition-medium);
}

.contact-form__shortcode .ff-el-form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(115, 53, 16, 0.1);
}

.contact-form__shortcode .ff-el-form-control:hover {
  border-color: var(--color-primary);
}

.contact-form__shortcode .ff-el-input--label {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-xs);
  display: block;
}

.contact-form__shortcode .ff-el-is-required .ff-el-input--label::after {
  content: " *";
  color: var(--color-error);
  font-weight: var(--font-weight-bold);
}

.contact-form__shortcode textarea.ff-el-form-control {
  resize: vertical;
  min-height: 120px;
}

.contact-form__shortcode .ff-btn-submit {
  min-width: 200px;
  padding: var(--spacing-sm) var(--spacing-xl);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  background-color: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-medium);
  cursor: pointer;
  transition: all var(--transition-medium);
  text-transform: none;
}

.contact-form__shortcode .ff-btn-submit:hover {
  background-color: var(--color-text-primary);
  transform: translateY(-2px);
  box-shadow: var(--shadow-heavy);
}

.contact-form__shortcode .ff-btn-submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.contact-form__shortcode .ff-message-success {
  background-color: rgba(40, 167, 69, 0.1);
  color: var(--color-success);
  border: 1px solid var(--color-success);
  border-radius: var(--radius-medium);
  padding: var(--spacing-md);
  margin-top: var(--spacing-md);
}

.contact-form__shortcode .ff-message-container {
  margin-top: var(--spacing-md);
}

.contact-form__shortcode .ff-el-is-error .ff-el-form-control {
  border-color: var(--color-error);
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.contact-form__shortcode .ff-el-tooltip {
  color: var(--color-error);
  font-size: var(--font-size-small);
  margin-top: var(--spacing-xs);
}

.contact-form__shortcode .ff-el-group .ff-el-form-check-input {
  margin-left: var(--spacing-xs);
}

.contact-form__shortcode .ff-el-form-check-label {
  font-size: var(--font-size-body);
  color: var(--color-text-primary);
  margin-bottom: 0;
}

/* Contact Form 7 Styles */
.contact-form__shortcode .wpcf7-form {
  display: grid;
  gap: var(--spacing-lg);
}

.contact-form__shortcode .wpcf7-form-control-wrap {
  position: relative;
  display: block;
  width: 100%;
}

.contact-form__shortcode .wpcf7-form-control {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 2px solid rgba(115, 53, 16, 0.2);
  border-radius: var(--radius-medium);
  font-size: var(--font-size-body);
  font-family: inherit;
  background-color: var(--color-white);
  color: var(--color-text-primary);
  transition: all var(--transition-medium);
}

.contact-form__shortcode .wpcf7-form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(115, 53, 16, 0.1);
}

.contact-form__shortcode .wpcf7-textarea {
  resize: vertical;
  min-height: 120px;
}

.contact-form__shortcode .wpcf7-submit {
  min-width: 200px;
  padding: var(--spacing-sm) var(--spacing-xl);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  border: none;
  border-radius: var(--radius-medium);
  cursor: pointer;
  transition: all var(--transition-medium);
}

.contact-form__shortcode .wpcf7-not-valid {
  border-color: var(--color-error) !important;
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1) !important;
}

.contact-form__shortcode .wpcf7-validation-errors {
  background-color: rgba(220, 53, 69, 0.1);
  color: var(--color-error);
  border: 1px solid var(--color-error);
  border-radius: var(--radius-medium);
  padding: var(--spacing-md);
  margin-top: var(--spacing-md);
}

.contact-form__shortcode .wpcf7-mail-sent-ok {
  background-color: rgba(40, 167, 69, 0.1);
  color: var(--color-success);
  border: 1px solid var(--color-success);
  border-radius: var(--radius-medium);
  padding: var(--spacing-md);
  margin-top: var(--spacing-md);
}

/* ================================================================
   RESPONSIVE DESIGN
   ================================================================ */

/* Tablet Styles */
@media (max-width: 992px) {
  .contact-content {
    padding: var(--spacing-xl) 0;
  }
  
  .contact-form {
    padding: var(--spacing-lg);
  }
  
  .contact-form__title {
    font-size: var(--font-size-h4);
  }
}

/* Mobile Styles */
@media (max-width: 768px) {
  .contact-content {
    padding: var(--spacing-lg) 0;
  }
  
  .contact-form {
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
  }
  
  .contact-form__header {
    margin-bottom: var(--spacing-lg);
  }
  
  .contact-form__title {
    font-size: var(--font-size-h5);
  }
  
  .contact-form__description {
    font-size: var(--font-size-small);
  }
  
  .contact-form__fields {
    gap: var(--spacing-md);
  }
  
  .contact-form__submit {
    width: 100%;
    min-width: auto;
  }
  
  /* Fluent Forms Mobile Adjustments */
  .contact-form__shortcode .ff-btn-submit {
    width: 100%;
    min-width: auto;
  }
  
  .contact-form__shortcode .ff-el-form-control {
    padding: var(--spacing-xs) var(--spacing-sm);
  }
}

/* Small Mobile Styles */
@media (max-width: 480px) {
  .contact-form__input,
  .contact-form__textarea,
  .contact-form__select {
    padding: var(--spacing-xs) var(--spacing-sm);
  }
}


/* ================================================================
   ANIMATION SUPPORT
   ================================================================ */

@media (prefers-reduced-motion: no-preference) {
  .contact-form {
    animation: fadeInUp 1s ease-out;
  }
  
  .contact-form__field {
    animation: fadeInUp 0.8s ease-out;
  }
  
  .contact-form__field:nth-child(1) { animation-delay: 0.1s; }
  .contact-form__field:nth-child(2) { animation-delay: 0.2s; }
  .contact-form__field:nth-child(3) { animation-delay: 0.3s; }
  .contact-form__field:nth-child(4) { animation-delay: 0.4s; }
  
  .contact-form__actions {
    animation: fadeInUp 1s ease-out 0.5s both;
  }
}

/* ================================================================
   ACCESSIBILITY
   ================================================================ */

.contact-form__input:focus,
.contact-form__textarea:focus,
.contact-form__select:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.contact-form__submit:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 4px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .contact-form {
    border: 2px solid var(--color-text-secondary);
  }
  
  .contact-form__input,
  .contact-form__textarea,
  .contact-form__select {
    border-width: 3px;
  }
}

/* Screen reader improvements */
.contact-form__field[aria-invalid="true"] .contact-form__label::after {
  content: " (خطأ)";
  color: var(--color-error);
  font-weight: var(--font-weight-bold);
}