/* ══════════════════════════════════════════════════
   OFFRES D'EMPLOI — Liste — Mobile-first
══════════════════════════════════════════════════ */

/* ── HERO ───────────────────────────────────────── */
.jobs-hero {
  background: linear-gradient(145deg,#1a1d3b 0%,#0f3460 50%,#2d1060 100%);
  padding: clamp(90px,12vw,130px) 0 0;
  position: relative; overflow: hidden;
}
.jobs-hero::before {
  content:''; position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);
  background-size: 28px 28px; pointer-events:none;
}
.jh-orb { position:absolute; border-radius:50%; pointer-events:none; }
.jh-orb-1 { width:500px;height:500px;top:-180px;right:-100px;background:radial-gradient(circle,rgba(54,162,206,.2),transparent 70%); }
.jh-orb-2 { width:360px;height:360px;bottom:0;left:-80px; background:radial-gradient(circle,rgba(130,190,96,.15),transparent 70%); }

.jh-label { display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:7px 18px;border-radius:50px;margin-bottom:20px; }
.jobs-hero h1 { font-family:var(--font-heading);font-size:clamp(1.9rem,5vw,3.2rem);font-weight:800;color:#fff;line-height:1.15;margin-bottom:14px; }
.jobs-hero-sub { font-size:clamp(.9rem,1.8vw,1.05rem);color:rgba(255,255,255,.7);line-height:1.8;max-width:520px; }
.jh-breadcrumb { display:flex;align-items:center;gap:8px;margin-top:18px;font-size:.76rem;color:rgba(255,255,255,.4);flex-wrap:wrap; }
.jh-breadcrumb a { color:rgba(255,255,255,.55);text-decoration:none; }
.jh-breadcrumb a:hover { color:#fff; }

/* Stats hero */
.jh-stats { display:flex;gap:0;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:14px;overflow:hidden;margin-top:28px;max-width:400px; }
.jhs-item { flex:1;padding:14px;text-align:center;border-right:1px solid rgba(255,255,255,.08); }
.jhs-item:last-child { border-right:none; }
.jhs-val { font-family:var(--font-heading);font-size:1.4rem;font-weight:800;color:#fff; }
.jhs-lbl { font-size:.65rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.04em;margin-top:2px; }

/* ── BARRE DE RECHERCHE & FILTRES ───────────────── */
.jobs-search-bar {
  background: #fff;
  padding: clamp(20px,3.5vw,32px) 0;
  border-bottom: 1px solid var(--c-border);
  position: sticky; top: 70px; z-index: 50;
  box-shadow: 0 2px 16px rgba(0,0,0,.06);
}

.jsb-form { display:grid; grid-template-columns:1fr auto auto auto; gap:10px; align-items:center; }

/* Champ recherche texte */
.jsb-search-wrap { position:relative; }
.jsb-search-icon { position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--c-muted);font-size:.9rem; }
.jsb-input {
  width:100%;padding:12px 14px 12px 42px;
  border:1.5px solid var(--c-border);border-radius:11px;
  font-family:var(--font-body);font-size:.9rem;color:var(--c-navy);
  background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;
}
.jsb-input:focus { border-color:var(--c-purple);box-shadow:0 0 0 3px rgba(78,43,134,.1); }

/* Selects filtres */
.jsb-select {
  padding:12px 36px 12px 14px;
  border:1.5px solid var(--c-border);border-radius:11px;
  font-family:var(--font-body);font-size:.87rem;color:var(--c-navy);
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 12px center/12px no-repeat;
  -webkit-appearance:none;outline:none;cursor:pointer;
  border-color:var(--c-border);transition:border-color .2s;
  white-space:nowrap;
}
.jsb-select:focus { border-color:var(--c-purple); }

/* Bouton rechercher */
.jsb-btn {
  padding:12px 22px;border-radius:11px;
  background:var(--grad-main);color:#fff;border:none;
  font-family:var(--font-heading);font-size:.88rem;font-weight:700;
  cursor:pointer;display:flex;align-items:center;gap:8px;
  transition:transform .2s,box-shadow .2s;white-space:nowrap;
}
.jsb-btn:hover { transform:translateY(-1px);box-shadow:var(--shadow-btn); }

/* Reset filtres */
.jsb-reset {
  display:inline-flex;align-items:center;gap:6px;
  font-size:.8rem;color:var(--c-muted);text-decoration:none;
  padding:4px 0;transition:color .2s;
  margin-top:10px;
}
.jsb-reset:hover { color:var(--c-purple); }

/* Filtres actifs badges */
.active-filters { display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;align-items:center; }
.af-badge-label { font-size:.74rem;color:var(--c-muted);font-weight:600; }
.af-badge {
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(78,43,134,.08);border:1px solid rgba(78,43,134,.2);
  color:var(--c-purple);border-radius:50px;
  padding:4px 12px;font-size:.76rem;font-weight:600;
}
.af-badge a { color:inherit;text-decoration:none;opacity:.6;transition:opacity .2s; }
.af-badge a:hover { opacity:1; }

/* ── SECTION LISTE ──────────────────────────────── */
.section-jobs { padding:clamp(36px,5vw,56px) 0 clamp(64px,10vw,100px);background:var(--c-light); }

.jobs-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:clamp(20px,3vw,32px);flex-wrap:wrap;gap:12px;
}
.jobs-count { font-family:var(--font-heading);font-size:.9rem;font-weight:700;color:var(--c-navy); }
.jobs-count span { color:var(--c-purple); }

/* Sort */
.jobs-sort { display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--c-muted); }
.jobs-sort select { border:1.5px solid var(--c-border);border-radius:8px;padding:6px 28px 6px 10px;font-size:.82rem;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 8px center/10px no-repeat;-webkit-appearance:none;outline:none; }

/* ── CARDS OFFRES ───────────────────────────────── */
.jobs-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,20px); }

.job-card {
  background:#fff;border-radius:18px;
  border:1.5px solid var(--c-border);
  padding:clamp(20px,3vw,28px);
  display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;
  text-decoration:none;
}
.job-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-full);opacity:0;transition:opacity .25s;
}
.job-card:hover { transform:translateY(-5px);box-shadow:0 16px 44px rgba(78,43,134,.1);border-color:transparent; }
.job-card:hover::before { opacity:1; }

/* Badge type contrat */
.jc-type {
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 12px;border-radius:50px;
  font-family:var(--font-heading);font-size:.7rem;font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:14px;align-self:flex-start;
}
.type-CDI        { background:rgba(130,190,96,.12); color:var(--c-green); }
.type-CDD        { background:rgba(54,162,206,.1);  color:var(--c-blue);  }
.type-STAGE      { background:rgba(245,158,11,.1);  color:#b45309; }
.type-ALTERNANCE { background:rgba(234,88,12,.1);   color:#c2410c; }
.type-FREELANCE  { background:rgba(78,43,134,.1);   color:var(--c-purple); }

.jc-title {
  font-family:var(--font-heading);font-size:clamp(.97rem,1.8vw,1.1rem);
  font-weight:800;color:var(--c-navy);line-height:1.35;
  margin-bottom:8px;transition:color .2s;
}
.job-card:hover .jc-title { color:var(--c-purple); }

.jc-category { font-size:.78rem;color:var(--c-muted);margin-bottom:14px;display:flex;align-items:center;gap:5px; }

/* Infos (lieu, date limite, vues) */
.jc-meta { display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px; }
.jc-meta-item { display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--c-text); }
.jc-meta-item i { color:var(--c-muted);font-size:.72rem; }

/* Salaire */
.jc-salary {
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(130,190,96,.1);border:1px solid rgba(130,190,96,.25);
  color:#166534;border-radius:8px;padding:4px 12px;
  font-family:var(--font-heading);font-size:.76rem;font-weight:700;
  margin-bottom:16px;align-self:flex-start;
}

/* Description courte */
.jc-desc { font-size:.83rem;color:var(--c-text);line-height:1.7;margin-bottom:18px;flex:1; }

/* Footer card */
.jc-footer {
  display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;border-top:1px solid var(--c-border);
  margin-top:auto;
}
.jc-deadline { font-size:.74rem;color:var(--c-muted);display:flex;align-items:center;gap:5px; }
.jc-deadline.urgent { color:#ef4444;font-weight:600; }
.jc-cta {
  display:inline-flex;align-items:center;gap:7px;
  background:var(--grad-main);color:#fff;
  padding:8px 16px;border-radius:9px;
  font-family:var(--font-heading);font-size:.78rem;font-weight:700;
  transition:transform .2s,box-shadow .2s;
  text-decoration:none;
}
.jc-cta:hover { transform:translateY(-1px);box-shadow:0 4px 14px rgba(78,43,134,.35); }

/* Badge "Nouveau" */
.jc-new-badge {
  position:absolute;top:16px;right:16px;
  background:var(--c-green);color:#fff;
  font-family:var(--font-heading);font-size:.65rem;font-weight:800;
  letter-spacing:.06em;text-transform:uppercase;
  padding:3px 10px;border-radius:50px;
}

/* ── ÉTAT VIDE ───────────────────────────────────── */
.jobs-empty {
  grid-column:1/-1;text-align:center;
  padding:clamp(48px,8vw,80px) 24px;
  background:#fff;border-radius:18px;border:1.5px solid var(--c-border);
}
.je-icon { width:80px;height:80px;border-radius:50%;background:var(--c-light);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:2rem;color:rgba(78,43,134,.25); }
.je-title { font-family:var(--font-heading);font-size:1.2rem;font-weight:800;color:var(--c-navy);margin-bottom:8px; }
.je-sub   { font-size:.9rem;color:var(--c-muted);line-height:1.7;max-width:400px;margin:0 auto 24px; }

/* ── CTA ALERTE EMPLOI ──────────────────────────── */
.section-job-alert {
  padding:clamp(48px,7vw,72px) 0;
  background:linear-gradient(145deg,#1a1d3b 0%,#2d1060 60%,#0f3460 100%);
  position:relative;overflow:hidden;text-align:center;
}
.section-job-alert::before { content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;pointer-events:none; }

/* RESPONSIVE */
@media (max-width:1199px) { .jsb-form { grid-template-columns:1fr auto auto; } .jsb-select:last-of-type { display:none; } }
@media (max-width:991px)  {
  .jsb-form { grid-template-columns:1fr auto; }
  .jsb-select { display:none; }
  .jobs-grid { grid-template-columns:1fr; }
  .jobs-search-bar { top:60px; }
}
@media (max-width:767px) {
  .jsb-form { grid-template-columns:1fr; }
  .jsb-btn  { width:100%;justify-content:center; }
  .jh-stats { max-width:100%; }
}
@media (max-width:480px) {
  .job-card { padding:18px 16px; }
  .jc-meta  { gap:8px; }
}
