/* legal.css — shared styles for Impressum / Datenschutz / AGB */

* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --c-blue: #0096C8;
  --c-blue-deep: #006B96;
  --c-blue-tint: #E6F4FA;
  --c-green: #8AC11F;
  --c-green-deep: #6DA517;
  --c-ink: #0F1722;
  --c-ink-2: #2A3340;
  --c-muted: #6B7385;
  --c-line: #E6E9EF;
  --c-line-2: #F0F2F6;
  --c-bg: #FFFFFF;
  --c-bg-soft: #F7F8FB;
  --c-bg-warm: #FAFAF7;
  --f-sans: "Inter", system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --maxw: 880px;
}

html, body {
  background: var(--c-bg);
  color: var(--c-ink);
  font-family: var(--f-sans);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
}
body { overflow-x: hidden; }
a { color: var(--c-blue-deep); text-decoration: underline; text-decoration-color: rgba(0,107,150,.25); text-underline-offset: 3px; transition: color .15s ease, text-decoration-color .15s ease; }
a:hover { color: var(--c-ink); text-decoration-color: var(--c-ink); }

/* ---------- Top bar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--c-line);
}
.topbar-inner {
  max-width: 1240px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.brand { display: flex; align-items: center; gap: 10px; color: var(--c-ink); text-decoration: none; }
.brand:hover { color: var(--c-ink); }
.brand img { width: 32px; height: 32px; }
.brand-name { font-weight: 600; font-size: 17px; letter-spacing: -0.01em; text-decoration: none; }
.brand-name em { font-style: normal; font-weight: 400; color: var(--c-muted); margin-left: 4px; }
.back-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-mono); font-size: 12px; color: var(--c-muted);
  text-decoration: none; letter-spacing: 0.04em;
}
.back-link:hover { color: var(--c-ink); }

/* ---------- Page wrap ---------- */
.legal {
  max-width: var(--maxw); margin: 0 auto;
  padding: 64px 24px 96px;
}
.legal-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--c-blue-deep);
  padding: 6px 10px; border: 1px solid var(--c-line);
  border-radius: 999px; background: var(--c-bg);
  text-decoration: none;
}
.legal-eyebrow::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--c-green); }

.legal h1 {
  font-size: clamp(38px, 4.4vw, 56px);
  line-height: 1.05; letter-spacing: -0.025em;
  font-weight: 600; margin: 16px 0 8px;
}
.legal .lead {
  font-size: 18px; color: var(--c-ink-2); line-height: 1.55;
  max-width: 60ch; margin-bottom: 12px;
}
.legal .updated {
  font-family: var(--f-mono); font-size: 12px; color: var(--c-muted);
  text-transform: uppercase; letter-spacing: 0.06em;
  margin-top: 12px;
}

/* ---------- Placeholder banner ---------- */
.legal-banner {
  margin: 32px 0;
  padding: 14px 18px;
  border-left: 3px solid var(--c-green);
  background: #FAFCEC;
  border-radius: 0 8px 8px 0;
  font-size: 14px; color: var(--c-ink-2);
}
.legal-banner strong { color: var(--c-ink); }

/* ---------- Content blocks ---------- */
.legal h2 {
  font-size: 24px; font-weight: 600; letter-spacing: -0.015em;
  margin: 48px 0 12px;
  padding-top: 20px;
  border-top: 1px solid var(--c-line);
}
.legal h2:first-of-type { border-top: 0; padding-top: 0; }
.legal h3 {
  font-size: 17px; font-weight: 600;
  margin: 28px 0 8px;
}
.legal p { margin: 10px 0; color: var(--c-ink-2); text-wrap: pretty; }
.legal ul, .legal ol { margin: 10px 0 10px 24px; color: var(--c-ink-2); }
.legal li { margin: 6px 0; }
.legal hr { border: 0; border-top: 1px solid var(--c-line); margin: 48px 0; }

.kv { display: grid; grid-template-columns: 180px 1fr; gap: 8px 24px; margin: 12px 0; }
.kv dt { color: var(--c-muted); font-size: 14px; font-family: var(--f-mono); letter-spacing: 0.02em; }
.kv dd { color: var(--c-ink); font-size: 15px; }
.kv dd .ph { color: var(--c-muted); font-style: italic; }
@media (max-width: 600px) { .kv { grid-template-columns: 1fr; gap: 2px 0; } .kv dt { margin-top: 10px; } }

.ph {
  display: inline-block;
  background: #FFF8E1; color: #8A6500;
  padding: 1px 6px; border-radius: 4px;
  font-family: var(--f-mono); font-size: 13px;
  font-style: normal;
}

/* ---------- TOC ---------- */
.toc {
  background: var(--c-bg-soft);
  border: 1px solid var(--c-line);
  border-radius: 12px;
  padding: 20px 24px;
  margin: 32px 0 48px;
}
.toc-title {
  font-family: var(--f-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--c-muted); margin-bottom: 10px;
}
.toc ol { margin: 0 0 0 20px; }
.toc a { text-decoration: none; color: var(--c-ink); font-size: 14px; }
.toc a:hover { color: var(--c-blue-deep); }
.toc li { margin: 4px 0; }

/* ---------- Footer ---------- */
footer {
  border-top: 1px solid var(--c-line);
  background: var(--c-bg-soft);
  padding: 40px 0;
}
.footer-inner {
  max-width: 1240px; margin: 0 auto; padding: 0 24px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
  font-size: 12px; color: var(--c-muted);
}
.footer-links { display: flex; gap: 16px; }
.footer-links a { color: var(--c-ink-2); text-decoration: none; }
.footer-links a:hover { color: var(--c-blue-deep); }
