/* Shared styles for the legal pages (Impressum, Datenschutz).
   Mirrors the design tokens used on the landing page. */
:root {
  --primary: #17A368;
  --primary-dark: #14241B;
  --coral: #FF6B4A;
  --cream: #F6F3EC;
  --body: #33453A;
  --muted: #5A6B5E;
  --muted2: #8A968C;
  --divider: #F0ECE2;
  --warn-bg: #FFF4E8;
  --warn-text: #8A6A33;
  --display: 'Bricolage Grotesque', sans-serif;
  --text: 'Plus Jakarta Sans', sans-serif;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--text);
  color: var(--body);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
.wrap { max-width: 760px; margin: 0 auto; padding: 0 22px; }

nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246,243,236,0.82);
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  border-bottom: 1px solid var(--divider);
}
.nav-inner { max-width: 1080px; margin: 0 auto; padding: 0 22px; display: flex; align-items: center; justify-content: space-between; height: 66px; }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--display); font-weight: 800; font-size: 19px; color: var(--primary-dark); }
.brand .mark { width: 34px; height: 34px; border-radius: 10px; background: var(--coral); display: flex; align-items: center; justify-content: center; box-shadow: 0 5px 12px rgba(255,107,74,.34); }
.back-link { color: var(--primary); font-weight: 700; font-size: 14px; }
.back-link:hover { text-decoration: underline; }
a { color: inherit; text-decoration: none; }

main { padding: 50px 0 70px; }
.legal-head { margin-bottom: 36px; }
.legal-head .eyebrow { text-transform: uppercase; letter-spacing: 1.2px; font-size: 12px; font-weight: 800; color: var(--primary); margin-bottom: 10px; }
.legal-head h1 { font-family: var(--display); font-weight: 800; font-size: 38px; letter-spacing: -1px; color: var(--primary-dark); }
.legal-head .updated { font-size: 13.5px; color: var(--muted2); margin-top: 10px; }

.card {
  background: #fff; border-radius: 22px; padding: 30px 32px;
  box-shadow: 0 3px 14px rgba(20,36,27,.06); border: 1px solid var(--divider);
  margin-bottom: 18px;
}
.card h2 { font-family: var(--display); font-weight: 700; font-size: 21px; color: var(--primary-dark); margin-bottom: 12px; letter-spacing: -0.4px; }
.card h3 { font-family: var(--text); font-weight: 700; font-size: 16px; color: var(--primary-dark); margin: 18px 0 6px; }
.card p { font-size: 15.5px; color: var(--body); margin-bottom: 10px; }
.card p:last-child { margin-bottom: 0; }
.card ul { margin: 6px 0 12px; padding-left: 20px; }
.card li { font-size: 15.5px; color: var(--body); margin-bottom: 6px; }
.card a { color: var(--primary); font-weight: 600; }
.card a:hover { text-decoration: underline; }
.muted { color: var(--muted); }

.placeholder-note {
  background: var(--warn-bg); border-radius: 16px; padding: 16px 18px;
  font-size: 14px; color: var(--warn-text); margin-bottom: 28px;
  display: flex; gap: 12px; align-items: flex-start;
}
.placeholder-note svg { flex-shrink: 0; margin-top: 1px; }

footer { padding: 30px 0 50px; border-top: 1px solid var(--divider); }
.foot-inner { max-width: 1080px; margin: 0 auto; padding: 0 22px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 14px; }
.foot-links { display: flex; gap: 22px; font-size: 14px; color: var(--muted); font-weight: 600; }
.foot-links a:hover { color: var(--primary); }
.foot-copy { font-size: 13px; color: var(--muted2); }

@media (max-width: 600px) {
  .legal-head h1 { font-size: 30px; }
  .card { padding: 24px 22px; }
}
