/* Base */
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;background-image: url("http://villa.marketing-hagen.de/mw/assets/img/body_bg.jpg");overlay: linear-gradient(180deg, rgba(255,255,255,.35), rgba(0,0,0,.65));color:var(--ink);font:400 18px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial; 
background-attachment: fixed;
  background-size: cover; background-position: center; background-repeat: no-repeat;}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h2 {font-size: 50px;font-weight: 300;text-decoration:none; text-shadow: 1px 1px 2px black;}a:hover{text-decoration:underline;}
h3 {font-size: 30px;font-weight: 300;text-decoration:none; text-shadow: 1px 1px 2px black;}a:hover{text-decoration:underline;}
/* Header */
.site-header{position:sticky;top:0;z-index:10;background:rgba(175,203,82,.85);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid rgba(255,255,255,.08)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;min-height:164px}
.logo-link{display:inline-flex;align-items:center}
.logo{height:130px;width:auto;display:block;object-fit:contain;image-rendering:-webkit-optimize-contrast}
.brand .tagline{font-size:14px;opacity:.85;margin-left:12px}
.nav a{margin-left:18px;font-weight:300;font-size: 20px;text-shadow: 1px 1px 2px black; color:#fff;opacity:.9}.nav a:hover{opacity:1}

/* Burger */
.burger{display:none;appearance:none;border:0;background:transparent;cursor:pointer;width:44px;height:44px;border-radius:8px;position:relative}
.burger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.burger-box{position:absolute;inset:0;display:grid;place-items:center}
.burger-line{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.burger-line+.burger-line{margin-top:5px}

/* HERO (mit Absicherung via !important) */
.hero,.page-hero{
  background-image:var(--hero) !important;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  min-height:68vh;position:relative;
}
.hero .overlay,.page-hero .overlay{
  min-height:68vh;display:grid;place-items:center;text-align:center;
  background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.25));
}
.hero h1{font-size:clamp(42px,5vw,76px);margin:0 0 -200px;max-width:1000px; font-weight:300;text-shadow: 1px 1px 2px black}.lead{font-size:clamp(20px,2.1vw,32px);opacity:.95;margin:0 auto 22px;max-width:800px; text-shadow: 1px 1px 2px black}
.button{display:inline-block;background:var(--accent);color:#fff;padding:12px 20px;border-radius:10px;font-weight:700;border:0}
.hint{font-size:12px;opacity:.7;margin-top:8px}

/* Sections & cards */
.section{padding:130px 0}.section-alt{background-color: #798F36;}.intro{max-width:900px;margin:0 0 28px;opacity:.9;color:#6E6C6C;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#A1141C;border:0px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.card img{width:100%;height:auto;display:block}.card-body{padding:16px}

/* Galerie */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.section-alt p.intro {color:#ffffff;}
.gal-item img{width:100%;height:auto;display:block;border-radius:10px;border:1px solid rgba(255,255,255,.08)}

/* Über */
.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.side-media img{width:100%;display:block;border-radius:14px;border:1px solid rgba(255,255,255,.08)}
#ueber p {color:#6E6C6C;}

/* Kontakt */
.contact{display:grid;grid-template-columns:1fr 1.2fr;gap:24px}
.contact-card{background:#111;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px}
.contact-form{display:grid;gap:12px}
.contact-form input,.contact-form textarea{border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#0c0f12;color:#fff;padding:12px}
.notice{margin-top:12px;background:#113d2a;color:#bdf1d3;padding:10px 12px;border-radius:8px}

/* Footer */
.site-footer{background:#0a0d10;border-top:1px solid rgba(255,255,255,.08);padding:28px 0;margin-top:40px}
.site-footer .container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* Responsive */
@media (max-width:1024px){
  .grid-3,.gallery{grid-template-columns:repeat(2,1fr)}
  .two-col,.contact{grid-template-columns:1fr}
}
@media (max-width:900px){
  .burger{display:inline-flex}
  .nav{position:absolute;right:20px;top:64px;background:#0e1216;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px;display:none;flex-direction:column;gap:4px;width:min(86vw,320px);box-shadow:0 10px 30px rgba(0,0,0,.35)}
  .nav a{margin:0;padding:10px 12px;border-radius:8px;color:#fff;display:block}
  .nav a:hover{background:rgba(255,255,255,.06);text-decoration:none}
  .nav.is-open{display:flex}
  body.menu-open .burger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.menu-open .burger-line:nth-child(2){opacity:0}
  body.menu-open .burger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .site-header .container{position:relative}
}
@media (max-width:680px){
  .hero,.page-hero{background-image:var(--hero-mobile,var(--hero)) !important}
  .logo{height:100px}
  .brand .tagline{display:none}
}
/* Bildbasiertes Hero – unabhängig von background-image */
.hero{position:relative;min-height:68vh}
.hero-media{position:absolute;inset:0;z-index:0;display:block}
.hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.hero .overlay{
  position:relative;z-index:1;
  min-height:68vh;display:grid;place-items:center;text-align:center;
  background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.25));
}
/* Abschnitt mit Hintergrundbild + halbtransparentem Overlay */
.section-bg {
  position: relative;
  color: var(--ink);
  background: none;            /* kein Hintergrund von section-alt übernehmen */
  overflow: hidden;
}

/* Hintergrundbild */
.section-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("assets/img/section_bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
}

/* Overlay-Ebene */
.section-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);   /* Farbe & Transparenz hier anpassen */
  z-index: 1;
}

/* eigentliche Inhalte über dem Overlay */
.section-bg > * {
  position: relative;
  z-index: 2;
}
.page-impressum .side-media img{
  width: 50%;
  height: auto;
  display: block;
  margin: 0 auto; /* optional zentrieren */
}
@media (max-width: 680px){
  .page-impressum .side-media img{ width: 100%; } /* mobil wieder vollbreit */
}
@media (max-width: 680px){
  .grid-3,
  .gallery{
    grid-template-columns: 1fr;   /* statt 2 Spalten */
  }
}
/* Datenschutz: responsive fix */
.page-datenschutz .two-col{
  grid-template-columns: 1.2fr .8fr;   /* Desktop */
  gap: 40px;
  align-items: center;
}

/* Tablet & kleiner: einspaltig */
@media (max-width: 1024px){
  .page-datenschutz .two-col{
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

/* Bild sauber skalieren */
.page-datenschutz .side-media img{
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
}

/* Optional: Headline etwas kleiner auf Mobile */
@media (max-width: 680px){
  .page-datenschutz h1{ font-size: clamp(28px, 6vw, 40px); }
	body p {
    margin: 20px;
	width: 70%;
}
	{
    .page-datenschutz .two-col {
        grid-template-columns: 1fr;
        gap: 24px;
		width: 70%;
    }
}
}

