/* ============================================ */
/* ========== FOOTER ========== */
/* ============================================ */
footer.site-footer {
  background: var(--color-primary);
  color: color-mix(in srgb, var(--color-surface) 88%, transparent);
  padding: 80px 0 0;
}
.footer-fleuron {
  text-align: center;
  color: var(--color-accent);
  opacity: 0.35;
  margin-bottom: 64px;
}
.footer-fleuron svg { width: 24px; height: 24px; display: inline-block; }
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 56px;
  margin-bottom: 64px;
}
.footer-brand p {
  font-size: 0.9rem;
  line-height: 1.7;
  opacity: 0.7;
}
.footer-col h4 {
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 20px;
  font-weight: 600;
}
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 11px; font-size: 0.93rem; }
.footer-col a { color: color-mix(in srgb, var(--color-surface) 88%, transparent); transition: color 0.2s; }
.footer-col a:hover { color: var(--color-accent); }
.footer-social { display: flex; gap: 12px; margin-top: 20px; }
.footer-social a {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--color-surface) 20%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: color-mix(in srgb, var(--color-surface) 70%, transparent);
  transition: all 0.25s;
}
.footer-social a:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, transparent);
}
.footer-social svg { width: 16px; height: 16px; }
.footer-bottom {
  border-top: 1px solid color-mix(in srgb, var(--color-surface) 12%, transparent);
  padding: 28px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 0.82rem;
  opacity: 0.6;
}
.footer-bottom a { transition: color 0.2s; }
.footer-bottom a:hover { color: var(--color-accent); opacity: 1; }
.footer-bottom-links { display: flex; gap: 24px; flex-wrap: wrap; }

.footer-credit {
  text-align: center;
  padding: 16px 0 28px;
  font-size: 0.75rem;
  color: color-mix(in srgb, var(--color-surface) 30%, transparent);
  letter-spacing: 0.04em;
}
.footer-credit a {
  color: color-mix(in srgb, var(--color-accent) 65%, transparent);
  font-weight: 600;
  letter-spacing: 0.06em;
  transition: color 0.2s;
}
.footer-credit a:hover { color: var(--color-accent); }

@media (max-width: 960px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 700px) {
  .footer-grid { grid-template-columns: 1fr; }
}
