:root{
  --green-900:#0b2f1b;
  --green-800:#14532d;
  --green-700:#166534;
  --green-600:#1b7a3f;
  --green-050:#f4f7f5;
  --green-100:#eef4ea;
  --gold:#F4D03F;
  --gold-strong:#facc15;
  --text:#111827;
  --muted:#4b5563;
  --white:#ffffff;
  --line:rgba(17,24,39,.08);
  --shadow:0 14px 36px rgba(0,0,0,.08);
  --shadow-strong:0 22px 48px rgba(0,0,0,.12);
  --radius-xl:24px;
  --radius-lg:18px;
  --radius-md:14px;
  --page-max:1120px;
  --page-pad:16px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  color:var(--text);
  background:#fff;
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{text-decoration:none;}

.page-wrap,
.container{
  width:min(var(--page-max), calc(100% - 32px));
  margin:0 auto;
}

.section-head{
  margin-bottom:34px;
}
.section-head h2,
.intro-card-cleanout h2,
.benefit-left h2,
.tax-layout h2,
.faq-cta h3{
  margin:10px 0 14px;
  font-size:clamp(28px,3.2vw,42px);
  line-height:1.08;
  letter-spacing:-0.02em;
}
.section-head p,
.intro-card-cleanout p,
.benefit-left p,
.tax-layout p,
.case-card p,
.case-highlight p,
.faq-content p{
  color:var(--muted);
}

.section-label-cleanout{
  display:inline-block;
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--green-700);
}
.section-label-cleanout--gold{color:var(--gold);}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 22px;
  border-radius:12px;
  font-weight:700;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn--solid{
  background:var(--gold-strong);
  color:#111;
  box-shadow:0 10px 24px rgba(250,204,21,.28);
}
.btn--ghost{
  background:rgba(255,255,255,.12);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
}

/* =========================================
   HERO-INHALT UNTER ÜBERSCHRIFT
   wie auf Bild 2: zwei Boxen nebeneinander
   Überschrift bleibt oben stehen
========================================= */

/* =========================================
   HERO nur für Überschrift
========================================= */

.hero-split{
  padding: 0;
  background: #eef2f0;
  overflow: visible;
}

.hero-split__wrap{
  width: 100%;
  margin: 0;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 18px 55px rgba(0,0,0,0.10);
}

.hero-split__left{
  position: relative;
  color: #fff;
  background: linear-gradient(135deg, #1b7a3f, #0b2f1b);
}

.hero-split__left--headline-only{
  min-height: 320px;
  display: flex;
  align-items: center;
  padding-top: 56px;
  padding-bottom: 56px;
  padding-left: max(16px, calc((100vw - 1120px) / 2 + 16px));
  padding-right: 16px;
}

.hero-split__left--headline-only::after{
  content:"";
  position:absolute;
  top:0;
  right:-90px;
  width:190px;
  height:100%;
  background: linear-gradient(135deg, #1b7a3f, #0b2f1b);
  transform: skewX(-12deg);
  z-index: 1;
}

.hero-split__left--headline-only .nachlass-wrapper{
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 2;
}

.hero-split__title{
  margin: 0;
  font-size: clamp(40px, 6vw, 76px);
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  font-weight: 900;
  max-width: 820px;
}

.hero-subline{
  display: block;
  margin-top: 14px;
  font-size: clamp(20px, 2vw, 34px);
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: 0.02em;
  opacity: 0.98;
}

/* Abstand zwischen Hero und Box-Section */
.hero-info-section{
  margin-top: 0;
  position: relative;
  z-index: 3;
}

/* RESPONSIVE */
@media (max-width: 520px){
  .hero-split__wrap{
    overflow: hidden;
  }

  .hero-split__left--headline-only{
    min-height: auto;
    padding: 26px 16px 30px;
  }

  .hero-split__title{
    font-size: clamp(18px, 8vw, 34px);
    line-height: 1.02;
    letter-spacing: -0.02em;
    max-width: 100%;
    word-break: break-word;
    overflow-wrap: anywhere;  
  }

  

  .hero-subline{
    display: block;
    margin-top: 10px;
    font-size: clamp(12px, 3.8vw, 18px);
    line-height: 1.15;
    max-width: 100%;
    overflow-wrap: anywhere;
  }
}

@media (max-width: 520px){
  .hero-split__left--headline-only{
    min-height: 220px;
    padding: 28px 16px 34px;
  }

  .hero-split__left--headline-only::after{
    right: -35px;
    width: 90px;
    transform: skewX(-10deg);
  }

  .hero-split__title{
    font-size: clamp(28px, 9vw, 40px);
    line-height: 0.98;
  }

  .hero-subline{
    margin-top: 10px;
    font-size: clamp(14px, 4.3vw, 18px);
    line-height: 1.1;
  }
}

.hero-title-break{
  display:inline;
}

@media (max-width: 520px){
  .hero-title-break{
    display:block;
  }

  .hero-title-break::after{
    content:"-";
  }
}

/* Text + Leistungen nicht mehr frei im Hero verteilen */
.hero-split__left .hero-text,
.hero-split__left .hero-features,
.hero-split__left .hero-actions{
  display: none;
}
.hero-title-break,
.hero-title-rest,
.hero-title-dash{
  display:inline;
}

@media (max-width: 520px){
  .hero-title-break,
  .hero-title-rest{
    display:block;
  }

  .hero-title-break::after{
    content:"-";
  }

  .hero-title-dash{
    display:block;
  }

  .hero-split__title{
    font-size: clamp(28px, 9vw, 40px);
    line-height: 0.98;
    max-width: 100%;
    word-break: normal;
    overflow-wrap: normal;
  }
}

/* =========================================
   INFO-BOXEN UNTER DEM HERO
   näher an Bild 2
========================================= */

.hero-info-section{
  background: #f3f4f3;
  padding: 42px 0 34px;
}

.hero-info-wrap{
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 28px;
  align-items: stretch;
}

/* beide Kästchen moderner / softer */
.hero-info-text,
.hero-info-list{
  background: #f8f8f6;
  border-radius: 22px;
  padding: 28px 30px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

/* linke Box mit gelbem Akzent wie im 2. Bild */
.hero-info-text{
  position: relative;
  overflow: hidden;
}

.hero-info-text::before{
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 5px;
  border-radius: 999px;
  background: #facc15;
}

.hero-info-text p{
  margin: 0;
  font-size: 18px;
  line-height: 1.75;
  color: #111827;
  max-width: 28ch;
}

/* rechte Box grün wie Bild 2 */
.hero-info-list{
  position: relative;
  overflow: hidden;
  background: #f8f8f6;
  border-radius: 22px;
  padding: 28px 30px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.hero-info-list::before{
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 5px;
  border-radius: 999px;
  background: #1b7a3f;
}

.hero-info-list ul{
  list-style: none;
  margin: 0;
  padding: 0;
}

.hero-info-list li{
  position: relative;
  padding-left: 30px;
  margin-bottom: 14px;
  font-size: 17px;
  line-height: 1.5;
  color: #111827;
}

.hero-info-list li:last-child{
  margin-bottom: 0;
}

.hero-info-list li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 18px;
  font-weight: 800;
  color: #1b7a3f;
}

/* Buttons mittig */
.hero-info-actions{
  width: min(1120px, calc(100% - 32px));
  margin: 24px auto 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.hero-info-actions .btn,
.hero-info-actions .btn-outline{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 14px 28px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 800;
  font-size: 17px;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.hero-info-actions .btn{
  background: #facc15;
  color: #111827;
  box-shadow: 0 10px 24px rgba(250, 204, 21, 0.22);
}

.hero-info-actions .btn-outline{
  background: #2f6f3e;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 10px 24px rgba(22, 101, 52, 0.18);
}

.hero-info-actions .btn:hover,
.hero-info-actions .btn-outline:hover{
  transform: translateY(-2px);
}

/* responsive */
@media (max-width: 900px){
  .hero-info-wrap{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .hero-info-text,
  .hero-info-list{
    padding: 24px 20px;
    border-radius: 18px;
  }

  .hero-info-text p,
  .hero-info-list li{
    font-size: 16px;
  }

  .hero-info-text p{
    max-width: none;
  }
}

@media (max-width: 640px){
  .hero-info-section{
    padding: 28px 0 26px;
  }

  .hero-info-actions{
    flex-direction: column;
  }

  .hero-info-actions .btn,
  .hero-info-actions .btn-outline{
    width: 100%;
    max-width: 360px;
  }
}

/* =========================================
   SECTION ab "Was ist eine Entrümpelung?"
========================================= */

.intro-section-cleanout{
  background: #ffffff !important;
  padding-top: 78px;
  padding-bottom: 90px;
}

/* innerer Wrapper etwas tiefer */
.intro-section-cleanout .nachlass-container,
.intro-section-cleanout .container,
.intro-section-cleanout .content-wrap,
.intro-section-cleanout .cleanout-wrapper{
  padding-top: 10px;
}

/* Überschrift etwas weiter nach unten */
.intro-section-cleanout h2{
  margin-top: 14px;
}

/* Text luftiger */
.intro-section-cleanout p,
.intro-section-cleanout li{
  line-height: 1.7;
}

/* mehr Abstand zwischen Buttons und weißer Section */
.hero-info-section{
  padding-bottom: 44px;
}

/* SERVICES */

.service-section{padding:78px 0;background:#fff;}
.service-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.service-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:26px 22px;
  box-shadow:var(--shadow);
  transition:transform .22s ease, box-shadow .22s ease;
}
.service-card:hover,
.case-card:hover,
.tax-card:hover,
.price-card:hover,
.faq-item:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-strong);
}
.service-card--accent{
  background:linear-gradient(180deg, #f7fbf8, #eef4ea);
}
.service-icon{font-size:28px;margin-bottom:14px;}
.service-card h3{margin:0 0 8px;font-size:1.1rem;}
.service-card p{margin:0;color:var(--muted);}

/* BENEFITS */
.benefits-section{padding:80px 0;background:var(--green-050);}
.benefit-layout{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:24px;
  align-items:stretch;
}
.benefit-left{padding-right:16px;}
.trust-box{
  margin-top:24px;
  padding:20px 22px;
  border-radius:18px;
  background:#fff;
  border-left:5px solid var(--gold);
  box-shadow:var(--shadow);
}
.trust-box h3{margin:0 0 8px;}
.trust-box p{margin:0;}
.benefit-right{
  background:linear-gradient(180deg, var(--green-700), var(--green-900));
  color:#fff;
  border-radius:22px;
  padding:32px;
  box-shadow:var(--shadow);
}
.check-item + .check-item{margin-top:18px;}
.check-item strong{display:block;margin-bottom:5px;font-size:1rem;}
.check-item p{margin:0;color:rgba(255,255,255,.82);}

/* TIMELINE */
.timeline-section{padding:84px 0;background:#fff;}
.timeline-cleanout{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:28px;
  --line-x:22px;
}
.timeline-cleanout::before{
  content:"";
  position:absolute;
  left:var(--line-x);
  top:18px;
  bottom:18px;
  width:3px;
  background:#d1d5db;
}
.timeline-step{position:relative;padding-left:68px;}
.timeline-number{
  position:absolute;
  left:var(--line-x);
  top:0;
  transform:translateX(-50%);
  width:42px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--gold);
  font-weight:800;
  color:#111;
}
.timeline-step h3{margin:0 0 6px;font-size:1.08rem;}
.timeline-step p{margin:0;color:var(--muted);}

/* PRICING */
.pricing-cleanout{
  padding:88px 0;
  background:linear-gradient(180deg, var(--green-800), var(--green-900));
  color:#fff;
}
.section-head--light p{color:rgba(255,255,255,.82);}
.price-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:30px;
}
.price-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:24px;
}
.price-card h3{margin:0 0 10px;color:#fff;font-size:1.1rem;}
.price-value{margin:0;color:var(--gold);font-size:1.4rem;font-weight:800;}
.pricing-note{
  margin-top:24px;
  padding:18px 20px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}
.pricing-note p{margin:0;color:rgba(255,255,255,.88);}

/* CASES */
.cases-section{padding:84px 0;background:#fff;}
.cases-grid,
.tax-cards{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:18px;
}
.case-card,
.tax-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
}
.case-card h3,
.tax-card h3,
.case-highlight h3{margin:0 0 10px;font-size:1.1rem;}
.case-highlight-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
  margin-top:18px;
}
.case-highlight{
  padding:24px;
  border-radius:20px;
  background:var(--green-050);
  border:1px solid rgba(22,101,52,.10);
}
.case-highlight ul{margin:0;padding-left:18px;}
.case-highlight li{margin:7px 0;}
.case-highlight--green{
  background:linear-gradient(180deg, #edf6ef, #dff0e4);
}

.case-highlight-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: stretch;
}

.case-highlight{
  width: 100%;
  max-width: none;
  min-width: 0;
  box-sizing: border-box;
}

@media (max-width: 900px){
  .case-highlight-grid{
    grid-template-columns: 1fr;
  }
}

/* TAX */
.tax-section{padding:84px 0;background:var(--green-050);}
.tax-layout{display:grid;gap:26px;}
.tax-card ul{margin:12px 0 0;padding-left:18px;}
.tax-card li{margin:6px 0;color:var(--muted);}

/* FAQ */
.faq-section{padding:84px 0;background:#fff;}
.faq-list{display:grid;gap:14px;}
.faq-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:18px 20px;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"▾";
  opacity:.6;
  transition:transform .18s ease;
}
.faq-item[open] summary::after{transform:rotate(180deg);}
.faq-item[open] summary{border-bottom:1px solid var(--line);}
.faq-content{padding:0 20px 18px;}
.faq-content p{margin:0;}
.faq-cta{
  margin-top:28px;
  padding:30px;
  border-radius:22px;
  background:linear-gradient(135deg, var(--green-600), var(--green-900));
  color:#fff;
}
.faq-cta p{margin:0 0 18px;color:rgba(255,255,255,.85);}

/* MOBILE NAV STATE */
.mobile-nav{display:none;}
.mobile-nav.is-open{display:block;}

/* ================================
   MOBILE MENU BUTTON FIX
================================ */
.nav-toggle{
  display: none;
  width: 52px;
  height: 52px;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 14px;
  background: #fff;
  padding: 0;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 6px;
  appearance: none;
  -webkit-appearance: none;
}

.nav-toggle span{
  display: block;
  width: 22px;
  height: 2px;
  background: #111827;
  border-radius: 999px;
  margin: 0;
  flex: 0 0 auto;
}

/* CTA Buttons wie im Screenshot */
.hero-cleanout__actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:18px;
}

.hero-cleanout__actions .btn,
.hero-cleanout__actions .btn-outline{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:14px 24px;
  border-radius:14px;
  font-weight:800;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}

.hero-cleanout__actions .btn:hover,
.hero-cleanout__actions .btn-outline:hover{
  transform:translateY(-2px);
}

/* Gelber Button mit schwarzer Schrift */
.hero-cleanout__actions .btn{
  background:#facc15;
  color:#111827;
  border:1px solid #facc15;
  box-shadow:0 10px 24px rgba(250,204,21,.22);
}

/* Transparenter Button */
.hero-cleanout__actions .btn-outline{
  background:rgba(255,255,255,.10);
  color:#ffffff;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}

.hero-cleanout__actions .btn-outline:hover{
  background:rgba(255,255,255,.14);
}

.hero-cleanout__actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:18px;
}
@media (max-width:640px){
  .hero-cleanout__actions{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:14px;
  }

  .hero-cleanout__actions .btn,
  .hero-cleanout__actions .btn-outline{
    width:100%;
    max-width:320px;
    min-width:320px;
    min-height:56px;
    box-sizing:border-box;
    justify-content:center;
    text-align:center;
  }
}

@media (max-width:640px){
  .hero-cleanout__actions{
    flex-direction:column;
  }

  .hero-cleanout__actions .btn,
  .hero-cleanout__actions .btn-outline{
    width:100%;
    max-width:360px;
  }
}

/* mobil */
@media (max-width:640px){
  .hero-cleanout__actions{
    flex-direction:column;
  }

  .hero-cleanout__actions .btn,
  .hero-cleanout__actions .btn-outline{
    width:100%;
    max-width:360px;
  }
}

/* nur mobil anzeigen */
@media (max-width: 900px){
  .nav-toggle{
    display: flex;
  }

  .nav-links{
    display: none;
  }
}

/* RESPONSIVE */
@media (max-width: 1100px){
  .service-grid{grid-template-columns:repeat(2,1fr);}  
}

@media (max-width: 980px){
  .hero-cleanout__wrap,
  .intro-card-cleanout,
  .benefit-layout,
  .case-highlight-grid,
  .price-grid,
  .cases-grid,
  .tax-cards{
    grid-template-columns:1fr;
  }

  .hero-cleanout__left{
    padding-left:16px;
    padding-right:16px;
  }
  .hero-cleanout__left::after{display:none;}
  .hero-cleanout__right{min-height:280px;}
}

@media (max-width: 900px){
  .nav-links{display:none;}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;}
  .mobile-nav{padding:0 16px 16px;}
  .mobile-nav .nav-link{
    display:block;
    background:#fff;
    padding:12px 14px;
    margin-top:8px;
    border-radius:12px;
  }
}

@media (max-width: 768px){
  .page-wrap,
  .container{width:min(1120px, calc(100% - 24px));}

  .hero-cleanout__left{padding:34px 16px;}
  .hero-cleanout__title{font-size:clamp(26px, 8vw, 36px);}
  .hero-cleanout__text{font-size:1rem;}
  .hero-cleanout__chips span{font-size:13px;}
  .intro-card-cleanout{margin-top:-30px;padding:22px;}
  .service-grid{grid-template-columns:1fr;}
  .benefit-right,
  .faq-cta{padding:24px 18px;}
  .timeline-step{padding-left:56px;}
  .timeline-number{width:34px;height:34px;font-size:14px;}
  .timeline-cleanout{--line-x:18px;gap:22px;}
  .section-head h2,
  .intro-card-cleanout h2,
  .benefit-left h2,
  .tax-layout h2,
  .faq-cta h3{font-size:clamp(24px, 7vw, 32px);}  
}

@media (max-width: 520px){
  .hero-cleanout__wrap{display:block;min-height:auto;}
  .hero-cleanout__left{min-height:320px;}
  .hero-cleanout__right{display:none;}
  .hero-cleanout__actions .btn{width:100%;}
  .reason-box,
  .service-card,
  .case-card,
  .tax-card,
  .price-card{padding:20px 16px;}
  .faq-item summary{padding:16px;}
  .faq-content{padding:0 16px 16px;}
}



.tax-cards--three{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}

@media (max-width: 980px){
  .tax-cards--three{
    grid-template-columns:1fr;
  }
}