.gradient-bg {
  background: linear-gradient(135deg, #1d4ed8 0%, #6366f1 55%, #7c3aed 100%);
}

.soft-blue {
  background: #eaf2ff;
}

/* petit effet de chargement */
body.is-loading {
  opacity: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
}

/* Clamp helpers (Tailwind CDN doesn't always ship the line-clamp plugin) */
.line-clamp-1,
.line-clamp-3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-1 { -webkit-line-clamp: 1; }
.line-clamp-3 { -webkit-line-clamp: 3; }

/* Partners marquee (top, finite loops) */
.partners-marquee {
  width: 100%;
  overflow: hidden;
  position: relative;
  scrollbar-width: none;
  overflow-x: hidden;
}

.partners-marquee::-webkit-scrollbar {
  display: none;
}

.partners-track {
  display: flex;
  gap: 12px;
  align-items: center;
  width: max-content;
  will-change: transform;
}

.partners-track-3x {
  animation: partners-marquee 14s linear 0s 3;
}

.partners-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  white-space: nowrap;
  transition: background 150ms ease, border-color 150ms ease, transform 150ms ease;
}

.partners-item:hover {
  background: #f9fafb;
  border-color: #d1d5db;
  transform: translateY(-1px);
}

.partners-img {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid #e5e7eb;
  background: #f3f4f6;
  flex: 0 0 auto;
}

.partners-img-fallback {
  background: linear-gradient(135deg, #1d4ed8 0%, #6366f1 55%, #7c3aed 100%);
}

.partners-title {
  font-weight: 800;
  color: #111827;
  font-size: 14px;
}

@keyframes partners-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
