/* Footer styling overrides (global). */
#main-footer {
  position: relative;
  background: linear-gradient(180deg, #1a1a1a 0%, #0f0f0f 100%);
  background-image: none;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
  font-family: var(--font-barlow, 'Barlow Condensed', sans-serif);
}
#main-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(640px 260px at 12% 0%, rgba(140, 149, 0, 0.2), transparent 70%),
    radial-gradient(720px 280px at 88% 10%, rgba(217, 101, 40, 0.18), transparent 70%),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0 1px, transparent 1px 8px);
  opacity: 0.6;
  pointer-events: none;
}
#main-footer section,
#main-footer .container {
  position: relative;
  z-index: 1;
}

#footer-top {
  padding: 0;
}
#footer-top .container {
  position: static;
}
#main-footer {
  --footer-content-width: min(1064px, 91vw);
}
#main-footer .container {
  width: var(--footer-content-width);
  margin-left: auto;
  margin-right: auto;
}
#main-footer .footer-logo-abs {
  position: static;
  margin-left: auto;
  align-self: flex-end;
  display: block;
}
#main-footer .footer-logo-abs img {
  width: clamp(160px, 18vw, 250px);
  height: auto;
  display: block;
}

#footer-top img {
  max-height: 48px;
  padding: 18px 0 8px;
}

#footer-mid {
  padding: 28px 0 32px;
}
#footer-mid a {
  color: #f2f2f2;
  display: block;
  font-size: 17px;
  line-height: 1.6rem;
}
#footer-mid a:hover {
  color: #ffffff;
}
#footer-mid img {
  height: 22px;
  width: 22px;
  margin-bottom: 17px;
}
#footer-mid .social-nav-icons {
  display: flex;
  flex-direction: column;
}
#main-footer #footer-mid .container.footer-hidden {
  --footer-column-gap: 6px;
  display: flex;
  gap: var(--footer-column-gap);
  flex-wrap: nowrap;
  align-items: flex-start;
}
#main-footer #footer-mid .container.footer-hidden > .span3:first-child {
  margin-left: 0;
  padding-left: 0;
}
#main-footer #footer-mid .container.footer-hidden > [class*="span"] {
  float: none;
  margin-left: 0;
  width: auto;
}
#main-footer #footer-mid .container.footer-hidden > .footer-col {
  flex: 1 1 0;
  min-width: 0;
}
#main-footer #footer-mid .container.footer-hidden > .footer-logo-col {
  flex: 0 0 auto;
}

#footer-bottom {
  background-color: rgba(140, 149, 0, 0.85);
  color: #fff;
}
#footer-bottom .container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 4px 20px; /* row-gap column-gap */
  padding: 14px 0;
}
#footer-bottom span {
  white-space: nowrap;
}
#footer-bottom a {
  color: #fff;
}

@media (max-width: 960px) {
  #footer-top {
    padding: 18px 0 8px;
  }
  #main-footer .footer-logo-abs img {
    width: 180px;
    height: auto;
  }
  #main-footer #footer-mid .container.footer-hidden {
    --footer-column-gap: 24px;
  }
  #main-footer #footer-mid .container.footer-hidden > .span3:first-child {
    margin-left: 0;
  }
}

@media (max-width: 767px) {
  #main-footer #footer-mid .container.footer-hidden {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    column-gap: 16px;
    row-gap: 18px;
  }
  #main-footer #footer-mid .container.footer-hidden .footer-logo-col {
    grid-column: 1 / span 2;
    grid-row: 2;
    justify-self: start;
  }
  #main-footer .footer-logo-abs {
    margin-left: 0;
  }
}

@media (max-width: 500px) {
  #main-footer #footer-mid .container.footer-hidden {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 20px;
    row-gap: 18px;
  }
  #main-footer #footer-mid .container.footer-hidden .footer-col-primary {
    grid-column: 1;
    grid-row: 1;
  }
  #main-footer #footer-mid .container.footer-hidden .footer-col-secondary {
    grid-column: 2;
    grid-row: 1;
  }
  #main-footer #footer-mid .container.footer-hidden .footer-col-tertiary {
    grid-column: 1;
    grid-row: 2;
  }
  #main-footer #footer-mid .container.footer-hidden .footer-col-social {
    grid-column: 2;
    grid-row: 2;
  }
  #main-footer #footer-mid .container.footer-hidden .footer-logo-col {
    grid-column: 1;
    grid-row: 3;
    margin-left: 0;
    align-self: flex-start;
  }
  #main-footer .footer-logo-abs img {
    width: 150px;
  }
}

/* App User Mode styles moved to dedicated appuser.css */
