/* ==========================================================================
   JP Jobs — Public Styles
   ========================================================================== */

/* ── Variables ── */
:root {
  --jp-primary:       #fd5320;
  --jp-primary-dark:  #d9471a;
  --jp-success:       #198754;
  --jp-danger:        #c43d2f;
  --jp-warning:       #b7791f;
  --jp-gray-50:       #fffaf7;
  --jp-gray-100:      #f6efe9;
  --jp-gray-200:      #eadfd6;
  --jp-gray-400:      #8e8178;
  --jp-gray-600:      #514841;
  --jp-gray-800:      #1f1a17;
  --jp-radius:        12px;
  --jp-shadow:        0 10px 30px rgba(31,26,23,.08);
  --jp-shadow-md:     0 16px 36px rgba(31,26,23,.12);
  --jp-transition:    .2s ease;
}

/* ==========================================================================
   Archive — liste des offres
   ========================================================================== */

.jp-jobs-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* Barre de filtres */
.jp-filters-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: flex-end;
  background: var(--jp-gray-50);
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  padding: 1.25rem;
  margin-bottom: 1.5rem;
  box-sizing: border-box;
  width: 100%;
}

.jp-filter-group {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  flex: 1 1 160px;
  min-width: 0;
  box-sizing: border-box;
}

.jp-filter-group label {
  font-size: .75rem;
  font-weight: 600;
  color: var(--jp-gray-600);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.jp-filter-group select,
.jp-filter-group input[type="text"],
.jp-filter-group input[type="search"] {
  padding: .5rem .75rem;
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  font-size: .9rem;
  background: #fff;
  color: var(--jp-gray-800);
  transition: border-color var(--jp-transition), box-shadow var(--jp-transition);
  width: 100%;
  box-sizing: border-box;
  min-width: 0;
}

/* Barre de recherche seule [jp_search] */
.jp-search-only {
  flex-wrap: nowrap;
  align-items: stretch;
}
.jp-search-field {
  flex: 1 1 auto;
  min-width: 0;
}
.jp-search-input {
  width: 100%;
  box-sizing: border-box;
  height: 2.6rem;
}
.jp-search-only .jp-btn {
  flex-shrink: 0;
  white-space: nowrap;
  align-self: flex-end;
}

@media (max-width: 480px) {
  .jp-search-only          { flex-wrap: wrap; }
  .jp-search-field         { flex: 1 1 100%; }
  .jp-search-only .jp-btn  { width: 100%; justify-content: center; }
  .jp-filters-bar          { padding: .75rem; }
  .jp-filter-group select,
  .jp-filter-group input[type="text"],
  .jp-filter-group input[type="search"] {
    font-size: 16px; /* empêche le zoom automatique iOS */
  }
  .jp-results-count        { font-size: .8rem; }
  .jp-job-card             { padding: .875rem; }
  .jp-job-card-meta        { gap: .3rem; }
  .jp-job-card-footer      { width: 100%; gap: .75rem; }
  .jp-job-card-date        { white-space: normal; }
}

.jp-filter-group select:focus,
.jp-filter-group input:focus {
  outline: none;
  border-color: var(--jp-primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,.15);
}

.jp-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .55rem 1.1rem;
  border: none;
  border-radius: var(--jp-radius);
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--jp-transition), transform var(--jp-transition);
  text-decoration: none;
}

.jp-btn:active { transform: scale(.97); }

.jp-btn-primary {
  background: var(--jp-primary);
  color: #fff;
}
.jp-btn-primary:hover { background: var(--jp-primary-dark); color: #fff; }

.jp-btn-outline {
  background: #fff;
  color: var(--jp-primary);
  border: 1px solid var(--jp-primary);
}
.jp-btn-outline:hover { background: var(--jp-gray-50); }

.jp-btn-danger {
  background: var(--jp-danger);
  color: #fff;
}
.jp-btn-danger:hover { background: #b91c1c; }

/* Compteur de résultats */
.jp-results-count {
  font-size: .85rem;
  color: var(--jp-gray-600);
  margin-bottom: 1rem;
}
.jp-results-count strong { color: var(--jp-gray-800); }

/* Liste des offres */
.jp-jobs-list {
  display: flex;
  flex-direction: column;
  gap: .625rem;
}

/* ── Carte offre ── */
.jp-job-card {
  position: relative; /* requis pour le bouton favoris (addon) positionné en absolute */
  display: flex;
  align-items: stretch; /* stretch : permet à l'aside de s'aligner en bas */
  gap: 1rem;
  background: #fff;
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  padding: .875rem 1.25rem;
  padding-right: 1.5rem;
  min-height: 90px; /* garantit assez de hauteur pour éviter chevauchement cœur/bouton */
  box-shadow: var(--jp-shadow);
  transition: box-shadow var(--jp-transition), border-color var(--jp-transition);
  text-decoration: none;
  color: inherit;
}

.jp-job-card:hover {
  box-shadow: var(--jp-shadow-md);
  border-color: var(--jp-primary);
}

.jp-job-card-logo {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--jp-radius);
  overflow: hidden;
  border: 1px solid var(--jp-gray-200);
  background: var(--jp-gray-50);
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center; /* centrage vertical dans la carte en stretch */
}
.jp-job-card-logo img { width: 100%; height: 100%; object-fit: contain; }
.jp-job-card-logo-placeholder {
  font-size: 1.5rem;
  color: var(--jp-gray-400);
}


.jp-job-card-body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  align-self: stretch;
}

.jp-job-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: auto;
  padding-top: .95rem;
}

.jp-job-card-date {
  font-size: .875rem;
  color: var(--jp-gray-600);
  white-space: nowrap;
}

/* Bouton CTA — maintenant dans le footer de la card */
.jp-job-card-cta-btn {
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--jp-cta-btn-py, .55rem) var(--jp-cta-btn-px, 1.1rem);
  font-size: var(--jp-cta-btn-font-size, .9rem);
  border-radius: var(--jp-cta-btn-radius, 999px);
  margin-left: auto;
}

/* Anciens selectors conservés pour rétrocompat thème/templates */
.jp-job-card-top { flex: 1; }
.jp-job-card-cta,
.jp-job-card-aside { display: none; }
.jp-job-card .jp-job-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--jp-gray-800);
  margin: 0 0 2px 0 !important; /* !important : neutralise les h3 du thème actif */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.jp-job-card .jp-job-card-company {
  font-size: .875rem;
  color: var(--jp-gray-600);
  margin: 0 0 8px 0 !important; /* !important : neutralise les p du thème — 8px d'air avant les badges */
}

.jp-job-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

.jp-badge {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .2rem .6rem;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 600;
  background: var(--jp-gray-100);
  color: var(--jp-gray-600);
}
.jp-badge-contract  { background: #eff6ff; color: #1d4ed8; }
.jp-badge-location  { background: #f0fdf4; color: #15803d; }
.jp-badge-salary    { background: #fefce8; color: #92400e; }
.jp-badge-remote    { background: #f5f3ff; color: #6d28d9; }
.jp-badge-new       { background: var(--jp-primary); color: #fff; }

.jp-badge-experience { background: #fdf4ff; color: #6d28d9; }
.jp-badge-education  { background: #f0f9ff; color: #0369a1; }

.jp-badge[data-term-url] { cursor: pointer; }
.jp-badge[data-term-url]:hover { filter: brightness(.93); }

/* Salary range slider */
.jp-filter-salary label { display: flex; align-items: center; gap: .4rem; }
.jp-salary-display { font-weight: 700; color: var(--jp-primary, #fd5320); }
.jp-salary-range {
  width: 100%;
  accent-color: var(--jp-primary, #fd5320);
  margin-top: .35rem;
  cursor: pointer;
}

/* Pagination */
.jp-pagination {
  display: flex;
  justify-content: center;
  gap: .4rem;
  margin-top: 2rem;
  flex-wrap: wrap;
}
.jp-pagination a,
.jp-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--jp-radius);
  border: 1px solid var(--jp-gray-200);
  font-size: .875rem;
  text-decoration: none;
  color: var(--jp-gray-800);
  transition: background var(--jp-transition);
}
.jp-pagination a:hover       { background: var(--jp-gray-100); }
.jp-pagination .current      { background: var(--jp-primary); color: #fff; border-color: var(--jp-primary); }

/* Liens Précédent / Suivant : largeur automatique pour le texte */
.jp-pagination a.prev,
.jp-pagination span.prev,
.jp-pagination a.next,
.jp-pagination span.next {
  width: auto;
  padding: 0 .75rem;
  white-space: nowrap;
}

/* Loader Ajax */
.jp-loader {
  display: none;
  text-align: center;
  padding: 2rem;
  color: var(--jp-gray-400);
}
.jp-loader.is-loading { display: block; }
.jp-spinner {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  border: 3px solid var(--jp-gray-200);
  border-top-color: var(--jp-primary);
  border-radius: 50%;
  animation: jp-spin .6s linear infinite;
}
@keyframes jp-spin { to { transform: rotate(360deg); } }

/* Aucun résultat */
.jp-no-results {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--jp-gray-400);
}
.jp-no-results svg { width: 3rem; height: 3rem; margin-bottom: .75rem; }
.jp-no-results p { font-size: 1rem; margin: 0; }

/* ==========================================================================
   Single — fiche offre
   ========================================================================== */

.jp-single-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 1.5rem 1rem 0;
}

.jp-single-header {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--jp-gray-200);
}

.jp-single-logo {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: var(--jp-radius);
  overflow: hidden;
  border: 1px solid var(--jp-gray-200);
  background: var(--jp-gray-50);
  display: flex;
  align-items: center;
  justify-content: center;
}
.jp-single-logo img { width: 100%; object-fit: contain; }

.jp-single-title-block h1 {
  font-size: 1.6rem;
  margin: 0 0 .4rem;
  color: var(--jp-gray-800);
}

.jp-single-company {
  font-size: 1rem;
  color: var(--jp-gray-600);
  margin-bottom: .75rem;
}

.jp-single-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

/* Layout 2 colonnes */
.jp-single-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 2rem;
  align-items: start;
}

@media (max-width: 768px) {
  .jp-single-body            { grid-template-columns: 1fr; }
  .jp-single-description     { order: 1; min-width: 0; }
  .jp-single-sidebar         { order: 2; position: static; }
  .jp-single-header          { flex-direction: column; align-items: flex-start; }
  .jp-single-logo            { width: 60px; height: 60px; }
  .jp-single-title-block h1  { font-size: 1.3rem; }
  .jp-stats-row              { grid-template-columns: repeat(2, 1fr); }
  .jp-dashboard-header       { flex-direction: column; align-items: flex-start; }
  .jp-table th,
  .jp-table td               { padding: .5rem .6rem; font-size: .8rem; }
}

/* Description */
.jp-single-description h2,
.jp-single-description h3 {
  color: var(--jp-gray-800);
  margin-top: 1.5rem;
}
.jp-single-description ul { padding-left: 1.25rem; }
.jp-single-description li { margin-bottom: .35rem; }

/* Sidebar infos */
.jp-single-sidebar {
  position: sticky;
  top: 2rem;
}

.jp-info-card {
  background: var(--jp-gray-50);
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  padding: 1.25rem;
  margin-bottom: 1.25rem;
}
.jp-info-card h3 {
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--jp-gray-400);
  margin: 0 0 1rem;
}
.jp-info-row {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .875rem;
  color: var(--jp-gray-800);
  margin-bottom: .75rem;
}
.jp-info-row:last-child { margin-bottom: 0; }
.jp-info-row svg {
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  color: var(--jp-gray-400);
  margin-top: .1rem;
}
.jp-info-label {
  font-size: .75rem;
  color: var(--jp-gray-400);
  display: block;
}

/* Bouton candidater */
.jp-apply-btn-wrap {
  margin-bottom: 1.25rem;
}
.jp-apply-btn-wrap .jp-btn { width: 100%; justify-content: center; font-size: 1rem; padding: .75rem; }

/* Expiration */
.jp-expiry-notice {
  font-size: .8rem;
  color: var(--jp-gray-400);
  text-align: center;
}
.jp-expiry-notice.is-soon { color: var(--jp-warning); }
.jp-expiry-notice.is-expired { color: var(--jp-danger); }

/* Offres similaires */
.jp-related-jobs { margin-top: 3rem; }
.jp-related-jobs h2 { font-size: 1.2rem; margin-bottom: 1rem; }

/* ==========================================================================
   Formulaire de candidature
   ========================================================================== */

.jp-apply-wrap {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 1rem;
}

.jp-form-card {
  background: #fff;
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  box-shadow: var(--jp-shadow-md);
  overflow: hidden;
}

.jp-form-header {
  background: var(--jp-primary);
  color: #fff;
  padding: 1.5rem 2rem;
}
.jp-form-header h2 { margin: 0 0 .25rem; font-size: 1.2rem; }
.jp-form-header p  { margin: 0; opacity: .85; font-size: .875rem; }

.jp-form-body { padding: 2rem; }

.jp-field-group {
  margin-bottom: 1.25rem;
}

.jp-field-group label {
  display: block;
  font-size: .875rem;
  font-weight: 600;
  color: var(--jp-gray-800);
  margin-bottom: .4rem;
}
.jp-field-group label .jp-required { color: var(--jp-danger); margin-left: .15rem; }

.jp-field-group input[type="text"],
.jp-field-group input[type="email"],
.jp-field-group input[type="tel"],
.jp-field-group input[type="url"],
.jp-field-group textarea,
.jp-field-group select {
  width: 100%;
  padding: .6rem .875rem;
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  font-size: .9rem;
  color: var(--jp-gray-800);
  background: #fff;
  transition: border-color var(--jp-transition), box-shadow var(--jp-transition);
  box-sizing: border-box;
}

.jp-field-group input:focus,
.jp-field-group textarea:focus,
.jp-field-group select:focus {
  outline: none;
  border-color: var(--jp-primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,.15);
}

.jp-field-group textarea { min-height: 120px; resize: vertical; }

/* Upload CV */
.jp-upload-area {
  border: 2px dashed var(--jp-gray-200);
  border-radius: var(--jp-radius);
  padding: 2rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: border-color var(--jp-transition), background var(--jp-transition);
  display: block;
  position: relative;
}
.jp-upload-area:hover,
.jp-upload-area.jp-dragover {
  border-color: var(--jp-primary);
  background: #eff6ff;
}
.jp-upload-area svg { width: 2rem; height: 2rem; color: var(--jp-gray-400); margin-bottom: .5rem; }
.jp-upload-area p { margin: 0; font-size: .875rem; color: var(--jp-gray-600); }
.jp-file-name {
  font-size: .8rem;
  color: var(--jp-primary);
  margin-top: .5rem;
  font-weight: 600;
}
.jp-field-label {
  display: block;
  font-size: .875rem;
  font-weight: 600;
  color: var(--jp-gray-800);
  margin-bottom: .4rem;
}

/* RGPD */
.jp-rgpd-check {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .8rem;
  color: var(--jp-gray-600);
  margin-bottom: 1.25rem;
}
.jp-rgpd-check input[type="checkbox"] { margin-top: .15rem; flex-shrink: 0; }

/* Messages retour */
.jp-notice {
  padding: .875rem 1rem;
  border-radius: var(--jp-radius);
  font-size: .875rem;
  margin-bottom: 1rem;
  display: none;
}
.jp-notice.is-visible { display: block; }
.jp-notice-success { background: #f0fdf4; border: 1px solid #86efac; color: #15803d; }
.jp-notice-error   { background: #fef2f2; border: 1px solid #fca5a5; color: var(--jp-danger); }
.jp-notice-info    { background: #eff6ff; border: 1px solid #93c5fd; color: #1d4ed8; }

/* Field error */
.jp-field-error {
  font-size: .75rem;
  color: var(--jp-danger);
  margin-top: .25rem;
  display: none;
}
.jp-field-group.has-error input,
.jp-field-group.has-error textarea,
.jp-field-group.has-error select {
  border-color: var(--jp-danger);
}
.jp-field-group.has-error .jp-field-error { display: block; }

/* Submit */
.jp-form-submit { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.jp-submit-btn  { min-width: 160px; justify-content: center; position: relative; }
.jp-submit-btn .jp-spinner { width: 1rem; height: 1rem; border-width: 2px; display: none; }
.jp-submit-btn.is-loading .jp-spinner { display: inline-block; }
.jp-submit-btn.is-loading .jp-btn-label { opacity: .6; }

/* ==========================================================================
   Formulaire dépôt offre (recruteur)
   ========================================================================== */

.jp-post-job-wrap {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 1rem;
}

.jp-form-steps {
  display: flex;
  gap: 0;
  margin-bottom: 2rem;
  border-radius: var(--jp-radius);
  overflow: hidden;
  border: 1px solid var(--jp-gray-200);
}

.jp-step {
  flex: 1;
  text-align: center;
  padding: .75rem .5rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--jp-gray-400);
  background: var(--jp-gray-50);
  border-right: 1px solid var(--jp-gray-200);
  position: relative;
}
.jp-step:last-child { border-right: none; }
.jp-step.is-active   { background: var(--jp-primary); color: #fff; }
.jp-step.is-complete { background: var(--jp-gray-100); color: var(--jp-success); }

.jp-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  font-size: .7rem;
  margin-right: .3rem;
}
.jp-step.is-active .jp-step-num { background: rgba(255,255,255,.3); }

.jp-form-section { display: none; }
.jp-form-section.is-active { display: block; }

.jp-form-section-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--jp-gray-800);
  margin-bottom: 1.25rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--jp-gray-200);
}

.jp-fields-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 560px) { .jp-fields-row { grid-template-columns: 1fr; } }

.jp-form-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--jp-gray-200);
}

/* ==========================================================================
   Dashboard recruteur
   ========================================================================== */

.jp-dashboard-wrap {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 1rem;
}

.jp-dashboard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.jp-dashboard-header h2 { margin: 0; font-size: 1.3rem; }

.jp-stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.jp-stat-card {
  background: #fff;
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  padding: 1.25rem;
  text-align: center;
  box-shadow: var(--jp-shadow);
}
.jp-stat-value { font-size: 2rem; font-weight: 700; color: var(--jp-primary); line-height: 1; }
.jp-stat-label { font-size: .8rem; color: var(--jp-gray-600); margin-top: .35rem; }

.jp-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--jp-gray-200);
  margin-bottom: 1.5rem;
}
.jp-tab-btn {
  padding: .6rem 1.2rem;
  border: none;
  background: none;
  font-size: .9rem;
  font-weight: 600;
  color: var(--jp-gray-600);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color var(--jp-transition), border-color var(--jp-transition);
}
.jp-tab-btn:hover  { color: var(--jp-primary); }
.jp-tab-btn.active { color: var(--jp-primary); border-bottom-color: var(--jp-primary); }

.jp-tab-panel { display: none; }
.jp-tab-panel.active { display: block; }

/* Tableau candidatures */
.jp-table-responsive { overflow-x: auto; }
.jp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .875rem;
}
.jp-table th {
  text-align: left;
  padding: .625rem .875rem;
  background: var(--jp-gray-50);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--jp-gray-600);
  border-bottom: 1px solid var(--jp-gray-200);
}
.jp-table td {
  padding: .75rem .875rem;
  border-bottom: 1px solid var(--jp-gray-100);
  vertical-align: middle;
}
.jp-table tr:hover td { background: var(--jp-gray-50); }

.jp-status-select {
  padding: .25rem .5rem;
  border-radius: 999px;
  border: 1px solid var(--jp-gray-200);
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
  background: var(--jp-gray-50);
}
.jp-status-select[data-status="new"]       { background: #eff6ff; color: #1d4ed8; border-color: #93c5fd; }
.jp-status-select[data-status="reviewed"]  { background: #fefce8; color: #92400e; border-color: #fde68a; }
.jp-status-select[data-status="interview"] { background: #f5f3ff; color: #6d28d9; border-color: #c4b5fd; }
.jp-status-select[data-status="hired"]     { background: #f0fdf4; color: #15803d; border-color: #86efac; }
.jp-status-select[data-status="rejected"]  { background: #fef2f2; color: var(--jp-danger); border-color: #fca5a5; }

/* Shortcode [jp_count] */
.jp-count-inline {
  display: block;
  font-weight: 700;
  color: var(--jp-primary);
  margin: 0 0 1rem;
}

/* ==========================================================================
   Responsive général
   ========================================================================== */

@media (max-width: 640px) {
  /* Wrapper global */
  .jp-jobs-wrap,
  .jp-single-wrap,
  .jp-apply-wrap,
  .jp-post-job-wrap,
  .jp-dashboard-wrap       { padding: 0 .75rem; box-sizing: border-box; }

  /* Filtres — tout en colonne, pleine largeur */
  .jp-filters-bar          { flex-direction: column; padding: .875rem; gap: .6rem; }
  .jp-filter-group         { flex: 1 1 100%; width: 100%; }
  .jp-filter-group select,
  .jp-filter-group input   { width: 100%; box-sizing: border-box; font-size: 1rem; /* évite le zoom iOS */ }
  /* Reset width sur mobile : ignoré, rendu comme lien discret (voir v1.9.22) */

  /* Cartes offres — mobile : logo + titre côte à côte */
  .jp-job-card             { gap: .875rem; padding: 1rem; }
  .jp-job-card-logo        { width: 44px; height: 44px; flex-shrink: 0; }
  .jp-job-card-title       { font-size: .9rem; }
  .jp-job-card-company     { font-size: .8rem; }
  .jp-job-card-cta .jp-btn { font-size: .8rem; padding: .4rem .875rem; }

  /* Formulaire candidature */
  .jp-form-header          { padding: 1.25rem; }
  .jp-form-body            { padding: 1.1rem; box-sizing: border-box; }
  .jp-fields-row           { grid-template-columns: 1fr; gap: 0; }
  .jp-form-submit          { flex-direction: column; align-items: stretch; }
  .jp-submit-btn           { width: 100%; justify-content: center; }

  /* Upload CV */
  .jp-upload-area          { padding: 1.25rem .75rem; }

  /* Formulaire dépôt offre */
  .jp-form-steps           { flex-wrap: wrap; }
  .jp-step                 { flex: 1 1 45%; font-size: .72rem; padding: .6rem .4rem; }
  .jp-form-nav             { flex-wrap: wrap; gap: .75rem; }
  .jp-form-nav .jp-btn     { flex: 1; justify-content: center; }

  /* Single offre */
  .jp-single-wrap          { padding: 1rem .75rem 0; }
  .jp-single-header        { gap: .75rem; }
  .jp-single-meta          { gap: .35rem; }
  .jp-info-card            { padding: 1rem; }
  .jp-apply-btn-wrap .jp-btn { font-size: .9rem; padding: .65rem; }

  /* Dashboard recruteur */
  .jp-stats-row            { grid-template-columns: repeat(2, 1fr); }
  .jp-tabs                 { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .jp-tab-btn              { white-space: nowrap; padding: .6rem .875rem; }
  .jp-table-responsive     { font-size: .8rem; }

  /* Pagination */
  .jp-pagination           { gap: .25rem; }
  .jp-pagination a,
  .jp-pagination span      { width: 2rem; height: 2rem; font-size: .8rem; }
  /* Prev/Next : largeur automatique sur mobile pour éviter le chevauchement */
  .jp-pagination a.prev,
  .jp-pagination span.prev,
  .jp-pagination a.next,
  .jp-pagination span.next { width: auto !important; padding: 0 .5rem; }

  /* Badges */
  .jp-badge                { font-size: .7rem; padding: .15rem .45rem; }
}


.jp-job-editorial-section {
  margin: 0 0 2.5rem;
}

.jp-job-editorial-section h2 {
  margin: 0 0 .9rem;
  font-size: 1.15rem;
  line-height: 1.3;
  letter-spacing: -.01em;
}

.jp-job-editorial-section p:last-child {
  margin-bottom: 0;
}

.jp-job-profile-content ul,
.jp-job-profile-content ol {
  padding-left: 1.2rem;
}

/* ── Avantages front-end ── */
.jp-i-benefits {
  margin: .5rem 0 0;
  padding-left: 1.2rem;
  display: flex;
  flex-wrap: wrap;
  gap: .3rem .75rem;
  list-style: none;
  padding: 0;
}
.jp-i-benefits li {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 999px;
  padding: .25rem .75rem;
  font-size: .82rem;
  color: #166534;
}
.jp-i-benefits li::before {
  content: "✓";
  font-weight: 700;
}

/* ── Section title standalone (formulaire 1 page recruteur) ── */
.jp-form-section-title {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--jp-gray-400, #9ca3af);
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--jp-border, #e5e7eb);
  margin-bottom: 1rem;
}


/* ==========================================================================
   Premium-ready refinements
   ========================================================================== */

.jp-btn {
  border-radius: 999px;
}

.jp-btn-primary {
  box-shadow: 0 10px 20px rgba(253,83,32,.14);
}

.jp-form-card,
.jp-dashboard-header,
.jp-stat-card,
.jp-table-responsive,
.jp-no-results,
.jp-job-card,
.jp-filters-bar {
  border-radius: 16px;
}

.jp-form-header h2,
.jp-dashboard-header h2 {
  color: var(--jp-gray-800);
}

.jp-form-header p,
.jp-dashboard-header p {
  color: var(--jp-gray-600);
}

.jp-form-section-title {
  color: var(--jp-gray-800);
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: .85rem;
}

.jp-field-group label {
  color: var(--jp-gray-800);
  font-weight: 600;
  text-transform: none;
  letter-spacing: normal;
}

.jp-field-group input[type="text"],
.jp-field-group input[type="email"],
.jp-field-group input[type="search"],
.jp-field-group input[type="tel"],
.jp-field-group select,
.jp-field-group textarea {
  border-radius: 10px;
}

.jp-field-group input:focus,
.jp-field-group select:focus,
.jp-field-group textarea:focus {
  border-color: var(--jp-primary);
  box-shadow: 0 0 0 3px rgba(253,83,32,.12);
}

.jp-dashboard-kicker {
  margin-bottom: .65rem;
}

.jp-table thead th {
  background: #fff7f3;
}

.jp-status-badge {
  border-radius: 999px;
}

.jp-no-results {
  border: 1px solid var(--jp-gray-200);
  background: #fff;
  padding: 1.25rem;
}

.jp-job-card:hover {
  border-color: rgba(253,83,32,.35);
}


@media (max-width: 767px) {
  .jp-job-card-aside {
    width: 100%;
    padding-left: 0;
    padding-top: .75rem;
    border-top: 0;
    justify-content: flex-start;
  }
  .jp-job-card-cta-btn {
    width: 100%;
  }
}


/* ── Capsule dropdown filters (both layouts) ── */

/* Barre en mode capsule : transparente, flex-wrap, gap serré */
.jp-filters-bar,
.jp-filters-bar-compact {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0 0 1rem;
  gap: .5rem;
  align-items: center;
}

/* Wrapper de chaque dropdown capsule */
.jp-filter-dropdown {
  position: relative;
  flex: 0 0 auto;
}

/* Le bouton-capsule déclencheur */
.jp-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .42rem .85rem .42rem .9rem;
  border-radius: 999px;
  border: 1.5px solid var(--jp-gray-200);
  background: #fff;
  font-size: .875rem;
  color: var(--jp-gray-800);
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.3;
  transition: border-color var(--jp-transition), box-shadow var(--jp-transition);
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.jp-filter-pill:hover {
  border-color: var(--jp-gray-400);
}
.jp-filter-pill[aria-expanded="true"],
.jp-filter-pill.is-active {
  border-color: var(--jp-primary);
  color: var(--jp-primary);
  box-shadow: 0 0 0 3px rgba(253,83,32,.12);
}
.jp-filter-pill-label {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.jp-filter-pill-chevron {
  flex-shrink: 0;
  width: 12px;
  height: 12px;
  color: var(--jp-gray-400);
  transition: transform var(--jp-transition);
}
.jp-filter-pill[aria-expanded="true"] .jp-filter-pill-chevron {
  transform: rotate(180deg);
}

/* Panneau déroulant */
.jp-filter-panel {
  position: absolute;
  top: calc(100% + .4rem);
  left: 0;
  min-width: 180px;
  background: #fff;
  border: 1px solid var(--jp-gray-200);
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  z-index: 200;
  overflow: hidden;
  display: none;
}
.jp-filter-panel.is-open { display: block; }
.jp-filter-option {
  display: block;
  width: 100%;
  text-align: left;
  padding: .5rem 1rem;
  font-size: .875rem;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--jp-gray-800);
  transition: background var(--jp-transition);
  line-height: 1.3;
}
.jp-filter-option:hover { background: var(--jp-gray-50); }
.jp-filter-option.is-active {
  color: var(--jp-primary);
  font-weight: 600;
  background: #fff5f2;
}

/* Champ texte city — conserve son label + input classique */
.jp-filter-group-compact { flex: 0 0 auto; }
.jp-filter-group-compact input[type="text"],
.jp-filter-group-compact input[type="search"] {
  border-radius: 999px;
  min-height: 36px;
  padding: .38rem .85rem;
  background: #fff;
  font-size: .875rem;
  border: 1.5px solid var(--jp-gray-200);
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.jp-filter-group-compact label {
  display: none; /* label masqué : le placeholder suffit */
}

/* Filtre salaire : conserve son libellé + range */
.jp-filter-salary { flex: 0 0 auto; min-width: 160px; }
.jp-filters-bar-compact .jp-filter-salary label,
.jp-filter-salary label {
  display: flex;
  font-size: .78rem;
  font-weight: 600;
  color: var(--jp-gray-600);
  gap: .3rem;
  align-items: center;
  margin-bottom: .25rem;
}

/* Reset : style lien discret (voir bloc v1.9.22 en fin de fichier) */
/* .jp-filters-reset { ... } — géré dans v1.9.22 */

/* Card spacing : géré dans le bloc v1.9.15 ci-dessous */

/* Single benefits */
.jp-job-benefits-list {
  margin: .75rem 0 0 1.1rem;
  padding: 0;
}
.jp-job-benefits-list li {
  margin: 0 0 .45rem;
}

@media (max-width: 767px) {
  .jp-job-card {
    padding-right: 1rem;
    min-height: 0;
  }
}


/* v1.9.15 — card layout rationalisé */
.jp-job-card {
  position: relative;
  align-items: stretch;
  /* padding-right réservé au bouton cœur (position:absolute) */
  padding-right: 3.25rem;
}
/* Bouton cœur (favoris addon) */
.jp-fav-btn { top: .875rem; right: .875rem; }

/* Le footer aligne date à gauche, bouton CTA à droite — pas de positionnement absolu */
.jp-job-card-footer {
  justify-content: space-between;
  align-items: center;
}
.jp-job-card-cta-btn {
  position: static;
  margin-left: 0;
  flex-shrink: 0;
}


/* v1.9.18 — CTA conservé + resserrage supplémentaire search/filters */
.jp-job-card-body {
  position: relative;
  padding-bottom: 0;
}
.jp-job-card-footer {
  position: relative;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  min-height: 2.8rem;
  padding-top: .8rem;
}
.jp-job-card-date {
  flex: 1 1 auto;
  min-width: 0;
  padding-right: 8.5rem;
}
.jp-job-card-cta-btn {
  position: absolute;
  right: -2.25rem;
  bottom: 0;
  margin-left: 0;
  align-self: auto;
}

.jp-search-only {
  margin-bottom: .1rem;
  padding-bottom: 0;
}
.jp-search-only + .jp-filters-bar,
.jp-search-only + .jp-filters-bar-compact {
  margin-top: 0;
}
.jp-filters-bar,
.jp-filters-bar-compact {
  padding-bottom: .2rem;
}

.jp-filter-panel {
  min-width: 250px;
  max-width: 320px;
  overflow: hidden;
}
.jp-filter-panel-scroll {
  max-height: 260px;
  overflow-y: auto;
  padding: .35rem 0;
}
.jp-filter-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  width: 100%;
  padding: .45rem .9rem;
}
.jp-filter-option-main {
  display: flex;
  align-items: center;
  gap: .65rem;
  min-width: 0;
  flex: 1 1 auto;
}
.jp-filter-checkbox {
  width: 16px;
  height: 16px;
  margin: 0;
  flex: 0 0 16px;
}
.jp-filter-option-label {
  min-width: 0;
}
.jp-filter-option-count {
  flex: 0 0 auto;
  min-width: 1.85rem;
  padding: .12rem .45rem;
  border-radius: 999px;
  background: var(--jp-gray-100);
  color: var(--jp-gray-600);
  font-size: .78rem;
  text-align: center;
}
.jp-filter-option.is-active {
  color: var(--jp-primary);
  font-weight: 600;
  background: #fff5f2;
}
.jp-filter-option.is-active .jp-filter-option-count {
  background: #ffe4db;
  color: var(--jp-primary);
}


/* ==========================================================================
   v1.9.21 — mobile : filtres + card layout finalisés
   ========================================================================== */

/* ── Bouton reset : masqué par défaut, visible uniquement si filtre actif ── */
/* Rendu comme un petit lien texte discret (style Ideal Profeel) */
.jp-filters-reset {
  display: none !important;
  background: none;
  border: none;
  color: #888;
  font-size: .8rem;
  font-family: inherit;
  cursor: pointer;
  padding: 4px 6px;
  text-decoration: underline;
  text-underline-offset: 2px;
  align-self: center;
  transition: color .15s;
  border-radius: 0;
  box-shadow: none;
}
.jp-filters-reset:hover {
  color: #333;
  background: none;
  transform: none;
}
.jp-filters-reset.is-visible {
  display: inline-flex !important;
}

/*
 * Z-index filter panels : on NE crée PAS de stacking context sur la barre.
 * Le panel (position:absolute) doit vivre dans le root stacking context
 * pour passer au-dessus des cards (position:relative, z-index:auto).
 * Un z-index explicite sur le parent créerait un stacking context isolé
 * qui limiterait l'efficacité du z-index du panel.
 */
.jp-filter-panel {
  z-index: 9999; /* assez haut pour passer au-dessus de tout */
}

@media (max-width: 767px) {

  /* ── Filtres : multi-lignes, alignés à gauche ── */
  .jp-filters-bar-compact {
    flex-direction: row !important;   /* annule le column du breakpoint 640px */
    flex-wrap: wrap !important;       /* plusieurs lignes — PAS de scroll horizontal */
    overflow: visible !important;     /* indispensable : overflow:auto coupe les panels dropdown */
    padding-bottom: .65rem;
    gap: .4rem;
    justify-content: flex-start;
    align-items: center;
    text-align: left;
  }
  /* Plus de scrollbar à masquer */

  /* ── Jauge salary : plus compacte sur mobile ── */
  .jp-filter-salary {
    min-width: 120px;
    max-width: 150px;
  }
  .jp-salary-range {
    width: 100%;
  }

  /* ──────────────────────────────────────────────────────
     CARD MOBILE — layout distinct du desktop/tablette
     Layout : logo 40px à gauche + titre/société à droite
     Badges et footer s'étendent jusqu'aux bords de la card
     ────────────────────────────────────────────────────── */

  .jp-job-card {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: flex-start;
    gap: .75rem;                     /* écart logo ↔ body ; utilisé dans les calculs ci-dessous */
    padding: .875rem;                /* padding uniforme côté card */
    padding-right: .875rem !important; /* pas besoin de 2.75rem : le bouton cœur est
                                          en haut, "View job" est en bas = pas de chevauchement */
    min-height: 0;
    position: relative;
  }

  /* Logo : 40px, calé en haut */
  .jp-job-card-logo {
    flex: 0 0 40px;
    width: 40px;
    height: 40px;
    align-self: flex-start;
    margin-top: 2px; /* micro-alignement optique avec la baseline du titre */
  }

  /* Body : flex-colonne, prend le reste de la largeur */
  .jp-job-card-body {
    flex: 1 1 0;
    min-width: 0;
    position: relative; /* pour le positionnement absolu éventuel des addons */
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  /* Titre : margin-right pour ne pas passer sous le bouton cœur (absolu top-right) */
  .jp-job-card .jp-job-card-title {
    padding-right: 2rem !important;
  }

  /*
   * Badges : restent dans la colonne body (pas de marges négatives).
   * Fix chevauchement logo : les marges négatives causaient un débordement
   * des badges sur le logo en haut à gauche sur téléphone.
   */
  .jp-job-card-meta {
    margin-left: 0;
    width: 100%;
    margin-top: .5rem;
    flex-wrap: wrap;
  }

  /* Footer : pleine largeur du body, sans marge négative */
  .jp-job-card-footer {
    position: static !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    min-height: 0 !important;
    padding-top: .6rem;
    gap: .5rem;
    margin-left: 0;
    width: 100%;
  }

  .jp-job-card-date {
    padding-right: 0 !important;
    flex: 1 1 auto;
    min-width: 0;
    font-size: .8rem;
  }

  /* Bouton "View job" : statique, à droite du footer, jamais full-width */
  .jp-job-card-cta-btn {
    position: static !important;
    width: auto !important;
    right: auto !important;
    bottom: auto !important;
    margin-left: auto;
    flex-shrink: 0;
    font-size: .78rem;
    padding: .38rem .8rem;
  }
}


/* ==========================================================================
   v1.9.22 — comportements Ideal Profeel : options vides + badge
   ========================================================================== */

/* ── Options vides (count = 0, comportement IP) ── */
.jp-filter-option.jp-filter-option--empty {
  cursor: not-allowed;
  pointer-events: none;
}
.jp-filter-option.jp-filter-option--empty .jp-filter-option-label,
.jp-filter-option.jp-filter-option--empty .jp-filter-option-count {
  opacity: .38;
}
.jp-filter-option.jp-filter-option--empty:hover {
  background: transparent;
}
.jp-filter-option.jp-filter-option--empty .jp-filter-checkbox {
  opacity: .38;
}

/* ── Badge nombre d'options sélectionnées (sur le bouton-pill) ── */
.jp-filter-pill-badge {
  display: none;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 50%;
  background: var(--jp-primary);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  line-height: 1;
  margin-left: .1rem;
  flex-shrink: 0;
}
.jp-filter-pill-badge.is-visible {
  display: inline-flex;
}


/* ==========================================================================
   v1.9.23 — barre de recherche icône loupe (style Ideal Profeel)
   ========================================================================== */

/* Conteneur search — remplace jp-search-only + jp-btn-primary Search */
.jp-search-bar-wrap {
  display: flex;
  align-items: center;
  gap: .65rem;
  background: #fff;
  border: 1px solid var(--jp-gray-200);
  border-radius: var(--jp-radius);
  padding: .7rem 1rem;
  margin-bottom: .75rem;
  box-shadow: var(--jp-shadow);
  box-sizing: border-box;
  width: 100%;
}

.jp-search-bar-icon {
  flex-shrink: 0;
  color: var(--jp-gray-400);
  width: 16px;
  height: 16px;
}

/* Override : l'input search dans le nouveau wrapper — pleine largeur, sans bordure */
.jp-search-bar-wrap .jp-search-input {
  flex: 1 1 auto;
  min-width: 0;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  font-size: 1rem;
  color: var(--jp-gray-800);
  border-radius: 0 !important;
  height: auto !important;
  line-height: 1.4;
}

.jp-search-bar-wrap .jp-search-input::placeholder {
  color: var(--jp-gray-400);
}

.jp-search-bar-wrap:focus-within {
  border-color: var(--jp-primary);
  box-shadow: 0 0 0 3px rgba(253,83,32,.12);
}

/* Le gros bouton Search n'existe plus — supprimer les règles qui lui étaient liées */
.jp-search-submit { display: none !important; }

@media (max-width: 640px) {
  .jp-search-bar-wrap {
    padding: .6rem .875rem;
  }
}

/* ==========================================================================
   v1.9.24 — search bar : toujours row sur une seule ligne (PC / tablette / mobile)
   ========================================================================== */

/* La barre de recherche ne porte plus la classe jp-filters-bar depuis la correction.
   Ces règles garantissent une ligne unique sur tous les breakpoints. */
.jp-search-bar-wrap {
  flex-direction: row !important;
  flex-wrap: nowrap !important;   /* empêche l'icône et l'input de sauter à la ligne */
  text-align: left;
}

/* L'input doit rester pleine largeur dans le wrapper, sans border ni shadow */
.jp-search-bar-wrap .jp-search-input {
  min-width: 0;          /* crucial : permet à flex:1 de rétrécir en dessous de sa taille intrinsèque */
}

/* Compteur d'offres : alignement gauche même si le thème impose text-align:center */
.jp-results-count,
.jp-count-inline {
  text-align: left;
}
