/* Shared styling for the static legal pages (Impressum, Datenschutz, AGB). */
:root { color-scheme: light; }
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  color: #334155;
  background: #f8fafc;
  line-height: 1.7;
}
.site-header {
  background: #0f172a;
  padding: 1.25rem 0;
}
.wrap { max-width: 46rem; margin: 0 auto; padding: 0 1.25rem; }
.brand {
  display: inline-flex; align-items: center; gap: .55rem;
  text-decoration: none; color: #fff; font-weight: 600; font-size: 1.35rem;
  font-family: "Poppins", system-ui, sans-serif;
}
.brand .mark {
  width: 34px; height: 34px; border-radius: 8px; background: #0d9488;
  display: inline-flex; align-items: center; justify-content: center;
}
.brand .mark svg { width: 20px; height: 20px; }
.brand .accent { color: #2dd4bf; }
main { padding: 3rem 0 4rem; }
h1 { font-family: "Poppins", system-ui, sans-serif; color: #0f172a; font-size: 2rem; margin: 0 0 .5rem; }
h2 { font-family: "Poppins", system-ui, sans-serif; color: #0f172a; font-size: 1.25rem; margin: 2.25rem 0 .5rem; }
h3 { color: #0f172a; font-size: 1.05rem; margin: 1.5rem 0 .25rem; }
a { color: #0f766e; }
.updated { color: #64748b; font-size: .9rem; margin-bottom: 2rem; }
.ph {
  background: #fef3c7; color: #92400e; padding: 0 .35em; border-radius: 4px;
  font-weight: 600; white-space: nowrap;
}
.note {
  background: #ecfdf5; border: 1px solid #99f6e4; color: #0f766e;
  border-radius: 12px; padding: 1rem 1.25rem; font-size: .92rem; margin: 1.5rem 0;
}
.back { display: inline-block; margin-top: 2.5rem; color: #0f766e; font-weight: 600; text-decoration: none; }
.back:hover { text-decoration: underline; }
footer { border-top: 1px solid #e2e8f0; padding: 1.5rem 0; color: #94a3b8; font-size: .85rem; }
footer a { color: #64748b; }
