/* ======================================================
   Card Réalisations — PREMIUM (SCOPED)
   Fichier : assets/css/card-realisations.css
   Scope   : .card-realisation
   ====================================================== */

/* Grille (si tu l'utilises) */
.card-realisations-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-6, 24px);
}

/* =========================
   Card
   ========================= */
.card-realisation{
  position: relative;
  background: var(--color-surface, #ffffff);
  border: 1px solid var(--color-line, #e5e7eb);
  border-radius: var(--radius, 16px);
  overflow: hidden;
  box-shadow: var(--shadow-sm, 0 8px 22px rgba(0,0,0,.05));
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.card-realisation:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow, 0 18px 40px rgba(0,0,0,.08));
  border-color: rgba(17,24,39,.14);
}

.card-realisation__link{
  display: block;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

/* Focus a11y */
.card-realisation__link:focus{
  outline: none;
}
.card-realisation__link:focus-visible{
  outline: 3px solid var(--color-focus, rgba(47,128,237,.45));
  outline-offset: 2px;
  border-radius: calc(var(--radius, 16px) - 2px);
}

/* =========================
   Media
   ========================= */
.card-realisation__media{
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-surface-2, #f3f4f6);
}

.card-realisation__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.001);
  transition: transform .42s ease;
  display: block;
}

.card-realisation:hover .card-realisation__media img{
  transform: scale(1.06);
}

/* Fallback */
.card-realisation__placeholder{
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: rgba(17,24,39,.55);
}
.card-realisation__placeholder .dashicons{
  font-size: 34px;
  width: 34px;
  height: 34px;
  line-height: 34px;
}

/* Shade pour lisibilité badges */
.card-realisation__shade{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.30), rgba(0,0,0,0) 55%),
    radial-gradient(900px 260px at 10% 0%, rgba(0,0,0,.18), transparent 62%);
  pointer-events: none;
  opacity: .92;
  transition: opacity .22s ease;
}
.card-realisation:hover .card-realisation__shade{
  opacity: .98;
}

/* Top badges */
.card-realisation__top{
  position: absolute;
  left: 12px;
  right: 12px;
  top: 12px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  z-index: 2;
}

.cr-badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .01em;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(17,24,39,.40);
  color: #fff;
  backdrop-filter: blur(6px);
}

.cr-badge .dashicons{
  font-size: 16px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  opacity: .95;
}

.cr-badge--year{
  background: rgba(17,24,39,.28);
}

/* =========================
   Content
   ========================= */
.card-realisation__content{
  padding: 16px 16px 14px;
}

.card-realisation__title{
  margin: 0 0 8px;
  font-size: 1.05rem;
  font-weight: 850;
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.card-realisation__excerpt{
  margin: 0 0 12px;
  color: var(--color-muted, #6b7280);
  font-size: .95rem;
  line-height: 1.55;
}

/* Meta list */
.card-realisation__meta{
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: grid;
  gap: 8px;
}

.cr-meta{
  display: grid;
  grid-template-columns: 18px auto 1fr;
  gap: 8px;
  align-items: baseline;
  color: var(--color-text, #111827);
  font-size: .92rem;
}

.cr-meta .dashicons{
  font-size: 16px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  color: rgba(17,24,39,.70);
}

.cr-meta__k{
  color: var(--color-muted, #6b7280);
  font-weight: 700;
  white-space: nowrap;
}

.cr-meta__v{
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Tags */
.card-realisation__tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 12px;
}

.cr-tag{
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--color-line, #e5e7eb);
  background: var(--color-surface-2, #f8fafc);
  color: rgba(17,24,39,.82);
  font-weight: 750;
  font-size: 12px;
}

/* Foot */
.card-realisation__foot{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-top: 6px;
  border-top: 1px solid rgba(229,231,235,.75);
}

.card-realisation__cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 850;
  font-size: 13px;
  color: rgba(17,24,39,.92);
}

.card-realisation__cta .dashicons{
  font-size: 18px;
  width: 18px;
  height: 18px;
  line-height: 18px;
}

.card-realisation__ext{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--color-line, #e5e7eb);
  background: var(--color-surface, #fff);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.card-realisation__ext .dashicons{
  font-size: 16px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  opacity: .85;
}

/* External button (small, bottom-right) */
.card-realisation__external{
  position: absolute;
  right: 12px;
  bottom: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 850;
  font-size: 13px;
  color: #fff;
  background: rgba(17,24,39,.92);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 14px 34px rgba(0,0,0,.14);
  z-index: 3;
  transform: translateY(0);
  transition: transform .22s ease, opacity .22s ease;
}

.card-realisation__external .dashicons{
  font-size: 16px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  opacity: .95;
}

.card-realisation:hover .card-realisation__external{
  transform: translateY(-1px);
}

/* Mobile polish */
@media (max-width: 520px){
  .card-realisation__content{
    padding: 14px 14px 12px;
  }
}
