/* ============================================================
   VENITE ADOREMUS — Composants du système de design
   Classes .va-* réutilisables (boutons, chips, badges, carte,
   bloc-date, champs, toolbar, pin…). Namespacées → sûres
   site-wide. Dépend de venite-tokens.css.
   (Le reset global * et les styles d'éléments body/h1-4/p ont
    été retirés et déplacés dans homepage.css, scopés .va-accueil,
    pour ne pas perturber Blocksy.)
   ============================================================ */

.va-display {
  font-family: var(--serif);
  font-weight: 500;
  font-size: var(--t-4xl);
  line-height: 0.98;
  letter-spacing: -0.02em;
}

.va-kicker {
  font-family: var(--sans);
  font-weight: 600;
  font-size: var(--t-xs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

/* ============================================================
   BOUTONS
   ============================================================ */
.va-btn {
  font-family: var(--sans);
  font-weight: 600;
  font-size: var(--t-sm);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0.7em 1.4em;
  border-radius: var(--r-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  text-decoration: none;
  line-height: 1;
  transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
}
.va-btn:active { transform: translateY(1px); }

.va-btn--primary {
  background: var(--or-700);
  color: var(--blanc);
  box-shadow: 0 6px 16px oklch(0.68 0.168 55 / 0.32);
}
.va-btn--primary:hover { background: var(--or-800); box-shadow: 0 8px 22px oklch(0.68 0.168 55 / 0.40); color: var(--blanc); }

.va-btn--ghost {
  background: transparent;
  color: var(--or-800);
  border-color: var(--or-700);
}
.va-btn--ghost:hover { background: var(--or-100); color: var(--or-800); }

.va-btn--soft {
  background: var(--blanc);
  color: var(--encre);
  border-color: var(--ligne);
  box-shadow: var(--sh-sm);
}
.va-btn--soft:hover { border-color: var(--or-500); color: var(--or-800); }

/* sur fond nuit */
.va-btn--lumiere {
  background: var(--or-500);
  color: var(--nuit-950);
  box-shadow: var(--sh-glow);
}
.va-btn--lumiere:hover { background: var(--or-400); color: var(--nuit-950); }

.va-btn--contour-nuit {
  background: oklch(1 0 0 / 0.06);
  color: var(--etoile);
  border-color: var(--ligne-nuit);
}
.va-btn--contour-nuit:hover { background: oklch(1 0 0 / 0.12); border-color: var(--or-400); color: var(--etoile); }

/* ============================================================
   CHIPS / FILTRES CATÉGORIES
   ============================================================ */
.va-chip {
  font-family: var(--sans);
  font-weight: 600;
  font-size: var(--t-sm);
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  padding: 0.5em 1em;
  border-radius: var(--r-pill);
  border: 1.5px solid var(--ligne);
  background: var(--blanc);
  color: var(--encre);
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s, color 0.18s, box-shadow 0.18s;
  white-space: nowrap;
}
.va-chip:hover { box-shadow: var(--sh-sm); }
.va-chip .va-chip__ico { width: 1.05em; height: 1.05em; display: inline-flex; }

/* puce active : teinte par sa catégorie via --c */
.va-chip[aria-pressed="true"], .va-chip.is-active {
  border-color: color-mix(in oklab, var(--c, var(--or-700)) 55%, transparent);
  background: color-mix(in oklab, var(--c, var(--or-700)) 12%, var(--blanc));
  color: color-mix(in oklab, var(--c, var(--or-700)) 75%, var(--encre));
}
.va-chip .va-chip__ico { color: var(--c, var(--encre-soft)); }

/* ============================================================
   BADGES
   ============================================================ */
.va-badge {
  font-family: var(--sans);
  font-weight: 700;
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  padding: 0.32em 0.7em;
  border-radius: var(--r-sm);
  background: var(--or-100);
  color: var(--or-800);
}
.va-badge--live {
  background: color-mix(in oklab, var(--encours) 14%, white);
  color: var(--or-800);
}
.va-badge--live::before {
  content: ""; width: 0.5em; height: 0.5em; border-radius: 50%;
  background: var(--encours); box-shadow: 0 0 0 0 oklch(0.68 0.168 55 / 0.5);
  animation: va-pulse 1.8s infinite;
}
@keyframes va-pulse { 0%{box-shadow:0 0 0 0 oklch(0.68 0.168 55/.5);} 70%{box-shadow:0 0 0 6px oklch(0.68 0.168 55/0);} 100%{box-shadow:0 0 0 0 oklch(0.68 0.168 55/0);} }

/* ============================================================
   BLOC-DATE
   ============================================================ */
.va-date {
  font-family: var(--sans);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 92px;
  flex: 0 0 92px;
  padding: var(--sp-4) var(--sp-2);
  background: linear-gradient(160deg, var(--nuit-700), var(--nuit-900));
  color: var(--etoile);
  border-radius: var(--r-md) 0 0 var(--r-md);
  text-align: center;
}
.va-date__dow { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--or-400); }
.va-date__day { font-family: var(--serif); font-weight: 600; font-size: 2.4rem; line-height: 1; margin: 0.1em 0; }
.va-date__mon { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.8; }

/* ============================================================
   CARTE ÉVÉNEMENT
   ============================================================ */
.va-card {
  display: flex;
  background: var(--blanc);
  border: 1px solid var(--ligne);
  border-radius: var(--r-md);
  box-shadow: var(--sh-sm);
  overflow: hidden;
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s;
}
.va-card:hover { box-shadow: var(--sh-md); border-color: color-mix(in oklab, var(--or-500) 40%, var(--ligne)); }
.va-card__body { padding: var(--sp-4) var(--sp-5); flex: 1; min-width: 0; }
.va-card__title { font-family: var(--serif); font-size: var(--t-lg); font-weight: 600; color: var(--encre); margin-bottom: var(--sp-2); }
.va-card__meta { display: flex; align-items: center; gap: 0.4em; color: var(--encre-soft); font-size: var(--t-sm); margin-top: var(--sp-1); }
.va-card__cats { display: flex; gap: var(--sp-2); margin: var(--sp-3) 0; flex-wrap: wrap; }
.va-cat-dot {
  width: 1.85em; height: 1.85em; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: color-mix(in oklab, var(--c, var(--or-700)) 14%, white);
  color: var(--c, var(--or-700));
}

/* ============================================================
   CHAMPS / RECHERCHE
   ============================================================ */
.va-field {
  font-family: var(--sans);
  font-size: var(--t-sm);
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.65em 1em;
  background: var(--blanc);
  border: 1.5px solid var(--ligne);
  border-radius: var(--r-pill);
  color: var(--encre);
}
.va-field:focus-within { border-color: var(--or-500); box-shadow: 0 0 0 3px var(--or-100); }
.va-field input { border: 0; outline: 0; background: transparent; font: inherit; color: inherit; min-width: 0; }

.va-toolbar {
  background: var(--blanc);
  border: 1px solid var(--ligne);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-md);
  padding: var(--sp-5);
}

/* ============================================================
   MARQUEUR / PUCE CARTE
   ============================================================ */
.va-pin {
  display: inline-flex; align-items: center; gap: 0.3em;
  background: var(--or-700);
  color: var(--blanc);
  padding: 0.4em 0.7em;
  border-radius: var(--r-pill);
  box-shadow: var(--sh-md);
  font-size: var(--t-sm);
}

/* ============================================================
   DIVERS
   ============================================================ */
.va-rule { border: 0; border-top: 1px solid var(--ligne); margin: var(--sp-6) 0; }
.va-rule--nuit { border-top-color: var(--ligne-nuit); }

/* étoiles décoratives (dessinées au CSS) */
.va-star { position: absolute; color: var(--etoile); opacity: 0.85; }
@keyframes va-twinkle { 0%,100%{opacity:0.25;} 50%{opacity:0.95;} }
