/** Pied de page : colonnes de widgets, newsletter, réseaux sociaux, bas de page. */

.site-footer { background: var(--jdj-surface-2); border-top: 1px solid var(--jdj-border); margin-top: var(--sp-7); }

.footer-newsletter {
  background: linear-gradient(135deg, var(--jdj-primary), var(--jdj-primary-700));
  color: #fff; border-radius: var(--jdj-radius); padding: clamp(var(--sp-4), 5vw, var(--sp-6));
  display: grid; gap: var(--sp-3); align-items: center;
  margin-block: var(--sp-6) 0; transform: translateY(calc(var(--sp-6) * -1 + var(--sp-3)));
}
@media (min-width: 760px) { .footer-newsletter { grid-template-columns: 1.2fr 1fr; } }
.footer-newsletter h2 { color: #fff; font-size: var(--fs-xl); }
.footer-newsletter p { color: rgba(255,255,255,0.85); font-size: var(--fs-sm); margin-top: var(--sp-1); }
.footer-newsletter form { display: flex; gap: var(--sp-1); flex-wrap: wrap; }
.footer-newsletter input[type="email"] { flex: 1; min-width: 200px; background: rgba(255,255,255,0.95); border: 0; }

.footer-cols { display: grid; gap: var(--sp-4); padding-block: var(--sp-5); grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr)); }

.footer-brand__title { font-family: var(--jdj-font-headings); font-weight: 800; font-size: var(--fs-lg); }
.footer-brand p { color: var(--jdj-text-muted); font-size: var(--fs-sm); margin-top: var(--sp-1); max-width: 32ch; }

/* Réseaux sociaux. */
.social-links { display: flex; gap: var(--sp-1); margin-top: var(--sp-2); }
.social-links a {
  display: inline-grid; place-items: center; width: 40px; height: 40px;
  border-radius: 50%; background: var(--jdj-surface); border: 1px solid var(--jdj-border);
  color: var(--jdj-text); transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.social-links a:hover { background: var(--jdj-primary); color: #fff; transform: translateY(-2px); }
.social-links svg { width: 18px; height: 18px; }

.footer-bottom {
  border-top: 1px solid var(--jdj-border); padding-block: var(--sp-3);
  display: flex; flex-wrap: wrap; gap: var(--sp-2); justify-content: space-between; align-items: center;
  font-size: var(--fs-sm); color: var(--jdj-text-muted);
}
.footer-bottom nav { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.footer-bottom a { color: var(--jdj-text-muted); text-decoration: none; }
.footer-bottom a:hover { color: var(--jdj-primary); }

/* Bouton retour en haut. */
.to-top {
  position: fixed; right: var(--sp-3); bottom: var(--sp-3); z-index: 90;
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--jdj-primary); color: #fff; box-shadow: var(--shadow-md);
  display: grid; place-items: center;
  opacity: 0; transform: translateY(12px) scale(0.9); pointer-events: none;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.to-top[data-visible="true"] { opacity: 1; transform: none; pointer-events: auto; }
