/* Import Google Font Montserrat */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/* Google Font formatieren */
.material-symbols-outlined {
  font-variation-settings:
  'FILL' 0,
  'wght' 400,
  'GRAD' 0,
  'opsz' 24
}

/* Danach bleiben Elemente innerhalb ihrer Container.*/
*,
*::before,
*::after {
  box-sizing: border-box;
}

body, .form-all {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-size: 18px;
  font-weight: 500; /* medium */
  font-style: normal;
  color: #222222;
}

h1, h2, h3, h4 {
  line-height: 1.3;
}

p, blockquote, li, summary {
  line-height: 1.5;
}



h1 {
  margin: 0 0 0px 0;
  padding: 8px 14px;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: 0em; /* adjust letter spacing depending on font size */
  word-spacing: 0em; /* adjust word spacing depending on font size */
  -webkit-font-smoothing: antialiased; /* looks better */
  -moz-osx-font-smoothing: grayscale; /* looks better */
  font-weight: 700; /* bold */
  color: #fff;
  background: linear-gradient(to right, #A7B805, #D0DB68);
}

h2 {
  margin: 0px;
  padding: 8px 24px;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: 0em; /* adjust letter spacing depending on font size */
  word-spacing: 0em; /* adjust word spacing depending on font size */
  -webkit-font-smoothing: antialiased; /* looks better */
  -moz-osx-font-smoothing: grayscale; /* looks better */
  font-size: 28px;
  font-weight: 700; /* bold */
  color: #fff;
  background: linear-gradient(to right, #A7B805, #D0DB68);
}

h3, summary, nav li {
  margin: 0 0 24px 0;
  padding: 12px 0;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: 0em; /* adjust letter spacing depending on font size */
  word-spacing: 0em; /* adjust word spacing depending on font size */
  -webkit-font-smoothing: antialiased; /* looks better */
  -moz-osx-font-smoothing: grayscale; /* looks better */
  font-size: 24px !important;
  font-weight: 700; /* bold */
  color: #222222;
}

footer nav li {
  margin: 0px;
  padding: 0px;
}

footer nav li a {
  font-size: 22px;
}

footer nav ul li a, footer p a  {
  color:#222222 !important;
  font-weight: 400; /* regular */
}

h4 {
  font-size: 22px;
  font-weight: 400; /* regular */
}

p, li {
  padding-right: 0%;
}

blockquote {
  padding: 20px 20px;
}

blockquote p {
  padding-right: 0px;
}

.wp-block-column p {
  padding-right: 0;
}

p, .wp-block-column-is-layout-flow ul li, .wp-block-list li  {
  margin: 25px 0 30px 0;
  font-size: 20px;
  font-weight: 400; /* regular */
}

p strong, li strong {
  font-weight: 700 !important; /* bold */
}

h2, img {
  margin-bottom: 0px; /* Standard-Abstand für Text */
}

/* Wenn direkt danach ein Bild kommt → kein Abstand */
h2 + img, h1 + img {
  margin-top: 0;
}

img + h2 {
  margin-top: 0;
}

/* Wenn direkt danach ein Absatz kommt → Abstand */
h2 + p, h1 + p {
  margin-top: 25px;
}

ul.wp-block-list {
  margin: 25px 0 0px 0;
}

q, blockquote {
  margin:0px;
  font-weight: 400; /* regular */
  font-size: 18px;
  font-style: italic;
  color:#6C9C30;
}

figure {
  font-weight: 500; /* medium */
  font-size: 14px;
  margin:0px;
}

a {
  font-weight: 700; /* bold */
  text-decoration: none; 
  color:#6C9C30;
}

a.button {
  color: #fff;
  background-color: #BCCF02; 
  border-radius: 29px;
  height: 58px;
  width: auto;
  padding: auto 25px;
}

a.button:hover {
  color: #A7B805;
  background-color: #fff; 
  border: 1px solid #222222;
}

.wp-block-button__link {
  color:#222222 !important;
  background-color: #D0DB68 !important;
  margin: 0 0 29px 0;
}

body hr.wp-block-separator.is-style-dots {
  margin:0px;
  border-top: 3px dotted #FDC300 !important;
}
body hr.wp-block-separator.is-style-dots::before {
  content: none !important;
}

/* Negative Class Styles */
.negativ {
  color: white;
}

summary {
  list-style: none;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  display: flex;
  border-bottom: 3px dotted #FDC300;
}

.wp-block-details[open] summary{
  border-bottom: none;
}

/* eigener Pfeil rechts */
summary::after {
  content: "";
  background-image: url('../images/plus.png');
  width: 44px;
  height: 44px;
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 0.5em;
}

/* gedrehtes Symbol wenn geöffnet */
.wp-block-details[open] summary::after {
  background-image: url('../images/minus.png');
}

.swiper {
  margin-bottom: 25px !important;
}

.gutslider-caption {
  text-align: left !important;
  color: #222222 !important;
  
  background-color: white !important;
}
.wp-block-gutsliders-photo-carousel .swiper-pagination.swiper-pagination-horizontal {
  bottom:-30px !important;
}

.swiper-button-next, .swiper-button-prev {
  margin:0px !important;
  padding:0px !important;
  background: none !important;
  width: 60px !important;
  height: 60px !important;
}

.wp-block-gutsliders-photo-carousel.has__pagination {
  margin-bottom: 59px !important;
}

.swiper-button-next::after {
  margin:0px!important;
  padding:0px!important;
  content: "" !important;
  background-image: url('../images/arrow-right.png') !important;
  width: 60px !important;
  height: 60px !important;
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 0.5em;
}

.swiper-button-prev::after {
  margin:0px !important;
  padding:0px !important;
  content: "" !important;
  background-image: url('../images/arrow-left.png') !important;
  width: 60px !important;
  height: 60px !important;
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 0.5em;
}

.swiper-pagination-bullet-active {
  background-color: #222222 !important;
}

.wp-block-column-is-layout-flow ul li, .wp-block-list li {
  margin: 0 0 12px 0;
}

.wp-block-image :where(figcaption){
  margin:5px 0 30px 0 !important;
  color: #6C9C31;
  font-size: 19px;
}

/* Breakpoints */
@media (max-width: 480px) {
  h1 {
    font-size: 36px; /* smaller */
  }

  .swiper-container-outer {
    height: auto !important;
  }

}

@media (min-width: 481px) {
  h1 {
    font-size: 36px; /* smaller */
  }

  .swiper-container-outer {
    height: auto !important;
    max-height: 524px !important;
  }
}

@media (min-width: 768px) {
  blockquote {
    padding: 20px 10%;
  }

  p, .wp-block-column-is-layout-flow ul li, .wp-block-list li  {
    font-size: 22px;
  }
}

@media (min-width: 1280px) {

  h1 {
    font-size: 48px; /* Standard */
  }

  p, li {
    padding-right: 15%;
  }

  .wp-block-group .wp-block-group p, .wp-block-group .wp-block-group li {
    padding-right: 0%;
  }

  .wp-block-column p {
    padding-right: 5%;
  }
}

@media (min-width: 1600px) {


  .wp-block-image :where(figcaption){
    margin-bottom:60px !important;
  }
}