:root{
  --green:#3f7e28;
  --ink:#222;
  --muted:#6b7280;
  --bg:#fff;
  --card:#fff;
  --shadow:0 10px 30px rgba(0,0,0,.08);
}
html, body {
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE 10+ */
}


html::-webkit-scrollbar,
body::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Edge */
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}

/* Layout helpers */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section--light{background:#f7f7f7}
.section__lead{color:var(--muted);margin-top:6px}
.chip{display:inline-block;padding:8px 12px;border-radius:999px;background:#f0f7ef;color:#2a4e1c;font-weight:600}

/* NAV */
.nav{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:2px solid var(--green);box-shadow:0 4px 12px rgba(0,0,0,.06)}
.nav__wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;max-width:1200px;margin:0 auto}
.nav__brand img{height:54px;width:auto;display:block}
.nav__links {
  display: flex;
  align-items: center;
  gap: 12px;
}
.nav__links a {
  color: var(--ink);
  text-decoration: none;
  font-weight: 600;
  border: 2px solid var(--green);
  border-radius: 10px;
  padding: 6px 14px;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}
.nav__links a:hover {
  background: var(--green);
  color: #fff;
  box-shadow: 0 3px 8px rgba(63,126,40,.3);
}
.nav__links .btn{margin-left:8px}
.nav__burger{display:none;background:none;border:0;cursor:pointer}
.nav__burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0}

/* HERO (dunkler & größer, mittig) */
.hero{position:relative;width:100%;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff;padding-top:0}
.hero__bg{position:absolute;top:0;left:0;width:100%;height:110vh;background:url('/assets/img/bg.png') center/cover no-repeat;transform:scale(1.1);z-index:0}
.hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,0.55);z-index:1}
.hero__content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;text-align:center;width:100%;height:100%;padding:0 20px}
.hero__inner{max-width:800px}
.hero__content h1{font-size:clamp(2rem,5vw,3.2rem);margin:0 0 16px;line-height:1.2;color:#fff}
.hero__content p{font-size:1.1rem;color:#f0f0f0;max-width:680px;margin:0 auto 30px}
.hero__cta{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:10px;font-weight:700;text-decoration:none;border:2px solid transparent;transition:transform .15s,box-shadow .25s,background .25s,color .25s}
.btn--primary{background:var(--green);color:#fff}
.btn--primary:hover{transform:translateY(-1px);box-shadow:var(--shadow);background:#2e5d1c}
.btn--secondary{background:#eaf5e7;color:#1f3d14;border-color:var(--green)}
.btn--secondary:hover{background:#dff0d9}
.btn--ghost{background:transparent;border-color:var(--green);color:#1f3d14}
.btn--ghost:hover{background:#eff8ec}

/* About */
.section--about {
  background: #fff;
}

.about {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}

/* Bild */
.about__image img {
  width: 100%;
  max-width: 480px;
  border-radius: 16px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.1);
  object-fit: cover;
}

/* Rechte Seite (Text & Chips) */
.about__content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.about__text h2 {
  font-size: 2rem;
  color: var(--green);
  margin-bottom: 10px;
}

.about__text p {
  color: var(--ink);
  line-height: 1.6;
  margin: 0;
}

.about__highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

/* Mobil: Bild oben, Text unten */
@media (max-width: 900px) {
  .about {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .about__image img {
    max-width: 320px;
    margin: 0 auto;
  }

  .about__content {
    align-items: center;
  }
}

/* Leistungen Slider (wie Original: 3/1, Pfeile & Swipe) */
.features-slider{position:relative;padding: 0 48px;margin-top:20px}
.features-viewport{overflow:hidden;position: relative; z-index: 1}
.features-track{display:flex;gap:20px;will-change:transform;transition:transform .45s ease}
.feature-card{
  flex:0 0 calc((100% - 40px) / 3); /* 3 sichtbar minus Lücken */
  background:var(--card);border-radius:14px;padding:24px;text-align:center;box-shadow:var(--shadow);
}
.feature-card .icon{font-size:2rem;margin-bottom:10px}
.feature-card h3{margin:6px 0 8px;color:var(--green)}
.features-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;                  /* über Track & Karten */
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  font-size: 1.6rem;
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0,0,0,.15);
  transition: background .2s ease, transform .1s ease;
  pointer-events: auto;
}

.features-btn.prev{ left: -12px; }
.features-btn.next{ right: -12px; }
.features-btn:hover{ background:#2e5d1c; transform:translateY(-50%) scale(1.04); }

/* Optional: auf sehr breiten Screens Pfeile noch weiter außen */
@media (min-width: 1400px){
  .features-btn.prev{ left: -18px; }
  .features-btn.next{ right: -18px; }
}

/* Mobil: 1 Karte, Pfeile ausblenden, Swipe übernehmen */
@media (max-width: 800px){
  .feature-card{ flex: 0 0 100%; }
  .features-slider{ padding: 0; }
  .features-btn{ display: none; }
}

/* Mobile smooth-snap Slider */
@media (max-width: 800px) {
  .features-track {
    scroll-snap-type: x mandatory;
  }
  .feature-card {
    scroll-snap-align: center;
  }
}

/* Kontakt (Originalstil) */
.contact-section {
  position: relative;
  background: url('/assets/img/kontakt-bg.png') center/cover no-repeat;
  padding: 100px 0;
  color: #fff;
  overflow: hidden;
}

.hp-field {
    position: absolute;
    left: -9999px;
    visibility: hidden;
}


/* Dunkler Overlay, damit Text lesbar bleibt */
.contact-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 0;
}

/* Container-Inhalt über dem Overlay */
.contact-container {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Titel */
.section-title {
  text-align: center;
  font-size: 2rem;
  margin-bottom: 50px;
  color: #fff;
}

/* Grid bleibt wie bisher */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 40px;
  align-items: start;
}

/* Linke Spalte (Info) */
.contact-info .info-item {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 25px;
}

.contact-info i {
  font-size: 1.8rem;
  color: var(--green);
  flex-shrink: 0;
  width: 35px;
  text-align: center;
}

.contact-info h3 {
  margin: 0;
  font-size: 1.1rem;
  color: #fff;
}

.contact-info p {
  margin: 2px 0 0;
  color: #f2f2f2;
}

.contact-info a {
  color: #d9ffcd;
  text-decoration: none;
}

.contact-info a:hover {
  text-decoration: underline;
}

/* Rechte Spalte (Formular) */
.contact-form {
  background: rgba(255,255,255,0.12);
  padding: 30px;
  border-radius: 14px;
  backdrop-filter: blur(8px);
  box-shadow: 0 0 25px rgba(0,0,0,0.2);
}

/* Formular-Button mittig */
.contact-form button {
  display: block;
  margin: 20px auto 0 auto;   /* oben etwas Abstand, dann zentriert */
  padding: 12px 26px;
  border: none;
  border-radius: 10px;
  background: var(--green);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  transition: background .25s ease, transform .15s ease;
}

.contact-form button:hover {
  background: #2e5d1c;
  transform: translateY(-1px);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.contact-form label span {
  display: block;
  margin: 8px 0 4px;
  font-weight: 600;
  color: #fff;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  font: inherit;
  padding: 10px 12px;
  border-radius: 8px;
  border: 2px solid rgba(255,255,255,0.4);
  background: rgba(255,255,255,0.15);
  color: #fff;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--green);
  background: rgba(255,255,255,0.25);
  box-shadow: 0 0 0 3px rgba(63,126,40,.3);
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: #ddd;
}

/* Checkbox + Text korrekt im Formular */
.check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 10px 0 20px;
  font-size: .95rem;
  color: #eaeaea;
  text-align: left;
  max-width: 100%;              /* verhindert, dass Text aus der Box läuft */
  flex-wrap: wrap;              /* bricht Textzeilen korrekt um */
}

.check input[type="checkbox"] {
  margin-top: 3px;
  flex-shrink: 0;
}

.check span {
  flex: 1;
  line-height: 1.4;
}

.check a {
  color: #b8f2a8;
  text-decoration: none;
}

.check a:hover {
  text-decoration: underline;
}

.features-track {
  transition: transform .5s ease-in-out;
}


.form-msg {
  margin-top: 8px;
  font-weight: 600;
  color: #fff;
}

/* Responsive */
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
}


/* Footer */
.footer{background:#222;color:#fff;padding:24px 0}
.footer__wrap{display:flex;justify-content:space-between;align-items:center;gap:16px}
.footer__brand img{height:44px;width:auto;filter:brightness(0) invert(1)}
.footer__legal a{color:#fff;text-decoration:underline}

/* Anker-Korrektur bei fixer Nav */
#leistungen,#kontakt{scroll-margin-top:100px}

/* Responsive */
@media (max-width:1024px){
  .about{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .features-btn.prev{left:4px}
  .features-btn.next{right:4px}
}
@media (max-width:800px){
  .feature-card{flex:0 0 100%} /* mobil: 1 sichtbar */
}
@media (max-width:640px){
  .nav__links{display:none}
  .nav__burger{display:block}
  .form-row{grid-template-columns:1fr}
  .hero{height:80vh}
  .hero__bg{transform:scale(1.2)}
}

/* ===============================
   Rechtstexte (Impressum & Datenschutz)
   =============================== */

.hero--small {
  height: 40vh;
  min-height: 320px;
}

.legal {
  background: #f7f7f7;
}

.legal .container {
  display: flex;
  flex-direction: column;
  gap: 30px;              /* gleichmäßiger Abstand */
}

.legal-card {
  background: #fff;
  border-radius: 14px;
  box-shadow: var(--shadow);
  padding: 24px 28px;
  line-height: 1.6;
}

.legal-card h2 {
  color: var(--green);
  margin-top: 0;
  margin-bottom: 10px;
}

.legal-card a {
  color: var(--green);
  text-decoration: none;
}

.legal-card a:hover {
  text-decoration: underline;
}

@media (max-width: 700px) {
  .hero--small { height: 50vh; }
  .legal-card { padding: 20px; }
}

