/* ═══════════════════════════════════════════════════════════
   ecosystem.css — Page Fonctionnalités / Écosystème
   ═══════════════════════════════════════════════════════════ */

/* ─── Hub central écosystème ───────────────────────── */
.eco-hub {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: var(--grad1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: .85rem;
  text-align: center;
  line-height: 1.3;
  box-shadow: 0 0 40px rgba(59, 130, 246, .4);
  position: relative;
}

.eco-hub::before {
  content: '';
  position: absolute;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  border: 1px solid rgba(59, 130, 246, .25);
  animation: spin 20s linear infinite;
}

.eco-hub::after {
  content: '';
  position: absolute;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  border: 1px solid rgba(99, 102, 241, .15);
  animation: spin 14s linear reverse infinite;
}

/* ─── Grille de modules ────────────────────────────── */
.eco-modules {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  width: 100%;
}

.eco-module {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1.1rem 1rem;
  text-align: center;
  transition: all var(--t);
}

.eco-module:hover {
  border-color: rgba(59, 130, 246, .4);
  transform: translateY(-2px);
}

.eco-module .ico  { font-size: 1.5rem; margin-bottom: .4rem; }
.eco-module span  { font-size: .82rem; color: var(--muted); display: block; }

/* ─── Responsive ───────────────────────────────────── */
@media (max-width: 1024px) {
  .eco-modules { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .eco-modules { grid-template-columns: 1fr 1fr; }
}
