/**
 * Job Details Section
 *
 * Page de détail d'un job avec informations et formulaire de candidature
 *
 * @package Dioqa_UI_Kit
 */

/* ============================================
   Section Container
   ============================================ */

.job-details-section {
  position: relative;
}

/* ============================================
   Title
   ============================================ */

.job-details-title {
  font-family: var(--font-heading, 'Poppins', sans-serif);
  font-size: var(--font-size-display-md, 2.25rem);
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-gray-darker, #212529);
  margin-bottom: 1.5rem;
}

/* ============================================
   Meta Information - Tags style
   ============================================ */

.job-details-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 2.5rem;
}

.job-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-body, 'Roboto', sans-serif);
  font-size: var(--font-size-text-sm, 0.875rem);
  font-weight: 500;
  color: var(--bs-primary);
  background: rgba(var(--bs-primary-rgb), 0.08);
  padding: 0.5rem 1rem;
  border-radius: 50px;
  transition: all 0.2s ease;
}

.job-meta-item:hover {
  background: rgba(var(--bs-primary-rgb), 0.15);
}

.job-meta-item svg {
  width: 16px;
  height: 16px;
  color: var(--bs-primary);
  flex-shrink: 0;
}

/* ============================================
   Content
   ============================================ */

.job-details-content {
  font-family: var(--font-body, 'Roboto', sans-serif);
  font-size: var(--font-size-text-md, 1rem);
  line-height: 1.75;
  color: var(--color-gray-medium, #6b687d);
}

.job-details-content h2,
.job-details-content h3,
.job-details-content h4 {
  font-family: var(--font-heading, 'Poppins', sans-serif);
  font-weight: 500;
  color: var(--color-gray-darker, #212529);
  margin-top: 2rem;
  margin-bottom: 1rem;
}

.job-details-content h2 {
  font-size: var(--font-size-text-xl, 1.25rem);
}

.job-details-content h3 {
  font-size: var(--font-size-text-lg, 1.125rem);
}

.job-details-content h4 {
  font-size: var(--font-size-text-md, 1rem);
}

.job-details-content p {
  margin-bottom: 1rem;
}

.job-details-content ul,
.job-details-content ol {
  margin-bottom: 1.5rem;
  padding-left: 1.25rem;
}

.job-details-content li {
  margin-bottom: 0.5rem;
  position: relative;
}

.job-details-content ul li::marker {
  color: var(--bs-primary);
}

.job-details-content strong {
  font-weight: 600;
  color: var(--color-gray-darker, #212529);
}

/* ============================================
   Application Form Card
   ============================================ */

.job-application-form {
  background: #ffffff;
  border-radius: 16px;
  padding: 2rem;
  position: sticky;
  top: 120px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.application-form-title {
  font-family: var(--font-heading, 'Poppins', sans-serif);
  font-size: var(--font-size-text-xl, 1.25rem);
  font-weight: 500;
  color: var(--color-gray-darker, #212529);
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

/* ============================================
   Gravity Forms Styling (match contact-form-1)
   ============================================ */

.job-application-form .gform_wrapper,
.job-application-form form {
  margin: 0 !important;
}

.job-application-form .gform_fields {
  padding: 0;
  margin: 0;
  list-style: none;
  display: grid;
  gap: 1.25rem;
  grid-row-gap: 1.25rem !important;
  row-gap: 1.25rem !important;
}

.job-application-form .gfield {
  margin: 0 !important;
  padding: 0 !important;
}

.job-application-form .gfield_label,
.job-application-form .gform-field-label {
  color: var(--bs-gray-dark, #212529);
  font-family: var(--font-heading, 'Poppins', sans-serif);
  font-size: var(--text-sm, 0.875rem);
  font-weight: 600;
  margin-bottom: 0.5rem;
  display: inline-block;
  width: 100%;
}

.job-application-form .gfield_required {
  color: var(--bs-primary) !important;
  margin-left: 0.25rem !important;
}

.job-application-form .gfield_required_text {
  display: inline !important;
  color: var(--bs-primary) !important;
}

/* Input fields */
.job-application-form input[type='text'],
.job-application-form input[type='email'],
.job-application-form input[type='tel'],
.job-application-form input[type='url'],
.job-application-form input[type='number'],
.job-application-form textarea,
.job-application-form select {
  width: 100% !important;
  padding: 1rem 1.25rem !important;
  border: none !important;
  border-radius: var(--input-border-radius, 8px) !important;
  font-family: var(--font-body, 'Roboto', sans-serif) !important;
  font-size: var(--text-sm, 0.875rem) !important;
  color: var(--bs-gray-dark, #212529) !important;
  transition: all 0.2s ease !important;
  background: #eceff2 !important;
}

.job-application-form input[type='text']:focus,
.job-application-form input[type='email']:focus,
.job-application-form input[type='tel']:focus,
.job-application-form textarea:focus,
.job-application-form select:focus {
  outline: none !important;
  border: none !important;
  background: #eceff2 !important;
  box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.1) !important;
}

.job-application-form textarea {
  min-height: 120px !important;
  height: 120px !important;
  resize: vertical;
}

/* Placeholders */
.job-application-form input::placeholder,
.job-application-form textarea::placeholder {
  color: var(--bs-gray-medium, #6b687d) !important;
  opacity: 0.7 !important;
}

/* File upload */
.job-application-form .ginput_container_fileupload input[type='file'] {
  width: 100% !important;
  padding: 0.75rem !important;
  background: #eceff2 !important;
  border: none !important;
  border-radius: var(--input-border-radius, 8px) !important;
  font-family: var(--font-body, 'Roboto', sans-serif) !important;
  font-size: var(--text-sm, 0.875rem) !important;
}

.job-application-form .gfield_description,
.job-application-form .gform_fileupload_rules {
  font-size: var(--text-xs, 0.75rem) !important;
  color: var(--bs-gray-medium, #6b687d) !important;
  margin-top: 0.5rem !important;
  font-family: var(--font-body, 'Roboto', sans-serif) !important;
}

/* Submit button */
.job-application-form .gform_footer,
.job-application-form .gform-footer {
  margin: 1.5rem 0 0 0 !important;
  padding: 0 !important;
}

.job-application-form .gform_button,
.job-application-form input[type='submit'] {
  background: var(--bs-primary) !important;
  color: var(--bs-white, #ffffff) !important;
  border: none !important;
  padding: 1rem 2rem !important;
  border-radius: var(--radius-full, 50px) !important;
  font-family: var(--font-heading, 'Poppins', sans-serif) !important;
  font-size: var(--text-md, 1rem) !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  display: block !important;
  width: 100% !important;
}

.job-application-form .gform_button:hover,
.job-application-form input[type='submit']:hover {
  background: var(--bs-primary-dark, var(--bs-primary)) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.3) !important;
}

/* Validation errors */
.job-application-form .gfield_error {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

.job-application-form .gfield_error input,
.job-application-form .gfield_error textarea {
  border: 2px solid #dc3545 !important;
  background: #fff5f5 !important;
}

.job-application-form .validation_message {
  color: #dc3545 !important;
  font-size: var(--text-xs, 0.75rem) !important;
  margin-top: 0.5rem !important;
}

/* ============================================
   Responsive
   ============================================ */

/* Tablettes */
@media (max-width: 991.98px) {
  .job-details-title {
    font-size: var(--font-size-display-sm, 1.875rem);
  }

  .job-application-form {
    position: static;
    margin-top: 3rem;
  }
}

/* Mobile */
@media (max-width: 767.98px) {
  .job-details-title {
    font-size: var(--font-size-text-2xl, 1.5rem);
  }

  .job-details-meta {
    gap: 0.5rem;
  }

  .job-meta-item {
    font-size: var(--font-size-text-xs, 0.75rem);
    padding: 0.375rem 0.75rem;
  }

  .job-meta-item svg {
    width: 14px;
    height: 14px;
  }

  .job-application-form {
    padding: 1.5rem;
    border-radius: 12px;
  }

  .application-form-title {
    font-size: var(--font-size-text-lg, 1.125rem);
  }
}
