/* ============================================================
   LEGAL-PAGES (Impressum / Datenschutz)
   ============================================================ */

.legal-body {
  font-family: 'DM Sans', system-ui, sans-serif;
  background: #FAF8F4;
  color: #2A2420;
  line-height: 1.7;
  overflow: auto;
}

/* Header */
.legal-hdr {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: .9rem 1.5rem;
  background: #fff;
  border-bottom: 1px solid #E8E0D2;
  height: 76px;
}
.legal-back { display: flex; align-items: center; }
.legal-back img { height: 52px; width: auto; filter: brightness(0); }
.legal-back-link {
  font-size: .9rem;
  font-weight: 500;
  color: #8C7A6B;
  text-decoration: none;
  transition: color .2s;
}
.legal-back-link:hover, .legal-back-link:focus-visible { color: #2A2420; }

/* Hauptinhalt */
.legal-main {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem) 1.5rem 5rem;
}
.legal-article h1 {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  font-style: italic;
  letter-spacing: -.025em;
  margin-bottom: 1.5rem;
  color: #2A2420;
}
.legal-article h2 {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: #2A2420;
  margin: 2.5rem 0 .75rem;
  letter-spacing: -.01em;
}
.legal-article h2:first-of-type { margin-top: 1.5rem; }

.legal-article p,
.legal-article ul {
  font-size: 1rem;
  color: #3a342f;
  margin-bottom: 1rem;
  max-width: 720px;
}
.legal-article ul {
  padding-left: 1.4rem;
}
.legal-article li {
  margin-bottom: .25rem;
}
.legal-article a {
  color: #A8722A;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .2s;
}
.legal-article a:hover, .legal-article a:focus-visible { color: #6f4c1a; }

.legal-article code {
  font-family: 'SF Mono', 'Menlo', 'Monaco', 'Consolas', monospace;
  font-size: .88em;
  background: rgba(168, 114, 42, .08);
  border-radius: 4px;
  padding: .12em .35em;
  color: #6f4c1a;
}

.legal-intro {
  font-size: 1.05rem;
  color: #5a5048;
  border-left: 3px solid #A8722A;
  padding-left: 1rem;
  margin-bottom: 2.5rem;
}

.legal-fillin {
  display: inline-block;
  background: rgba(168, 114, 42, .12);
  color: #6f4c1a;
  font-style: normal;
  font-weight: 600;
  padding: .12em .55em;
  border-radius: 4px;
  border: 1px dashed #A8722A;
}

.legal-meta {
  margin-top: 3rem;
  font-size: .85rem;
  color: #8C7A6B;
  font-style: italic;
}

/* Footer */
.legal-footer {
  background: #2A2420;
  color: rgba(255, 255, 255, .55);
  padding: 2rem 1.5rem;
  text-align: center;
  font-size: .9rem;
  line-height: 1.7;
}
.legal-footer strong { color: rgba(255, 255, 255, .85); }
.legal-footer a {
  color: rgba(255, 255, 255, .55);
  text-decoration: none;
  transition: color .2s;
}
.legal-footer a:hover, .legal-footer a:focus-visible { color: #fff; }
.legal-footer p { margin: .25rem 0; }

/* Print-Friendly */
@media print {
  .legal-hdr, .legal-footer { display: none; }
  .legal-body { background: #fff; color: #000; }
  .legal-article a { color: #000; }
}
