/**
 * Rodapé: faixa preta, separação vermelha, ícones, ticker (mesma estética do intro)
 */

.site-footer {
  position: relative;
  z-index: 1;
  background: #000;
  border-top: 1px solid rgba(255, 0, 0, 0.3);
  color: #f0f0f0;
  text-align: center;
}

.site-footer__inner {
  max-width: 100%;
  margin: 0 auto;
  padding: 2.75rem clamp(1rem, 3vw, 2rem) 2.1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.45rem;
}

.site-footer__social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
}

.site-footer__icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  transition: color 0.2s ease, transform 0.2s ease;
  text-decoration: none;
}

.site-footer__icon-link:hover,
.site-footer__icon-link:focus-visible {
  color: #ff3b2f;
  transform: scale(1.08);
  outline: none;
}

.site-footer__meta {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.85rem;
  max-width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.site-footer__contact {
  margin: 0;
  font-family: "Poppins", "Montserrat", sans-serif;
  font-size: clamp(0.85rem, 2vw, 0.95rem);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.35rem 0.75rem;
  text-transform: uppercase;
}

.site-footer__sep {
  color: rgba(255, 255, 255, 0.45);
  user-select: none;
}

.site-footer__link {
  color: #f0f0f0;
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 59, 47, 0.35);
  transition: color 0.2s, border-color 0.2s;
  text-transform: uppercase;
}

.site-footer__link:hover,
.site-footer__link:focus-visible {
  color: #ff3b2f;
  border-bottom-color: rgba(255, 59, 47, 0.8);
  outline: none;
}

.site-footer__legal {
  margin: 0;
  font-family: "Poppins", "Montserrat", sans-serif;
  font-size: clamp(0.75rem, 1.6vw, 0.85rem);
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.7);
  text-transform: uppercase;
  width: 100%;
  box-sizing: border-box;
  text-align: justify;
  text-align-last: justify;
  hyphens: none;
}

/* “Estica” a linha única de copyright à largura dos contatos (largura definida por JS no .site-footer__meta) */
.site-footer__legal::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 0;
  vertical-align: top;
}

/* Ticker — continua a mesma família/estilo do intro, mais compacto */
.site-footer__marquee {
  overflow: hidden;
  width: 100%;
  background: #000;
  padding: 0.3rem 0 0.45rem;
}

.site-footer__marquee-row {
  display: flex;
  width: max-content;
  animation: site-footer-marquee 52s linear infinite;
  animation-play-state: paused;
  /* --marquee-shift (px) preenchido por site-footer-marquee.js; fallback -50% */
  transform: translate3d(0, 0, 0);
}

.site-footer__marquee-row.is-marquee-synced {
  animation-play-state: running;
}

@media (prefers-reduced-motion: reduce) {
  .site-footer__marquee-row {
    animation: none;
    animation-play-state: running;
    margin: 0 auto;
    max-width: 100%;
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
  }

  .site-footer__marquee-letter {
    transform: rotateX(0deg);
    color: #fff;
    -webkit-text-fill-color: #fff;
    -webkit-text-stroke-width: 0;
  }
}

@keyframes site-footer-marquee {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(var(--marquee-shift, -50%), 0, 0);
  }
}

.site-footer__marquee-group {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  flex: 0 0 auto;
  flex-shrink: 0;
  padding: 0 0.5rem;
  box-sizing: border-box;
}

.site-footer__marquee-phrase {
  font-family: "Poppins", sans-serif;
  font-weight: 900;
  text-transform: uppercase;
  color: #ffffff;
  font-size: clamp(0.65rem, 1.1vw, 0.95rem);
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.site-footer__marquee-mundo {
  color: #ff0000;
  text-shadow: 0 0 10px rgba(255, 0, 0, 0.45);
  font-style: normal;
  font-weight: 900;
}

/* CONTRÁRIO — GSAP no JS; estilo como na intro (contorno durante o flip) */
.site-footer__marquee-contrario {
  display: inline-flex;
  align-items: center;
  vertical-align: baseline;
  margin: 0 0.02em;
  box-sizing: border-box;
  perspective: 560px;
  transform-style: preserve-3d;
}

.site-footer__marquee-letter {
  display: inline-block;
  transform-origin: center center;
  transform-style: preserve-3d;
  color: #fff;
  -webkit-text-fill-color: #fff;
  -webkit-text-stroke-width: 0;
  -webkit-text-stroke-color: transparent;
  paint-order: stroke fill;
}

/* Igual à intro (.intro-line-4b-outline), à escala do ticker — aplicado antes do flip escalonado */
.site-footer__marquee-contrario-outline .site-footer__marquee-letter {
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
  -webkit-text-stroke-width: 1.5px;
  -webkit-text-stroke-color: #ffffff;
}

@media (max-width: 480px) {
  .site-footer__marquee-contrario-outline .site-footer__marquee-letter {
    -webkit-text-stroke-width: 1px;
  }
}

.site-footer__marquee-dot {
  display: inline-block;
  color: rgba(255, 255, 255, 0.45);
  font-weight: 700;
  margin: 0 0.5rem;
  user-select: none;
  font-size: 0.65em;
}

@media (max-width: 480px) {
  .site-footer__marquee-phrase {
    font-size: clamp(0.6rem, 2.2vw, 0.8rem);
  }
}
