/* ============================================================
   Legal pages — readable document layout on the tech-noir theme.
   Loads AFTER style.css (reuses its design tokens + self-hosted fonts).
   ============================================================ */

.legal-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem clamp(1.25rem, 4vw, 2.5rem);
  /* gleiche Glas-Sprache wie die Hauptseite (Tokens aus style.css) */
  background: var(--glass-bg, rgba(0, 0, 0, 0.72));
  backdrop-filter: var(--glass-blur, blur(12px));
  -webkit-backdrop-filter: var(--glass-blur, blur(12px));
  border-bottom: 1px solid var(--glass-border, var(--border));
}
.legal-nav .brand {
  display: inline-flex; align-items: center;
  font-family: var(--font-display);
  font-size: 1.1rem; letter-spacing: -0.015em; color: var(--text); text-decoration: none;
}
/* Wortmarke wie auf der Hauptseite: SITE fett, Atom, BASE leicht */
.legal-nav .brand .brand-strong { font-weight: 700; }
.legal-nav .brand .brand-light  { font-weight: 350; opacity: 0.82; }
.legal-nav .brand .logo-atom { fill: none; stroke: currentColor; stroke-width: 1; }
.legal-back {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-muted); text-decoration: none;
  min-height: 44px; display: inline-flex; align-items: center;
}
.legal-back:hover { color: var(--accent, #C9A86B); }
.legal-back:focus-visible { outline: 2px solid var(--accent, #C9A86B); outline-offset: 3px; }

.legal-doc {
  max-width: 50rem; margin: 0 auto;
  padding: clamp(2.5rem, 6vw, 5rem) clamp(1.25rem, 4vw, 2.5rem) 6rem;
  font-family: var(--font-display); color: var(--text-muted);
  line-height: 1.7; font-size: clamp(0.95rem, 0.9rem + 0.2vw, 1.05rem);
}

/* Prominent draft banner — these pages are NOT yet legally effective. */
.legal-draft-banner {
  margin-bottom: 2.5rem; padding: 1rem 1.2rem; border-radius: 4px;
  border: 1px solid rgba(180, 84, 0, 0.45);
  background: rgba(180, 84, 0, 0.1);
  font-family: var(--font-mono); font-size: 0.78rem; line-height: 1.65; color: #f0b67c;
}

.legal-title {
  font-family: var(--font-anchor); font-weight: 400;
  font-size: clamp(1.8rem, 1.2rem + 2.4vw, 2.8rem); line-height: 1.1;
  letter-spacing: -0.02em; color: var(--text); margin: 0 0 0.6rem;
}
.legal-meta {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-faint); margin: 0 0 2.5rem;
}
.legal-doc h2 {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(1.15rem, 1rem + 0.6vw, 1.5rem); color: var(--text);
  margin: 2.6rem 0 0.8rem; letter-spacing: -0.01em;
}
.legal-doc h3 {
  font-family: var(--font-display); font-weight: 600; font-size: 1.05rem;
  color: var(--text); margin: 1.6rem 0 0.5rem;
}
.legal-doc p { margin: 0 0 1rem; }
.legal-doc ul, .legal-doc ol { margin: 0 0 1.2rem; padding-left: 1.3rem; }
.legal-doc li { margin: 0 0 0.45rem; }
.legal-doc a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.legal-doc strong { color: var(--text); font-weight: 600; }

/* Placeholder for real data the user/lawyer must fill in. */
.legal-ph {
  font-family: var(--font-mono); font-size: 0.85em; color: #f0b67c;
  background: rgba(180, 84, 0, 0.12); border: 1px dashed rgba(180, 84, 0, 0.4);
  border-radius: 3px; padding: 0.05em 0.4em;
}
/* Items that a lawyer must finalize before launch. */
.legal-todo {
  margin: 0.6rem 0 1.4rem; padding: 0.7rem 1rem;
  border-left: 3px solid #b45400; background: rgba(180, 84, 0, 0.07);
  font-size: 0.9rem; color: #e0a878;
}
.legal-table { width: 100%; border-collapse: collapse; margin: 0 0 1.5rem; font-size: 0.9rem; }
.legal-table th, .legal-table td { text-align: left; padding: 0.6rem 0.8rem; border: 1px solid var(--border); vertical-align: top; }
.legal-table th {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-faint); background: rgba(255, 255, 255, 0.02);
}
