/* ============================================================
   Shared styles for the legal pages (privacy / terms / cookies / impressum).
   Mirrors the main site's design tokens so these pages look native.
   ============================================================ */
:root{
  --ink:#0a0a0c; --ink-2:#1a1a1f; --muted:#5b5b66; --muted-2:#8a8a95;
  --line:rgba(10,10,12,0.08); --line-2:rgba(10,10,12,0.12);
  --paper:#ffffff; --glass-strong:rgba(255,255,255,0.72); --glass-edge:rgba(255,255,255,0.9);
  --serif:"Instrument Serif","New York","Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text",system-ui,"Segoe UI",Helvetica,Arial,sans-serif;
  --radius:22px;
  --shadow-soft:0 1px 0 rgba(255,255,255,0.6) inset,0 1px 2px rgba(10,10,12,0.04),0 10px 30px -12px rgba(10,10,12,0.10);
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{ font-family:var(--sans); color:var(--ink); background:#fbf8f4; -webkit-font-smoothing:antialiased; line-height:1.5; }
a{ color:inherit; text-decoration:none; }

.wrap{ max-width:1240px; margin:0 auto; padding:0 28px; }

/* nav */
.nav{
  position:sticky; top:14px; z-index:50;
  margin:14px auto 0; width:min(1240px,calc(100% - 28px));
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px 10px 22px;
  background:var(--glass-strong); border:1px solid var(--glass-edge);
  border-radius:999px; backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  box-shadow:var(--shadow-soft);
}
.brand{ display:flex; align-items:center; gap:10px; font-weight:600; letter-spacing:-0.01em; font-size:17px; }
.brand-mark{ width:26px; height:26px; border-radius:50%; background:conic-gradient(from 210deg,#0a0a0c,#2a2a35,#0a0a0c); box-shadow:inset 0 0 0 1px rgba(255,255,255,0.18),0 4px 10px rgba(10,10,12,0.18); }
.brand small{ font-weight:400; color:var(--muted-2); margin-left:6px; font-size:12px; letter-spacing:.04em; text-transform:uppercase; }
.nav-links{ display:flex; gap:4px; }
.nav-links a{ padding:8px 14px; border-radius:999px; font-size:14px; color:var(--ink-2); transition:background .2s ease; }
.nav-links a:hover{ background:rgba(10,10,12,0.05); }
.nav-cta{ display:flex; gap:8px; align-items:center; }
.btn{ display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px; font-size:14px; font-weight:500; border:1px solid transparent; transition:transform .15s ease,background .2s ease,box-shadow .2s ease; }
.btn:hover{ transform:translateY(-1px); }
.btn-ghost{ color:var(--ink); border-color:var(--line); background:rgba(255,255,255,0.6); }
.btn-ghost:hover{ background:rgba(255,255,255,0.9); }
.btn-dark{ background:linear-gradient(180deg,#1a1a22 0%,#0a0a0c 100%); color:#fff; box-shadow:0 1px 0 rgba(255,255,255,0.15) inset,0 8px 20px -6px rgba(10,10,12,0.45); }

/* legal content */
.legal-head{ max-width:760px; margin:64px auto 0; padding:0 28px; }
.kicker{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); font-weight:500; }
.legal-head h1{ font-family:var(--serif); font-weight:400; font-size:clamp(40px,7vw,64px); line-height:1.02; letter-spacing:-0.02em; margin:14px 0 0; }
.legal-head h1 em{ font-style:italic; }
.updated{ margin-top:16px; color:var(--muted); font-size:14px; }

.legal{ max-width:760px; margin:8px auto 0; padding:0 28px 40px; }
.legal .notice{ margin:28px 0; padding:16px 18px; border:1px solid var(--line-2); border-radius:16px; background:rgba(255,255,255,0.6); color:var(--muted); font-size:13.5px; line-height:1.6; }
.legal h2{ font-family:var(--serif); font-weight:400; font-size:26px; letter-spacing:-0.01em; margin:42px 0 10px; color:var(--ink-2); }
.legal h3{ font-size:15px; font-weight:600; margin:22px 0 6px; }
.legal p{ color:var(--muted); font-size:15px; line-height:1.7; margin:10px 0; }
.legal ul{ color:var(--muted); font-size:15px; line-height:1.7; padding-left:22px; margin:10px 0; }
.legal li{ margin:6px 0; }
.legal a.inline{ color:var(--ink-2); border-bottom:1px solid var(--line-2); }
.legal .fill{ background:#fdf3d6; padding:1px 6px; border-radius:6px; font-size:13.5px; color:#6b5a1f; }
.legal table{ width:100%; border-collapse:collapse; margin:14px 0; font-size:14px; }
.legal th,.legal td{ text-align:left; padding:10px 12px; border-bottom:1px solid var(--line); color:var(--muted); vertical-align:top; }
.legal th{ color:var(--ink-2); font-weight:600; }

/* footer */
footer{ margin-top:60px; padding:60px 0 30px; border-top:1px solid var(--line); background:rgba(255,255,255,0.5); }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; }
.foot-top h5{ font-size:12px; text-transform:uppercase; letter-spacing:.14em; color:var(--muted-2); margin:0 0 16px; font-weight:500; }
.foot-top a{ display:block; padding:4px 0; color:var(--ink-2); font-size:14px; }
.foot-brand{ max-width:320px; color:var(--muted); font-size:14px; line-height:1.55; }
.foot-bottom{ margin-top:60px; padding-top:24px; border-top:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; color:var(--muted-2); font-size:13px; }
.foot-bottom .links{ display:flex; gap:22px; }
.foot-bottom .links a:hover{ color:var(--ink); }

@media (max-width:720px){
  .nav-links{ display:none; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:28px; }
  .foot-bottom{ flex-direction:column; gap:14px; align-items:flex-start; }
}
