/* Unterseiten-Hero OVERRIDES (greifen zuletzt) */
#page-banner.hero.hero--mystic.hero--site{
  --hero-site-panel-h: 280px;
  position: relative;
  padding: 0;
  background: none;

}

#page-banner .hero_layer{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.1fr 0.9fr;
  align-items:center; min-height: var(--hero-site-panel-h);
  gap: clamp(24px,4vw,40px);
}


#page-banner .hero_media img{
  max-width:320px; height:auto; width:auto;
}

.ribbon{
  position:relative;
  z-index:100;
  display:flex;
  align-items:center;
  min-height:56px;
}

#page-banner .float_shapes { /* Korrigiert: mit # */
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

/* --- Unterseiten-Karte kompakter --- */
#page-banner.hero.hero--mystic.hero--site .hero_card {
  max-width: 480px !important;      /* schmaler als Startseite */
  padding: 22px 26px !important;    /* weniger Innenabstand */
  min-height: auto !important;      /* keine feste Höhe */
  transform: translateY(0%);         /* kein Schweben nach unten */
}

/* Text kleiner */
.hero h1{
  font-family:"Playfair Display",serif;
  font-size:clamp(28px,4.5vw,44px);
  line-height:1.12;
  margin:0 0 10px
}

#page-banner.hero.hero--mystic.hero--site .hero_card .cta .btn {
  font-size: 0.85rem !important;
  padding: 10px 16px !important;
  position: relative;
z-index: 6;
}
#page-banner.hero.hero--mystic.hero--site .hero_media img {
  max-width: 225px !important;  /* kleineres Foto */
  height: auto !important;
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
#page-banner.hero.hero--mystic.hero--site .hero_layer {
  display: grid;
  grid-template-columns: 1.0fr 1.0fr;
  align-items: center !important;    /* vertikal mittig */

}

#page-banner.hero.hero--mystic.hero--site .hero_media {
  position: absolute;
  right: clamp(16px,4vw,48px);
  top: 55% !important;               /* kleiner = höher, größer = tiefer */
  transform: translateY(-50%);
  z-index: 6;
}



/* =========================================
   Schwebende Formen nur im grünen Bereich sichtbar
   ========================================= */

/* Alle Formen (circle, pill, diamond, hex) innerhalb des Panels beschneiden */
#page-banner.hero.hero--mystic.hero--site .shape {
  position: absolute;
  z-index: 2;                   /* unter Karte/Bild, über Hintergrund */
  pointer-events: none;
  clip-path: inset(0 0 calc(100% - var(--hero-site-panel-h)) 0);
  /* ↑ schneidet alles ab, was unterhalb der Panelhöhe liegt */
}



/* Karte und Bild bleiben über den Formen */
#page-banner.hero.hero--mystic.hero--site .hero_layer {
  position: relative;
  z-index: 5;
}

/* Karte und Foto über Shapes/Abdeckung */
#page-banner .hero_layer{ position:relative; z-index: 5; }
/* ===== FINAL FIX: Ebenen im Unterseiten-Banner ===== */


/* Grüner Hintergrund ganz hinten */
#page-banner.hero.hero--mystic.hero--site::before{
  content:"";
  position:absolute; inset:0;
  height: var(--hero-site-panel-h, 280px);
  background: radial-gradient(120% 120% at 30% 30%, #2b3130 0%, #1f2222 60%, #171818 100%);
  z-index: 1 !important;
  pointer-events: none;
}

/* Inhaltsebene (Karte+Buttons) über Shapes */
#page-banner.hero.hero--mystic.hero--site .hero_layer{
  position: relative;
  z-index: 5;
  min-height: 100%;
  display: grid;
  align-items: center;        /* Karte vertikal mittig */
  gap: clamp(24px,4vw,40px);
  min-height: var(--hero-site-panel-h, 280px);
}


/* === MASKIERER: verdeckt Shapes NUR unterhalb des Panels === */
#page-banner.hero.hero--mystic.hero--site::after{
  content:"";
  position:absolute;
  left:0; right:0;
  top: calc(var(--hero-site-panel-h) - 1px); /* exakt an der Panelkante ansetzen */
  bottom: -1px;                               /* großzügig nach unten */
  background: var(--bg, #f5f0e6);             /* gleiche Creme wie Seite */
  z-index: 3;                                  /* über Shapes (2), unter Inhalt (10/11) */
  pointer-events: none;
}
/* =========================================
   Breadcrumb – "Sie sind hier" Navigationszeile
   ========================================= */
.breadcrumb {
  background: var(--light);
  border-top: 1px solid rgba(60, 50, 40, 0.1);
  border-bottom: 1px solid rgba(60, 50, 40, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
  padding: 8px 0;
  font-size: 0.9rem;
  color: var(--text);
}

.breadcrumb_row {
  display: flex;
  align-items: center;
  gap: 6px;
}

.breadcrumb_label {
  font-weight: 600;
  color: var(--accent-2);
  margin-right: 4px;
}

.breadcrumb a {
  color: var(--accent-2);
  text-decoration: none;
  transition: color 0.2s ease;
}

.breadcrumb a:hover {
  color: var(--gold);
}

.breadcrumb .sep {
  color: rgba(80, 70, 60, 0.5);
}

.breadcrumb a.active {
  color: var(--gold);
  font-weight: 600;
  cursor: default;
}
.breadcrumb a.active {
  pointer-events: none;
  text-decoration: none;
}
/* Stacking-Kontext für den Banner */
#page-banner { position: relative; z-index: 0; }

/* Shapes-Ebene: hinter Karte/Foto */
#page-banner .float_shapes {
  position: absolute;
  inset: 0;
  z-index: 1;           /* HINTER Karte & Foto */
  pointer-events: none; /* nie anklickbar */
}

/* Einzelne Shapes absolut positionieren */
#page-banner .float_shapes .shape {
  position: absolute;
  left: var(--x-start);
  top: calc(var(--y) * 1%);
  width: var(--w);
  height: var(--h);
  transform: rotate(var(--rot));
  animation: banner-drift var(--dur) linear infinite;
}

/* Karte & Foto VOR die Shapes */
#page-banner .hero_card,
#page-banner .hero_media {
  position: relative;
  z-index: 3;
}

/* optionale Deko-Linie leicht über den Shapes, aber unter Karte/Foto */
#page-banner .hero_slash { position: absolute; z-index: 2; }

/* Beispiel-Animation (falls noch nicht vorhanden) */
@keyframes banner-drift {
  0%   { transform: translateX(0)  rotate(var(--rot)); }
  100% { transform: translateX(calc(var(--x-end) - var(--x-start))) rotate(var(--rotDelta)); }
}


/* Full-bleed Shapes: füllen Höhe des Banners und sind viewport-breit */
#page-banner .float_shapes{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%); /* zentriert relativ zum Viewport */
  width: 100vw;                /* volle Bildschirmbreite */
  height: 100%;
  z-index: 1;                  /* hinter Karte/Foto */
  pointer-events: none;
}

/* Einzelne Shapes */
#page-banner .float_shapes .shape{
  position: absolute;
  left: var(--x-start);
  top: calc(var(--y) * 1%);
  width: var(--w);
  height: var(--h);
  transform: rotate(var(--rot));
  animation: banner-drift var(--dur) linear infinite;
}

/* Karte & Foto darüber */
#page-banner .hero_card,
#page-banner .hero_media{ position: relative; z-index: 3; }

/* Deko-Slash zwischen Shapes und Karte */
#page-banner .hero_slash{ position: absolute; z-index: 2; }

/* (falls nicht vorhanden) */
@keyframes banner-drift{
  0%   { transform: translateX(0) rotate(var(--rot)); }
  100% { transform: translateX(calc(var(--x-end) - var(--x-start))) rotate(var(--rotDelta)); }
}
/* === SWAP: Hintergrund Ribbon ↔ Breadcrumb ================== */

/* 1) Der Hintergrund, der bisher unter dem Breadcrumb lag,
      wandert jetzt ins Zwischenbanner (.ribbon) */
.hero--site + .ribbon {
  /* zarter Beige-Verlauf – nimm diesen oder deinen exakten Breadcrumb-Verlauf */
  background: linear-gradient(180deg, #efe6d8 0%, #e6dac6 100%) !important;
  border-top: 5px solid rgba(60, 40, 20, .06);
  border-bottom: 1px solid rgba(60, 40, 20, .06);
  margin-top: 0;
  margin-bottom: 0px !important;
    margin: 0 6px !important;
}

.hero--site + .ribbon .ribbon_text {
  font-size: .95rem;
  line-height: 1.25;
}

.hero--site + .ribbon .ribbon_row {
  min-height: 48px;
  gap:10px;
}

.hero--site + .ribbon .dot{
  width:4px;
  height:4px; }

/* 2) Breadcrumb bekommt den bisherigen (quasi) transparenten Ribbon-Look */
.breadcrumb,
.you-are-here,
.trail {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding-top: .5rem;
  padding-bottom: .5rem;
  margin-top: 6px;  /* leicht unter dem Ribbon */
}

/* 3) Sicherheit: Inhalt in der Breadcrumb-Zeile bleibt ruhig/luftig */
.breadcrumb .container,
.you-are-here .container,
.trail .container {
  padding-left: 0;
  padding-right: 0;
}
/* Ribbon kompakt – gewinnt gegen frühere Regeln */
.hero--site + .ribbon{
  display: flex !important;        /* verhindert Margin-Collapsing */
  align-items: center !important;
  min-height: 0 !important;
  padding: 6px 0 !important;       /* echte Bandhöhe */
}


.sheet-card {
  background-color: var(--paper);
}

.page-sheet.legal .sheet-card {
  background: var(--light);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

/* Entfernt die überflüssige äußere Box bei Impressum & Datenschutz */
section.page-sheet.legal {
  background: transparent !important;   /* kein eigener Hintergrund mehr */
  box-shadow: none !important;          /* keine Schattierung */
  padding: 0 !important;                /* kein zusätzlicher Rand */
  margin: 0 auto !important;
}

/* Optional: sorgt dafür, dass nur die Textbox sichtbar bleibt */
section.page-sheet.legal .sheet-card {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.page-sheet.honorar {
  max-width: var(--wrap-narrow, 980px);
  margin: 0 auto;
  padding: 2rem 1rem 3rem;
  background: var(--light, #f8f4ec);  /* gleicher sanfter Ton wie Anfrage */
  border-radius: var(--radius, 20px);
  box-shadow: var(--shadow, 0 4px 12px rgba(0,0,0,.08));
}

/* Abschnitt mit den Angebotskarten */
.page-sheet.honorar .offer-cards {
  margin-top: 1.5rem;
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

/* Einzelne Karten (gleichen Stil wie Anfrage-Boxen) */
.page-sheet.honorar .offer-card {
  background: var(--panel-light, #fffaf5);
  border-radius: var(--radius, 16px);
  box-shadow: var(--shadow, 0 6px 14px rgba(0,0,0,.08));
  padding: 1.25rem 1.5rem;
}

/* =========================================
   HONORAR – Hauptbox breiter & dunkler
   ========================================= */

.page-sheet.honorar .sheet-card,
.page-sheet.honorar {
  max-width: 1100px;                        /* etwas breiter als Anfrage */
  margin: 0 auto;
  background: #f0e9dc;                      /* etwas dunkleres Creme-Beige */
  border-radius: var(--radius, 18px);
  box-shadow: 0 10px 25px rgba(0,0,0,.12),  /* kräftigerer Schatten */
              0 2px 6px rgba(0,0,0,.06);
  padding: 2.5rem 2rem;
}

/* Die kleinen Karten behalten ihren helleren Hintergrund */
.page-sheet.honorar .offer-card {
  background: #fcf8f2;                      /* bleibt heller für Kontrast */
  border-radius: 16px;
  box-shadow: 0 6px 14px rgba(0,0,0,.08);
  padding: 1.25rem 1.5rem;
}

/* Optional: Textfarbe leicht abdunkeln für bessere Lesbarkeit */
.page-sheet.honorar h1,
.page-sheet.honorar h2,
.page-sheet.honorar p {
  color: #3c342b;
}

.hero_card--small h1 {
  font-size: 2rem;        /* kleiner als Startseite */
  line-height: 1.2;
}

.hero_subtitle {
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-size: 0.9rem;
  color: #d8c4a3;          /* gold-beiger Ton */
  margin-top: 0.3rem;
  margin-bottom: 1.2rem;
  display: block;
}

/* === SUBPAGE HERO – MOBILE FIX (≤700px) ====================== */
@media (max-width: 700px){

  /* 1) Panelhöhe kleiner & nix darf seitlich überstehen */
  #page-banner.hero.hero--mystic.hero--site{
    --hero-site-panel-h: 220px;
    overflow: hidden;         /* statt clip, damit Scrollbar weg ist */
    z-index: 0;               /* Banner bleibt unter dem Sticky-Header */
  }
  #page-banner.hero.hero--mystic.hero--site::before{
    height: var(--hero-site-panel-h) !important;
  }

  /* 2) Layout einkolumnig – Karte über dem Bild */
  #page-banner.hero.hero--mystic.hero--site .hero_layer{
    padding: 12px 14px !important;
  }



  /* 4) Karte mittig & schmal, damit Buttons nicht anstoßen */
  #page-banner.hero.hero--mystic.hero--site .hero_card{
    max-width: 640px !important;              /* genug Breite für 2-Spalten-Menü */
    margin: 0 auto !important;
    padding: 18px 16px !important;
  }

  /* 5) Shapes im Banner deaktivieren – verhindern horizontales Schieben */
  #page-banner.hero.hero--mystic.hero--site .float_shapes,
  #page-banner.hero.hero--mystic.hero--site .shape{
    display: none !important;
  }
}

/* === SUBPAGE HERO: Hard Reset & Mobile-Fix ================== */

/* 0) Grund-Stack – eine Quelle der Wahrheit */
#page-banner.hero.hero--mystic.hero--site{ position: relative; z-index: 0; overflow: hidden; }
#page-banner .float_shapes{ position:absolute; inset:0; z-index: 2; pointer-events:none; }
#page-banner .hero_slash{ position:absolute; z-index: 3; }
#page-banner .hero_card,
#page-banner .hero_layer{ position:relative; z-index: 5; }
#page-banner .hero_media{ position: relative; z-index: 6; }

/* 1) Ribbon wieder vollbreit – keine Mini-Größe */
.hero--site + .ribbon{
  width: 100% !important; height: auto !important;
  display:flex !important; align-items:center !important;
  padding: 8px 0 !important; margin: 0 !important;
  background: linear-gradient(180deg, #efe6d8 0%, #e6dac6 100%) !important;
  border-top: 5px solid rgba(60,40,20,.06);
  border-bottom: 1px solid rgba(60,40,20,.06);
}

/* 2) Desktop-Layout vereinheitlichen */
#page-banner.hero.hero--mystic.hero--site .hero_layer{
  display:grid; grid-template-columns: 1.1fr 0.9fr;
  align-items:center; gap: clamp(24px,4vw,40px);
  min-height: var(--hero-site-panel-h, 280px);
}


/* 3) Mobile: einkolumnig, Bild aus dem absoluten Fluss, Shapes aus */
@media (max-width: 700px){
  #page-banner.hero.hero--mystic.hero--site{
    --hero-site-panel-h: 220px;
  }
  #page-banner.hero.hero--mystic.hero--site .hero_layer{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 12px 14px !important;
    min-height: auto !important;
  }
  #page-banner.hero.hero--mystic.hero--site .hero_card{
    max-width: 640px !important;
    margin: 0 auto !important;
    padding: 18px 16px !important;
  }
  #page-banner.hero.hero--mystic.hero--site .hero_media{
    position: static !important;
    top: auto !important; right: auto !important; transform: none !important;
    margin: 6px auto 0 !important; text-align: center;
  }
  #page-banner.hero.hero--mystic.hero--site .hero_media img{
    max-width: min(56vw, 260px) !important;
    height: auto !important;
  }
  /* Shapes mobil sicher weg, damit keine H-Scroll entsteht */
  #page-banner.hero.hero--mystic.hero--site .float_shapes,
  #page-banner.hero.hero--mystic.hero--site .shape{
    display: none !important;
  }
}

/* 5) H-Scroll-Schutz auf der Ebene darunter (failsafe) */
@media (max-width: 700px){
  #page-banner,
  #page-banner .hero_layer{
    max-width: 100vw !important;
    overflow-x: clip !important;
  }
}

.content-block {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  margin: 60px 0;
  align-items: center;
}

.content-text {
  flex: 1 1 60%;
}

.content-image {
  flex: 1 1 40%;
  text-align: center;
}

.content-image img {
  width: 100%;
  max-width: 420px;
  border-radius: 12px;
  opacity: 0.9;
}

.content-block.reverse {
  flex-direction: row-reverse;
}

/* Bildgröße für diese spezielle Bildart */
.content-img {
  width: 60%;
  max-width: 280px;
  border-radius: 12px;
  opacity: 0.95;
  margin: 0 auto;
}

@media (max-width: 700px) {
  .content-block {
    flex-direction: column;
    text-align: center;
  }

  /* === SUBPAGE HERO – saubere Trennung Desktop vs. Mobile === */

  /* Desktop: 2 Spalten + Foto absolut NUR für .hero--site */
  @media (min-width:701px){
    #page-banner.hero.hero--mystic.hero--site .hero_layer{
      display:grid; grid-template-columns:1.1fr 0.9fr;
      align-items:center; gap:clamp(24px,4vw,40px);
      min-height:var(--hero-site-panel-h,280px);
    }
    #page-banner.hero.hero--mystic.hero--site .hero_media{
      position:absolute; right:clamp(16px,4vw,48px); top:55%;
      transform:translateY(-50%); z-index:6;
    }
  }

  /* Mobile: einkolumnig + Bild im Fluss */
  @media (max-width:700px){
    #page-banner.hero.hero--mystic.hero--site{ --hero-site-panel-h:220px; overflow:hidden; }
    #page-banner.hero.hero--mystic.hero--site .hero_layer{
      display:grid !important; grid-template-columns:1fr !important;
      gap:12px !important; padding:12px 14px !important; min-height:auto !important;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_card{
      max-width:640px !important; margin:0 auto !important; padding:18px 16px !important;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_media{
      position:static !important; top:auto !important; right:auto !important; transform:none !important;
      margin:6px auto 0 !important; text-align:center;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_media img{
      max-width:min(56vw,260px) !important; height:auto !important;
    }
    /* Shapes mobil aus, H-Scroll vermeiden */
    #page-banner.hero.hero--mystic.hero--site .float_shapes,
    #page-banner.hero.hero--mystic.hero--site .shape{ display:none !important; }
    #page-banner, #page-banner .hero_layer{ max-width:100vw !important; overflow-x:clip !important; }
  }

  /* Ribbon immer vollbreit (Sicherungsnetz) */
  .hero--site + .ribbon{
    width:100% !important; height:auto !important; display:flex !important; align-items:center !important;
    padding:8px 0 !important; margin:0 !important;
  }

  /* === SUBPAGE HERO – CRITICAL HOTFIX (keine verschachtelten @media!) === */

  /* Desktop: 2 Spalten + Foto absolut NUR auf Unterseiten-Banner */
  @media (min-width: 701px){
    #page-banner.hero.hero--mystic.hero--site .hero_layer{
      display: grid;
      grid-template-columns: 1.1fr 0.9fr;
      align-items: center;
      gap: clamp(24px, 4vw, 40px);
      min-height: var(--hero-site-panel-h, 280px);
    }
    #page-banner.hero.hero--mystic.hero--site .hero_media{
      position: absolute;
      right: clamp(16px, 4vw, 48px);
      top: 55%;
      transform: translateY(-50%);
      z-index: 6;
    }
  }

  /* Mobile: einkolumnig + Bild im normalen Fluss, Deko aus */
  @media (max-width: 700px){
    #page-banner.hero.hero--mystic.hero--site{
      --hero-site-panel-h: 220px;
      overflow: hidden !important;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_layer{
      display: grid !important;
      grid-template-columns: 1fr !important;
      gap: 12px !important;
      padding: 12px 14px !important;
      min-height: auto !important;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_card{
      max-width: 640px !important;
      margin: 0 auto !important;
      padding: 18px 16px !important;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_media{
      position: static !important;
      top: auto !important;
      right: auto !important;
      transform: none !important;
      margin: 6px auto 0 !important;
      text-align: center;
    }
    #page-banner.hero.hero--mystic.hero--site .hero_media img{
      max-width: min(56vw, 260px) !important;
      height: auto !important;
    }
    #page-banner.hero.hero--mystic.hero--site .float_shapes,
    #page-banner.hero.hero--mystic.hero--site .shape{
      display: none !important;
    }
    #page-banner, #page-banner .hero_layer{
      max-width: 100vw !important;
      overflow-x: clip !important;
    }
  }
