/* Julepa — shared legal-page styles (Impressum & Datenschutz) */
:root{
  --magenta:     #B43C6E;
  --magenta-dp:  #8e2c55;
  --navy:        #2F325B;
  --turquoise:   #37B7C8;
  --pink-light:  #DCA8BA;
  --paper:    #ffffff;
  --paper-2:  #faf6f7;
  --paper-3:  #f3ebee;
  --ink:      var(--navy);
  --ink-2:    #4a4b6e;
  --ink-3:    #7f7d8e;
  --rule:        rgba(47,50,91,.14);
  --rule-strong: rgba(47,50,91,.55);
  --maxw:  900px;
  --pad-x: clamp(20px, 4vw, 56px);
  --sans: "Montserrat", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  font-weight:400;
  line-height:1.65;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--magenta);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--magenta-dp);text-decoration:underline;text-underline-offset:3px}
img{display:block;max-width:100%}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.wrap-wide{max-width:1180px;margin:0 auto;padding:0 var(--pad-x)}

/* ─── Header (matches main page) ─── */
header.site{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab, var(--paper) 94%, transparent);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  border-bottom:1px solid var(--rule);
}
header.site .row{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  height:84px;
}
.brand img{height:46px;width:auto;display:block}
nav.primary{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-2)}
nav.primary a{position:relative;padding:4px 0;color:var(--ink-2);transition:color .2s ease}
nav.primary a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--magenta);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
nav.primary a:hover{color:var(--magenta);text-decoration:none}
nav.primary a:hover::after{transform:scaleX(1)}
@media (max-width:760px){ nav.primary{display:none} }
.btn{
  display:inline-flex;align-items:center;gap:10px;
  height:44px;padding:0 22px;
  font-size:14px;font-weight:500;
  border-radius:999px;
  transition:background .2s ease,color .2s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--magenta);color:#fff}
.btn-primary:hover{background:var(--magenta-dp);color:#fff;text-decoration:none}
.btn .arr{width:14px;height:14px;transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

/* ─── Legal hero ─── */
.legal-hero{
  padding:clamp(56px,7vw,96px) 0 clamp(36px,4vw,56px);
  border-bottom:1px solid var(--rule);
  background:var(--paper-2);
}
.legal-hero .crumb{
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);
  display:flex;align-items:center;gap:8px;
  margin-bottom:18px;
}
.legal-hero .crumb a{color:var(--ink-3);font-weight:600}
.legal-hero .crumb a:hover{color:var(--magenta)}
.legal-hero .crumb .sep{color:var(--rule-strong);font-weight:400}
.legal-hero h1{
  font-size:clamp(36px, 5vw, 64px);font-weight:900;
  line-height:1.05;letter-spacing:-0.02em;
  margin:0 0 14px;color:var(--navy);text-wrap:balance;
}
.legal-hero .meta{
  font-size:13px;color:var(--ink-3);
  font-weight:500;
}

/* ─── Body content ─── */
.legal{
  padding:clamp(56px,7vw,96px) 0;
}
.legal section{
  border-top:1px solid var(--rule);
  padding-top:40px;
  margin-top:40px;
}
.legal section:first-child{ border-top:0; padding-top:0; margin-top:0; }
.legal h2{
  font-size:clamp(22px,2.4vw,30px);font-weight:800;
  line-height:1.2;letter-spacing:-0.015em;
  margin:0 0 18px;color:var(--navy);
  display:flex;align-items:baseline;gap:14px;
}
.legal h2 .num{
  font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--magenta);
}
.legal h3{
  font-size:17px;font-weight:700;
  margin:28px 0 10px;color:var(--navy);
}
.legal p{ margin:0 0 14px;color:var(--ink-2); max-width:62ch; }
.legal p:last-child{ margin-bottom:0; }
.legal strong{color:var(--navy);font-weight:600}
.legal ul{margin:0 0 16px;padding-left:22px;color:var(--ink-2)}
.legal ul li{margin:4px 0}
.legal .kv{
  display:grid;grid-template-columns:1fr;gap:0;
  margin:14px 0;
}
@media (min-width:560px){ .legal .kv{grid-template-columns:170px 1fr;gap:0 20px;} }
.legal .kv dt{
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);
  padding:10px 0;
  border-top:1px solid var(--rule);
}
.legal .kv dt:first-of-type{ border-top:0; }
.legal .kv dd{
  margin:0;padding:10px 0;
  color:var(--navy);font-weight:500;
  border-top:1px solid var(--rule);
}
.legal .kv dd:first-of-type{ border-top:0; }
@media (max-width:560px){
  .legal .kv dt{ padding-bottom:0; border-top:1px solid var(--rule); }
  .legal .kv dt:first-of-type{ border-top:0; }
  .legal .kv dd{ padding-top:2px; border-top:0; }
}
.legal .note{
  margin:18px 0 0;
  padding:16px 20px;
  background:var(--paper-3);
  border-radius:14px;
  font-size:14px;color:var(--ink-2);
}

/* ─── Footer ─── */
footer.site{
  padding:48px 0 28px;
  background:var(--navy);
  color:#fff;
}
footer .row{
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  align-items:center;
}
footer .brandline{display:flex;align-items:center;gap:12px}
footer .brandline img{height:26px;width:auto}
footer .legal-links{
  display:flex;gap:18px;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.7);
}
footer .legal-links a{color:rgba(255,255,255,.7)}
footer .legal-links a:hover{color:var(--turquoise);text-decoration:none}
footer .copy{
  margin-top:24px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);
  font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.55);
}
