@charset "UTF-8";
/*
 Theme Name:     Divi Child-Theme
 Theme URI:      http://www.elegantthemes.com
 Description:    Divi Child-Theme
 Author:         
 Author URI:     
 Template:       Divi
 Version:        1.0.0
*/

/* New css data
------------------------------------------------------- */
:root {
  --text-dark-blue: #0a6eb3;
  --color-blue: #0e71b4;
  --color-green: #83b81f;
  --color-black: #333333;
  --color-white: #ffffff;
  --btn-primary: #2ba9dc;
}
h1 {
  font-size: 50px !important;
  color: var(--text-dark-blue);
  font-weight: 700;
  line-height: 1;
  font-family: 'segoe bold',Helvetica,Arial,Lucida,sans-serif !important;
}
h2 {
  font-size: 40px;
  color: var(--text-dark-blue);
  line-height: 1;
  /* tablet font size : 35px */
  /* moblie font size : 30px */
}
h3 {
  font-size: 32px;
  color: var(--text-dark-blue);
  line-height: 1;
}
h4 {
  font-size: 26px !important; 
  color: var(--text-dark-blue);
  padding-top: 25px !important;  
  line-height: 1;
}
h5 {
  font-size: 20px;
  color: var(--text-dark-blue);
  line-height: 1;
}
h6 {
  font-size: 18px;
  color: var(--text-dark-blue);
  line-height: 1;
}



/* Borlabs Buttons + TOP Button vom Hover-Effekt ausschließen */
#main-content a.brlbs-cmpnt-cb-btn,
#main-content a[data-borlabs-cookie-unblock],
#main-content a[data-borlabs-cookie-accept-service],
.et_pb_button a,
a#top-link {  /* TOP Button ID anpassen falls nötig */
  position: static !important;  /* relative für ::before-Effekt deaktivieren */
}

#main-content a.brlbs-cmpnt-cb-btn::before,
#main-content a[data-borlabs-cookie-unblock]::before,
#main-content a[data-borlabs-cookie-accept-service]::before {
  display: none !important;  /* ::before komplett ausblenden */
}





 /* 1. Container über grauen Background heben */
#main-content .et_pb_column:not(.et_pb_column--with-menu),
#main-content .et_pb_text,
#main-content .et_pb_text_inner {
  position: relative;
  z-index: 1;  /* ? Container über Grau */
}

/* 2. DEIN ALTES CSS unverändert (z-index: -1 bleibt!) */
#main-content a:not(.et_pb_column--with-menu a),
#main-content .et_pb_column:not(.et_pb_column--with-menu) a {
  text-decoration: none;
  color: var(--color-blue);
  font-weight: 700;
  position: relative;
}

#main-content a:not(.et_pb_column--with-menu a)::before,
#main-content .et_pb_column:not(.et_pb_column--with-menu) a::before {
  content: "";
  background-color: hsla(196, 61%, 58%, 0.75);
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 100%;
  height: 2px;
  z-index: -1;  /* ? HINTER Text, VOR Container */
  transition: all 0.3s ease-in-out;
}

#main-content a:not(.et_pb_column--with-menu a):hover,
#main-content .et_pb_column:not(.et_pb_column--with-menu) a:hover {
  background-color: transparent;
}

#main-content a:not(.et_pb_column--with-menu a):hover::before,
#main-content .et_pb_column:not(.et_pb_column--with-menu) a:hover::before {
  bottom: 0;
  height: 100%;
  background-color: hsla(196, 61%, 80%, 0.75);
}




.et_pb_text_inner::after {
  content: "";
  display: block;
  clear: both;
}
.background-color {
  background-color: #e9f6fb;
}
.background-color .container {
  padding-top: 0px !important;
}
.section-fullwidth-reverse-curves .et_pb_module_heading {
  padding-bottom: 0px !important;
}
.section-fullwidth-reverse-curves {
  position: relative;
  overflow: hidden;
}
.section-fullwidth-reverse-curves .et_pb_button_module_wrapper > a {
  z-index: 1;
}
.section-fullwidth-reverse-curves::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: clamp(400px, 96vw, 800px);
  background: #e9f6fb;
  clip-path: ellipse(70% 100% at 50% 100%);
}
.section-fullwidth-reverse-curves::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: clamp(400px, 100vw, 800px);
  background-color: #e9f6fb;
  clip-path: ellipse(70% 100% at 50% 0);
  z-index: 0;
}
.slider .et_pb_slide_description {
  padding-left: 0px !important;
}

/* style for the Gastgeber */
.gastgeber-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(333px, 1fr));
  gap: 40px;
  padding: 0px 0;
}
.gastgeber-item {
  background: #fff;
  border-radius: 30px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease;
  padding: 10px;
  /* justify-content: space-between; */
}
.gastgeber-item h5 {
  font-weight: bold;
  color: var(--text-dark-blue);
  padding-left: 13px;
  padding-top: 25px;
  padding-bottom: 8px !important;
  font-size: 24px;
}
.gastgeber-item p {
  padding-bottom: 15px;
  padding-left: 13px;
  padding-right: 13px;
}
.gastgeber-image-wrapper {
  position: relative;
  overflow: hidden;
}
.gastgeber-stars-badge {
  position: absolute;
  top: 18px;
  right: 18px;
  background: white;
  color: black;
  padding: 5px 14px;
  border-radius: 20px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
  z-index: 2;
}
.gastgeber-item .gastgeber-image-wrapper img {
  border-top-left-radius: 30px;
  border-top-right-radius: 30px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  display: block;
}
.gastgeber-badge {
  position: absolute;
  top: 77%;
  left: 4%;
  background: #ffffff;
  color: #333;
  padding: 5px 14px;
  border-radius: 20px;
  z-index: 2;
}

.gastgeber-button {
  display: inline-block;
  font-weight: bold;
  font-size: 18px;
  margin-left: 13px;
  background-color: var(--btn-primary);
  color: #fff !important;
  padding: 13px 34px;
  border-radius: 30px;
  border:4px solid #ffffff;
  text-decoration: none;
  margin-right: auto;
  margin-top: 16px;
  margin-bottom: 10px;
  cursor: pointer;
  line-height: 1.4;
}
.gastgeber-button:hover {
  background-color: var(--color-green) !important;
}

.gastgeber-button:active {
  position:relative;
  top:1px;
}

.gastgeber-item .Gastgeber-price {
  font-weight: bold;
  color: var(--color-blue);
  font-size: 20px;
}
.gastgeber-card {
  margin-bottom: 30px;
}
.gastgeber-card .Gastgeber-price {
  color: var(--color-blue);
  font-size: 20px;
}
.gastgeber-card .gastgeber-badge {
  top: 85%;
  left: 1%;
}
.gastgeber-image-wrapper img {
  width: 100%;
  display: block;
  transition: transform 0.4s ease;
  height: 100%;
  object-fit: cover;
}
.gastgeber-wrapper {
  /* margin-top: 20px;
  margin-bottom: 25px; */
  position: relative;
  overflow: hidden;
  cursor: pointer;
}
.gastgeber-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.gastgeber-card h2 {
  /* margin: 16px 0px; */
  /* margin-bottom: 16px;
  font-size: 30px;
  color: #0a6eb3;
  font-weight: bold; */
}
.gastgeber-card h1 {
  font-size: 40px !important;
  margin-bottom: 16px;
  font-weight: bold;
}
.gastgeber-card p , .gastgeber-card li {
  /* margin: 0 16px 5px; */
  font-size: 18px;
  color: #000000;
}
.gastgeber-price {
  font-weight: bold;
  color: #2e8b57;
  font-size: 1.1rem;
}
/* .gastgeber-description {
  margin: 10px 16px 12px;
} */
.gastgeber-long-description ul {
  list-style-type: disc;
  margin-left: 2.1em;
  padding-left: 0;
  padding-bottom: 20px;
}
.gastgeber-prices {
  margin-top: 20px;
  margin-bottom: 20px;
}
.gastgeber-prices p {
  margin-left: 0;
}
.gastgeber-prices span {
  font-size: 22px;
  margin-bottom: 10px;
  font-weight: bold;
  color: var(--text-dark-blue);
}
.gastgeber-contact{
  margin-top: 10px;
}
.gastgeber-contact span {
  /* margin-left: 15px; */
  font-size: 22px;
  /* margin-bottom: 10px; */
  font-weight: bold;
  color: var(--text-dark-blue);
}
.gastgeber-contact-heading {
  margin-left: 22px;
  margin-bottom: 16px;
  color: var(--text-dark-blue) !important;
}
.gastgeber-google-link {
  display: flex;
  justify-content: center;
}
.gastgeber-item .short-description {
  margin-bottom: 24px;
}
.hotel-services-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-content:flex-start;
}
.gastgeber-divider-bottom {
  border: none;
  border-top: 1px solid #f5f5f5;
  margin: auto 13px 0 13px;
}
/* .hotel-services-list {
  margin: 25px 16px 25px;
} */
.tel-text-color .et_pb_blurb_description p a {
  color: white !important;
}
/* Dark (available) */
.service-item.available img {
  filter: none;
  opacity: 1;
}
.service-item.temporary-unavailable img {
  filter: grayscale(100%);
  opacity: 0.4;
}

/* Style for this section Das Rottal entdecken, erleben und genieÃŸen*/
.right-image-blurb .et_pb_blurb_content {
  max-width: 100% !important;
  width: 100%;
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
}
.right-image-blurb .et_pb_main_blurb_image,
.right-image-blurb .et_pb_blurb_container {
  flex: 0 0 50%;
  max-width: 50%;
  margin-bottom: 0px;
}
.right-image-blurb .et_pb_blurb_container {
  display: flex;
  align-items: center;
}
.right-image-blurb .et_pb_blurb_position_left .et_pb_main_blurb_image {
  width: 100%;
}
.right-image-blurb ul {
  padding-bottom: 0 !important;
  list-style: none;
  padding-left: 0;
}
.right-image-blurb ul li {
  padding-bottom: 6px;
}

.right-image-blurb ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

#Massing .et_pb_blurb_description, .Massing .et_pb_blurb_description  {
    margin-left: -40px;
}


.right-image-blurb ul li {
  position: relative;
  padding-left: 1.5em; 
}
.right-image-blurb ul li::before {
  content: "\2714";
  color: var(--color-green);
  font-weight: bold;
  position: absolute;
  left: 0;
  top: 0;
}
.two-columns {
  text-align: justify;
  columns: 2 100px;
  -webkit-columns: 2 100px;
  -moz-columns: 2 100px;
}


.right-image-blurb img {
  width: 100% !important;
}
.right-image-blurb h3 {
  margin-bottom: 30px;
}
.right-image-blurb .et_pb_blurb_description {
  margin-top: 35px;
}
.highlighted-section {
  background-color: #f5fce9 !important;
  transition: background-color 0.3s;
}

/* .vertical-menu-style in rottle in page */
.vertical-menu-style ul {
  display: flex;
  flex-direction: column;
}
.vertical-menu-style ul li {
  border: 5px solid #f4fafe;
  border-radius: 0px 999px 999px 0px;
  margin-bottom: 10px !important;
}
.vertical-menu-style ul li a {
  padding: 27px 100px 27px 25px !important;
  display: block;
  min-width: 300px;
  max-width: 100%;
  box-sizing: border-box;
  line-height: 1;
}
.vertical-menu-style ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 4px;
  height: 100%;
  background-color: var(--text-dark-blue);
  transition: background-color 0.3s;
}
.vertical-menu-style ul li.active a {
  color: var(--color-green) !important;
}
.vertical-menu-style ul li.active::before {
  background-color: var(--color-green) !important;
}
.vertical-menu-style ul li.active {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}
.scroll-section.highlighted-section {
  background-color: #f5fce9;
}

/* Start CSS for the contact form - Minimal Fancy Version */
.custom-contact-form {
  max-width: 700px;
  margin: 40px auto;
  padding: 24px;
  background: #ffffff;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
}
.custom-contact-form input[type="text"],
.custom-contact-form input[type="email"],
.custom-contact-form input[type="tel"],
.custom-contact-form textarea {
  width: 100%;
  padding: 14px 18px;
  margin-bottom: 20px;
  border: 1px solid #ddd;
  border-radius: 10px;
  font-size: 16px;
  background: #f9f9f9;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.custom-contact-form input:focus,
.custom-contact-form textarea:focus {
  border-color: var(--color-green);
  box-shadow: 0 0 0 3px rgba(131, 184, 31, 0.15);
  outline: none;
  background: #fff;
}
.custom-contact-form input::placeholder,
.custom-contact-form textarea::placeholder {
  color: #888;
}
.custom-contact-form input[type="submit"] {
  display: inline-block;
  background-color: var(--btn-primary);
  color: #fff;
  padding: 14px 36px;
  border: none;
  border-radius: 30px;
  font-size: 20px;
  cursor: pointer;
  transition: background-color 0.3s, transform 0.2s;
}
.custom-contact-form input[type="submit"]:hover {
  background-color: var(--color-green);
  transform: translateY(-1px);
}

/* style start  for the all services  */
.accommodation-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  padding: 0;
  margin-bottom: 10px;
}

.accommodation-card {
  background: #fff;
  border-radius: 30px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease;
  padding: 10px;
  justify-content: space-between;
}

.accommodation-grid .accommodation-item img {
  border-top-left-radius: 30px;
  border-top-right-radius: 30px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  display: block;
}

.accommodation-badge {
  position: absolute;
  top: 84%;
  left: 4%;
  background: #ffffff;
  color: #333;
  padding: 5px 14px;
  border-radius: 20px;
  z-index: 2;
}
.accommodation-grid h5 {
  font-weight: bold;
  color: var(--text-dark-blue);
  padding-left: 13px;
  padding-top: 25px;
  padding-bottom: 8px !important;
  font-size: 24px;
}

.accommodation-item p {
  padding-bottom: 15px !important;
  padding-left: 13px;
  padding-right: 13px;
}
.accommodation-item .Gastgeber-price {
  font-weight: bold;
  color: var(--color-blue);
  font-size: 20px;
}

.accommodation-item {
  background: #fff;
  border-radius: 30px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease;
  padding: 10px;
  justify-content: space-between;
}

.accommodation-item .gastgeber-badge {
  position: absolute;
  top: 84%;
  left: 4%;
  background: #ffffff;
  color: #333;
  padding: 5px 14px;
  border-radius: 20px;
  z-index: 2;
}

.accommodation-grid .short-description {
  margin-bottom: 24px;
}
.hotel-services-list .service-item img {
  border-top-left-radius: 0px;
  border-top-right-radius: 0px;
  /* padding-top: 5px; */
  /* margin-bottom: 5px; */
  aspect-ratio: auto;
  height: 100%;
  display: block;
}

/* style end  for the all services  */

/* styles for the filter */

.filter-container {
  background: #f9f9f9;
  padding: 30px;
  margin-bottom: 40px;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

#filterForm label,
#filterForm legend {
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 14px;
  color: #333;
}

#filterForm select {
  width: 100%;
  padding: 8px 10px;
  font-size: 14px;
  border: 1px solid #ccc;
  border-radius: 6px;
  background-color: #fff;
  color: #333;
}

.filter-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

.filter-column {
  display: flex;
  flex-direction: column;
}
#filterForm fieldset legend {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 10px;
}
#filterForm h5 {
  color: var(--color-blue);
}
#filterForm .filter-analysis {
  display: flex;
  justify-content: center;
}

#filterForm fieldset label {
  display: block;
  font-size: 14px;
  margin-bottom: 5px;
  color: #444;
}

#filterForm input[type="checkbox"] {
  margin-right: 8px;
}

/* Submit button */
#filterForm button[type="submit"] {
  width: fit-content;
  justify-self: start;
  padding: 10px 25px;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  background-color: var(--text-dark-blue);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.kategorie-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px 20px;
}

.kategorie-grid label {
  display: flex;
  align-items: center;
  gap: 8px;
}
.dienstleistungen-filter-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px 20px;
  margin-top: 10px;
}
.dienstleistungen-filter-form legend {
  margin-top: 20px;
}
/* styles end for the filter */

.footer-background-image {
  left: 0 !important;
  transform: translatex(0) !important;
}
.circular-section p {
  line-height: 1;
}

.fullwidth-mobile-menu.et_pb_menu_0_tb_header.et_pb_menu ul li.current-page-ancestor > a {
  color: #ffffff !important;
}
.fullwidth-mobile-menu ul li{
  margin-top: 0px !important;
  padding-top: 40px !important;
  padding-bottom: 36px !important;
}

.fullwidth-mobile-menu ul{
  column-gap: 10px;
}

.fullwidth-mobile-menu li a {
  padding-top: 10px;
  padding-bottom: 10px !important;
 
}

.fullwidth-mobile-menu .current_page_item a::after,
.fullwidth-mobile-menu li:hover > a::after,
.fullwidth-mobile-menu li.current-menu-item > a::after,
.fullwidth-mobile-menu li.current_page_item > a::after,
.fullwidth-mobile-menu li.current-menu-ancestor > a::after,
.fullwidth-mobile-menu li.current_page_ancestor > a::after,
.fullwidth-mobile-menu li.current-page-ancestor > a::after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 2px;
    background-color: white;
}

.fullwidth-mobile-menu li:hover,
.fullwidth-mobile-menu li.current-menu-item,
.fullwidth-mobile-menu li.current_page_item, 
.fullwidth-mobile-menu li.current-menu-ancestor,
.fullwidth-mobile-menu li.current_page_ancestor,
.fullwidth-mobile-menu li.current-page-ancestor
{
  background-color: var(--color-green);
  height: 100%;
}

.main-header{
  padding-bottom: 0px !important;
}

/* New styles  */
.accommodation-item .gastgeber-buttons-grid {
  display: flex;
  gap: 15px;
}
.accommodation-item .gastgeber-buttons-grid .gastgeber-button{
  display: inline-block;
    font-weight: bold;
    margin-left: 13px;
    background-color: var(--btn-primary);
    color: #fff;
    padding: 13px 34px;
    border-radius: 30px;
    text-decoration: none;
    margin-right: 0px;
    margin-top: 16px;
    margin-bottom: 10px;
    cursor: pointer;
}
.gastgeber-buttons-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; 
}
.gastgeber-card .gastgeber-wrapper-description {
    display: flex;
    gap: 20px;
    margin: 20px 0px;
    align-items: flex-start;
}
.gastgeber-card .gastgeber-wrapper-description > * {
    flex: 1 1 50%;
}
.accommodation-grid .accommodation-item .hotel-services-list{
    padding-bottom: 15px;
    padding-left: 13px
}


.massing .et_pb_blurb_content {
  display: flex;
  flex-direction: column-reverse;
}
.parish-churches .et_pb_blurb_content {
  display: flex;
  flex-direction: column-reverse;
}
.postmunster .et_pb_blurb_content {
  display: flex;
  flex-direction: column-reverse;
}

.circular-section .et_pb_main_blurb_image {
  margin-bottom: 0px;
}
/*  New styles  */

.gastgeber-card  .back-button-grid .back-button .gastgeber-button {
  margin-left: 0px;
}
.gastgeber-email {
  margin-top: 10px;
}
.gastgeber-email span {
  font-size: 22px;
  font-weight: bold;
  color: var(--text-dark-blue);
}

/* New styles  */
.gastgeber-wrapper-description .gastgeber-image-button .back-button-grid {
  margin-top: 20px;
}
.gastgeber-wrapper-description .gastgeber-image-button {
    background: #fff;
    border-radius: 30px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    padding: 10px;
}
.gastgeber-wrapper-description .gastgeber-image-button .gastgeber-image-wrapper img {
  border-top-left-radius: 30px;
  border-top-right-radius: 30px;
  width: 100%;
  height: 100%;
}
.gastgeber-wrapper-description .gastgeber-image-button .back-button-grid .back-button .gastgeber-button {
  margin-left: 0px;
}
.gastgeber-footer a {
  color: white !important;
}
.gastgeber-footer a:hover{
  text-decoration: underline;
}

.vertical-menu-style ul li.current-menu-item > a,
.vertical-menu-style ul li.current-menu-ancestor > a,
.vertical-menu-style ul li.current_page_item > a,
.vertical-menu-style ul li.current_page_ancestor > a {
  color: var(--color-green);
}


@media (max-width: 1400px) {
  .vertical-menu-style ul li a {
    padding: 22px 42px 22px 28px !important;
    width: auto;
    word-break: break-all;
  }
  .right-image-blurb h3 {
    margin-bottom: 5px;
  }
  .section-fullwidth-reverse-curves::before {
    clip-path: ellipse(75% 100% at 50% 100%);
  }
  .section-fullwidth-reverse-curves::after {
    clip-path: ellipse(75% 100% at 50% 0);
  }
  /* .right-image-blurb .et_pb_main_blurb_image {
    flex: 0 0 40%;
    max-width: 40%;
  }
     .right-image-blurb .et_pb_main_blurb_image img {
    min-height: 500px;
  }
  .right-image-blurb .et_pb_blurb_container {
    flex: 0 0 60%;
    max-width: 60%;
  } */

  /* .no-wrap-text .et_pb_main_blurb_image {
    flex: 0 0 40%;
    max-width: 40%;
  }
  .no-wrap-text .et_pb_main_blurb_image img {
    min-height: 500px;
  }
  .no-wrap-text .et_pb_blurb_container {
    flex: 0 0 60%;
    max-width: 60%;
  } */
    .gastgeber-item .gastgeber-buttons-grid {
    grid-template-columns: 1fr; 
  }
    .gastgeber-card .gastgeber-badge {
  padding: 5px 14px;
   top: 80%;
  left: 1%;
}

}

@media (max-width: 1200px) {
  .vertical-menu-style ul li a {
    padding: 22px 15px 22px 18px !important;
  }

  .my-custom-header-row .my-custom-header {
    padding: 10px 15px !important;
    gap: 18px !important;
  }
  .my-custom-header-row
    .et_pb_menu--without-logo
    .et_pb_menu__menu
    > nav
    > ul
    > li
    > a {
    font-size: 9px !important;
  }
  .gastgeber-item h5 {
    font-size: 22px;
  }
  .gastgeber-item .Gastgeber-price {
    font-size: 18px;
  }
  .accommodation-grid h5 {
    font-size: 22px;
  }
  .accommodation-item .Gastgeber-price {
    font-size: 18px;
  }

  /* New Styles  */
   .gastgeber-card .gastgeber-wrapper-description {
    flex-direction: column-reverse;
  }  
 .gastgeber-card .gastgeber-wrapper-description > * {
    flex: 1 1 100%;
  }
  .accommodation-item .gastgeber-button{
        padding: 13px 20px;
  }
  .accommodation-item .gastgeber-buttons-grid .gastgeber-button{
    padding: 13px 15px;
  }
  .gastgeber-item .gastgeber-buttons-grid .gastgeber-button{
    padding: 13px 15px;
  }
  .gastgeber-card .gastgeber-badge {
  padding: 5px 14px;
   top: 80%;
  left: 1%;
}
}

@media (max-width: 992px) {
  h1 {
    font-size: 40px !important;
  }
  h2 {
    font-size: 35px;
  }
  h3 {
    font-size: 28px;
  }
  h4 {
    font-size: 22px;
  }
  h5 {
    font-size: 18px;
  }
  h6 {
    font-size: 16px;
  }

  #Massing .et_pb_blurb_description, .Massing .et_pb_blurb_description  {
    margin-left: 0px;
}

}

@media (min-width: 1400px) and (max-width: 1580px) {
.gastgeber-item .gastgeber-buttons-grid .gastgeber-button {
  padding: 13px 20px;
}
}

@media (min-width: 980px) and (max-width: 1500px) {
 .vertical-menu-style ul li a {
    padding: 22px 42px 22px 28px !important;
    min-width: auto;
    word-break: break-all;
    line-height: 1;
  }
}

@media (min-width: 1025px) and (max-width: 1450px) {
  .gastgeber-item .gastgeber-image-wrapper img {
    min-height: 250px;
  }
  .gastgeber-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .gastgeber-badge {
    padding: 0px 5px;
  }
  .my-custom-header-row
    .et_pb_menu--without-logo
    .et_pb_menu__menu
    > nav
    > ul
    > li
    > a {
    font-size: 11px !important;
  }
  .my-custom-header-row
    .et_pb_button_0_tb_header_wrapper
    .et_pb_button_0_tb_header {
    /* padding-left: 20px !important; */
    /* padding-right: 20px !important; */
  }
  /* .circular-section .circle-wrapper img {
    width: 100%;
  }
  .circular-section img {
    width: 60%;
  }
  .circular-section .parish-churches img {
    width: 50%;
  }
  .circular-section .massing img {
    width: 50%;
  }
  .circular-section .postmunster img {
    width: 50%;
  } */

   .fullwidth-mobile-menu ul{
    column-gap: 8px;
  }

}
@media (min-width: 980px) and (max-width: 1249px) {
  .circular-section .circle-wrapper img {
    width: 100%;
  }
  .circular-section .parish-churches img {
    width: 45%;
  }
  .circular-section .massing img {
    width: 45%;
  }
  .circular-section .postmunster img {
    width: 45%;
  }
  .circular-section img {
    width: 65%;
  }
  .circular-section p {
    font-size: 14px;
  }
  .circular-section .et_pb_column_11 {
    left: 25px;
  }
  .circular-section .et_pb_column_6,
  .circular-section .et_pb_column_7,
  .circular-section .et_pb_column_8 {
    position: relative;
  }

  .circular-section .et_pb_column_12 {
    left: -25px;
  }
}
@media (min-width: 1250px) and (max-width: 1400px) {
  .circular-section .circle-wrapper img {
    width: 100%;
  }
  .circular-section img {
    width: 85%;
  }
  .circular-section .parish-churches img {
    width: 50%;
  }
  .circular-section .massing img {
    width: 50%;
  }
  .circular-section .postmunster img {
    width: 50%;
  }
}
@media (max-width: 980px) {
  .my-custom-header-row {
    position: initial !important;
    padding-left: 200px;
  }
  .my-custom-header-row .et_pb_menu_inner_container {
    position: initial !important;
  }
  .fullwidth-mobile-menu {
    position: initial !important;
  }
  .section-fullwidth-reverse-curves::before,
  .section-fullwidth-reverse-curves::after {
    display: none;
  }
  .fullwidth-mobile-menu .et_pb_module_inner,
  .fullwidth-mobile-menu {
    width: 100% !important;
  }
  .fullwidth-mobile-menu .et_mobile_menu li a {
    padding: 16px 24px;
  }
  .my-custom-header {
    padding: 5px 10px;
  }
  .my-custom-header-row {
    flex-direction: row-reverse;
    gap: 10px;
  }
  .gastgeber-item .gastgeber-badge {
    top: 86%;
  }
  .gastgeber-grid {
    grid-template-columns: 1fr;
  }
  .right-image-blurb .et_pb_blurb_content {
    flex-direction: column;
  }
  .right-image-blurb .et_pb_main_blurb_image,
  .right-image-blurb .et_pb_blurb_container {
    max-width: 100%;
    width: 100% !important;
  }
  .vertical-menu-style .et_mobile_nav_menu {
    display: none !important;
  }
  .vertical-menu-style .et_pb_menu__wrap,
  .vertical-menu-style .et_pb_menu__menu {
    display: block !important;
    width: 100% !important;
  }
  .vertical-menu-style .et_pb_menu__menu ul {
    display: block !important;
    width: 100% !important;
    margin: 0;
  }
  .vertical-menu-style .et_pb_menu__menu li {
    display: block !important;
    text-align: center;
  }
  .kategorie-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .dienstleistungen-filter-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .accommodation-grid {
    grid-template-columns: 1fr;
  }
  .circular-section .et_pb_column {
    width: auto !important;
  }
  .circular-section .et_pb_row {
    width: 100%;
  }

  .circular-section .circle-wrapper img {
    width: 100%;
  }
  /* .circular-section img {
    width: 60%;
  }
  .circular-section .parish-churches img {
    width: 70%;
  }
  .circular-section .massing img {
    width: 60%;
  }
  .circular-section .postmunster img {
    width: 60%;
  } */
  .circular-section .circle-row-3 {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .circular-section .circle-row-4 {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .circular-section .circle-row-2 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
  }

  /* .circular-section .et_pb_blurb_1 .et_pb_main_blurb_image .et_pb_image_wrap,
  .et_pb_blurb_4 .et_pb_main_blurb_image .et_pb_image_wrap,
  .et_pb_blurb_6 .et_pb_main_blurb_image .et_pb_image_wrap {
    max-width: 100% !important;
  } */
  .circular-section p {
    font-size: 12px;
  }
  .fullwidth-mobile-menu ul li{
  padding-top: 15px !important;
  padding-bottom: 12px !important;
}
.fullwidth-mobile-menu li:hover,
.fullwidth-mobile-menu li.current-menu-item,
.fullwidth-mobile-menu li.current_page_item{
  height: auto;
  margin-bottom: 8px;

}
   .gastgeber-item .gastgeber-buttons-grid {
    grid-template-columns: 1fr 1fr; 
  }
    .accommodation-item .gastgeber-button{
        padding: 13px 34px;
  }
}


/* @media (max-width: 700px) {
  .circular-section .circle-wrapper img {
    width: 100%;
  }
  .circular-section img {
    width: 55%;
  }
  .circular-section .parish-churches img {
    width: 65%;
  }
  .circular-section .massing img {
    width: 65%;
  }
  .circular-section .postmunster img {
    width: 65%;
  }
} */
 @media (max-width: 767px) {
  h1 {
    font-size: 30px !important;
  }
  h2 {
    font-size: 28px;
  }
  h3 {
    font-size: 22px;
  }
  h4 {
    font-size: 20px;
  }
  h5 {
    font-size: 16px;
  }
  h6 {
    font-size: 14px;
  }
}

@media (max-width: 600px) {
  .two-columns {
    columns: 1;
    -webkit-columns: 1;
    -moz-columns: 1;
  }
  .my-custom-header-row {
    padding-left: 0 !important;
  }
  .gastgeber-item .gastgeber-badge {
    top: 75%;
  }
  .accommodation-item .gastgeber-badge {
    top: 75%;
  }
  .custom-contact-form {
    padding: 25px 20px;
  }

  .kategorie-grid {
    grid-template-columns: 1fr;
  }
  .dienstleistungen-filter-grid {
    grid-template-columns: 1fr;
  }

  .circular-section .circle-row-1 img {
    width: 100%;
  }
  .circular-section .parish-churches img {
    width: 100%;
  }
  .circular-section .massing img {
    width: 100%;
  }
  .circular-section .postmunster img {
    width: 100%;
  }
  .circular-section p {
    font-size: 8px;
  }
  /* .circular-section .et_pb_row_1 {
    top: 20px;
  } */
    .gastgeber-card .gastgeber-badge {
  padding: 2px 10px;
  top: 70%;
  left: 1%;
  }
}
@media (max-width: 500px) {
  .circular-section p {
    line-height: 1;
  }
  .circular-section p {
    font-size: 6px;
  }
  /* .circular-section img {
    width: 70%;
  }
  .circular-section .parish-churches img {
    width: 75% !important;
  }
  .circular-section .massing img {
    width: 75% !important;
  }
  .circular-section .postmunster img {
    width: 75% !important;
  }
  */
}

@media (max-width: 575px) {
  .gastgeber-item .gastgeber-buttons-grid {
    grid-template-columns : 1fr;
  }
  .accommodation-item .gastgeber-buttons-grid {
  flex-direction: column;
  gap: 0;
  }
  .gastgeber-item .gastgeber-buttons-grid .gastgeber-button {
    margin-right: unset;
    margin-left: unset;
    text-align: center;
  }
  .accommodation-item .gastgeber-buttons-grid .gastgeber-button {
    margin-right: unset;
    margin-left: unset;
    text-align: center;
  }
}


/* show close icon */
.fullwidth-mobile-menu .mobile_menu_bar.menu-opened::before {
  content: "\00d7"; 
  font-size: 34px;
  width: 100%;
  height: 100%;
}

.fullwidth-mobile-menu li a {
  transition: none !important;
}


