/* ============================================================
   Job Manager - Modern Style  v1.3.0
   Author : JNS Web Solutions
   License: GPL-2.0+
   Compatible avec tout site utilisant WP Job Manager.
   Personnalisez les couleurs via les variables :root en section 1.
============================================================ */

/* ============================================================
   1. VARIABLES
============================================================ */
:root {
  --jms-primary:        #0f1b4c;
  --jms-primary-light:  #1a2d6b;
  --jms-accent:         #c9a84c;
  --jms-accent-light:   #e8c97a;
  --jms-bg:             #f4f6fb;
  --jms-white:          #ffffff;
  --jms-border:         #e2e8f0;
  --jms-text:           #2d3748;
  --jms-muted:          #718096;
  --jms-green-bg:       #dcfce7;
  --jms-green-text:     #15803d;
  --jms-green-border:   #bbf7d0;
  --jms-red-bg:         #fef2f2;
  --jms-red-text:       #dc2626;
  --jms-red-border:     #fecaca;
  --jms-radius-sm:      8px;
  --jms-radius-md:      10px;
  --jms-radius-lg:      14px;
  --jms-radius-xl:      16px;
}

/* ============================================================
   2a. TITRE DE PAGE
============================================================ */
h1.entry-title {
  position: relative;
  color: var(--jms-primary);
}
h1.entry-title::after {
  content: '';
  display: block;
  width: 56px;
  height: 4px;
  background: linear-gradient(90deg, var(--jms-accent), var(--jms-accent-light));
  border-radius: 2px;
  margin: .45rem auto 0;
}

/* ============================================================
   2b. FORMULAIRE DE RECHERCHE
============================================================ */
.job_filters {
  background: var(--jms-white) !important;
  border: 1px solid var(--jms-border);
  border-radius: var(--jms-radius-xl);
  box-shadow: 0 0 8px rgba(15,27,76,.08) !important;
  padding: 1.5rem 2rem 0rem;
  margin-bottom: 2rem;
}
.gjm-filters-wrapper {
  margin-top: 8px !important;
}
form.gjm-features-enabled i.gjm-locator-btn {
  top: 13px !important;
  right: 10px !important;
}
.job_filters input[type="text"],
.job_filters input[type="search"] {
  border: 2px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .75rem 1.1rem !important;
  font-size: .95rem !important;
  color: var(--jms-text) !important;
  background: var(--jms-bg) !important;
  box-shadow: none !important;
  transition: border-color .25s, box-shadow .25s;
}
.job_filters input[type="text"]:focus,
.job_filters input[type="search"]:focus {
  border-color: var(--jms-primary) !important;
  box-shadow: 0 0 0 3px rgba(15,27,76,.12) !important;
  background: var(--jms-white) !important;
  outline: none;
}
.job_filters [type="submit"],
.job_filters button[type="submit"] {
  display: block !important;
  width: 100% !important;
  padding: .9rem 2rem !important;
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: var(--jms-white) !important;
  border: none !important;
  border-radius: var(--jms-radius-md) !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow .25s !important;
  margin-top: .5rem !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.15) !important;
}
.job_filters [type="submit"]:hover,
.job_filters button[type="submit"]:hover {
  box-shadow: 0 0 10px rgba(15,27,76,.30) !important;
}
.job_filters .job_types {
  border: none !important;
}

/* ============================================================
   2c. SELECT2
============================================================ */
.job_filters .select2-container {
  width: 100% !important;
}
.job_filters .select2-selection--single {
  background: var(--jms-bg) !important;
  border: 2px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  height: auto !important;
  padding: .72rem 2.5rem .72rem 1.1rem !important;
  transition: border-color .25s, box-shadow .25s !important;
  display: flex !important;
  align-items: center !important;
}
.job_filters .select2-container--open .select2-selection--single,
.job_filters .select2-selection--single:focus {
  border-color: var(--jms-primary) !important;
  box-shadow: 0 0 0 3px rgba(15,27,76,.12) !important;
  outline: none !important;
  background: var(--jms-white) !important;
}
.job_filters .select2-selection__rendered {
  color: var(--jms-text) !important;
  font-size: .95rem !important;
  line-height: 1.4 !important;
  padding: 0 !important;
}
.job_filters .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%) !important;
  right: 14px !important;
  height: auto !important;
}
.job_filters .select2-selection__arrow b {
  border-color: var(--jms-primary) transparent transparent transparent !important;
  border-width: 6px 5px 0 5px !important;
  margin-top: -3px !important;
}
.job_filters .select2-container--open .select2-selection__arrow b {
  border-color: transparent transparent var(--jms-primary) transparent !important;
  border-width: 0 5px 6px 5px !important;
  margin-top: -3px !important;
}
.select2-dropdown {
  border: 2px solid var(--jms-primary) !important;
  border-radius: var(--jms-radius-md) !important;
  box-shadow: 0 8px 24px rgba(15,27,76,.18) !important;
  overflow: hidden !important;
}
.select2-results__option {
  padding: .6rem 1.1rem !important;
  font-size: .92rem !important;
  color: var(--jms-text) !important;
  transition: background .15s !important;
}
.select2-results__option--highlighted,
.select2-results__option[aria-selected="true"] {
  background: var(--jms-primary) !important;
  color: var(--jms-white) !important;
}
.select2-search--dropdown .select2-search__field {
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-sm) !important;
  padding: .4rem .7rem !important;
}
form.gjm-features-enabled div.gjm-filters-wrapper div.gjm-filter-wrapper:first-child {
  margin-right: 1em !important;
}

/* ============================================================
   2d. CARTE GOOGLE MAPS (liste)
============================================================ */
.gjm-map {
  border-radius: var(--jms-radius-xl) !important;
  overflow: hidden !important;
  box-shadow: 0 6px 24px rgba(15,27,76,.14) !important;
  margin-bottom: 2rem !important;
  border: 1px solid var(--jms-border) !important;
}

/* ============================================================
   2e. FICHES MISSIONS
============================================================ */
ul.job_listings {
  border: none !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
}
ul.job_listings li.job_listing {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  box-shadow: 0 0 8px rgba(15,27,76,.08) !important;
  transition: box-shadow .25s ease, border-color .25s ease !important;
  overflow: hidden !important;
  padding: 0 !important;
}
ul.job_listings li.job_listing:hover {
  box-shadow: 0 0 10px rgba(15,27,76,.2) !important;
}
ul.job_listings li.job_listing > a {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  padding: 1.25rem 1.5rem 1.25rem 100px !important;
  text-decoration: none !important;
  color: inherit !important;
  gap: 1rem !important;
  min-height: 80px !important;
  overflow: hidden !important;
}
ul.job_listings li.job_listing > a .company_logo {
  width: 60px !important;
  height: 60px !important;
  object-fit: contain !important;
  border-radius: var(--jms-radius-sm) !important;
  border: 1px solid var(--jms-border) !important;
  background: var(--jms-bg) !important;
  padding: 4px !important;
}
ul.job_listings li.job_listing > a .position {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}
ul.job_listings li.job_listing > a .position h3 {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  margin: 0 0 .2rem !important;
  line-height: 1.3 !important;
  white-space: wrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
ul.job_listings li.job_listing > a .position .company {
  font-size: .85rem !important;
  color: var(--jms-muted) !important;
  margin: 0 !important;
  display: block !important;
}
ul.job_listings li.job_listing > a .position .company strong {
  color: var(--jms-text) !important;
  font-weight: 600 !important;
}
ul.job_listings li.job_listing > a .location {
  font-size: .82rem !important;
  color: var(--jms-muted) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: 200px !important;
  flex-shrink: 0 !important;
}
ul.job_listings li.job_listing > a .meta {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  text-align: right !important;
  min-width: 110px !important;
  flex-shrink: 0 !important;
}
ul.job_listings li.job_listing > a .meta li {
  font-size: .78rem !important;
  color: var(--jms-muted) !important;
  list-style: none !important;
  white-space: nowrap !important;
}

/* ============================================================
   2f. BADGE POSTULE
============================================================ */
span.job-manager-applications-applied-notice {
  background: var(--jms-green-bg) !important;
  color: var(--jms-green-text) !important;
  border: 1px solid var(--jms-green-border) !important;
  border-radius: 100px !important;
  padding: .2rem .7rem 0.2rem 0.4rem !important;
  font-size: .76rem !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
}

/* ============================================================
   2g. BOUTON ALERTE + MASQUER RSS
============================================================ */
.showing_jobs {
  background: transparent !important;
  border: none !important;
}
.showing_jobs a.alert {
  display: inline-flex !important;
  align-items: center !important;
  gap: .5rem !important;
  background: transparent !important;
  color: var(--jms-primary) !important;
  border: 1px solid var(--jms-primary) !important;
  border-radius: var(--jms-radius-sm) !important;
  padding: .45rem 1.1rem !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  letter-spacing: .03em !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow .2s !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.18) !important;
}
.showing_jobs a.alert::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0f3";
  font-size: .8rem;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.showing_jobs a.alert:hover {
  box-shadow: 0 0 10px rgba(15,27,76,.28) !important;
}
.showing_jobs a.rss_link {
  display: none !important;
}

/* ============================================================
   3a. META LOCALISATION + DATE (page poste)
============================================================ */
ul.job-listing-meta.meta {
  list-style: none !important;
  padding: 0 !important;
  margin: .5rem 0 1.75rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 1.5rem !important;
  flex-wrap: wrap !important;
}
ul.job-listing-meta.meta li {
  display: flex !important;
  align-items: center !important;
  gap: .35rem !important;
  font-size: .88rem !important;
  color: var(--jms-muted) !important;
  list-style: none !important;
}
ul.job-listing-meta.meta li.location a {
  color: var(--jms-primary) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border-bottom: 1.5px solid var(--jms-accent) !important;
  transition: color .2s !important;
}
ul.job-listing-meta.meta li.location a:hover {
  color: var(--jms-accent) !important;
}

/* ============================================================
   3b. BANDEAU DEJA POSTULE
============================================================ */
.job-manager-applications-applied-notice {
  background: var(--jms-green-bg) !important;
  color: var(--jms-green-text) !important;
  border: 1px solid var(--jms-green-border) !important;
  border-radius: var(--jms-radius-md) !important;
  padding: 0.2rem 0.7rem 0.2rem 0.4rem !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  margin-bottom: 0rem !important;
  display: flex !important;
  align-items: center !important;
  gap: .5rem !important;
}

/* ============================================================
   3c. FORMULAIRE SIGNETS
============================================================ */
.wp-job-manager-bookmarks-form {
  border: none !important;
  border-width: 0 !important;
  margin: 2em 0 !important;
  overflow: visible !important;
  background: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
form.wp-job-manager-bookmarks-form a.bookmark-notice,
form.wp-job-manager-bookmarks-form a.remove-bookmark {
  display: inline-flex !important;
  align-items: center !important;
  gap: .5rem !important;
  background: transparent !important;
  color: var(--jms-primary) !important;
  border: 1px solid var(--jms-primary) !important;
  border-radius: var(--jms-radius-sm) !important;
  padding: .4rem 1rem !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  letter-spacing: .03em !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow .2s !important;
  box-shadow: 0 2px 6px rgba(15,27,76,.12) !important;
}
form.wp-job-manager-bookmarks-form a.bookmark-notice:hover,
form.wp-job-manager-bookmarks-form a.remove-bookmark:hover {
  box-shadow: 0 0 10px rgba(15,27,76,.25) !important;
  color: var(--jms-primary) !important;
  text-decoration: none !important;
}

/* ============================================================
   3d. BLOC ENTREPRISE
   Prefixe .single_job_listing pour ne pas affecter la liste.
============================================================ */
.single_job_listing div.company {
  display: flex !important;
  align-items: center !important;
  gap: 1.25rem !important;
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  padding: 1.1rem 1.4rem !important;
  margin-bottom: 1.5rem !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.07) !important;
}
.single_job_listing div.company picture.company_logo {
  width: 72px !important;
  height: 72px !important;
  min-width: 72px !important;
  position: relative !important;
  display: block !important;
  flex-shrink: 0 !important;
}
.single_job_listing div.company picture.company_logo img {
  position: static !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  border-radius: var(--jms-radius-sm) !important;
  border: 1px solid var(--jms-border) !important;
  background: var(--jms-bg) !important;
  padding: 4px !important;
  display: block !important;
}
.single_job_listing div.company .company_header {
  flex: 1 !important;
}
.single_job_listing div.company .company_header p.name {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  margin: 0 !important;
}
.single_job_listing .company .tagline {
  margin: 0 !important;
}

/* ============================================================
   3e. CARTE GOOGLE MAPS (poste single)
============================================================ */
.gjm-map-wrapper.single-page .gjm-map {
  border-radius: var(--jms-radius-lg) !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(15,27,76,.12) !important;
  border: 1px solid var(--jms-border) !important;
  margin-bottom: 1.5rem !important;
}

/* ============================================================
   3f. DESCRIPTION DE LA MISSION
============================================================ */
.job_description {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  padding: 1.4rem 1.6rem !important;
  margin-bottom: 1.5rem !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.06) !important;
  font-size: .95rem !important;
  color: var(--jms-text) !important;
  line-height: 1.7 !important;
}

/* ============================================================
   3g. BOUTON M'ALERTER
============================================================ */
p.job-manager-single-alert-link {
  margin-top: .5rem !important;
  margin-bottom: 2rem !important;
}
p.job-manager-single-alert-link a {
  display: inline-flex !important;
  align-items: center !important;
  gap: .5rem !important;
  background: transparent !important;
  color: var(--jms-primary) !important;
  border: 1px solid var(--jms-primary) !important;
  border-radius: var(--jms-radius-sm) !important;
  padding: .45rem 1.1rem !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  letter-spacing: .03em !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  transition: box-shadow .2s !important;
  box-shadow: 0 2px 6px rgba(15,27,76,.12) !important;
}
p.job-manager-single-alert-link a::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0f3";
  font-size: .8rem;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
p.job-manager-single-alert-link a:hover {
  box-shadow: 0 0 10px rgba(15,27,76,.28) !important;
  text-decoration: none !important;
  color: var(--jms-primary) !important;
}

/* ============================================================
   4. BOUTON DE CANDIDATURE
============================================================ */
.single_job_listing .job_application .application_button,
.single_job_listing .application .application_button,
.job_application .application_button,
.application .application_button {
  font-size: 1rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: #ffffff !important;
  border-radius: var(--jms-radius-sm) !important;
  padding: .8rem 1.8rem !important;
  box-shadow: 0 2px 6px rgba(15,27,76,.12) !important;
  border: none !important;
  cursor: pointer !important;
  transition: box-shadow .2s !important;
  display: inline-block !important;
}
.single_job_listing .job_application .application_button:hover,
.single_job_listing .application .application_button:hover,
.job_application .application_button:hover,
.application .application_button:hover {
  box-shadow: 0 0 12px rgba(15,27,76,.30) !important;
}

/* ============================================================
   5. FORMULAIRE DE CANDIDATURE
============================================================ */
.job-manager-form:not(.wp-job-manager-bookmarks-form),
form.job-manager-form:not(.wp-job-manager-bookmarks-form) {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  padding: 1.75rem 2rem !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.07) !important;
  margin-top: 1.5rem !important;
}
.job-manager-form h3 {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  margin-bottom: 1.25rem !important;
  padding-bottom: .75rem !important;
  border-bottom: 2px solid var(--jms-border) !important;
}
.job-manager-form input[type="text"],
.job-manager-form input[type="email"],
.job-manager-form input[type="tel"],
.job-manager-form input[type="url"],
.job-manager-form input[type="number"],
.job-manager-form textarea,
.job-manager-form select {
  width: 100% !important;
  border: 2px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .72rem 1.1rem !important;
  font-size: .95rem !important;
  color: var(--jms-text) !important;
  background: var(--jms-bg) !important;
  box-shadow: none !important;
  transition: border-color .25s, box-shadow .25s !important;
}
.job-manager-form input:focus,
.job-manager-form textarea:focus,
.job-manager-form select:focus {
  border-color: var(--jms-primary) !important;
  box-shadow: 0 0 0 3px rgba(15,27,76,.10) !important;
  background: var(--jms-white) !important;
  outline: none !important;
}
.job-manager-form label {
  font-size: .88rem !important;
  font-weight: 600 !important;
  color: var(--jms-text) !important;
  margin-bottom: .35rem !important;
  display: block !important;
}
.job-manager-form input[type="submit"],
.job-manager-form button[type="submit"] {
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: var(--jms-white) !important;
  border: none !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .85rem 2rem !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow .25s !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.15) !important;
  width: auto !important;
}
.job-manager-form input[type="submit"]:hover,
.job-manager-form button[type="submit"]:hover {
  box-shadow: 0 0 12px rgba(15,27,76,.30) !important;
}

/* ============================================================
   6. CONNEXION / INSCRIPTION CANDIDAT
============================================================ */
.account-sign-in,
.account-sign-in form,
.job-manager-login,
.job-manager-register,
#login-form,
#register-form {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  padding: 2rem !important;
  box-shadow: 0 2px 12px rgba(15,27,76,.08) !important;
  max-width: 480px !important;
  margin: 0 auto !important;
}
.account-sign-in h2,
.job-manager-login h2,
.job-manager-register h2 {
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  margin-bottom: 1.5rem !important;
  text-align: center !important;
}
.account-sign-in input[type="text"],
.account-sign-in input[type="email"],
.account-sign-in input[type="password"],
.job-manager-login input,
.job-manager-register input {
  width: 100% !important;
  border: 2px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .72rem 1.1rem !important;
  font-size: .95rem !important;
  color: var(--jms-text) !important;
  background: var(--jms-bg) !important;
  box-shadow: none !important;
  transition: border-color .25s, box-shadow .25s !important;
}
.account-sign-in input:focus,
.job-manager-login input:focus,
.job-manager-register input:focus {
  border-color: var(--jms-primary) !important;
  box-shadow: 0 0 0 3px rgba(15,27,76,.10) !important;
  background: var(--jms-white) !important;
  outline: none !important;
}
.account-sign-in input[type="submit"],
.account-sign-in button[type="submit"],
.job-manager-login input[type="submit"],
.job-manager-register input[type="submit"] {
  width: 100% !important;
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: var(--jms-white) !important;
  border: none !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .85rem 2rem !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow .25s !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.15) !important;
  margin-top: .5rem !important;
}
.account-sign-in input[type="submit"]:hover,
.job-manager-login input[type="submit"]:hover,
.job-manager-register input[type="submit"]:hover {
  box-shadow: 0 0 12px rgba(15,27,76,.30) !important;
}

/* ============================================================
   7. DASHBOARD CANDIDAT - ONGLETS
============================================================ */
.candidate-dashboard-tabs,
ul.candidate-dashboard-tabs,
.job-manager-tabs,
ul.job-manager-tabs {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  display: flex !important;
  gap: .5rem !important;
  flex-wrap: wrap !important;
  border-bottom: 2px solid var(--jms-border) !important;
}
.candidate-dashboard-tabs li a,
.job-manager-tabs li a {
  display: inline-block !important;
  padding: .6rem 1.2rem !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  color: var(--jms-muted) !important;
  text-decoration: none !important;
  border-radius: var(--jms-radius-sm) var(--jms-radius-sm) 0 0 !important;
  border-bottom: 3px solid transparent !important;
  transition: color .2s, border-color .2s !important;
  margin-bottom: -2px !important;
}
.candidate-dashboard-tabs li.active a,
.candidate-dashboard-tabs li a:hover,
.job-manager-tabs li.active a,
.job-manager-tabs li a:hover {
  color: var(--jms-primary) !important;
  border-bottom-color: var(--jms-accent) !important;
}

/* Tableau des candidatures (dashboard employeur) */
table.my-applications th,
table.job-applications th {
  font-size: .78rem !important;
  font-weight: 700 !important;
  color: var(--jms-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  padding: .5rem 1rem !important;
  border-bottom: 2px solid var(--jms-border) !important;
  text-align: left !important;
}
table.my-applications td,
table.job-applications td {
  padding: .85rem 1rem !important;
  font-size: .9rem !important;
  color: var(--jms-text) !important;
  border-top: 1px solid var(--jms-border) !important;
}
table.my-applications tr:hover td,
table.job-applications tr:hover td {
  background: #f8faff !important;
}
.status-pending  { color: #d97706 !important; font-weight: 600 !important; }
.status-approved { color: var(--jms-green-text) !important; font-weight: 600 !important; }
.status-rejected { color: var(--jms-red-text) !important; font-weight: 600 !important; }

/* ============================================================
   8. FORMULAIRE CV / INSCRIPTION CANDIDAT
============================================================ */
form#submit-resume-form,
.resume-submit-form {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  padding: 1.75rem 2rem !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.07) !important;
}
form#submit-resume-form fieldset,
.resume-submit-form fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 0 1.25rem !important;
}
form#submit-resume-form legend,
.resume-submit-form legend {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  margin-bottom: .75rem !important;
  padding-bottom: .4rem !important;
  border-bottom: 2px solid var(--jms-border) !important;
  width: 100% !important;
}
form#submit-resume-form input[type="text"],
form#submit-resume-form input[type="email"],
form#submit-resume-form input[type="tel"],
form#submit-resume-form textarea,
form#submit-resume-form select,
.resume-submit-form input[type="text"],
.resume-submit-form textarea,
.resume-submit-form select {
  width: 100% !important;
  border: 2px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .72rem 1.1rem !important;
  font-size: .95rem !important;
  color: var(--jms-text) !important;
  background: var(--jms-bg) !important;
  box-shadow: none !important;
  transition: border-color .25s, box-shadow .25s !important;
}
form#submit-resume-form input:focus,
form#submit-resume-form textarea:focus,
form#submit-resume-form select:focus {
  border-color: var(--jms-primary) !important;
  box-shadow: 0 0 0 3px rgba(15,27,76,.10) !important;
  background: var(--jms-white) !important;
  outline: none !important;
}
form#submit-resume-form input[type="submit"],
.resume-submit-form input[type="submit"] {
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: var(--jms-white) !important;
  border: none !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .85rem 2.5rem !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow .25s !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.15) !important;
}
form#submit-resume-form input[type="submit"]:hover,
.resume-submit-form input[type="submit"]:hover {
  box-shadow: 0 0 12px rgba(15,27,76,.30) !important;
}

/* ============================================================
   9. MESSAGES GLOBAUX
============================================================ */
.job-manager-message,
p.job-manager-message {
  border-radius: var(--jms-radius-md) !important;
  padding: .85rem 1.25rem !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  margin-bottom: 1.25rem !important;
  border-left: 4px solid var(--jms-accent) !important;
  background: #fefdf5 !important;
  color: var(--jms-text) !important;
  border-top: 1px solid #f3eed5 !important;
  border-right: 1px solid #f3eed5 !important;
  border-bottom: 1px solid #f3eed5 !important;
}
.job-manager-error,
p.job-manager-error {
  border-radius: var(--jms-radius-md) !important;
  padding: .85rem 1.25rem !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  margin-bottom: 1.25rem !important;
  border-left: 4px solid var(--jms-red-text) !important;
  background: var(--jms-red-bg) !important;
  color: var(--jms-red-text) !important;
  border-top: 1px solid var(--jms-red-border) !important;
  border-right: 1px solid var(--jms-red-border) !important;
  border-bottom: 1px solid var(--jms-red-border) !important;
}
.job-manager-info {
  border-left: 4px solid var(--jms-primary) !important;
  background: #f0f4ff !important;
  color: var(--jms-primary) !important;
  border-top: 1px solid #d0dbf5 !important;
  border-right: 1px solid #d0dbf5 !important;
  border-bottom: 1px solid #d0dbf5 !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .85rem 1.25rem !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  margin-bottom: 1.25rem !important;
}

/* ============================================================
   10. PAGINATION
============================================================ */
.job-manager-pagination,
.jobs-pagination {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: .35rem !important;
  margin-top: 2rem !important;
}
.job-manager-pagination a,
.job-manager-pagination span,
.jobs-pagination a,
.jobs-pagination span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: var(--jms-radius-sm) !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border: 1.5px solid var(--jms-border) !important;
  color: var(--jms-text) !important;
  transition: background .2s, border-color .2s, color .2s !important;
}
.job-manager-pagination a:hover,
.jobs-pagination a:hover {
  background: var(--jms-bg) !important;
  border-color: var(--jms-primary) !important;
  color: var(--jms-primary) !important;
}
.job-manager-pagination .current,
.jobs-pagination .current {
  background: var(--jms-primary) !important;
  border-color: var(--jms-primary) !important;
  color: var(--jms-white) !important;
}

/* ============================================================
   11. PAGE "MES CANDIDATURES" — table job-manager-past-applications
============================================================ */

/* Conteneur Elementor */
.elementor-shortcode:has(.job-manager-past-applications) {
  background: var(--jms-white);
  border-radius: var(--jms-radius-lg);
  padding: 2rem;
  box-shadow: 0 0 8px rgba(15,27,76,.08);
  border: 1px solid var(--jms-border);
  overflow: hidden;
}

/* Table */
.job-manager-past-applications {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: .95rem;
}

/* En-têtes
   reset.css cible : table tbody > tr:nth-child(2n+1) > th  (spécificité 0,0,3,1)
   On bat avec :    table.job-manager-past-applications thead > tr > th (0,1,2,2) + !important */
table.job-manager-past-applications thead > tr > th,
table.job-manager-past-applications th {
  background: var(--jms-primary) !important;
  color: var(--jms-white) !important;
  font-weight: 600 !important;
  font-size: .78rem !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  padding: 14px 18px !important;
  border: none !important;
  text-align: left !important;
}
table.job-manager-past-applications thead > tr > th:first-child,
table.job-manager-past-applications th:first-child {
  border-radius: var(--jms-radius-md) 0 0 0 !important;
}
table.job-manager-past-applications thead > tr > th:last-child,
table.job-manager-past-applications th:last-child {
  border-radius: 0 var(--jms-radius-md) 0 0 !important;
}

/* Lignes / cellules
   reset.css cible : table tbody > tr:nth-child(2n+1) > td  (0,0,3,1)
                     table tbody tr:hover > td               (0,0,3,1)
   On bat avec table.job-manager-past-applications tbody > tr > td (0,1,2,2) + !important */
table.job-manager-past-applications tbody > tr:not(:last-child) > td {
  border-bottom: 1px solid var(--jms-border) !important;
}
table.job-manager-past-applications tbody > tr:nth-child(odd) > td {
  background: var(--jms-white) !important;
}
table.job-manager-past-applications tbody > tr:nth-child(even) > td {
  background: #f9fafd !important;
}
table.job-manager-past-applications tbody > tr:hover > td,
table.job-manager-past-applications tbody > tr:hover > th {
  background: #eef1fa !important;
  transition: background .2s ease;
}
/* Pas de changement de couleur sur les th au survol */
table.job-manager-past-applications thead > tr:hover > th,
table.job-manager-past-applications thead tr:hover th {
  background: var(--jms-primary) !important;
  cursor: default;
}
table.job-manager-past-applications tbody > tr > td {
  padding: 16px 18px !important;
  border: none !important;
  color: var(--jms-text) !important;
  vertical-align: middle !important;
  font-size: .9rem !important;
}
.job-manager-past-applications tbody tr:last-child td:first-child {
  border-radius: 0 0 0 var(--jms-radius-lg);
}
.job-manager-past-applications tbody tr:last-child td:last-child {
  border-radius: 0 0 var(--jms-radius-lg) 0;
}

/* Colonne 1 : lien emploi */
.job-manager-past-applications td:first-child a {
  color: var(--jms-primary);
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  transition: color .2s ease;
}
.job-manager-past-applications td:first-child a:hover {
  color: var(--jms-accent);
}

/* Colonne 2 : date */
.job-manager-past-applications td:nth-child(2) {
  color: var(--jms-muted);
  font-size: .85rem;
  white-space: nowrap;
}

/* Colonne 3 : statut — barre dorée à gauche */
.job-manager-past-applications tbody td:nth-child(3) {
  color: var(--jms-primary);
  font-weight: 700;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  border-left: 3px solid var(--jms-accent);
  padding-left: 15px;
}

/* Colonne 4 : message */
.job-manager-past-applications td.application-message {
  color: var(--jms-muted);
  font-size: .88rem;
  font-style: italic;
  max-width: 280px;
}
.job-manager-past-applications td.application-message p {
  margin: 0;
  line-height: 1.5;
}

/* État vide */
.job-manager-past-applications td[colspan] {
  text-align: center;
  padding: 40px 20px;
  color: var(--jms-muted);
  font-style: italic;
  background: var(--jms-white);
}

/* ============================================================
   12. RESPONSIVE MOBILE
============================================================ */
@media (max-width: 768px) {

  /* Mes candidatures — cartes empilées */
  .elementor-shortcode:has(.job-manager-past-applications) {
    padding: 0;
    border-radius: var(--jms-radius-md);
  }
  .job-manager-past-applications,
  .job-manager-past-applications tbody,
  .job-manager-past-applications tr,
  .job-manager-past-applications td {
    display: block;
    width: 100%;
  }
  .job-manager-past-applications thead {
    display: none;
  }
  .job-manager-past-applications tbody tr {
    background: var(--jms-white);
    border: 1px solid var(--jms-border);
    border-radius: var(--jms-radius-lg);
    margin-bottom: 12px;
    box-shadow: 0 0 8px rgba(15,27,76,.08);
    overflow: hidden;
  }
  .job-manager-past-applications tbody tr:nth-child(odd) td,
  .job-manager-past-applications tbody tr:nth-child(even) td {
    background: transparent;
  }
  .job-manager-past-applications tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--jms-border);
    font-size: .9rem;
  }
  .job-manager-past-applications tbody td:last-child {
    border-bottom: none;
  }
  .job-manager-past-applications td:first-child a {
    font-size: 1rem;
    font-weight: 700;
  }
  .job-manager-past-applications tbody td:nth-child(3) {
    border-left: none;
    padding-left: 16px;
  }
  .job-manager-past-applications tbody tr:last-child td:first-child,
  .job-manager-past-applications tbody tr:last-child td:last-child {
    border-radius: 0;
  }
}

@media (max-width: 680px) {
  .job_filters {
    padding: 0rem 0rem 0.8rem;
    margin-bottom: 1rem;
  }
  
  .job_filters input[type="text"], 
  .job_filters input[type="search"] {
    padding: .5rem 1rem !important;
    }
    
    .job_filters [type="submit"],
    .job_filters button[type="submit"] {
      padding: .6rem 1rem !important;
      font-size: .85rem !important;
      font-weight: 600 !important;
      letter-spacing: 0em !important;
    }
    
  .showing_jobs {
      display: none !important;
  }
  
  ul.job_listings li.job_listing > a {
    padding: 1rem 1rem !important;
    flex-wrap: wrap !important;
    gap: .5rem !important;
  }
  ul.job_listings li.job_listing > a .location,
  ul.job_listings li.job_listing > a .meta {
    flex-basis: 100% !important;
    max-width: 100% !important;
    text-align: left !important;
    padding: 0em !important;
  }
  
  ul.job_listings li.job_listing > a .company_logo {
      visibility: visible !important;
      position: static !important;
      margin-right: 0.5rem !important;
      padding: 2px !important;
    }

}

/* ============================================================
   13. PAGE "MES ALERTES" — WP Job Manager Alerts
============================================================ */

/* Conteneur global */
.jm-alerts__my-alerts {
  font-size: .95rem;
}

/* Texte intro email */
.jm-alerts__my-alerts__email-info {
  color: var(--jms-muted);
  font-size: .88rem;
  margin-bottom: 1.5rem !important;
}

/* Liste des alertes */
.jm-alerts__alert-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
  display: flex !important;
  flex-direction: column !important;
  gap: .75rem !important;
}

/* Carte alerte */
.jm-alert {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-lg) !important;
  box-shadow: 0 0 8px rgba(15,27,76,.08) !important;
  padding: 1.1rem 1.4rem !important;
  transition: box-shadow .25s ease, border-color .25s ease !important;
}
.jm-alert:hover {
  box-shadow: 0 4px 16px rgba(15,27,76,.14) !important;
  border-color: #c8d0e8 !important;
}

/* Alerte désactivée : légèrement atténuée */
.jm-alert:not(.alert-enabled) {
  opacity: .65 !important;
  border-style: dashed !important;
}

/* En-tête carte : titre + fréquence */
.jm-alert__header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  margin-bottom: .6rem !important;
}

/* Titre alerte */
.jm-alert__title {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  margin: 0 !important;
}

/* Fréquence (badge) */
.jm-alert__frequency {
  display: inline-flex !important;
  align-items: center !important;
  gap: .3rem !important;
  background: var(--jms-bg) !important;
  color: var(--jms-muted) !important;
  border: 1px solid var(--jms-border) !important;
  border-radius: 999px !important;
  padding: .2rem .85rem !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
}

/* Prochain envoi */
.jm-alert__frequency__next {
  font-size: .78rem !important;
  color: var(--jms-muted) !important;
  font-style: italic !important;
}

/* Termes (localisation, mots-clés...) */
.jm-alert__terms {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .4rem !important;
  margin-bottom: .9rem !important;
  align-items: center !important;
}
.jm-alert__term-label {
  font-size: .78rem !important;
  font-weight: 600 !important;
  color: var(--jms-text) !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.jm-alert__term-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .35rem !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.jm-alert__term {
  background: #eef1fa !important;
  color: var(--jms-primary) !important;
  border-radius: 999px !important;
  padding: .18rem .75rem !important;
  font-size: .78rem !important;
  font-weight: 600 !important;
}

/* Actions */
.jm-alert__actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .5rem !important;
  padding-top: .75rem !important;
  border-top: 1px solid var(--jms-border) !important;
  margin-top: .1rem !important;
}
.jm-alert__action {
  display: inline-flex !important;
  align-items: center !important;
  padding: .32rem .9rem !important;
  border-radius: var(--jms-radius-sm) !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  transition: box-shadow .2s, background .2s !important;
  cursor: pointer !important;
  border: none !important;
  background: none !important;
}

/* Action : Résultats */
.job-alerts-action-view {
  background: var(--jms-primary) !important;
  color: var(--jms-white) !important;
  box-shadow: 0 2px 6px rgba(15,27,76,.15) !important;
}
.job-alerts-action-view:hover {
  box-shadow: 0 4px 12px rgba(15,27,76,.28) !important;
  color: var(--jms-white) !important;
}

/* Action : Envoyer maintenant */
.job-alerts-action-email {
  background: transparent !important;
  color: var(--jms-primary) !important;
  border: 1px solid var(--jms-primary) !important;
}
.job-alerts-action-email:hover {
  background: var(--jms-bg) !important;
}

/* Action : Éditer */
.job-alerts-action-edit {
  background: transparent !important;
  color: var(--jms-muted) !important;
  border: 1px solid var(--jms-border) !important;
}
.job-alerts-action-edit:hover {
  color: var(--jms-primary) !important;
  border-color: var(--jms-primary) !important;
  background: var(--jms-bg) !important;
}

/* Action : Désactiver / Activer */
.job-alerts-action-toggle_status {
  background: transparent !important;
  color: var(--jms-muted) !important;
  border: 1px solid var(--jms-border) !important;
}
.job-alerts-action-toggle_status:hover {
  color: var(--jms-primary) !important;
  border-color: var(--jms-primary) !important;
  background: var(--jms-bg) !important;
}

/* Action : Supprimer */
.job-alerts-action-delete {
  background: transparent !important;
  color: var(--jms-red-text) !important;
  border: 1px solid var(--jms-red-border) !important;
}
.job-alerts-action-delete:hover {
  background: var(--jms-red-bg) !important;
}

/* Bouton "Ajouter une alerte" — le <a> est dans div.jm-alerts__add-new sans classe propre */
.jm-alerts__add-new {
  margin-top: .75rem !important;
}
.jm-alerts__add-new a {
  display: block !important;
  width: 100% !important;
  padding: .85rem 2rem !important;
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: var(--jms-white) !important;
  border: none !important;
  border-radius: var(--jms-radius-md) !important;
  font-size: .88rem !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: box-shadow .25s !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.15) !important;
  box-sizing: border-box !important;
}
.jm-alerts__add-new a:hover {
  box-shadow: 0 4px 16px rgba(15,27,76,.30) !important;
  color: var(--jms-white) !important;
  text-decoration: none !important;
}

/* Responsive mobile */
@media (max-width: 768px) {
  .jm-alert__header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: .4rem !important;
  }
  .jm-alert__actions {
    gap: .4rem !important;
  }
  .jm-alert__action {
    font-size: .72rem !important;
    padding: .3rem .7rem !important;
  }
}

/* ============================================================
   14. PAGE "MES FAVORIS" — table job-manager-bookmarks
   Structure identique à job-manager-past-applications
============================================================ */

/* Conteneur Elementor */
.elementor-shortcode:has(.job-manager-bookmarks) {
  background: var(--jms-white);
  border-radius: var(--jms-radius-lg);
  padding: 2rem;
  box-shadow: 0 0 8px rgba(15,27,76,.08);
  border: 1px solid var(--jms-border);
  overflow: hidden;
}

/* Table */
.job-manager-bookmarks {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: .95rem;
}

/* En-têtes */
table.job-manager-bookmarks thead > tr > th,
table.job-manager-bookmarks th {
  background: var(--jms-primary) !important;
  color: var(--jms-white) !important;
  font-weight: 600 !important;
  font-size: .78rem !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  padding: 14px 18px !important;
  border: none !important;
  text-align: left !important;
}
table.job-manager-bookmarks thead > tr > th:first-child,
table.job-manager-bookmarks th:first-child {
  border-radius: var(--jms-radius-md) 0 0 0 !important;
}
table.job-manager-bookmarks thead > tr > th:last-child,
table.job-manager-bookmarks th:last-child {
  border-radius: 0 var(--jms-radius-md) 0 0 !important;
}

/* Lignes */
table.job-manager-bookmarks tbody > tr:not(:last-child) > td {
  border-bottom: 1px solid var(--jms-border) !important;
}
table.job-manager-bookmarks tbody > tr:nth-child(odd) > td {
  background: var(--jms-white) !important;
}
table.job-manager-bookmarks tbody > tr:nth-child(even) > td {
  background: #f9fafd !important;
}
table.job-manager-bookmarks tbody > tr:hover > td {
  background: #eef1fa !important;
  transition: background .2s ease;
}
/* Bloquer hover sur thead */
table.job-manager-bookmarks thead > tr:hover > th {
  background: var(--jms-primary) !important;
}

/* Cellules */
table.job-manager-bookmarks tbody > tr > td {
  padding: 16px 18px !important;
  border: none !important;
  color: var(--jms-text) !important;
  vertical-align: middle !important;
  font-size: .9rem !important;
}
table.job-manager-bookmarks tbody > tr:last-child > td:first-child {
  border-radius: 0 0 0 var(--jms-radius-lg) !important;
}
table.job-manager-bookmarks tbody > tr:last-child > td:last-child {
  border-radius: 0 0 var(--jms-radius-lg) 0 !important;
}

/* Cellule favori — flex row : lien à gauche, bouton à droite */
table.job-manager-bookmarks tbody > tr > td:first-child {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
}

/* Lien favori — logo + titre alignés horizontalement */
table.job-manager-bookmarks td:first-child > a {
  display: flex !important;
  align-items: center !important;
  gap: .85rem !important;
  color: var(--jms-primary) !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
  text-decoration: none !important;
  transition: color .2s ease !important;
  flex: 1 !important;
  min-width: 0 !important;
}
table.job-manager-bookmarks td:first-child > a:hover {
  color: var(--jms-accent) !important;
}

/* Logo entreprise — 60x60px */
table.job-manager-bookmarks td:first-child a picture.company_logo {
  width: 60px !important;
  height: 60px !important;
  min-width: 60px !important;
  flex-shrink: 0 !important;
  display: block !important;
}
table.job-manager-bookmarks td:first-child a picture.company_logo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  border-radius: var(--jms-radius-sm) !important;
  border: 1px solid var(--jms-border) !important;
  background: var(--jms-bg) !important;
  padding: 4px !important;
  display: block !important;
}

/* Liste d'actions — toujours visible (override du frontend.css natif qui met visibility:hidden) */
ul.job-manager-bookmark-actions,
#job-manager-bookmarks table ul.job-manager-bookmark-actions {
  visibility: visible !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  gap: .4rem !important;
  flex-shrink: 0 !important;
}

/* Masquer la colonne Commentaires vide (2ème colonne) */
table.job-manager-bookmarks thead > tr > th:nth-child(2),
table.job-manager-bookmarks tbody > tr > td:nth-child(2) {
  display: none !important;
}

/* S'assurer que la 1ère colonne prend toute la largeur */
table.job-manager-bookmarks thead > tr > th:first-child,
table.job-manager-bookmarks tbody > tr > td:first-child {
  width: 100% !important;
}

/* Bouton Supprimer — toujours visible, style bouton outline rouge */
a.job-manager-bookmark-action-delete {
  display: inline-flex !important;
  align-items: center !important;
  padding: .32rem .9rem !important;
  border-radius: var(--jms-radius-sm) !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  transition: background .2s, box-shadow .2s !important;
  cursor: pointer !important;
  background: transparent !important;
  color: var(--jms-red-text) !important;
  border: 1px solid var(--jms-red-border) !important;
}
a.job-manager-bookmark-action-delete:hover {
  background: var(--jms-red-bg) !important;
  box-shadow: 0 2px 6px rgba(220,38,38,.15) !important;
  color: var(--jms-red-text) !important;
  text-decoration: none !important;
}

/* État vide */
table.job-manager-bookmarks td[colspan] {
  text-align: center !important;
  padding: 40px 20px !important;
  color: var(--jms-muted) !important;
  font-style: italic !important;
  background: var(--jms-white) !important;
}

/* Responsive mobile */
@media (max-width: 768px) {
  .elementor-shortcode:has(.job-manager-bookmarks) {
    padding: 0;
    border-radius: var(--jms-radius-md);
  }
  .job-manager-bookmarks,
  .job-manager-bookmarks tbody,
  .job-manager-bookmarks tr,
  .job-manager-bookmarks td {
    display: block;
    width: 100%;
  }
  .job-manager-bookmarks thead {
    display: none;
  }
  .job-manager-bookmarks tbody tr {
    background: var(--jms-white);
    border: 1px solid var(--jms-border);
    border-radius: var(--jms-radius-lg);
    margin-bottom: 12px;
    box-shadow: 0 0 8px rgba(15,27,76,.08);
    overflow: hidden;
  }
  .job-manager-bookmarks tbody tr:nth-child(odd) td,
  .job-manager-bookmarks tbody tr:nth-child(even) td {
    background: transparent;
  }
  .job-manager-bookmarks tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--jms-border);
    font-size: .9rem;
  }
  .job-manager-bookmarks tbody td:last-child {
    border-bottom: none;
  }
  .job-manager-bookmarks tbody tr:last-child td:first-child,
  .job-manager-bookmarks tbody tr:last-child td:last-child {
    border-radius: 0;
  }
}
/* ============================================================
   15. PAGE "TABLEAU DE BORD MISSIONS" — jm-dashboard
============================================================ */

/* Barre intro : champ recherche + bouton Ajouter */
.jm-dashboard__intro {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  margin-bottom: 1.5rem !important;
  flex-wrap: wrap !important;
}

/* Champ recherche */
.jm-dashboard__filters input[type="search"],
.jm-dashboard__filters input[type="text"] {
  border: 2px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .6rem 1rem .6rem 2.4rem !important;
  font-size: .88rem !important;
  color: var(--jms-text) !important;
  background: var(--jms-bg) !important;
  box-shadow: none !important;
  transition: border-color .25s, box-shadow .25s !important;
  min-width: 220px !important;
}
.jm-dashboard__filters input:focus {
  border-color: var(--jms-primary) !important;
  box-shadow: 0 0 0 3px rgba(15,27,76,.10) !important;
  background: var(--jms-white) !important;
  outline: none !important;
}

/* Bouton Ajouter une offre d'emploi */
.jm-dashboard__actions a,
.jm-dashboard__actions button {
  background: linear-gradient(135deg, var(--jms-primary) 0%, var(--jms-primary-light) 100%) !important;
  color: var(--jms-white) !important;
  border: none !important;
  border-radius: var(--jms-radius-md) !important;
  padding: .65rem 1.4rem !important;
  font-size: .85rem !important;
  font-weight: 700 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: box-shadow .25s !important;
  box-shadow: 0 2px 8px rgba(15,27,76,.15) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: .4rem !important;
  white-space: nowrap !important;
}
.jm-dashboard__actions a:hover {
  box-shadow: 0 4px 16px rgba(15,27,76,.30) !important;
  color: var(--jms-white) !important;
  text-decoration: none !important;
}

/* En-tête des colonnes */
.jm-dashboard-header {
  display: flex !important;
  align-items: center !important;
  padding: 10px 18px !important;
  background: var(--jms-primary) !important;
  border-radius: var(--jms-radius-md) var(--jms-radius-md) 0 0 !important;
}
.jm-dashboard-header .jm-dashboard-job-column {
  font-size: .72rem !important;
  font-weight: 700 !important;
  color: var(--jms-white) !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* Liste des lignes */
.jm-dashboard-rows {
  border: 1.5px solid var(--jms-border) !important;
  border-top: none !important;
  border-radius: 0 0 var(--jms-radius-md) var(--jms-radius-md) !important;
  overflow: hidden !important;
}

/* Ligne mission */
.jm-dashboard-job {
  padding: 14px 18px !important;
  background: var(--jms-white) !important;
  border-bottom: 1px solid var(--jms-border) !important;
  transition: background .2s !important;
}
.jm-dashboard-job:last-child {
  border-bottom: none !important;
}
.jm-dashboard-job:nth-child(even) {
  background: #f9fafd !important;
}
.jm-dashboard-job:hover {
  background: #eef1fa !important;
}

/* Label mobile masqué desktop */
.jm-dashboard-job-column-label {
  display: none !important;
}

/* Logo entreprise */
.jm-dashboard-job-column.company picture.company_logo img {
  width: 44px !important;
  height: 44px !important;
  object-fit: contain !important;
  border-radius: var(--jms-radius-sm) !important;
  border: 1px solid var(--jms-border) !important;
  background: var(--jms-bg) !important;
  padding: 3px !important;
  display: block !important;
}

/* Titre */
.jm-dashboard-job-column.job_title .job-title {
  font-size: .92rem !important;
  font-weight: 700 !important;
  color: var(--jms-primary) !important;
  text-decoration: none !important;
  display: block !important;
  margin-bottom: .2rem !important;
  transition: color .2s !important;
}
.jm-dashboard-job-column.job_title .job-title:hover {
  color: var(--jms-accent) !important;
}

/* Badge statut */
.job-status {
  display: inline-flex !important;
  align-items: center !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  padding: .15rem .6rem !important;
  border-radius: 999px !important;
  width: fit-content !important;
}
.job-status-publish {
  background: var(--jms-green-bg) !important;
  color: var(--jms-green-text) !important;
  border: 1px solid var(--jms-green-border) !important;
}
.job-status-expired {
  background: var(--jms-red-bg) !important;
  color: var(--jms-red-text) !important;
  border: 1px solid var(--jms-red-border) !important;
}

/* Date + stats */
.jm-dashboard-job-column.date,
.jm-dashboard-job-column.stats {
  font-size: .82rem !important;
  color: var(--jms-text) !important;
}
.jm-dashboard-job-column.date small,
.jm-dashboard-job-column.stats small {
  display: block !important;
  color: var(--jms-muted) !important;
  font-size: .76rem !important;
}

/* Candidatures */
.jm-dashboard-job-column.applications a {
  color: var(--jms-primary) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  font-size: .85rem !important;
}
.jm-dashboard-job-column.applications a:hover {
  color: var(--jms-accent) !important;
}
.jm-ui-marker-dot {
  display: inline-block !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--jms-red-text) !important;
  vertical-align: middle !important;
  margin-left: 2px !important;
}

/* Bouton action principal */
a.jm-ui-button--outline.jm-dashboard-action--primary {
  display: inline-flex !important;
  align-items: center !important;
  padding: .32rem .9rem !important;
  border-radius: var(--jms-radius-sm) !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  white-space: nowrap !important;
  transition: background .2s, box-shadow .2s !important;
  color: var(--jms-primary) !important;
  border: 1px solid var(--jms-primary) !important;
  background: transparent !important;
}
a.jm-ui-button--outline.jm-dashboard-action--primary:hover {
  background: var(--jms-bg) !important;
  box-shadow: 0 2px 6px rgba(15,27,76,.12) !important;
}

/* Bouton menu "..." */
.jm-ui-action-menu__open-button {
  background: transparent !important;
  border: 1px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-sm) !important;
  color: var(--jms-muted) !important;
  cursor: pointer !important;
  width: 30px !important;
  height: 30px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: border-color .2s, color .2s !important;
  padding: 0 !important;
}
.jm-ui-action-menu__open-button:hover {
  border-color: var(--jms-primary) !important;
  color: var(--jms-primary) !important;
}

/* Dropdown du menu */
.jm-ui-action-menu__content {
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  box-shadow: 0 8px 24px rgba(15,27,76,.14) !important;
  padding: .4rem 0 !important;
  min-width: 150px !important;
}
.jm-ui-action-menu__content .jm-ui-button--link {
  display: block !important;
  padding: .5rem 1rem !important;
  font-size: .82rem !important;
  color: var(--jms-text) !important;
  text-decoration: none !important;
  transition: background .15s !important;
  white-space: nowrap !important;
  background: transparent !important;
  border: none !important;
  width: 100% !important;
  text-align: left !important;
  cursor: pointer !important;
}
.jm-ui-action-menu__content .jm-ui-button--link:hover {
  background: var(--jms-bg) !important;
  color: var(--jms-primary) !important;
}
.jm-ui-action-menu__content .job-dashboard-action-delete {
  color: var(--jms-red-text) !important;
}
.jm-ui-action-menu__content .job-dashboard-action-delete:hover {
  background: var(--jms-red-bg) !important;
}

/* Responsive mobile */
@media (max-width: 768px) {
  .jm-dashboard__intro {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .jm-dashboard-header {
    display: none !important;
  }
  .jm-dashboard-rows {
    border-radius: var(--jms-radius-md) !important;
    border-top: 1.5px solid var(--jms-border) !important;
  }
  .jm-dashboard-job {
    border-radius: 0 !important;
  }
  .jm-dashboard-job-column-label {
    display: block !important;
    font-size: .7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: var(--jms-muted) !important;
    margin-bottom: .2rem !important;
  }
}

/* ============================================================
   15b. CORRECTIONS TABLEAU DE BORD
============================================================ */

/* En-tête : forcer la couleur blanche sur le contenu (écrasé par le thème) */
.jm-dashboard-header,
.jm-dashboard-header * {
  color: var(--jms-white) !important;
}

/* Badges statut : padding renforcé avec spécificité + !important */
.jm-dashboard-job .job-status,
.jm-dashboard-rows .job-status,
div.job-status.job-status-publish,
div.job-status.job-status-expired,
div.job-status.job-status-pending {
  padding: .25rem .75rem !important;
  border-radius: 999px !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: .3rem !important;
  width: fit-content !important;
}
div.job-status.job-status-publish {
  background: var(--jms-green-bg) !important;
  color: var(--jms-green-text) !important;
  border: 1px solid var(--jms-green-border) !important;
}
div.job-status.job-status-expired {
  background: var(--jms-red-bg) !important;
  color: var(--jms-red-text) !important;
  border: 1px solid var(--jms-red-border) !important;
}

/* Dropdown menu : supprimer overflow:hidden sur les rows
   pour que le menu des dernières lignes ne soit pas coupé */
.jm-dashboard-rows {
  overflow: visible !important;
  border: 1.5px solid var(--jms-border) !important;
  border-top: none !important;
  border-radius: 0 0 var(--jms-radius-md) var(--jms-radius-md) !important;
}

/* Repositionner le dropdown vers le haut si c'est la dernière ligne */
.jm-ui-actions-menu {
  position: relative !important;
}
.jm-ui-action-menu__content {
  position: absolute !important;
  right: 0 !important;
  z-index: 999 !important;
  background: var(--jms-white) !important;
  border: 1.5px solid var(--jms-border) !important;
  border-radius: var(--jms-radius-md) !important;
  box-shadow: 0 8px 24px rgba(15,27,76,.18) !important;
  padding: .4rem 0 !important;
  min-width: 160px !important;
}

/* ============================================================
   15c. CORRECTION HEADER — les colonnes du header ont la classe
   jm-dashboard-job-column-label qu'on masquait trop largement
============================================================ */

/* Masquer les labels UNIQUEMENT dans les lignes, pas dans le header */
.jm-dashboard-rows .jm-dashboard-job-column-label {
  display: none !important;
}

/* Réafficher dans le header */
.jm-dashboard-header .jm-dashboard-job-column-label {
  display: block !important;
  visibility: visible !important;
  color: var(--jms-white) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* ============================================================
   15d. CORRECTIONS v1.5.3
============================================================ */

/* Header : forcer display et visibility avec spécificité maximale */
.jm-dashboard .jm-dashboard-header .jm-dashboard-job-column.jm-dashboard-job-column-label,
.jm-dashboard .jm-dashboard-header [class*="jm-dashboard-job-column"] {
  display: block !important;
  visibility: visible !important;
  color: var(--jms-white) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* Supprimer le margin-bottom natif sur les lignes */
.jm-dashboard-rows .jm-dashboard-job {
  margin-bottom: 0 !important;
  margin-top: 0 !important;
}

/* ============================================================
   15e. CORRECTION alignwide — neutraliser le débordement
============================================================ */
.jm-dashboard.alignwide {
  margin-inline: 0 !important;
  max-width: 100% !important;
}