/* ===== SturzflugTV — Rechtsseiten (Impressum / Datenschutz) =====
   Eigenes, schlankes Stylesheet im "Über den Wolken"-Look. Lesbarkeit zuerst,
   Marke im Detail. Teilt sich Tokens + Theme (sf-theme) mit der Startseite. */

/* Self-hosted fonts (we own these — no Google CDN) */
@font-face{font-family:'Rajdhani';font-weight:400;font-display:swap;src:url('/fonts/rajdhani-400.woff2') format('woff2')}
@font-face{font-family:'Rajdhani';font-weight:500;font-display:swap;src:url('/fonts/rajdhani-500.woff2') format('woff2')}
@font-face{font-family:'Rajdhani';font-weight:600;font-display:swap;src:url('/fonts/rajdhani-600.woff2') format('woff2')}
@font-face{font-family:'Rajdhani';font-weight:700;font-display:swap;src:url('/fonts/rajdhani-700.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-weight:400;font-display:swap;src:url('/fonts/jbmono-400.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-weight:500;font-display:swap;src:url('/fonts/jbmono-500.woff2') format('woff2')}

:root{
  --bg:#0A1622; --s1:#0E1C2B; --s2:#12273A; --s3:#1B3650;
  --cy:#2FD4E6; --cyb:#7BEFF7; --cyd:#2A6E80;
  --ink:#E6F0FA; --muted:#9DB6D0;
  --line:rgba(47,212,230,.16); --hair:rgba(157,182,208,.16);
  --disp:'Rajdhani',Oswald,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Consolas,monospace;
  --maxw:840px; --pad:clamp(20px,5vw,56px);
}
html.light{
  --bg:#E9F1F8; --s1:#FFFFFF; --s2:#F2F7FB; --s3:#E1EBF4;
  --cy:#0FA5BD; --cyb:#0B7E92; --cyd:#7FB3C0;
  --ink:#12293B; --muted:#48677E;
  --line:rgba(15,165,189,.30); --hair:rgba(18,41,59,.15);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--disp);background:var(--bg);color:var(--ink);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;
  background-image:
    radial-gradient(120% 80% at 50% -10%, color-mix(in srgb, var(--cy) 12%, transparent), transparent 60%);
  background-attachment:fixed;
}
html.light body{
  background-image:
    radial-gradient(120% 90% at 50% -20%, #FFFFFF 0%, #DDEAF6 45%, #E9F1F8 100%);
}

/* ---- top bar ---- */
.bar{
  position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:16px;
  padding:14px var(--pad);border-bottom:1px solid var(--line);
  background:color-mix(in srgb, var(--bg) 82%, transparent);backdrop-filter:blur(10px);
}
.bar .brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.5px;
  font-size:18px;color:var(--ink);text-decoration:none}
.bar .brand b{color:var(--cy)}
.bar .brand img{width:26px;height:26px;display:block}
.bar .spacer{flex:1}
.bar a.nav{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;padding:6px 10px;border-radius:6px}
.bar a.nav:hover{color:var(--cy);background:var(--s2)}
.toggle{font-family:var(--mono);font-size:12px;cursor:pointer;color:var(--muted);
  background:var(--s2);border:1px solid var(--line);border-radius:6px;padding:6px 10px}
.toggle:hover{color:var(--cy)}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:clamp(28px,6vw,64px) var(--pad) 80px}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--cy);
  display:inline-flex;align-items:center;gap:8px;margin-bottom:10px}
.kicker::before{content:"";width:26px;height:1px;background:var(--cy);display:inline-block}
h1{font-size:clamp(30px,6vw,46px);font-weight:700;letter-spacing:.5px;line-height:1.1;margin-bottom:6px}
.lead{color:var(--muted);font-size:16px;margin-bottom:8px}

section{margin-top:30px;background:var(--s1);border:1px solid var(--line);border-radius:12px;
  padding:clamp(18px,3.5vw,28px)}
h2{font-size:20px;font-weight:700;color:var(--cy);margin-bottom:10px;letter-spacing:.3px}
h3{font-size:15px;font-weight:600;margin:16px 0 4px}
p{margin:8px 0;color:var(--ink)}
p.muted, .muted{color:var(--muted)}
a{color:var(--cy);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--cy) 40%,transparent)}
a:hover{border-bottom-color:var(--cy)}
ul{margin:8px 0 8px 20px}li{margin:4px 0}
.addr{font-family:var(--mono);font-size:14px;line-height:1.9;color:var(--ink);
  background:var(--s2);border-left:3px solid var(--cy);border-radius:6px;padding:12px 16px;margin:10px 0}
.small{font-size:13px}
.note{font-family:var(--mono);font-size:12.5px;color:var(--muted);background:var(--s2);
  border:1px dashed var(--line);border-radius:8px;padding:12px 14px;margin-top:14px}
.stand{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:26px;text-align:center}

footer{border-top:1px solid var(--line);padding:22px var(--pad);text-align:center}
footer a{margin:0 8px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
footer .c{display:block;margin-top:8px;color:var(--muted);font-size:12px;font-family:var(--mono)}

/* ---- kompakter Header auf kleinen Screens (sonst klippt die Navi) ---- */
@media (max-width:560px){
  .bar{gap:10px;padding:12px 18px}
  .bar .brand{font-size:16px}
  .bar a.nav{padding:5px 8px;font-size:11px}
}
@media (max-width:480px){
  .bar a.nav{display:none}              /* Navigation übernimmt der Footer + Marke→Start */
  .bar .spacer{flex:1}
}
