/* ============================================================
   FinToolbox — shared styling for /legal/* pages.
   Typography only. Layout reuses .page / .page-head / .card.
   ============================================================ */

.legal-page { max-width: 820px; }

.legal-body { padding: 28px 32px; line-height: 1.7; }
.legal-body > h2:first-child { margin-top: 0; }

.legal-body h2 {
  margin: 28px 0 10px;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text);
}
.legal-body h3 {
  margin: 20px 0 6px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.legal-body p,
.legal-body li {
  font-size: 14.5px;
  color: var(--text-2);
}
.legal-body p { margin: 0 0 12px; }
.legal-body ul { margin: 0 0 14px; padding-left: 22px; }
.legal-body ul li { margin-bottom: 6px; }

.legal-body a { color: var(--green); text-decoration: none; }
.legal-body a:hover { text-decoration: underline; }

.legal-body code {
  background: var(--card-hi);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--mono);
  font-size: 0.92em;
}

.legal-body strong { color: var(--text); font-weight: 600; }

/* Impressum: definition list with aligned label/value columns. */
.legal-dl {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 8px 18px;
  margin: 0 0 14px;
  font-size: 14.5px;
}
.legal-dl dt { color: var(--text-3); font-weight: 500; }
.legal-dl dd { margin: 0; color: var(--text-2); }

@media (max-width: 720px) {
  .legal-body { padding: 22px 18px; }
  .legal-dl { grid-template-columns: 1fr; gap: 2px 0; }
  .legal-dl dt { margin-top: 8px; }
}
