:root{
  --bg:#F9FAFB;
  --text:#111827;
  --accent:#16A34A;
  --secondary:#0F766E;
  --muted:#6B7280;
  --card:#FFFFFF;
  --line:#E5E7EB;
  --radius:16px;
  --max:1120px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.container{max-width:var(--max);margin:0 auto;padding:0 20px}

.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{left:20px;top:20px;width:auto;height:auto;background:#fff;border:1px solid var(--line);padding:10px;border-radius:10px;z-index:9999}

header{
  position:sticky;top:0;z-index:50;
  background:rgba(249,250,251,.88);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px}
.logo{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),var(--secondary));
}
.brand strong{letter-spacing:.2px;font-size:18px}
.brand span{color:var(--muted);font-weight:500;font-size:13px;display:block;margin-top:-2px}

.navlinks{display:flex;align-items:center;gap:18px}
.navlinks a{font-weight:600}
.navlinks a[aria-current="page"]{color:var(--secondary);text-decoration:underline;text-underline-offset:6px}

.nav-cta{
  display:flex;align-items:center;gap:10px
}
.button{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:700;
  color: #000;
}
.button.primary{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
.button.secondary{
  background:transparent;
  border-color:var(--secondary);
  color:var(--secondary);
}
.button:hover{transform:translateY(-1px)}
.button:active{transform:translateY(0)}
.button:focus{outline:3px solid rgba(22,163,74,.25);outline-offset:2px}

.burger{
  display:none;
  width:44px;height:44px;border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  align-items:center;justify-content:center;
}
.burger span, .burger span::before, .burger span::after{
  content:"";
  display:block;
  width:18px;height:2px;background:var(--text);
  position:relative;border-radius:3px;
}
.burger span::before{position:absolute;top:-6px;left:0}
.burger span::after{position:absolute;top:6px;left:0}

.mobile-panel{
  display:none;
  border-top:1px solid var(--line);
  padding:10px 0 16px;
}
.mobile-panel a{display:block;padding:10px 0;font-weight:700}
.mobile-panel .mobile-cta{display:flex;gap:10px;flex-wrap:wrap;padding-top:8px}
.mobile-open .mobile-panel{display:block}

.hero{
  padding:34px 0 10px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:24px;
  align-items:stretch;
}
.hero-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.hero-media{
  height:420px;
  background:
    linear-gradient(rgba(17,24,39,.35), rgba(17,24,39,.55)),
    url("https://images.unsplash.com/photo-1560518883-ce09059eeffa?auto=format&fit=crop&w=1800&q=80");
  background-size:cover;
  background-position:center;
  display:flex;align-items:flex-end;
}
.hero-content{
  padding:26px;
  color:#fff;
}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  padding:8px 12px;border-radius:999px;
  font-weight:700;font-size:13px;
}
.kicker i{
  width:10px;height:10px;border-radius:3px;background:var(--accent);display:inline-block
}
.hero h1{
  margin:14px 0 8px;
  font-size:46px;
  line-height:1.05;
  letter-spacing:-.02em;
}
.hero p{
  margin:0;
  font-size:16px;
  color:rgba(255,255,255,.88);
  max-width:56ch;
}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

.hero-side{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.panel{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.panel h3{margin:0 0 8px;font-size:18px;letter-spacing:-.01em}
.panel p{margin:0;color:var(--muted);font-weight:500}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.badge{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:10px 12px;
  font-weight:800;
  font-size:13px;
}
.badge b{color:var(--secondary)}

.section{padding:44px 0}
.section h2{
  font-size:34px;
  letter-spacing:-.02em;
  line-height:1.1;
  margin:0 0 14px;
}
.section .lead{
  margin:0 0 22px;
  max-width:72ch;
  color:var(--muted);
  font-weight:550;
}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cards{display:grid;grid-template-columns:repeat(2, 1fr);gap:14px}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height: 100%;
}
.card .media{
  height:430px;
  background-size:cover;
  background-position:center;
  border-bottom:1px solid var(--line);
}
.card .body{padding:14px 14px 16px}
.card h3{margin:0 0 6px;font-size:17px;letter-spacing:-.01em}
.meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-weight:650;font-size:13px}
.price{color:var(--secondary);font-weight:900}
.card p{margin:10px 0 0;color:var(--muted);font-weight:520}
.card .footer{margin-top:auto;padding:0 14px 14px}
.card .footer a{font-weight:800;color:var(--accent);text-decoration:none}
.card .footer a:hover{text-decoration:underline}

.step{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.step .num{
  width:36px;height:36px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(15,118,110,.12);
  border:1px solid rgba(15,118,110,.2);
  color:var(--secondary);
  font-weight:900;
}
.step h3{margin:12px 0 8px;font-size:18px}
.step p{margin:0;color:var(--muted);font-weight:520}

.service{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.service h3{margin:0 0 8px;font-size:18px}
.service p{margin:0;color:var(--muted);font-weight:520}

.quote{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.quote p{margin:0 0 10px;font-weight:650}
.quote .who{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-weight:650;font-size:13px}
.stars{letter-spacing:1px;color:var(--accent);font-weight:900}

.cta{
  background:linear-gradient(135deg, rgba(22,163,74,.12), rgba(15,118,110,.12));
  border:1px solid rgba(17,24,39,.08);
  border-radius:24px;
  padding:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.cta h2{margin:0;font-size:34px}
.cta p{margin:8px 0 0;color:var(--muted);font-weight:550;max-width:70ch}
.cta .actions{display:flex;gap:10px;flex-wrap:wrap}

.contact{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
}
.form{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
label{font-weight:800}
input, textarea{
  font:inherit;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
}
textarea{min-height:120px;resize:vertical}
.note{color:var(--muted);font-weight:520;font-size:13px;margin-top:8px}
.kontaktkarte{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.kontaktkarte h3{margin:0 0 10px}
.kontaktkarte p{margin:0;color:var(--muted);font-weight:520}
.kontaktkarte .list{margin-top:12px;display:grid;gap:10px}
.kontaktkarte .item{padding:12px;border-radius:14px;border:1px solid var(--line);background:#fff;font-weight:750}
.kontaktkarte .item small{display:block;color:var(--muted);font-weight:650;margin-top:4px}
.map{
  margin-top:14px;
  border-radius:16px;
  border:1px solid var(--line);
  overflow:hidden;
  height:220px;
}

footer{
  border-top:1px solid var(--line);
  padding:26px 0;
  color:var(--muted);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  align-items:start;
}
.footer-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.footer-links a{font-weight:700;color:var(--muted);text-decoration:none}
.footer-links a:hover{color:var(--text);text-decoration:underline}

.page-hero{
  padding:34px 0 10px;
}
.page-hero h1{margin:0;font-size:40px;letter-spacing:-.02em;line-height:1.05}
.page-hero p{margin:10px 0 0;color:var(--muted);font-weight:550;max-width:78ch}

.list{
  display:grid;
  gap:12px;
}
.list-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.list-item h3{margin:0 0 6px;font-size:18px}
.list-item p{margin:0;color:var(--muted);font-weight:520}
.list-item .right{min-width:180px;text-align:right}
.list-item .right .price{font-size:18px}
.list-item .right .button{margin-top:10px}

.policy{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;
}
.policy h2{margin:18px 0 10px;font-size:22px}
.policy p, .policy li{color:var(--muted);font-weight:520}
.policy ul{margin:10px 0 16px;padding-left:18px}

.cookie-banner{
  position:fixed;
  left:14px;right:14px;bottom:14px;
  max-width:var(--max);
  margin:0 auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  display:none;
  z-index:100;
}
.cookie-banner.show{display:block}
.cookie-banner .row{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cookie-banner p{margin:0;color:var(--muted);font-weight:520;max-width:78ch}
.cookie-banner .actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner a{font-weight:800;color:var(--secondary);text-decoration:none}
.cookie-banner a:hover{text-decoration:underline}

@media (max-width: 1020px){
  .cards{grid-template-columns:repeat(2, 1fr)}
  .hero-grid{grid-template-columns: 1fr}
  .hero-media{height:380px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 760px){
  .navlinks, .nav-cta{display:none}
  .burger{display:inline-flex}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-links{justify-content:flex-start}
  .list-item{flex-direction:column}
  .list-item .right{min-width:0;text-align:left}
  .hero h1{font-size:40px}
}

.logo-img{
  width:40px;
  height:40px;
  display:block;
  object-fit:contain;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
}
.brand strong{ font-size:18px; line-height:1.1; }
.brand span{ display:block; font-size:12px; color:#6B7280; margin-top:2px; }