/* Vertical Monkey — shared CSS for all legal pages.
   Matches landing/index.html's visual language: warm cream background,
   emerald primary, terracotta accent. Narrower max-width for prose.    */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  background:#faf6ee;
  color:#1a1a1a;
  line-height:1.7;
}
a{color:#059669;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
a:hover{color:#047857}

:root{
  --bg:#faf6ee;
  --bg-elevated:#ffffff;
  --bg-elevated-2:#f5efdc;
  --border:#e8ddc4;
  --border-strong:#d4c8a6;
  --text:#1a1a1a;
  --text-muted:#57534e;
  --text-dim:#8a8073;
  --primary:#10b981;
  --primary-dark:#059669;
  --primary-soft:#d1fae5;
  --accent:#e07a3c;
  --accent-dark:#c7632a;
  --accent-soft:#fde4d2;
  --warn-bg:#fef3c7;
  --warn-border:#fbbf24;
  --warn-text:#92400e;
}

/* ───── Nav ───── */
.nav{
  position:sticky;top:0;z-index:30;
  background:rgba(250,246,238,.92);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:1100px;margin:0 auto;
  padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:16px;letter-spacing:-.01em;color:var(--text);text-decoration:none}
.brand-logo{width:48px;height:48px;border-radius:12px;object-fit:cover;display:block}

.nav-links{display:none;gap:24px;font-size:13px;color:var(--text-muted)}
.nav-links a{color:var(--text-muted);text-decoration:none}
.nav-links a:hover,.nav-links a.active{color:var(--primary-dark)}
.nav-links a.active{font-weight:600}
@media(min-width:720px){.nav-links{display:flex}}

.nav-right{display:flex;align-items:center;gap:8px}

/* Language switcher */
.lang-switch{
  display:inline-flex;align-items:center;gap:2px;
  padding:3px;border-radius:999px;
  background:var(--bg-elevated);
  border:1px solid var(--border);
}
.lang-btn{
  padding:4px 9px;border-radius:999px;
  font-size:11px;font-weight:600;letter-spacing:.02em;
  color:var(--text-muted);
  background:transparent;border:none;cursor:pointer;
  transition:background .15s,color .15s;
  display:inline-flex;align-items:center;gap:6px;
}
.lang-btn .flag{
  display:inline-block;width:16px;height:12px;border-radius:2px;
  object-fit:cover;box-shadow:0 0 0 1px rgba(0,0,0,.08);
}
.lang-btn:hover{color:var(--text)}
.lang-btn.active{background:var(--primary);color:#fff}

@media(max-width:540px){
  .lang-btn{padding:3px 7px;font-size:10px;gap:4px}
  .lang-btn .flag{width:14px;height:10px}
}

/* ───── Legal content ───── */
.legal{
  padding:48px 24px 96px;
}
.legal-inner{
  max-width:760px;margin:0 auto;
}

.review-banner{
  background:var(--warn-bg);
  border:1px solid var(--warn-border);
  border-left-width:4px;
  color:var(--warn-text);
  padding:14px 18px;
  border-radius:8px;
  font-size:14px;line-height:1.55;
  margin-bottom:36px;
}
.review-banner strong{font-weight:700}

h1{
  font-size:clamp(32px,4.5vw,44px);
  font-weight:700;letter-spacing:-.025em;line-height:1.15;
  margin:0 0 10px;color:var(--text);
}
.subtitle{
  color:var(--text-muted);
  font-size:15px;
  margin:0 0 40px;
}

section{
  margin-bottom:36px;
}
h2{
  font-size:20px;font-weight:600;letter-spacing:-.01em;
  margin:0 0 14px;color:var(--text);
  padding-bottom:8px;
  border-bottom:1px solid var(--border);
}
h3{
  font-size:16px;font-weight:600;
  margin:20px 0 8px;color:var(--text);
}
p{
  margin:0 0 12px;
  color:var(--text);
  font-size:15px;
}
p:last-child{margin-bottom:0}

/* Definition list used in Impressum */
.legal-dl{
  display:grid;
  grid-template-columns:1fr;
  gap:4px 20px;
  margin:0 0 0;
}
@media(min-width:600px){
  .legal-dl{grid-template-columns:180px 1fr}
}
.legal-dl dt{
  font-weight:600;
  color:var(--text-muted);
  font-size:14px;
  padding-top:8px;
}
.legal-dl dd{
  margin:0;
  padding-bottom:8px;
  font-size:15px;
  border-bottom:1px dashed var(--border);
}
.legal-dl dd:last-of-type{border-bottom:none}
@media(max-width:599px){
  .legal-dl dt{padding-top:12px}
  .legal-dl dd{border-bottom:1px dashed var(--border)}
}

/* Ordered + unordered lists inside legal sections */
section ul,section ol{
  margin:0 0 12px 20px;
  padding:0;
}
section li{
  margin-bottom:6px;
  color:var(--text);
  font-size:15px;
}

/* Nested sub-sections */
section section{margin-top:18px;margin-bottom:0}
section section h2{font-size:17px;border-bottom:none;padding-bottom:0;margin-bottom:8px}

code{
  font-family:'SF Mono',Menlo,Consolas,monospace;font-size:13px;
  background:var(--primary-soft);padding:1px 6px;border-radius:4px;color:var(--primary-dark);
}

.legal-footer-date{
  margin-top:48px;
  padding-top:20px;
  border-top:1px solid var(--border);
  font-size:13px;
  color:var(--text-dim);
  font-style:italic;
}

/* Tables for data categories (Privacy) */
.legal table{
  width:100%;
  border-collapse:collapse;
  margin:12px 0;
  font-size:14px;
}
.legal th,.legal td{
  text-align:left;
  padding:10px 12px;
  border:1px solid var(--border);
  vertical-align:top;
}
.legal th{
  background:var(--bg-elevated-2);
  font-weight:600;
  color:var(--text);
}

/* ───── Footer ───── */
.legal-foot{
  padding:32px 24px;
  border-top:1px solid var(--border);
  background:var(--bg-elevated-2);
  margin-top:48px;
}
.legal-foot-inner{
  max-width:1100px;margin:0 auto;
  display:flex;flex-direction:column;gap:14px;
  font-size:12px;color:var(--text-dim);
}
@media(min-width:720px){
  .legal-foot-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:24px}
}
.legal-foot-company{
  font-size:11px;line-height:1.5;
  max-width:640px;
}
.legal-foot-links{
  display:flex;flex-wrap:wrap;gap:14px;
}
.legal-foot-links a{
  color:var(--text-dim);
  text-decoration:none;
}
.legal-foot-links a:hover{color:var(--text)}
