/* ============================================================
   ScreenImmos — Legal / prose subpages (Impressum, Datenschutz, AGB)
   Built on tokens.css + base.css (header, footer, buttons reused).
   ============================================================ */

/* ---------- Hero band ---------- */
.legal-hero {
  position: relative;
  background: var(--bg-soft);
  border-bottom: 1px solid var(--border-soft);
  padding-block: clamp(2.75rem, 1.8rem + 4.5vw, 5rem) clamp(2rem, 1.5rem + 2.5vw, 3.25rem);
  overflow: clip;
}
/* brand hairline at the very top of the band */
.legal-hero::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--grad-full);
}
.legal-hero .container { max-width: 860px; }

.legal-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 1.4rem;
  font-size: var(--text-label);
  font-weight: 700;
  color: var(--muted-tint);
  transition: color var(--duration-fast), gap var(--duration-fast);
}
.legal-breadcrumb::before { content: "←"; font-size: 1.05em; line-height: 1; }
.legal-breadcrumb:hover { color: var(--ink-strong); gap: 0.7rem; }

.legal-hero h1 {
  font-size: clamp(2.3rem, 1.5rem + 3vw, 3.5rem);
  letter-spacing: -0.035em;
  hyphens: auto;
}
.legal-hero .legal-sub {
  max-width: 60ch;
  margin-top: 1.1rem;
  font-size: var(--text-lead);
  color: var(--muted);
}

/* ---------- Prose column ---------- */
.legal-prose { padding-block: clamp(2.25rem, 1.6rem + 2.5vw, 3.5rem) var(--space-section); }
.legal-prose .container { max-width: 860px; }

.legal-prose section {
  padding: 0;
  margin-bottom: clamp(1.85rem, 1.4rem + 1.4vw, 2.75rem);
  scroll-margin-top: 92px;
}
.legal-prose section:last-child { margin-bottom: 0; }

.legal-prose h2 {
  font-size: clamp(1.35rem, 1.15rem + 0.9vw, 1.85rem);
  letter-spacing: -0.02em;
  margin-bottom: 0.9rem;
}
.legal-prose h2 .sec-no {
  color: var(--purple);
  font-variant-numeric: tabular-nums;
  margin-right: 0.5rem;
}
.legal-prose h3 {
  margin: 1.5rem 0 0.55rem;
  font-size: var(--text-h3);
}
.legal-prose p { margin-bottom: 0.9rem; color: var(--ink); }
.legal-prose p:last-child { margin-bottom: 0; }

.legal-prose ul,
.legal-prose ol {
  margin: 0 0 1rem;
  padding-left: 1.35rem;
  display: grid;
  gap: 0.4rem;
}
.legal-prose li { padding-left: 0.15rem; }
.legal-prose li::marker { color: var(--faint); }

.legal-prose strong { color: var(--ink-strong); font-weight: 700; }

/* inline links inside prose (breadcrumb + buttons excluded) */
.legal-prose a:not(.legal-breadcrumb):not(.btn) {
  color: var(--blue-ink);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  text-decoration-color: color-mix(in srgb, var(--blue-ink) 35%, transparent);
  transition: color var(--duration-fast), text-decoration-color var(--duration-fast);
  overflow-wrap: anywhere;
}
.legal-prose a:not(.legal-breadcrumb):not(.btn):hover {
  color: var(--purple-ink);
  text-decoration-color: currentColor;
}

/* ---------- Identity card (Impressum) ---------- */
.legal-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: clamp(1.4rem, 1rem + 1.8vw, 2.1rem) clamp(1.4rem, 1rem + 1.8vw, 2.3rem);
}

.legal-identity { margin: 0; }
.legal-identity > div { padding-block: 0.85rem; border-top: 1px solid var(--border-soft); }
.legal-identity > div:first-child { padding-top: 0; border-top: 0; }
.legal-identity > div:last-child { padding-bottom: 0; }
.legal-identity dt {
  font-size: var(--text-label);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--teal-text); /* AA-safe label ink (--teal-deep fails 4.5:1 small) */
}
.legal-identity dd {
  margin: 0.3rem 0 0;
  font-size: 1.05rem;
  color: var(--ink-strong);
  line-height: 1.5;
}

/* ---------- Table of contents (Datenschutz, AGB) ---------- */
.legal-toc {
  margin: 0 0 clamp(2rem, 1.5rem + 1.5vw, 2.75rem);
  padding: clamp(1.25rem, 1rem + 1vw, 1.7rem) clamp(1.35rem, 1rem + 1.2vw, 1.9rem);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  background: var(--bg-soft);
}
.legal-toc h2 {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-strong);
  margin: 0 0 1rem;
}
.legal-toc ol {
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: toc;
  display: grid;
  gap: 0.55rem;
}
@media (min-width: 640px) {
  .legal-toc ol { grid-template-columns: 1fr 1fr; gap: 0.55rem 2rem; }
}
.legal-toc li { counter-increment: toc; padding: 0; }
.legal-toc a {
  display: inline-flex;
  gap: 0.55rem;
  color: var(--muted-tint);
  font-weight: 600;
  transition: color var(--duration-fast);
}
.legal-toc a::before {
  content: counter(toc);
  flex: none;
  min-width: 1.4em;
  font-variant-numeric: tabular-nums;
  color: var(--purple-ink); /* AA on --bg-soft (small counter) */
  font-weight: 700;
}
.legal-toc a:hover { color: var(--ink-strong); }

/* ---------- Callout (notes inside prose) ---------- */
.legal-note {
  margin: 1.1rem 0;
  padding: 1rem 1.2rem;
  border-left: 3px solid var(--teal);
  border-radius: 0 var(--radius-card) var(--radius-card) 0;
  background: color-mix(in srgb, var(--teal) 6%, var(--bg));
  font-size: 0.98rem;
  color: var(--ink);
}
.legal-note strong { color: var(--teal-text); }

/* ---------- Back-to-top / home footer link inside prose ---------- */
.legal-backhome {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: clamp(2.25rem, 1.8rem + 1.5vw, 3rem);
  font-weight: 700;
  color: var(--ink-strong);
}
.legal-backhome:hover { color: var(--purple-ink); }
