/* FOOTER */
footer {
  padding: 56px 32px 120px;
  border-top: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-bg-deep) 90%, transparent);
  margin-top: 40px;
}
.footer-inner {
  max-width: 1100px; margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 48px;
}
.footer-cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(200px, 1fr));
  gap: 48px;
  width: 100%;
  max-width: 900px;
  justify-items: start;
}
@media (max-width: 820px) {
  .footer-cols { grid-template-columns: 1fr 1fr; gap: 28px; }
}
@media (max-width: 520px) {
  .footer-cols { grid-template-columns: 1fr; justify-items: center; text-align: center; }
  footer .footer-list-emoji li { justify-content: center; }
}
.footer-brand-wrap {
  text-align: center;
  max-width: 560px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border);
  width: 100%;
}
.footer-brand-wrap .footer-brand { justify-content: center; }
footer h4 {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 500; font-style: italic;
  margin-bottom: 14px;
}
footer ul { list-style: none; }
footer li { padding: 5px 0; font-size: 13.5px; color: var(--color-text-muted); cursor: pointer; }
footer li:hover { color: var(--color-gold); }

/* Listes footer avec emojis alignes */
footer .footer-list-emoji li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 6px 0;
  font-feature-settings: "zero" 0;
  transition: transform 200ms ease, color 200ms ease;
}
footer .footer-list-emoji li:hover {
  transform: translateX(3px);
}
footer .foot-emoji {
  font-size: 15px;
  width: 28px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  filter: drop-shadow(0 0 4px rgba(245, 198, 89, 0.25));
}
footer .foot-emoji-infinity {
  font-family: var(--font-mono);
  font-size: 20px;
  color: var(--color-gold);
  font-weight: 500;
}
.footer-brand {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 8px;
}
.footer-brand .footer-logo-wrap {
  width: 48px; height: 48px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  animation: logo-pulse 3s ease-in-out infinite;
}
.footer-brand .footer-logo-wrap img {
  width: 118%; height: 118%;
  object-fit: cover;
  margin: -9%;
  display: block;
}
.footer-brand-text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 26px; font-weight: 500;
  letter-spacing: -0.015em;
}
.footer-brand-text .dot { color: var(--color-gold); }
.footer-tagline {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-gold);
  font-size: 17px;
  margin: 6px 0 14px;
}
/* Footer socials colored */
.footer-socials-colored {
  display: flex;
  gap: 10px;
  margin-top: 20px;
  justify-content: center;
  flex-wrap: wrap;
}
.footer-socials-colored a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: white;
  transition: transform 200ms ease, filter 200ms ease, box-shadow 200ms ease;
}
.footer-socials-colored a:hover {
  transform: translateY(-2px) scale(1.08);
  filter: brightness(1.1);
}
.footer-socials-colored .fs-fb  { background: #1877F2; }
.footer-socials-colored .fs-ig  { background: radial-gradient(circle at 30% 107%, #FED373 0%, #F15245 30%, #D92E7F 60%, #9B36B7 85%, #515ECF 100%); }
.footer-socials-colored .fs-tt  { background: #000000; }
.footer-socials-colored .fs-li  { background: #0A66C2; }
.footer-socials-colored .fs-yt  { background: #FF0000; }
.footer-socials-colored .fs-wa  { background: #25D366; }
.footer-socials-colored .fs-gmb { background: #fff; }
.footer-socials-colored .fs-fb:hover  { box-shadow: 0 0 18px rgba(24, 119, 242, 0.6); }
.footer-socials-colored .fs-ig:hover  { box-shadow: 0 0 18px rgba(228, 64, 95, 0.6); }
.footer-socials-colored .fs-tt:hover  { box-shadow: 0 0 18px rgba(255, 0, 80, 0.6); }
.footer-socials-colored .fs-li:hover  { box-shadow: 0 0 18px rgba(10, 102, 194, 0.6); }
.footer-socials-colored .fs-yt:hover  { box-shadow: 0 0 18px rgba(255, 0, 0, 0.6); }
.footer-socials-colored .fs-wa:hover  { box-shadow: 0 0 18px rgba(37, 211, 102, 0.7); }
.footer-socials-colored .fs-gmb:hover { box-shadow: 0 0 18px rgba(66, 133, 244, 0.6); }

.footer-legal {
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  color: var(--color-text-subtle);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
/* Footer signature button */
.footer-signature-btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 14px 28px;
  border-radius: 100px;
  background: linear-gradient(135deg, rgba(10,5,24,0.9), rgba(26,15,56,0.9));
  position: relative;
  text-decoration: none;
  transition: transform 200ms ease, box-shadow 200ms ease;
  cursor: pointer;
}
.footer-signature-btn::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 100px;
  background: conic-gradient(from var(--fsb-angle, 0deg),
    var(--color-gold) 0%, transparent 25%,
    var(--color-magenta) 50%, transparent 75%,
    var(--color-gold) 100%);
  z-index: -1;
  opacity: 0.7;
  animation: fsb-rotate 8s linear infinite;
}
@property --fsb-angle { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@keyframes fsb-rotate { to { --fsb-angle: 360deg; } }
.footer-signature-btn:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 12px 40px rgba(245, 198, 89, 0.4); }
.footer-signature-btn:hover::before { opacity: 1; }
.fsb-wand { font-size: 20px; filter: drop-shadow(0 0 8px var(--color-gold)); }
.fsb-text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: -0.01em;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.fsb-brand {
  background: linear-gradient(90deg, var(--color-gold), var(--color-magenta));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.fsb-dot { color: var(--color-gold); }
.fsb-cross { font-family: var(--font-mono); font-style: normal; color: var(--color-gold); font-size: 14px; }
.fsb-ida { font-family: var(--font-mono); font-style: normal; letter-spacing: 0.1em; font-size: 18px; color: var(--color-text); font-feature-settings: "zero" 0; }
.fsb-infinity { color: var(--color-gold); font-size: 24px; filter: drop-shadow(0 0 8px var(--color-gold)); }
.fsb-year {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--color-text-subtle);
  padding-left: 14px;
  border-left: 1px solid var(--color-border-glow);
}
.footer-legal-links {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  color: var(--color-text-subtle);
}
