/* ─────────────────────────────────────────────────────────────
 * ZoliBat — Components Library (marketing site)
 * ─────────────────────────────────────────────────────────────
 * Bibliothèque de composants CSS réutilisables, alignés sur les tokens.
 * Prérequis : tokens.css chargé en amont.
 *
 * Convention de nommage : BEM-lite
 *   .bloc            — le composant de base
 *   .bloc--modifier  — une variante (primary, sm, dark…)
 *   .bloc__element   — un sous-élément interne
 *
 * Règle : aucun hex, aucun px arbitraire. Tout passe par les tokens.
 * ───────────────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════
 * SECTION · conteneur vertical rythmé
 * ═══════════════════════════════════════════════════════════ */
.section {
  padding-block: var(--space-8);
}
.section--tight   { padding-block: var(--space-6); }
.section--loose   { padding-block: var(--space-9); }
.section--hero    { padding-block: var(--space-9) var(--space-8); }

.section__title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}
@media (min-width: 768px) {
  .section__title { font-size: var(--font-size-4xl); }
}
.section__lead {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  max-width: 65ch;
}
.section__eyebrow {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  color: var(--color-accent-400);
  margin-bottom: var(--space-3);
}

/* ═══════════════════════════════════════════════════════════
 * BUTTON
 * ═══════════════════════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-pill);
  font-family: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform var(--transition-fast),
              box-shadow var(--transition-fast),
              background-color var(--transition-fast),
              color var(--transition-fast);
  white-space: nowrap;
}
.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.55;
  cursor: not-allowed;
  pointer-events: none;
}
.btn:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

/* Tailles */
.btn--sm { padding: var(--space-2) var(--space-3); font-size: var(--font-size-xs); }
.btn--lg { padding: var(--space-4) var(--space-6); font-size: var(--font-size-base); }

/* Variantes */
.btn--primary {
  background-color: var(--color-accent-400);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-sm);
}
.btn--primary:hover { background-color: var(--color-accent-300); box-shadow: var(--shadow-md); transform: translateY(-1px); color: var(--color-text-inverse); }

.btn--secondary {
  background-color: var(--color-primary-500);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-sm);
}
.btn--secondary:hover { background-color: var(--color-primary-400); box-shadow: var(--shadow-md); color: var(--color-text-inverse); }

.btn--ghost {
  background-color: transparent;
  color: var(--color-text-primary);
  border-color: var(--color-border-subtle);
}
.btn--ghost:hover { background-color: var(--color-bg-subtle); }

.btn--link {
  background-color: transparent;
  color: var(--color-primary-500);
  padding: 0;
  border: none;
  border-radius: 0;
}
.btn--link:hover { color: var(--color-primary-400); text-decoration: underline; }

.btn--danger {
  background-color: var(--color-danger-fg);
  color: var(--color-text-inverse);
}
.btn--danger:hover { filter: brightness(1.05); }

.btn--on-dark {
  background-color: var(--color-bg-surface);
  color: var(--color-primary-500);
  box-shadow: var(--shadow-md);
}
.btn--on-dark:hover { background-color: var(--color-neutral-100); }

/* ═══════════════════════════════════════════════════════════
 * CARD
 * ═══════════════════════════════════════════════════════════ */
.card {
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}
.card--interactive { cursor: pointer; }
.card--interactive:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.card__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
  line-height: var(--line-height-snug);
}
.card__body {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}
.card__footer {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-subtle);
}

/* Variant : carte « feature » avec icône colorée en haut */
.feature-card {
  composes: card;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.feature-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(27,77,62,0.10);
  color: var(--color-primary-500);
}

/* ═══════════════════════════════════════════════════════════
 * BADGE
 * ═══════════════════════════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1.3;
  white-space: nowrap;
}
.badge--neutral   { background-color: var(--color-neutral-200);  color: var(--color-text-secondary); }
.badge--primary   { background-color: rgba(27,77,62,0.10);        color: var(--color-primary-500); }
.badge--accent    { background-color: rgba(232,168,56,0.15);      color: var(--color-accent-600); }
.badge--success   { background-color: var(--color-success-bg);    color: var(--color-success-fg); }
.badge--warning   { background-color: var(--color-warning-bg);    color: var(--color-warning-fg); }
.badge--danger    { background-color: var(--color-danger-bg);     color: var(--color-danger-fg); }
.badge--info      { background-color: var(--color-info-bg);       color: var(--color-info-fg); }

.badge--uppercase {
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  font-size: 11px;
}

/* ═══════════════════════════════════════════════════════════
 * FORM — field, input, textarea, select, checkbox, label
 * ═══════════════════════════════════════════════════════════ */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.field__label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
}
.field__hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}
.field__error {
  font-size: var(--font-size-xs);
  color: var(--color-danger-fg);
  font-weight: var(--font-weight-medium);
}

.input,
.textarea,
.select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  line-height: var(--line-height-normal);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.input::placeholder,
.textarea::placeholder { color: var(--color-neutral-500); }
.input:focus-visible,
.textarea:focus-visible,
.select:focus-visible {
  outline: none;
  border-color: var(--color-primary-500);
  box-shadow: 0 0 0 3px rgba(27,77,62,0.15);
}
.input:disabled,
.textarea:disabled,
.select:disabled {
  background-color: var(--color-neutral-100);
  color: var(--color-text-secondary);
  cursor: not-allowed;
}
.field--error .input,
.field--error .textarea,
.field--error .select {
  border-color: var(--color-danger-fg);
}
.textarea { min-height: 120px; resize: vertical; }

/* ═══════════════════════════════════════════════════════════
 * NAV (header principal marketing)
 * ═══════════════════════════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background-color: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--color-border-subtle);
}
.nav__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding: var(--space-3) var(--grid-gutter-mobile);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
}
@media (min-width: 768px) {
  .nav__inner { padding-inline: var(--grid-gutter); }
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-primary-500);
  text-decoration: none;
  white-space: nowrap;
}
.nav__brand em {
  font-style: normal;
  color: var(--color-accent-400);
}

.nav__links {
  display: none;
  list-style: none;
  gap: var(--space-5);
  align-items: center;
  flex: 1;
  justify-content: center;
}
@media (min-width: 1024px) { .nav__links { display: flex; } }

.nav__links a {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
}
.nav__links a:hover { color: var(--color-primary-500); background-color: var(--color-bg-subtle); }
.nav__links a[aria-current="page"] { color: var(--color-primary-500); font-weight: var(--font-weight-semibold); }

.nav__cta-group { display: flex; align-items: center; gap: var(--space-2); }
.nav__cta-group .btn { white-space: nowrap; }

.nav__burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  background: none;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--color-text-primary);
}
.nav__burger:hover { background-color: var(--color-bg-subtle); }
@media (min-width: 1024px) { .nav__burger { display: none; } }

/* Mobile drawer */
.nav-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  background-color: var(--color-primary-500);
  color: var(--color-text-inverse);
  padding: var(--space-5);
  transform: translateX(100%);
  transition: transform var(--transition-normal);
  overflow-y: auto;
}
.nav-drawer.open { transform: translateX(0); }
.nav-drawer__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  background: none;
  border: none;
  color: var(--color-text-inverse);
  cursor: pointer;
  font-size: var(--font-size-xl);
  width: 40px; height: 40px;
  border-radius: var(--radius-md);
}
.nav-drawer__close:hover { background-color: rgba(255,255,255,0.1); }
.nav-drawer__links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-8);
}
.nav-drawer__links a {
  display: block;
  padding: var(--space-3) var(--space-4);
  color: var(--color-text-inverse);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  text-decoration: none;
  border-radius: var(--radius-md);
}
.nav-drawer__links a:hover { background-color: rgba(255,255,255,0.08); }

/* ═══════════════════════════════════════════════════════════
 * FOOTER
 * ═══════════════════════════════════════════════════════════ */
.footer {
  background-color: var(--color-primary-700);
  color: var(--color-neutral-300);
  padding-block: var(--space-7) var(--space-5);
  margin-top: var(--space-9);
}
.footer__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--grid-gutter-mobile);
}
@media (min-width: 768px) {
  .footer__inner { padding-inline: var(--grid-gutter); }
}

.footer__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}

.footer__brand {
  font-family: var(--font-display);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-text-inverse);
  margin-bottom: var(--space-2);
}
.footer__tagline {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-neutral-400);
  max-width: 30ch;
}

.footer__heading {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-inverse);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  margin-bottom: var(--space-3);
}
.footer__links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.footer__links a {
  color: var(--color-neutral-300);
  font-size: var(--font-size-sm);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.footer__links a:hover { color: var(--color-accent-400); }

.footer__bottom {
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--color-neutral-500);
}

/* ═══════════════════════════════════════════════════════════
 * HERO
 * ═══════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  padding-block: var(--space-8) var(--space-8);
  overflow: hidden;
}
.hero--gradient {
  background: linear-gradient(135deg,
    var(--color-primary-700) 0%,
    var(--color-primary-500) 55%,
    var(--color-primary-400) 100%);
  color: var(--color-text-inverse);
}
.hero__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--grid-gutter-mobile);
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .hero__inner { padding-inline: var(--grid-gutter); }
  .hero { padding-block: var(--space-9); }
}

.hero__title {
  font-family: var(--font-display);
  font-size: var(--font-size-4xl);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-4);
  max-width: 18ch;
}
@media (min-width: 768px) {
  .hero__title { font-size: var(--font-size-5xl); }
}
@media (min-width: 1280px) {
  .hero__title { font-size: var(--font-size-6xl); }
}
.hero__lead {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-5);
  max-width: 55ch;
  opacity: 0.92;
}
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.hero--gradient .hero__lead { color: rgba(255,255,255,0.88); }
.hero--gradient .section__eyebrow { color: var(--color-accent-200); }

/* ═══════════════════════════════════════════════════════════
 * FAQ
 * ═══════════════════════════════════════════════════════════ */
.faq {
  max-width: var(--container-prose);
  margin-inline: auto;
}
.faq-item {
  border-bottom: 1px solid var(--color-border-subtle);
}
.faq-item__question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding-block: var(--space-4);
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  text-align: left;
}
.faq-item__question:hover { color: var(--color-primary-500); }
.faq-item__chevron {
  width: 20px; height: 20px;
  flex-shrink: 0;
  color: var(--color-text-secondary);
  transition: transform var(--transition-fast);
}
.faq-item[aria-expanded="true"] .faq-item__chevron { transform: rotate(180deg); }

.faq-item__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow), padding var(--transition-fast);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
}
.faq-item[aria-expanded="true"] .faq-item__answer {
  max-height: 600px;
  padding-bottom: var(--space-4);
}

/* ═══════════════════════════════════════════════════════════
 * TESTIMONIAL
 * ═══════════════════════════════════════════════════════════ */
.testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-4);
}
.testimonial {
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}
.testimonial:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.testimonial__stars {
  color: var(--color-accent-400);
  font-size: var(--font-size-sm);
  letter-spacing: 2px;
  margin-bottom: var(--space-3);
}
.testimonial__text {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  font-style: italic;
  margin-bottom: var(--space-4);
}
.testimonial__author { display: flex; align-items: center; gap: var(--space-3); }
.testimonial__avatar {
  width: 44px; height: 44px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-primary-500);
  color: var(--color-text-inverse);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-base);
  flex-shrink: 0;
}
.testimonial__name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
}
.testimonial__role {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

/* ═══════════════════════════════════════════════════════════
 * PROSE — mise en forme articles blog / pages longues
 * ═══════════════════════════════════════════════════════════ */
.prose {
  max-width: var(--container-prose);
  margin-inline: auto;
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-primary);
}
.prose > * + * { margin-top: var(--space-4); }
.prose h1 {
  font-family: var(--font-display);
  font-size: var(--font-size-4xl);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  font-weight: var(--font-weight-bold);
  margin-top: var(--space-7);
}
.prose h2 {
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-snug);
  font-weight: var(--font-weight-bold);
  margin-top: var(--space-7);
  color: var(--color-primary-500);
}
.prose h3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  margin-top: var(--space-6);
}
.prose p { color: var(--color-text-primary); }
.prose a { color: var(--color-primary-500); text-decoration: underline; text-underline-offset: 2px; }
.prose a:hover { color: var(--color-primary-400); }
.prose strong { font-weight: var(--font-weight-bold); color: var(--color-text-primary); }
.prose em { font-style: italic; }
.prose ul, .prose ol { padding-left: var(--space-5); }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose li { margin-top: var(--space-2); }
.prose blockquote {
  border-left: 3px solid var(--color-accent-400);
  padding-left: var(--space-4);
  font-style: italic;
  color: var(--color-text-secondary);
  margin-block: var(--space-5);
}
.prose code {
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 0.92em;
  background-color: var(--color-bg-subtle);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}
.prose pre {
  background-color: var(--color-primary-700);
  color: var(--color-neutral-100);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  overflow-x: auto;
  font-size: var(--font-size-sm);
}
.prose pre code { background: none; padding: 0; color: inherit; }
.prose hr {
  border: none;
  border-top: 1px solid var(--color-border-subtle);
  margin-block: var(--space-6);
}
.prose img, .prose video {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  margin-block: var(--space-5);
}

/* ═══════════════════════════════════════════════════════════
 * KPI GRID — chiffres clés sur les landings
 * ═══════════════════════════════════════════════════════════ */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .kpi-grid { grid-template-columns: repeat(4, 1fr); }
}
.kpi {
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  text-align: left;
  box-shadow: var(--shadow-sm);
}
.kpi__value {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-extrabold);
  line-height: 1;
  color: var(--color-primary-500);
  letter-spacing: var(--letter-spacing-tight);
}
.kpi__label {
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-snug);
}
.kpi__delta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-success-fg);
}
.kpi__delta--down { color: var(--color-danger-fg); }

/* ═══════════════════════════════════════════════════════════
 * ALERT / CALLOUT
 * ═══════════════════════════════════════════════════════════ */
.alert {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
}
.alert__icon { flex-shrink: 0; }
.alert--info    { background-color: var(--color-info-bg);    color: var(--color-info-fg); }
.alert--success { background-color: var(--color-success-bg); color: var(--color-success-fg); }
.alert--warning { background-color: var(--color-warning-bg); color: var(--color-warning-fg); }
.alert--danger  { background-color: var(--color-danger-bg);  color: var(--color-danger-fg); }

/* ═══════════════════════════════════════════════════════════
 * UTILITIES minimales
 * ═══════════════════════════════════════════════════════════ */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-3);
  z-index: var(--z-toast);
  background-color: var(--color-primary-500);
  color: var(--color-text-inverse);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  text-decoration: none;
  font-weight: var(--font-weight-semibold);
}
.skip-link:focus { top: var(--space-3); }

.text-center { text-align: center; }
.text-balance { text-wrap: balance; }

.grid-2 { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
@media (min-width: 768px) { .grid-2 { grid-template-columns: 1fr 1fr; gap: var(--space-6); } }
.grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-5); }

/* Motion-reduce : suspend toutes les transitions/animations */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
