: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-estate 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-estate p,
.benefit-left p,
.tax-layout p,
.case-card p,
.case-highlight p,
.faq-content p{
  color:var(--muted);
}

.section-label-estate{
  display:inline-block;
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--green-700);
}
.section-label-estate--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 */
.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;
}

/* INFO BOXEN */
.hero-info-section{
  margin-top:0;
  position:relative;
  z-index:3;
  background:#f3f4f3;
  padding:42px 0 44px;
}

.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;
}

.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);
}

.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;
}

.hero-info-list{
  position:relative;
  overflow:hidden;
}

.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;
}

.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);
}

/* INTRO */
.intro-section-estate{
  background:#ffffff !important;
  padding-top:78px;
  padding-bottom:90px;
}

.intro-card-estate{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:start;
}

.intro-card-estate h2{
  margin-top:14px;
}

.intro-card-estate p,
.intro-card-estate li{
  line-height:1.7;
}

.reason-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
}
.reason-box h3{
  margin:0 0 10px;
}
.reason-box ul{
  margin:0;
  padding-left:18px;
}
.reason-box li{
  margin:7px 0;
  color:var(--muted);
}

.intro-card-estate{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:start;
}

.intro-card-estate .reason-box{
  margin-top: 44px; /* senkt den rechten Kasten auf Höhe der H2 */
}

@media (max-width: 980px){
  .intro-card-estate{
    grid-template-columns:1fr;
  }

  .intro-card-estate .reason-box{
    margin-top: 0;
  }
}

/* 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,
.extra-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-estate{
  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(2,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-card p,
.price-card li{color:rgba(255,255,255,.88);}
.price-card ul{margin:0;padding-left:18px;}
.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;
}
.tax-cards{
  grid-template-columns:repeat(3, 1fr);
}
.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:repeat(2, minmax(0, 1fr));
  gap:20px;
  margin-top:18px;
  align-items:stretch;
}
.case-highlight{
  padding:24px;
  border-radius:20px;
  background:var(--green-050);
  border:1px solid rgba(22,101,52,.10);
  width:100%;
  max-width:none;
  min-width:0;
  box-sizing:border-box;
}
.case-highlight ul{margin:0;padding-left:18px;}
.case-highlight li{margin:7px 0;}
.case-highlight--green{
  background:linear-gradient(180deg, #edf6ef, #dff0e4);
}

@media (max-width: 900px){
  .case-highlight-grid{
    grid-template-columns:1fr;
  }
}

/* =========================================
   SCHLICHTE ZUSATZLEISTUNGEN
========================================= */

.extra-section-simple{
  padding: 78px 0 54px;
  background: #fff;
}

.extra-list-simple{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
}

.extra-item-simple{
  padding: 16px 18px;
  background: #fff;
  border: 1px solid rgba(17,24,39,.08);
  border-radius: 14px;
  font-weight: 700;
  color: #111827;
  box-shadow: 0 8px 22px rgba(0,0,0,.04);
}

/* =========================================
   SPEZIELLE FÄLLE
========================================= */

.special-cases-section{
  padding: 54px 0 84px;
  background: #fff;
}

.special-cases-list{
  display: grid;
  gap: 22px;
}

.special-case-item{
  padding: 0;
  border: 0;
  background: transparent;
}

.special-case-item h3{
  margin: 0 0 4px;
  font-size: 1.05rem;
  line-height: 1.35;
  color: #111827;
  font-weight: 800;
}

.special-case-item p{
  margin: 0;
  color: #374151;
  line-height: 1.6;
  font-size: 1rem;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 768px){
  .extra-list-simple{
    grid-template-columns: 1fr;
  }

  .extra-section-simple{
    padding: 58px 0 40px;
  }

  .special-cases-section{
    padding: 40px 0 64px;
  }

  .extra-item-simple{
    padding: 15px 16px;
  }

  .special-case-item h3{
    font-size: 1rem;
  }

  .special-case-item p{
    font-size: 0.98rem;
  }
}

/* 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;
}

/* 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);}
  .extra-grid{grid-template-columns:repeat(2,1fr);}
}

@media (max-width: 980px){
  .intro-card-estate,
  .benefit-layout,
  .case-highlight-grid,
  .price-grid,
  .cases-grid,
  .tax-cards,
  .extra-grid,
  .hero-info-wrap{
    grid-template-columns:1fr;
  }
}

@media (max-width: 900px){
  .hero-split__left--headline-only{
    min-height:260px;
    padding-top:42px;
    padding-bottom:42px;
    padding-left:16px;
    padding-right:16px;
  }

  .hero-split__left--headline-only::after{
    right:-60px;
    width:130px;
    transform:skewX(-10deg);
  }

  .hero-split__title{
    font-size:clamp(32px, 7vw, 52px);
  }

  .hero-subline{
    font-size:clamp(16px, 3.4vw, 24px);
  }

  .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;
  }

  .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: 768px){
  .page-wrap,
  .container{width:min(1120px, calc(100% - 24px));}

  .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-estate h2,
  .benefit-left h2,
  .tax-layout h2,
  .faq-cta h3{font-size:clamp(24px, 7vw, 32px);}
}

@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;
  }
}

@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;
  }

  .reason-box,
  .service-card,
  .case-card,
  .tax-card,
  .price-card,
  .extra-item{
    padding:20px 16px;
  }
  .faq-item summary{padding:16px;}
  .faq-content{padding:0 16px 16px;}
}