/* Rechtsseiten – gemeinsames Styling, passend zum snorley-Design */
:root{
  --brand:#1488C8; --brand-700:#0F6CA3; --brand-deep:#16457E;
  --sky:#EAF4FB; --sky-2:#F5FAFE; --paper:#FFFFFF;
  --ink:#1B2A3A; --accent:#FB7A52; --accent-700:#E5663F; --pill:999px; --haze:#5C6E82; --line:rgba(20,45,75,.10);
  --fd:"Bricolage Grotesque",system-ui,sans-serif;
  --fb:"Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--fb);color:var(--ink);background:var(--paper);line-height:1.65;font-size:1.02rem;-webkit-font-smoothing:antialiased}
.lhead{position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.lhead .in{max-width:1120px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.lhead .logo{height:28px;width:auto}
.lhead a.back{color:var(--brand-700);text-decoration:none;font-weight:600;font-size:.95rem}
.lhead a.back:hover{text-decoration:underline}
main.legal{max-width:760px;margin:0 auto;padding:clamp(32px,5vw,64px) 22px}
.legal h1{font-family:var(--fd);font-weight:700;font-size:clamp(1.9rem,3.4vw,2.6rem);letter-spacing:-.015em;margin:0 0 .3rem}
.legal .updated{color:var(--haze);font-size:.9rem;margin:0 0 1.8rem}
.legal h2{font-family:var(--fd);font-weight:600;font-size:1.25rem;letter-spacing:0;margin:2rem 0 .6rem;padding-top:1rem;border-top:1px solid var(--line)}
.legal h2:first-of-type{border-top:0;padding-top:0}
.legal p{margin:0 0 1rem}
.legal ul,.legal ol{margin:0 0 1rem;padding-left:1.3rem}
.legal li{margin:.3rem 0}
.legal a{color:var(--brand-700)}
.legal .box{background:var(--sky-2);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:0 0 1rem}
.legal address{font-style:normal;line-height:1.7}
.lfoot{background:var(--sky);border-top:1px solid var(--line);padding:28px 0;font-size:.92rem;color:var(--haze)}
.lfoot .in{max-width:1120px;margin:0 auto;padding:0 22px;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
.lfoot a{color:var(--brand-700);text-decoration:none}
.lfoot a:hover{text-decoration:underline}
.lfoot .legalnav{display:flex;flex-wrap:wrap;gap:16px}
:where(a):focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:6px}

/* Sprachumschalter mit Flaggen */

/* ===== Sprachumschalter mit Flaggen ===== */
.langsw{display:inline-flex;align-items:center;gap:3px;background:var(--sky-2);border:1px solid var(--line);border-radius:999px;padding:3px}
.langsw .opt{display:inline-flex;align-items:center;gap:7px;min-height:28px;margin:0;padding:4px 10px;border-radius:999px;text-decoration:none;font-weight:600;font-size:.82rem;letter-spacing:.02em;color:var(--haze);line-height:1;transition:background .18s,color .18s,box-shadow .18s}
.langsw .opt:hover{color:var(--ink);background:rgba(255,255,255,.7)}
.langsw .opt[aria-current]{background:#fff;color:var(--brand-deep);box-shadow:0 2px 7px -3px rgba(22,69,126,.5)}
.langsw .flag{width:22px;height:16px;border-radius:4px;overflow:hidden;flex:none;display:block;box-shadow:0 0 0 1px rgba(20,45,75,.14) inset}
.langsw .flag svg{display:block;width:100%;height:100%}
.langsw .vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.lhead .in .langsw{flex:none}

/* Kopf-Menü auf Rechtsseiten */
.lhead .lnav{display:flex;gap:1.15rem;align-items:center;flex-wrap:wrap}
.lhead .lnav a{color:var(--ink);text-decoration:none;font-weight:600;font-size:.92rem}
.lhead .lnav a:hover{color:var(--brand-700)}
@media (max-width:820px){.lhead .lnav{display:none}}

/* ===== Einheitlicher Header wie Startseite ===== */
.wrap{max-width:1120px;margin-inline:auto;padding-inline:22px}
header.site{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.site .nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:12px}
header.site .nav .logo{height:30px;width:auto}
.nav-links{display:flex;gap:1.5rem;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);text-decoration:none;font-weight:500}
.nav-links a:hover{color:var(--brand-700)}
.nav-links li>a{position:relative}
.nav-links li>a::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:2px;background:var(--brand);transition:right .26s ease}
.nav-links li>a:hover::after{right:0}
.nav-cta{display:flex;gap:.6rem;align-items:center}
.btn{display:inline-flex;align-items:center;gap:.5em;min-height:50px;padding:.8em 1.7em;border-radius:var(--pill);font-family:var(--fb);font-weight:600;font-size:1rem;text-decoration:none;border:2px solid transparent;cursor:pointer;transition:background .18s,transform .12s,color .18s,border-color .18s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-700)}
.btn-primary:active{transform:translateY(1px)}
.burger{display:none;background:none;border:0;cursor:pointer;color:var(--brand-deep);padding:8px}
dialog.menu{border:0;padding:0;width:min(340px,88vw);margin-left:auto;height:100dvh;max-height:100dvh;background:#fff}
dialog.menu::backdrop{background:rgba(22,69,126,.45)}
dialog.menu .in{padding:22px;display:flex;flex-direction:column;gap:6px}
dialog.menu .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}
dialog.menu a{padding:12px 0;text-decoration:none;color:var(--ink);font-weight:600;font-size:1.05rem;border-bottom:1px solid var(--line)}
dialog.menu .close{background:none;border:0;cursor:pointer;color:var(--brand-deep)}
dialog.menu .mflag{width:22px;height:16px;border-radius:4px;overflow:hidden;display:inline-block;vertical-align:-3px;margin-right:9px;box-shadow:0 0 0 1px rgba(20,45,75,.14) inset}
dialog.menu .mflag svg{display:block;width:100%;height:100%}
@media (max-width:600px){.nav-links{display:none}.burger{display:block}}

/* ===== Einheitlicher Footer wie Startseite ===== */
footer.site{background:var(--sky);border-top:1px solid var(--line);padding-block:36px;font-size:.93rem;color:var(--haze)}
footer.site .cols{display:flex;flex-wrap:wrap;gap:28px;justify-content:space-between;align-items:flex-start}
footer.site .logo{height:26px;width:auto;margin-bottom:.6rem}
footer.site a{color:var(--brand-700);text-decoration:none}
footer.site a:hover{text-decoration:underline}
footer.site .legal{display:flex;flex-wrap:wrap;gap:16px}
footer.site .copy{margin-top:22px;border-top:1px solid var(--line);padding-top:16px;font-size:.85rem}
