/* =====================================================================
   Cartes d'annonces — nouveau design "façon Airbnb"
   Même logique/contenu qu'avant : seul l'habillage change.
   Fichier dédié, chargé APRÈS style.css pour surcharger l'ancien rendu.
   ===================================================================== */

/* La grille : on neutralise les anciennes contraintes pour des cartes régulières */
.feature-block .job-card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #ffffff;
  border: 1px solid #eef1f6;
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 10px 30px rgba(20, 30, 60, .06);
  transition: transform .25s ease, box-shadow .25s ease;
  overflow: hidden;
}

/* Léger soulèvement au survol */
.feature-block .job-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(20, 30, 60, .12);
}

/* Bandeau "TOP RECRUTEUR" (annonces premium) — ruban d'angle HAUT-DROIT auto-rogné.
   Le cadre (.job-card-ribbon) fait office de fenêtre carrée en overflow:hidden : la bande (span)
   est ainsi découpée proprement en triangle d'angle, même si la carte ne rogne pas son contenu. */
.feature-block .job-card .job-card-ribbon {
  position: absolute;
  top: 0;
  right: 0;
  width: 122px;
  height: 122px;
  overflow: hidden;
  z-index: 2;
  pointer-events: none;
  background: none;
  padding: 0;
}
.feature-block .job-card .job-card-ribbon span {
  position: absolute;
  top: 26px;
  right: -36px;
  width: 165px;
  transform: rotate(45deg);
  background: #c0a86e;
  color: #fff;
  text-align: center;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .5px;
  padding: 6px 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .18);
}

/* ---------- En-tête : titre + pastilles ---------- */
.feature-block .job-card .job-card-header {
  margin: 2px 0 12px;
}

.feature-block .job-card .job-card-title {
  font-size: 19px;
  font-weight: 800;
  line-height: 1.25;
  color: #16203a;
  margin: 0;
}

/* Rangée de pastilles (type de contrat + rythme) */
.feature-block .job-card .job-card-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 0;
}

.feature-block .job-card .yj-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  background: #eef1ff;          /* couleur par défaut */
  color: #4f5bd5;
}

.feature-block .job-card .yj-badge i {
  font-size: 12px;
}

/* Couleurs par type de contrat / rythme (cf. visuel) */
.yj-badge--cdi          { background: #eef0ff; color: #4f5bd5; }
.yj-badge--cdd          { background: #e8f6ee; color: #2e9e5b; }
.yj-badge--interim,
.yj-badge--stage,
.yj-badge--alternance   { background: #fdeef6; color: #d6489b; }
.yj-badge--temps-plein  { background: #f3ecff; color: #7c3aed; }
.yj-badge--temps-partiel{ background: #fff1e6; color: #ea7a2f; }
.yj-badge--ponctuel     { background: #e3f7f4; color: #0fb3a3; }

/* ---------- Image illustrée ---------- */
.feature-block .job-card .job-card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 16px;
  overflow: hidden;
  background: #f4f7fc;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 4px 0 14px;
}

/* contain : on voit le personnage EN ENTIER (tête comprise), jamais recadré */
.feature-block .job-card .job-card-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Cas logo partenaire / France Travail : on n'écrase pas le logo (pas de recadrage) */
.feature-block .job-card .job-card-image-partner img,
.feature-block .job-card .job-card-image img[src*="logo-france-travail"] {
  object-fit: contain;
  padding: 18px;
  background: #fff;
}

/* ---------- Corps ---------- */
.feature-block .job-card .job-card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* On masque l'ancienne ligne "catégorie" en doublon (remplacée par les pastilles) */
.feature-block .job-card .job-card-category {
  display: none;
}

.feature-block .job-card .job-card-desc {
  margin: 0 0 14px;
}

.feature-block .job-card .job-card-description {
  color: #5b6478;
  font-size: 14.5px;
  line-height: 1.5;
  margin: 0;
  /* Coupe propre à 3 lignes (on neutralise le max-height hérité de style.css) */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-height: none;
}

/* Description dépliée : on retire toute coupe et toute hauteur max */
.feature-block .job-card .job-card-description.expanded {
  display: block;
  -webkit-line-clamp: unset;
  overflow: visible;
  max-height: none;
}

/* Lien "Voir plus / Voir moins" */
.feature-block .job-card .job-card-more {
  display: inline-block;
  background: none;
  border: 0;
  padding: 0;
  margin-top: 6px;
  color: #2563eb;
  font-size: 13.5px;
  font-weight: 700;
  cursor: pointer;
}

.feature-block .job-card .job-card-more:hover {
  text-decoration: underline;
}

/* Bloc "Informations pratiques" */
.feature-block .job-card .job-card-info {
  margin-bottom: 16px;
}

.feature-block .job-card .job-card-info-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 800;
  color: #16203a;
  margin-bottom: 12px;
}

.feature-block .job-card .job-card-info-title i {
  color: #2563eb;
}

/* Grille de 4 tuiles (2 par ligne) — grid-auto-rows: 1fr => les 4 cases ont la MÊME hauteur */
.feature-block .job-card .job-card-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: 8px;
}

/* Une tuile = icône à GAUCHE (centrée) + (libellé gris au-dessus / valeur noire en dessous) */
.feature-block .job-card .job-card-tile {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #f7f8fc;
  border: 1px solid #eef1f8;
  border-radius: 12px;
  padding: 10px 12px;
  min-width: 0;
}
/* Tuile pleine largeur (ex. Rémunération, en gros carré sous Date/Lieu) */
.feature-block .job-card .job-card-tile--full {
  grid-column: 1 / -1;
  padding: 12px 14px;
}
.feature-block .job-card .job-card-tile--full .val {
  font-size: 15px;
}

.feature-block .job-card .job-card-tile i {
  flex-shrink: 0;
  color: #2563eb;
  font-size: 16px;
  line-height: 1;
}

/* Colonne texte : libellé gris au-dessus, valeur noire en dessous */
.feature-block .job-card .job-card-tile-txt {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.feature-block .job-card .job-card-tile .lbl {
  font-size: 12px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  color: #98a2b3;
  margin-bottom: 2px;
}

.feature-block .job-card .job-card-tile .val {
  font-size: 13px;
  font-weight: 600;
  color: #2a3447;
  line-height: 1.3;
  word-break: break-word;
}

/* Sur très petit écran, on repasse en une colonne */
@media (max-width: 360px) {
  .feature-block .job-card .job-card-info-grid {
    grid-template-columns: 1fr;
  }
}

/* ---------- Pied : places + bouton ---------- */
.feature-block .job-card .job-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: auto;
}

.feature-block .job-card .job-card-places {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fdeef0;
  color: #e0556b;
  font-size: 12.5px;
  font-weight: 700;
  padding: 7px 13px;
  border-radius: 999px;
}

.feature-block .job-card .job-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  padding: 11px 22px;
  border-radius: 12px;
  text-decoration: none;
  transition: background .2s ease, transform .2s ease;
  white-space: nowrap;
}

.feature-block .job-card .job-card-cta:hover {
  background: #1d4ed8;
  transform: translateY(-1px);
  color: #fff;
}

/* Petits écrans : on empile places / bouton proprement */
@media (max-width: 480px) {
  .feature-block .job-card .job-card-footer {
    flex-direction: column;
    align-items: stretch;
  }
  .feature-block .job-card .job-card-cta {
    justify-content: center;
  }
}

/* =====================================================================
   Bouton « Partager » d'une annonce (coin haut-droit de la carte)
   ===================================================================== */
.feature-block .job-card .yj-share {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 5;
}
/* Bouton rond avec la flèche (orientée haut-droite) */
.yj-share__btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid #e6eaf2;
  background: #ffffff;
  color: #2563eb;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(20, 30, 60, .10);
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.yj-share__btn:hover { background: #eef4ff; border-color: #cfe0ff; }
.yj-share__btn i {
  font-size: 15px;
  transform: rotate(45deg); /* flèche vers le haut-droite */
}
/* Petit menu de partage (s'ouvre à l'intérieur de la carte) */
.yj-share__menu {
  position: absolute;
  top: 46px;
  right: 0;
  min-width: 184px;
  background: #ffffff;
  border: 1px solid #eef1f6;
  border-radius: 14px;
  box-shadow: 0 14px 34px rgba(20, 30, 60, .16);
  padding: 6px;
  display: none;
  flex-direction: column;
  gap: 2px;
}
.yj-share.is-open .yj-share__menu { display: flex; }
.yj-share__item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  border: none;
  background: transparent;
  border-radius: 9px;
  font-size: 14px;
  font-weight: 600;
  color: #16355a;
  text-decoration: none;
  cursor: pointer;
  text-align: left;
}
.yj-share__item:hover { background: #f3f6fb; color: #16355a; text-decoration: none; }
.yj-share__item i { width: 18px; text-align: center; font-size: 15px; color: #2563eb; }
