/* ============================================================
   FOOTER · Light premium variant
   Overrides previous dark/red footer styles. Loaded last.
   ============================================================ */

/* ---- Reset prior overrides on .footer.footer--light ---- */
.footer.footer--light,
.footer.footer--light.invert-on-scroll,
.footer.footer--light.invert-on-scroll.is-inverted {
  background: #FFFFFF !important;
  color: #0A0B0D !important;
  border-top: 1px solid rgba(10,11,13,0.08) !important;
  padding: clamp(64px, 9vh, 112px) 0 28px !important;
  position: relative;
  overflow: hidden;
}

/* Kill any inherited gradient overlays / decorative bars */
.footer.footer--light::before,
.footer.footer--light::after,
.footer.footer--light.invert-on-scroll::before,
.footer.footer--light.invert-on-scroll.is-inverted::before {
  content: none !important;
  display: none !important;
  background: none !important;
}

/* Premium top hairline accent — a refined static rule, no red */
.footer.footer--light > .wrap::before {
  content: "";
  display: block;
  width: 56px;
  height: 2px;
  background: #0A0B0D;
  margin: 0 0 clamp(32px, 5vh, 56px);
  border-radius: 2px;
}

/* ---- Lead block ---- */
.footer-lead {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 32px;
  padding-bottom: clamp(40px, 6vh, 72px);
  border-bottom: 1px solid rgba(10,11,13,0.08);
}
.footer-lead__brand {
  display: flex;
  align-items: center;
  gap: 20px;
  min-width: 0;
}
.footer-lead__brand .brand-logo-footer {
  width: 56px;
  height: 56px;
  flex: 0 0 56px;
  animation: none !important;
  filter: none !important;
}
.footer-lead__title {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.footer-lead__eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(10,11,13,0.55) !important;
}
.footer-lead__headline {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 600;
  line-height: 1.18;
  letter-spacing: -0.015em;
  color: #0A0B0D !important;
  margin: 0;
  max-width: 28ch;
  text-wrap: pretty;
}
.footer-lead__regions {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #0A0B0D !important;
  white-space: nowrap;
}
.footer-region {
  position: relative;
  padding: 6px 10px;
  border: 1px solid rgba(10,11,13,0.14);
  border-radius: 999px;
  background: rgba(10,11,13,0.02);
}
.footer-region__sep {
  color: rgba(10,11,13,0.30) !important;
  font-size: 10px;
}

/* ---- Grid ---- */
.footer.footer--light .footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  padding: clamp(40px, 6vh, 64px) 0 clamp(32px, 5vh, 48px);
  border-bottom: 1px solid rgba(10,11,13,0.08);
}
.footer.footer--light .footer-col { min-width: 0; }
.footer.footer--light .footer-about {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(10,11,13,0.62) !important;
  max-width: 38ch;
  margin: 0;
}

/* Column titles */
.footer.footer--light h5,
.footer.footer--light .footer-grid h5 {
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: rgba(10,11,13,0.45) !important;
  margin: 0 0 18px !important;
}

/* Links */
.footer.footer--light .footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer.footer--light .footer-links li {
  margin: 0 !important;
  color: #0A0B0D !important;
}
.footer.footer--light .footer-links a,
.footer.footer--light .footer-grid a,
.footer.footer--light .footer-grid li {
  font-family: var(--font-body);
  font-size: 14.5px;
  font-weight: 500;
  color: #0A0B0D !important;
  text-decoration: none;
  position: relative;
  display: inline-block;
  transition: color .25s var(--e-out), transform .25s var(--e-out);
  transform: none !important;
}
.footer.footer--light .footer-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .35s var(--e-out);
}
.footer.footer--light .footer-links a:hover {
  color: #0A0B0D !important;
  transform: none !important;
}
.footer.footer--light .footer-links a:hover::after {
  transform: scaleX(1);
}

/* ---- Bottom bar ---- */
.footer.footer--light .footer-bottom {
  padding-top: 28px !important;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(10,11,13,0.50) !important;
  border-top: 0 !important;
}
.footer.footer--light .footer-bottom .footer-copy,
.footer.footer--light .footer-bottom .footer-meta,
.footer.footer--light .footer-bottom span {
  color: rgba(10,11,13,0.50) !important;
}
.footer.footer--light .footer-bottom #year { color: inherit !important; }

/* ---- Kill any inherited dark-theme leakage ---- */
.footer.footer--light .muted,
.footer.footer--light p,
.footer.footer--light span,
.footer.footer--light a,
.footer.footer--light h2,
.footer.footer--light h5 {
  text-shadow: none !important;
}
.footer.footer--light .brand-logo-footer {
  animation: none !important;
}

/* ---- Responsive ---- */
@media (max-width: 980px) {
  .footer-lead {
    grid-template-columns: 1fr;
    align-items: flex-start;
    gap: 24px;
  }
  .footer-lead__regions { justify-content: flex-start; }
  .footer.footer--light .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px 24px;
  }
  .footer.footer--light .footer-col--about { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .footer-lead__brand { gap: 14px; }
  .footer-lead__brand .brand-logo-footer { width: 44px; height: 44px; flex-basis: 44px; }
  .footer.footer--light .footer-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .footer.footer--light .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}
