/* ========== Grundstyles ========== */
/* playfair-display-sc-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display SC';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/playfair-display-sc-v17-latin/playfair-display-sc-v17-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-sc-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display SC';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/playfair-display-sc-v17-latin/playfair-display-sc-v17-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/roboto-v47-latin/roboto-v47-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/roboto-v47-latin/roboto-v47-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
@font-face {
  font-family: 'Playfair var';
  src: url('../fonts/playfair/Playfair[opsz,wdth,wght].ttf') format('truetype');
  font-display: swap;
}



/* Reset */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  width: 100%;
  overflow-x: hidden;
  height: calc(var(--vh) * 100);
}

body {
  font-family: "Roboto", sans-serif;
  line-height: 1.5;
  padding: 0px;
  background-color: #fafafa;
  color: #000;
  max-width: 100%;
  scroll-behavior: smooth; 
  overflow-x: hidden;
  height: calc(var(--vh) * 100);
}

a {
  color: inherit;
  text-decoration: none;
}

/* ========== Intro Texteeeeee ========== */
.intro-text {
  padding: 6rem 1rem;
  padding-bottom: 2rem;
  max-width: 1200px;
  margin: 0 auto !important;
  text-align: center;
}
.intro-text h2 {
  font-size: 2.5rem;
  font-family: 'Playfair Display SC';
  text-transform: uppercase;
  font-weight: 400;
  padding-top: 2rem;
}
.intro-text p {
  font-size: 1rem;
  font-weight: 300;
  color: #646464;
}
@media (max-width: 768px) {
  .intro-text h2 {
    font-size: 2rem;
  }
}
@media (max-width: 480px) {
  .intro-text .intro-heading h2 {
    font-size: 1.6rem !important;
  }
}

/* Formular */
form {
  display: flex;
  flex-direction: column;
  width: 100%;
}

/* Inline-Kalender */
/* ---------- Container für Inline-Kalender ---------- */
#inline-calendar {
  width: 100%;
  margin: 2.5rem auto;
  border: none;
  border-radius: 0px;
  padding: 10px;
  min-height: 320px; /* Platzhalter */
  display: flex;
}


/* ---------- Flatpickr-Kalender im RangeMode/Inlinedarstellung ---------- */
.flatpickr-calendar.rangeMode.inline {
  margin: 0 auto;
  /* Wir lassen Flatpickr selbst die Breite verwalten,
     aber begrenzen maximal. */
  width: auto !important;
  max-width: 100%;
  min-height: 320px;
  border-radius: 0px;
  padding: 10px;
  display: flex;
  flex-direction: column; /* Damit Monate untereinander zentriert bleiben */
  box-shadow: 0 -2px 8px rgba(0,0,0,0.1) !important;
}

/* ---------- Innerer Container ---------- */
.flatpickr-innerContainer {
  margin: 0 auto !important;
  width: auto !important;
  max-width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  overflow: visible !important;
}


/* ---------- Weekday-Container (Mo,Di,Mi...) ---------- */
.flatpickr-weekdaycontainer {
  display: flex;
  justify-content: space-around;
  flex: 1; /* Verteilt die Wochentage schön über die Breite */
}

.flatpickr-days.dayContainer {
  margin: 0 auto !important;
  /* Wir lassen Flatpickr selbst die Breite verwalten,
     aber begrenzen maximal. */
  width: auto !important;
  max-width: 100%;
  justify-content: space-between !important;
  text-align: center !important;
}

/* Größere Tagesfelder */
.flatpickr-day {
  width: 2.4rem;
  height: 2.4rem;
  line-height: 24px;
  margin: 1px;
  font-size: 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  color: rgba(57, 57, 57, 0.3);
}

.flatpickr-day.flatpickr-disabled {
  text-decoration: line-through !important;
  opacity: 0.4 !important; /* Damit sie leicht ausgegraut sind */
  color: red !important;
}

.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.startRange,
.flatpickr-day.selected.endRange,
.flatpickr-day.selected.startRange:hover,
.flatpickr-day.selected.endRange:hover,
.flatpickr-day.selected.startRange,
.endRange:not(:nth-child(7n+1)), 
.flatpickr-day.startRange.startRange,
.endRange:not(:nth-child(7n+1)) {
  border-radius: 50px 50px 50px 50px !important;
  background: #000000 !important;
  color: #fefefe !important;
  background-color: none !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
}



.flatpickr-day.inRange,
.flatpickr-day.inRange:hover {
  border-radius: 50px !important;
  background: #e6e6e6 !important;
  border: 1px solid #e6e6e6 !important;
  box-shadow: none !important;
}


/* Container der Monate */
.flatpickr-months {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 1.5rem; /* Abstand zwischen den Monatsblöcken */
}

/* Jeder einzelne Monatsblock */
.flatpickr-month {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* In .flatpickr-current-month liegen Monat + Jahr. */
.flatpickr-current-month {
  display: flex !important;
  flex-direction: row !important; /* So liegen Monat + Jahr/Span nebeneinander */
  align-items: center !important;
  justify-content: center !important;
  gap: 2rem; /* Für etwas Abstand */
  font-size: 1rem !important;
  padding: 5px !important;
}


/* Monatstext (z. B. "Mai"), klickbar fürs Dropdown */
.cur-month {
  font-weight: bold;
  font-size: 1rem;
  cursor: pointer;
  color: #000; /* Sichergestellt, dass es sichtbar ist */
}
.cur-month:hover {
  background-color: none !important;
  background: none !important;
}

/* Jahr-Eingabe, das Flatpickr standardmäßig rendert. 
   Wir ersetzen es per JS durch ein <span>. 
   Falls das Input doch auftaucht, z.B. vor JS, machen wir es unsichtbar. */
.cur-year {
  display: none !important;
}

/* Die hoch/runter Pfeile fürs Jahr wollen wir ausblenden */
.arrowUp,
.arrowDown {
  display: none !important;
}

/* Vor-/Zurück-Pfeile für Monate (links/rechts) bleiben sichtbar */
.flatpickr-prev-month,
.flatpickr-next-month {
  cursor: pointer;
}
.flatpickr-prev-month svg,
.flatpickr-next-month svg {
  width: 1rem;
  height: 1rem;
  fill: #000;
}

.flatpickr-current-month .numInputWrapper {
  width: auto !important;
  height: auto !important; /* oder 30px, wenn du eine feste Höhe willst */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1rem !important;
  margin: 0 !important; /* ggf. Ränder entfernen */
  padding: 0 !important; 
  background-color: none !important;
  background: none !important;
}


.my-year-span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: middle !important;
  color: #000 !important;
  font-size: 1rem !important;
  font-weight: bold;
  cursor: pointer;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 1 !important;
  
  background: none !important;
}


.my-year-span:hover {
  opacity: 1 !important;
  
  background: none !important;
}


/* ---------------------------------------------
 * 2) CUSTOM-DROPDOWN (Overlay von unten)
 * --------------------------------------------- */
.custom-dropdown-container {
  position: fixed;
  left: 0; 
  right: 0; 
  bottom: 0;
  z-index: 9999;
  height: 50vh;
  background: #fefefe;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
  box-shadow: 0 -2px 8px rgba(0,0,0,0.2);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transform: translateY(100%);
  transition: transform 0.3s ease;
  display: none; 
}

@media (max-width: 768px) {
  .custom-dropdown-container {
    height: 75vh;
  }
}

/* Hochfahren (öffnen) */
.custom-dropdown-container.slide-up {
  transform: translateY(0);
}
/* Runterfahren (schließen) */
.custom-dropdown-container.slide-down {
  transform: translateY(100%);
}

/* Dropdown-Einträge */
.custom-dropdown-item {
  padding: 1rem;
  display: flex;
  align-items: center;
  cursor: pointer;
  border-bottom: 1px solid rgba(0,0,0,0.15);
}
.custom-dropdown-item:last-child {
  border-bottom: none;
}

/* Markierungskreis rechts */
.selection-circle {
  margin-left: auto;
  width: 1rem; 
  height: 1rem;
  border-radius: 50%;
  border: 1.5px solid #000;
}
.selection-circle.selected {
  background: #000;
  border-color: #000;
}


/* Container */
.booking-section {
  width: 60%;
  margin: 15px auto 0 auto; 
  justify-content: center;
}
@media (max-width: 768px) {
  .booking-section {
    width: 327px;
  }
}
@media (min-width: 1200px) {
  .booking-section {
    width: 63%;
  }
}


/* Gästeauswahl Section */
.row-of-6 {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  max-width: 768px;
  margin-bottom: 0.5rem;
}
.row-of-6 > * {
  flex: 1 1 calc(50% - 15px); /* 2 nebeneinander auf Desktop */
  min-width: 250px;
}


@media (max-width: 1024px) {
  .row-of-6 {
    flex-direction: column;
    flex-wrap: wrap;
  }
  .row-of-6 > * {
    flex: 1 1 100%;
    max-width: 100%;
  }
}
@media (min-width: 1024px) {
  .row-of-6 {
    margin: 0 auto;
  }
}





/* "Fake-Felder" */
.field-wrapper {
  border: 1px solid #c9c9c9;
  background-color: #fefefe;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  border-radius: 0px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 12px;
  min-height: 48px;
  position: relative;
}


.field-wrapper svg {
  width: 1.4rem;
  height: 1.4rem;
}

/* Linker Teil => Icon + Label */
.field-left {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
}

/* Rechter Teil => Wert + Pfeil */
.field-right {
  display: flex;
  align-items: center;
  gap: 0px;
  text-align: right;
}


.field-value {
  font-weight: 400;
  min-width: 30px;
  padding-right: 1.6rem;
}


/* Input/Select unsichtbar, aber klickbar */
.field-wrapper input[type="text"],
.field-wrapper select{
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: default;
  z-index: 1;                           /* Eine Ebene unter dem ✕ */
}

/* ------------- ✕-Button */
.clear-btn{
  position: absolute;                   /* frei platzieren */
  right: .8rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;                           /* liegt über dem Overlay  */
  display: none;                        /* wird per JS ein-/ausgeblendet */
  background: none;
  border: 0;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  color: #000;
  background-color: #eee;
  padding: .15rem .3rem;
  border-radius: 0px;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  transition: 0.3s ease;
}
.field-right:hover .clear-btn{ opacity: 0.7; }

.stepper {
  display: flex;
  align-items: center;
  gap: 0.6rem
}
.stepper button {
  width: 2rem;
  height: 2rem;
  border: none;
  border-radius: 0px;
  background: #eee;
  cursor: pointer;
  font-size: 1.1rem;
  color: #000;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
}
.stepper button:disabled {
  opacity: 0.4;
  cursor: default
}





/* Überschriften, Preisanzeige */
.price-title {
  position: relative;
  font-family: 'Roboto';
  font-size: 1.4rem;
  margin-bottom: 0px;
  text-align: left;
  line-height: 1.6;
}

.price-title::after {
  content: "";
  position: absolute;
  top: 2.2rem; /* Abstand der Linie vom Text; hier 10px oberhalb des Elements, passe den Wert nach Bedarf an */
  left: 0;
  right: 0;
  height: 1px; /* Dicke der Linie */
  background-color: #e8e8e8; /* Farbe und Opacity der Linie (0.5 entspricht 50% Opacity) */
}

#price_details {
  margin-top: .5rem;
}

.price-row {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5px;
  font-size: 1.1rem;
  border-bottom: 1px solid #e8e8e8;
  line-height: 2.2;
}
.price-row-left {
  display: inline-flex;
  align-items: center;
  gap: 6px;          /* Abstand zwischen Icon und Text */
}
.price-row svg {
  width: 1rem;
  height: 1rem;
}

.final-price {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
  font-size: 1.2rem;
  line-height: 1.6;
}



/* Form-Aktionen */
.form-actions {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 22px;
  margin-bottom: 22px;
}
.form-actions-booking {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 22px;
  margin-bottom: 22px;
}
.form-actions-booking button,
.form-actions button {
  border: 1px solid #484848;
  background-color: #fefefe;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  color: #000;
  padding: 10px 20px;
  font-size: 1rem;
  font-weight: 300;
  cursor: pointer;
  border-radius: 0px;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.form-actions-booking button:disabled,
.form-actions button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.form-actions-booking button:hover,
.form-actions button:hover {
  background-color: #000;
  color: #fefefe;
}







/* Details.phphphpph */
/* Container für das Formular */
/* Container für das Formular */
/* Container für das Formular */
.form-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
}


.section {
  margin: 2rem 0;
}
.section-notes {
  margin-bottom: 1rem;
}
.section-sum-last {
  margin-top: 5rem;
}
.section-pay {
  margin-bottom: 2rem;
}

.details-box {
  padding: 1rem;
  margin: 3rem 0;
}

/* Allgemeine Form-Reihen */
.form-row {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row !important;
  gap: 15px;
  margin-bottom: 10px;
}

/* Form-Gruppen: Label über Input */
.form-group {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.form-group label {
  font-weight: 700;
}

/* Breitenklassen */
.full-width {
  flex: 1 1 100%;
  
}

.half-width {
  flex: 1 1 calc(50% - 15px);  
}

.one-third {
  flex: 1 1 calc(33.33% - 15px);
}

.two-thirds {
  flex: 1 1 calc(66.66% - 15px);
  
}

/* Styling der Input-Felder und des Textareas */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  padding: 10px;
  border: 1px solid #c9c9c9;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  border-radius: 0px;
  font-size: 1rem;
  font-family: 'Roboto';
}

/* Platzhalter in grau */
input::placeholder,
textarea::placeholder {
  background-color: #fefefe !important;
  font-family: 'Roboto';
  font-size: 1rem;
}

/* Großzügigeres Textarea */
textarea {
  resize: vertical;
  font-family: 'Roboto';
}


/* Mini Felder TT / MM / JJJJ gleich breit */
.form-row input[type="number"][placeholder="TT"],
.form-row input[type="number"][placeholder="MM"]{
  flex:1 1 30%;
  text-align:center;
}
.form-row input[type="number"][placeholder="JJJJ"]{
  flex:1 1 40%;
  text-align:center;
}

.checkbox-container {
  display: flex;
  align-items: center;
  font-family: sans-serif;
  gap: .3rem;
  flex-wrap: wrap;
}

.checkbox-container input[type="checkbox"] {
  appearance: none;
  width: 16px;
  height: 16px;
  border: 1px solid #000;
  background-color: transparent;
  cursor: pointer;
  border-radius: 0; /* Kein Border-Radius */
  display: inline-block;
  position: relative;
  transition: all 0.3s ease;
  justify-content: center;
  align-items: center;
}

/* Farbe ändern wenn angeklickt */
.checkbox-container input[type="checkbox"]:checked {
  background-color: #000; /* z. B. Honig-Gelb */
  border-color: #000;
}

/* Optional: Haken anzeigen */
.checkbox-container input[type="checkbox"]::after {
  content: '';
  position: absolute;
  top: 1px;
  left: 4px;
  width: 4px;
  height: 8px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  opacity: 0;
}

.checkbox-container input[type="checkbox"]:checked::after {
  opacity: 1;
}

/* Link optisch angleichen */
.checkbox-container a {
  color: #000;
  text-decoration: underline;
}










/* Zahlungs-Container */
.payment-container {
  border: 1px solid #c9c9c9;
  background-color: #fafafa;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  padding: 0px 0px;
  margin-bottom: 40px;
  border-radius: 0px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: 10px;
  row-gap: 5px;
}
.payment-container button {
  color: #000;
  border: 1px solid #c9c9c9;
  background-color: #fefefe;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  padding: 10px 20px;
  font-size: 1rem;
  cursor: pointer;
  border-radius: 0px;
  transition: background-color 0.3s ease, color 0.3s ease;
  margin-bottom: 0px;
}
.payment-container button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.payment-container button:hover {
  background-color: #000;
  color: #fff;
}


.section-pay {
  text-align: left;
  justify-content: center;
  max-width: 750px;
  margin: 3rem 0;
  margin-bottom: 5rem;
}



/* Rabattcode-Container */
.discount-container {
  display: flex;
  align-items: center;
  gap: 10px;
}
.discount-container input[type="text"] {
  flex: 1;
  margin: 0;
}

.discount-container button {
  border: 1px solid #c9c9c9;
  background-color: #fefefe;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03), 0px 3px 6px rgba(0, 0, 0, 0.02);
  color: #000;
  padding: 10px 20px;
  font-size: 1rem;
  cursor: pointer;
  border-radius: 0px;
  transition: background-color 0.2s ease, color 0.2s ease;
  margin-bottom: 0px;
}
.discount-container button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.discount-container button:hover {
  background-color: #000;
  color: #fefefe;
}
.discount-row {
  margin-bottom: 5px;
  margin-top: 1.5rem;
}
.discount-row label {
  text-align: left;
  margin-top: 10px;
  font-family: 'Roboto';
  font-weight: 400;
  text-transform: none;
}
#discount_info {
  text-align: left;
  margin-top: -.5rem;
}




/* Preis-Zusammenfassung, Überschriften und Endpreis */

.price-title-details {
  position: relative;
  font-family: 'Roboto';
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.6;
  text-transform: none;
}

.price-title-details::after {
  content: "";
  position: absolute;
  top: 2.2rem; /* Abstand der Linie vom Text; hier 10px oberhalb des Elements, passe den Wert nach Bedarf an */
  left: 0;
  right: 0;
  height: 1px; /* Dicke der Linie */
  background-color: #e8e8e8; /* Farbe und Opacity der Linie (0.5 entspricht 50% Opacity) */
}


.price-summary {
  text-align: center;
}

.final-price-details {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-top: 1rem;
  font-weight: 700;
  font-size: 1.2rem;
  
}
.final-price-details::before {
  content: "";
  position: absolute;
  top: -10px; /* Abstand der Linie vom Text; hier 10px oberhalb des Elements, passe den Wert nach Bedarf an */
  left: 0;
  right: 0;
  height: 1px; /* Dicke der Linie */
  background-color: rgb(0, 0, 0.5); /* Farbe und Opacity der Linie (0.5 entspricht 50% Opacity) */
}

/* Überschriften-Anpassungen */
.sub-title-details {
  font-family: 'Roboto';
  font-size: 1.4rem;
  text-transform: none;
  font-weight: 400;
  text-align: left;
  margin-top: 15px;
  margin-bottom: 0px;
}

.form-actions-details {
  display: flex;
  justify-content: flex-start;
  gap: 10px;
  margin-top: 22px;
  margin-bottom: 22px;
}

/* Responsive Anpassungen */
@media (max-width: 768px) {
  
  .payment-container {
    flex-direction: column;
  }
  .discount-container {
    flex-direction: column;
    align-items: stretch;
  }
  
}

.payment-methods {
  margin-top: 4rem;
  padding: 0 10px;
  display: flex;
  gap: 10px;
  align-items: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.payment-methods img {
  height: 4rem;
  width: auto;
  filter: none;
  transition: filter 0.4s ease;
}

.payment-methods img:hover {
  filter: grayscale(100%);
}






/* ---------------
Success 
------------------*/
body.succes-page {
  font-family: "Roboto", sans-serif;
  line-height: 1.5;
  padding: 20px;
  background-color: #fafafa;
  color: #000;
  width: 100%;
  height: calc(var(--vh) * 100);
  flex-direction: column;
  display: flex;
}

/* Fehlermeldungen */
.error-message {
  background-color: #ffffff;
  color: #000000;
  border-radius: 0px;
  margin-bottom: 1em;
  text-align: left;
  font-size: 1em;
  font-family: 'Roboto';
  font-weight: 400;
}

.intro-text-suc {
  padding: 0rem 1rem;
  padding-top: 6rem;
  max-width: 1200px;
  margin: 0 auto !important;
  text-align: center;
}



/* Container für den Buchungsinhalt */
.success-container {
  background-color: #ffffff;
  padding: 0 2em;
  width: 90%;
  max-width: 800px;
  box-sizing: border-box;
  margin: 0 auto;
  flex: 1;
  margin-top: -6rem;
}

.success-container .intro-text {
  padding-left: 0rem;
  padding-right: 0rem;
}

.intro-heading {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  text-align: center;
  gap: 0.5rem;
  flex-wrap: nowrap;
  max-width: 800px;
}

.intro-heading svg {
  flex-shrink: 0;
  height: 3.5rem;
  width: 3.5rem;
}

@media (max-width: 480px) {
  .intro-heading svg {
    height: 2.5rem;
    width: 2.5rem;
  }
}

.error-container {
  background-color: #ffffff;
  padding: 0 2em;
  width: 90%;
  max-width: 800px;
  height: 100vh;
  box-sizing: border-box;
  margin: 0 auto;
  flex: 1;
  box-shadow: none !important;
  border: none !important;
}

/* ---------------------------- */
/* Buchungsbestätigung-Inhalt     */
/* ---------------------------- */

.success-box {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 0rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  padding: 2rem;
  margin: 3rem 0;
}

.booking-details {
  text-align: left;
  margin-bottom: 2rem;
}

.booking-detail-row {
  display: flex;
  justify-content: space-between;
  padding: 0.5em 0;
  border-bottom: 1px solid #ddd;
  font-size: 1.1rem;
}
.booking-detail-row-spez {
  display: flex;
  justify-content: space-between;
  padding: 0.5em 0;
}

.booking-detail-left {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.detail-label {
  color: #000;
}


.detail-value {
  color: #000;
}

.booking-messages {
  text-align: left;
  margin-bottom: 1.5em;
}

.booking-messages p {
  margin: 0.5em 0;
  font-size: 1.1em;
  color: #333;
}

.booking-buttons-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
}
.booking-buttons-container button {
  min-width: 160px;
}


.booking-buttons {
  text-align: center;
  justify-content: space-between;
  transition: 0.4s ease;
}

.booking-button-download button,
.booking-button-home button,
.booking-button-retry button {
  padding: 10px 20px;
  font-size: 1em;
  cursor: pointer;
  transition: 0.4s ease;
  justify-content: center;
  align-items: center;
}

.download-button {
  background-color: #fefefe;
  color: #000;
  border: 1px solid black;
  border-radius: 0px;
  justify-content: space-between;
  justify-content: center; /* Inhalte horizontal zentrieren */
  align-items: center; /* Inhalte vertikal zentrieren */
  align-self: flex-end;
}

.download-button:hover {
  background-color: #000;
  color: #fff;
  border: 1px solid #fff;
}

.home-button {
  background-color: #fefefe;
  color: #000;
  border: 1px solid black;
  border-radius: 0px;
  align-self: flex-start;
}

.home-button:hover {
  background-color: #000;
  color: #fff;
  border: 1px solid #fff;
}

.retry-button {
  background-color: #fefefe;
  color: #000;
  border: 1px solid black;
  border-radius: 0px;
  align-self: flex-end;
}

.retry-button:hover {
  background-color: #000;
  color: #fff;
  border: 1px solid #fff;
}

@media screen and (max-width: 600px) {
  .success-container {
    padding: 1em;
    width: 95%;
  }
  
  .success-header h1 {
    font-size: 2em;
  }
  
  .success-header .subheading {
    font-size: 1.2em;
  }
  
  .booking-buttons button {
    margin-bottom: 10px;
  }
}





/*=====================================*/
/*=====================================*/
/*=====================================*/

/* Navba mit html auf andere übertragen und header.js chekcne */

/*=====================================*/
/*=====================================*/
/*=====================================*/

.navbar-white {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding: 20px;
  height: 12vh;
  z-index: 999;
  transition: all 0.5s ease;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  font-family: 'Playfair Display SC';
  padding-top: 2.5rem;
}
@media (max-width: 768px) {
  .navbar-white {
    height: 10vh;
  }
}

.navbar-white.initial-white {
  background-color: transparent;
  color: white;
  font-family: 'Playfair Display SC';
  
}

.navbar-white.scrolled {
  background-color: white;
  color: black;
  border-bottom: 1px solid black;
  height: 8vh;
  padding-top: 20px;
}

.navbar-white.menu-open .center-button-white {
  display: none;
}
.navbar-white.menu-open .mobile-nav-white {
  justify-content: space-between;
}

/* Mobile Navigation */
.mobile-nav-white {
  display: flex;
  width: 100%;
  justify-content: space-between;
  z-index: 1200;
  align-items: center;
  position: relative;
}



.logo-place-white img {
  width: 3.5rem;
  height: 3.5rem;
  padding-top: 3px;
  transition: 0.3s ease;
}
.navbar-white.scrolled .logo-place-white img {
  width: 2.8rem;
  height: 2.8rem;
  padding-top: 3px;
  /* Passe hier ggf. weitere Abstände an */
}

.menu-toggle-container-white {
  display: flex;
  align-items: center;
  flex-direction: row;
  z-index: 1200;
}

/* Burger Menu */
.menu-toggle-white {
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 2rem;
  height: 2rem;
  justify-content: center;
  align-items: center;
  align-self: flex-end;
  
}
.menu-toggle-white.active {
  align-self: flex-end;
}
.burger-white {
  width: 2.2rem;
  height: 0.33rem;
  background-color: none;
  transition: 0.4s;
  border-radius: 2rem;
  transform-origin: center;
  border: 1.3px solid black;
}


.menu-toggle-white.active .burger-white:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
  background-color: none;
  border: 1.3px solid white;
}
.menu-toggle-white.active .burger-white:nth-child(2) {
  opacity: 0;
}
.menu-toggle-white.active .burger-white:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
  background-color: black;
  border: 1.3px solid white;
}

/* Menü-Label */
.menu-label-white {
  right: 0.5rem;
  color: black; /* Von Anfang an schwarz */
  font-family: 'Playfair Display SC', sans-serif;
  text-transform: uppercase;
  font-size: 1rem;
  position: relative;
  text-align: center;
  justify-content: center;
  align-items: center;
  transition: 0.44s ease;
}
@media (max-width: 769px) {
  .menu-label-white {
    font-size: 0.9rem;
  }
}
.menu-label-white span {
  display: inline-block;
  transition: color 0.3s;
  position: relative;
}

/* Slide-out (nach oben raus) */
.slide-out {
  animation: slideOut 0.3s ease;
}

/* Slide-in (von oben rein) */
.slide-in {
  animation: slideIn 0.3s ease;
}

@keyframes slideOut {
  from {
    transform: translateY(0);
    opacity: 1;
  }
  to {
    transform: translateY(-100%);
    opacity: 0;
  }
}

@keyframes slideIn {
  from {
    transform: translateY(100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* Burger im scrolled Zustand (Farbe wechseln) */
.navbar-white.scrolled .burger-white {
  background-color: none;
  border: 1.3px solid black;
}
.navbar-white.scrolled .menu-label-white {
  color: black;
}

/* Ausklappbares Menü (Mobile) */
.nav-menu-white {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: black;
  transform: translateY(-100%);
  transition: 0.5s;
  opacity: 0;
  z-index: 998;
  display: flex;
  align-items: center;
  justify-content: left;
  padding-left: 3rem;
}

.nav-menu-white.active {
  transform: translateY(0);
  opacity: 1;
}

/* Wrapper für die vier Spalten */
.menu-white-grid {
  display: flex;
  flex-direction: column;
  gap: 0px;
  padding-top: 4rem;
}


@media (min-width: 480px) {
  .menu-white-grid {
    display: flex;
    flex-direction: column;
    gap: 0px;
    padding-top: 4rem;
  }
  .nav-menu-white {
    justify-content: left;
    padding-left: 6rem !important;
  }
  .menu-column li {
    margin-bottom: 1.5rem !important;
  }
  .menu-column a {
    color: white;
    font-size: 2rem !important;
    text-transform: capitalize;
    font-family: 'Playfair Display SC';
    text-decoration: none;
    transition: 0.3s ease;
  }
}
/* Ab Tablet: vier Spalten nebeneinander */
@media (min-width: 1024px) {
  .menu-white-grid {
    display: grid;
    grid-template-columns: repeat(4, auto);
    gap: 6rem !important;
    margin-top: -2rem;
    padding: 2rem;
  }
  .nav-menu-white {
    justify-content: center;
    padding-left: 0rem !important;
  }
  .menu-column li {
    margin-bottom: 1.5rem;
  }
}


.menu-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.menu-column li {
  margin-bottom: 1rem;
}

.menu-column a {
  color: white;
  font-size: 1.8rem;
  text-transform: uppercase;
  font-family: 'Playfair var';
  font-weight: 200;
  text-decoration: none;
  transition: 0.3s ease;
}

.menu-column a:hover {
  color: #ffffff8c;
}

/* Reservieren-Button */
.nav-menu-button-white {
  border: 1px solid black;
  background-color: white;
  color: black;
  text-align: center;
  font-size: 1.8rem;
  transition: 0.5s ease;
  font-family: 'Playfair var';
  font-weight: 200;
  text-transform: uppercase;
  display: inline-block;
  margin-top: -0.25rem;
  cursor: pointer;
  padding: 0.2rem 1.2rem;
}

.nav-menu-button-white:hover {
  border: 1px solid white;
  background-color: black;
  color: white !important;
}











/* ====================================
   Footer
==================================== */
.footer {
  background: #000;
  color: #fefefe;
  padding: 3rem 2rem;
  margin-top: 6rem;
  padding-bottom: 1.5rem;
}

.footer-content {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2rem;
  margin-bottom: 2rem;
}

.footer-section h4 {
  color: #fefefe;
  margin-bottom: 1rem;
  font-size: 1.5rem;
  font-family: 'Playfair Display SC';
}
.footer-section h5 {
  color: #fefefe;
  margin-bottom: 1rem;
  font-size: 1rem;
  font-family: 'Playfair Display SC';
}

.footer-label {
  color: #fefefe;
}

.footer-section p {
  color: #ccc;
  line-height: 1.6;
  font-family: 'Roboto';
  margin: 0;
}

.footer-section ul {
  list-style: none;
  padding-left: 0;
  font-family: 'Roboto';
}

.footer-section ul li {
  margin-bottom: 0.5rem;
  font-family: 'Roboto';
}

.footer-section ul li a {
  color: #ccc;
  text-decoration: none;
  transition: 0.3s ease;
  font-family: 'Roboto';
}
.footer-section ul li a:hover {
  color: #aaa;
}

.social-links {
  display: flex;
  gap: 1rem;
}

.footer-bottom {
  text-align: center;
  font-size: 0.9rem;
  color: #aaa;
}

.footer-bottom p {
  padding: 0;
}



.payment-methods {
  margin-top: 2rem;
  display: flex;
  gap: 10px;
  align-items: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.payment-methods img {
  height: 4rem;
  width: auto;
  filter: none;
  transition: filter 0.4s ease;
}

.payment-methods img:hover {
  filter: grayscale(100%);
}


/*----------------------------
     Progress Bar
-----------------------------*/
.progress-container {
  max-width: 1200px;
  margin: 2rem auto;
  margin-bottom: 0rem;
  padding: 0 1rem;
}

.progress-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  position: relative;
}

.step {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  pointer-events: none;
  text-decoration: none;
}

.step-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: inherit;
  width: 100%;
  height: 100%;
}


.step.done {
  pointer-events: auto;
}

.circle {
  width: 1.6rem;
  height: 1.6rem;
  background: #eee;
  color: #000;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  font-size: 0.9rem;
  z-index: 2;
}

.step.done .circle {
  background: #000;
  color: #fff;
}

.label {
  margin-top: 0.3rem;
  font-size: 0.75rem;
  color: #444;
}

/* Linien zwischen den Punkten */
.step::after {
  content: "";
  position: absolute;
  top: 0.8rem;
  left: 50%;
  width: 100%;
  height: 2px;
  background: #eee;
  z-index: 1;
  transform: translateX(0);
}

.step.done::after {
  background: #000;
}

/* Letzter Punkt bekommt keine Linie */
.step:last-child::after {
  display: none;
}

/* Verhindere Doppellinienüberstand */
.step:nth-child(1)::after { width: calc(100% + 0.5rem); }
.step:nth-child(2)::after { width: calc(100% + 0.5rem); }
.step:nth-child(3)::after { width: calc(100% + 0.5rem); }

/* Responsive: Umbruch früher */
@media (max-width: 768px) {
  .progress-bar {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 2.4rem;
  }

  /* Linien auch bei Zeilenumbruch sichtbar */
  .step::after {
    top: 0.8rem;
    height: 2px;
  }
  .step:nth-child(3)::before {
    content: "";
    position: absolute;
    top: 0.8rem;
    left: -50%; /* nach links raus, Länge manuell angepasst */
    width: 110%;
    height: 2px;
    background: #eee;
    z-index: 1;
  }

  .step.done:nth-child(3)::before {
    background: #000;
  }
}

body.theme-warm{
  background:#ffffff;
  color:#2b2b2b;
}

.theme-warm .booking-section,
.theme-warm .form-container,
.theme-warm .success-box,
.theme-warm .error-container{
  background:#ffffff;
  border:1px solid #e8e8e8;
  border-radius:14px;
  box-shadow:0 10px 30px rgba(27,16,1,.06);
  padding:20px;
}

.theme-warm .details-box{background:#ffffff;border:1px solid #e8e8e8;border-radius:12px}

.theme-warm .field-wrapper{border-color:#c9c9c9;background:#fff;border-radius:14px;min-height:54px}

.theme-warm input[type="text"],
.theme-warm input[type="email"],
.theme-warm input[type="tel"],
.theme-warm textarea{
  border-color:#c9c9c9;
  background:#fff;
  border-radius:12px;
}
.theme-warm input:focus,
.theme-warm textarea:focus{outline:2px solid rgba(0,0,0,.15);outline-offset:1px}


.theme-warm .progress-container{margin-top:2.5rem}
.theme-warm .circle{background:#f3f3f3;color:#6e6e6e}
.theme-warm .step.done .circle{background:#000;color:#fff}
.theme-warm .label{color:#6e6e6e}
.theme-warm .step::after{background:#e8e8e8}
.theme-warm .step.done::after{background:#000}

.theme-warm .payment-methods img{filter:saturate(1.1) contrast(1)}

.theme-warm .form-group{position:relative}
.theme-warm .form-group label{position:absolute;top:6px;left:12px;font-size:.8rem;color:#6e6e6e;opacity:.85;pointer-events:none}
.theme-warm .form-group input[type="text"],
.theme-warm .form-group input[type="email"],
.theme-warm .form-group input[type="tel"],
.theme-warm .form-group textarea{padding-top:1.6rem}

.theme-warm #payment-element{background:#fff;border:none;border-radius:12px;padding:10px;box-shadow:0 2px 10px rgba(0,0,0,.06)}

.theme-warm #inline-calendar{border-radius:12px;overflow:hidden}
.theme-warm .flatpickr-calendar.rangeMode.inline{border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.06)}

.theme-warm #booking-form{width:fit-content;max-width:100%;display:inline-block}

.theme-warm .success-hero{width:100%;max-width:800px;margin:1rem auto 0;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.06);display:block}

.theme-warm .error-container{padding:0 2rem;margin-top:0;height:auto}

.theme-warm .booking-section{width:auto;max-width:100%;display:flex;justify-content:center}

.theme-warm .form-actions-booking button,
.theme-warm .form-actions button,
.theme-warm .payment-container button,
.theme-warm .discount-container button,
.theme-warm .download-button,
.theme-warm .home-button,
.theme-warm .retry-button{ border-radius:12px }
