/* Klaro
*********************************/
.klaro {
  --green1: var(--green);
  --dark2: var(--red);
  --blue1: var(--gray);
}
.consent-needed {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: var(--gutter);
  background-color: var(--gray-light);
}

/* Jiggys
*********************************/

.jiggy {}
.jiggy .jiggy-header {
  margin:0 0 .5em 0;
}
.jiggy .jiggy-header h4 {
  margin:0;
}
.jiggy .jiggy-content :last-child {
  margin-bottom:0;
}

.jiggy-social {
  margin-top: 1em;
}
.jiggy-social ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  gap: 1rem;
}
.jiggy-social li {
  margin: 0;
  padding: 0;
}
.jiggy-social .social-icon {
  font-size: 1.5em;
  vertical-align: middle;
}

/* Jiggy, Seitenende
*********************************/
.site-content .jiggy {
  margin-bottom:5rem;
}
.site-content .jiggy .subheadline {
  font-size:1.125rem;
}
.site-content .jiggy .jiggy-link {
  text-align: center;
}
/* Seite, Standard
*********************************/
.page-standard {}
.page-standard .page-header {
  margin:0 0 1.3rem 0;
  position:relative;
  min-height:1px;
}
.page-standard .page-header > h1 {
  position:absolute;
  top:-10rem;
  font-weight:500;
  font-size:3rem;
  color:#fff;
  margin:0;
}
.page-standard .page-header > .h1 {
  position:relative;
  max-width:45rem;
}
.page-standard .page-header > .h1::before {
  content:'\bb';
  position:absolute;
  left:-1rem;
}
.page-standard .page-header > .h1::after {
  content:'\ab';
}
.page-standard .page-banner {
  padding-bottom:2rem;
}
.page-standard .page-banner img {
  display: block;
  width: 100%;
  height: auto;
}
.page-standard .page-content {
  padding-bottom:3rem;
}
.page-standard .page-content :last-child {
  margin-bottom:0;
}

@media only screen and (min-width : 992px) {
  .page-standard .page-intro {
    columns:2;
    column-gap: 2rem;
  }
  .page-standard .page-intro p {
    break-inside: avoid;
  }
}

/* Seite, Kategorieuebersicht
********************************/
.pages-overview {}
.pages-overview ul {
  margin:0 -1rem 2rem -1rem !important;
  padding:0;
  list-style: none;
  display:flex;
  flex-wrap: wrap;
}
.pages-overview li {
  margin:00;
  padding:0 1rem;
}
.pages-overview a {
  display:block;
  color:var(--green);
  border:solid var(--green) 1px;
  margin:0 0 2rem 0;
  padding:.625rem 1rem;
  text-align:center;
}


/* Artikel, Standard
*********************************/
.articles {
}
.articles .article {
  clear:both;
  border-top:solid var(--gray-light) 1px;
  padding:2rem 0 0 0;
  margin:0 0 2rem 0;
}
.articles .article-header {
  margin:0 0 1.3rem 0;
}
.articles .article-header > * {
  margin:0;
}
.articles .article-time::before {
  content:'(';
}
.articles .article-time::after {
  content:')';
}
.articles .article-time:empty {
  display:none;
}
.articles .article-image {
  /*margin:0 0 1.3em 0;*/
}
.articles .article-image img {
  width:100%;
  height:auto;
}
.articles .article-content :last-child {
  margin-bottom:0;
}

@media only screen and (min-width : 768px) {
  .articles .article-image {
    flex:0 0 50%;
    max-width:50%;
  }
  .articles .article-image + .article-content {
    flex:0 0 50%;
    max-width:50%;
  }
}
@media only screen and (min-width : 992px) {
  .articles .article-image {
    flex:0 0 33.3333%;
    max-width:33.3333%;
    margin-bottom:0;
  }
  .articles .article-image figure {
    margin-bottom:0;
  }
  .articles .article-image + .article-content {
    flex:0 0 66.6666%;
    max-width:66.6666%;
  }
}

/* Artikel, Pagenavig
 **********************************/
.pagenavig {
  display:flex;
  justify-content: center;
}
.pagenavig a {
  display:block;
  min-width:2.5rem;
  padding:.5rem;
  text-align: center;
  text-decoration: none;
  color:#000;
  margin:0 .25rem;
  border:solid var(--gray-light) 1px;
  transition:border .2s ease, background .2s ease, color .2s ease;
}
.pagenavig a:hover {
  background:var(--gray);
  border-color:var(--gray);
  color:#fff;
}
.pagenavig a.a1 {
  background:var(--green);
  border-color:var(--green);
  color:#fff;
}

/* Artikel, Akkordeon, jQuery
 **********************************/
.articles-accordion {
  padding:0 0 4rem 0;
}
.articles-accordion article {
  margin:0 0 1px 0;
}
.articles-accordion .article-header {
  background:var(--green-light);
  color:#fff;
  cursor:pointer;
  padding:1rem 3rem 1rem 1rem;
  position:relative;
  transition:background .2s ease, color .2s ease;
}
.articles-accordion .article-header h2 {
  margin:0;
}
.articles-accordion .article-header h2::before {
  content:'\bb';
  margin-right:.3em;
}
.articles-accordion .article-header span {
  position: absolute;
  right:1rem;
  top:1.375rem;
  /*transform:rotate(90deg);*/
  transition: transform .2s ease;
}
.articles-accordion .article-header.active span {
  transform:rotate(180deg);
}
.articles-accordion .article-header.active {
  background:var(--green);
  color:#fff;
  outline:0;
}
.articles-accordion .article-content {
  padding:1.5rem 3rem 1.5rem 1rem;
}
.articles-accordion .article-content-image {
  order:2;
}
.articles-accordion .article-content-text {
  order:1;
}
.articles-accordion .article-content-image img {
  width:100%;
  height:auto;
  display:block;
}

@media only screen and (min-width : 768px) {
  .articles-accordion .article-content-image {
    flex:0 0 50%;
    max-width:50%;    
  }
  .articles-accordion .article-content-image + .article-content-text {
    flex:0 0 50%;
    max-width:50%;
  }
}

/* Pagenavig
*********************************/
.pagenavig {
  display: flex;
  gap: .5rem;
  margin: 1.5rem 0;
}
.pagenavig a {
  display: block;
  min-width: 2rem;
  line-height: 2rem;
  background-color: var(--gray-light);
  color: #000;
  text-align: center;
  transition: .2s ease;
  transition-property: background-color, color;
}
.pagenavig a:hover {
  text-decoration: none;
  background-color: var(--gray);
}
.pagenavig a.a1 {
  background-color: var(--green);
  color: #fff;
}

/* Downloads (FTP)
*********************************/
.ftp-path {}
.ftp-path .icon {
  display:inline-block;
  width:1rem;
  margin-left:.5rem;
  margin-right:.375rem;
}
table.ftp-downloads {
  width:100%;
}
table.ftp-downloads .name {
  width:100%;
}
table.ftp-downloads .name .icon {
  display:inline-block;
  width:1rem;
  margin-right:.375rem;
}
table.ftp-downloads .date {
  white-space:nowrap;
}
table.ftp-downloads .size {
  white-space:nowrap;
  text-align:right;
}
table.ftp-downloads a {
  color:#000;
}
table.ftp-downloads a:hover {
  text-decoration: none;
}
table.ftp-downloads a:hover .title {
  text-decoration: underline;
}

/* Suche
*********************************/
form.search {
  display:flex;
}
/*
.site-footer form.search input[type=text] {
  border-color:#fff;
}
.site-footer form.search button {
  background-color:var(--green-dark);
  border-color:var(--green-dark);
}
.site-footer form.search button:hover {
  background-color:var(--green-darker);
  border-color:var(--green-darker);
}
*/

/* Galerie, Banner
*********************************/
.banner-gallery {
  height:100%;
  position:relative;
}
.banner-gallery .gallery-item {
  height:50rem;
  background-size:cover;
  background-position:50% 0;
}
.banner-gallery:not(.slick-slider) .gallery-item:not(:first-child) {
  display:none;
}

.banner-gallery .slick-arrow {
  position:absolute;
  left:1rem;
  top:50%;
  z-index:1060;
  transform:translate(0, -50%);
  background:var(--red);
  border:0;
  color:#fff;
  opacity:.6;
  transition:opacity .2s ease;
}
.banner-gallery .slick-next {
  left:auto;
  right:1rem;
}
.banner-gallery .slick-arrow:hover {
  opacity:1;
}

/* Galerie, Carousel
*********************************/
.gallery-carousel {
  margin:0 0 1.5rem 0;
}
.gallery-carousel ul {
  margin:0 -.5rem;
  padding:0;
  list-style: none;
}
.gallery-carousel li {
  margin:0;
  padding:0 .5rem;
}
.gallery-carousel a {
  display:block;
}
.gallery-carousel img {
  display:block;
  width:100%;
  height:auto;
}

/* no-js fallback */
.gallery-carousel ul:not(.slick-slider) {
  display:flex;
  overflow-x:scroll;
}
.gallery-carousel ul:not(.slick-slider) li {
  flex:0 0 100%;
  max-width:100%;
}
@media only screen and (min-width : 768px) {
  .gallery-carousel ul:not(.slick-slider) li {
    flex:0 0 50%;
    max-width:50%;
  }  
}
@media only screen and (min-width : 992px) {
  .gallery-carousel ul:not(.slick-slider) li {
    flex:0 0 33.3333%;
    max-width:33.3333%;
  }  
}

/* slick arrows */
.gallery-carousel .slick-track {
  margin:0;
}
.gallery-carousel .slick-arrow {
  position:absolute;
  left:.5rem;
  top:50%;
  z-index:1050;
  transform:translate(0, -50%);
}
.gallery-carousel .slick-next {
  left:auto;
  right:.5rem;
}

/* Formulare
*********************************/
form p {
  clear:both;
  margin:0 0 .75em 0;
}

fieldset {
  margin:0 0 15px 0;
  padding:0;
  border:0;
}
fieldset legend {
}

.required label:after,
.required-span span.label:after,
.required-span span.label-indent:after,
.required-span span.label-block:after {
  content:'*';
}
input[type=text],
input[type=password],
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=email],
input[type=month],
input[type=number],
input[type=search],
input[type=tel],
input[type=time],
input[type=url],
input[type=week],
textarea { 
  width:100%;
  margin:0;
  padding:.5em;
  border:solid var(--gray-light) 1px;
}
input[type=text]:focus,
input[type=password]:focus,
input[type=date]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=email]:focus,
input[type=month]:focus,
input[type=number]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=time]:focus,
input[type=url]:focus,
input[type=week]:focus,
textarea:focus {
  margin:0;
  border:solid var(--gray-light) 1px;
}
textarea {
  height:12rem;
}
a.btn,
button,
input[type=submit] {
  display:inline-block;
  margin:0;
  padding:.5em 1em;
  border:solid var(--green) 1px;
  border-radius:0;
  cursor:pointer;
  background:var(--green);
  color:#fff;
  text-transform:uppercase;
  text-decoration:none;
  transition:background .2s ease, border .2s ease;
}
input[type=submit]::-moz-focus-inner {
  border: 0;
}
a.btn:hover,
button:hover,
input[type=submit]:hover {
  background-color:var(--green-dark);
  border-color:var(--green-dark);
  color:#fff;
}
a.btn:focus,
button:focus,
input[type=submit]:focus {
  box-shadow: 0 0 0 2px var(--green-darker);
  outline:0;
}
.sendmail_emptyfield1 label,
label.sendmail_emptyfield1 {
  color:#f00;
}
.sendmail_emptyfield1 input.text,
input.sendmail_emptyfield1,
.sendmail_emptyfield1 textarea {
  border-color:#f00;
}
.message {
  border:solid #f6e468 1px;
  background:#ffffdb;
  padding:5px;
  margin:0 0 .8em 0;
}