/* Shared styles for Impressum & Datenschutz pages */
*, *::before, *::after { box-sizing: border-box; }
body {
  margin: 0;
  background: #fbfbf8;
  color: #16271f;
  font-family: 'Public Sans', sans-serif;
  -webkit-font-smoothing: antialiased;
}
*::selection { background: #cfe3d6; }

.skip-link {
  position: absolute; left: -9999px; top: 8px; z-index: 50;
  background: #2f6b4f; color: #fff; padding: 10px 16px; border-radius: 3px;
  font-size: 14px; font-weight: 600; text-decoration: none;
}
.skip-link:focus { left: 16px; }

a:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid #2f6b4f; outline-offset: 2px; border-radius: 2px;
}

.wrap { max-width: 820px; margin: 0 auto; padding: 0 max(22px, 5vw); }

.legal-header {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 18px 0; border-bottom: 1px solid #e6ebe4; margin-bottom: 8px;
}
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.brand-name {
  font-family: Spectral, serif; font-size: 20px; font-weight: 600;
  letter-spacing: .02em; color: #1a2b22;
}
.back-link { font-size: 14px; font-weight: 600; color: #2f6b4f; text-decoration: none; }
.back-link:hover { text-decoration: underline; }

.legal { padding: clamp(28px, 5vw, 48px) 0 16px; outline: none; }
.legal h1 {
  font-family: Spectral, serif; font-weight: 500; letter-spacing: -.01em;
  font-size: clamp(30px, 5vw, 42px); line-height: 1.12; color: #16271f;
  margin: 0 0 22px;
}
.legal h2 {
  font-family: Spectral, serif; font-weight: 500;
  font-size: clamp(20px, 2.8vw, 25px); color: #16271f;
  margin: 38px 0 12px; padding-top: 20px; border-top: 1px solid #e6ebe4;
}
.legal h3 {
  font-family: 'Public Sans', sans-serif; font-weight: 600;
  font-size: 16.5px; color: #1c2d24; margin: 24px 0 8px;
}
.legal p, .legal li {
  font-size: 16px; line-height: 1.66; color: #46544b; margin: 0 0 14px;
}
.legal ul { margin: 0 0 16px; padding-left: 22px; }
.legal li { margin-bottom: 8px; }
.legal a { color: #2f6b4f; }
.legal strong { color: #2c3a32; }

/* Highlight unfilled placeholders so the client can spot them */
.legal :is(p, li, strong) { } /* no-op anchor */
.legal-foot { margin-top: 36px; padding-top: 18px; border-top: 1px solid #e6ebe4; }
.legal-foot a { font-weight: 600; text-decoration: none; }
.legal-foot a:hover { text-decoration: underline; }

.legal-pagefoot {
  display: flex; flex-wrap: wrap; gap: 8px 20px;
  justify-content: space-between; align-items: center;
  margin-top: 40px; padding: 26px 0 44px; border-top: 1px solid #e6ebe4;
  font-size: 13.5px; color: #6a7770;
}
.legal-pagefoot a { color: #2f6b4f; text-decoration: none; }
.legal-pagefoot a:hover { text-decoration: underline; }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
