/* Shared site footer. Loaded by every public page; styles pull from
   /_shared/theme.css so reskinning is a one-block edit. No raw hex/rgba.
   WiseTech-aligned: full-bleed indigo, mauve sub-headings, sky-blue hover. */
.vr-footer {
  background: var(--vr-footer-bg);
  padding: 72px 0 40px;
  border-top: 0;
  font-family: var(--vr-font-sans);
  color: var(--vr-footer-fg);
}
.vr-footer .vr-footer-wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 32px;
}
.vr-footer .ft-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
  gap: 32px;
}
.vr-footer .ft-brand {
  font-size: 20px;
  font-weight: 700;
  color: var(--vr-footer-fg);
  letter-spacing: -.025em;
  margin-bottom: 12px;
}
.vr-footer .ft-tagline {
  font-size: 14px;
  color: var(--vr-footer-fg-dim);
  max-width: 28ch;
  line-height: 1.65;
}
.vr-footer .ft-col h4 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  color: var(--vr-footer-heading);
  margin: 0 0 16px;
}
.vr-footer .ft-col a {
  display: block;
  color: var(--vr-footer-fg);
  text-decoration: none;
  font-size: 14px;
  margin-bottom: 12px;
  transition: var(--vr-transition);
}
.vr-footer .ft-col a:hover { color: var(--vr-footer-link-hover); }
.vr-footer .ft-bottom {
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--vr-footer-rule);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.vr-footer .ft-trust { font-size: 13px; color: var(--vr-footer-fg-faint); margin: 0; }
.vr-footer .ft-legal { font-size: 12px; color: var(--vr-footer-fg-faint); margin: 0; opacity: .85; }
.vr-footer .ft-copy  { font-size: 13px; color: var(--vr-footer-fg-faint); margin: 0; }

@media (max-width: 980px) {
  .vr-footer .ft-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
}
@media (max-width: 640px) {
  .vr-footer { padding: 56px 0 32px; }
  .vr-footer .vr-footer-wrap { padding: 0 20px; }
  .vr-footer .ft-grid { grid-template-columns: 1fr; gap: 24px; }
  .vr-footer .ft-bottom { margin-top: 40px; }
}
