




.houses-heading {
  font-weight: 700;
  color: #173660;
  font-size: 36px;
  margin: 60px 0 24px; /* ↑ großer Abstand nach oben */
}

.more-houses .cards {
  margin-bottom: 100px;
}


.sub-title {
    font-size: 1rem;
    color: #666;
    margin-top: -23px;
    margin-bottom: 1em;
    font-weight: 400;
}



/* Tablet (max. 992px) */
@media (max-width: 992px) {
  .sub-title {
    font-size: 1rem;
    margin-bottom: 0.8em;
  }
}

/* Handy (max. 600px) */
@media (max-width: 600px) {
  .sub-title {
    font-size: 0.9rem;
    color: #777; /* etwas heller für mobile Optik */
    text-align: center;
margin-top: -2px;
margin-bottom: 40px;
  }

  .textanbieter13 {
    text-align: center; /* optional: alles mittig */
  }
}




.textanbieter13 .detail-label {
  font-size: 18px;
  font-weight: 700;
  color: black;
  margin-bottom: 0.25rem;
}

.textanbieter13 .detail-value {
  font-size: 18px;
  color: #000;
}

    .cards-wrapper {
      max-width: 1200px;
      width: 100%;
      display: flex;
      justify-content: center;
    }

    .cards {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      max-width: 1100px; 
      gap: 35px;
      width: 100%;
      justify-items: center;
    }

    a.card-link {
      text-decoration: none; /* kein Unterstrich */
      color: inherit; /* Textfarbe übernehmen */
      display: block;
      width: 100%;
      max-width: 310px;
      border-radius: 16px;
    }

    .card {
      background: #fff;
      border-radius: 16px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      width: 100%;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .card:hover {
      transform: translateY(-6px);
      box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
    }

    .card img {
      width: 100%;
      height: 230px;
      object-fit: cover;
    }

    .card-content {
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .card-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .card-title {
      font-size: 18px;
      font-weight: bold;
    }

    .card-logo img {
      width: 50px;
      height: 50px;
      object-fit: contain;
      display: block;
    }

    .card-company {
      color: #666;
      font-size: 14px;
      word-break: break-word;
    }

    .card-row {
      display: flex;
      justify-content: space-between;
      font-size: 16px;
      font-weight: bold;
    }

    .card-footer {
      display: flex;
      justify-content: space-between;
      font-size: 13px;
      color: #555;
    }

    *{box-sizing:border-box}
    html,body{margin:0;padding:0}
    body{
      font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
      background:var(--bg);
      color:var(--text);
      line-height:1.6;
    }
    
h2.uebers{font-weight:700;color:#173660;margin:0 0 14px;font-size:36px;}
h2.ueber{font-weight:700;color:#173660;margin:0 0 20px;font-size:36px;text-align: center}
h3.uebers{font-weight:700;color:#173660;margin:0 0 14px;font-size:18px;}
    p.texte{margin:0 0 18px;color:black}

    .container{
      max-width:1200px;
      margin:0 auto;
      padding:20px;
    }

/* Container mittig & sicher gegen Theme-Übersteuerungen */
.ref-section {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 16px;
  box-sizing: border-box;
}

/* Layout */
.ref-wrapper {
  --overlap: clamp(0px, 3vw, 48px); /* steuert die Überlappung */
  display: flex;
  align-items: center;       /* Text vertikal am Bild zentrieren */
  gap: 2rem;
  margin: 2.5rem 0;
  position: relative;
  isolation: isolate;        /* sorgt für zuverlässige z-index-Stapelung */
  overflow: visible;         /* Überlappung nicht abschneiden */
  margin-bottom: 100px;}

/* Bild: max. 400px, bleibt responsiv */
.ref-image {
  flex: 0 0 auto;
  width: min(100%, 400px);
  position: relative;
  z-index: 1;
  margin: 0;                 /* reset für figure */
}

.ref-image img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
}

/* Textblock mit Überlappung */
.ref-text {
  flex: 1 1 0;
  background: #fff;
  padding: clamp(16px, 2.2vw, 32px);
  margin-left:-3rem; /* Überlappt das Bild */
  border-radius: 12px;
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  position: relative;
  z-index: 2;
}

.ref-text blockquote {
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  font-style: italic;
  color: #333;
}

.ref-text .autor {
  margin-top: 1rem;
  text-align: right;
  font-weight: 600;
  color: #666;
}
/* Spiegel-Variante */
.ref-wrapper--reverse {
  flex-direction: row;
}

.ref-wrapper--reverse .ref-text {
  margin-left: 0;                  /* reset */
  margin-right: -3rem; /* Überlappt Bild von links */
}

    /* Banner */
    .banner{
      position:relative;
      background-size:cover;
      background-position:center;
      border-radius:16px;
      min-height:420px;
      display:flex;
      align-items:flex-end;
      padding:30px;
      color:#fff;
      box-shadow:0 8px 24px rgba(0,0,0,.2);
      margin:20px 0 40px;
      overflow:hidden;
    }
    .banner::after{
      content:"";
      position:absolute;inset:0;
      background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.55));
    }
    .banner-content{position:relative;z-index:2;max-width:800px}
    .brand-badge{
      position:absolute;top:18px;left:18px;z-index:2;
      background:#fff;border-radius:10px;padding:8px 10px;display:flex;align-items:center;gap:10px;
      box-shadow:0 6px 18px rgba(0,0,0,.15);
    }
    .brand-badge img{height:40px;width:auto;border-radius:6px}

    /* Section title */
    .section-title{
      font-size:2rem;text-align:center;margin:10px 0 26px;position:relative;
    }
    .section-title::after{
      content:"";display:block;width:92px;height:4px;margin:12px auto 0;
      background:linear-gradient(90deg, var(--success), var(--accent));border-radius:2px;
    }

    /* Icon rows */
    .icon-row{display:flex;flex-wrap:wrap;gap:22px;justify-content:center;margin:0px 0 100px}
    .icon-box{
      flex:0 1 180px;background:#fff;border-radius:14px;padding:18px 16px;text-align:center;
      box-shadow:0 4px 12px rgba(0,0,0,.08);transition:transform .2s, box-shadow .2s;
    }
    .icon-box:hover{transform:translateY(-6px);box-shadow:0 10px 22px rgba(0,0,0,.12)}
    .icon-symbol{color:var(--success);margin-bottom:8px}
    .icon-symbol svg{width:48px;height:48px;display:inline-block;fill:#173360}
    .icon-label{font-weight:600;color:var(--primary);margin-bottom:6px}
    .icon-value{font-size:1.4rem;font-weight:700;color:var(--primary)}

    /* Buttons */
    .btn{
      display:inline-block;padding:14px 28px;font-size:1rem;font-weight:600;border-radius:10px;border:none;cursor:pointer;
      background: #4CAF50;color:#fff;text-decoration:none;transition:transform .25s ease, filter .25s ease;
      box-shadow:0 6px 16px rgba(0,0,0,.12);
    }
    .btn:hover{transform:translateY(-2px) scale(1.03);filter:brightness(1.05)}

    .btn-center{text-align:center;margin:-70px 0 100px}

    /* Split content sections */
    .split{display:flex;align-items:center;gap:30px;flex-wrap:wrap;margin:54px 0 100px}
    .split img{width:100%;max-width:440px;border-radius:14px;box-shadow:0 8px 22px rgba(0,0,0,.12)}
    .split .text{flex:1;min-width:260px}

    /* Grid cards (regions) */
    .grid{display:grid;grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));gap:20px;margin:26px 0 100px}
    .cardr{background:#fff;border-radius:16px;box-shadow:0 6px 20px rgba(0,0,0,.08);padding:22px;text-align:center;transition:transform .2s}
    .cardr:hover{transform:translateY(-6px)}
    .regions span{display:inline-block;background:var(--chip);border-radius:12px;padding:5px 12px;margin:4px;font-size:.92rem}

    /* Awards row */
    .awards{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin:20px 0 80px}
    .awards img{width:200px;height:200px;object-fit:contain;border-radius:10px;border:1px solid #e6e8ee;background:#fff}

    /* House cards */
    .houses{display:flex;flex-wrap:wrap;gap:22px;justify-content:center}
    .house-card{
      width:320px;background:#fff;border-radius:16px;overflow:hidden;text-decoration:none;color:inherit;
      box-shadow:0 6px 20px rgba(0,0,0,.08);transition:transform .25s ease, box-shadow .25s ease;
    }
    .house-card:hover{transform:translateY(-8px);box-shadow:0 12px 28px rgba(0,0,0,.14)}
    .house-card img{width:100%;height:auto;display:block}
    .house-content{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px}
    .house-left{flex:1;min-width:0}
    .house-title{font-weight:700;font-size:1.1rem;margin-bottom:2px;color:var(--primary)}
    .house-price{font-weight:700;color:var(--accent);margin-top:6px}
    .house-meta{font-size:.92rem;color:#666}
    .house-right{text-align:right;max-width:82px;flex-shrink:0}
    .house-right img{width:56px;height:56px;border-radius:6px;margin-bottom:6px}
    .house-right .size{font-weight:700;margin-top:6px;color:var(--primary)}

    /* CTA banner */
    .cta{background:linear-gradient(90deg,#38b000,#70e000);color:#fff;text-align:center;padding:56px 20px;border-radius:16px;margin:60px 0;box-shadow:0 8px 24px rgba(0,0,0,.15)}
    .cta h2{font-size:2rem;margin:0 0 12px}

    /* Contact block */
    .contact{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:26px 28px;margin:100px 0 20px}
    .contact .info p{margin:4px 0;color:black}
    .contact .info h3{margin-bottom:6px}

    /* Anchors spacing */
    .anchor{position:relative;top:-80px;visibility:hidden}

    @media (max-width: 820px){
      .banner{min-height:320px}
      .house-content{flex-direction:column;align-items:center;text-align:center}
      .house-right{margin-top:8px}
      .contact{flex-direction:column;text-align:center}
    }

    .main-container {
  max-width: 1200px;
  margin: 0 auto;
    background: #f8f4f4;
  overflow: hidden;

}

.banner-preishausanbieter1 {
      display: flex;
      justify-content: space-between;
      align-items: center;
      height: 500px;
      background-size: cover;
      background-position: center;
      color: white;
      padding: 40px 30px;
      border-radius: 12px 12px 0 0;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
      font-family: Arial, sans-serif;
      position: relative;
      overflow: hidden;
      flex-wrap: wrap;
      margin-bottom: 30px;
      max-width: 1200px;
    }

    .banner-text-preishausanbieter1,
    .banner-image-preishausanbieter1 {
      position: absolute;
      z-index: 1;
      bottom: 20px;
    }

    .banner-image-preishausanbieter1 img {
      max-width: 100px;
      padding: 10px;
      height: auto;
      border-radius: 8px;
      background: white;
    }

     .textanbieter13 {
  max-width: 700px;
  margin:  auto;
  padding: 20px;
  font-family: Arial, sans-serif;
  font-size: 1.1rem;
  line-height: 1.6;
  color: black;
  text-align: center;
  
  
}



h1.main-title {
    font-size: 48px !important;
    color: #173660;
font-weight: 700;
    
    margin: 0 0 14px;
    
  }

 .haus-features {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

.badge {
  background: #f1f5f9;
  color: #173660;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 0.9rem;
  font-weight: 500;
}

.badge.highlight {
  background: #0077cc;
  color: #fff;
}



.split-2 {
  display: flex;
  align-items: center;
  gap: 30px;
  margin: 60px 0 100px;
  flex-wrap: wrap;
}

.split-2 img {
  width: 100%;
  max-width: 440px;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}

.split-2 .text {
  flex: 1;
  min-width: 260px;
}

.cta-split {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  
  color: #fff;
  padding: 50px 30px;
  border-radius: 16px;
  margin: 60px 0;
}
.cta-split .cta-text { flex: 1; }

.cta-split .cta-image img {
  max-width: 240px;
  border-radius: 12px;
  box-shadow: 0 6px 20px rgba(0,0,0,.2);
}
@media(max-width: 820px){
  .cta-split { flex-direction: column; text-align: center; }
}


@media (max-width: 820px) {
  .split-2 {
    flex-direction: column;
  }
.split{
    flex-direction: column-reverse;
  }
}






     @media (max-width: 500px) {
      .banner-preishausanbieter1 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 200px;

}


 h2.cta-text {
    margin-bottom: 14px;
    font-size: 26px;
}



.banner-image-preishausanbieter1 img {
    max-width: 40px;
    padding: 10px;
    height: auto;
    border-radius: 8px;
    background: white;
}
}



/* Für kleinere Bildschirme: untereinander */
@media (max-width: 768px) {
  .textanbieter13 .haus-details {
    flex-direction: column;
    gap: 0px;
  }
  .textanbieter13 .detail-item {
    /* Damit auch Label & Value auf kleinen Displays untereinander bleiben */
    flex-direction: row; /* wenn du Label und Value nebeneinander willst */
    align-items: baseline;
  }
  .textanbieter13 .detail-label {
    margin-right: 0.5rem;
    
  }
}

/* Responsive für Mobile */
    /* Mobile: untereinander & leichte Überlappung nach oben */
@media (max-width: 850px) {
  .ref-wrapper {
    flex-direction: column;
    align-items: stretch;
    gap: 1.25rem;
  }

  .ref-image {
    width: 100%;
    max-width: 400px;   /* bleibt begrenzt, zentriert */
    margin-inline: auto;
  }

  .ref-text {
    margin-left: 0;
    margin-top: -2.5rem;  /* ragt leicht ins Bild hinein */
  }
.ref-wrapper--reverse {
    flex-direction: column-reverse;
  }
  .ref-wrapper--reverse .ref-text {
    margin-right: 0;
    margin-top: -2.5rem;
  }
}

 @media (max-width: 500px) { 
.icon-box {
    flex: 0 1 130px;
    background: #fff;
    border-radius: 14px;
    padding: 5px 10px;
    text-align: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .08);
    transition: transform .2s, box-shadow .2s;
}

h2.cta-text {
    margin-bottom: 14px;
    font-size: 26px;
}
.cta-split {
padding: 50px 0px;}

section.contact {padding: 26px 15px;
text-align: start;}

h1.main-title {
    font-size: 28px !important;
    color: #173660;
    
  }
h2.uebers{font-weight:700;color:#173660;margin:0 0 14px;font-size:28px;}
h2.ueber{font-weight:700;color:#173660;margin:0 0 20px;font-size:28px;text-align: center}
h3.uebers{font-weight:700;color:#173660;margin:0 0 14px;font-size:18px;}
    p.texte{margin:0 0 18px;color:black; font-size: 16px;}

.banner-preishausanbieter1

 {
    display: flex
;
    justify-content: space-between;
    align-items: center;
    height: 250px;
    background-size: cover;
    background-position: center;
    color: white;
    padding: 40px 30px;
    border-radius: 0 ;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    font-family: Arial, sans-serif;
    position: relative;
    overflow: hidden;
    flex-wrap: wrap;
    margin-bottom: 3px;
}
.banner-image-preishausanbieter1 img {
    max-width: 50px;
    padding: 2px;
    height: auto;
    border-radius: 8px;
    background: white;
}


.main-container{ padding: 0px;}
.banner-image-preishausanbieter1 {
    position: absolute;
    z-index: 1;
    bottom: 3px;
    left: 10px;

}



.textanbieter13 .main-title {
  font-size: 36px !important;
  font-weight: bold;
  margin-bottom: 0.75rem;
  line-height: normal !important;
 
}

.textanbieter13 .haus-details {
  display: flex;
  flex-wrap: wrap;
  gap: 0px; /* Abstand zwischen den "detail-item"s */
}

.textanbieter13 .detail-item {
  /* Damit Label und Value zusammenbleiben */
  display: flex;
  
}

.textanbieter13 .detail-label {
  font-size: 16px;
  font-weight: 700;
  color: black;
  margin-bottom: 0.25rem;
}

.textanbieter13 .detail-value {
  font-size: 1rem;
  color: #000;
text-align: start;
}}


@media (max-width: 500px){
  .has-global-padding {
    padding-right: 1px !important;
    padding-left: 1px !important;
} 
  
  body{
  --wp--style--root--padding-top: 0 !important;
    --wp--style--root--padding-right: 0 !important;
    --wp--style--root--padding-bottom: 0 !important;
    --wp--style--root--padding-left: 0 !important;
  }
  
  .houses-heading {
  font-weight: 700;
  color: #173660;
  font-size: 24px;
  margin: 60px 0 24px; /* ↑ großer Abstand nach oben */
}
  
}

.main-container {
margin-top: -80px;
}

@media (max-width: 700px){
  .main-container {
margin-top: -56px;
} 
}
