:root{--bg:#f3f7ef;--paper:#fff;--ink:#14241d;--muted:#5e6c63;--g:#2e7d32;--g-600:#27692b;--accent:#c9a85a;--line:rgba(20,36,29,.10);--shadow:0 18px 50px rgba(28,58,39,.10);--ring:0 0 0 3px rgba(39,105,43,.2)}
*{box-sizing:border-box}
html,body{margin:0;background:linear-gradient(180deg,#fbfdf8 0,#f3f7ef 280px,var(--bg) 100%);color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Noto Sans",sans-serif;line-height:1.65}
img{max-width:100%;display:block;height:auto}
.container{max-width:1120px;margin:0 auto;padding:0 20px}

/* Header/Navi */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:saturate(175%) blur(14px);border-bottom:1px solid var(--line)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-weight:800;font-size:20px;color:var(--ink);text-decoration:none;letter-spacing:.1px}
.nav{display:flex;gap:18px;align-items:center}
.nav a{position:relative;color:var(--ink);padding:8px 10px;border-radius:8px;text-decoration:none;font-size:14px}
.nav a:hover{background:rgba(46,125,50,.08)}
.nav a.active::after{content:'';position:absolute;left:10px;right:10px;bottom:5px;height:2px;background:linear-gradient(90deg,var(--g),var(--accent))}
.burger{display:none;flex-direction:column;gap:4px;background:transparent;border:0}
.burger span{width:22px;height:2px;background:var(--ink);display:block;border-radius:2px}

/* Hero Ken-Burns */
.hero.hero-kenburns{position:relative;min-height:70vh;display:grid;place-items:center;overflow:hidden}
.hero .kb{position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(246,249,243,.82),rgba(246,249,243,.92)),
    var(--img, url('../images/hero.webp')) center/cover no-repeat;
  animation:kbZoom 18s ease-in-out infinite alternate;will-change:transform}
@keyframes kbZoom{from{transform:scale(1.05) translate3d(-2%,0,0)}to{transform:scale(1.13) translate3d(2%,-2%,0)}}
.hero-inner{position:relative;text-align:center;padding:96px 0}
.hero h1{font-size:clamp(36px,5.8vw,68px);line-height:1.02;margin:0 0 12px}
.hero-lead{max-width:680px;margin:0 auto 22px;color:#263a32;font-size:clamp(17px,2.2vw,21px);line-height:1.45;font-weight:600}
.lead{color:var(--muted);font-size:18px;margin:0 0 20px}
.cta-row{display:flex;gap:12px;justify-content:center}

/* Logo oben rechts */
.hero-logo{position:absolute;right:clamp(14px,4vw,32px);top:clamp(14px,4vw,24px);width:clamp(120px,18vw,240px);filter:drop-shadow(0 10px 24px rgba(0,0,0,.25));animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* Buttons */
.btn{display:inline-block;padding:12px 17px;border-radius:8px;text-decoration:none;font-weight:800;border:1px solid var(--line);transition:transform .15s ease, box-shadow .15s ease, background .15s ease}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(28,58,39,.12)}
.btn:focus-visible,.nav a:focus-visible,.burger:focus-visible{outline:none;box-shadow:var(--ring)}
.btn.primary{background:var(--g);color:#fff;border-color:transparent}
.btn.primary:hover{background:var(--g-600)}
.btn.ghost{background:rgba(255,255,255,.82);color:var(--ink)}

/* Badges/Benefits */
.badges{padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.76)}
.badge-row{display:flex;gap:10px;list-style:none;padding:0;margin:0;justify-content:center;flex-wrap:wrap}
.badge-row li{display:flex;align-items:center;gap:8px;color:#2e4639;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 13px;font-weight:700;font-size:14px}

/* Text helpers */
.section-title{text-align:center;margin:0 0 10px;font-size:clamp(26px,3vw,38px);line-height:1.12}
.section-lead{color:var(--muted);text-align:center;margin:0 auto 24px;max-width:720px}

/* CTA + Footer */
.site-footer{background:#fff;border-top:1px solid var(--line);padding:28px 0;margin-top:20px}
.footer-grid{display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center}
.footer-grid nav{display:flex;gap:16px}
.copy{justify-self:end;color:var(--muted)}

/* Reveals */
.reveal-up{opacity:0;transform:translateY(16px);transition:600ms ease}
.reveal-up.is-visible{opacity:1;transform:none}
.reveal-fade{opacity:0;transition:800ms ease}
.reveal-fade.is-visible{opacity:1}

/* Hero – mit korrektem Pfad (CSS liegt in /css, Bilder in /images) */
.hero .kb{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(246,249,243,.58), rgba(246,249,243,.30)),
    var(--img, url('../images/hero.webp')) center/cover no-repeat;
  animation:kbZoom 18s ease-in-out infinite alternate;
  will-change:transform;
}

/* Bewegungen für „Bewegung reduzieren“-Nutzer abschalten */
@media (prefers-reduced-motion: reduce){
  .hero .kb{ animation:none }
  .hero-logo{ animation:none }
  .reveal-up, .reveal-fade{ opacity:1; transform:none }
  .track{ scroll-behavior:auto }
}

/* --- Carousel Fix: kein Drift durch figure-default-margins --- */
figure { margin: 0; }               /* WICHTIG */

/* Responsive */
@media (max-width:1024px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:820px){
  .features{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;text-align:center}
  .nav{display:none;position:absolute;right:20px;top:64px;background:#fff;padding:10px;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);flex-direction:column}
  .nav.open{display:flex}
  .burger{display:flex}
}
@media (max-width:560px){
  .hero.hero-kenburns{min-height:68vh}
  .hero-inner{padding:112px 0 64px}
  .hero-logo{width:112px}
  .cta-row{flex-direction:column;align-items:stretch}
  .cta-row .btn{text-align:center}
  .nav{left:20px;right:20px;align-items:stretch}
  .nav a{text-align:center}
}
