.footer {
  background: var(--ink);
  color: var(--cream);
  padding-block: clamp(48px, 6vw, 80px);
}

.footer__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(24px, 4vw, 48px);
  margin-bottom: 48px;
}

.footer__col img {
  margin-bottom: 12px;
  border-radius: var(--r-md);
  opacity: 0.9;
}

.footer__name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--white);
  margin-bottom: 4px;
}

.footer__title {
  font-size: 0.8rem;
  color: var(--sage-light);
  margin-bottom: 16px;
}

.footer__addr {
  font-size: 0.85rem;
  color: var(--cream-dark);
  line-height: 1.6;
  margin-bottom: 12px;
}

.footer__col a {
  font-size: 0.85rem;
  color: var(--cream-dark);
  transition: color var(--duration);
  display: inline;
}
.footer__col a:hover { color: var(--gold-light); }

.footer__col h3 {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-light);
  margin-bottom: 16px;
}

.footer__col ul { display: flex; flex-direction: column; gap: 8px; }
.footer__col ul li a {
  font-size: 0.875rem;
  color: var(--ink-light);
  display: block;
  transition: color var(--duration);
}
.footer__col ul li a:hover { color: var(--cream); }

.footer__zones {
  font-size: 0.8rem;
  color: var(--ink-light);
  line-height: 1.8;
}

.footer__bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
}

.footer__bottom p {
  font-size: 0.8rem;
  color: var(--ink-light);
}

.footer__bottom nav {
  display: flex;
  gap: 24px;
}

.footer__bottom nav a {
  font-size: 0.8rem;
  color: var(--ink-light);
  transition: color var(--duration);
}
.footer__bottom nav a:hover { color: var(--cream); }
