/* ──────────────────────────────────────
   ANIMATIONS & TRANSITIONS
────────────────────────────────────── */

/* Fade-in page */
@keyframes pageFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

body {
  animation: pageFadeIn 0.25s ease both;
}

/* Fade-out avant navigation */
body.is-leaving {
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 0.18s ease, transform 0.18s ease;
  pointer-events: none;
}

/* ──────────────────────────────────────
   ENTRÉE EN CASCADE DES CARTES
────────────────────────────────────── */
@keyframes cardEnter {
  from { opacity: 0; transform: translateY(12px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.plant-card {
  animation: cardEnter 0.3s ease both;
  animation-delay: calc(var(--card-index, 0) * 60ms);
}

/* ──────────────────────────────────────
   SKELETON DE CHARGEMENT
────────────────────────────────────── */
@keyframes shimmer {
  from { background-position: -200% 0; }
  to   { background-position:  200% 0; }
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--color-border) 25%,
    #ede8e0 50%,
    var(--color-border) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite linear;
  border-radius: var(--radius-sm);
}

.skeleton-card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.skeleton-card__photo {
  aspect-ratio: 1 / 1;
}

.skeleton-card__info {
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.skeleton-card__line {
  height: 14px;
  border-radius: var(--radius-sm);
}

.skeleton-card__line--short {
  width: 55%;
}
