/* =====================================================================
   Webfonts — lokal ausgeliefert (DSGVO-konform, kein Drittserver-Load)
===================================================================== */
@font-face{
  font-family:'Source Serif 4';font-style:normal;font-weight:300 600;font-display:swap;
  src:url('assets/fonts/SourceSerif4-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Source Serif 4';font-style:normal;font-weight:300 600;font-display:swap;
  src:url('assets/fonts/SourceSerif4-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:'Inter';font-style:normal;font-weight:300 700;font-display:swap;
  src:url('assets/fonts/Inter-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Inter';font-style:normal;font-weight:300 700;font-display:swap;
  src:url('assets/fonts/Inter-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* =====================================================================
   I.R.M. — Legal subpages (Impressum, Datenschutz)
   Lean sibling of the main stylesheet, same tokens and voice.
===================================================================== */
:root{
  --ivory:#F4EEE0;
  --ivory-2:#EADFC7;
  --paper:#FBF7EC;
  --white:#FFFFFF;
  --ink:#0E141C;
  --ink-2:#323C4B;
  --ink-3:#6B7280;
  --rule:rgba(14,20,28,.10);
  --rule-2:rgba(14,20,28,.18);
  --rule-3:rgba(14,20,28,.32);
  --navy:#0A1628;
  --navy-2:#122037;
  --burgundy:#7A1D1D;
  --gold:#A3843A;
  --serif:"Source Serif 4","Source Serif Pro","EB Garamond",Georgia,Cambria,"Times New Roman",Times,serif;
  --sans:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --max:1120px;
  --pad:clamp(24px,4.5vw,72px);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--ivory);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,p{margin:0}
::selection{background:var(--navy);color:var(--ivory)}

.label{
  font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;
}
.label--right{text-align:right}

/* =====================================================================
   NAV (slim back bar)
===================================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  color:var(--ink);background:rgba(244,238,224,.88);
  backdrop-filter:saturate(140%) blur(16px);
  -webkit-backdrop-filter:saturate(140%) blur(16px);
  border-bottom:1px solid var(--rule);
  transition:background .4s var(--ease),border-color .4s var(--ease);
}
.nav__inner{
  max-width:var(--max);margin:0 auto;padding:18px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav__brand{display:inline-flex;align-items:center}
.nav__logo{height:28px;width:auto;display:block;transition:opacity .25s var(--ease)}
.nav__brand:hover .nav__logo{opacity:.75}
.nav__back{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:13px;font-weight:500;
  padding:10px 18px;border:1px solid var(--rule-3);border-radius:2px;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);
}
.nav__back:hover{background:var(--navy);color:var(--ivory);border-color:var(--navy)}
.nav__back svg{transition:transform .35s var(--ease)}
.nav__back:hover svg{transform:translateX(-3px)}

/* =====================================================================
   CONTENT
===================================================================== */
.legal{padding:120px 0 80px}
.legal__inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

.legal__meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:16px;border-top:1px solid var(--rule-2);
  margin-bottom:clamp(40px,6vh,72px);
}

.legal__header{margin-bottom:clamp(48px,7vh,84px)}
.legal__header .display{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(44px,6vw,88px);line-height:1.02;letter-spacing:-.02em;color:var(--ink);
}
.legal__lede{
  font-family:var(--sans);font-size:17px;line-height:1.7;
  color:var(--ink-2);max-width:64ch;margin-top:24px;
}

.legal__section{
  padding:clamp(32px,5vh,56px) 0;
  border-top:1px solid var(--rule-2);
}
.legal__section:first-of-type{border-top:0;padding-top:0}
.legal__section h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(24px,2.6vw,34px);line-height:1.2;letter-spacing:-.012em;
  color:var(--ink);margin-bottom:20px;
}
.legal__section h3{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(18px,1.6vw,22px);line-height:1.25;letter-spacing:-.005em;
  color:var(--ink);margin-bottom:12px;
}
.legal__section p{
  font-family:var(--sans);font-size:15.5px;line-height:1.75;
  color:var(--ink-2);max-width:72ch;margin-bottom:14px;
}
.legal__section p:last-child{margin-bottom:0}
.legal__section p a{color:var(--burgundy);border-bottom:1px solid currentColor;transition:color .25s var(--ease)}
.legal__section p a:hover{color:var(--navy)}
.legal__section b{color:var(--ink);font-weight:600}
.legal__section ul{padding-left:20px;margin:0 0 14px}
.legal__section ul li{
  font-family:var(--sans);font-size:15.5px;line-height:1.75;color:var(--ink-2);
  margin-bottom:4px;
}
.legal__meta-info{
  color:var(--ink-3);font-size:14px;
}

.legal__col2{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(24px,3vw,48px);
}
@media (max-width:760px){.legal__col2{grid-template-columns:1fr;gap:32px}}
.legal__col2 article{
  padding:clamp(24px,3vw,32px);
  background:var(--paper);
  border:1px solid var(--rule-2);
}
.legal__col2 article h3{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--rule)}
.legal__col2 article p{font-size:15px;max-width:none}

.legal__foot-note{
  font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;margin-top:clamp(40px,6vh,72px);
  padding-top:24px;border-top:1px solid var(--rule-2);
}

/* =====================================================================
   FOOTER (mirrors main site)
===================================================================== */
.foot{background:var(--ink);color:rgba(244,238,224,.65)}
.foot__inner{
  max-width:var(--max);margin:0 auto;padding:36px var(--pad);
  display:flex;flex-direction:column;gap:24px;
}
.foot__top{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding-bottom:22px;border-bottom:1px solid rgba(244,238,224,.1);
  flex-wrap:wrap;
}
.foot__brand img{height:28px;filter:brightness(0) invert(1);opacity:.9}
.foot__nav{display:flex;flex-wrap:wrap;gap:28px}
.foot__nav a{
  font-family:var(--sans);font-size:13px;font-weight:500;
  color:rgba(244,238,224,.7);transition:color .25s var(--ease);
}
.foot__nav a:hover{color:var(--ivory)}
.foot__bottom{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:500;color:rgba(244,238,224,.45);
  flex-wrap:wrap;
}
.foot__bottom .foot__meta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.foot__meta a{
  color:rgba(244,238,224,.65);transition:color .25s var(--ease);
}
.foot__meta a:hover{color:var(--ivory)}
@media (max-width:760px){
  .foot__top{flex-direction:column;align-items:flex-start;gap:18px}
  .foot__nav{gap:18px}
}

/* =====================================================================
   MOBILE — comprehensive responsive pass for legal pages
===================================================================== */
@media (max-width:720px){
  :root{--pad:clamp(16px,4.5vw,28px)}

  .nav__inner{padding:14px var(--pad);gap:12px}
  .nav__logo{height:24px}
  .nav__back{padding:8px 14px;font-size:12px;gap:8px}
  .nav__back svg{width:12px;height:12px}

  .legal{padding:96px 0 48px}
  .legal__meta{padding-top:14px;margin-bottom:32px}
  .legal__header{margin-bottom:36px}
  .legal__header .display{font-size:clamp(36px,9vw,56px)}
  .legal__lede{font-size:15.5px;margin-top:18px}

  .legal__section{padding:28px 0}
  .legal__section h2{font-size:clamp(22px,5.5vw,28px);margin-bottom:14px}
  .legal__section h3{font-size:clamp(17px,4.5vw,20px);margin-bottom:10px}
  .legal__section p{font-size:15px;line-height:1.7;margin-bottom:12px}
  .legal__section ul li{font-size:15px;line-height:1.7}
  .legal__col2{gap:20px}
  .legal__col2 article{padding:22px 20px}

  .legal__foot-note{font-size:11px;margin-top:36px;padding-top:20px}

  .foot__inner{padding:28px var(--pad);gap:18px}
  .foot__top{flex-direction:column;align-items:flex-start;gap:18px;padding-bottom:18px}
  .foot__nav{gap:14px}
  .foot__nav a{font-size:12px}
  .foot__bottom{font-size:10px;flex-direction:column;align-items:flex-start;gap:8px}
  .foot__bottom .foot__meta{gap:14px}
}

@media (max-width:480px){
  .nav__back span{display:none}
  .nav__back{padding:8px 12px}
}
