/*
Theme Name: Steins Haus & Gartenservice Komplett editierbar
Theme URI: https://steins-service.de/
Author: OpenAI
Description: Komplett bearbeitbares WordPress Theme für Steins Haus & Gartenservice mit Customizer und Contact Form 7.
Version: 3.1 Finale
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: steins-service
*/

:root{
  --bg:#f5f3ee;
  --bg-soft:#e9eee8;
  --white:#ffffff;
  --text:#2d3b34;
  --muted:#5a655f;
  --green:#2f6d58;
  --green-dark:#17362b;
  --green-mid:#214d40;
  --gold:#f1c14f;
  --shadow:0 12px 30px rgba(0,0,0,.08);
  --radius:28px;
  --container:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:auto}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(calc(100% - 32px), var(--container));margin:0 auto}

.site-header{position:sticky;top:0;z-index:1000;background:rgba(23,54,43,.88);backdrop-filter:blur(10px);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0}
.brand{font-size:1.35rem;font-weight:700;letter-spacing:.2px}
.nav-menu{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.nav-menu a{color:#fff;opacity:.92}
.nav-menu a:hover{opacity:1}

.btn{display:inline-block;padding:14px 22px;border-radius:18px;font-weight:700;transition:transform .2s ease, opacity .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 10px 22px rgba(0,0,0,.15)}
.btn-secondary{background:#fff;color:var(--green-dark);box-shadow:0 10px 22px rgba(0,0,0,.10)}
.btn-outline{border:2px solid var(--green);color:var(--green)}

.hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(19,57,45,.9) 0%, rgba(19,57,45,.74) 40%, rgba(19,57,45,.18) 74%);
}
.hero-inner{
  position:relative;
  min-height:520px;
  display:flex;
  align-items:center;
  padding:60px 0;
}
.hero-content{max-width:760px}
.eyebrow{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  margin-bottom:18px;
  font-size:.92rem;
}
.hero h1{font-size:clamp(2.2rem,4vw,3.6rem);line-height:1.1;margin:0 0 14px}
.hero p.lead{font-size:clamp(1.05rem,2vw,1.3rem);max-width:760px;color:rgba(255,255,255,.92);margin:0 0 12px}
.hero .highlight{color:var(--gold);font-size:1.18rem;font-weight:700;margin:10px 0 0}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:30px;max-width:760px}
.point{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:18px;backdrop-filter:blur(8px)}
.point strong{display:block;font-size:1.08rem;line-height:1.2;margin-bottom:6px}

section{padding:80px 0}
.section-head{max-width:860px;margin:0 auto 46px;text-align:center}
.section-head h2{margin:0 0 16px;font-size:clamp(2rem,4vw,3rem);line-height:1.1}
.section-head p{margin:0;color:var(--muted);font-size:1.06rem}


.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.service-card{
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.05);
  display:flex;
  flex-direction:column;
  min-height:100%;
}
.service-media{
  height:210px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.service-media::after{
  content:"";
  display:none;
}
.service-content{
  padding:24px 24px 26px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}
.service-icon{
  font-size:1.8rem;
  color:var(--green);
  margin-bottom:2px;
}
.service-card h3{
  margin:0;
  font-size:1.65rem;
  line-height:1.15;
  color:var(--green-mid);
}
.service-card p{
  margin:0;
  color:var(--muted);
  font-size:1.02rem;
  line-height:1.65;
}

.notice{background:#fff7e0;border-left:4px solid var(--gold);padding:22px;border-radius:18px;box-shadow:0 8px 18px rgba(0,0,0,.05);margin-top:34px;color:#5d5433}
.center-cta{text-align:center;margin-top:42px}
.center-cta h3{font-size:2rem;margin:0 0 20px;color:var(--green-dark)}

.features-wrap{background:rgba(255,255,255,.65)}
.features-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:40px;align-items:start}
.feature-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.feature-card{background:#fff;border-radius:24px;padding:22px;box-shadow:0 10px 24px rgba(0,0,0,.06)}
.feature-card .check{font-size:1.6rem;color:var(--green);margin-bottom:8px;font-weight:700}

.banner{
  position:relative;
  color:#fff;
  overflow:hidden;
  background-size:cover;
  background-position:center;
}
.banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(19,57,45,.92) 0%, rgba(19,57,45,.84) 44%, rgba(19,57,45,.28) 78%);
}
.banner-inner{position:relative;display:grid;grid-template-columns:1fr;gap:30px;min-height:360px;align-items:center}
.banner-copy{max-width:760px}
.banner h2{font-size:clamp(2rem,4vw,3.1rem);line-height:1.1;margin:0 0 16px}
.banner p{font-size:1.08rem;color:rgba(255,255,255,.88);max-width:720px}

.steps-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:start}
.steps-list{display:grid;gap:16px;margin-top:26px}
.step{background:#fff;border-radius:26px;padding:24px;box-shadow:0 10px 28px rgba(0,0,0,.07)}
.step h3{margin:0 0 8px;color:var(--green-mid);font-size:1.5rem}
.step p{margin:0;color:var(--muted)}
.image-panel{background:#fff;padding:14px;border-radius:32px;box-shadow:0 16px 40px rgba(0,0,0,.10)}
.image-panel img{width:100%;height:460px;object-fit:cover;border-radius:24px}

.support-section{background:var(--bg-soft)}
.support-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px}
.support-item{background:#fff;padding:22px;border-radius:24px;box-shadow:0 8px 24px rgba(0,0,0,.06);color:#44514b;font-size:1.02rem}

.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:32px;align-items:start}
.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:26px}
.contact-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 10px 28px rgba(0,0,0,.07)}
.contact-card.full{grid-column:1 / -1}
.contact-card h3{margin:0 0 8px;color:var(--green-mid)}
.contact-card p{margin:0;color:var(--muted)}
.contact-form-box{background:#fff;padding:24px;border-radius:24px;box-shadow:0 10px 28px rgba(0,0,0,.07);margin-top:16px}
.contact-form-box p{color:var(--muted)}
.cf7-shortcode{margin-top:14px;padding:16px;border:1px dashed #bcc8c2;border-radius:16px;background:#f9fbfa;color:#44514b;word-break:break-all}

.footer{background:var(--green-dark);color:#fff;padding:56px 0}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.footer p,.footer li{color:rgba(255,255,255,.82)}
.footer h3,.footer h4{margin-top:0}
.footer ul{list-style:none;padding:0;margin:0}
.footer li+li{margin-top:8px}

.simple-page{padding:60px 0}
.simple-page .entry{background:#fff;border-radius:24px;padding:28px;box-shadow:var(--shadow)}

@media (max-width:1100px){
  .features-grid,.steps-grid,.contact-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-menu{display:none}
  .hero-inner{min-height:auto;padding:54px 0}
  .hero-points,.services-grid,.feature-cards,.support-grid,.contact-cards,.footer-grid{grid-template-columns:1fr}
  .service-card{display:flex;flex-direction:column}
  .service-media{min-height:220px}
  .image-panel img{height:320px}
  section{padding:68px 0}
  .hero h1{font-size:2.2rem}
}



/* WordPress Menü */
.nav-menu ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  align-items:center;
}
.nav-menu li{
  list-style:none;
  margin:0;
  padding:0;
}
.nav-menu a{
  color:#fff;
  opacity:.92;
  text-decoration:none;
}
.nav-menu a:hover{
  opacity:1;
}



/* Leistungsbereich optimiert */
#leistungen .section-head p{
  max-width:760px;
  margin:0 auto;
}

/* Rechtlicher Hinweis */
.rechtlicher-hinweis {
  background: #e9eee8;
  padding: 56px 20px 72px;
}

.rechtlicher-hinweis .container {
  max-width: 1200px;
}

.rechtlicher-hinweis-card {
  max-width: 760px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(47, 109, 88, 0.12);
  border-radius: 26px;
  padding: 28px 32px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
  position: relative;
  overflow: hidden;
}

.rechtlicher-hinweis-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 6px;
  height: 100%;
  background: #2f6d58;
}

.rechtlicher-hinweis-header {
  margin-bottom: 16px;
}

.rechtlicher-hinweis-badge {
  display: inline-block;
  margin-bottom: 10px;
  padding: 6px 12px;
  border-radius: 999px;
  background: #e9eee8;
  color: #214d40;
  font-size: 0.82rem;
  line-height: 1;
  font-weight: 700;
}

.rechtlicher-hinweis h3 {
  margin: 0;
  color: #17362b;
  font-size: clamp(1.45rem, 2.4vw, 1.9rem);
  line-height: 1.15;
}

.rechtlicher-hinweis-text {
  display: grid;
  gap: 12px;
}

.rechtlicher-hinweis p {
  margin: 0;
  color: #4f5a55;
  font-size: 0.98rem;
  line-height: 1.7;
}

.rechtlicher-hinweis-link {
  color: #2f6d58;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

.rechtlicher-hinweis-link:hover {
  color: #17362b;
}

@media (max-width: 760px) {
  .rechtlicher-hinweis {
    padding: 44px 16px 58px;
  }

  .rechtlicher-hinweis-card {
    padding: 24px 22px 24px 26px;
    border-radius: 22px;
  }

  .rechtlicher-hinweis p {
    font-size: 0.95rem;
  }
}

/* Hinweis zur Entsorgung */
.entsorgung-hinweis {
  background: #f5f3ee;
  padding: 0 20px 72px;
  margin-top: -24px;
}

.entsorgung-card {
  max-width: 980px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(47, 109, 88, 0.12);
  border-radius: 26px;
  padding: 28px 32px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: start;
}

.entsorgung-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: #e9eee8;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.45rem;
}

.entsorgung-card h3 {
  margin: 0 0 12px;
  color: #17362b;
  font-size: clamp(1.35rem, 2.4vw, 1.8rem);
  line-height: 1.15;
}

.entsorgung-card p {
  margin: 0 0 12px;
  color: #4f5a55;
  font-size: 1rem;
  line-height: 1.7;
}

.entsorgung-card p:last-child {
  margin-bottom: 0;
}

@media (max-width: 760px) {
  .entsorgung-hinweis {
    padding: 0 16px 54px;
    margin-top: -18px;
  }

  .entsorgung-card {
    grid-template-columns: 1fr;
    padding: 24px 22px;
    border-radius: 22px;
  }
}


/* Finale Anker-Navigation */
html {
  scroll-behavior: auto !important;
}

#leistungen,
#vorteile,
#ablauf,
#kontakt,
#impressum,
#datenschutz,
#agb {
  scroll-margin-top: 95px;
}

.nav-menu {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  align-items: center;
}

.nav-menu a {
  color: #fff;
  text-decoration: none;
  white-space: nowrap;
  opacity: .92;
}

.nav-menu a:hover {
  opacity: 1;
}

@media (max-width: 900px) {
  .header-inner {
    align-items: flex-start;
    flex-direction: column;
  }

  .nav-menu {
    gap: 12px 16px;
  }
}


/* Externe Rechtseiten */
#leistungen,
#vorteile,
#ablauf,
#kontakt {
  scroll-margin-top: 95px;
}

.simple-page {
  padding: 80px 0;
  background: #f5f3ee;
}

.simple-page .entry {
  max-width: 900px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 26px;
  padding: 34px 38px;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  border-left: 5px solid #2f6d58;
}

.simple-page .entry h1 {
  margin-top: 0;
  color: #17362b;
}

.simple-page .entry p {
  color: #4f5a55;
  line-height: 1.7;
}


/* Startseiten-Sprungmarken */
#leistungen,
#vorteile,
#ablauf,
#kontakt,
.anchor-target {
  scroll-margin-top: 110px;
}


/* Scroll-Ziele */
.anchor-target,
#leistungen,
#vorteile,
#ablauf,
#kontakt {
  scroll-margin-top: 110px;
}


/* Google Bewertungen */
.google-bewertungen {
  background: #ffffff;
  padding: 82px 0;
}

.bewertung-badge {
  display: inline-block;
  margin-bottom: 12px;
  padding: 7px 13px;
  border-radius: 999px;
  background: #e9eee8;
  color: #214d40;
  font-size: 0.9rem;
  font-weight: 700;
}

.bewertung-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.bewertung-card {
  background: #f5f3ee;
  border-radius: 24px;
  padding: 26px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  border: 1px solid rgba(47,109,88,.08);
}

.sterne {
  color: #f1c14f;
  font-size: 1.25rem;
  letter-spacing: 2px;
  margin-bottom: 14px;
}

.bewertung-card p {
  color: #4f5a55;
  line-height: 1.7;
  margin: 0 0 16px;
}

.bewertung-card strong {
  color: #17362b;
}

.bewertung-cta {
  margin-top: 30px;
  text-align: center;
}

/* WhatsApp Button */
.whatsapp-float {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  border-radius: 999px;
  background: #25D366;
  color: #ffffff;
  font-weight: 800;
  box-shadow: 0 14px 30px rgba(0,0,0,.22);
  transition: transform .2s ease, box-shadow .2s ease;
}

.whatsapp-float:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 34px rgba(0,0,0,.28);
}

@media (max-width: 900px) {
  .bewertung-grid {
    grid-template-columns: 1fr;
  }

  .whatsapp-float {
    right: 16px;
    bottom: 16px;
  }
}


.google-reviews-plugin-box {
  max-width: 1100px;
  margin: 0 auto;
}

.google-reviews-plugin-box iframe,
.google-reviews-plugin-box > div {
  max-width: 100%;
}


/* DSGVO-sicherer WhatsApp Hinweis */
.whatsapp-consent-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(23, 54, 43, 0.58);
}

.whatsapp-consent-modal.is-visible {
  display: flex;
}

.whatsapp-consent-card {
  width: min(100%, 520px);
  background: #ffffff;
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 18px 46px rgba(0,0,0,.25);
}

.whatsapp-consent-card h3 {
  margin: 0 0 12px;
  color: #17362b;
}

.whatsapp-consent-card p {
  color: #4f5a55;
  line-height: 1.7;
  margin: 0 0 22px;
}

.whatsapp-consent-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.google-reviews-plugin-box {
  max-width: 1100px;
  margin: 0 auto;
}

.google-reviews-plugin-box iframe,
.google-reviews-plugin-box > div {
  max-width: 100%;
}



/* Footer SEO Links klickbar */
.footer-service-links a,
.footer a {
  color: rgba(255,255,255,.86);
  text-decoration: none;
  pointer-events: auto;
  cursor: pointer;
}

.footer-service-links a:hover,
.footer a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.footer,
.footer * {
  pointer-events: auto;
}




/* SEO-Ortsseiten */
.simple-page {
  padding: 80px 0;
  background: #f5f3ee;
}

.simple-page .entry {
  max-width: 940px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 26px;
  padding: 34px 38px;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  border-left: 5px solid #2f6d58;
}

.simple-page .entry h1,
.simple-page .entry h2 {
  color: #17362b;
}

.simple-page .entry p,
.simple-page .entry li {
  color: #4f5a55;
  line-height: 1.7;
}

.footer-service-links a {
  color: rgba(255,255,255,.86);
  text-decoration: none;
}

.footer-service-links a:hover {
  color: #fff;
  text-decoration: underline;
}

/* SEO-Ortsseiten ganz unten */
.seo-location-footer {
  background:
    radial-gradient(circle at 20% 10%, rgba(47, 109, 88, .28), transparent 32%),
    linear-gradient(180deg, #123f31 0%, #0f3329 100%);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 58px 20px 68px;
  color: rgba(255,255,255,.86);
}

.seo-location-head {
  max-width: 780px;
  margin: 0 auto 34px;
  text-align: center;
}

.seo-location-head span {
  display: inline-block;
  margin-bottom: 12px;
  padding: 7px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: #d7efe6;
  font-size: .88rem;
  font-weight: 800;
  border: 1px solid rgba(255,255,255,.14);
}

.seo-location-head h3 {
  color: #ffffff;
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  line-height: 1.15;
  margin: 0 0 12px;
}

.seo-location-head p {
  margin: 0;
  color: rgba(255,255,255,.72);
  line-height: 1.7;
}

.seo-location-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.seo-location-card {
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 18px 34px rgba(0,0,0,.12);
  backdrop-filter: blur(8px);
}

.seo-location-card h4 {
  color: #ffffff;
  margin: 0 0 14px;
  font-size: 1.1rem;
}

.seo-location-card a {
  display: flex;
  align-items: center;
  gap: 9px;
  color: rgba(255,255,255,.8);
  text-decoration: none;
  padding: 8px 0;
  line-height: 1.35;
  font-size: .96rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.seo-location-card a:last-child {
  border-bottom: 0;
}

.seo-location-card a::before {
  content: "›";
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: #d7efe6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-weight: 900;
}

.seo-location-card a:hover {
  color: #ffffff;
  transform: translateX(2px);
}

.seo-location-card a:hover::before {
  background: #2f6d58;
  color: #ffffff;
}

@media (max-width: 1100px) {
  .seo-location-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .seo-location-footer {
    padding: 46px 16px 54px;
  }

  .seo-location-grid {
    grid-template-columns: 1fr;
  }

  .seo-location-card {
    padding: 20px;
    border-radius: 20px;
  }
}


.footer-legal {
  background: #0c2f26;
  padding: 14px 0;
  text-align: center;
}

.footer-legal a {
  color: rgba(255,255,255,.75);
  margin: 0 12px;
  text-decoration: none;
}

.footer-legal a:hover {
  color: #fff;
}


/* SEO Bereich kompakter */
.seo-location-footer {
  padding: 40px 20px 45px;
}

.seo-location-head {
  margin-bottom: 20px;
}

.seo-location-head h3 {
  font-size: 1.8rem;
}

.seo-location-head p {
  font-size: 0.9rem;
}

.seo-location-grid {
  gap: 16px;
}

.seo-location-card {
  padding: 18px 20px;
  border-radius: 18px;
}

.seo-location-card h4 {
  font-size: 1rem;
  margin-bottom: 10px;
}

.seo-location-card a {
  padding: 6px 0;
  font-size: 0.9rem;
}


/* WhatsApp Original Button */
.whatsapp-float {
  position: fixed;
  width: 60px;
  height: 60px;
  bottom: 20px;
  right: 20px;
  background-color: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 25px rgba(0,0,0,0.25);
  z-index: 9999;
  animation: pulse 2s infinite;
}

.whatsapp-float img {
  width: 32px;
  height: 32px;
}

.whatsapp-float:hover {
  transform: scale(1.1);
}

@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.6); }
  70% { box-shadow: 0 0 0 15px rgba(37, 211, 102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}



/* WhatsApp Datenschutz Hinweis */
.whatsapp-privacy-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(12, 47, 38, 0.62);
}

.whatsapp-privacy-modal.is-visible {
  display: flex;
}

.whatsapp-privacy-box {
  width: min(100%, 520px);
  background: #ffffff;
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 20px 50px rgba(0,0,0,.28);
  border-left: 6px solid #25D366;
}

.whatsapp-privacy-box h3 {
  margin: 0 0 12px;
  color: #17362b;
  font-size: 1.45rem;
}

.whatsapp-privacy-box p {
  margin: 0 0 14px;
  color: #4f5a55;
  line-height: 1.65;
}

.whatsapp-privacy-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 20px;
}

.whatsapp-privacy-accept,
.whatsapp-privacy-cancel {
  border: 0;
  border-radius: 999px;
  padding: 12px 18px;
  font-weight: 800;
  cursor: pointer;
}

.whatsapp-privacy-accept {
  background: #25D366;
  color: #ffffff;
}

.whatsapp-privacy-accept:hover {
  background: #1ebe5d;
}

.whatsapp-privacy-cancel {
  background: #e9eee8;
  color: #17362b;
}

.whatsapp-privacy-cancel:hover {
  background: #dce5dc;
}



/* Angebot anfordern */
.angebot-section {
  background: #f5f3ee;
  padding: 84px 20px;
}

.angebot-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 34px;
  align-items: stretch;
}

.angebot-content,
.angebot-form-card {
  background: #ffffff;
  border-radius: 28px;
  padding: 34px;
  box-shadow: 0 16px 38px rgba(0,0,0,.08);
  border: 1px solid rgba(47,109,88,.1);
}

.angebot-content {
  background:
    radial-gradient(circle at top left, rgba(47,109,88,.13), transparent 36%),
    #ffffff;
}

.angebot-badge {
  display: inline-block;
  margin-bottom: 14px;
  padding: 7px 13px;
  border-radius: 999px;
  background: #e9eee8;
  color: #214d40;
  font-size: .88rem;
  font-weight: 800;
}

.angebot-content h2 {
  margin: 0 0 14px;
  color: #17362b;
  font-size: clamp(1.9rem, 3vw, 2.7rem);
  line-height: 1.1;
}

.angebot-content p {
  color: #4f5a55;
  line-height: 1.75;
  margin-bottom: 22px;
}

.angebot-vorteile {
  display: grid;
  gap: 10px;
  margin: 24px 0;
}

.angebot-vorteile div {
  background: #f5f3ee;
  border-radius: 16px;
  padding: 13px 14px;
  color: #4f5a55;
}

.angebot-vorteile strong {
  color: #2f6d58;
  margin-right: 8px;
}

.angebot-form-card form {
  display: grid;
  gap: 14px;
}

.angebot-form-card input,
.angebot-form-card select,
.angebot-form-card textarea {
  width: 100%;
  border: 1px solid rgba(47,109,88,.18);
  border-radius: 14px;
  padding: 13px 14px;
  font: inherit;
  background: #fff;
}

.angebot-form-card textarea {
  min-height: 130px;
}

.angebot-form-card input[type="submit"],
.angebot-form-card button[type="submit"],
.angebot-form-card .wpcf7-submit {
  background: #2f6d58;
  color: #ffffff;
  border: 0;
  cursor: pointer;
  font-weight: 800;
  border-radius: 999px;
  padding: 14px 20px;
}

.angebot-form-card input[type="submit"]:hover,
.angebot-form-card button[type="submit"]:hover,
.angebot-form-card .wpcf7-submit:hover {
  background: #214d40;
}

.angebot-placeholder {
  border: 2px dashed rgba(47,109,88,.25);
  border-radius: 22px;
  padding: 26px;
  background: #f5f3ee;
}

.angebot-placeholder h3 {
  color: #17362b;
  margin-top: 0;
}

.angebot-whatsapp {
  display: inline-flex;
}

@media (max-width: 920px) {
  .angebot-grid {
    grid-template-columns: 1fr;
  }

  .angebot-section {
    padding: 60px 16px;
  }

  .angebot-content,
  .angebot-form-card {
    padding: 26px 22px;
    border-radius: 22px;
  }
}

/* Schwebender Angebot-Button */
.angebot-float {
  position: fixed;
  right: 22px;
  bottom: 94px;
  z-index: 9998;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #2f6d58;
  color: #ffffff;
  padding: 13px 17px;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 14px 34px rgba(0,0,0,.24);
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease;
}

.angebot-float:hover {
  background: #214d40;
  color: #ffffff;
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(0,0,0,.3);
}

.angebot-float span {
  font-size: 1.15rem;
}

.angebot-modal-section {
  position: fixed;
  inset: 0;
  z-index: 9997;
  display: none;
  overflow-y: auto;
  background: rgba(15, 51, 41, .72);
  padding: 40px 20px;
}

.angebot-modal-section.is-visible {
  display: block;
}

.angebot-modal-section .angebot-grid {
  position: relative;
  max-width: 1180px;
  margin: 40px auto;
}

.angebot-close {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 10001;
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 999px;
  background: #ffffff;
  color: #17362b;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(0,0,0,.2);
}

.angebot-close:hover {
  background: #e9eee8;
}

body.angebot-open {
  overflow: hidden;
}

@media (max-width: 640px) {
  .angebot-float {
    right: 16px;
    bottom: 84px;
    padding: 12px 15px;
  }

  .angebot-float strong {
    display: none;
  }

  .angebot-modal-section {
    padding: 26px 14px;
  }

  .angebot-close {
    top: 14px;
    right: 14px;
  }
}



/* SEO Startseiten-Text */
.seo-home-text {
  background: #f5f3ee;
  padding: 56px 20px 24px;
}
.seo-home-card {
  max-width: 980px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 26px;
  padding: 30px 34px;
  box-shadow: 0 12px 30px rgba(0,0,0,.07);
  border-left: 5px solid #2f6d58;
}
.seo-home-card h2 {
  color: #17362b;
  margin: 0 0 14px;
  font-size: clamp(1.55rem, 2.7vw, 2.2rem);
}
.seo-home-card p {
  color: #4f5a55;
  line-height: 1.75;
}

/* SEO-Ortsseiten */
.simple-page {
  padding: 80px 0;
  background: #f5f3ee;
}
.simple-page .entry {
  max-width: 940px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 26px;
  padding: 34px 38px;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  border-left: 5px solid #2f6d58;
}
.simple-page .entry h1,
.simple-page .entry h2 {
  color: #17362b;
}
.simple-page .entry p,
.simple-page .entry li {
  color: #4f5a55;
  line-height: 1.7;
}
.simple-page .entry a {
  color: #2f6d58;
  font-weight: 700;
}
.footer-seo-boost {
  max-width: 900px;
  margin: 28px auto 0;
  color: rgba(255,255,255,.72);
  line-height: 1.7;
  text-align: center;
  font-size: .95rem;
}




/* SEO-Ortsseiten 400-700 Wörter */
.simple-page {
  padding: 80px 0;
  background: #f5f3ee;
}
.simple-page .entry {
  max-width: 940px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 26px;
  padding: 34px 38px;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  border-left: 5px solid #2f6d58;
}
.simple-page .entry h1,
.simple-page .entry h2 {
  color: #17362b;
}
.simple-page .entry p,
.simple-page .entry li {
  color: #4f5a55;
  line-height: 1.75;
}
.simple-page .entry a {
  color: #2f6d58;
  font-weight: 700;
}







/* Kombinierte Google Bewertungen */
.combined-reviews {
  background: #f5f3ee;
  padding: 82px 20px;
}

.combined-reviews .section-head {
  text-align: center;
  max-width: 850px;
  margin: 0 auto 38px;
}

.bewertung-badge {
  display: inline-block;
  background: #e9eee8;
  color: #214d40;
  border-radius: 999px;
  padding: 7px 14px;
  font-size: .9rem;
  font-weight: 800;
  margin-bottom: 12px;
}

.combined-reviews h2 {
  color: #17362b;
  margin: 0 0 12px;
  font-size: clamp(2rem, 3vw, 3rem);
}

.combined-reviews .section-head p {
  color: #4f5a55;
  line-height: 1.7;
  margin: 0;
}

.bewertung-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  max-width: 1140px;
  margin: 0 auto;
}

.bewertung-card {
  background: #f2f0eb;
  border-radius: 24px;
  padding: 30px;
  min-height: 210px;
  box-shadow: 0 14px 34px rgba(0,0,0,.06);
  border: 1px solid rgba(47,109,88,.1);
}

.bewertung-card .sterne {
  color: #f5a623;
  font-size: 1.15rem;
  letter-spacing: 2px;
  margin-bottom: 18px;
}

.bewertung-card p {
  color: #4f5a55;
  line-height: 1.7;
  margin: 0 0 20px;
}

.bewertung-card strong {
  color: #17362b;
}

.google-live-reviews {
  max-width: 1140px;
  margin: 30px auto 0;
  background: #ffffff;
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 14px 34px rgba(0,0,0,.06);
  border: 1px solid rgba(47,109,88,.1);
}

.bewertung-cta {
  text-align: center;
  margin-top: 30px;
}

@media (max-width: 920px) {
  .bewertung-grid {
    grid-template-columns: 1fr;
  }

  .combined-reviews {
    padding: 60px 16px;
  }
}

/* Unsere Arbeiten unter Leistungen - final sauber */
.service-images {
  padding: 70px 20px;
  background: #f5f3ee;
}

.service-images h2 {
  max-width: 1180px;
  margin: 0 auto 28px;
  color: #17362b;
  font-size: clamp(1.8rem, 3vw, 2.5rem);
}

.service-images .grid {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.service-images .work-item {
  overflow: hidden;
  background: #ffffff;
  border-radius: 24px;
  box-shadow: 0 16px 34px rgba(0,0,0,.08);
  border: 1px solid rgba(47,109,88,.1);
  text-align: center;
  transition: transform .22s ease, box-shadow .22s ease;
}

.service-images .work-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 42px rgba(0,0,0,.12);
}

.service-images .work-item img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.service-images .work-text {
  min-height: 145px;
  padding: 22px 22px 24px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.service-images .work-text h3 {
  margin: 0 0 10px;
  color: #17362b;
  font-size: 1.25rem;
  line-height: 1.25;
}

.service-images .work-text p {
  margin: 0 auto;
  max-width: 280px;
  color: #5b665f;
  line-height: 1.55;
}

@media (max-width: 920px) {
  .service-images .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .service-images {
    padding: 54px 16px;
  }

  .service-images .grid {
    grid-template-columns: 1fr;
  }

  .service-images .work-item img {
    height: 220px;
  }

  .service-images .work-text {
    min-height: auto;
  }
}

/* FAQ Bereich im Website-Design */
.faq-polished {
  background: #f5f3ee;
  padding: 76px 20px;
}

.faq-card {
  max-width: 1120px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 28px;
  padding: 36px;
  box-shadow: 0 16px 38px rgba(0,0,0,.08);
  border-left: 6px solid #2f6d58;
}

.faq-badge {
  display: inline-block;
  margin-bottom: 12px;
  padding: 7px 14px;
  border-radius: 999px;
  background: #e9eee8;
  color: #214d40;
  font-size: .9rem;
  font-weight: 800;
}

.faq-card h2 {
  margin: 0 0 26px;
  color: #17362b;
  font-size: clamp(1.9rem, 3vw, 2.7rem);
  line-height: 1.15;
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.faq-item {
  background: #f5f3ee;
  border-radius: 20px;
  padding: 24px;
  border: 1px solid rgba(47,109,88,.08);
}

.faq-item h3 {
  margin: 0 0 12px;
  color: #17362b;
  font-size: 1.08rem;
  line-height: 1.35;
}

.faq-item p {
  margin: 0;
  color: #5b665f;
  line-height: 1.65;
}

@media (max-width: 920px) {
  .faq-grid {
    grid-template-columns: 1fr;
  }

  .faq-card {
    padding: 28px 22px;
    border-radius: 22px;
  }
}


/* REFINED PROFESSIONAL TOUCH */

/* better spacing */
section {
  padding: 90px 20px;
}

/* cleaner typography */
h1,h2,h3 {
  letter-spacing: -0.03em;
}

/* unify containers */
.container {
  max-width: 1200px;
  margin: 0 auto;
}

/* softer shadows */
.service-card,
.service-images .work-item,
.faq-card,
.bewertung-card {
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
  border-radius: 24px;
}

/* subtle hover */
.service-images .work-item:hover,
.service-card:hover {
  transform: translateY(-4px);
  transition: 0.2s ease;
}

/* better image proportions */
.service-images .work-item img {
  height: 230px;
  object-fit: cover;
}

/* FAQ cleaner spacing */
.faq-item {
  padding: 22px;
}

/* buttons cleaner */
.btn, button {
  border-radius: 999px;
  font-weight: 700;
  padding: 12px 24px;
}

/* Conversion Boost */
.mini-trust {
  max-width: 920px;
  margin: 18px auto 0;
  padding: 10px 18px;
  text-align: center;
  color: #4f5a55;
  background: #ffffff;
  border-radius: 999px;
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  font-size: .95rem;
}

.conversion-cta-box {
  max-width: 980px;
  margin: -26px auto 70px;
  padding: 30px 34px;
  background: linear-gradient(135deg, #17362b, #214d40);
  color: #ffffff;
  border-radius: 28px;
  text-align: center;
  box-shadow: 0 18px 42px rgba(0,0,0,.14);
}

.conversion-cta-box p {
  margin: 0 0 18px;
  font-size: clamp(1.25rem, 2.2vw, 1.8rem);
  font-weight: 800;
  line-height: 1.25;
}

.conversion-cta-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}













@media (max-width: 640px) {
  .mini-trust {
    margin: 14px 16px 0;
    border-radius: 18px;
    line-height: 1.5;
  }

  .conversion-cta-box {
    margin: -16px 16px 54px;
    padding: 26px 20px;
    border-radius: 22px;
  }

  .conversion-cta-actions {
    flex-direction: column;
  }

  

  
}


/* Angebot Anchor Fix */
.angebot-anchor {
  display: block;
  position: relative;
  top: -90px;
  visibility: hidden;
}



/* Angebot Ziel Fix */
.angebot-target {
  display: block;
  height: 0;
  overflow: hidden;
  scroll-margin-top: 120px;
}

.angebot-direct-section {
  background: #f5f3ee;
  padding: 70px 20px;
}

.angebot-direct-card {
  max-width: 920px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 28px;
  padding: 34px;
  text-align: center;
  box-shadow: 0 16px 38px rgba(0,0,0,.08);
  border-left: 6px solid #2f6d58;
}

.angebot-direct-card h2 {
  margin: 0 0 12px;
  color: #17362b;
}

.angebot-direct-card p {
  color: #4f5a55;
  line-height: 1.7;
}

.angebot-direct-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
}



/* Kontakt Sprungziel */
#kontakt {
  scroll-margin-top: 100px;
}


/* Button Komplett Sauber */
.conversion-sticky-offer { display: none !important; }

.conversion-btn,
.conversion-btn.primary,
.conversion-btn-primary {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  border-radius: 999px !important;
  z-index: 2 !important;
}

.conversion-btn::before,
.conversion-btn::after,
.conversion-btn-primary::before,
.conversion-btn-primary::after {
  content: none !important;
  display: none !important;
}

/* Rechtlicher Hinweis Design stabil */
.legal-notice-section,
.legal-section,
.rechtlicher-hinweis-section {
  overflow: visible !important;
}

.legal-notice-card,
.legal-box,
.rechtlicher-hinweis,
.notice-box {
  overflow: visible !important;
  box-sizing: border-box !important;
}

.legal-notice-card p,
.legal-box p,
.rechtlicher-hinweis p,
.notice-box p {
  line-height: 1.75;
  margin-bottom: 18px;
}


/* Kontaktbereich Premium Final */
#kontakt {
  background: #f5f3ee !important;
  padding: 86px 20px !important;
}

#kontakt > .container,
#kontakt .container {
  width: min(1120px, calc(100% - 40px)) !important;
  max-width: 1120px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

#kontakt h2,
#kontakt .contact-title {
  color: #17362b !important;
  font-size: clamp(2.2rem, 4vw, 3.4rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.04em !important;
  margin-bottom: 16px !important;
}

#kontakt > .container > p,
#kontakt .contact-intro {
  max-width: 640px !important;
  color: #4f5a55 !important;
  line-height: 1.75 !important;
  margin-bottom: 28px !important;
}

#kontakt .contact-form-wrapper {
  max-width: 760px !important;
  width: 100% !important;
  margin: 28px 0 34px !important;
  background: #ffffff !important;
  border-radius: 28px !important;
  padding: 34px 36px !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.08) !important;
  border-left: 6px solid #2f6d58 !important;
  box-sizing: border-box !important;
}

#kontakt .contact-form-title,
#kontakt .contact-form-wrapper h3 {
  margin: 0 0 22px !important;
  color: #17362b !important;
  font-size: 1.45rem !important;
  line-height: 1.25 !important;
}

#kontakt .contact-form-wrapper label,
#kontakt .wpcf7 label {
  display: block !important;
  margin: 0 0 7px !important;
  color: #17362b !important;
  font-weight: 800 !important;
  font-size: .95rem !important;
}

#kontakt .contact-form-wrapper p,
#kontakt .wpcf7 p {
  margin: 0 0 17px !important;
}

#kontakt input[type="text"],
#kontakt input[type="email"],
#kontakt input[type="tel"],
#kontakt textarea,
#kontakt select {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 48px !important;
  box-sizing: border-box !important;
  padding: 13px 15px !important;
  border: 1px solid rgba(47,109,88,.18) !important;
  border-radius: 14px !important;
  background: #f7f5f0 !important;
  color: #17362b !important;
  font-size: 1rem !important;
  outline: none !important;
}

#kontakt textarea {
  min-height: 135px !important;
  resize: vertical !important;
}

#kontakt input:focus,
#kontakt textarea:focus,
#kontakt select:focus {
  border-color: #2f6d58 !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 4px rgba(47,109,88,.10) !important;
}

#kontakt input[type="checkbox"] {
  width: auto !important;
  min-height: auto !important;
  accent-color: #2f6d58 !important;
}

#kontakt .wpcf7-list-item {
  margin: 0 !important;
}

#kontakt input[type="submit"],
#kontakt .wpcf7-submit {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 190px !important;
  min-height: 52px !important;
  padding: 14px 28px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #2f8a67, #2f6d58) !important;
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 1rem !important;
  cursor: pointer !important;
  box-shadow: 0 12px 28px rgba(47,109,88,.28) !important;
}

#kontakt input[type="submit"]:hover,
#kontakt .wpcf7-submit:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 18px 38px rgba(47,109,88,.36) !important;
}

#kontakt .contact-card,
#kontakt .kontakt-card,
#kontakt .contact-info-card,
#kontakt .info-card {
  background: #ffffff !important;
  border-radius: 22px !important;
  padding: 24px !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.07) !important;
  border: 1px solid rgba(47,109,88,.08) !important;
}

#kontakt .contact-card h3,
#kontakt .kontakt-card h3,
#kontakt .info-card h3 {
  color: #17362b !important;
  margin-bottom: 10px !important;
}

#kontakt .contact-card p,
#kontakt .kontakt-card p,
#kontakt .info-card p {
  color: #4f5a55 !important;
  line-height: 1.6 !important;
}

#kontakt .wpcf7-not-valid-tip {
  margin-top: 6px !important;
  color: #b42318 !important;
  font-size: .9rem !important;
}

#kontakt .wpcf7-response-output {
  margin: 18px 0 0 !important;
  padding: 14px 16px !important;
  border-radius: 14px !important;
  border-color: rgba(47,109,88,.25) !important;
}

@media (max-width: 720px) {
  #kontakt {
    padding: 64px 16px !important;
  }

  #kontakt > .container,
  #kontakt .container {
    width: 100% !important;
  }

  #kontakt .contact-form-wrapper {
    padding: 28px 20px !important;
    border-radius: 22px !important;
  }

  #kontakt input[type="submit"],
  #kontakt .wpcf7-submit {
    width: 100% !important;
  }
}


/* Kontaktpanel wiederhergestellt */
#kontakt .contact-form-wrapper {
  max-width: 760px !important;
  width: 100% !important;
  margin: 28px 0 34px !important;
  background: #ffffff !important;
  border-radius: 28px !important;
  padding: 34px 36px !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.08) !important;
  border-left: 6px solid #2f6d58 !important;
  box-sizing: border-box !important;
}

#kontakt .contact-form-title {
  margin: 0 0 22px !important;
  color: #17362b !important;
  font-size: 1.45rem !important;
  line-height: 1.25 !important;
}

#kontakt .contact-form-wrapper input[type="text"],
#kontakt .contact-form-wrapper input[type="email"],
#kontakt .contact-form-wrapper input[type="tel"],
#kontakt .contact-form-wrapper textarea,
#kontakt .contact-form-wrapper select {
  width: 100% !important;
  box-sizing: border-box !important;
  min-height: 48px !important;
  padding: 13px 15px !important;
  border: 1px solid rgba(47,109,88,.18) !important;
  border-radius: 14px !important;
  background: #f7f5f0 !important;
  color: #17362b !important;
}

#kontakt .contact-form-wrapper textarea {
  min-height: 135px !important;
}

#kontakt .contact-form-wrapper input[type="submit"],
#kontakt .contact-form-wrapper .wpcf7-submit {
  min-width: 190px !important;
  min-height: 52px !important;
  padding: 14px 28px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #2f8a67, #2f6d58) !important;
  color: #ffffff !important;
  font-weight: 900 !important;
  cursor: pointer !important;
}

@media (max-width: 720px) {
  #kontakt .contact-form-wrapper {
    padding: 28px 20px !important;
    border-radius: 22px !important;
  }
}


/* Kontakt Customizer Final Fix */
#kontakt .contact-form-box.contact-form-clean {
  background: #ffffff !important;
  border-radius: 24px !important;
  padding: 30px !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.08) !important;
  border-left: 6px solid #2f6d58 !important;
}

#kontakt .contact-form-box.contact-form-clean:empty {
  display: none !important;
}

#kontakt .cf7-shortcode,
#kontakt .contact-form-box > strong {
  display: none !important;
}

#kontakt .wpcf7 p {
  margin: 0 0 16px !important;
}

#kontakt .wpcf7 label {
  display: block !important;
  color: #17362b !important;
  font-weight: 800 !important;
  margin-bottom: 7px !important;
}

#kontakt .wpcf7 input[type="text"],
#kontakt .wpcf7 input[type="email"],
#kontakt .wpcf7 input[type="tel"],
#kontakt .wpcf7 textarea,
#kontakt .wpcf7 select {
  width: 100% !important;
  min-height: 48px !important;
  box-sizing: border-box !important;
  padding: 13px 15px !important;
  border: 1px solid rgba(47,109,88,.18) !important;
  border-radius: 14px !important;
  background: #f7f5f0 !important;
  color: #17362b !important;
}

#kontakt .wpcf7 textarea {
  min-height: 135px !important;
}

#kontakt .wpcf7-submit,
#kontakt input[type="submit"] {
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #2f8a67, #2f6d58) !important;
  color: #fff !important;
  font-weight: 900 !important;
  padding: 14px 28px !important;
  min-height: 52px !important;
  cursor: pointer !important;
}


/* CTA Buttons wiederhergestellt */
.conversion-cta-box {
  text-align: center !important;
}

.conversion-cta-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 14px !important;
  margin-top: 18px !important;
}

.conversion-btn,
.conversion-btn-primary,
.conversion-btn-whatsapp {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 52px !important;
  padding: 14px 26px !important;
  border-radius: 999px !important;
  font-weight: 900 !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  text-decoration: none !important;
  border: 0 !important;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease !important;
}

.conversion-btn-primary {
  background: #ffffff !important;
  color: #17362b !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.18) !important;
}

.conversion-btn-whatsapp {
  background: rgba(255,255,255,.14) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.28) !important;
}

.conversion-btn:hover,
.conversion-btn-primary:hover,
.conversion-btn-whatsapp:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 18px 38px rgba(0,0,0,.22) !important;
}

.conversion-btn::before,
.conversion-btn::after,
.conversion-btn-primary::before,
.conversion-btn-primary::after,
.conversion-btn-whatsapp::before,
.conversion-btn-whatsapp::after {
  content: none !important;
  display: none !important;
}

@media (max-width: 640px) {
  .conversion-cta-actions {
    flex-direction: column !important;
  }

  .conversion-btn,
  .conversion-btn-primary,
  .conversion-btn-whatsapp {
    width: 100% !important;
    max-width: 320px !important;
  }
}


/* SEO Text Design Fix */
.seo-local-section {
  background: #f5f3ee !important;
  padding: 52px 20px 24px !important;
}

.seo-local-section .container {
  width: min(960px, calc(100% - 40px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.seo-local-card {
  background: #ffffff !important;
  border-radius: 28px !important;
  padding: 34px 38px !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.07) !important;
  border-left: 6px solid #2f6d58 !important;
}

.seo-local-card .seo-badge {
  display: inline-block !important;
  margin-bottom: 12px !important;
  padding: 7px 14px !important;
  border-radius: 999px !important;
  background: #e9eee8 !important;
  color: #214d40 !important;
  font-size: .9rem !important;
  font-weight: 800 !important;
}

.seo-local-card h2 {
  margin: 0 0 16px !important;
  color: #17362b !important;
  font-size: clamp(1.8rem, 3vw, 2.45rem) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.035em !important;
}

.seo-local-card p {
  margin: 0 0 14px !important;
  color: #4f5a55 !important;
  line-height: 1.75 !important;
  font-size: 1rem !important;
}

.seo-local-card p:last-child {
  margin-bottom: 0 !important;
  font-weight: 700 !important;
  color: #17362b !important;
}

@media (max-width: 640px) {
  .seo-local-section {
    padding: 42px 16px 18px !important;
  }

  .seo-local-section .container {
    width: 100% !important;
  }

  .seo-local-card {
    padding: 28px 22px !important;
    border-radius: 22px !important;
  }
}


/* Google Reviews Design Final */
.google-bewertungen,
.combined-reviews {
  background: #f5f3ee !important;
  padding: 86px 20px !important;
}

.google-bewertungen .container,
.combined-reviews .container {
  width: min(1120px, calc(100% - 40px)) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
}

.google-bewertungen .section-head,
.combined-reviews .section-head {
  text-align: center !important;
  max-width: 860px !important;
  margin: 0 auto 34px !important;
}

.google-bewertungen .bewertung-badge,
.combined-reviews .bewertung-badge {
  display: inline-block !important;
  padding: 8px 16px !important;
  border-radius: 999px !important;
  background: #e9eee8 !important;
  color: #214d40 !important;
  font-weight: 900 !important;
  font-size: .95rem !important;
  margin-bottom: 14px !important;
}

.google-bewertungen h2,
.combined-reviews h2 {
  margin: 0 0 14px !important;
  color: #17362b !important;
  font-size: clamp(2.2rem, 4vw, 3.5rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.045em !important;
}

.google-bewertungen .section-head p,
.combined-reviews .section-head p {
  color: #4f5a55 !important;
  font-size: 1.05rem !important;
  line-height: 1.65 !important;
  margin: 0 !important;
}

/* Plugin-Einbettung */
.google-reviews-plugin-wrap {
  max-width: 980px !important;
  margin: 36px auto 0 !important;
  background: #ffffff !important;
  border-radius: 30px !important;
  padding: 30px !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.08) !important;
  border: 1px solid rgba(47,109,88,.08) !important;
  overflow: hidden !important;
}

/* Viele Google-Review-Plugins erzeugen eigene Karten: nur sanft angleichen */
.google-reviews-plugin-wrap iframe,
.google-reviews-plugin-wrap > div {
  max-width: 100% !important;
}

.google-reviews-plugin-wrap .ti-widget,
.google-reviews-plugin-wrap .ti-widget-container,
.google-reviews-plugin-wrap .trustindex-widget,
.google-reviews-plugin-wrap .wp-google-reviews {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Fallback-Bewertungen */
.bewertung-grid.reviews-static {
  margin-top: 36px !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

.bewertung-card {
  background: #ffffff !important;
  border-radius: 24px !important;
  padding: 30px !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.07) !important;
  border: 1px solid rgba(47,109,88,.08) !important;
}

/* Button */
.bewertungen-button-wrap {
  text-align: center !important;
  margin-top: 34px !important;
}

.google-review-button,
.bewertungen-button-wrap .btn-primary {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 52px !important;
  padding: 14px 28px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #2f8a67, #2f6d58) !important;
  color: #ffffff !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  box-shadow: 0 14px 30px rgba(47,109,88,.28) !important;
  border: 0 !important;
  transition: transform .2s ease, box-shadow .2s ease !important;
}

.google-review-button:hover,
.bewertungen-button-wrap .btn-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 18px 40px rgba(47,109,88,.36) !important;
}

@media (max-width: 900px) {
  .bewertung-grid.reviews-static {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .google-bewertungen,
  .combined-reviews {
    padding: 64px 16px !important;
  }

  .google-bewertungen .container,
  .combined-reviews .container {
    width: 100% !important;
  }

  .google-reviews-plugin-wrap {
    padding: 18px !important;
    border-radius: 22px !important;
  }

  .google-review-button,
  .bewertungen-button-wrap .btn-primary {
    width: 100% !important;
    max-width: 320px !important;
  }
}



/* Bewertungen mittig + sauber */
.google-reviews-plugin-wrap,
.reviews-static {
  display: flex !important;
  justify-content: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;
}

.google-reviews-plugin-wrap > *,
.reviews-static > * {
  margin: 0 auto !important;
}

/* Karten schöner zentriert */
.reviews-static {
  max-width: 900px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Optional: gleichmäßige Kartenbreite */
.reviews-static .bewertung-card {
  max-width: 280px;
}



/* Begrenzung für saubere Optik */
.ablauf-bild img {
  max-height: 420px;
}

/* Mobile */
@media (max-width: 768px) {
  .ablauf-bild img {
    max-height: 300px;
  }
}


/* Ablauf Bild Layout Final */
.ablauf-section .container,
#ablauf .container {
  max-width: 1080px !important;
}

/* Der Ablaufbereich bekommt ein ruhiges Layout, damit breite Infografiken lesbar bleiben */
.ablauf-section .process-grid,
#ablauf .process-grid,
.ablauf-section .ablauf-grid,
#ablauf .ablauf-grid,
.ablauf-section .steps-grid,
#ablauf .steps-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 28px !important;
  align-items: start !important;
}

/* Bildkarte nicht mehr klein rechts quetschen */
.ablauf-section .image-panel,
#ablauf .image-panel,
.ablauf-section .ablauf-bild,
#ablauf .ablauf-bild,
.ablauf-section .process-image,
#ablauf .process-image,
.ablauf-section .steps-image,
#ablauf .steps-image {
  width: 100% !important;
  max-width: 760px !important;
  margin: 26px auto 0 !important;
  padding: 12px !important;
  background: #ffffff !important;
  border-radius: 28px !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.08) !important;
  overflow: visible !important;
}

/* Infografik komplett anzeigen, keine Beschneidung */
.ablauf-section .image-panel img,
#ablauf .image-panel img,
.ablauf-section .ablauf-bild img,
#ablauf .ablauf-bild img,
.ablauf-section .process-image img,
#ablauf .process-image img,
.ablauf-section .steps-image img,
#ablauf .steps-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  border-radius: 20px !important;
}

/* Die Schritt-Karten bleiben sauber oben */
.ablauf-section .steps,
#ablauf .steps,
.ablauf-section .process-steps,
#ablauf .process-steps {
  max-width: 760px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Mobile */
@media (max-width: 768px) {
  .ablauf-section .image-panel,
  #ablauf .image-panel,
  .ablauf-section .ablauf-bild,
  #ablauf .ablauf-bild,
  .ablauf-section .process-image,
  #ablauf .process-image,
  .ablauf-section .steps-image,
  #ablauf .steps-image {
    max-width: 100% !important;
    padding: 8px !important;
    border-radius: 22px !important;
  }

  .ablauf-section .image-panel img,
  #ablauf .image-panel img,
  .ablauf-section .ablauf-bild img,
  #ablauf .ablauf-bild img,
  .ablauf-section .process-image img,
  #ablauf .process-image img,
  .ablauf-section .steps-image img,
  #ablauf .steps-image img {
    border-radius: 16px !important;
  }
}


/* Ablauf nur Bild (repariert) */
/* Wichtig: Schritte werden nur ausgeblendet, PHP bleibt unverändert */
#ablauf .steps,
#ablauf .process-steps,
#ablauf .ablauf-steps,
#ablauf .step-list,
#ablauf .timeline,
.ablauf-section .steps,
.ablauf-section .process-steps,
.ablauf-section .ablauf-steps,
.ablauf-section .step-list,
.ablauf-section .timeline {
  display: none !important;
}

/* einzelne Step-Karten ausblenden, falls sie nicht in einem Wrapper liegen */
#ablauf .step,
#ablauf .process-step,
#ablauf .ablauf-step,
.ablauf-section .step,
.ablauf-section .process-step,
.ablauf-section .ablauf-step {
  display: none !important;
}

/* Bild groß, mittig und vollständig sichtbar */
#ablauf .image-panel,
#ablauf .ablauf-bild,
#ablauf .process-image,
#ablauf .steps-image,
.ablauf-section .image-panel,
.ablauf-section .ablauf-bild,
.ablauf-section .process-image,
.ablauf-section .steps-image {
  width: 100% !important;
  max-width: 820px !important;
  margin: 40px auto 0 !important;
  padding: 12px !important;
  background: #ffffff !important;
  border-radius: 28px !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.08) !important;
  overflow: visible !important;
}

#ablauf .image-panel img,
#ablauf .ablauf-bild img,
#ablauf .process-image img,
#ablauf .steps-image img,
.ablauf-section .image-panel img,
.ablauf-section .ablauf-bild img,
.ablauf-section .process-image img,
.ablauf-section .steps-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  border-radius: 20px !important;
}

@media (max-width: 768px) {
  #ablauf .image-panel,
  #ablauf .ablauf-bild,
  #ablauf .process-image,
  #ablauf .steps-image,
  .ablauf-section .image-panel,
  .ablauf-section .ablauf-bild,
  .ablauf-section .process-image,
  .ablauf-section .steps-image {
    max-width: 100% !important;
    padding: 8px !important;
    border-radius: 22px !important;
  }
}



/* Ablauf Bereich schöner gestalten */
#ablauf .section-head {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 30px;
}

#ablauf .section-head span {
  display: inline-block;
  background: #e9eee8;
  color: #214d40;
  padding: 6px 14px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.9rem;
  margin-bottom: 12px;
}

#ablauf h2 {
  font-size: 2.8rem;
  margin-bottom: 10px;
}

#ablauf p {
  color: #5b6661;
  font-size: 1.05rem;
  max-width: 600px;
  margin: 0 auto;
}


/* Complete Local SEO Version */
.regional-seo-links {
  background: linear-gradient(135deg, #123c31, #0e3329) !important;
  color: #ffffff !important;
  padding: 86px 20px !important;
}

.regional-seo-links .section-head {
  text-align: center !important;
  max-width: 920px !important;
  margin: 0 auto 34px !important;
}

.regional-seo-links h2 {
  color: #ffffff !important;
  font-size: clamp(2rem, 3vw, 3rem) !important;
  margin: 0 0 12px !important;
}

.regional-seo-links p {
  color: rgba(255,255,255,.78) !important;
}

.regional-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
}

.regional-card {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 22px !important;
  padding: 24px !important;
}

.regional-card h3 {
  color: #ffffff !important;
  margin: 0 0 14px !important;
}

.regional-card ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.regional-card li {
  border-top: 1px solid rgba(255,255,255,.10) !important;
}

.regional-card li:first-child {
  border-top: 0 !important;
}

.regional-card a {
  display: block !important;
  padding: 9px 0 !important;
  color: rgba(255,255,255,.88) !important;
  text-decoration: none !important;
  font-weight: 700 !important;
}

.regional-card a:hover {
  color: #ffffff !important;
  transform: translateX(3px) !important;
}

.regional-seo-copy {
  max-width: 900px !important;
  margin: 28px auto 0 !important;
  text-align: center !important;
}

.seo-page-hero {
  background: linear-gradient(135deg, #123c31, #0e3329) !important;
  padding: 90px 20px !important;
  color: #ffffff !important;
}

.seo-page-hero .container {
  max-width: 920px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.seo-badge {
  display: inline-block !important;
  padding: 8px 16px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.13) !important;
  color: #ffffff !important;
  font-weight: 900 !important;
  margin-bottom: 16px !important;
}

.seo-page-hero h1 {
  color: #ffffff !important;
  font-size: clamp(2.4rem, 5vw, 4.2rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.05em !important;
  margin: 0 0 18px !important;
}

.seo-page-hero p {
  color: rgba(255,255,255,.86) !important;
  font-size: 1.15rem !important;
  line-height: 1.7 !important;
  margin: 0 auto 28px !important;
  max-width: 760px !important;
}

.seo-page-actions {
  display: flex !important;
  justify-content: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

.seo-page-content {
  background: #f5f3ee !important;
  padding: 76px 20px !important;
}

.seo-page-grid {
  max-width: 1120px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 320px !important;
  gap: 26px !important;
}

.seo-page-card,
.sidebar-card {
  background: #ffffff !important;
  border-radius: 26px !important;
  padding: 34px !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.08) !important;
}

.seo-page-card {
  border-left: 6px solid #2f6d58 !important;
}

.seo-page-card h2 {
  color: #17362b !important;
  margin: 0 0 16px !important;
  font-size: clamp(1.7rem, 3vw, 2.4rem) !important;
}

.seo-page-card p {
  color: #4f5a55 !important;
  line-height: 1.75 !important;
  margin: 0 0 18px !important;
}

.seo-check-list,
.sidebar-card ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.seo-check-list li,
.sidebar-card li {
  padding: 10px 0 !important;
  border-top: 1px solid rgba(47,109,88,.10) !important;
  color: #4f5a55 !important;
}

.seo-check-list li:before {
  content: "✓ ";
  color: #2f6d58;
  font-weight: 900;
}

.sidebar-card {
  margin-bottom: 20px !important;
}

.sidebar-card h3 {
  color: #17362b !important;
  margin: 0 0 14px !important;
}

.internal-links a {
  color: #2f6d58 !important;
  text-decoration: none !important;
  font-weight: 800 !important;
}

.seo-page-cta {
  background: #f5f3ee !important;
  padding: 0 20px 76px !important;
}

@media (max-width: 900px) {
  .regional-grid,
  .seo-page-grid {
    grid-template-columns: 1fr !important;
  }
}


/* Eigene Kontaktseite */
.kontakt-page-section {
  padding-top: 110px;
  padding-bottom: 80px;
}

/* Kontaktseite Modern Premium */
body.page-template-default #kontakt.kontakt-page-modern,
#kontakt.kontakt-page-modern {
  position: relative !important;
  overflow: hidden !important;
  min-height: calc(100vh - 90px) !important;
  padding: 92px 20px 104px !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(47,138,103,.18), transparent 30%),
    radial-gradient(circle at 92% 10%, rgba(23,54,43,.12), transparent 34%),
    linear-gradient(135deg, #f8f6f0 0%, #eeebe3 100%) !important;
}

.kontakt-page-modern .kontakt-bg-shape {
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  filter: blur(1px);
  opacity: .75;
}

.kontakt-page-modern .kontakt-bg-shape-one {
  width: 360px;
  height: 360px;
  left: -150px;
  top: 120px;
  background: rgba(47,109,88,.10);
}

.kontakt-page-modern .kontakt-bg-shape-two {
  width: 480px;
  height: 480px;
  right: -210px;
  bottom: -180px;
  background: rgba(47,138,103,.14);
}

.kontakt-modern-wrap {
  position: relative !important;
  z-index: 1 !important;
  max-width: 1180px !important;
}

.kontakt-modern-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, .85fr) !important;
  gap: 44px !important;
  align-items: center !important;
  margin-bottom: 40px !important;
}

.kontakt-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  margin-bottom: 18px !important;
  padding: 9px 16px !important;
  border-radius: 999px !important;
  background: rgba(47,109,88,.10) !important;
  color: #2f6d58 !important;
  font-weight: 900 !important;
  letter-spacing: .02em !important;
}

#kontakt.kontakt-page-modern h1 {
  max-width: 720px !important;
  margin: 0 0 18px !important;
  color: #17362b !important;
  font-size: clamp(2.6rem, 6vw, 5.4rem) !important;
  line-height: .92 !important;
  letter-spacing: -.07em !important;
}

.kontakt-modern-copy p {
  max-width: 660px !important;
  margin: 0 !important;
  color: #4f5a55 !important;
  font-size: clamp(1.05rem, 1.7vw, 1.28rem) !important;
  line-height: 1.75 !important;
}

.kontakt-quick-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 28px !important;
}

.kontakt-action {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 50px !important;
  padding: 13px 22px !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #17362b !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.07) !important;
  border: 1px solid rgba(47,109,88,.10) !important;
}

.kontakt-action-primary {
  background: linear-gradient(135deg, #2f8a67, #2f6d58) !important;
  color: #fff !important;
  box-shadow: 0 16px 34px rgba(47,109,88,.28) !important;
}

.kontakt-portrait-card {
  position: relative !important;
  justify-self: end !important;
  width: min(100%, 420px) !important;
  padding: 12px !important;
  border-radius: 34px !important;
  background: rgba(255,255,255,.82) !important;
  box-shadow: 0 30px 70px rgba(23,54,43,.16) !important;
  backdrop-filter: blur(10px) !important;
}

.kontakt-portrait-card img {
  display: block !important;
  width: 100% !important;
  height: 430px !important;
  object-fit: cover !important;
  border-radius: 26px !important;
}

.kontakt-portrait-badge {
  position: absolute !important;
  left: 28px !important;
  right: 28px !important;
  bottom: 28px !important;
  padding: 16px 18px !important;
  border-radius: 22px !important;
  background: rgba(255,255,255,.90) !important;
  box-shadow: 0 16px 34px rgba(0,0,0,.13) !important;
}

.kontakt-portrait-badge strong,
.kontakt-portrait-badge span {
  display: block !important;
}
.kontakt-portrait-badge strong { color: #17362b !important; font-size: 1rem !important; }
.kontakt-portrait-badge span { color: #4f5a55 !important; margin-top: 3px !important; }

.kontakt-main-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, .85fr) !important;
  gap: 24px !important;
  align-items: start !important;
}

#kontakt .contact-form-box.contact-form-clean.kontakt-modern-form {
  margin: 0 !important;
  padding: clamp(26px, 4vw, 44px) !important;
  border: 1px solid rgba(47,109,88,.10) !important;
  border-left: 0 !important;
  border-radius: 34px !important;
  background: rgba(255,255,255,.86) !important;
  box-shadow: 0 26px 64px rgba(23,54,43,.11) !important;
  backdrop-filter: blur(10px) !important;
}

.kontakt-form-head {
  margin-bottom: 24px !important;
}
.kontakt-form-head span {
  display: block !important;
  color: #2f6d58 !important;
  font-weight: 900 !important;
  margin-bottom: 8px !important;
}
.kontakt-form-head h2 {
  margin: 0 !important;
  color: #17362b !important;
  font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
  letter-spacing: -.04em !important;
  line-height: 1.05 !important;
}

.kontakt-info-column {
  display: grid !important;
  gap: 14px !important;
  position: sticky !important;
  top: 96px !important;
}

#kontakt .kontakt-info-card {
  display: grid !important;
  grid-template-columns: 46px 1fr !important;
  gap: 14px !important;
  align-items: center !important;
  padding: 20px !important;
  border-radius: 26px !important;
  background: rgba(255,255,255,.82) !important;
  border: 1px solid rgba(47,109,88,.10) !important;
  box-shadow: 0 16px 36px rgba(23,54,43,.08) !important;
}

#kontakt .kontakt-info-card.featured {
  background: linear-gradient(135deg, #ffffff, #f2f6f1) !important;
}

#kontakt .kontakt-icon {
  width: 46px !important;
  height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 16px !important;
  background: rgba(47,109,88,.10) !important;
  color: #2f6d58 !important;
  font-weight: 900 !important;
}

#kontakt .kontakt-info-card h3 {
  margin: 0 0 4px !important;
  color: #17362b !important;
  font-size: .98rem !important;
}
#kontakt .kontakt-info-card p {
  margin: 0 !important;
  color: #4f5a55 !important;
  line-height: 1.55 !important;
}
#kontakt .kontakt-info-card a {
  color: inherit !important;
  text-decoration: none !important;
}
#kontakt .kontakt-info-card a:hover { color: #2f6d58 !important; }

#kontakt.kontakt-page-modern .wpcf7 input[type="text"],
#kontakt.kontakt-page-modern .wpcf7 input[type="email"],
#kontakt.kontakt-page-modern .wpcf7 input[type="tel"],
#kontakt.kontakt-page-modern .wpcf7 textarea,
#kontakt.kontakt-page-modern .wpcf7 select {
  border-radius: 16px !important;
  background: #f8f6f0 !important;
  border-color: rgba(23,54,43,.13) !important;
}

#kontakt.kontakt-page-modern .wpcf7-submit,
#kontakt.kontakt-page-modern input[type="submit"] {
  width: auto !important;
  min-width: 210px !important;
  box-shadow: 0 16px 34px rgba(47,109,88,.25) !important;
}

@media (max-width: 920px) {
  .kontakt-modern-hero,
  .kontakt-main-layout {
    grid-template-columns: 1fr !important;
  }
  .kontakt-portrait-card {
    justify-self: stretch !important;
    width: 100% !important;
  }
  .kontakt-portrait-card img {
    height: 340px !important;
  }
  .kontakt-info-column {
    position: static !important;
    grid-template-columns: 1fr 1fr !important;
  }
  #kontakt .kontakt-info-card.full {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 620px) {
  #kontakt.kontakt-page-modern {
    padding: 62px 16px 72px !important;
  }
  .kontakt-quick-actions,
  .kontakt-action,
  #kontakt.kontakt-page-modern .wpcf7-submit,
  #kontakt.kontakt-page-modern input[type="submit"] {
    width: 100% !important;
  }
  .kontakt-info-column {
    grid-template-columns: 1fr !important;
  }
  .kontakt-portrait-card img {
    height: 300px !important;
  }
  .kontakt-portrait-badge {
    left: 20px !important;
    right: 20px !important;
    bottom: 20px !important;
  }
  #kontakt .kontakt-info-card {
    grid-template-columns: 42px 1fr !important;
    padding: 18px !important;
  }
}

/* Kontaktseite Design-Final: passt zur Startseite und erzwingt volles Layout */
body:has(#kontakt.kontakt-page-modern) {
  background: #f5f3ee !important;
}

#content:has(#kontakt.kontakt-page-modern),
.site-main:has(#kontakt.kontakt-page-modern),
main:has(#kontakt.kontakt-page-modern) {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#kontakt.kontakt-page-modern {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: clamp(72px, 7vw, 112px) 24px 96px !important;
  background:
    radial-gradient(circle at 8% 14%, rgba(47,109,88,.14), transparent 28%),
    radial-gradient(circle at 92% 7%, rgba(47,138,103,.10), transparent 32%),
    linear-gradient(180deg, #f8f6f0 0%, #f1eee7 100%) !important;
}

#kontakt.kontakt-page-modern .kontakt-modern-wrap {
  width: min(1180px, calc(100vw - 48px)) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

#kontakt.kontakt-page-modern .kontakt-modern-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, .8fr) !important;
  gap: clamp(28px, 5vw, 64px) !important;
  align-items: center !important;
  margin: 0 0 38px !important;
}

#kontakt.kontakt-page-modern .kontakt-eyebrow {
  background: #e7eee8 !important;
  color: #2f6d58 !important;
  box-shadow: inset 0 0 0 1px rgba(47,109,88,.10) !important;
}

#kontakt.kontakt-page-modern h1 {
  font-size: clamp(2.7rem, 5.2vw, 5.2rem) !important;
  line-height: .94 !important;
  letter-spacing: -.065em !important;
  color: #17362b !important;
}

#kontakt.kontakt-page-modern .kontakt-modern-copy p {
  max-width: 650px !important;
  font-size: clamp(1.05rem, 1.35vw, 1.22rem) !important;
  color: #4f5a55 !important;
}

#kontakt.kontakt-page-modern .kontakt-portrait-card {
  width: min(100%, 410px) !important;
  justify-self: end !important;
  padding: 12px !important;
  border-radius: 34px !important;
  background: rgba(255,255,255,.9) !important;
  box-shadow: 0 26px 65px rgba(23,54,43,.16) !important;
}

#kontakt.kontakt-page-modern .kontakt-portrait-card img {
  width: 100% !important;
  height: 420px !important;
  object-fit: cover !important;
  border-radius: 26px !important;
}

#kontakt.kontakt-page-modern .kontakt-main-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.35fr) minmax(310px, .75fr) !important;
  gap: 24px !important;
  align-items: start !important;
}

#kontakt.kontakt-page-modern .kontakt-form-column,
#kontakt.kontakt-page-modern .kontakt-info-column {
  min-width: 0 !important;
}

#kontakt.kontakt-page-modern .contact-form-box.contact-form-clean.kontakt-modern-form {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(28px, 3.4vw, 46px) !important;
  border: 1px solid rgba(47,109,88,.10) !important;
  border-left: 6px solid #2f6d58 !important;
  border-radius: 32px !important;
  background: #ffffff !important;
  box-shadow: 0 22px 55px rgba(23,54,43,.11) !important;
}

#kontakt.kontakt-page-modern .kontakt-info-column {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  position: sticky !important;
  top: 100px !important;
}

#kontakt.kontakt-page-modern .kontakt-info-card {
  display: grid !important;
  grid-template-columns: 48px 1fr !important;
  gap: 14px !important;
  align-items: center !important;
  padding: 20px !important;
  border-radius: 24px !important;
  background: #ffffff !important;
  box-shadow: 0 14px 34px rgba(23,54,43,.08) !important;
}

#kontakt.kontakt-page-modern .wpcf7 input[type="text"],
#kontakt.kontakt-page-modern .wpcf7 input[type="email"],
#kontakt.kontakt-page-modern .wpcf7 input[type="tel"],
#kontakt.kontakt-page-modern .wpcf7 textarea,
#kontakt.kontakt-page-modern .wpcf7 select {
  min-height: 50px !important;
  border-radius: 14px !important;
  background: #f7f5f0 !important;
}

@media (max-width: 980px) {
  #kontakt.kontakt-page-modern .kontakt-modern-hero,
  #kontakt.kontakt-page-modern .kontakt-main-layout {
    grid-template-columns: 1fr !important;
  }
  #kontakt.kontakt-page-modern .kontakt-portrait-card {
    justify-self: stretch !important;
    width: 100% !important;
  }
  #kontakt.kontakt-page-modern .kontakt-portrait-card img {
    height: 360px !important;
  }
  #kontakt.kontakt-page-modern .kontakt-info-column {
    position: static !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  #kontakt.kontakt-page-modern .kontakt-info-card.full {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 640px) {
  #kontakt.kontakt-page-modern {
    padding: 58px 16px 72px !important;
  }
  #kontakt.kontakt-page-modern .kontakt-modern-wrap {
    width: 100% !important;
  }
  #kontakt.kontakt-page-modern .kontakt-info-column {
    grid-template-columns: 1fr !important;
  }
  #kontakt.kontakt-page-modern .kontakt-portrait-card img {
    height: 300px !important;
  }
}

/* SEO-Seiten Premium-Optimierung */
.seo-service-page-premium {
  background: #f5f3ee !important;
}

.seo-service-page-premium .seo-page-hero {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.16), transparent 30%),
    radial-gradient(circle at 88% 10%, rgba(151,191,160,.22), transparent 34%),
    linear-gradient(135deg, #17362b 0%, #235643 55%, #123c31 100%) !important;
  padding: clamp(76px, 8vw, 122px) 20px !important;
}

.seo-service-page-premium .seo-hero-grid {
  max-width: 1180px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 340px !important;
  gap: clamp(28px, 5vw, 64px) !important;
  align-items: center !important;
  text-align: left !important;
}

.seo-service-page-premium .seo-hero-copy p {
  margin-left: 0 !important;
  max-width: 760px !important;
}

.seo-service-page-premium .seo-service-icon {
  width: 72px !important;
  height: 72px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 24px !important;
  margin: 0 0 18px !important;
  background: rgba(255,255,255,.14) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.14) !important;
  font-size: 2rem !important;
}

.seo-service-page-premium .seo-page-actions {
  justify-content: flex-start !important;
}

.seo-service-page-premium .seo-hero-card {
  padding: 28px !important;
  border-radius: 30px !important;
  background: rgba(255,255,255,.94) !important;
  color: #17362b !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.18) !important;
}

.seo-service-page-premium .seo-hero-card strong {
  display: block !important;
  font-size: 1.2rem !important;
  margin-bottom: 14px !important;
}

.seo-service-page-premium .seo-hero-card ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.seo-service-page-premium .seo-hero-card li {
  padding: 11px 0 !important;
  border-top: 1px solid rgba(47,109,88,.12) !important;
  color: #4f5a55 !important;
}

.seo-service-page-premium .seo-hero-card li:before,
.seo-service-page-premium .seo-process-card span {
  color: #2f6d58 !important;
}

.seo-service-page-premium .seo-hero-card li:before {
  content: "✓ " !important;
  font-weight: 900 !important;
}

.seo-service-page-premium .conversion-btn-light {
  background: #ffffff !important;
  color: #17362b !important;
  border: 1px solid rgba(23,54,43,.12) !important;
}

.seo-service-page-premium .seo-page-content,
.seo-service-page-premium .seo-page-cta {
  background: #f5f3ee !important;
}

.seo-service-page-premium .seo-page-card,
.seo-service-page-premium .sidebar-card,
.seo-service-page-premium .seo-area-card,
.seo-service-page-premium .seo-faq-item,
.seo-service-page-premium .seo-process-card {
  border: 1px solid rgba(47,109,88,.10) !important;
  box-shadow: 0 18px 46px rgba(23,54,43,.08) !important;
}

.seo-service-page-premium .seo-highlight-box {
  margin: 28px 0 !important;
  padding: 20px 22px !important;
  border-radius: 20px !important;
  background: #edf4ef !important;
  color: #17362b !important;
  border-left: 5px solid #2f6d58 !important;
}

.seo-service-page-premium .sidebar-contact-card p {
  color: #4f5a55 !important;
  line-height: 1.6 !important;
}

.seo-process-section,
.seo-area-section,
.seo-faq-section {
  background: #f5f3ee !important;
  padding: 0 20px 76px !important;
}

.seo-process-section .container,
.seo-area-section .container,
.seo-faq-section .container {
  max-width: 1120px !important;
  margin: 0 auto !important;
}

.section-head.compact {
  text-align: center !important;
  margin-bottom: 28px !important;
}

.section-head.compact h2 {
  color: #17362b !important;
  font-size: clamp(1.9rem, 3vw, 2.8rem) !important;
  margin-bottom: 8px !important;
}

.section-head.compact p {
  color: #63706a !important;
}

.seo-process-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.seo-process-card {
  background: #ffffff !important;
  border-radius: 24px !important;
  padding: 24px !important;
}

.seo-process-card span {
  display: inline-grid !important;
  place-items: center !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  background: #edf4ef !important;
  font-weight: 900 !important;
  margin-bottom: 14px !important;
}

.seo-process-card p {
  margin: 0 !important;
  color: #4f5a55 !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
}

.seo-area-card {
  background: #ffffff !important;
  border-radius: 30px !important;
  padding: clamp(28px, 4vw, 44px) !important;
  text-align: center !important;
}

.seo-area-card h2 {
  color: #17362b !important;
  margin: 0 0 8px !important;
}

.seo-area-card p {
  color: #63706a !important;
  margin: 0 0 22px !important;
}

.seo-area-tags {
  display: flex !important;
  justify-content: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.seo-area-tags span {
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: #edf4ef !important;
  color: #235643 !important;
  font-weight: 800 !important;
}

.seo-faq-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.seo-faq-item {
  background: #ffffff !important;
  border-radius: 22px !important;
  padding: 18px 20px !important;
}

.seo-faq-item summary {
  cursor: pointer !important;
  color: #17362b !important;
  font-weight: 900 !important;
}

.seo-faq-item p {
  color: #4f5a55 !important;
  line-height: 1.65 !important;
  margin: 12px 0 0 !important;
}

@media (max-width: 980px) {
  .seo-service-page-premium .seo-hero-grid,
  .seo-process-grid,
  .seo-faq-grid {
    grid-template-columns: 1fr !important;
  }
  .seo-service-page-premium .seo-hero-card {
    max-width: 520px !important;
  }
}

@media (max-width: 640px) {
  .seo-service-page-premium .seo-page-hero {
    padding: 64px 16px !important;
  }
  .seo-page-content,
  .seo-process-section,
  .seo-area-section,
  .seo-faq-section,
  .seo-page-cta {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .seo-page-card,
  .sidebar-card {
    padding: 24px !important;
    border-radius: 22px !important;
  }
}


/* SEO-Seiten Feinschliff: stärkere Hero-Zeile, Vertrauensbox und sichtbare FAQs */
.seo-service-page-premium .seo-trust-row {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  margin: 18px 0 4px !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.12) !important;
  color: #ffffff !important;
  font-weight: 800 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.16) !important;
}

.seo-service-page-premium .seo-why-box {
  margin: 32px 0 !important;
  padding: 26px !important;
  border-radius: 26px !important;
  background: linear-gradient(135deg, #edf4ef, #ffffff) !important;
  border: 1px solid rgba(47,109,88,.14) !important;
}

.seo-service-page-premium .seo-why-box h2 {
  margin-top: 0 !important;
}

.seo-service-page-premium .seo-why-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.seo-service-page-premium .seo-why-grid span {
  display: block !important;
  padding: 12px 14px !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  color: #17362b !important;
  font-weight: 800 !important;
  box-shadow: 0 10px 24px rgba(23,54,43,.06) !important;
}

.seo-service-page-premium .seo-faq-item[open] summary {
  margin-bottom: 8px !important;
}

@media (max-width: 640px) {
  .seo-service-page-premium .seo-why-grid {
    grid-template-columns: 1fr !important;
  }
  .seo-service-page-premium .seo-trust-row {
    border-radius: 18px !important;
  }
}

/* Finaler Conversion-Boost: Header-Telefon, Vertrauensleiste, interne Links & mobile Sticky-CTA */
.header-right { display:flex !important; align-items:center !important; gap:20px !important; }
.header-call { display:inline-flex !important; align-items:center !important; gap:8px !important; padding:10px 14px !important; border-radius:999px !important; background:#fff !important; color:#17362b !important; font-weight:900 !important; box-shadow:0 10px 24px rgba(0,0,0,.12) !important; white-space:nowrap !important; }
.header-call:hover { transform:translateY(-1px) !important; }
.seo-proof-strip { background:#f5f3ee !important; padding:28px 20px 0 !important; }
.seo-proof-grid { max-width:1120px !important; display:grid !important; grid-template-columns:repeat(3,minmax(0,1fr)) !important; gap:16px !important; }
.seo-proof-grid > div { background:#fff !important; border:1px solid rgba(47,109,88,.10) !important; border-radius:22px !important; padding:18px 20px !important; box-shadow:0 16px 40px rgba(23,54,43,.07) !important; }
.seo-proof-grid strong,.seo-proof-grid span { display:block !important; }
.seo-proof-grid strong { color:#17362b !important; font-size:1rem !important; margin-bottom:4px !important; }
.seo-proof-grid span { color:#5a655f !important; font-weight:700 !important; }
.seo-internal-text { padding:18px 20px !important; border-radius:20px !important; background:#f7faf8 !important; border:1px solid rgba(47,109,88,.12) !important; }
.seo-internal-text a { color:#2f6d58 !important; font-weight:900 !important; text-decoration:underline !important; text-underline-offset:3px !important; }
.mobile-sticky-cta { display:none !important; }
@media (max-width:920px){ .header-inner{align-items:flex-start !important;} .header-right{flex-direction:column !important; align-items:flex-end !important; gap:10px !important;} .header-call{font-size:.9rem !important; padding:8px 12px !important;} .seo-proof-grid{grid-template-columns:1fr !important;} }
@media (max-width:640px){ body{padding-bottom:78px !important;} .header-call{display:none !important;} .mobile-sticky-cta{position:fixed !important; left:12px !important; right:12px !important; bottom:12px !important; z-index:9999 !important; display:grid !important; grid-template-columns:1fr 1fr !important; gap:10px !important; padding:10px !important; border-radius:24px !important; background:rgba(255,255,255,.96) !important; box-shadow:0 18px 48px rgba(0,0,0,.18) !important; border:1px solid rgba(47,109,88,.12) !important; backdrop-filter:blur(12px) !important;} .mobile-sticky-cta a{display:flex !important; align-items:center !important; justify-content:center !important; min-height:48px !important; border-radius:16px !important; font-weight:900 !important; color:#fff !important;} .mobile-sticky-call{background:#17362b !important;} .mobile-sticky-whatsapp{background:#2f6d58 !important;} .seo-proof-strip{padding:18px 16px 0 !important;} }

/* Premium Header Fix v3 - sauberes Menü, separater Telefonbutton, responsive */
.site-header.premium-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 10000 !important;
  background: rgba(20, 54, 43, .78) !important;
  border-bottom: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.12) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}
.premium-header-inner {
  min-height: 76px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 28px !important;
  padding: 10px 0 !important;
}
.premium-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  color: #fff !important;
  min-width: 220px !important;
}
.premium-brand-mark {
  width: 42px !important;
  height: 42px !important;
  border-radius: 15px !important;
  display: grid !important;
  place-items: center !important;
  background: linear-gradient(135deg,#fff,#eaf4ed) !important;
  color: #17362b !important;
  font-weight: 950 !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.18) !important;
}
.premium-brand-text { display: flex !important; flex-direction: column !important; line-height: 1.12 !important; }
.premium-brand-text strong { font-size: 1.05rem !important; letter-spacing: -.02em !important; }
.premium-brand-text small { margin-top: 3px !important; font-size: .72rem !important; color: rgba(255,255,255,.76) !important; font-weight: 700 !important; }
.premium-nav { justify-self: center !important; min-width: 0 !important; }
.premium-nav-list {
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 6px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  max-width: 100% !important;
}
.premium-nav-list li { margin: 0 !important; padding: 0 !important; list-style: none !important; }
.premium-nav-list a {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 38px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  color: rgba(255,255,255,.92) !important;
  font-weight: 850 !important;
  font-size: .94rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  transition: background .18s ease, color .18s ease, transform .18s ease !important;
}
.premium-nav-list a:hover,
.premium-nav-list .current-menu-item > a,
.premium-nav-list .current_page_item > a {
  background: #fff !important;
  color: #17362b !important;
  transform: translateY(-1px) !important;
}
.premium-header-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  justify-content: flex-end !important;
}
.premium-call,
.premium-whatsapp {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 42px !important;
  border-radius: 999px !important;
  font-weight: 950 !important;
  white-space: nowrap !important;
  transition: transform .18s ease, box-shadow .18s ease !important;
}
.premium-call {
  padding: 0 16px !important;
  background: #fff !important;
  color: #17362b !important;
  box-shadow: 0 12px 30px rgba(0,0,0,.18) !important;
}
.premium-whatsapp {
  padding: 0 14px !important;
  background: #2f6d58 !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.18) !important;
}
.premium-call:hover,
.premium-whatsapp:hover { transform: translateY(-1px) !important; }

@media (max-width: 1180px) {
  .premium-header-inner { grid-template-columns: 1fr auto !important; gap: 14px !important; }
  .premium-nav { grid-column: 1 / -1 !important; justify-self: stretch !important; order: 3 !important; }
  .premium-nav-list { justify-content: flex-start !important; overflow-x: auto !important; scrollbar-width: none !important; border-radius: 18px !important; }
  .premium-nav-list::-webkit-scrollbar { display: none !important; }
}
@media (max-width: 760px) {
  .premium-header-inner { min-height: 66px !important; display: flex !important; justify-content: space-between !important; align-items: center !important; flex-wrap: wrap !important; }
  .premium-brand { min-width: 0 !important; }
  .premium-brand-text small { display: none !important; }
  .premium-brand-text strong { font-size: .98rem !important; }
  .premium-whatsapp { display: none !important; }
  .premium-call { display: none !important; }
  .premium-nav { flex: 0 0 100% !important; width: 100% !important; }
  .premium-nav-list { width: 100% !important; padding: 5px !important; gap: 4px !important; }
  .premium-nav-list a { min-height: 34px !important; padding: 0 11px !important; font-size: .86rem !important; }
}


/* Final Design Cleanup */
.premium-nav-list a[href*="/impressum"], .premium-nav-list a[href*="/datenschutz"], .premium-nav-list a[href*="/agb"], .premium-nav-list a[href^="tel:"], .premium-nav-list a[href*="wa.me"] { display:none !important; }
.angebot-placeholder-clean{min-height:260px!important;display:flex!important;flex-direction:column!important;align-items:flex-start!important;justify-content:center!important;gap:14px!important;padding:34px!important;border-radius:26px!important;background:linear-gradient(135deg,#f5faf7,#fff)!important;border:1px solid rgba(47,109,88,.14)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)!important;}
.angebot-placeholder-clean h3{margin:0!important;color:#17362b!important;font-size:1.45rem!important;}
.angebot-placeholder-clean p{margin:0!important;color:#53645d!important;line-height:1.65!important;}
.angebot-placeholder-clean .btn{margin-top:6px!important;}
.footer{padding:66px 0 46px!important;}
.footer-grid{gap:42px!important;}
.footer h3,.footer h4{margin-bottom:16px!important;}
.footer p,.footer li{line-height:1.7!important;}
.footer-legal{padding:18px 0!important;background:#10261f!important;}
.footer-legal .container{display:flex!important;justify-content:center!important;gap:22px!important;flex-wrap:wrap!important;}
@media(max-width:760px){.angebot-placeholder-clean{padding:24px!important;min-height:220px!important;}}

/* Header komplett neu gebaut - Backup-Regeln im Stylesheet */
.site-header.premium-header{display:none!important;}
.steins-premium-header ul,.steins-premium-header li{list-style:none!important;}
.steins-premium-header a{text-decoration:none!important;}


/* === Steins Header Final Perfect v4 === */
.steins-premium-header{
  position: sticky !important;
  top: 0 !important;
  z-index: 99999 !important;
  background: rgba(22, 52, 42, .92) !important;
  color: #fff !important;
  border-bottom: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 12px 34px rgba(0,0,0,.14) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}
.steins-premium-header *,
.steins-premium-header *::before,
.steins-premium-header *::after{box-sizing:border-box!important;}
.steins-premium-header .customize-partial-edit-shortcut{display:none!important;}
.steins-header-wrap{
  width:min(calc(100% - 40px),1180px)!important;
  margin:0 auto!important;
  min-height:72px!important;
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr) auto!important;
  gap:28px!important;
  align-items:center!important;
  padding:9px 0!important;
}
.steins-brand{display:inline-flex!important;align-items:center!important;gap:12px!important;color:#fff!important;text-decoration:none!important;min-width:235px!important;}
.steins-brand-logo{width:40px!important;height:40px!important;border-radius:14px!important;display:grid!important;place-items:center!important;background:#fff!important;color:#17362b!important;font-weight:950!important;font-size:1rem!important;line-height:1!important;box-shadow:0 8px 22px rgba(0,0,0,.16)!important;}
.steins-brand-copy{display:flex!important;flex-direction:column!important;line-height:1.08!important;min-width:0!important;}
.steins-brand-copy strong{font-size:1.02rem!important;font-weight:950!important;letter-spacing:-.025em!important;color:#fff!important;white-space:nowrap!important;}
.steins-brand-copy small{margin-top:4px!important;font-size:.71rem!important;font-weight:750!important;color:rgba(255,255,255,.74)!important;white-space:nowrap!important;}
.steins-main-nav{justify-self:center!important;min-width:0!important;max-width:100%!important;}
.steins-main-nav ul,.steins-main-nav li{list-style:none!important;margin:0!important;padding:0!important;}
.steins-main-nav ul{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:5px!important;padding:5px!important;border-radius:999px!important;background:rgba(255,255,255,.075)!important;border:1px solid rgba(255,255,255,.12)!important;max-width:100%!important;}
.steins-main-nav li{display:block!important;float:none!important;position:relative!important;}
.steins-main-nav a{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:36px!important;padding:0 15px!important;border-radius:999px!important;color:rgba(255,255,255,.93)!important;text-decoration:none!important;font-size:.90rem!important;font-weight:850!important;line-height:1!important;white-space:nowrap!important;transition:background .18s ease,color .18s ease,transform .18s ease!important;}
.steins-main-nav a:hover,.steins-main-nav .current-menu-item>a,.steins-main-nav .current_page_item>a{background:#fff!important;color:#17362b!important;transform:translateY(-1px)!important;}
.steins-main-nav a[href*="/impressum"],.steins-main-nav a[href*="/datenschutz"],.steins-main-nav a[href*="/agb"],.steins-main-nav a[href^="tel:"],.steins-main-nav a[href*="wa.me"]{display:none!important;}
.steins-header-actions{display:inline-flex!important;align-items:center!important;justify-content:flex-end!important;gap:10px!important;}
.steins-header-actions a{height:40px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;border-radius:999px!important;text-decoration:none!important;font-weight:950!important;white-space:nowrap!important;padding:0 16px!important;line-height:1!important;font-size:.93rem!important;transition:transform .18s ease,box-shadow .18s ease,background .18s ease!important;}
.steins-whatsapp{background:#2f6d58!important;color:#fff!important;border:1px solid rgba(255,255,255,.18)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)!important;}
.steins-call{background:#fff!important;color:#17362b!important;box-shadow:0 10px 24px rgba(0,0,0,.15)!important;}
.steins-header-actions a:hover{transform:translateY(-1px)!important;}
@media (max-width:1120px){
  .steins-header-wrap{grid-template-columns:1fr auto!important;gap:12px 16px!important;}
  .steins-main-nav{grid-column:1/-1!important;justify-self:stretch!important;order:3!important;}
  .steins-main-nav ul{justify-content:flex-start!important;overflow-x:auto!important;border-radius:18px!important;scrollbar-width:none!important;}
  .steins-main-nav ul::-webkit-scrollbar{display:none!important;}
}
@media (max-width:760px){
  .steins-header-wrap{width:min(calc(100% - 24px),1180px)!important;display:flex!important;flex-wrap:wrap!important;justify-content:space-between!important;align-items:center!important;min-height:64px!important;padding:8px 0!important;gap:10px!important;}
  .steins-brand{min-width:0!important;gap:10px!important;}
  .steins-brand-logo{width:38px!important;height:38px!important;border-radius:13px!important;}
  .steins-brand-copy strong{font-size:.98rem!important;}
  .steins-brand-copy small{display:none!important;}
  .steins-header-actions{display:none!important;}
  .steins-main-nav{flex:0 0 100%!important;width:100%!important;}
  .steins-main-nav ul{width:100%!important;padding:5px!important;gap:4px!important;justify-content:flex-start!important;}
  .steins-main-nav a{min-height:34px!important;padding:0 12px!important;font-size:.84rem!important;}
}

/* FINAL HEADER LOGO FIX */
.steins-premium-header{min-height:72px!important;background:rgba(22,52,42,.96)!important;}
.steins-brand-logo{width:44px!important;height:44px!important;min-width:44px!important;max-width:44px!important;border-radius:14px!important;overflow:hidden!important;background:#fff!important;padding:4px!important;display:flex!important;align-items:center!important;justify-content:center!important;}
.steins-brand-logo img{width:100%!important;height:100%!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important;display:block!important;}
.steins-main-nav a:before,.steins-main-nav a:after{display:none!important;content:none!important;}
.hero{background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;}
@media (max-width:760px){.steins-brand-logo{width:40px!important;height:40px!important;min-width:40px!important;max-width:40px!important}.steins-brand-copy small{display:none!important}}


/* === Header Final Korrektur: Brandname + einheitliche Navigation === */
.steins-brand{min-width:320px!important;}
.steins-brand-copy strong{font-size:1rem!important;}
.steins-main-nav a,
.steins-main-nav .current-menu-item > a,
.steins-main-nav .current_page_item > a,
.steins-main-nav .current-menu-ancestor > a{
  background:#fff!important;
  color:#17362b!important;
  transform:none!important;
}
.steins-main-nav a:hover{
  background:#eaf4ed!important;
  color:#17362b!important;
  transform:translateY(-1px)!important;
}
.steins-main-nav a::before,
.steins-main-nav a::after{display:none!important;content:none!important;}
@media (max-width:760px){
  .steins-brand{min-width:0!important;}
  .steins-brand-copy strong{font-size:.90rem!important;white-space:normal!important;}
}

/* Final: Header-Menü vollständig über WordPress bearbeitbar */
.steins-main-nav ul,.steins-main-nav .steins-menu{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:6px!important;padding:5px!important;margin:0!important;list-style:none!important;border-radius:999px!important;background:rgba(255,255,255,.075)!important;border:1px solid rgba(255,255,255,.12)!important;max-width:100%!important;overflow-x:auto!important;scrollbar-width:none!important;}
.steins-main-nav ul::-webkit-scrollbar,.steins-main-nav .steins-menu::-webkit-scrollbar{display:none!important;}
.steins-main-nav li{list-style:none!important;margin:0!important;padding:0!important;flex:0 0 auto!important;}
.steins-main-nav a,.steins-main-nav .current-menu-item>a,.steins-main-nav .current_page_item>a,.steins-main-nav .current-menu-ancestor>a{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:36px!important;padding:0 15px!important;border-radius:999px!important;background:#fff!important;color:#17362b!important;text-decoration:none!important;font-size:.90rem!important;font-weight:850!important;line-height:1!important;white-space:nowrap!important;}
.steins-main-nav a:hover{background:#eaf4ed!important;color:#17362b!important;transform:translateY(-1px)!important;box-shadow:0 8px 18px rgba(0,0,0,.12)!important;}
.steins-main-nav a[href*="/impressum"],.steins-main-nav a[href*="/datenschutz"],.steins-main-nav a[href*="/agb"],.steins-main-nav a[href^="tel:"],.steins-main-nav a[href*="wa.me"]{display:inline-flex!important;}
@media(max-width:1120px){.steins-main-nav ul,.steins-main-nav .steins-menu{justify-content:flex-start!important;border-radius:18px!important;}}
@media(max-width:760px){.steins-main-nav ul,.steins-main-nav .steins-menu{width:100%!important;justify-content:flex-start!important;gap:4px!important}.steins-main-nav a{min-height:34px!important;padding:0 12px!important;font-size:.84rem!important;}}

/* ===== Steins Clean Final v3 ===== */
.steins-premium-header .steins-main-nav a[href*="/impressum"],
.steins-premium-header .steins-main-nav a[href*="/datenschutz"],
.steins-premium-header .steins-main-nav a[href*="/agb"],
.steins-premium-header .steins-main-nav a[href^="tel:"],
.steins-premium-header .steins-main-nav a[href*="wa.me"] {
  display: none !important;
}

.steins-premium-header .steins-main-nav ul,
.steins-premium-header .steins-main-nav li {
  list-style: none !important;
}

.steins-premium-header .steins-main-nav li::marker {
  content: "" !important;
}

.steins-brand-logo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  display: block !important;
  border-radius: 12px !important;
}

.angebot-contact-card {
  border: 1px solid rgba(27, 94, 32, .12) !important;
  background: linear-gradient(180deg, #ffffff 0%, #f7faf8 100%) !important;
}

.angebot-mini-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(27, 94, 32, .09);
  color: #174a18;
  font-size: .78rem;
  font-weight: 800;
}

.angebot-contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.footer-legal .container {
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer-legal-menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 18px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-legal-menu li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-legal-menu a {
  color: inherit;
  text-decoration: none;
  opacity: .9;
}

.footer-legal-menu a:hover {
  opacity: 1;
  text-decoration: underline;
}

@media (max-width: 760px) {
  .angebot-contact-actions .btn {
    width: 100%;
    justify-content: center;
  }
}


/* === Premium Footer Final === */
.footer-premium{background:linear-gradient(135deg,#10261f 0%,#173b2f 52%,#10261f 100%)!important;color:#fff!important;padding:68px 0 24px!important;border-top:1px solid rgba(255,255,255,.08)!important}.footer-premium-grid{display:grid!important;grid-template-columns:minmax(280px,1.35fr) repeat(3,minmax(180px,.75fr))!important;gap:22px!important;align-items:stretch!important}.footer-premium h3,.footer-premium h4{color:#fff!important;margin:0 0 12px!important;line-height:1.2!important}.footer-premium h3{font-size:22px!important}.footer-premium h4{font-size:17px!important}.footer-brand-card,.footer-card{background:rgba(255,255,255,.065)!important;border:1px solid rgba(255,255,255,.11)!important;border-radius:22px!important;padding:24px!important;box-shadow:0 20px 50px rgba(0,0,0,.14)!important}.footer-brand-card{background:rgba(255,255,255,.09)!important}.footer-brand-top{display:flex!important;align-items:center!important;gap:14px!important;margin-bottom:18px!important}.footer-brand-logo{width:58px!important;height:58px!important;object-fit:contain!important;border-radius:16px!important;background:rgba(255,255,255,.9)!important;padding:6px!important;flex:0 0 auto!important}.footer-brand-subline,.footer-brand-text,.footer-premium p,.footer-premium address{color:rgba(255,255,255,.78)!important;font-style:normal!important;line-height:1.7!important;margin:0 0 14px!important}.footer-brand-subline{font-size:13px!important;margin:0!important}.footer-trust-pills{display:flex!important;flex-wrap:wrap!important;gap:8px!important;margin-top:18px!important}.footer-trust-pills span{display:inline-flex!important;align-items:center!important;border-radius:999px!important;padding:7px 11px!important;background:rgba(105,180,120,.18)!important;border:1px solid rgba(255,255,255,.12)!important;color:#fff!important;font-size:13px!important;font-weight:700!important}.footer-premium a{color:rgba(255,255,255,.88)!important;text-decoration:none!important;transition:transform .18s ease,background .18s ease,color .18s ease!important}.footer-premium a:hover{color:#fff!important;text-decoration:none!important}.footer-contact-card a,.footer-links-card a{display:flex!important;align-items:center!important;gap:8px!important;padding:9px 0!important;border-bottom:1px solid rgba(255,255,255,.09)!important}.footer-contact-card a:hover,.footer-links-card a:hover{transform:translateX(3px)!important}.footer-legal-menu-premium,.footer-legal-menu{list-style:none!important;margin:14px 0 0!important;padding:0!important;display:grid!important;gap:10px!important}.footer-legal-menu-premium li,.footer-legal-menu li{list-style:none!important;margin:0!important;padding:0!important}.footer-legal-menu-premium a,.footer-legal-menu a{display:flex!important;align-items:center!important;justify-content:space-between!important;width:100%!important;padding:11px 13px!important;border-radius:14px!important;background:rgba(255,255,255,.11)!important;color:#fff!important;font-weight:800!important;border:1px solid rgba(255,255,255,.13)!important}.footer-legal-menu-premium a::after,.footer-legal-menu a::after{content:"›"!important;font-size:18px!important;opacity:.75!important}.footer-legal-menu-premium a:hover,.footer-legal-menu a:hover{background:rgba(255,255,255,.18)!important;transform:translateY(-1px)!important}.footer-premium-bottom{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:18px!important;flex-wrap:wrap!important;margin-top:24px!important;padding-top:22px!important;border-top:1px solid rgba(255,255,255,.12)!important}.footer-premium-bottom p{margin:0!important;font-size:14px!important;color:rgba(255,255,255,.72)!important}.footer-bottom-legal{display:flex!important;align-items:center!important;gap:10px!important;flex-wrap:wrap!important;font-size:14px!important}.footer-bottom-legal a{color:rgba(255,255,255,.86)!important;font-weight:700!important}.footer-bottom-legal a:hover{color:#fff!important;text-decoration:underline!important}@media(max-width:1020px){.footer-premium-grid{grid-template-columns:1fr 1fr!important}}@media(max-width:680px){.footer-premium{padding:46px 0 86px!important}.footer-premium-grid{grid-template-columns:1fr!important}.footer-brand-top{align-items:flex-start!important}.footer-premium-bottom{justify-content:center!important;text-align:center!important}.footer-bottom-legal{justify-content:center!important}}

/* Finaler Footer Feinschliff */
.footer-premium-grid{gap:30px!important;}
.footer-brand-card,.footer-card{padding:30px!important;}
.footer-trust-pills::after{content:"⭐ 5.0 bei Google Bewertungen";display:inline-flex!important;align-items:center!important;border-radius:999px!important;padding:7px 11px!important;background:rgba(105,180,120,.18)!important;border:1px solid rgba(255,255,255,.12)!important;color:#fff!important;font-size:13px!important;font-weight:700!important;}
@media(max-width:680px){.footer-brand-card,.footer-card{padding:24px!important;}}

/* Schnelle Navigation: Anker springen sofort statt langsam zu scrollen */
html {
  scroll-behavior: auto !important;
}

/* fonts-safe-marker: Theme nutzt Systemschriften; keine externen Google Fonts. */
html, body, button, input, select, textarea {
  font-family: Arial, Helvetica, sans-serif !important;
}


/* Mülltonnenservice Startseiten-Highlight */
.muelltonnen-highlight-card{display:grid;grid-template-columns:90px 1fr;gap:24px;align-items:start;max-width:1050px;margin:32px auto 10px;padding:28px;border-radius:24px;background:linear-gradient(135deg,#f1f8f3,#ffffff);border:1px solid rgba(27,94,32,.12);box-shadow:0 16px 45px rgba(0,0,0,.08)}
.muelltonnen-highlight-icon{width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:20px;background:#1b5e20;color:#fff;font-size:34px;box-shadow:0 12px 25px rgba(27,94,32,.25)}
.muelltonnen-highlight-content h3{margin:8px 0 10px;font-size:clamp(1.35rem,2.4vw,2rem);color:#173c1d}.muelltonnen-highlight-content p{margin-bottom:14px;color:#415244;line-height:1.7}.muelltonnen-highlight-content ul{display:grid;gap:8px;margin:0 0 20px;padding:0;list-style:none}.muelltonnen-highlight-content li::before{content:'✓';color:#1b5e20;font-weight:800;margin-right:8px}.mini-badge{display:inline-flex;align-items:center;width:fit-content;padding:6px 12px;border-radius:999px;background:rgba(27,94,32,.1);color:#1b5e20;font-weight:800;font-size:.82rem;letter-spacing:.02em}@media(max-width:700px){.muelltonnen-highlight-card{grid-template-columns:1fr;padding:22px}}

/* Final Fix: Mülltonnenservice im Hero optisch wie die anderen Leistungsboxen */
.hero-points .point {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 22px;
  padding: 18px;
  color: #fff;
  backdrop-filter: blur(8px);
}
.hero-points .point strong {
  display: block;
  font-size: 1.08rem;
  line-height: 1.2;
  margin-bottom: 6px;
  color: #fff;
}

/* Version 3.0: lokaler WhatsApp-Floating-Button ohne externes Bild */
.whatsapp-float-icon{font-size:30px;line-height:1;color:#fff;display:inline-flex;align-items:center;justify-content:center;}


/* Version 3.1 Finale: Footer Links einheitlich und ruhig */
.footer-links-card nav a,
.footer-links-card nav a[href*="muelltonnenservice"] {
  font-weight: 400 !important;
  color: rgba(255,255,255,.88) !important;
}
.footer-links-card nav a:hover,
.footer-links-card nav a[href*="muelltonnenservice"]:hover {
  color: #fff !important;
}
.footer-links-card nav a {
  line-height: 1.35 !important;
}
