/*
Theme Name: Ernst-Reuter-Schule
Theme URI: https://ers-edermuende.de
Author: Bastian Ranft, flexx-hosting.de
Author URI: https://flexx-hosting.de
Description: 
Version: 1.0
Tags: 
/*
@charset "UTF-8";
/* CSS Document */
/* roboto-100 - latin */
@font-face {
  font-display: swap;
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 100;
  src: url('assets/fonts/roboto-v32-latin-100.woff2') format('woff2'); 
}
/* roboto-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('assets/fonts/roboto-v32-latin-regular.woff2') format('woff2');
}
/* roboto-900 - latin */
@font-face {
  font-display: swap;
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 900;
  src: url('assets/fonts/roboto-v32-latin-900.woff2') format('woff2');
}
:root {
    --trans: rgba(255,255,255,0);
    --white: rgba(255,255,255,1);
    --white95: rgba(255,255,255,.95);
    --white90: rgba(255,255,255,.9);
    --white80: rgba(255,255,255,.8);
    --white70: rgba(255,255,255,.7);
    --white60: rgba(255,255,255,.6);
    --white50: rgba(255,255,255,.5);
    --white40: rgba(255,255,255,.4);
    --white30: rgba(255,255,255,.3);
    --white20: rgba(255,255,255,.2);
    --white10: rgba(255,255,255,.1);
    --white5: rgba(255,255,255,.05);
    --white-hover: rgba(255,255,255,.3);
    --black: rgba(0,0,0,1);
    --black95: rgba(0,0,0,.95);
    --black90: rgba(0,0,0,.9);
    --black80: rgba(0,0,0,.8);
    --black70: rgba(0,0,0,.7);
    --black60: rgba(0,0,0,.6);
    --black50: rgba(0,0,0,.5);
    --black40: rgba(0,0,0,.4);
    --black30: rgba(0,0,0,.3);
    --black20: rgba(0,0,0,.2);
    --black10: rgba(0,0,0,.1);
    --black-hover: rgba(0,0,0,.3);
    --gray: rgba(74,74,74,1);
    --gray95: rgba(74,74,74,.95);
    --gray90: rgba(74,74,74,.9);
    --gray80: rgba(74,74,74,.8);
    --gray70: rgba(74,74,74,.7);
    --gray60: rgba(74,74,74,.6);
    --gray50: rgba(74,74,74,.5);
    --gray40: rgba(74,74,74,.4);
    --gray30: rgba(74,74,74,.3);
    --gray20: rgba(74,74,74,.2);
    --gray10: rgba(74,74,74,.1);
    --gray-hover: rgba(50,50,50,1);
    --green: rgba(121,172,44,1);
    --green95: rgba(121,172,44,.95);
    --green90: rgba(121,172,44,.9);
    --green80: rgba(121,172,44,.8);
    --green70: rgba(121,172,44,.7);
    --green60: rgba(121,172,44,.6);
    --green50: rgba(121,172,44,.5);
    --green40: rgba(121,172,44,.4);
    --green30: rgba(121,172,44,.3);
    --green20: rgba(121,172,44,.2);
    --green10: rgba(121,172,44,.1);
    --green-hover: rgba(90,127,33,1);
    --red: rgba(192,77,68,1);
    --red95: rgba(192,77,68,.95);
    --red90: rgba(192,77,68,.9);
    --red80: rgba(192,77,68,.8);
    --red70: rgba(192,77,68,.7);
    --red60: rgba(192,77,68,.6);
    --red50: rgba(192,77,68,.5);
    --red40: rgba(192,77,68,.4);
    --red30: rgba(192,77,68,.3);
    --red20: rgba(192,77,68,.2);
    --red10: rgba(192,77,68,.1);
    --red-hover: rgba(144,54,47,1);
    --orange: rgba(229,190,73,1);
    --orange95: rgba(229,190,73,.95);
    --orange90: rgba(229,190,73,.9);
    --orange80: rgba(229,190,73,.8);
    --orange70: rgba(229,190,73,.7);
    --orange60: rgba(229,190,73,.6);
    --orange50: rgba(229,190,73,.5);
    --orange40: rgba(229,190,73,.4);
    --orange30: rgba(229,190,73,.3);
    --orange20: rgba(229,190,73,.2);
    --orange10: rgba(229,190,73,.1);
    --orange-hover: rgba(198,160,44,1);
    --yellow: rgba(243,233,161,1);
    --yellow95: rgba(243,233,161,.95);
    --yellow90: rgba(243,233,161,.9);
    --yellow80: rgba(243,233,161,.8);
    --yellow70: rgba(243,233,161,.7);
    --yellow60: rgba(243,233,161,.6);
    --yellow50: rgba(243,233,161,.5);
    --yellow40: rgba(243,233,161,.4);
    --yellow30: rgba(243,233,161,.3);
    --yellow25: rgba(243,233,161,.25);
    --yellow20: rgba(243,233,161,.2);
    --yellow10: rgba(243,233,161,.1);
    --yellow-hover: rgba(217,209,150,1);
    --lightgray: rgba(245,245,245,1);
    --lightgray-hover: rgba(228,228,228,1);
    /*--body-background: rgba(243,253,238,1);*/
    --body-background: rgba(255,255,255,1);


    --emphasis: rgba(150,0,0,1);
    --emphasis-hover: rgba(125,0,0,1);



    
    --font-size-headline-xlarge: 3.5rem;
    --line-height-headline-xlarge: 4.0rem;
    --font-size-headline-large: 2.8rem;
    --line-height-headline-large: 3.3rem;
    --font-size-headline-medium: 2.0rem;
    --line-height-headline-medium: 2.5rem;
    --font-size-headline-navigation: 1.5rem;
    --line-height-headline-navigation: 2.0rem;
    --font-size-headline-small: 1.5rem;
    --line-height-headline-small: 2.0rem;
    --font-size-headline-xsmall: 1.2rem;
    --line-height-headline-xsmall: 1.8rem;
    --text-font-size: 1.2rem;
    --text-font-line-height: 2.0rem;
    --text-font-size-small: 1.0rem;
    --text-font-line-height-small: 1.7rem;
    --text-font-size-xs: 0.8rem;
    --text-font-line-height-xs: 1.3rem;
    --transition-normal: all ease 0.2s;
    --mp-xl: 350px;
    --mp-lg: 175px;
    --mp-md: 125px;
    --mp-sm: 75px;
    --mp-xs: 50px;
    --mp-xxs: 20px;
    --spacer-lg: 20px;
    --spacer-md: 15px;
    --spacer-sm: 10px;
    --spacer-xs: 5px;
    --spacer-xxs: 3px;
    --padding-color-container-lg: 160px 20px;
    --padding-color-container-md: 80px 20px;
    --padding-color-container-sm: 40px 20px;
    --padding-color-container-xs: 20px 10px;
}
/* =============================================
### GENERAL-SETTINGS
================================================ */
*,
*:before,
*:after {
    box-sizing:border-box;
    -ms-box-sizing:border-box;
    -moz-box-sizing:border-box; 
    -webkit-box-sizing:border-box; 
    -o-box-sizing:border-box;
}
html,
body,
.container-height-100 {
  height:100%;
}
html {
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: var(--gray);
}
body {
    margin:0;
    padding:0;
    font-display: swap;
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 400;
    font-size:var(--text-font-size);
    line-height:var(--text-font-line-height);
    color:var(--gray);
    background-color: var(--body-background);
    -webkit-font-smoothing: antialiased;
    /*
    background:url(https://cab.flexx-hosting.de/wp-content/uploads/2024/11/header_sample_001.jpg) center top/100% auto no-repeat var(--trans);
    */
}
.clear {
    clear: both;
}
/*
header .sticky .equal .inner {
    background-color: red;
}
*/
header .logo {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}

header .logo img,
header.shrink .logo img {
    width: auto;
    border: none;
    margin:10px 10px 15px;
}

/* =============================================
### CONTAINER
================================================ */


/* =============================================
### COLORS / BACKGROUNDS / BORDER / STYLING
================================================ */
/* BACKGROUNDS */
.bg_white,
.bg_black,
.bg_trans,
.bg_lightgray,
.bg_lightgray_hover,
.bg_gray,
.bg_gray_hover,
.bg_green,
.bg_green_hover,
.bg_lightgreen,
.bg_lightgreen_hover,
.bg_red,
.bg_red_hover,
.bg_orange,
.bg_orange_hover,
.bg_yellow,
.bg_yellow_hover,
.bg_lightyellow,
.bg_lightyellow_hover,
.bg_blue,
.bg_blue_hover,
.bg_transition_lightgray,
.bg_contactform,
.bg_ferien,
.hyperlinks .inner {
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
    hyphenate-limit-chars: auto 5;
    hyphenate-limit-lines: 2;
    color: var(--white);
}
.bg_white {
    background-color:var(--white);
    color: var(--gray);
}
.bg_black {
    background-color:var(--black);
}
.bg_trans {
    background-color: var(--trans);
    color: var(--gray);
}
.bg_lightgray {
    background-color: var(--lightgray);
    color: var(--gray);
}
.bg_lightgray_hover {
    background-color: var(--lightgray-hover);
    color: var(--gray);
}
.bg_gray {
    background-color: var(--gray);
}
.bg_gray_hover {
    background-color: var(--gray-hover);
}
.bg_green {
    background-color: var(--green);
    border-right:10px solid var(--green-hover);
}
.bg_green_hover {
    background-color: var(--green-hover);
    border-right:10px solid var(--green);
}
.bg_green_hover {
    background-color: var(--green40);
    border-right:10px solid var(--green60);
}
.bg_lightgreen {
    background-color: var(--green20);
    border-right:10px solid var(--green40);
    color: var(--gray);
}
.bg_lightgreen_hover {
    background-color: var(--green40);
    border-right:10px solid var(--green60);
    color: var(--gray);
}
.bg_red {
    background-color: var(--red);
    border-right:10px solid var(--red-hover);
}
.bg_red_hover {
    background-color: var(--red-hover);
    border-right:10px solid var(--red);
}
.bg_orange {
    background-color: var(--orange);
    border-right:10px solid var(--orange-hover);
}
.bg_orange_hover {
    background-color: var(--orange-hover);
    border-right:10px solid var(--orange);
}
.bg_yellow {
    background-color: var(--yellow);
    color: var(--gray);
    border-right:10px solid var(--yellow-hover);
}
.bg_yellow_hover {
    background-color: var(--yellow-hover);
    color: var(--gray);
    border-right:10px solid var(--yellow);
}
.bg_lightyellow {
    background-color: var(--yellow30);
    color: var(--gray);
    border-right:10px solid var(--yellow-hover);
}
.bg_lightyellow_hover {
    background-color: var(--yellow50);
    color: var(--gray);
    border-right:10px solid var(--yellow);
}
.bg_blue {
    background-color: var(--blue);
    color: var(--gray);
    border-right:10px solid var(--blue-hover);
}
.bg_blue_hover {
    background-color: var(--blue-hover);
    color: var(--gray);
    border-right:10px solid var(--blue);
}
.bg_sketch {
    background-position: center bottom;
    background-size: 90% auto;
    background-repeat: no-repeat;
}
.bg_sketch_small {
    background-position: center bottom;
    background-size: 60% auto;
    background-repeat: no-repeat;
}
.children {
    background-image:url(assets/images/layout/bg_children.png);
}
.hills {
    background-image:url(assets/images/layout/bg_hills.png);
}
.bg_ferien {
    color: var(--gray);
}
.bg_transition_lightgray {
    background-color: rgba(255, 255, 255, 1);
    background-image: linear-gradient(30deg, rgba(255, 255, 255, 1) 50%, rgba(197, 197, 197, 1) 100%);
    color: var(--gray);
}
.bg_contactform {
    /*
    background: url(assets/images/layout/bg_contactform_2.jpg) top center no-repeat var(--white);
    /*
    background-image: url(assets/images/layout/bg_contactform_white_80.png),url(assets/images/layout/bg_contactform.jpg);
    background-position: left top,center top;
    background-size: 100% 100%,cover;
    background-repeat: no-repeat;
    background-color: var(--white);
    */
}
.hyperlinks .inner {
    background-color: var(--green10);
    color: var(--gray);
}
.hyperlinks .inner:hover {
    background-color: var(--green20);
    color: var(--gray);
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
.hyperlinks .align {
    padding: 50px 15px;
}
footer {
    background: url(assets/images/layout/bg_nav_8.png) right top 4px no-repeat, url(assets/images/layout/bg_nav_gradient_2.png) left bottom / 100% 55px no-repeat var(--white);
}
/* VIDEO ELEMENT  */
.container-video {
    width: 100%;
    height: auto;
    position: relative;
}

video { 
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
}

.video-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    height: auto;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.video-overlay img {
    width: 100%;
    height: auto;
    border: none;
    margin: 0;
}
/* STYLING */
.vertical-align-middle {
    display: flex; 
    display: -webkit-flex;
}
.vertical-align-middle.left{
    justify-content: flex-start;
}
.vertical-align-middle.center{
    justify-content: center;
}
.vertical-align-middle.right{
    justify-content: flex-end;
}
.vertical-align-middle span,
.vertical-align-middle div.align {
    margin: auto 0;
}
.transition {
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
.shadow {
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.shadow:before {
    position: absolute;
    z-index: -1;
    display: block;
    background: rgba(0, 0, 0, 0.7);
    -webkit-box-shadow: 0 0 30px 0px rgba(0, 0, 0, 0.7);
    -moz-box-shadow: 0 0 30px 0px rgba(0, 0, 0, 0.7);
    box-shadow: 0 0 30px 0px rgba(0, 0, 0, 0.7);
    content: "";
    right: 20px;
    bottom: 0;
    left: 20px;
    height: 30px;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
}
/*
.border,
.border-no-padding,
.border-no-p {
    border:1px solid var(--black10) !important;
    padding:20px !important;
}
.border-no-padding,
.border-no-p {
    padding:0px !important;
}
*/
/* =============================================
### DIRECTION / PADDING / MARGIN
================================================ */
.al {
    text-align: left !important;
}
.ac {
    text-align: center !important;
}
.ar {
    text-align: right !important;
}
.aj {
    text-align: justify !important;
}
.padding-color-container-lg {
    padding: var(--padding-color-container-lg) !important;
}
.padding-color-container-md {
    padding: var(--padding-color-container-md) !important;
}
.padding-color-container-sm {
    padding: var(--padding-color-container-sm) !important;
}
.padding-color-container-xs {
    padding: var(--padding-color-container-xs) !important;
}
.no-padding,
.no-p {
    padding:0;
}
.p-xl {
    padding: var(--mp-xl);
}
.pt-xl {
    padding-top: var(--mp-xl);
}
.pr-xl {
    padding-right: var(--mp-xl);
}
.pb-xl {
    padding-bottom: var(--mp-xl);
}
.pl-xl {
    padding-left: var(--mp-xl);
}
.p-lg {
    padding: var(--mp-lg);
}
.pt-lg {
    padding-top: var(--mp-lg);
}
.pr-lg {
    padding-right: var(--mp-lg);
}
.pb-lg {
    padding-bottom: var(--mp-lg);
}
.pl-lg {
    padding-left: var(--mp-lg);
}
.p-md {
    padding: var(--mp-md);
}
.pt-md {
    padding-top: var(--mp-md);
}
.pr-md {
    padding-right: var(--mp-md);
}
.pb-md {
    padding-bottom: var(--mp-md);
}
.pl-md {
    padding-left: var(--mp-md);
}
.p-sm {
    padding: var(--mp-sm);
}
.pt-sm {
    padding-top: var(--mp-sm);
}
.pr-sm {
    padding-right: var(--mp-sm);
}
.pb-sm {
    padding-bottom: var(--mp-sm);
}
.pl-sm {
    padding-left: var(--mp-sm);
}
.p-xs {
    padding: var(--mp-xs);
}
.pt-xs {
    padding-top: var(--mp-xs);
}
.pr-xs {
    padding-right: var(--mp-xs);
}
.pb-xs {
    padding-bottom: var(--mp-xs);
}
.pl-xs {
    padding-left: var(--mp-xs);
}
.p-xxs {
    padding: var(--mp-xxs);
}
.pt-xxs {
    padding-top: var(--mp-xxs);
}
.pr-xxs {
    padding-right: var(--mp-xxs);
}
.pb-xxs {
    padding-bottom: var(--mp-xxs);
}
.pl-xxs {
    padding-left: var(--mp-xxs);
}
.m-lg {
    margin: var(--mp-lg);
}
.mt-lg {
    margin-top: var(--mp-lg);
}
.mr-lg {
    margin-right: var(--mp-lg);
}
.mb-lg {
    margin-bottom: var(--mp-lg);
}
.ml-lg {
    margin-left: var(--mp-lg);
}
.m-md {
    margin: var(--mp-md);
}
.mt-md {
    margin-top: var(--mp-md);
}
.mr-md {
    margin-right: var(--mp-md);
}
.mb-md {
    margin-bottom: var(--mp-md);
}
.ml-md {
    margin-left: var(--mp-md);
}
.m-sm {
    margin: var(--mp-sm);
}
.mt-sm {
    margin-top: var(--mp-sm);
}
.mr-sm {
    margin-right: var(--mp-sm);
}
.mb-sm {
    margin-bottom: var(--mp-sm);
}
.ml-sm {
    margin-left: var(--mp-sm);
}
.m-xs {
    margin: var(--mp-xs);
}
.mt-xs {
    margin-top: var(--mp-xs);
}
.mr-xs {
    margin-right: var(--mp-xs);
}
.mb-xs {
    margin-bottom: var(--mp-xs);
}
.ml-xs {
    margin-left: var(--mp-xs);
}
.m-xxs {
    margin: var(--mp-xss);
}
.mt-xxs {
    margin-top: var(--mp-xss);
}
.mr-xxs {
    margin-right: var(--mp-sxs);
}
.mb-xxs {
    margin-bottom: var(--mp-sxs);
}
.ml-xxs {
    margin-left: var(--mp-xss);
}
/* =============================================
### TEXT / HYPERLINKS
================================================ */
/* TEXT-ALIGNMENT */
.text-align-right {
    text-align: right;
}
.text-align-center {
    text-align: center;
}
.text-align-left {
    text-align: left;
}
.vertical-align-center .inner {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}



/* YEAH */
.align {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}
.vertical-center {
    justify-content: center;
    align-items: center;
}
.horizontal-center {
    text-align: center;
}


/* HEADLINES */
h1,
h2,
h3,
h4,
h5,
h6 {
    font-display: swap;
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 400;
    text-decoration:none;
    text-transform: uppercase;
    font-size:var(--font-size-headline-large);
    line-height:var(--line-height-headline-large);
    border:none;
    padding:0;
    margin:0;
    display: block;
    color: var(--black);
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
    hyphenate-limit-chars: auto 5;
    hyphenate-limit-lines: 2;
}
h1.white,
h2.white,
h3.white,
h4.white,
h5.white,
h6.white {
    color: var(--white);
}
h1 {
    margin-bottom: 50px;
    position: relative;
    display: inline-block; /* Macht die Überschrift so breit wie der Text */
}

h1::after {
    content: ""; /* Pseudo-Element benötigt content */
    position: absolute;
    left: 0;
    bottom: -5px; /* Abstand unter der Überschrift */
    width: 50px; /* Länge des Unterstrichs */
    height: 5px; /* Dicke des Unterstrichs */
    background-color: var(--green); /* Farbe des Unterstrichs */
}

h2 {
    font-size:var(--font-size-headline-medium);
    line-height:var(--line-height-headline-medium);
}
h3 {
    font-size:var(--font-size-headline-small);
    line-height:var(--line-height-headline-small);
}


/* FONT */
.font-size-small {
    font-size: var(--text-font-size-small);
    line-height: var(--text-font-line-height-small);
}
.font-size-xs {
    font-size: var(--text-font-size-xs);
    line-height: var(--text-font-line-height-xs);
}
/* BLOCKS UND ABSÄTZE  */
p {
    margin-block-start: 0 !important;
    margin-block-end: 0 !important;
}
/* HYPERLINKS */
a#light_a,
a#light_a:hover,
a#light_a:visited,
a#light_a:active,
a.light_a,
a.light_a:hover,
a.light_a:visited,
a.light_a:active,
a#light_a_gray,
a#light_a_gray:hover,
a#light_a_gray:visited,
a#light_a_gray:active,
a.light_a_gray,
a.light_a_gray:hover,
a.light_a_gray:visited,
a.light_a_gray:active
a#light_a_white,
a#light_a_white:hover,
a#light_a_white:visited,
a#light_a_white:active,
a.light_a_white,
a.light_a_white:hover,
a.light_a_white:visited,
a.light_a_white:active {
    color: var(--gray);
    margin:0px !important;
    padding:0px !important;
    background:none !important;
    text-decoration: none !important;
    -webkit-user-select: none !important;
    -webkit-touch-callout: none !important;
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
a#light_a_white,
a#light_a_white:hover,
a#light_a_white:visited,
a#light_a_white:active,
a.light_a_white,
a.light_a_white:hover,
a.light_a_white:visited,
a.light_a_white:active {
    color: var(--white);
}
a#light_a_trans,
a#light_a_trans:hover,
a#light_a_trans:visited,
a#light_a_trans:active,
a.light_a_trans,
a.light_a_trans:hover,
a.light_a_trans:visited,
a.light_a_trans:active {
    color: var(--trans);
}
a,
a:visited,
a:focus,
a:active {
    text-decoration: none;
    background: none;
    color: var(--gray);
    padding:0;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    -ms-transition: all 0.2s ease;
    transition: all 0.2s ease;
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
a:hover {
    text-decoration: none;
    background: none var(--gray);
    color: var(--white);
    padding:0 5px;
    -webkit-user-select: none;
    -webkit-touch-callout: none;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    -ms-transition: all 0.2s ease;
    transition: all 0.2s ease;
}
a.white,
a.white:visited,
a.white:focus,
a.white:active {
    background: none;
    color: var(--white);
}
a.white:hover {
    background: none var(--white);
    color: var(--gray);
}
/* FOOTER */

/* HYPERLINK-EFFECTS */
a.effect,
a.effect > span {
    position: relative;
    color: inherit;
    text-decoration: none;
    font-size: var(--text-font-size-small);
    line-height: var(--text-font-line-height-small);
}
a.effect:before,
a.effect:after,
a.effect > span:before,
a.effect > span:after {
    content: "";
    position: absolute;
    transition: transform 0.5s ease;
}
.effect-1,
.effect-2,
.effect-3 {
    display: inline-block;
    padding-top: 0px;
    padding-bottom: 0px;
    overflow: hidden;
}
.effect-1:before,
.effect-2:before,
.effect-3:before {
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: var(--darkblue);
    transform: translateX(-100%);
}
.effect-1:hover,
.effect-2:hover,
.effect-3:hover {
    background: none var(--trans);
    padding:0 0;
}
.effect-1:hover:before,
.effect-2:hover:before,
.effect-3:hover:before {
    transform: translateX(0);
}


a.effect.effect-2,
a.effect.effect-2 > span,
a.effect.effect-3,
a.effect.effect-3 > span {
    font-size: var(--text-font-size);
    line-height: var(--text-font-line-height);
}
.effect-2 {
    color: var(--white);
}
.effect-3 {
    color: var(--black);
}
.effect-2:before,
.effect-3:before {
    background: var(--rose);
}
.navigation-top a,
.navigation-top a:visited,
.navigation-top a:focus,
.navigation-top a:active,
.navigation-top a:hover {
    text-decoration: none;
    background: none;
    color: var(--white);
    padding:0;
    font-size: var(--text-font-size-small);
    line-height: var(--text-font-line-height-small);
    text-shadow: rgba(0,0,0,0.9) 0px 0px 8px;
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
.navigation-top a:hover {
    color: var(--white);
    -webkit-user-select: none;
    -webkit-touch-callout: none;
}
.rotate-xs {
    transform: rotate(0deg);
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
.rotate-xs:hover {
    transform: rotate(-5deg);
}


/* =============================================
### ELEMENTS / BUTTON / SPACER / CONTAINER / IMAGES
================================================ */



/* BUTTON-SETTINGS */
a.button:link,
a.button:visited,
a.button:active,
a.button:hover {
    border-width: 1px;
    border-style: solid;
    background: noen;
    background-color: none;
    margin-top:15px;
    padding: 3px 15px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    transition: background 350ms ease-in-out;
}
a.button.block,
a.button.white.block,
a.button.gray.block {
    display: block;
    margin: 15px auto;
}
a.button.white:link,
a.button.white:visited,
a.button.white:active,
a.button.white:hover {
    border-color: var(--white);
    color:var(--white);
}
a.button.white:hover {
    border-color: var(--white);
    background-color: var(--white);
    color: var(--gray);
}
a.button.gray:link,
a.button.gray:visited,
a.button.gray:active,
a.button.gray:hover {
    border-color: var(--gray);
    color:var(--gray);
}
a.button.gray:hover {
    border-color: var(--gray);
    background-color: var(--gray);
    color: var(--white);
}






/* CONTAINER */
.container-fluid-inner.first-container{
padding: ;osition: relative;
    margin-top: -15%;
}

.container-header-image {
    padding-top: 95px;
}

/*  SYMBOLS */
.symbol-lg i ,
hyperlinks .symbol-lg i {
    font-size: var(--font-size-headline-xlarge);
    line-height: var(--line-height-headline-xlarge);
    margin:20px 10px;
}
.hyperlinks .symbol-lg i {
    margin:0;
    color: var(--green);
}
.symbol-lg.symbol-gray i {
    color: var(--gray);
}
.symbol-lg.symbol-white i {
    color: var(--white);
}
.symbol-lg.symbol-red i {
    color: var(--red50);
}
.symbol-lg.symbol-green i {
    color: var(--green50);
}


/* TAGS */
.tag {
    padding:0 0 10px !important;
}
.tag.white {
    color: var(--white);
}
.tag.black {
    color: var(--black);
}
.tag.blue {
    color: var(--blue);
}
.tag.darkblue {
    color: var(--darkblue);
}
.tag.deepblue {
    color: var(--deepblue);
}
.tag.green {
    color: var(--green);
}
.tag.yellow {
    color: var(--yellow);
}

/* SPACER */
hr {
    width: 100%;
    height: 1px;
    border: none;
    padding:0;
    margin:0;
}
hr.line {
    border:1px dotted var(--black20);
    margin:25px 0;
}
hr.top-spacer {
    border:none;
    height:90px;
}
hr.content-spacer {
border:none;
height:100px;
}
hr.lg {
    margin-top: var(--mp-lg);
    margin-bottom: var(--mp-lg);
}
hr.md {
    margin-top: var(--mp-md);
    margin-bottom: var(--mp-md);
}
hr.sm {
    margin-top: var(--mp-sm);
    margin-bottom: var(--mp-sm);
}
hr.xs {
    margin-top: var(--mp-xs);
    margin-bottom: var(--mp-xs);
}
hr.xxs {
    margin-top: var(--mp-xxs);
    margin-bottom: var(--mp-xxs);
}


.spacer.lg {
    margin-right: var(--spacer-lg);
    margin-left: var(--spacer-lg);
}
.spacer.md {
    margin-right: var(--spacer-md);
    margin-left: var(--spacer-md);
}
.spacer.sm {
    margin-right: var(--spacer-sm);
    margin-left: var(--spacer-sm);
}
.spacer.xs {
    margin-right: var(--spacer-xs);
    margin-left: var(--spacer-xs);
}

/* IMAGES */
.img-responsive,
.img-responsive-100,
.img-responsive-90,
.img-responsive-80,
.img-responsive-70,
.img-responsive-60,
.img-responsive-50,
.img-responsive-40,
.img-responsive-30,
img.thumbs {
    display: block;
    width: auto ;
    height: auto;
    margin:0 auto;
    box-sizing:border-box;
    -ms-box-sizing:border-box;
    -moz-box-sizing:border-box; 
    -webkit-box-sizing:border-box; 
    -o-box-sizing:border-box;
    border:none;
}
.img-responsive {
    width: 100%;
}
.img-responsive-100 {
    max-width: 100%;
}
.img-responsive-90 {
    max-width: 90%;
}
.img-responsive-80 {
    max-width: 80%;
}
.img-responsive-70 {
    max-width: 70%;
}
.img-responsive-60 {
    max-width: 60%;
}
.img-responsive-50 {
    max-width: 50%;
}
.img-responsive-40 {
    max-width: 40%;
}
.img-responsive-30 {
    max-width: 30%;
}


/* Container für das Logo */




img.filter-grayscale {
    -webkit-filter: grayscale(1);
    filter: grayscale(1);
    opacity: 0.4;
    filter: alpha(opacity=40);
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
img.filter-grayscale:hover {
    -webkit-filter: grayscale(0);
    filter: grayscale(0);
    opacity: 1;
    filter: alpha(opacity=1);
}
img.fill,
img.fit {
    width:100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}
img.pr {
    position: relative;
}
img.pa {
    position: absolute;
}
img.top {
    top: 0;
}
img.right {
    right: 0;
    float:right;
}
img.bottom {
    bottom: 0;
}
img.left {
    left:0;
    float:left;
}
img.right,
img.left:after {
    clear: both;
}
img.margin-bottom {
    margin-bottom:35%;
}
img.border {
    border-width: 20px;
    border-style: solid;
}

.vertical-align-center img.align-center{
    margin: auto;
}

/* GALLERY  */
#swipebox-overlay {
    z-index: 999999999!important;
}
.gallery-item {
    margin: 0 !important;
    padding: 0 0 6px 15px!important;
    box-sizing:border-box;
    -ms-box-sizing:border-box;
    -moz-box-sizing:border-box; 
    -webkit-box-sizing:border-box; 
    -o-box-sizing:border-box;
}
img.attachment-thumbnail.size-thumbnail,
img.attachment-medium.size-medium,
img.attachment-large.size-large,
img.attachment-large.size-full,
img.attachment-320px_500px.size-320px_500px,
img.attachment-640px_480px.size-640px_480px,
img.attachment-800px_350px.size-800px_350px,
img.attachment-800px_450px.size-800px_450px,
img.attachment-800px_500px.size-800px_500px,
img.attachment-800px_600px.size-800px_600px,
img.attachment-fix_width_800px_flex_height.size-fix_width_800px_flex_height,
img.attachment-crop_800px_350px.size-crop_800px_350px,
img.attachment-crop_460px_460px.size-crop_460px_460px,
img.attachment-slider_image.size-slider_image,
img.attachment-xs.size-xs,
img.attachment-sm.size-sm,
img.attachment-md.size-md,
img.attachment-lg.size-lg {
    width:100%;
    height:auto;
    border:none !important;
}
.gallery-item a,
.gallery-item a:hover,
.gallery-item a:visited,
.gallery-item a:active {
    color: var(--trans);
    margin:0px !important;
    padding:0px !important;
    background:none !important;
    text-decoration: none !important;
    -webkit-user-select: none !important;
    -webkit-touch-callout: none !important;
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
.gallery-item a:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
/* Kontaktformular ===== */
.input_field,
.input_area,
#input_button {
    width:100%;
    height:auto;
    padding:15px 15px;
    margin-bottom:15px;
    background-color:var(--gray10);
    font-size: var(--text-font-size);
    line-height: var(--text-font-line-height);
    border:none;
    color:var(--black);
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    transition: all 0.5s ease;
}
.input_area {
    height:295px;
}
.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder{
    color:var(--black50);
}
#input_button,
#input_button:hover,
#input_button:focus {
    width: 100%;
    border-width: 1px;
    border-style: solid;
    background: none;
    background-color: var(--gray30);
    margin-top:15px;
    padding: 15px 15px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    transition: background 350ms ease-in-out;
    border-color: var(--gray30);
    color:var(--black);
}
#input_button:hover,
#input_button:focus {
    border-color: var(--green-hover);
    background-color: var(--green-hover);
    color: var(--white);
    outline-width: 0 !important;
}
#input_button i {
    margin-right:20px;
}






  


/* custom checkbox styling for contact form 7 checkbox */
span.wpcf7-list-item {
    display: inline-block;
    margin: 0;
}
.wpcf7 .wpcf7-list-item {
    display: block;
    margin-bottom: 10px;
}
.wpcf7-checkbox label {
    position: relative;
    cursor: pointer;
}
.wpcf7-checkbox input[type=checkbox] {
    /*position: relative;*/
    position: absolute;
    visibility: hidden;
    width: 30px;
    height: 30px;
    top: 0;
    left: 0;
}
.wpcf7-checkbox input[type=checkbox] + span {
    /* border: 3px solid red; */
}
.wpcf7-checkbox input[type=checkbox] + span:before {
    display: block;
    position: absolute;
    content: '';
    border-radius: 0;
    height: 30px;
    width: 30px;
    top: 0px;
    left: 0px;
    border: none;
    background-color: var(--gray30);
}
.wpcf7-checkbox input[type=checkbox] + span:after {
    display: block;
    position: absolute;
    content: "\2713";
    height: 30px;
    width: 30px;
    top: 0;
    left: 0;
    visibility: hidden;
    font-size: 18px;
    text-align: center;
    line-height: 30px;
}
.wpcf7-checkbox input[type=checkbox]:checked + span:before {
    background: transparent;
}
.wpcf7-checkbox input[type=checkbox]:checked + span:after {
    visibility: visible;
}
.wpcf7-list-item-label {
    margin-left: 40px;
    display: inline-block;
}

#checkbox_datenschutz .wpcf7-list-item-label {
    color: var(--trans);
}
.wpcf7-checkbox input[type=checkbox] + span:before, .wpcf7-checkbox input[type=checkbox] + span:after {
    color: #111;
}


.wpcf7 img.ajax-loader {
    width:auto;
    max-width:100%;
    height:auto;
    border:none;
}
.wpcf7 .flexx-h-p {
    opacity: 0;
}
/* =============================================
### TABLE / TABLEPRESS
================================================ */
table.flexx-table {
    width:100%;
    -webkit-border-horizontal-spacing: 2px;
    -webkit-border-vertical-spacing: 2px;
    border-top-color: none;
}
table.flexx-table tr {
    text-align: left;
}
table.flexx-table tr td{
    padding:5px 10px;
}
table.flexx-table thead tr {
    background-color: var(--green80) !important;
    color: var(--white) !important;
}
table.flexx-table tr:nth-child(even) {
    background-color: var(--green20);
}
table.flexx-table tr:nth-child(odd) {
    background-color: var(--green40);
}
table.flexx-table tr:hover {
    background-color: var(--green60);
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}
table.flexx-table.flexx-col-1 td,
table.flexx-table.flexx-col-2 td {
    width:50%;
}
table.flexx-table.flexx-col-3 td {
    width:33.3333%;
}
table.flexx-table.flexx-col-4 td {
    width:25%;
}

table.flexx-table.downloads {
  width: 100%;
  table-layout: auto; 
}

table.flexx-table.downloads thead tr {
  background-color: var(--trans) !important;
  color: var(--black) !important;
  
}

table.flexx-table.downloads tbody tr td:first-child {
  width: 1%;
  white-space: nowrap; 
  text-align: center;
}

table.flexx-table.downloads tbody tr td:first-child i {
  display: inline-block;
  width: 1em;
  height: 1em;
  line-height: 1;
  vertical-align: middle;
  
}

table.flexx-table.downloads tbody tr td:last-child {
  width: auto;
}



/*


.tablepress > :where(thead, tfoot) > * > th {
    background-color: var(--lightblue) !important;
    color: var(--darkblue) !important;
    font-weight: normal !important;
    padding: var(--spacer-sm) !important;
}
.tablepress > * + tbody > * > *,
.tablepress > tbody > * ~ * > *,
.tablepress > tfoot > * > * {
    border-top: 1px dotted var(--lightblue30) !important;
}
.tablepress > :where(tbody) > .even > *,
.tablepress > :where(tbody) > .odd > * {
    background-color: var(--lightblue10) !important;
    padding: var(--spacer-sm) !important;
    color: var(--white) !important;
}
.tablepress > :where(tbody) > .even > * {
    background-color: var(--lightblue5) !important;
}
.tablepress > .row-hover > tr:hover > * {
    background-color: var(--lightblue20) !important;
    color: var(--white) !important;
}
.tablepress a,
.tablepress a:hover,
.tablepress a:visited,
.tablepress a:active {
    text-decoration: none;
    background: none;
    color: var(--white);
    padding:0;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    -ms-transition: all 0.2s ease;
    transition: all 0.2s ease;
    -webkit-transition: var(--transition-normal);
    -moz-transition: var(--transition-normal);
    -o-transition: var(--transition-normal);
    -ms-transition: var(--transition-normal);
    transition: var(--transition-normal);
}

/*


/* ---------- PAGINATION STYLE ---------- */
.pagination-wrapper {
    text-align: center;
    margin: 40px 0;
}

/* Basis-Styling */
.pagination-wrapper ul {
    display: inline-flex;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: center;
}

.pagination-wrapper li {
    display: inline-block;
}

/* Links & Seitenzahlen */
.pagination-wrapper a,
.pagination-wrapper span {
    display: inline-block;
    padding: 10px 14px;
    background: var(--lightgray);
    color: var(--black);
    text-decoration: none;
    font-size: 14px;
    line-height: 1;
    min-width: 40px;
    text-align: center;
    transition: all 0.2s ease;
}

/* Hover */
.pagination-wrapper a:hover {
    background: var(--lightgray-hover);
    color: var(--black);
}

/* Aktive Seite */
.pagination-wrapper .current {
    background: var(--lightgray-hover);
    color: var(--black);
    font-weight: 600;
}

/* ---------- RESPONSIVE ---------- */

/* Tablet: kompakter */
@media (max-width: 992px) {
    .pagination-wrapper ul {
        gap: 4px;
    }
    .pagination-wrapper a,
    .pagination-wrapper span {
        padding: 9px 12px;
        min-width: 36px;
        font-size: 13px;
    }
}

/* Mobile: horizontal scrollbar, gut klickbar */
@media (max-width: 600px) {
    .pagination-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .pagination-wrapper ul {
        display: flex;
        gap: 4px;
        justify-content: flex-start;
        flex-wrap: nowrap;
        padding: 0 8px;
        margin: 0 auto;
        width: max-content;
    }
    .pagination-wrapper a,
    .pagination-wrapper span {
        padding: 12px 14px;
        min-width: 42px;
        font-size: 15px;
        border-radius: 8px;
    }
    .pagination-wrapper .prev,
    .pagination-wrapper .next {
        font-weight: 600;
    }
}



/* =============================================
###
================================================ */
@media (max-width: 767px) {
    body {
        font-size:var(--text-font-size-small);
        line-height:var(--text-font-line-height-small);
    }
    header .logo img,
    header.shrink .logo img {
        max-height: 45px;
        margin:5px 10px 5px;
    }
    .container-video {
        width:auto;
    }
    video { 
        width: 100%;
        height: 100vh;
        object-fit: cover;
        object-position: center;
    }
    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-size:var(--font-size-headline-small);
        line-height:var(--line-height-headline-small);
        margin:0;
    }
    h3 {
        font-size:var(--font-size-headline-xsmall);
        line-height:var(--line-height-headline-xsmall);
    }
    .symbol-lg i ,
    hyperlinks .symbol-lg i {
        font-size: var(--font-size-headline-medium);
        line-height: var(--line-height-headline-medium);
    }
}

/* =============================================
###
================================================ */
@media (min-width: 768px) {
    header .logo img {
        max-height: 80px;
    }

    header.shrink .logo img {
        max-height: 65px;
    }

}


/* =============================================
###
================================================ */
@media (min-width: 992px) {
    hr.top-spacer {
        height:150px;
    }
    header .logo img {
        max-height: 125px;
    }

    header.shrink .logo img {
        max-height: 70px;
    }
}

/* =============================================
###
================================================ */
@media (min-width: 1200px) {
    hr.top-spacer {
        height:200px;
    }

    header .logo img {
        max-height: 140px;
    }

    header.shrink .logo img {
        max-height: 90px;
    }
    
}