/* ============================================================
   Rechtsseiten (AGB · Impressum · Datenschutz) — geteilte Styles
   ============================================================ */
.legal { max-width: 820px; margin: 0 auto; }

.legal-meta { display: inline-flex; align-items: center; gap: 9px; font-size: 13.5px; color: var(--ink-3); background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-pill); padding: 7px 16px; margin-top: 22px; }
.legal-meta svg { width: 15px; height: 15px; color: var(--accent-deep); }

.legal-body { margin-top: clamp(32px, 5vw, 56px); display: flex; flex-direction: column; gap: 4px; }
.legal-art { padding: 24px 0; border-top: 1px solid var(--line); }
.legal-art:first-child { border-top: none; }
.legal-art h2 { font-size: 19px; font-weight: 600; letter-spacing: -0.02em; display: flex; gap: 12px; align-items: baseline; }
.legal-art h2 .par { font-family: var(--mono); font-size: 14px; color: var(--accent-deep); font-weight: 600; flex: none; }
.legal-art p { font-size: 15.5px; color: var(--ink-2); line-height: 1.72; margin-top: 12px; }
.legal-art p strong { color: var(--ink); font-weight: 600; }
.legal-art a { color: var(--accent-deep); font-weight: 500; }
.legal-art a:hover { text-decoration: underline; }

.legal-foot { margin-top: 40px; padding: 18px 22px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); display: flex; gap: 13px; align-items: flex-start; }
.legal-foot svg { width: 18px; height: 18px; color: var(--ink-4); flex: none; margin-top: 2px; }
.legal-foot p { font-size: 13px; color: var(--ink-3); line-height: 1.6; }

.legal-toc { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 30px; }
.legal-toc a { font-size: 13px; color: var(--ink-2); background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-pill); padding: 7px 14px; transition: all .2s var(--ease-soft); }
.legal-toc a:hover { color: var(--accent-deep); border-color: var(--accent-ring); transform: translateY(-1px); }

/* Platzhalter-Hinweise */
.ph-flag { display: inline-flex; align-items: center; gap: 9px; font-size: 13px; color: oklch(0.5 0.1 70); background: var(--warning-soft); border: 1px solid transparent; border-radius: var(--r-pill); padding: 8px 16px; margin-top: 18px; }
.ph-flag svg { width: 15px; height: 15px; flex: none; }
.ph-inline { color: oklch(0.5 0.1 70); background: var(--warning-soft); border-radius: 6px; padding: 1px 8px; font-size: 14px; }

/* Impressum-Block */
.imp-card { margin-top: 14px; padding: 22px 24px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--shadow-xs); }
.imp-card p { margin-top: 0; }
.imp-card p + p { margin-top: 14px; }
.imp-rows { margin-top: 16px; display: flex; flex-direction: column; }
.imp-row { display: flex; gap: 20px; padding: 13px 0; border-top: 1px solid var(--line); font-size: 15.5px; }
.imp-row:first-child { border-top: none; }
.imp-k { flex: none; width: 120px; color: var(--ink-3); font-size: 14px; padding-top: 1px; }

/* Datenschutz-Listen */
.legal-art ul { margin: 12px 0 0; padding-left: 22px; display: flex; flex-direction: column; gap: 7px; }
.legal-art li { font-size: 15px; color: var(--ink-2); line-height: 1.6; }
.legal-sub { font-size: 15.5px; font-weight: 600; color: var(--ink); margin-top: 20px; letter-spacing: -0.01em; }
