@font-face {
  font-family: 'Catenary Stamp';
  src: url('../fonts/CatenaryStamp.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
}
* {
  box-sizing: border-box;
}
body {
  margin: 0px;
  font-family: Afacad;
  background-color: #e9e5e3; /* deine Standard-Hintergrundfarbe */
}
.scroll_margin_class {
  scroll-margin-top: 120px;
}
/*.description_text {
  font-size: 18px;
  color: rgba(0,0,0,1);
}*/
main {
  padding-top: 80px; /* oder so viel wie die Headerhöhe */
}
.main_header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
  background-color: #e9e5e3; /* oder #234a64 je nach Design */
  }
.title_frame {
  display: flex;
  align-items: center;
  gap: 12px;
}

.logo {
  height: 48px;
  width: auto;
}

.site_title {
  font-family: 'Catenary Stamp', sans-serif;
  font-size: 18px;
  color: #eabda8;
  line-height: 1.2;
  text-align: left;
}
/* Menü – mobil: scrollbar, Desktop: nebeneinander */
/* ===== ALT: anchor_buttons Menü (nicht mehr verwendet) =====
.anchor_buttons {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  overflow-x: auto;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  gap: 20px;
  padding: 0 8px;
  box-sizing: border-box;
  max-width: 100%;
  scrollbar-width: none; /* Firefox */
}

.anchor_buttons::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Edge */
}

.anchor_buttons a {
  flex: 0 0 auto;
  text-decoration: none;
  color: white;
  font-family: 'Afacad', sans-serif;
  font-size: 16px;
  display: inline-block;
}
@media (max-width: 768px) {
  .anchor_buttons a {
    color: rgba(244, 244, 244, 1) !important;
  }
}

/* ✅ Desktop Variante */
@media (min-width: 992px) {
  .header_frame {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  .anchor_buttons {
    overflow-x: visible;
    justify-content: flex-end;
    gap: 36px;
  }
}
===== ENDE ALT-MENÜ ===== */
  h1, h2, h3, .section_header, .hypnosis_sub_header {
    margin-top: 24px;
    margin-bottom: 12px;
  }

  p {
    margin-bottom: 12px;
  }
}
}
.header_button {
  font-size: 20px;
  color: rgba(244,244,244,1)!important;
  text-decoration: none;
  color: #ffffff;
  text-decoration: none;
  font-size: 16px;
  padding: 4px 8px;
  font-family: "Afacad", sans-serif;
}
.header_button:hover {
  text-decoration: underline;
}
.welcome_section {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin-top: 0;
  padding-top: 0;
}
#main_title {
  width: 100%;
  color: rgba(35,74,100,1);
  font-weight: SemiBold;
  font-size: 76px;
  text-align: center;
  margin-bottom: 50px;
}
.main_banner {
  width: 100%;
  max-width: 1200px;      /* exakt wie dein Textbereich */
  margin: 40px auto;      /* zentriert + Abstand oben/unten */
  overflow: hidden;
  border-radius: 16px;    /* leichte runde Ecken */
  margin-top: 0;
  padding-top: 0;
}

.main_banner img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
}
@media (max-width: 768px) {
  .main_banner {
    padding: 0 10px;
  }
}
.fullwidth-banner {
  width: 100%;
  overflow: hidden;
  border-radius: 20px;
}

.fullwidth-banner img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
}
.fullpage-banner {
  width: 100vw;           /* volle Fensterbreite */
  overflow: hidden;
  margin: 0;
  padding: 0;
  border-radius: 0;
}

.fullpage-banner img {
  width: 100%;
  height: auto;
  display: block;
}
.upper_text {
  display: flex;
  justify-content: center;
  margin-top: 30px;
  gap: 55px
}
.welcome_text {
  max-width: 700px;
  font-size: 1.2rem;
  line-height: 1.8;
  margin-bottom: 0 !important;
}
.welcome_text p {
  margin-bottom: 0.1rem;
}

/* === Basis === */
* {
  box-sizing: border-box;
}
body {
  margin: 0;
  font-family: "Afacad", sans-serif;
  padding-top: 60px; /* Platz für fixierten Header */
  overflow-x: hidden;
}
.scroll_margin_class {
  scroll-margin-top: 120px;
}

/* === Container-Struktur === */
.main_container {
  width: 100%;
  background: rgba(233,229,227,1);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding-top: 0; /* Höhe der fixen Menüleiste */
  margin-top: 0;
}
.main_container .welcome_section {
  margin-top: 20px; /* klein halten */
}
/* === Abschnitt: Wer sind wir === */
#about_us_section {
  padding: 60px 0;
  background-color: rgba(233,229,227,1);
}
/*.section_wrapper {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
}*/
/*.section_header {
  color: rgba(35,74,100,1);
  font-weight: SemiBold;
  font-size: 51px;
  display: block;
  margin-top: 0px;    
  margin-bottom: 8px;!important;
  padding-top: 0;
  padding-left: 20px
  font-size: clamp(20px, 5vw, 36px); /* passt sich automatisch an */
}*/

.section_header_narrow {
  padding-left: 0 !important;
}
.section_header_feedback {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 6px;
  margin-top: 0;
  padding-top: 0;
  display: block;
  text-align: left;
  padding-left: 12%;
}

@media (min-width: 768px) and (max-width: 991px) {
  .section_header_feedback {
    padding-left: 17%;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .section_header_feedback {
    padding-left: 9%;
  }
}

@media (min-width: 1200px) {
  .section_header_feedback {
    padding-left: 25%;
  }
}

*/alte Version mit Überschrift zu weit links
/*.section_header_about {
  text-align: left;
  margin-bottom: 40px;
}*/
.section_wrapper {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
  box-sizing: border-box;
}

/*.section_header_about {
  margin-bottom: 40px;
  padding-left: 205px; /* linker Abstand angepasst an Katjas Bild */
}*/

/*@media (max-width: 768px) {
  .section_header_about {
    padding-left: 24px;
    text-align: left;
  }
}*/

.welcome_headline {
  font-size: 32px;
  font-weight: 700;
  margin: 20px auto;
  text-align: center;
  word-break: keep-all;
  white-space: normal;
  padding: 0; /* wichtig: damit padding-left von .section_header überschrieben wird */
  display: block;
  margin-top: 8px; /* statt 20 oder 40 */
}

@media (min-width: 768px) {
  .welcome_headline {
    font-size: 40px;
    margin: 30px auto;
  }
}

@media (min-width: 1200px) {
  .welcome_headline {
    font-size: 48px;
    margin: 40px auto;
  }
}
@media (max-width: 480px) {
  .welcome_headline {
    font-size: 24px;
    margin: 24px auto;
  }
}
.scroll_margin_class {
  scroll-margin-top: 100px; /* anpassen je nach Header-Höhe */
}

@media (min-width: 992px) {
  .scroll_margin_class {
    scroll-margin-top: 120px;
  }
}
html {
  scroll-behavior: smooth;
}

/* Personen-Layout */
.about_us_descriptions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}
.person_block {
  flex: 1 1 400px;
  max-width: 600px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.person_img {
  width: 300px;
  height: 400px;
  object-fit: cover;
  object-position: top;
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  margin-bottom: 1.5rem;
}
.about_us_text {
  font-size: 1rem;
  line-height: 1.6;
  color: #1a1a1a;
  padding: 0 10px;
}

.about_us_text h3 {
  font-size: 1.5rem;
  margin: 0.5rem 0;
}
.about_us_text p {
  margin-bottom: 0.2rem;
}

/* Responsive */
@media (max-width: 768px) {
  .about_us_descriptions {
    flex-direction: column;
    align-items: center;
    gap: 32px;
  }
  .person_block {
    width: 90%;
    max-width: 300px;
  }
  .about_us_text {
    text-align: center;
  }
  .person_img {
    width: 100%;
    height: auto;
  }
}.section_header {
  color: rgba(35,74,100,1);
  font-weight: SemiBold;
  font-size: 51px;
}
#hypnosis_section {
  margin-top: 80px;
}
.hypnosis_text_1 {
  flex: 1 1 500px;
  max-width: 600px;
}
@media (max-width: 768px) {
  .hypnosis_row {
    flex-direction: column;
    align-items: center;
  }
  .hypnosis_img_1, .hypnosis_text_1 {
    max-width: 90%;
  }
}

.hypnosis_sub_header {
  max-width: 600px;
  color: rgba(35, 74, 100, 1);
  font-weight: 600; /* entspricht Semibold */
  font-size: 32px;
  margin-bottom: 1.5rem;
}
@media (max-width: 768px) {
  .hypnosis_sub_header {
    font-size: 24px;
    max-width: 90%;
  }
}
.v22_9 {
  width: 600px;
  margin-top: 20px;
}
.hypnosis_row {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  justify-content: center;
  align-items: flex-start;
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 20px;
}

.hypnosis_img_1 {
  flex: 1 1 400px;
  max-width: 450px;
  padding: 0 10px;
}
.hypnosis_img_1 img {
  width: 100%;
  height: auto;
  max-height: 520px;  /* <- Hier kannst du feinjustieren */
  object-fit: cover;
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.hypnosis_text_1 {
  flex: 1 1 500px;
  max-width: 600px;
}
/* 📱 Mobile & Tablet – Bild bleibt anpassbar */
@media (max-width: 1024px) {
  .hypnosis_img_1 img {
    max-height: 400px;
  }
}

/* 🖥️ Desktop – Bild darf länger sein */
@media (min-width: 1025px) {
  .hypnosis_img_1 img {
    max-height: 540px; /* Gern anpassen */
  }
}

@media (max-width: 768px) {
  .hypnosis_row {
    flex-direction: column;
    align-items: center;
  }

  .hypnosis_img_1,
  .hypnosis_text_1 {
    max-width: 90%;
  }
}
.hypnosis_row_2 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start; /* ändern wir gleich */
  gap: 40px;
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 20px;
}
/* Bildbereich in der Hypnose-Ablauf-Sektion */
.hypnosis_img_2 {
  flex: 1 1 300px;
  max-width: 400px;
  display: flex;
  align-items: center;
  margin-top: 30px; /* Feinjustierung, falls nötig */
}

.hypnosis_img_2 img {
  width: 100%;
  height: auto;
  max-height: 600px; /* kannst du nach Bedarf anpassen */
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* 📱 Mobile Optimierung */
@media (max-width: 768px) {
  .hypnosis_row_2 {
    flex-direction: column;
    align-items: center;
  }

  .hypnosis_img_2 {
    max-width: 90%;
    margin-top: 20px;
  }

  .hypnosis_img_2 img {
    max-height: 400px;
  }
}
.cta_button_wrapper {
  margin-top: 40px;
  text-align: center;
}

.cta_button {
  background-color: #234a64;
  color: white;
  padding: 14px 24px;
  font-size: 1.1rem;
  border-radius: 8px;
  text-decoration: none;
  transition: background 0.3s ease;
  display: inline-block;
}

.cta_button:hover {
  background-color: #1a3a50;
}
@media (max-width: 768px) {
  .cta_button {
    font-size: 1rem;
    padding: 12px 20px;
    width: 90%;
    max-width: 320px;
  }

  .cta_button_wrapper {
    text-align: center;
  }
}
.back_button {
  display: inline-block;
  background-color: #234a64;   /* Dunkelblau */
  color: #eabda8 !important;   /* Kupferfarbener Text */
  font-weight: 600;
  text-decoration: none !important;
  padding: 10px 18px;
  border-radius: 8px;
  margin: 20px 0;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transition: background-color 0.3s, transform 0.2s, box-shadow 0.3s;
}

.back_button:hover {
  background-color: #1a384f;
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0,0,0,0.3);
  color: #eabda8 !important;   /* bleibt Kupfer beim Hover */
}


.cta_button_wrapper {
  margin: 40px auto 20px auto;
}

#reviews_section {
  margin-top: 80px;
}
.end_span {
  height: 80px;
}
#contacts_section {
  width: 100%;
  background: rgba(35,74,100,1) !important;
  color: white;
  padding: 40px 20px;
  display: flex;
  justify-content: center;
}

.kontakt-flexbox {
  display: flex;
  flex-direction: column;
  gap: 30px;
  width: 100%;
  max-width: 1200px;
}

.kontakt-container {
  padding: 0 10px;
  font-size: 16px;
  line-height: 1.6;
}

.kontakt-mail {
  font-weight: bold;
  font-size: 1.5rem;
  margin-bottom: 1rem;
  color: white;
}

.kontakt-container p {
  margin: 8px 0;
}

.kontakt-container strong {
  font-weight: 600;
  color: white;
}

.social-icons {
  display: flex;
  gap: 10px;
  margin: 10px 0;
}

.icon {
  width: 28px;
  height: 28px;
  filter: brightness(0) invert(1);
}

.special-text {
  font-style: italic;
  font-size: 17px;
  margin-top: 10px;
}

/* Mobil zuerst – alles untereinander */
.kontakt-content {
  display: flex;
  flex-direction: column;
  gap: 40px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
}

.map-tour-row {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.iframe-wrapper iframe {
  width: 100%;
  height: 300px;
  max-width: 100%;
  border: none;
  border-radius: 8px;
}

/* Ab Desktop: Map & Tour nebeneinander */
@media (min-width: 992px) {
  .map-tour-row {
    flex-direction: row;
    gap: 60px;
  }

  .map-box,
  .tour-box {
    flex: 1;
  }

  .iframe-wrapper iframe {
    height: 400px;
  }
}

/* Ab Desktop (z. B. 992px) nebeneinander */
@media (min-width: 992px) {
  .map-tour-container {
    flex-direction: row;
    gap: 60px;
  }

  .map-box,
  .tour-box {
    flex: 1;
    width: auto;
    margin-bottom: 0;
  }
}

.iframe-label {
  font-weight: 500;
  margin-bottom: 6px;
  color: white;
}

.iframe-wrapper iframe {
  width: 100%;
  height: 300px;
  max-width: 100%;
  border: none;
  border-radius: 8px;
}

@media (min-width: 992px) {
  .kontakt-flexbox {
    flex-direction: row;
    gap: 60px;
    padding: 40px 60px;
  }

  .kontakt-container,
  .map-tour-container {
    flex: 1;
  }

  .iframe-wrapper iframe {
    height: 400px;
  }
}

.contacts_frame {
  width: 1200px;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.v35_34 {
  color: rgba(213,215,216,1);
  margin-top: 80px;
  font-size: 40px;
}
.info_box {
  width: 155px;
  height: 186px;
  margin: 15px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.footer_info {
  width: 190px;
  color: rgba(213,215,216,1);
  font-size: 32px;
}
.reviews_box {
  display: flex;
  gap: 30px
}
.review_column {
  width: 31%;
  margin-top: 20px;
}
.client_name {
  height: 53px;
  color: rgba(35,74,100,1);
  font-weight: SemiBold;
  font-size: 32px;
}
.review_text {
  margin-top: 20px;
}
/* === Kontakt: Social Media Icons & Einladungstext === */

.kontakt-mail {
  font-weight: bold;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.social-container {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.follow-text {
  font-weight: 500;
  margin-right: 10px;
  white-space: nowrap;
}

.social-icons {
  display: flex;
  gap: 12px;
  align-items: center;
}

.icon {
  width: 32px;
  height: 32px;
  transition: transform 0.2s ease, filter 0.2s ease;
}

.icon:hover {
  transform: scale(1.1);
  filter: brightness(1.2);
}

.freude-text {
  margin-top: 12px;
  font-style: italic;
}

.kontakt-details p {
  margin: 6px 0;
}

@media (max-width: 600px) {
  .social-container {
    flex-direction: column;
    align-items: flex-start;
  }
  .follow-text {
    white-space: normal;
    margin-right: 0;
  }
}
#contacts_section a {
  color: white;
  text-decoration: underline; /* Optional: für Erkennbarkeit als Link */
}

#contacts_section a:hover {
  color: #ffcc70; /* Optional: heller Akzent beim Drüberfahren */
}
.map-tour-container {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  justify-content: center;
  margin-top: 40px;
}
.ablauf-liste {
  padding-left: 1.2em;
  line-height: 1.6;
}

.ablauf-liste li {
  margin-bottom: 1.4em;
}

/* Mobiloptimierung */
@media (max-width: 768px) {
  .hypnosis_row_2 {
    flex-direction: column;
    align-items: center;
  }
  .hypnosis_text_1, .hypnosis_img_2 {
    max-width: 90%;
  }
}
<style>
.iframe-label {
  font-weight: bold;
  color: #ffffff;
  margin-bottom: 8px;
  font-size: 1.1rem;
}

.iframe-wrapper {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  border-radius: 8px;
  overflow: hidden;
}
  .special-text {
    font-family: 'Georgia', serif;
    font-style: italic;
    font-weight: 500;
    font-size: 1.3rem;
  }
</style>
<style>
  .iframe-label {
    font-weight: bold;
    color: #ffffff;
    margin-bottom: 8px;
    font-size: 1.1rem;
  }

  .special-text {
    font-family: 'Georgia', serif;
    font-style: italic;
    font-weight: 500;
    font-size: 1.3rem;
  }

 .iframe-wrapper iframe {
   width: 100%;
   height: 400px;
}
@media (max-width: 900px) {
  .map-box,
  .tour-box {
    flex: 1 1 100%;
  }
}
@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(-30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.fade-in-left {
  animation: fadeInLeft 1.2s ease-out both;
}
/* Abschnitt Willkommen */
.welcome_section {
  padding: 40px 20px;
  background-color: rgba(233,229,227,1);
  color: #234a64;
}

.fullwidth-banner {
  width: 100%;
  max-width: 100vw;
  overflow: hidden;
  margin-bottom: 30px;
}

.fullwidth-banner img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.upper_text {
  max-width: 1000px;
  margin: 0 auto;
}
.upper_text.two_columns {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: space-between;
  max-width: 1000px;
  margin: 0 auto;
}

.welcome_text {
  width: 48%;
  font-size: 17px;
  line-height: 1.4;
  padding: 0 5%;
  box-sizing: border-box;
}
/* Optional für große Bildschirme: zentriert + maximalbreit */
@media (min-width: 992px) {
  .welcome_text {
    padding: 0 20px;
    max-width: 380px;
  }
}

.welcome_text p {
  margin-bottom: 0.2rem;
}
.two_columns {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: space-between;
}
.upper_text.two_columns > div:nth-child(3) p {
  margin-bottom: 4px;
  line-height: 1.4;
}

.upper_text.two_columns > div:nth-child(3) p:last-child {
  margin-bottom: 0;
}
.two_columns .welcome_text {
  flex: 1 1 400px;
  min-width: 280px;
  font-size: 1.3rem;
  line-height: 1.7;
  color: #234a64; /* dein dunkles Blau */
}
/* Standard: Mobilgeräte – keine Verschiebung */
.shift_up {
  position: relative;
  top: 0;
}

/* Tablet: leichte Annäherung */
@media (min-width: 768px) and (max-width: 991px) {
  .shift_up {
    top: -80px;
  }
}

/* Desktop: starke Verschiebung wie gewünscht */
@media (min-width: 992px) {
  .shift_up {
    margin-top: -230px;
  }
}

/* Optional: Abstände innerhalb des Blocks etwas straffer */
.shift_up p {
  margin-bottom: 4px;
  line-height: 1.4;
}

.shift_up p:last-child {
  margin-bottom: 0;
}
.shift_up p {
  margin-bottom: 4px;
  line-height: 1.4;
}

.shift_up p:last-child {
  margin-bottom: 0;
}
.two_columns .welcome_text p {
  margin-bottom: 2px;
}

.two_columns .welcome_text strong {
  font-weight: bold;
  color: #234a64;
}
@media (max-width: 768px) {
  /* Hauptbanner: enger an den Text */
  .main_banner {
    margin-bottom: 4px !important;
    padding-bottom: 0 !important;
  }
  .two_columns .welcome_text p:last-of-type {
  margin-bottom: 0px; /* oder 0, je nach gewünschtem Abstand */
}
  /* Abstand zwischen Banner und "Welcome" */
 /* .section_header {
    font-size: 24px !important;
    margin-bottom: 6px !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
+/
  /* Textbereich: Einrücken + kompakter */
  .upper_text {
    margin-top: 0 !important;
    padding: 0 12px !important;
    box-sizing: border-box;
  }

  .upper_text p {
    margin-top: 0 !important;
    margin-bottom: 6px !important;
    line-height: 1.4 !important;
    font-size: 16px !important;
  }

  .welcome_text {
    margin-bottom: 12px !important;
    padding: 0 !important;
  }

  /* Optional: Kopfbereich enger machen */
 }


/* Stelle sicher, dass .burger_button ganz rechts sitzt */




/* Mobil: Menü verstecken */


  .main_nav.active {
    display: flex;
  }

  
}
/* Standard: Desktop-Ansicht */


/* Mobile: Menü versteckt */


  .main_nav.active {
    display: flex;
  }

  .anchor_buttons {
    display: none !important;
  }
}

/* ✅ HEADER & BURGER-MENÜ - CSS */

.main_header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #234a64;
  z-index: 9999;
  padding: 12px 0;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
}
.main_header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #234a64;
  z-index: -1;
}
.header_frame {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

.title_frame {
  display: flex;
  align-items: center;
  gap: 12px;
}

.logo {
  height: 48px;
  width: auto;
}

.site_title {
  font-family: 'Catenary Stamp', sans-serif;
  font-size: 18px;
  color: #eabda8;
  line-height: 1.2;
}

/* Menü-Links Standard */
.main_nav a,
.header_button {
  color: rgba(244, 244, 244, 1) !important;
  text-decoration: none;
  font-family: "Afacad", sans-serif;
  font-size: 16px;
  padding: 4px 8px;
}

.main_nav a:hover,
.header_button:hover {
  text-decoration: underline;
}

/* Burger Button */
.burger_button {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 1001;
  position: absolute;
  right: 16px;
  top: 20px;
  color: rgba(244, 244, 244, 1);
}

.burger_bar {
  width: 24px;
  height: 2px;
  background-color: rgba(244, 244, 244, 1);
  transition: all 0.3s ease;
}

/* Mobile Navigation */
@media (max-width: 768px) {
  .main_nav {
    position: absolute;
    top: 70px;
    left: 0;
    right: 0;
    background-color: #234a64;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 20px 0;
    display: none;
  }

  .main_nav.active {
    display: flex;
  }

  .burger_button {
    display: flex;
  }

 */ .anchor_buttons {
    display: none !important;
  }*/
}
/* Standardzustand – mobil geschlossen */
.main_nav {
  display: none;
  flex-direction: column;
  background-color: #234a64;
  position: absolute;
  top: 70px;
  left: 0;
  right: 0;
  gap: 16px;
  padding: 20px 0;
  align-items: center;
  z-index: 1000;
}

/* Aktiv (wenn Burger geklickt) */
.main_nav.active {
  display: flex;
}

/* Burger sichtbar machen */
.burger_button {
  display: flex;
}

/* Desktop: Standard horizontales Menü */
@media (min-width: 992px) {
  .main_nav {
    display: flex !important;
    position: static;
    flex-direction: row;
    justify-content: flex-end;
    gap: 36px;
  }

  .burger_button {
    display: none;
  }
}
.section_header_about {
  max-width: 1200px;           /* gleiche Breite wie Inhalt */
  margin: 0 auto;
  padding-left: 20px;          /* oder so viel wie der Innenabstand von .about_us_descriptions */
  padding-right: 20px;
  text-align: left;
  font-size: 32px;
}
.section_header.section_header_about {
  font-size: 32px;
  margin-bottom: 1.5em; /* oder z. B. 2em für etwas mehr Abstand */
}
/* Basis: Mobil (unter 768px) */
.section_header_about {
  padding-left: 12%;
}

@media (min-width: 768px) and (max-width: 991px) {
  .section_header_about {
    padding-left: 17%;
   }
}

@media (min-width: 1200px) {
  .section_header.section_header_about {
    padding-left: 12% !important;
  }
}
.section_wrapper {
  overflow: visible !important;
  text-align: left; /* wichtig */
}

.section_header_feedback {
  padding-left: 27%!important;
  display: block !important;
}
.section_header {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 6px;
  margin-top: 0;
  padding-top: 0;
  display: block;
  text-align: left;
  padding-left: 12%;
}
.section_header_narrow {
  padding-left: 0 !important;
}

@media (min-width: 768px) and (max-width: 991px) {
  .section_header {
    padding-left: 17%;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .section_header {
    padding-left: 9%;
  }
}

@media (min-width: 1200px) {
  .section_header {
    padding-left: 25%;
  }
}
.feedback_carousel {
  display: flex;
  overflow-x: auto;
  gap: 20px;
  padding: 20px 12%;
  scroll-snap-type: x mandatory;
  box-sizing: border-box;
}

.feedback_card {
  flex: 0 0 260px;
  scroll-snap-align: start;
  background: #f5f5f5;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  font-size: 1rem;
  min-height: 150px;
}

.feedback_carousel::-webkit-scrollbar {
  display: none;
}
.feedback_carousel {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
/* Global fix für unerwünschtes horizontales Scrollen */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}
.map-box,
.tour-box {
  flex: 1 1 100%;
  min-width: 0;
  width: 100%;
  background: transparent;
  margin-bottom: 30px;
}
.catenary {
  font-family: 'Catenary Stamp', sans-serif;
  font-weight: bold;
}
/* ----------------------------------------
   🔹 13. Preise & Rechtliches
---------------------------------------- */

.prices_wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: 40px 5%;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #234a64;
  padding-top: 100px; /* für den Header oben */
}

@media (max-width: 600px) {
  .prices_wrapper {
    padding: 20px 6%;
  }

  .section_header_big {
    font-size: 26px;
  }

  p {
    font-size: 17px;
    line-height: 1.5;
  }
}


.legal_hint {
  background-color: #f0f0f0;
  border-left: 4px solid #eabda8;
  padding: 1rem;
  margin-top: 2rem;
  border-radius: 8px;
}

.legal_hint h2 {
  font-size: 1.4rem;
  margin-bottom: 0.8rem;
  color: #234a64;
}

.checklist {
  list-style: none;
  padding-left: 0;
  margin-top: 1.5rem;
}

.checklist li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 0.8rem;
  font-size: 1.1rem;
}

.checklist li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: #eabda8; /* euer warmes Highlight */
  font-weight: bold;
  font-size: 1.2rem;
}

.image_section {
  margin: 2rem 0;
  text-align: center;
}

.image_section img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
  transition: opacity 0.3s ease-in-out;
}

/* Halbtransparente Variante */
.faded_image img {
  opacity: 0.5;
}

.faded_image img:hover {
  opacity: 1;
}

/* ----------------------------------------
   🔹 15. Datenschutz & Einzelseiten-Layout
---------------------------------------- */

.datenschutz_section {
  max-width: 800px;
  margin: 0 auto;
  padding: 120px 5% 60px;
  color: #234a64;
  font-size: 16px;
  line-height: 1.6;
}

.datenschutz_section h1,
.datenschutz_section h2,
.datenschutz_section h3 {
  color: #234a64;
  margin-top: 2rem;
  margin-bottom: 1rem;
  line-height: 1.3;
}

.datenschutz_section h1 {
  font-size: 32px;
  font-weight: 600;
  margin-left: 0;
  padding-left: 0; /* oder max. 1rem, je nach Textabstand */
}


.datenschutz_section h2 {
  font-size: 20px;
  font-weight: 600;
}

.datenschutz_section p,
.datenschutz_section li {
  margin-bottom: 1rem;
}

.datenschutz_section a {
  color: #234a64;
  text-decoration: underline;
}

.datenschutz_section ul,
.datenschutz_section ol {
  padding-left: 1.2rem;
  margin-bottom: 1.5rem;
}

.datenschutz_section .seal {
  font-size: 0.9rem;
  color: #777;
  margin-top: 3rem;
  border-top: 1px solid #ccc;
  padding-top: 1rem;
}

@media (max-width: 600px) {
  .datenschutz_section {
    padding: 100px 6% 40px;
    font-size: 15px;
  }

  .datenschutz_section h1 {
    font-size: 26px;
  }

  .datenschutz_section h2 {
    font-size: 18px;
  }
}