/* ============================================================
   FOOTER
   ============================================================ */

.footer {
  background: var(--blue);
  color: rgba(255, 255, 255, 0.82);
}

/* ---- Top Section ---- */
.footer_top {
  padding: 64px 0 48px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.footer_grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 40px;
}

/* ---- Brand Column ---- */

.footer_brand img {
  background-color: white;
  border-radius: 10px;
  padding: 10px;
  margin-bottom: 18px;
  display: block;
}

.footer_brand p {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.72);
  max-width: 280px;
  margin-bottom: 22px;
}

.footer_social {
  display: flex;
  gap: 10px;
}

.social_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.82);
  font-size: 14px;
  transition:
    background 0.22s ease,
    color 0.22s ease,
    transform 0.2s ease;
}

.social_link:hover {
  background: var(--gold);
  color: var(--blue);
  transform: translateY(-2px);
}

/* ---- Link Columns ---- */
.footer_col_title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 18px;
}

.footer_links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer_links li a {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.68);
  transition:
    color 0.2s ease,
    padding-left 0.2s ease;
  line-height: 1.4;
}

.footer_links li a:hover {
  color: var(--gold);
  padding-left: 4px;
}

/* ---- Bottom Bar ---- */
.footer_bottom {
  padding: 22px 0;
}

.footer_bottom_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.footer_bottom p {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.55);
}

.footer_disclaimer {
  font-size: 12px !important;
  font-style: italic;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  .footer_grid {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }

  .footer_brand {
    grid-column: 1 / -1;
  }

  .footer_brand p {
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  .footer_top {
    padding: 48px 0 36px;
  }

  .footer_grid {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }

  .footer_brand {
    grid-column: 1 / -1;
  }

  .footer_bottom_inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}

@media (max-width: 420px) {
  .footer_grid {
    grid-template-columns: 1fr;
  }
}
