/* VerwalterEnergie – Layout für Rechtsseiten */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --emerald:#10b981;--emerald-600:#059669;--emerald-700:#047857;--mint:#6ee7b7;
  --ink:#0a1f1c;--ink-2:#0f2d28;--line:#e3eae7;--line-dk:rgba(255,255,255,.10);
  --text:#13211e;--muted:#5d6f6a;--bg:#fff;--bg-soft:#f5f8f6;--bg-mint:#edf7f2;
  --r-sm:10px;--r:16px;--max:840px;--ease:cubic-bezier(.22,.61,.36,1);
  --sh-1:0 1px 2px rgba(10,31,28,.06),0 1px 3px rgba(10,31,28,.05);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Sora','Inter',sans-serif;line-height:1.2;letter-spacing:-.02em;color:var(--ink)}
a{color:var(--emerald-700);text-decoration:none}
a:hover{text-decoration:underline}
svg{display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* Barrierefreiheit */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:12px;top:-80px;z-index:300;background:#fff;color:var(--ink);padding:.7rem 1.1rem;border-radius:8px;font-weight:600;box-shadow:var(--sh-1)}
.skip-link:focus{top:12px}
:focus-visible{outline:3px solid #0ea5e9;outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{transition-duration:.001ms!important;scroll-behavior:auto!important}}

/* header */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line),var(--sh-1)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1180px;margin:0 auto;padding:0 24px}
.logo{display:flex;align-items:center;gap:.6rem;font-family:'Sora';font-weight:800;font-size:1.2rem;color:var(--ink);letter-spacing:-.03em}
.logo:hover{text-decoration:none}
.logo-mark{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--emerald),var(--emerald-700));display:grid;place-items:center;box-shadow:0 6px 16px -6px rgba(16,185,129,.8)}
.logo-mark svg{width:20px;height:20px;stroke:#fff}
.logo span{color:var(--emerald-600)}
.nav-back{font-weight:600;font-size:.92rem;color:var(--muted)}

/* hero strip */
.legal-hero{background:radial-gradient(120% 130% at 80% -20%,#16453c,var(--ink-2) 45%,var(--ink));color:#fff;padding:72px 0 60px}
.legal-hero .eyebrow{font-family:'Sora';font-weight:700;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mint);display:block;margin-bottom:.8rem}
.legal-hero h1{color:#fff;font-size:clamp(2rem,4vw,2.8rem);font-weight:800}
.legal-hero p{color:rgba(255,255,255,.7);margin-top:.7rem;max-width:560px}

/* content */
.legal{padding:56px 0 80px}
.legal h2{font-size:1.4rem;margin:2.4rem 0 .9rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.legal h2:first-of-type{border-top:none;padding-top:0;margin-top:0}
.legal h3{font-size:1.08rem;margin:1.6rem 0 .5rem}
.legal p{margin-bottom:1rem;color:var(--text)}
.legal ul,.legal ol{margin:0 0 1rem 1.3rem}
.legal li{margin-bottom:.5rem}
.legal strong{color:var(--ink)}
.legal address{font-style:normal;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:1.1rem 1.3rem;margin-bottom:1rem;line-height:1.8}
.ph{background:#fff7ed;color:#9a3412;border:1px dashed #f59e0b;border-radius:6px;padding:.05rem .4rem;font-weight:600;font-size:.95em}
.notice{display:flex;gap:.8rem;background:var(--bg-mint);border:1px solid #c8ebd9;border-radius:var(--r);padding:1rem 1.2rem;margin-bottom:2rem;font-size:.93rem;color:var(--emerald-700)}
.notice svg{width:20px;height:20px;stroke:var(--emerald-600);stroke-width:2;flex-shrink:0;margin-top:2px}
.legal .updated{color:var(--muted);font-size:.9rem;margin-top:2.5rem;padding-top:1.2rem;border-top:1px solid var(--line)}

/* footer */
.footer{background:var(--ink);color:rgba(255,255,255,.6);padding:40px 0;font-size:.9rem}
.footer .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center}
.footer a{color:rgba(255,255,255,.6)}
.footer a:hover{color:var(--mint);text-decoration:none}
.footer nav{display:flex;gap:1.4rem;flex-wrap:wrap}
@media(max-width:560px){.footer .container{flex-direction:column;text-align:center}}
