:root{
    /* --clr-primary-400: hsl(202, 100%, 35%);
    --clr-primary-300: hsl(202, 100%, 40%);
    --clr-primary-200: hsl(202, 100%, 50%);
    --clr-primary-100: hsl(198, 73%, 66%);

    --clr-accent-400: hsl(0, 100%, 38%);

    --clr-neutral-100: hsl(0, 0%, 100%);
    --clr-neutral-150: hsl(0, 0%, 97%);
    --clr-neutral-200: hsl(0, 0%, 95%);
    --clr-neutral-500: hsl(0, 0%, 80%);
    --clr-neutral-600: hsl(0, 0%, 65%);
    --clr-neutral-800: hsl(0, 0%, 25%);
    --clr-neutral-900: hsl(0 0% 0%);

    --clr-pflegedienst: hsl(198, 73%, 66%);
    --clr-physiotherapie: hsl(21, 88%, 49%);
    --clr-ergotherapie: hsl(21, 88%, 49%);
    --clr-senioren: hsl(0, 91%, 34%);
    --clr-mittelpunkt: hsl(34, 92%, 65%);
    --clr-behinderte: hsl(143, 100%, 28%);

    --clr-info_red: var(--clr-accent-400);

    --clr-default_font: #404040;
    --clr-primary_font: #ffffff; */

    --ff-primary: 'open_sans', Arial, sans-serif;
    --ff-light: 'open_sans_light', Arial, sans-serif;
    --ff-semibold: 'open_sans_semibold', Arial, sans-serif;
    --ff-bold: 'open_sans_bold', Arial, sans-serif;

    --ff-body: var(--ff-primary);
    --ff-heading: var(--ff-light);

    --fw-regular: 400;
    --fw-light: 400;
    --fw-bold: 400;

    --fs-100: 1.2rem;
    --fs-200: 1.4rem;
    --fs-300: 1.6rem;
    --fs-400: 1.8rem;
    --fs-500: 2rem;
    --fs-600: 2.2rem;
    --fs-630: 3rem;
    --fs-650: 3.6rem;
    --fs-700: 4rem;
    --fs-720: 4.5rem;
    --fs-800: 5rem;
    --fs-900: 6rem;

    --fs-body: var(--fs-600);
    --fs-primary-heading: var(--fs-650);
    --fs-secondary-heading: var(--fs-630);
    --fs-other-heading: var(--fs-600);
    --fs-nav: var(--fs-600);
    --fs-button: var(--fs-600);

    --size-100: 0.25rem;
    --size-200: 0.5rem;
    --size-300: 0.75rem;
    --size-400: 1rem;
    --size-500: 1.5rem;
    --size-600: 2rem;
    --size-700: 3rem;
    --size-710: 3rem;
    --size-800: 4rem;
    --size-900: 5rem;
}

@media (min-width: 50em) {
    :root {
      --fs-body: var(--fs-600);
      --fs-primary-heading: var(--fs-720);
      --fs-secondary-heading: var(--fs-650);
      --fs-other-heading: var(--fs-630);
      --fs-nav: var(--fs-600);
    }
}

/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

*::placeholder{
    color: var(--clr-neutral-600);
}

/* Remove default margin */
* {
  margin: 0;
  padding: 0;
  font-family: inherit;
  font-size: inherit;
}

b, strong{
    font-family: var(--ff-bold);
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role="list"],
ol[role="list"] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* html,
body {
  overflow-x: hidden;
} */

/* Set core body defaults */
body {
    height: 100%;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture,
svg {
  max-width: 100%;
  display: block;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* *:focus:not(:focus-visible) {
    outline: none
}

*:focus-visible {
    outline: 1px solid yellow;
    box-shadow: 0px 0px 5px 5px yellow;
} */

/* Utility classes */

.text-primary-400 {
    color: var(--clr-primary-400);
}

.text-primary-200 {
    color: var(--clr-primary-100);
}

.text-accent-400 {
    color: var(--clr-accent-400);
}

.text-neutral-100 {
    color: var(--clr-neutral-100);
}

.text-neutral-900 {
    color: var(--clr-neutral-900);
}

.bg-primary-400 {
    background-color: var(--clr-primary-400);
}

.bg-primary-200 {
    background-color: var(--clr-primary-100);
}

.bg-accent-400 {
    background-color: var(--clr-accent-400);
}

.bg-neutral-100 {
    background-color: var(--clr-neutral-100);
}

.bg-neutral-900 {
    background-color: var(--clr-neutral-900);
}

.fw-light {
    font-weight: var(--fw-light);
}

.fw-bold {
    font-weight: var(--fw-bold);
}

.fs-primary-heading {
    font-size: var(--fs-primary-heading);
    line-height: 1.1;
}

.fs-secondary-heading {
    font-size: var(--fs-secondary-heading);
    line-height: 1.1;
}

.fs-300 {
    font-size: var(--fs-300);
}

.fs-400 {
    font-size: var(--fs-400);
}

.fs-500 {
    font-size: var(--fs-500);
}

.fs-600 {
    font-size: var(--fs-600);
}

.fs-700 {
    font-size: var(--fs-700);
}  

.fs-80 {
    font-size: var(--fs-800);
}

.fs-900 {
    font-size: var(--fs-900);
}

.pd-900{
    padding-block: var(--size-900);
}

.pd-800{
    padding-block: var(--size-800);
}

.pd-700{
    padding-block: var(--size-700);
}

.pd-600{
    padding-block: var(--size-600);
}

.pd-500{
    padding-block: var(--size-700);
}

.pd-400{
    padding-block: var(--size-700);
}

.pd-300{
    padding-block: var(--size-700);
}

.pd-200{
    padding-block: var(--size-700);
}

.pd-100{
    padding-block: var(--size-700);
}

.gap-100{
    gap: 1rem;
}

.gap-200{
    gap: 8rem;
}

.gap-300{
    gap: 10rem;
}

.gap-400{
    gap: 5%;
}

.grid-66-33{
    display: grid;
    grid-template-columns: 2fr 1fr;
}

.grid-50-50{
    display: grid;
    grid-template-columns: 1fr 1fr;
}


.center{
    text-align: center;
}

*.uppercase{
    text-transform: uppercase;
}

html{
    font-size: 10px;
}

html.fontsize_small{
    font-size: 7px;
}

html.fontsize_big{
    font-size: 12px;
}

html.fontsize_bigger{
    font-size: 14px;
}

body{
    font-family: 'open_sans', Arial;
    color: var(--clr-neutral-800);
    font-size: var(--fs-body);
    background-color: var(--clr-neutral-100);
}

a{
    text-decoration: none;
    color: var(--clr-primary-400);
    cursor: pointer;
}

hr{
    height: 1px;
    background-color: var(--clr-neutral-500);
    margin: var(--size-700) 0;
    border: none;
}

h1{
    font-size: var(--fs-primary-heading);
    font-family: var(--ff-heading);
    margin-bottom: 0.8em;
    line-height: 1.3em;
}

h2{
    font-size: var(--fs-secondary-heading);
    font-family: var(--ff-heading);
    margin-bottom: 0.8em;
    margin-top: 1.6em;
    line-height: 1.3em;
}

h3{
    font-size: var(--fs-other-heading);
    font-family: var(--ff-heading);
    margin-top: 1.6em;
    margin-bottom: 0.8em;
    line-height: 1.3em;
}

h4{
    font-size: 1.1em;
    font-family: var(--ff-bold);
    margin-top: 1.6em;
    margin-bottom: 0.8em;
    line-height: 1.3em;
}

p{
    margin-bottom: 1em;
    line-height: 1.7em;
}

small{
    font-size: 0.8em;
    line-height: 1.3em;
}

select{
    max-width: 100%;
}

ul{
    padding-left: 40px;
}


*.button {
    display: inline-block;
    cursor: pointer;
    text-decoration: none;
    border: 0;
    border-radius: 10px;
    padding: 0.5em 1em;
    font-size: var(--fs-600);
    line-height: 1;
    color: var(--clr-neutral-100);
    background-color: var(--clr-primary-400);
}

*.button.full{
    width: 100%;
}

*.button.button-100{
    color: var(--clr-neutral-900);
    background-color: var(--clr-neutral-100);
}

.middle {
    --max-width: 1800px;
    --padding: 1rem;

    width: min(var(--max-width), 100% - (var(--padding) * 2));
    margin-inline: auto;
}

.even-columns {
    display: grid;
}

@media (min-width: 60em) {
    .even-columns.big-columns {
        grid-auto-flow: column;
        grid-auto-columns: 1fr;
    }
}

@media (min-width: 50em) {
    .even-columns:not(.big-columns) {
        grid-auto-flow: column;
        grid-auto-columns: 1fr;
    }
}

.clrfix:after{
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
    content: "";
}

.clr{
    clear: both; 
}

.clr10{
    clear: both; 
    height: 10px;
}

.clr20{
    clear: both; 
    height: 20px;
}

.clr30{
    clear: both; 
    height: 30px;
}

nav#jump_links{
    position: absolute;
    top: 0;
    left: 0;
    width: 120px;
    z-index: 900;
}

nav#jump_links ul{
    margin: 0;
    padding: 0;
    list-style-type: none;
    display: flex;
}

nav#jump_links ul a{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    padding: 0.5em 1em;
    white-space: nowrap;
    background-color: #fff;
    transform: translateY(-120%);
    font-size: 18px;
    text-decoration: none;
    color: var(--clr-primary-400);
}

nav#jump_links ul a:focus{
    transform: translateY(0);
}

/* Einstellungen für Barrierefreiheit */
#design_controls{
    background-color: var(--clr-primary-400);
    color: var(--clr-neutral-100);
    font-size: var(--fs-300);
    position: relative;
}

#design_controls .middle{
    margin: 0;
    width: 100%;
}

#design_controls .middle > a{
    display: block;
    text-align: center;
    color: var(--clr-neutral-100);
    padding: var(--size-400) 1rem;
}

#design_controls .middle > a:hover{
    background-color: var(--clr-primary-300);
}

#design_controls .middle > a:focus{
    background-color: var(--clr-accent-400);
}

#design_controls nav{
    display: none;
}

#design_controls:target nav{
    display: block;
}

#design_controls nav > ul{
    padding-left: 0;
}

#design_controls:target .middle > a{
    display: none;
}

#design_controls nav > ul > li{
    border-top: 1px solid var(--clr-primary-100);
    position: relative;
}

#design_controls nav > ul a{
    display: block;
    color: var(--clr-neutral-100);
    padding: var(--size-400) 1rem;
    text-decoration: none;
}

#design_controls nav > ul  > li:last-child > a{
    padding-right: 0;
}

#design_controls nav > ul > li:first-child a{
    background-color: var(--clr-accent-400);
}

#change_fontsize{
    display: block;
    list-style-type: none;
    margin: 0;
    padding-left: 20px;
    background-color: var(--clr-primary-400);
}

#change-fontsize-li:hover > ul, #change_fontsize:target{
    display: block;
}

@media screen and (min-width: 50em){
    #design_controls{
        z-index: 300;
    }

    #design_controls .middle{
        margin: 0 auto;
        width: min(var(--max-width), 100% - (var(--padding) * 2));
    }

    #design_controls .middle > a{
        display: none;
    }

    #design_controls nav{
        display: block;
    }

    #design_controls nav > ul{
        display: flex;
        justify-content: right;
        flex-wrap: wrap;
        gap: 10px;
    }

    #design_controls nav > ul > li:first-child{
        display: none;
    }

    #change_fontsize{
        display: none;
        position: absolute;
        top: 100%;
        right: -10px;
        list-style-type: none;
        margin: 0;
        padding: 0;
        background-color: var(--clr-primary-400);
    }
    
    #change-fontsize-li:hover > ul, #change_fontsize:target{
        display: block;
    }
}

#design_controls nav > ul a:hover{
    background-color: var(--clr-primary-300);
}

/* ENDE Einstellungen für Barrierefreiheit */

/* Header und Navi */
header{
    padding-top: 1rem;
    padding-bottom: 1rem;
    display: grid;
    grid-template-columns: 1fr 40px;
    gap: 20px;
}

.menu_icon{
    font-size: var(--fs-800);
    display: flex;
    align-items: center;
    justify-content: center;
}

a#logo{
    display: flex;
    width: 100%;
    max-width: 359px;
    align-items: center;
}

nav#main_navi{
    display: none;
    position: absolute;
    top: 0;
    right: -100%;
    width: 100%;
    max-width: 400px;
    z-index: 999;
    height: 100%;
    background-color: var(--clr-neutral-100);
    box-shadow: 0 0 10px 0 var(--clr-neutral-500);
    z-index: 100;
}

nav#main_navi  ul{
    list-style-type: none;
    padding-left: 0;
}

nav#main_navi:target{
    display: block;
    right: 0;
}

nav#main_navi > a{
    display: block;
    padding: var(--size-500);
    color: var(--clr-neutral-100);
    background-color: var(--clr-primary-400);
    display: flex;
    justify-content: right;
    align-items: center;
    gap: 20px;
}
nav#main_navi > a:hover{
    background-color: var(--clr-primary-300);
}
nav#main_navi > a:focus{
    background-color: var(--clr-accent-400);
}

nav#main_navi > ul > li > a{
    display: block;
    white-space: nowrap;
    font-size: var(--fs-600);
    color: var(--clr-neutral-900);
    background-color: var(--clr-neutral-100);
    padding: var(--size-500);
    border-bottom: 1px solid var(--clr-neutral-500);
}

nav#main_navi > ul > li a:hover{
    background-color: var(--clr-neutral-200);
}

nav#main_navi > ul > li a:focus{
    background-color: var(--clr-primary-300);
    color: var(--clr-neutral-100);
}

nav#main_navi > ul > li > ul > li > a{
    display: block;
    white-space: nowrap;
    font-size: var(--fs-300);
    color: var(--clr-neutral-900);
    background-color: var(--clr-neutral-150);
    padding: var(--size-400) var(--size-400) var(--size-400) var(--size-700);
    border-bottom: 1px solid var(--clr-neutral-500);
	text-overflow: ellipsis;
	overflow: hidden;
}   

@media screen and (min-width: 50rem){
    header{
        background-image: url('../img/ornament_dpbv.png');
        background-repeat: no-repeat;
        background-position: top right;
        min-height: 156px; 
        display: block;
    }

    .menu_icon{
        display: none;
    }

    nav#main_navi{
        display: block;
        position: relative;
        right: 0;
        max-width: none;        
        box-shadow: none;
        background-color: inherit;
        margin-top: var(--size-900);
        padding-bottom: var(--size-500);
    }

    nav#main_navi > a{
        display: none;
    }

    nav#main_navi > ul{
        display: flex;
        gap: 3rem;
        flex-wrap: wrap;
        justify-content: space-between;
        padding-left: 0;
    }

    html:not(.fontsize_normal) nav#main_navi > ul{
        justify-content: flex-start;
    }

    nav#main_navi > ul > li > a{
        padding: 0;
        border-bottom: none;
    }

    nav#main_navi > ul > li > a:hover,
    nav#main_navi > ul > li > a:focus{
        background-color: inherit;
        color: inherit;
        text-decoration: underline;
    }

    nav#main_navi > ul > li{
        position: relative;
    }

    nav#main_navi > ul > li > ul{
        position: absolute;
        top: 100%;
        left: calc(var(--size-400) * -1);
        padding-top: calc(var(--size-500) + 1rem);
        padding-left: 0;
    }

    nav#main_navi > ul > li > ul{
        display: none;
    }
    
    nav#main_navi > ul > li > a:hover + ul,
    nav#main_navi > ul > li > a:focus + ul,
    nav#main_navi > ul > li:focus-within > ul,
    nav#main_navi > ul > li:hover > ul{
        display: block;
    }

    nav#main_navi > ul > li > ul > li > a{
        padding: var(--size-400);
        border-top: 1px solid var(--clr-neutral-500);
        border-bottom: none;
    }  

    #unsere_angebote_submenue:target{
        display: block;
    }
}

@media screen and (min-width: 60rem){
    nav#main_navi{
        width: calc(100% - 120px);
        max-width: 850px;
    }

    .fontsize_bigger nav#main_navi, .fontsize_big nav#main_navi{
        max-width: none;
    }
}

/* Eende Header und Navi */

.headerbild-text-wrap{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

@media screen and (max-width: 600px){
    .headerbild-text-wrap{
        display: none;
    }
}

.headerbild-text-wrap .middle{
    position: relative;
    height: 100%;
}

#headerbild{
    position: relative;
    background-image: url('../img/header.jpg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right center;
    min-height: 622px;
    z-index: 10;
}



#headerbild img{
    display: none;
}

.headerbild_text{
    background-color: var(--clr-header-overlay, rgba(0, 113, 179, 0.9));
    color: var(--clr-neutral-100);
    padding: 1.5em 1.3em;
    font-size: 42px;
    font-style: italic;
    position: absolute;
    bottom: -20px;
    left: 0;
    width: 100%;
    max-width: 725px;
}

.headerbild_text .zitat_quelle{
    font-size: 1.6rem;
}

.headerbild_text .zitat_quelle:before{
    content: '- ';
}

.headerbild_text .zitat_quelle:after{
    content: ' -';
}

#headerbild[data-page=5] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=6] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=7] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=8] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=9] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=10] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=11] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=12] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=21] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=22] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }
#headerbild[data-page=23] .headerbild_text{ background-color: rgba(0, 113, 179, 0.9); }

@media screen and (max-width: 870px){
    #headerbild{
        min-height: 0px;
        padding-top: 400px;
    }
    .headerbild_text{
        position: relative;
        bottom: 0;
        left: 0;
        max-width: none;
        font-size: 28px;
    }
}

.important-info{
    background-color: var(--clr-accent-400);
    padding: var(--size-500);
    color: var(--clr-neutral-100);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 10px;
    margin-bottom: 10px;
}

.important-info *.button{
    white-space: nowrap;
}

@media screen and (min-width: 50rem){
    .important-info{
        background-color: var(--clr-accent-400);
        padding: var(--size-500);
        color: var(--clr-neutral-100);
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 20px;
    }
}

.important-message-detail-bereich{
    position: relative;
    top: -10px;
    background-color: var(--clr-job-meta, var(--clr-neutral-200));
    padding: 10px;
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.important-message-detail-bereich a{
    color: inherit;
}

.bereich-card{
    background-color: var(--clr-neutral-150);
    padding-bottom: 9rem;
    position: relative;
}

.bereich-card[data-bereich="soziale_angebote"]{
    padding-bottom: 0;
}

.bereich-card[data-bereich="pflegedienst"] .bereich-card__desc{
    background-image: url(../img/ornament_pflegedienst.png);
}

.bereich-card[data-bereich="physiotherapie"] .bereich-card__desc,
.bereich-card[data-bereich="ergotherapie"] .bereich-card__desc{
    background-image: url(../img/ornament_physio-ergo.png);
}

.bereich-card[data-bereich="soziale_angebote"] .bereich-card__desc{
    background-image: url(../img/ornament_soziale-angebote.png);
    min-height: 90px;
}

.bereich-card__title{
    background-color: var(--clr-neutral-200);
    font-size: var(--fs-700);
    padding: 1.5em 0.5em;
    text-align: center;
    text-transform: uppercase;
}

.bereich-card__desc{
    font-size: var(--fs-400);
    padding: 1.5em 1em 1em 80px;
    background-repeat: no-repeat;
    background-position: top left;
}

.bereich-card__btn{
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

.bereich-card__btn a{
    display: block;
    background-color: var(--clr-primary-400);
    color: var(--clr-neutral-100);
    display: block;
    padding: 0.3em;
    text-align: center;
    margin-top: 1rem;
    border-radius: 10px;
    outline: 20px solid var(--clr-neutral-100);
    margin-bottom: 20px;
}

.bereich-card__btn a:focus{
    background-color: var(--clr-accent-400);
}

.headline{
    background-color: var(--clr-neutral-200);
    font-size: var(--fs-700);
    padding: 1em 0.5em;
}

#big-buttons{
    margin: 30px 0;
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 2rem;
}

@media screen and (max-width: 1500px){
    #big-buttons{
        grid-template-columns: repeat(2,1fr);
    }
}

@media screen and (max-width: 700px){
    #big-buttons{
        grid-template-columns: repeat(1,1fr);
    }
}

a.big-button{
    display: block;
    font-size: var(--fs-body);
    color: var(--clr-neutral-100);
    background-color: var(--clr-primary-400);
    padding: 0.3em;
    text-align: center;
    border-radius: 10px;
}

a.big-button.disabled{
    background-color: var(--clr-primary-100);
}

#aktuelle_aktivitaeten{
    display: grid;
    grid-template-columns: 40% 1fr;
    gap: 40px;
    margin: 30px 0;
}

#aktuelle_aktivitaeten > *{
    background-color: var(--clr-neutral-150);
    padding: 4rem;
}

@media screen and (max-width: 1200px){
    #aktuelle_aktivitaeten{
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    
    #aktuelle_aktivitaeten > *{
        padding: 2rem 1rem;
    }

    #aktuelle_aktivitaeten h3{
        margin-top: 0;
    }
}

.news-listing >.item{
    border-top: 1px solid var(--clr-neutral-900);
    margin-top: 1em;
    padding-top: 1em;
}

.news-listing >.item:first-child{
    border-top: none;
}

.news-listing >.item .datum{
    font-size: var(--fs-400);
    margin-bottom: 1em;
}

.news-listing >.item .title{
    font-size: var(--fs-600);
    font-family: var(--ff-semibold);
}

.news-listing >.item .title a{
    font-family: var(--ff-primary);
    font-style: italic;
}

.news-listing2 > .item{
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 20px;
    border-top: 1px solid #ccc;
    margin-top: 20px;
    padding-top: 20px;
}

.news-listing2 > .item:first-child{
    border-top: none;
    margin-top: 0;
    padding-top: 0;
}

.news-listing2 > .item .datum{
    background-color: var(--clr-primary-400);
    color: #fff;
    padding: 10px 5px;
    font-family: Arial;
    line-height: normal;
    text-align: center;
}

.news-listing2 > .item .datum .tag {
    font-size: 30px;
    font-weight: bold;
    line-height: 27px;
}

.news-listing2 > .item .datum .monat {
    font-size: 24px;
    text-transform: uppercase;
}

.news-listing2 > .item .datum .jahr {
    font-size: 14px;
}

.news-listing2 > .item .bereich{
    font-size: var(--fs-300);
    margin-bottom: 10px;
    font-style: italic;
}

.news-listing2 > .item .bereich a{
    color: var(--clr-neutral-650);
}

@media screen and (max-width: 600px){
    .news-listing2 > .item{
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .news-listing2 > .item .datum{
        display: flex;
        gap: 10px;
        padding: 10px;
    }

    .news-listing2 > .item .datum > *{
        font-size: 25px !important;
    }

    .news-listing2 > .item .datum .tag:after{
        content: ".";
    }
}

.news_detail-image{
    display: block;
    float: right;
    max-width: 500px;
    width: 100%;
    margin-left: 20px;
}

.termin-filter-form{
    background-color: var(--clr-neutral-200);
    padding: 1.5rem;
}

.termin-filter{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.termin-listing > .item{
    border-top: 1px solid var(--clr-neutral-900);
    margin-top: 1em;
    padding-top: 1em;
}

.termin-listing > .item:first-child{
    border-top: none;
}

.termin-listing > .item > div{
    padding-left: 30px;
    position: relative;
}

.termin-listing > .item > div::before{
    display: block;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 15px;
    height: 100%;
    background-color: var(--clr-primary-400);
}

.termin-listing > .item[data-bereich="9"] > div::before{
    background-color: var(--clr-bereich-blue);
}

.termin-listing > .item[data-bereich="10"] > div::before,
.termin-listing > .item[data-bereich="11"] > div::before{
    background-color: var(--clr-bereich-orange);
}

.termin-listing > .item[data-bereich="1"] > div::before,
.termin-listing > .item[data-bereich="2"] > div::before,
.termin-listing > .item[data-bereich="5"] > div::before{
    background-color: var(--clr-bereich-red);
}

.termin-listing > .item[data-bereich="4"] > div::before{
    background-color: var(--clr-bereich-yellow);
}

.termin-listing > .item[data-bereich="3"] > div::before,
.termin-listing > .item[data-bereich="6"] > div::before,
.termin-listing > .item[data-bereich="7"] > div::before,
.termin-listing > .item[data-bereich="8"] > div::before{
    background-color: var(--clr-bereich-green);
}

.termin-listing > .item .title{
    font-size: var(--fs-600);
    font-family: var(--ff-semibold);
}

.termin-listing > .item .content{
    display: grid;
    grid-template-columns: 1fr 80px;
    gap: 10px;
    font-size: var(--fs-400);
    margin-top: 1em;
}

@media screen and (max-width: 1200px){
    .termin-listing > .item .content{
        grid-template-columns: 1fr;
    }
}



#vorstellung{
    display: grid;
    grid-template-columns: 40% 1fr;
    background-color: var(--clr-neutral-150);
    padding: 4rem;
    gap: 5%;
}

#vorstellung h2{
    margin-top: 0;
}

@media screen and (max-width: 1000px){
    #vorstellung{
        grid-template-columns: 1fr;
        gap: 2rem;
        padding: 1rem;
    }
}

#like{
    text-align: center;
    margin-bottom: var(--size-900);
    padding: 1rem;
}

.like-buttons{
    display: flex;
    justify-content: center;
    gap: 10%;
}

.like-buttons > *{
    cursor: pointer;
}

/* Footer */
footer{
    background-color: var(--clr-neutral-800);
    color: var(--clr-neutral-100);
    padding: var(--size-700);
}

footer > .middle{
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

footer .adresse{
    text-align: center;
}

#footer-nav{
    display: flex;
    justify-content: space-between;
}

#footer-nav a{
    color: var(--clr-neutral-100);
}

@media screen and (min-width: 1100px){
    footer > .middle{
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
    }

    footer .adresse{
        text-align: left;
    }
}

@media screen and (max-width: 660px){
    #footer-nav{
        display: grid;
        grid-template-columns: 1fr;
        gap: 2rem;
        text-align: center;
    }

    #footer-nav ul{
        padding-left: 0;
    }
}

#copyright{
    text-align: center;
    padding: var(--size-600);
}
/* ENDE Footer */

/* Formulare */

.form-row{
    margin-bottom: 1.5rem;
}

select, input[type="text"], input[type="password"], input[type="email"], input[type="phone"], textarea{
    font-family: inherit;
    font-size: inherit;
    width: 100%;
    border: 1px solid var(--clr-neutral-500);
    padding: 0.45rem;
    background-color: var(--clr-neutral-100);
    color: var(--clr-neutral-900);
}

select{
    cursor: pointer;
}

input[type="submit"], button, a.btn{
    display: inline-block;
    font-family: inherit;
    font-size: inherit;
    border: 1px solid var(--clr-primary-400);
    background-color: var(--clr-primary-400);
    color: var(--clr-primary_font);
    padding: 0.3rem 1rem;
    line-height: 1.5em;
    cursor: pointer;
    text-align: center;
}

a.btn.inactive{
    border: 1px solid var(--clr-primary-50);
    background-color: var(--clr-primary-50);
    color: var(--clr-primary_font);
}

a.btn.grey{
    background-color: var(--clr-neutral-200);
    color: var(--clr-neutral-800);
    border: none;
}

input[type="submit"].cornered, button.cornered, a.btn.cornered{
    border-radius: 10px;
}

input[type="submit"].uppercase, button.uppercase, a.btn.uppercase{
    text-transform: uppercase;
}

input[type="submit"].full, button.full, a.btn.full{
    width: 100%;
}

@media screen and (max-width: 500px){
    input[type="submit"].uppercase, button.uppercase, a.btn.uppercase, .button.uppercase{
        text-transform: none;
    }
}

/* Message Boxes */
#infomessages{
    --max-width: 1800px;
    --padding: 1rem;
    width: min(var(--max-width), 100% - (var(--padding) * 2));
    margin-inline: auto;
    margin-bottom: var(--size-500);
}

.note-box, .error-box, .success-box{
    display: block;
    padding: var(--size-400);
}

.note-box{
    background-color: #fefdee;
    border: 1px solid #FFAE00;
    color: #FFAE00;
}

.error-box{
    background-color: #fff1f1;
    border: 1px solid #cf2020;
    color: #cf2020;
}

.success-box{
    background-color: #f2fff1;
    border: 1px solid #429523;
    color: #429523;
}

.note-box i,
.error-box i,
.success-box i{
    display: block;
    float: left;
    font-size: 1.5em;
}

.note-box .msg,
.error-box .msg,
.success-box .msg{
    display: block;
    margin-left: 40px;
}

#kontakt_form{
    max-width: 800px;
}

.captcha_input{
    max-width: 140px;
}

.datenschutz{
    display: grid;
    grid-template-columns: 25px 1fr;
    font-size: 1.6rem;
    margin-bottom: 2rem;
}

.datenschutzx_text, #ds_cb{
    cursor: pointer;
}

.pflicht{
    float: right;
    font-size: 14px;
    color: #aaa;
}


/* Tabellen */
table.auflistung{
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}

table.auflistung.small{
    font-size: 0.8em;
    line-height: 1.3em;
}

table.auflistung.small select,
table.auflistung.small input{
    font-size: 0.8em;
    padding: 0;
}

table.auflistung.small input{
    padding: 3px;
    width: 50px;
}

table.auflistung thead td{
    background-color: var(--clr-primary-400);
    color: #fff;
    padding: 0.5em 0.7em;
    border: 1px solid #ccc;
}

table.auflistung thead tr.second-row td{
    background-color: #a8a8a8;
}

table.auflistung tbody td{
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 0.3em 0.7em;
    vertical-align: top;
}

table.auflistung tbody tr:nth-child(2n) td{
    background-color: #efefef;
}

table.auflistung tbody tr:hover td{
    background-color: #e8e8e8;
}

table td.small{
    width: 1px;
    white-space: nowrap;
}

table td.center{
    text-align: center;
}

table td.right{
    text-align: right;
}

table td.aktion a{
    color: #383838;
}

table td.aktion a:hover{
    color: #555555;
}

table.simple-data{
    border-spacing: 0;
    border-collapse: collapse;
}

table.simple-data tr td{
    padding: 0 0 0 10px;
    vertical-align: top;
}

table.simple-data thead tr td{
    padding: 0;
    font-weight: bold;
}

table.simple-data.border tr td{
    padding: 5px 10px;
    border: 1px solid #ccc;
}


/* ENDE Tabellen */

.contentwrap{
    margin-top: 50px;
}

.contentwrap.with-sidebar{
    display: grid;
    grid-template-columns: 1fr 500px;
    gap: 5%;
}

@media screen and (max-width: 1100px){
    .contentwrap.with-sidebar{
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}

.contentwrap.with-sidebar aside{
    /* display: grid;
    grid-template-columns: 1fr;
    gap: 3rem; */
    margin-bottom: 3rem;
}

.sidebar-box{
    background-color: var(--clr-neutral-150);
    padding: 2rem;
    margin-bottom: 3rem;
}

.sidebar-box > .title{
    font-family: var(--ff-bold);
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.content-box{
    margin-top: 30px;
}

.image-content-wrap{
    display: grid;
    grid-template-columns: 386px 1fr;
    gap: 2rem;
    background-color: var(--clr-neutral-150);
    padding: 2rem;
    margin-bottom: 3rem;
}

.image-content-wrap .csb-iframe-wrap{
    height: auto;
}

.image-content-wrap .image iframe{
    width: 100%;
    height: 257px;
}

.image-content-wrap .image .more-images{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 10px;
}

.image-content-wrap .image .more-images a{
    display: block;
}

.image-content-wrap .image .more-images a img{
    display: block;
    width: 100%;
    aspect-ratio: 386/257;
    object-fit: cover;
}

.image-content-wrap > .content > .title{
    font-family: var(--ff-bold);
    text-transform: uppercase;
    margin-bottom: 2rem;
}

.image-content-wrap > .content > .buttons{
    display: flex;
    gap: 1rem;
    text-align: center;
	flex-wrap: wrap;
}

.nl-form input[type="email"]{
    max-width: 300px;
}

.nl-ds{
    display: grid;
    grid-template-columns: 30px 1fr;
}

.nl-ds-text{
    font-size: var(--fs-200);
    color: var(--clr-neutral-600);
    margin-bottom: var(--fs-body);
}

@media screen and (max-width: 850px){
    .image-content-wrap{
        display: grid;
        grid-template-columns: 1fr;
    }
}

.foederung-dresden{
    background-color: var(--clr-neutral-150);
    padding: 2rem;
    text-align: center;
}

.foederung-dresden img{
    display: block;
    max-width: 100%;
    margin: 0 auto 1rem auto;
}

/* Paginator */
.paginator.default{
    margin: 10px 0;
    text-align: right;
}

.paginator.default ul{
    margin: 0;
    padding: 0;
    list-style-type: none;
    float: right;
}

.paginator.default ul li{
    display: inline-block;
    padding: 5px;
    border: 1px solid var(--clr-primary-400);
    height: 25px;
    line-height: 14px;
    font-size: 14px;
    min-width: 25px;
    text-align: center;
}

.paginator.default ul li.aktiv{
    background-color: var(--clr-primary-400);
    border: 1px solid var(--clr-primary-400);
}

.paginator.default ul li a{
    color: #383838;
    text-decoration: none;
}

.paginator.default ul li.aktiv a{
    color: #fff;
}

.paginator.default > .label{
    float: left;
    line-height: 14px;
    font-size: 14px;
    padding: 5px 5px 5px 0;
}

.paginator.selectbox{
    margin: 10px 0;
}

.paginator.selectbox > .label{
    float: right;
    line-height: 20px;
    font-size: 14px;
    padding: 5px;
}

.paginator.selectbox > select{
    display: block;
    float: right;
    width: auto;
    line-height: 14px;
    font-size: 14px;
    padding: 5px;
}
/* ENDE Paginator */

.checkbox-group .head{
    padding: 11px;
    background-color: var(--clr-primary-400);
    color: #fff;
}
  
.checkbox-group .item{
    padding: 10px;
    border: solid #ccc;
    border-width: 0 1px 1px 1px;
}

.checkbox-group .item:first-child{
    border-width: 1px;
}

#box-form-grid{
    display: grid;
    grid-template-columns: 1fr 500px;
    gap: 50px;
}

.object-image-uploader{
    aspect-ratio: 500 / 334;
}

.object-image-uploader #box_image,
.object-image-uploader #box_image .img,
.object-image-uploader #box_image2,
.object-image-uploader #box_image2 .img,
.object-image-uploader #news_image,
.object-image-uploader #news_image .img,
.object-image-uploader #termin_image,
.object-image-uploader #termin_image .img{
    height: 100%;
}

.btn-listing > .item{
    display: grid;
    grid-template-columns: 100px 300px 1fr 40px;
    gap: 10px;
    margin-bottom: 10px;
}

.btn-listing > .item .delete{
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    border: 1px solid #ccc;
}

.btn-listing > .item .delete:hover{
    background-color: var(--clr-neutral-200);
}


.btn-listing > .item .file{
    display: none;
}

.btn-listing > .item .link{
    position: relative;
}

.btn-listing > .item.file .link{
    display: none;
}

.btn-listing > .item.file .file{
    display: block;
    position: relative;
}

.btn-listing > .item .file input[type=file]{
    display: none;
}

.btn-listing > .item .file.empty input[type=file]{
    display: inline;
}

.btn-listing > .item .file.empty .filename{
    display: none;
}

.btn-listing > .item.file .file .file-actions,
.btn-listing > .item .link .file-actions{
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
}

#login-form{
    max-width: 500px;
    margin: 0 auto;
}


/* Accordion */

.accordion .accordion__btn {
    display: flex;
    align-items: center;
    width: 100%;
    margin: 0 0 10px 0;
    padding: 0 1rem;
    text-align: left;
    background-color: var(--clr-primary-400);
    border: 0;
    cursor: pointer;
}

.accordion__btn:focus-within{
    background-color: var(--clr-primary-200);
}


.accordion .accordion__btn .accordion__icon {
    transition: 0.3s ease-in-out;
    color: #fff;
}
.accordion .accordion__btn.active:hover .accordion__icon, .accordion .accordion__btn.active .accordion__icon {
    transform: rotate(45deg);
    transition: 0.3s ease-in-out;
}
.accordion .accordion__btn .accordion__label {
    margin: 0;
    padding: 1rem 0 1rem 1rem;
    border: 0;
    background: none;
    font-size: var(--fs-body);
    text-align: left;
    line-height: 1.4;
}
.accordion .panel {
    max-height: 0;
    overflow: hidden;
    transition: 0.3s ease-in-out;
    opacity: 0;
}
.accordion .panel.show {
    opacity: 1;
    max-height: 1000px;
}
.accordion .accordion__content {
    padding: 1rem;
}
.accordion .accordion__content h3 {
    margin: 1rem 0;
}

.job-listing{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
  
.job-listing a{
    display: flex;
    color: var(--clr-neutral-100);
    background-color: var(--clr-primary-400);
    padding: 10px;
    text-decoration: none;
    cursor: pointer;
    align-items: center;
}

.job__icon{
    margin-left: auto;
}

@media screen and (max-width: 1100px){
    .job-listing{
        grid-template-columns: 1fr;
    }
}

.job-50-50{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
}

@media screen and (max-width: 1000px){
    .job-50-50{
        grid-template-columns: 1fr;
        gap: 30px;
        margin-bottom: 30px;
    }
}

.grid-8-4{
    display: grid;
    grid-template-columns: 8fr 4fr;
    gap: 30px;
}

@media screen and (max-width: 1000px){
    .grid-8-4, .grid-66-33, .grid-50-50{
        grid-template-columns: 1fr;
    }

    .gap-300{
        gap: 30px;
    }
}

.datei-input{
    margin-bottom: 10px;
}

.job-meta{
    background-color: var(--clr-job-meta, var(--clr-neutral-200));
    padding: 10px;
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.job-meta__item{
    display: flex;
    gap: 3px;
}

.job-meta__title{
    font-family: var(--ff-bold);
}

.job-meta__title:after{
    content: ':';
}

.uhrzeit-select{
    display: flex;
    gap: 2px;
}

.uhrzeit-select select{
    width: 60px;
}

.termin-listing2 > .item{
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 20px;
    border-top: 1px solid #ccc;
    margin-top: 20px;
    padding-top: 20px;
}

.termin-listing2 > .item:first-child{
    border-top: none;
    margin-top: 0;
    padding-top: 0;
}

.termin-listing2 > .item .datum{
    background-color: var(--clr-primary-400);
    color: #fff;
    padding: 10px 5px;
    font-family: Arial;
    line-height: normal;
    text-align: center;
}

.termin-listing2 > .item .datum .tag {
    font-size: 30px;
    font-weight: bold;
    line-height: 27px;
}

.termin-listing2 > .item .datum .monat {
    font-size: 24px;
    text-transform: uppercase;
}

.termin-listing2 > .item .datum .jahr {
    font-size: 14px;
}

.termin-listing2 > .item .bereich{
    font-size: var(--fs-300);
    margin-bottom: 10px;
    font-style: italic;
}

.termin-listing2 > .item .bereich a{
    color: var(--clr-neutral-650);
}

.termin-listing2 > .item .meta{
    font-size: 0.8em;
}

@media screen and (max-width: 600px){
    .termin-listing2 > .item{
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .termin-listing2 > .item .datum{
        display: flex;
        gap: 10px;
        padding: 10px;
    }

    .termin-listing2 > .item .datum > *{
        font-size: 25px !important;
    }

    .termin-listing2 > .item .datum .tag:after{
        content: ".";
    }
}


.terminlisting-short > .item{
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--clr-neutral-500);
}

.terminlisting-short > .item:first-child{
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}


.bereich-meta{
    position: relative;
    top: -15px;
    margin-bottom: 10px;
    font-size: var(--fs-300);
    font-style: italic;
}

.bereich-meta a{
    color: var(--clr-neutral-650);
}

#barriere_melden_form{
    padding-top: 56px;
}

@media screen and (max-width: 1000px){
    #barriere_melden_form{
        padding-top: 0;
    }
}

.bereich-images-listing{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 4rem;
}

@media screen and (max-width: 1250px){
    #big-boxes.even-columns.big-columns {
        display: block;
        grid-template-columns: 1fr;
        grid-auto-flow: row;
    }

    .bereich-card__title{
        text-transform: none;
        padding: 0.5em 0.5em;
        font-size: var(--fs-650);
    }
}

#adminbar{
    background-color: #333;
    padding: 10px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    position: relative;
    z-index: 99999;
}

#adminbar a{
    color: #fff;
}

#adminnav > ul{
    margin: 0;
    padding: 0;
    list-style-type: none;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

#adminnav > ul > li{
    position: relative;
}

#adminnav > ul > li:before{
    content: " | ";
}

#adminnav > ul > li:first-child:before{
    content: "";
}

#adminnav > ul > li > ul{
    display: none;
    position: absolute;
    top: 100%;
    left: -10px;
    margin: 0;
    padding: 0;
    list-style-type: none;
    padding-top: 13px;
}

#adminnav > ul > li:hover > ul{
    display: block;
}

#adminnav > ul > li > ul > li{
    background-color: #333;
    border-top: 1px solid #ccc;
}

#adminnav > ul > li > ul > li:hover{
    background-color: #525252;
}

#adminnav > ul > li > ul > li > a{
    display: block;
    padding: 10px;
    white-space: nowrap;
}

a.easy_lang_active{
    background-color: var(--clr-accent-400);
}

#to-the-top{
    display: block;
    position: fixed;
    bottom: 20px;
    right: 80px;
    width: 50px;
    height: 50px;
    background-color: var(--clr-primary-400);
    border: 1px solid #ccc;
    border-radius: 50%;
    cursor: pointer;
}

#to-the-top:after{
    content: "\f077";
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #ccc;
}