.footer {
  background: #2d2d2d;
  color: #fff;
  padding: 50px 0 24px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 32px;
}

.footer-col h3 {
  font-size: 1.1rem;
  margin-bottom: 16px;
  color: #fff;
}

.footer-col p,
.footer-col a {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.75);
  line-height: 1.8;
}

.footer-col a:hover {
  color: #fff;
}

.footer-office {
  margin-bottom: 20px;
}

.footer-office:last-child {
  margin-bottom: 0;
}

.footer-office strong {
  display: block;
  font-size: 0.95rem;
  color: #fff;
  margin-bottom: 4px;
}

.footer-office p {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.75);
  line-height: 1.7;
  margin: 0;
}

.footer-links li {
  margin-bottom: 8px;
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.15);
  padding-top: 20px;
  text-align: center;
  font-size: 0.88rem;
  color: rgba(255,255,255,0.6);
}

@media (max-width: 767px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}
