.main {
  padding: 120px 24px 80px;
  max-width: 800px;
  margin: 0 auto;
}

.main h1 {
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: 48px;
}

.main h2 {
  font-size: 24px;
  font-weight: 700;
  margin: 48px 0 16px;
  padding-top: 48px;
  border-top: 1px solid var(--border);
}

.main h2:first-of-type {
  border-top: none;
  padding-top: 0;
}

.main h3 {
  font-size: 18px;
  font-weight: 600;
  margin: 28px 0 10px;
}

.main p {
  color: var(--muted);
  line-height: 1.8;
  margin-bottom: 16px;
}

.main p:last-child { margin-bottom: 0; }

.main ul {
  color: var(--muted);
  padding-left: 20px;
  line-height: 1.8;
  margin-bottom: 16px;
}

.main ul li { margin-bottom: 6px; }

.info-box {
  background: var(--bg-alt);
  border-left: 4px solid var(--accent);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  padding: 20px 24px;
  margin: 24px 0;
}

.info-box p { color: var(--text); margin: 0; }

address {
  font-style: normal;
  color: var(--muted);
  line-height: 1.9;
}

address a { color: var(--accent); }

footer.footer-compact .ft-bottom {
  max-width: 1200px;
  margin: 0 auto;
  border-top: none;
  padding-top: 0;
}

footer.footer-compact .ft-bottom a { margin-left: 16px; }

footer.footer-compact .ft-grid {
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 32px;
}

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