/* Fullscreen video background + centered overlay */
html,body{height:100%;margin:0}
.video-bg{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:-1}
.video-bg video{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:100%;min-height:100%;width:auto;height:auto;object-fit:cover}

.overlay{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#fff;text-align:center}
.text{max-width:1000px;padding:0 1rem}
.text h1{font-size:clamp(2rem,6vw,4rem);margin:0 0 .5rem;font-family:'Open Sans',sans-serif}
.text p{font-size:clamp(1rem,2.2vw,1.25rem);margin:0;font-family:'Open Sans',sans-serif}
.subtitle{opacity:0.9;margin-top:20rem;font-size:4rem}

.legal{position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);font-size:.95rem;color:rgba(255,255,255,.95)}
.legal a{color:inherit;text-decoration:underline}

/* Fallback background if no video is present: place an image at /images/background.jpg */
body{background:#000 url('/images/background.jpg') center/cover no-repeat fixed}

/* Container and light background for legal/text pages */
.container{padding:3rem 2rem;max-width:900px;margin:0 auto}
.light-bg{background-color:#f5f5f5;color:#333;min-height:100vh;margin-top:0}
.light-bg h1{color:#222;margin-top:0}
.light-bg a{color:#0066cc}

/* Optional: reduce motion for accessibility */
@media (prefers-reduced-motion:reduce){
  .video-bg video{display:none}
}

/* Schrifttyp für Impressum und Datenschutz */
.impressum,
.datenschutz {
  font-family: 'Segoe UI', sans-serif;
}

.home-btn { padding: 10px 20px; background-color: azure; color: #333; text-decoration: none; border-radius: 6px; font-size: 16px; display: inline-block; } .home-btn:hover { background-color: aqua; }
