/* ===== Réseaux sociaux (Contact) ===== */
.social-section{
  background:#111;
  padding-top:40px;
}
.social-title{
  font-family:'Nunito Sans','Avenir Next',sans-serif;
  font-weight:800;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:1.6rem;
  margin-bottom:22px;
}
.social-grid{
  list-style:none;
  margin:0 auto;
  padding:0;
  max-width:1100px;
  display:grid;
  grid-template-columns: repeat( auto-fit, minmax(220px, 1fr) );
  gap:18px;
}
.social-item{display:block;}
.social-link{
  display:flex;
  flex-direction:column;
  align-items:center; 
  gap:10px;
  text-decoration:none;
  background:#1a1a1a;
  color:#fff;
  border-radius:12px;
  padding:18px 16px;
  box-shadow:0 0 0 1px rgba(255,255,255,.06) inset,
             0 10px 30px rgba(0,0,0,.25);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.social-link:hover{
  transform: translateY(-2px);
  box-shadow:0 0 0 1px rgba(255,255,255,.08) inset,
             0 12px 34px rgba(0,0,0,.32);
  background:#1d1d1d;
}
.social-icon{
  display:grid; place-items:center;
  width:56px; height:56px;
  border-radius:14px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}
.social-icon svg{
  width:28px; height:28px; fill:#fff;
}

/* Thèmes par réseau */
.social-icon.li{ background: linear-gradient(135deg,#0a66c2,#0b5aa9); }
.social-icon.fb{ background: linear-gradient(135deg,#1877f2,#0f5cc4); }
.social-icon.ig{ background: radial-gradient(circle at 30% 30%, #feda75, #d62976 55%, #962fbf 75%, #4f5bd5); }

/* Texte sous l’icône */
.social-name{
  text-align:center;
  font:700 .98rem/1.25 'Nunito Sans',system-ui,sans-serif;
  color:#eee;
}
.social-tag{
  font:700 .72rem/1 'Nunito Sans',system-ui,sans-serif;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#ffcc70;
  opacity:.95;
}