/* Legal / Rechtliche Seiten · Impressum · AGB · Datenschutz */

.legal {
  padding-block: var(--space-10);
  background: var(--color-bg);
}

.legal__container {
  max-width: 780px;
  margin-inline: auto;
  padding-inline: var(--space-5);
}

.legal__breadcrumb {
  font-family: var(--ff-mono);
  font-size: var(--fs-tiny);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-4);
}
.legal__breadcrumb a { color: var(--color-text-muted); }

.legal__title {
  font-family: var(--ff-head);
  font-size: var(--fs-h1);
  line-height: 1.05;
  margin-bottom: var(--space-3);
}
.legal__title em { font-style: italic; color: var(--color-accent); font-weight: 500; }

.legal__meta {
  font-family: var(--ff-mono);
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}

.legal__placeholder {
  background: var(--color-accent-soft);
  border: 1px solid var(--color-accent-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin-bottom: var(--space-8);
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}
.legal__placeholder-icon {
  font-size: 1.4rem;
  line-height: 1;
}
.legal__placeholder-body { font-size: var(--fs-small); line-height: var(--lh-normal); }
.legal__placeholder-body strong { color: var(--color-text); display: block; margin-bottom: 0.25rem; }

.legal__content h2 {
  font-family: var(--ff-body);
  font-weight: var(--fw-semi);
  font-size: var(--fs-h4);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border);
}
.legal__content h2:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}
.legal__content h3 {
  font-family: var(--ff-body);
  font-weight: var(--fw-semi);
  font-size: var(--fs-h5);
  margin-top: var(--space-5);
  margin-bottom: var(--space-2);
}
.legal__content p,
.legal__content ul,
.legal__content ol {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.legal__content strong { color: var(--color-text); }
.legal__content ul,
.legal__content ol {
  padding-left: var(--space-5);
}
.legal__content li { margin-bottom: var(--space-2); }

.legal__block {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-block: var(--space-4);
  font-family: var(--ff-mono);
  font-size: var(--fs-small);
  color: var(--color-text);
}
.legal__block p { margin: 0 0 var(--space-2); font-family: inherit; font-size: inherit; color: inherit; line-height: 1.5; }
.legal__block p:last-child { margin-bottom: 0; }
.legal__block .legal__block-label {
  font-family: var(--ff-mono);
  font-size: var(--fs-tiny);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-2);
}

.legal__tag {
  display: inline-block;
  padding: 2px 8px;
  background: #fff3cd;
  color: #8a6d0b;
  border-radius: var(--radius-sm);
  font-family: var(--ff-mono);
  font-size: var(--fs-tiny);
  letter-spacing: 0.05em;
}

.legal__nav {
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  justify-content: space-between;
  font-size: var(--fs-small);
}
.legal__nav-links { display: flex; gap: var(--space-5); flex-wrap: wrap; }
