/*
███████████████████████████████████████████████████████████████████████████████████████████████
    FontAwesome
███████████████████████████████████████████████████████████████████████████████████████████████
*/
@import "fontawesome/fontawesome.min.css";
@import "fontawesome/brands.min.css";
@import "fontawesome/solid.min.css";
/*
██████████████████████████████████████████████████████████████████████████████████████
  Fonts
██████████████████████████████████████████████████████████████████████████████████████
*/
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/open-sans-v44-latin-300.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300;
  src: url("../fonts/open-sans-v44-latin-300italic.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/open-sans-v44-latin-regular.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 400;
  src: url("../fonts/open-sans-v44-latin-italic.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/open-sans-v44-latin-600.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 600;
  src: url("../fonts/open-sans-v44-latin-600italic.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/open-sans-v44-latin-700.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 700;
  src: url("../fonts/open-sans-v44-latin-700italic.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/open-sans-v44-latin-800.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 800;
  src: url("../fonts/open-sans-v44-latin-800italic.woff2") format("woff2");
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Resets
███████████████████████████████████████████████████████████████████████████████████████████████
*/
*,
*::before,
*::after {
  box-sizing: border-box;
}
* {
  margin: 0;
  padding: 0;
  font: inherit;
  border: none;
  background-repeat: no-repeat;
}
header,
section,
footer,
aside,
nav,
main,
article,
figure {
  display: block;
}
ol,
ul {
  list-style: none;
}
ol li {
  list-style: decimal;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
img,
picture,
svg,
video {
  display: block;
  max-width: 100%;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
}
small {
  font-size: 0.8em;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Viewport-Anweisung
███████████████████████████████████████████████████████████████████████████████████████████████
*/
@-ms-viewport {
  width: device-width;
  zoom: 1;
}
@-o-viewport {
  width: device-width;
  zoom: 1;
}
@viewport {
  width: device-width;
  zoom: 1;
}
/*
██████████████████████████████████████████████████████████████████████████████████████
    Barrierefreiheit
██████████████████████████████████████████████████████████████████████████████████████
*/
:root {
  --focus_outline_size: max(3px, 0.1em);
  --focus_outline_style: solid;
  --focus_outline_offset: 0.1rem;
  --focus_outline_color: oklch(49% 0.2 310);
}
@supports selector(:focus-visible) {
  *:focus {
    outline: none;
  }
}
*:focus-visible {
  outline: var(--focus_outline_size) var(--focus_outline_style)
    var(--focus_outline_color);
  outline-offset: var(--focus_outline_offset, var(--focus_outline_size));
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Variablen
███████████████████████████████████████████████████████████████████████████████████████████████
*/
:root {
  --font_serif: Charter, "Bitstream Charter", "Sitka Text", Cambria, serif;
  --font_sans_serif: "Open Sans", sans-serif;

  --font_size_html: 18px;

  --font_size_h1: 2.8em;
  --font_size_h2: 2em;
  --font_size_h3: 1.6em;
  --font_size_h4: 1.2em;

  --font_color_default: #333;
  --font_color_heading: #222;
  --font_color_link: #0e5287;

  --font_weight_light: 300;
  --font_weight_normal: 400;
  --font_weight_medium: 600;
  --font_weight_bold: 700;
  --font_weight_black: 800;

  --fontawesome: "Font Awesome 6 Free";
  --fontawesome_brands: "Font Awesome 6 Brands";

  /* CI-Farbe #1 - rot */
  --_hue_saturation_ci: 3, 78%;
  --_lightness_ci: 53%;
  --color_ci: hsl(var(--_hue_saturation_ci), var(--_lightness_ci));
  --color_ci_5p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 5%))
  );
  --color_ci_10p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 10%))
  );
  --color_ci_15p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 15%))
  );
  --color_ci_20p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 20%))
  );
  --color_ci_25p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 25%))
  );
  --color_ci_30p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 30%))
  );
  --color_ci_35p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 35%))
  );
  --color_ci_40p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 40%))
  );
  --color_ci_45p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 45%))
  );
  --color_ci_50p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 50%))
  );
  --color_ci_55p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 55%))
  );
  --color_ci_60p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 60%))
  );
  --color_ci_65p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 65%))
  );
  --color_ci_70p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 70%))
  );
  --color_ci_75p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 75%))
  );
  --color_ci_80p: hsl(
    var(--_hue_saturation_ci),
    min(100%, calc(var(--_lightness_ci) + 80%))
  );
  --color_ci_5m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 5%))
  );
  --color_ci_10m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 10%))
  );
  --color_ci_15m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 15%))
  );
  --color_ci_20m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 20%))
  );
  --color_ci_25m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 25%))
  );
  --color_ci_30m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 30%))
  );
  --color_ci_35m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 35%))
  );
  --color_ci_40m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 40%))
  );
  --color_ci_45m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 45%))
  );
  --color_ci_50m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 50%))
  );
  --color_ci_55m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 55%))
  );
  --color_ci_60m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 60%))
  );
  --color_ci_65m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 65%))
  );
  --color_ci_70m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 70%))
  );
  --color_ci_75m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 75%))
  );
  --color_ci_80m: hsl(
    var(--_hue_saturation_ci),
    max(0%, calc(var(--_lightness_ci) - 80%))
  );

  --color_cat_red: #bd1622;
  --color_cat_green: #79ab2b;
  --color_cat_blue: #006eb6;
  --color_cat_orange: #f29100;

  --color_grey: #6b6b6b;

  --color_emphasis: hsl(21, 100%, 45%);

  --color_bg_light_grey: #f4f4f4;

  --text_line_height: 1.7em;
  --text_block_spacer: 1.5em;

  --boundary_width_wide: 1700px;
  --boundary_width_regular: 1200px;
  --boundary_width_narrow: 980px;
}
@media (max-width: 700px) {
  :root {
    --font_size_html: 17px;
  }
}
@media (max-width: 600px) {
  :root {
    --font_size_html: 16px;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    allgemeine Einstellungen
███████████████████████████████████████████████████████████████████████████████████████████████
*/
html {
  font-size: var(--font_size_html);
  scroll-behavior: smooth;
  min-height: 100%;
  position: relative;
  background-color: #fff;
}
body {
  font-size: 100%;
}
body,
body * {
  font-family: var(--font_sans_serif);
  color: var(--font_color_default);
  line-height: var(--text_line_height);
  font-weight: var(--font_weight_normal);
}
p,
table {
  margin-bottom: var(--text_block_spacer);
}
strong {
  font-weight: var(--font_weight_bold);
}
strong * {
  font-weight: inherit;
}
i,
em {
  font-style: italic;
}
a {
  text-decoration: none;
}
#content a:not([class]),
#content a.telephone,
#content a.email {
  color: var(--font_color_link);
  text-decoration: underline;
}
ul[class],
ul[id] {
  list-style: none;
  margin: 0;
  padding: 0;
}
.center {
  text-align: center !important;
}
.center > * {
  display: inline-block;
}
.clear {
  clear: both;
  float: none;
  display: block;
}
.anchor {
  position: sticky;
  display: block;
  width: 0;
  height: 0;
  margin-top: -165px;
}
.content_grid > div .anchor {
  position: absolute;
}
a.fancybox {
  display: inline-block;
  cursor: zoom-in;
  justify-self: start;
  margin-bottom: 1.5rem;
}
a.fancybox img[style*="float:left"],
a.fancybox img[style*="float: left"] {
  margin: 0 2% 1% 0;
}
a.fancybox img[style*="float:right"],
a.fancybox img[style*="float: right"] {
  margin: 0 0 1% 2%;
}
a.fancybox.right {
  display: inline-block;
  float: right;
  margin: 0 0 1% 2%;
  box-shadow:
    0px 0px 0.5px rgba(0, 0, 0, 0.017),
    0px 0px 1.1px rgba(0, 0, 0, 0.024),
    0px 0px 2.1px rgba(0, 0, 0, 0.03),
    0px 0px 3.8px rgba(0, 0, 0, 0.036),
    0px 0px 7.1px rgba(0, 0, 0, 0.043),
    0px 0px 17px rgba(0, 0, 0, 0.06);
  cursor: zoom-in;
}
@media (max-width: 850px) {
  a.fancybox.right {
    max-width: 30%;
  }
}
@media (max-width: 400px) {
  a.fancybox.right {
    float: none;
    margin-left: 0;
    max-width: unset;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    dynamische Schriftgröße
███████████████████████████████████████████████████████████████████████████████████████████████
*/
@media (max-width: 1300px) {
  body {
    font-size: 98.4%;
  }
}
@media (max-width: 1200px) {
  body {
    font-size: 96.8%;
  }
}
@media (max-width: 1100px) {
  body {
    font-size: 95.2%;
  }
}
@media (max-width: 1000px) {
  body {
    font-size: 93.6%;
  }
}
@media (max-width: 900px) {
  body {
    font-size: 92%;
  }
}
@media (max-width: 800px) {
  body {
    font-size: 90.4%;
  }
}
@media (max-width: 700px) {
  body {
    font-size: 88.8%;
  }
}
@media (max-width: 600px) {
  body {
    font-size: 87.2%;
  }
}
@media (max-width: 500px) {
  body {
    font-size: 85.6%;
  }
}
@media (max-width: 400px) {
  body {
    font-size: 84%;
  }
}
@media (max-width: 300px) {
  body {
    font-size: 82.4%;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Überschriften
███████████████████████████████████████████████████████████████████████████████████████████████
*/
h1,
h2,
h3,
h4 {
  display: block;
  clear: both;
  float: none;
  overflow: visible;
  text-align: left;
  line-height: calc(var(--text_line_height) * 0.7);
  color: var(--font_color_heading);
  font-weight: var(--font_weight_medium);
  /* font-family: var(--font_serif); */
}
h1 *,
h2 *,
h3 *,
h4 * {
  line-height: inherit;
  font-weight: inherit;
}
h1,
.like_h1 {
  font-size: var(--font_size_h1);
  margin-top: 0;
  margin-bottom: calc(var(--font_size_h1) * 0.5);
  font-weight: var(--font_weight_normal);
  text-align: center;
}
h1 + .subheading {
  font-size: calc(var(--font_size_h1) * 0.5);
  margin-top: calc(var(--font_size_h1) * -0.4);
  margin-bottom: calc(var(--font_size_h1) * 0.5);
  padding-left: 0.1em;
}
h2,
.like_h2 {
  font-size: var(--font_size_h2);
  margin-top: calc(var(--font_size_h2) * 0.5);
  margin-bottom: calc(var(--font_size_h2) * 0.3);
  font-weight: var(--font_weight_normal);
}
h3 {
  font-size: var(--font_size_h3);
  margin-top: calc(var(--font_size_h3) * 0.6);
  margin-bottom: calc(var(--font_size_h3) * 0.5);
}
h2 + h3 {
  margin-top: 0;
}
h4 {
  font-size: var(--font_size_h4);
  margin-top: calc(var(--font_size_h4) * 1.5);
  margin-bottom: calc(var(--font_size_h4) * 0.3);
}
@media (max-width: 1100px) {
  h1,
  h2.like_h1 {
    font-size: calc(var(--font_size_h1) * 0.84);
  }
  h2,
  h1.like_h2 {
    font-size: calc(var(--font_size_h2) * 0.88);
  }
  h3 {
    font-size: calc(var(--font_size_h3) * 0.92);
  }
  h4 {
    font-size: calc(var(--font_size_h4) * 0.96);
  }
}
@media (max-width: 900px) {
  h1,
  h2.like_h1 {
    font-size: calc(var(--font_size_h1) * 0.8);
    text-transform: none;
  }
  h2,
  h1.like_h2 {
    font-size: calc(var(--font_size_h2) * 0.87);
  }
  h3 {
    font-size: calc(var(--font_size_h3) * 0.94);
  }
}
@media (max-width: 600px) {
  h1,
  h2.like_h1 {
    font-size: calc(var(--font_size_h1) * 0.78);
  }
  h2,
  h1.like_h2 {
    font-size: calc(var(--font_size_h2) * 0.83);
  }
  h3 {
    font-size: calc(var(--font_size_h3) * 0.88);
  }
  h4 {
    font-size: calc(var(--font_size_h4) * 0.93);
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Grund-Layout mit grid
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.content_grid {
  --padding_inline: 4vw;
  --wide_max_width: 1550px;
  --norm_max_width: 1300px;
  --narrow_max_width: 900px;
  --wide_size: calc((var(--wide_max_width) - var(--norm_max_width)) / 2);
  --norm_size: calc((var(--norm_max_width) - var(--narrow_max_width)) / 2);
  display: grid;
  grid-template-columns:
    [full_width-start]
    minmax(var(--padding_inline), 1fr)
    [wide-start]
    minmax(0, var(--wide_size))
    [norm-start]
    minmax(0, var(--norm_size))
    [narrow-start]
    min(((100% - var(--padding_inline) * 2) / 2), var(--narrow_max_width) / 2)
    [middle]
    min(((100% - var(--padding_inline) * 2) / 2), var(--narrow_max_width) / 2)
    [narrow-end]
    minmax(0, var(--norm_size))
    [norm-end]
    minmax(0, var(--wide_size))
    [wide-end]
    minmax(var(--padding_inline), 1fr)
    [full_width-end];
}
.content_grid > :not(.full_width, .wide, .narrow),
.full_width > :not(.full_width, .wide, .narrow) {
  grid-column: norm;
}
.content_grid > .wide {
  grid-column: wide;
}
.content_grid > .norm {
  grid-column: norm;
}
.content_grid > .narrow {
  grid-column: narrow;
}
.content_grid > .full_width {
  grid-column: full_width;
  display: grid;
  grid-template-columns: inherit;
}
.content_grid > .full_width.force {
  display: block;
  grid-template-columns: unset;
}
.content_grid > .full_width > .wide {
  grid-column: wide;
}
.content_grid > .full_width > .narrow {
  grid-column: narrow;
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Column-Layout
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.clc {
  overflow: auto;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  align-content: stretch;
}
.clc.vcenter {
  align-items: center;
  align-content: center;
}
.clc .col {
  flex-grow: 0;
  flex-shrink: 1;
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Header
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#header {
  --animation_duration: 300ms;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 5;
  max-width: inherit;
  background-color: #fff;
  transition: box-shadow var(--animation_duration) ease-in-out;
}
body:not(.home) #header {
  border-bottom: 3px solid var(--color_ci);
}
#header.shrink {
  box-shadow:
    0px 0px 1.7px rgba(0, 0, 0, 0.031),
    0px 0px 4px rgba(0, 0, 0, 0.044),
    0px 0px 7.5px rgba(0, 0, 0, 0.055),
    0px 0px 13.4px rgba(0, 0, 0, 0.066),
    0px 0px 25.1px rgba(0, 0, 0, 0.079),
    0px 0px 60px rgba(0, 0, 0, 0.11);
  border-width: 1px !important;
}
/* ========================================================================================= */
#header .top_line {
  background-color: #fff;
  padding-top: 0.8em;
  font-size: 0.8em;
  transition: all var(--animation_duration) ease-in-out;
  text-align: right;
  max-height: 5rem;
}
#header.shrink .top_line {
  padding-top: 0;
  font-size: 0;
  max-height: 0;
}
#header .top_line * {
  color: inherit;
}
#header.shrink .top_line > * {
  opacity: 0;
}
#header .top_line .social_media a {
  padding: 0.5em;
  margin-inline: 0.2em;
}
#header .top_line a:hover {
  color: var(--color_ci_20p);
}
#header .top_line .social_media a i {
  font-size: 1.1rem;
  color: #6b6b6b;
}
#header .top_line .social_media a:hover i {
  color: #000;
}
/* ========================================================================================= */
#header .main_line {
  padding-bottom: 0.5rem;
  transition: all var(--animation_duration) ease-in-out;
}
#header.shrink .main_line {
  padding-top: 0.3rem;
}
#header .main_line .grid {
  display: grid;
  align-content: space-between;
  justify-content: space-between;
  align-items: center;
  justify-items: auto;
  grid-template-columns: repeat(2, auto);
  gap: 2rem;
}
#header .logo {
  display: block;
}
#header .logo img {
  display: block;
  width: 412px;
  transition: all var(--animation_duration);
}
#header.shrink .logo img {
  width: 300px;
}
@media (max-width: 107rem) {
  #header .logo img {
    width: 300px;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Button
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.button {
  --_button_color: var(--color_grey);
  --_button_hover_color: var(--color_ci);
  --_button_border_radius: 0.55em;
  --_button_margin: 1rem;
  color: var(--_button_color);
  padding: 0.8em 1.3em;
  margin-top: var(--_button_margin);
  font-weight: var(--font_weight_medium);
  border: 3px solid var(--_button_color);
  background-color: transparent;
  overflow: hidden;
  line-height: 1.1em;
  cursor: pointer;
  display: inline-block;
  font-size: 1.1em;
  text-decoration: none !important;
  text-align: center;
  border-top-left-radius: var(--_button_border_radius);
  border-bottom-right-radius: var(--_button_border_radius);
}
.button:hover {
  --_button_color: var(--_button_hover_color) !important;
}
.button * {
  color: inherit;
  line-height: inherit;
}
.button:has(+ .button) {
  margin-right: var(--_button_margin);
}
.button i {
  margin-left: 0;
  margin-right: 0.35em;
}
.button i:last-child {
  margin-left: 0.35em;
  margin-right: 0;
}
/* ------------------------------------------------ */
.button.red {
  --_button_color: var(--color_ci_10m);
  --_button_hover_color: #444;
}
/* ------------------------------------------------ */
.button.white {
  --_button_color: #fff;
  --_button_hover_color: #444;
}
/* ------------------------------------------------ */
.button.filled {
  background-color: var(--_button_color);
  color: #fff;
}
@media (max-width: 80rem) {
  .button {
    font-size: 1em;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Viewport-Effects
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.vpe.taut {
  opacity: 0;
  transform: translateX(20%);
  transition: all 500ms ease-out;
}
.vpe.from_left.taut {
  transform: translateX(-10%);
}
body.nojs .vpe.taut,
.vpe.visible {
  opacity: 1;
  transform: translateX(0) !important;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Content
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#content {
  overflow: hidden visible;
  padding: 0;
  --section-vertical-padding: 6rem;
  min-height: 56vh;
  background-attachment: fixed;
  --border_radius: 1.3rem;
}
body:not(.home) #content {
  --section-vertical-padding: 3rem;
}
#content section {
  padding: var(--section-vertical-padding) 0;
}
#content section:has(> * > .side_by_side) {
  padding-block-start: calc(var(--section-vertical-padding) / 2);
}
#content section.no_top_space {
  padding-top: 0;
}
/* body:not(.home) #content section + section {
  border-top: 2px solid var(--color_ci2_15p);
} */
#content section > div h2:first-of-type,
#content section > div h3:first-of-type {
  margin-top: 0;
}
body.home #content section h2 {
  margin-top: 0 !important;
  color: var(--color_grey);
  font-weight: var(--font_weight_bold);
  font-size: 1.5em;
  text-transform: uppercase;
}
#content section > *:last-child {
  margin-bottom: 0;
}
#content section > h2:first-child,
#content section > .anchor:first-child + h2 {
  margin-top: 0;
}
#content section h2 .sup_line {
  display: block;
  color: var(--color_ci);
  font-weight: var(--font_weight_normal);
  font-size: 0.52em;
  text-transform: uppercase;
}
#content section h2 .sup_line::before {
  content: "";
  display: inline-block;
  width: 2em;
  height: 1px;
  background-color: var(--color_ci2);
  margin-right: 0.85em;
  margin-bottom: 0.3em;
}
#content article {
  padding-block: 3rem;
  position: relative;
}
#content article:first-of-type {
  padding-top: 1rem;
}
#content article > h2 {
  margin-top: 0 !important;
}
#content article > *:last-child {
  margin-bottom: 0 !important;
}
#content article + article::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(
    to right,
    var(--color_ci2_40p) 0%,
    var(--color_ci2) 50%,
    var(--color_ci2_40p) 100%
  );
}
#content hr {
  --space_multiplier: 2;
  position: relative;
  border: none;
  height: 1px;
  margin-inline: 0;
  margin-top: calc(
    max(0, (var(--space_multiplier) - 1)) * var(--text_block_spacer)
  );
  margin-bottom: calc(var(--space_multiplier) * var(--text_block_spacer));
  background: linear-gradient(
    to right,
    var(--color_ci2_40p) 0%,
    var(--color_ci2) 50%,
    var(--color_ci2_40p) 100%
  );
}
#content hr + * {
  margin-top: 0 !important;
}
#content ul:not([class]):not([id]) {
  margin-left: 2rem;
  list-style: none;
  margin-bottom: var(--text_block_spacer);
}
#content ul:not([class]):not([id]) li {
  margin-top: calc(var(--text_block_spacer) * 0.5);
  line-height: calc(var(--text_line_height) * 0.9);
}
#content ul:not([class]):not([id]) li:first-child {
  margin-top: 0;
}
#content ul:not([class]):not([id]) {
  margin-left: 0.5ch;
}
#content ul:not([class]):not([id]) li {
  position: relative;
  padding-left: 2.5ch;
}
#content ul:not([class]):not([id]) li::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0.4ch;
  width: 0.9em;
  height: 0.9em;
  background-color: var(--color_ci, #333);
  border-top-left-radius: 0.3em;
  border-bottom-right-radius: 0.3em;
}
#content .color_cat_red ul:not([class]):not([id]) li::before {
  background-color: var(--color_cat_red, #333);
}
#content .color_cat_orange ul:not([class]):not([id]) li::before {
  background-color: var(--color_cat_orange, #333);
}
#content .color_cat_blue ul:not([class]):not([id]) li::before {
  background-color: var(--color_cat_blue, #333);
}
#content .color_cat_green ul:not([class]):not([id]) li::before {
  background-color: var(--color_cat_green, #333);
}
#content ol {
  margin-left: 3.3em;
}
#content ol li {
  margin-top: 0.6em;
}
#content p,
#content table,
#content ol {
  margin-bottom: var(--text_block_spacer);
}
#content p.right {
  text-align: right;
}
#content table {
  justify-self: start;
  border-collapse: separate;
  border-spacing: 0 0.5em;
}
#content table tr {
  margin-bottom: 1rem;
}
#content table td {
  padding: 0.2em 1em;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
#content img {
  max-width: 100%;
}
#content img.right {
  float: right;
  margin: 0 0 0.5em 1.5em;
  max-width: 50%;
}
#content img.left {
  float: left;
  margin: 0 1.5em 0.5em 0;
  max-width: 50%;
}
#content .fullsize_pic {
  display: block;
  width: 100%;
}
#content ul a.fancybox {
  display: inline-block;
  margin: 0.4em 0.4em 0.7em 0.4em;
  line-height: 0;
  box-shadow:
    0 0px 0.7px -3px rgba(0, 0, 0, 0.02),
    0 0px 1.6px -3px rgba(0, 0, 0, 0.028),
    0 0px 3px -3px rgba(0, 0, 0, 0.035),
    0 0px 5.4px -3px rgba(0, 0, 0, 0.042),
    0 0px 10px -3px rgba(0, 0, 0, 0.05),
    0 0px 24px -3px rgba(0, 0, 0, 0.07);
}
#content button {
  border: none;
}
@media (max-width: 85rem) {
  #content {
    --section-vertical-padding: 5rem;
  }
}
@media (max-width: 65rem) {
  #content section:first-of-type {
    margin-top: 4rem;
  }
}
@media (max-width: 60rem) {
  #content {
    --border_radius: 1rem;
  }
}
@media (max-width: 50rem) {
  #content section:first-of-type {
    margin-top: 3.5rem;
  }
}
@media (max-width: 700px) {
  #content img.left,
  #content img.right {
    float: none;
    margin: 0 0 1em 0;
    width: auto;
    max-width: 100%;
  }
}
@media (max-width: 30rem) {
  #content section:first-of-type {
    margin-top: 0.5rem;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Bild-Text-Layout
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.pic_text_layout {
  overflow: visible;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: start;
  align-content: stretch;
  --pic_width: 500px;
  --gap: 4rem;
  margin-bottom: var(--text_block_spacer);
}
.pic_text_layout + .pic_text_layout {
  margin-top: 3em;
}
.pic_text_layout .col {
  flex-grow: 0;
  flex-shrink: 1;
}
.pic_text_layout .col.pic {
  position: relative;
  width: var(--pic_width);
  padding-top: 0.5em;
}
.pic_text_layout .col.pic img {
  display: block;
  width: auto;
  max-width: 100%;
}
.pic_text_layout .col.text {
  width: calc(100% - var(--pic_width) - var(--gap));
}
.pic_text_layout .col > h2,
.pic_text_layout .col > h3 {
  margin-top: 0;
}
@media (max-width: 70rem) {
  .pic_text_layout {
    display: block;
  }
  .pic_text_layout .col {
    width: 100% !important;
  }
}

/*
██████████████████████████████████████████████████████████████████████████████████████
    "Side by Side"-Layout
██████████████████████████████████████████████████████████████████████████████████████
*/
.side_by_side {
  --_border_radius: 1.5rem;
  position: relative;
  --text_col_width: 60%;
  --gap_vertical: 1rem;
  --gap_horizontal: 2rem;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  align-content: stretch;
  gap: var(--gap_vertical) var(--gap_horizontal);
  @media (max-width: 60rem) {
    & {
      flex-direction: column !important;
      align-items: flex-start;
    }
  }
}
.side_by_side:has(+ *) {
  margin-block-end: var(--text_block_spacer);
}
.side_by_side.reverse {
  flex-direction: row-reverse;
}
.side_by_side .text_col {
  flex: 0 0 var(--text_col_width);
  background-color: var(--color_bg_light_grey);
  padding: 2rem;
  border-radius: 0;
  border-top-left-radius: var(--_border_radius);
  @media (max-width: 60rem) {
    & {
      border-bottom-right-radius: var(--_border_radius);
      align-self: stretch;
    }
  }
}
.side_by_side.reverse .text_col {
  border-radius: 0;
  border-bottom-right-radius: var(--_border_radius);
}
.side_by_side .text_col :last-child,
.side_by_side .text_col :last-child :last-child {
  margin-block-end: 0 !important;
}
.side_by_side .media_col {
  flex-grow: 1;
  overflow: hidden;
  position: relative;
  border-radius: 0;
  border-bottom-right-radius: var(--_border_radius);
}
.side_by_side.reverse .media_col {
  border-radius: 0;
  border-top-left-radius: var(--_border_radius);
}
.side_by_side .media_col > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  @media (max-width: 60rem) {
    width: auto;
    height: auto;
    object-fit: unset;
    border-top-left-radius: var(--_border_radius);
    border-bottom-right-radius: var(--_border_radius);
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    "Hero"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#hero {
  background-color: #fff;
  position: relative;
  padding-top: 1rem;
}
#hero .intro_con {
  overflow: visible;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  align-content: stretch;
  --pic_width: 550px;
  --gap: 4rem;
  margin-bottom: 0;
}
#hero .intro_con .col {
  flex-grow: 0;
  flex-shrink: 1;
}
#hero .intro_con .col.pic {
  width: var(--pic_width);
  position: relative;
}
#hero .intro_con .col.pic img {
  display: block;
  width: auto;
  max-width: 100%;
}
#hero .intro_con .col.text {
  width: calc(100% - var(--pic_width) - var(--gap));
  text-align: center;
}
#hero h1 {
  color: var(--color_ci);
  font-size: 2.9em;
  text-transform: uppercase;
  font-weight: var(--font_weight_medium);
  margin-top: 0;
  margin-bottom: 0.7em;
}
@media (max-width: 100rem) {
  #hero .intro_con {
    --pic_width: 500px;
  }
  #hero h1 {
    font-size: 2.4em;
  }
}
@media (max-width: 85rem) {
  #hero .intro_con {
    --pic_width: 450px;
  }
  #hero h1 {
    font-size: 2.1em;
  }
}
@media (max-width: 75rem) {
  #hero .intro_con {
    --pic_width: 400px;
  }
}
@media (max-width: 65rem) {
  #hero .intro_con {
    --pic_width: 300px;
  }
}
@media (max-width: 50rem) {
  #hero h1 {
    font-size: 2em;
  }
}
@media (max-width: 43rem) {
  #hero .intro_con {
    margin-top: 2rem;
  }
  #hero .intro_con .col {
    width: 100% !important;
  }
  #hero .intro_con .col.pic img {
    display: block;
    width: var(--pic_width);
    max-width: 100%;
    margin: 2rem auto 0;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    HP-Section "Über Uns"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#about_us {
  padding-block: 0 !important;
}
#about_us .side_by_side {
  --text_col_width: 53.7%;
  @media (max-width: 90rem) {
    & {
      --text_col_width: 50%;
    }
  }
  @media (max-width: 85rem) {
    & {
      --text_col_width: 45%;
    }
  }
  @media (max-width: 75rem) {
    & {
      flex-direction: column !important;
      align-items: flex-start;
    }
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    HP-Section "Leistungen"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#services .service_grid {
  --_border_radius: 1rem;
  display: grid;
  align-content: space-between;
  justify-content: stretch;
  align-items: center;
  justify-items: stretch;
  grid-template-columns: 1fr 1fr;
  gap: 5rem 2.1rem;
}
#services .service_grid li {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  background-position: 50% 50%;
  background-size: cover;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#services .service_grid li.grgr {
  background-image: url("../bilder/home/gebaeude-und-glasreinigung.webp");
}
#services .service_grid li.srbr {
  background-image: url("../bilder/home/sonder-und-baureinigung.webp");
}
#services .service_grid li.lpgphd {
  background-image: url("../bilder/home/landschafts-und-gruenflaechenpflege-hausmeisterdienste.webp");
}
#services .service_grid li.gfwd {
  background-image: url("../bilder/home/grauflaechenpflege-winterdienst.webp");
}
#services .service_grid li.cs {
  background-image: url("../bilder/home/containerservice.webp");
}
#services .service_grid li a {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  position: relative;
  overflow: visible;
}
#services .service_grid li a .overlay {
  display: block;
  width: 100%;
  position: absolute;
  bottom: 0;
  transform-origin: bottom left;
  transform: translateY(2rem);
  display: grid;
  align-content: space-between;
  justify-content: stretch;
  align-items: stretch;
  justify-items: stretch;
  grid-template-columns: auto 5rem;
  gap: 1rem;
  transition: transform 300ms ease;
}
#services .service_grid li a:hover .overlay,
#services .service_grid li a:focus-visible .overlay {
  transform: translateY(1rem);
}
#services .service_grid li a .overlay > * {
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
  background-color: #006eb6;
  color: #fff;
  box-shadow:
    0.2px 0.2px 2.1px rgba(0, 0, 0, 0.025),
    0.4px 0.4px 5.1px rgba(0, 0, 0, 0.036),
    0.8px 0.8px 9.5px rgba(0, 0, 0, 0.045),
    1.3px 1.3px 17px rgba(0, 0, 0, 0.054),
    2.5px 2.5px 31.8px rgba(0, 0, 0, 0.065),
    6px 6px 76px rgba(0, 0, 0, 0.09);
}
#services .service_grid li.cat_red a .overlay > * {
  background-color: var(--color_cat_red);
}
#services .service_grid li.cat_green a .overlay > * {
  background-color: var(--color_cat_green);
}
#services .service_grid li.cat_blue a .overlay > * {
  background-color: var(--color_cat_blue);
}
#services .service_grid li.cat_orange a .overlay > * {
  background-color: var(--color_cat_orange);
}
/* #services .service_grid li.srbr a .overlay .text {
  min-height: 5em;
  max-width: 27em;
} */
#services .service_grid li a .overlay .text span {
  display: block;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  padding: 0.1em 1.5rem;
  font-size: 1.4em;
  line-height: 1.25em;
  color: inherit;
}
#services .service_grid li.cat_orange a .overlay .text span {
  color: #333;
}
#services .service_grid li a .overlay > .icon {
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 60%;
}
#services .service_grid li.cat_red a .overlay > .icon {
  background-image: url("../bilder/home/piktogram-besen.svg");
}
#services .service_grid li.cat_green a .overlay > .icon {
  background-image: url("../bilder/home/piktogram-pflanze.svg");
}
#services .service_grid li.cat_blue a .overlay > .icon {
  background-image: url("../bilder/home/piktogram-winterdienst.svg");
}
#services .service_grid li.cat_orange a .overlay > .icon {
  background-image: url("../bilder/home/piktogram-dach.svg");
}
#services .service_grid li a:hover::after {
  opacity: 1;
}
@media (max-width: 100rem) {
  #services .service_grid li a .overlay .text span {
    font-size: 1.3em;
  }
}
@media (max-width: 90rem) {
  #services .service_grid li a .overlay .text span {
    font-size: 1.2em;
  }
}
@media (max-width: 70rem) {
  #services .service_grid li a .overlay .text span {
    font-size: 1.1em;
  }
}
@media (max-width: 60rem) {
  #services .service_grid {
    width: 25rem;
    max-width: 100%;
    margin-inline: auto;
    grid-template-columns: 1fr;
  }
  #services .service_grid li.srbr {
    aspect-ratio: 1/1;
    grid-column: unset;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    HP-Section "News-Teaser"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
section#news {
  background-color: var(--color_ci);
}
section#news h2 {
  color: #fff !important;
}
#news_teaser {
  --_border_radius: 1.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-top: 2rem;
  @media (max-width: 60rem) {
    & {
      grid-template-columns: 1fr;
    }
  }
}
#news_teaser .teaser {
  padding: 2rem;
  background-color: #fff;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#news_teaser .teaser strong {
  display: block;
  font-size: 1.2em;
  margin-bottom: 1.5em;
}
#news_teaser .teaser .button {
  margin-top: 0;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    HP-Section "Call to Action"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#call_to_action .banner {
  border-top-left-radius: var(--border_radius);
  border-bottom-right-radius: var(--border_radius);
  color: #fff;
  background-color: var(--color_cat_blue);
  padding: 3rem 4rem;
  position: relative;
}
#call_to_action .banner::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 0;
  bottom: 0;
  right: 1rem;
  width: 37%;
  height: calc(100% + 4rem);
  background-image: url("../bilder/home/mann-anruf-geste.png");
  background-size: contain;
  background-position: 50% 100%;
  background-repeat: no-repeat;
}
#call_to_action .banner .text {
  width: 60%;
  color: inherit;
  position: relative;
  z-index: 1;
}
#call_to_action .banner .text .heading {
  color: inherit;
  font-weight: var(--font_weight_bold);
  font-size: 1.4em;
  margin-bottom: 1em;
}
#call_to_action .banner .text .heading * {
  color: inherit;
}
#call_to_action .banner .text .heading em {
  display: block;
  text-transform: uppercase;
  font-size: 1.2em;
  font-style: normal;
  font-weight: inherit;
  line-height: 1.1em;
}
#call_to_action .banner .text p {
  color: inherit;
  line-height: 1.5em;
}
@media (max-width: 80rem) {
  #call_to_action .banner {
    padding: 2rem 3.5rem;
  }
}
@media (max-width: 70rem) {
  #call_to_action .banner::after {
    right: -1rem;
    height: 100%;
  }
}
@media (max-width: 60rem) {
  #call_to_action .banner .text {
    width: 66%;
  }
}
@media (max-width: 54rem) {
  #call_to_action .banner {
    padding: 2rem;
  }
  #call_to_action .banner::after {
    right: 1rem;
    opacity: 0.4;
    height: 97%;
    width: 50%;
  }
  #call_to_action .banner .text {
    width: 100%;
  }
}
@media (max-width: 35rem) {
  #call_to_action .banner::after {
    width: 80%;
    background-position: 100% 100%;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Formular "Angebot anfordern"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.formulator {
  --_border_radius: 1rem;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
  padding: 2rem;
  border-top-left-radius: 2rem;
  border-bottom-right-radius: 2rem;
  background-color: var(--color_bg_light_grey);
}
/* .formulator .intro:has(+ #angebotsformular) {
  font-size: 0.9em;
  font-weight: var(--font_weight_light);
} */
.formulator #angebotsformular {
  margin-top: 1rem;
}
.formulator #angebotsformular input:not(.button),
.formulator #angebotsformular textarea,
.formulator #angebotsformular select {
  margin-bottom: 0.4em;
  border: 1px solid rgb(0 0 0 / 0.2);
  background-color: #fff;
  padding-block: 0.3em;
}
.formulator #angebotsformular input:not(.button):focus,
.formulator #angebotsformular textarea:focus,
.formulator #angebotsformular select:focus {
  background-color: #fff;
  outline: 1px solid rgba(0, 110, 182, 0.5);
  outline-offset: 4px;
  border-color: var(--color_cat_blue);
}
.formulator #angebotsformular input:not(.button):hover,
.formulator #angebotsformular textarea:hover,
.formulator #angebotsformular select:hover {
  background-color: rgba(255, 255, 255, 0.5);
}
.formulator #angebotsformular label {
  padding-bottom: 0;
  font-weight: var(--font_weight_normal);
  line-height: 1.3em;
}
.formulator #angebotsformular input[type="date"] {
  min-height: 2.35em;
}
.formulator #angebotsformular .consent_con {
  padding-top: 2rem;
}
.formulator #angebotsformular .clc.fifty_fifty {
  overflow: visible;
}
.formulator #angebotsformular .subheading {
  font-weight: var(--font_weight_normal);
  margin-top: 1.5rem;
}
.formulator #angebotsformular input[type="file"] {
  margin-top: 1rem;
}
#form_sent_icon {
  font-size: 5rem;
  margin: 2rem 0 3rem 0;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    HP-Section "Jobs-Banner"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#jobs_banner {
  --_clr_green: oklch(from var(--color_cat_green) calc(l * 0.8) c h);
  --_clr_grey: var(--color_grey);
  margin-top: var(--section-vertical-padding);
  padding-block: 0 !important;
  background: linear-gradient(
    to right,
    var(--_clr_green) 60%,
    var(--_clr_grey) 60%
  );
}
#jobs_banner .layout_grid {
  display: grid;
  align-content: space-between;
  justify-content: stretch;
  align-items: stretch;
  justify-items: stretch;
  grid-template-columns: 5fr 4fr;
  gap: 0;
  overflow: visible;
}
#jobs_banner .layout_grid > * {
  padding-block: 2rem;
}
#jobs_banner .layout_grid .info_con {
  background-color: var(--_clr_green);
  color: #fff;
  padding-right: 8rem;
}
#jobs_banner .layout_grid .info_con *:not(a) {
  color: inherit;
}
#jobs_banner .layout_grid .info_con .catch_phrase {
  font-size: 1.6em;
  margin-bottom: 1em;
  line-height: 1.2em;
}
#jobs_banner .layout_grid .design_con {
  background-color: var(--_clr_grey);
  position: relative;
}
#jobs_banner .layout_grid .design_con::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  width: 800px;
  height: 110%;
  bottom: 0;
  left: -360px;
  background-image: url("../bilder/home/jobs.webp");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 100%;
}
#jobs_banner .layout_grid .design_con * {
  overflow: visible;
}
#jobs_banner .layout_grid .design_con ul {
  margin: 0;
  text-align: right;
  color: #fff;
  font-size: 2em;
}
#jobs_banner .layout_grid .design_con ul * {
  color: inherit;
  text-transform: uppercase;
}
#jobs_banner .layout_grid .design_con ul li {
  line-height: 1.2em;
  margin-top: 0.5rem;
}
#jobs_banner .layout_grid .design_con ul li::before {
  display: none;
}
#jobs_banner .layout_grid .design_con li.svg {
  min-height: 4rem;
}
#jobs_banner .layout_grid .design_con svg text {
  text-transform: uppercase;
  font-size: 1rem;
  fill: none;
  stroke: #fff;
  stroke-width: 0.2;
  font-family: inherit;
  text-anchor: end;
}
#jobs_banner .layout_grid .design_con .fade {
  opacity: 0.4;
  font-size: 1.2em;
}
#jobs_banner .layout_grid .design_con .hollow {
  color: var(--_clr_grey);
  color: transparent;
  -webkit-text-stroke-width: 0.5px;
  -webkit-text-stroke-color: #fff;
}
#jobs_banner .layout_grid .design_con .bistyle {
  font-size: 1.4em;
  line-height: 1em !important;
}
#jobs_banner .layout_grid .design_con .bistyle * {
  line-height: inherit;
}
#jobs_banner .layout_grid .design_con .small {
  font-size: 0.9em;
}
#jobs_banner .layout_grid .design_con .small.hollow {
  -webkit-text-stroke-width: 0.4px;
}
@media (max-width: 70rem) {
  #jobs_banner .layout_grid .design_con {
    font-size: 0.9em;
  }
  #jobs_banner .layout_grid .design_con svg text {
    font-size: 0.9rem;
  }
  #jobs_banner .layout_grid .design_con::before {
    width: 600px;
    height: 80%;
    left: -280px;
  }
}
@media (max-width: 60rem) {
  #jobs_banner {
    background: linear-gradient(
      135deg,
      var(--_clr_green) 50%,
      var(--_clr_grey) 50%
    );
  }
  #jobs_banner .layout_grid {
    grid-template-columns: 1fr;
  }
  #jobs_banner .layout_grid .info_con,
  #jobs_banner .layout_grid .design_con {
    background-color: transparent;
  }
  #jobs_banner .layout_grid .info_con {
    padding-right: 0;
    padding-bottom: 1rem;
  }
  #jobs_banner .layout_grid .design_con::before {
    background-position: 0 100%;
    width: 100%;
    height: 100%;
    left: -1rem;
  }
  #jobs_banner .layout_grid .design_con ul li.svg {
    display: none;
  }
}
@media (max-width: 40rem) {
  #jobs_banner {
    background: linear-gradient(
      135deg,
      var(--_clr_green) 70%,
      var(--_clr_grey) 70%
    );
  }
  #jobs_banner .layout_grid .design_con::before {
    height: 80%;
    left: -1.5rem;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Flex-Galerien
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.flex_gallery {
  overflow: auto;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  align-content: stretch;
  margin-top: 1.5em;
  margin-bottom: 1.5em;
  --gap: 0.5rem;
  --pics_per_row: 3;
  gap: var(--gap);
}
.flex_gallery.per_row_2 {
  --pics_per_row: 2;
}
.flex_gallery.per_row_3 {
  --pics_per_row: 3;
}
.flex_gallery.per_row_4 {
  --pics_per_row: 4;
}
.flex_gallery.per_row_5 {
  --pics_per_row: 5;
}
.flex_gallery.per_row_6 {
  --pics_per_row: 6;
}
.flex_gallery a {
  align-items: center;
  align-content: center;
  flex-grow: 0;
  flex-shrink: 1;
  line-height: 0;
  position: relative;
  display: inline-block;
  width: calc(
    (100% - ((var(--pics_per_row) - 1) * var(--gap))) / var(--pics_per_row)
  );
  cursor: zoom-in;
}
.flex_gallery a::after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  box-shadow: inset 0px 0px 2px 0px rgba(0, 0, 0, 0.1);
}
.flex_gallery a:hover::after {
  outline: 3px solid var(--color_brand);
  outline-offset: -3px;
}
.flex_gallery a img {
  width: 100%;
  height: auto;
}
.flex_gallery a:hover img {
  filter: saturate(1.1) contrast(1.1);
}
.flex_gallery a div {
  position: absolute;
  bottom: 0;
  width: 100%;
  background-color: rgba(25, 25, 25, 0.6);
  padding: 0.4em;
  line-height: 1.2em;
  color: #fff;
}
.flex_gallery a:hover div {
  background-color: var(--color_brand);
}
@media (max-width: 1200px) {
  .flex_gallery.per_row_5 {
    --pics_per_row: 4;
  }
  .flex_gallery.per_row_3 {
    --pics_per_row: 2;
  }
}
@media (max-width: 800px) {
  .flex_gallery.per_row_5 {
    --pics_per_row: 3;
  }
  .flex_gallery.per_row_3 {
    --pics_per_row: 2;
  }
}
@media (max-width: 650px) {
  .flex_gallery.per_row_5 {
    --pics_per_row: 2;
  }
  .flex_gallery.per_row_4 {
    --pics_per_row: 2;
  }
}
@media (max-width: 600px) {
  .flex_gallery.per_row_2 a {
    width: 100%;
  }
}
@media (max-width: 350px) {
  .flex_gallery a {
    width: 100%;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Accordion
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#content .accordion {
  --_border_radius: 1rem;
  overflow: hidden;
  margin: 0 auto;
  width: 100%;
  text-align: left;
}
#content .accordion * {
  text-align: inherit;
}
#content .accordion input {
  position: absolute;
  opacity: 0;
  z-index: -1;
}
#content .accordion .tab {
  width: 100%;
  /* overflow: hidden; */
  margin: 1em 0;
}
#content .accordion .tab:last-of-type {
  border-bottom: none;
}
#content .accordion .tab_label {
  display: flex;
  position: relative;
  padding: 1em 2.9em 0.9em 0.9em;
  background-color: var(--color_ci_10m);
  color: #fff;
  font-weight: var(--font_weight_medium);
  font-size: 1.2em;
  cursor: pointer;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#content .accordion .tab:last-of-type .tab_label {
  border-bottom: none;
}
#content .accordion .tab_label h2 {
  padding: 0;
  margin: 0;
  line-height: 1.3em;
  color: inherit;
  font-weight: inherit;
  font-size: inherit;
}
#content .accordion .tab_label:hover {
  background: unset;
  background-color: #444;
  color: #fff;
}
#content .accordion .tab_label::after {
  font-family: var(--fontawesome);
  content: "\f0fe";
  position: absolute;
  font-size: 1.3em;
  right: 0;
  margin-right: 1em;
  margin-top: 0.1em;
  aspect-ratio: 1;
  line-height: 1em;
  text-align: center;
  transition: transform 0.35s;
}
#content .accordion .tab input:focus-visible + .tab_label::after {
  outline: var(--focus_outline_size) var(--focus_outline_style)
    var(--focus_outline_color);
  outline-offset: var(--focus_outline_offset, var(--focus_outline_size));
}
#content .accordion .tab_content {
  max-height: 0;
  overflow: hidden;
  padding: 0 1em 0 1em;
  background-color: #fff;
  transition: max-height 0.3s;
}
#content .accordion .tab_content p,
#content .accordion .tab_content ul {
  margin-bottom: 1.5em;
}
#content .accordion input:checked + .tab_label {
  background: unset;
  background-color: #444;
  color: #fff;
  text-shadow: 0 0 1px rgba(0, 0, 0, 0.3);
  border-radius: 0;
  border-top-left-radius: var(--_border_radius);
}
#content .accordion input:checked + .tab_label::after {
  transform: rotate(360deg);
  content: "\f146";
}
#content .accordion input:checked ~ .tab_content {
  max-height: 1000vh;
  padding: 1.5em;
  margin-bottom: 1em;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-top: none;
  border-bottom-right-radius: var(--_border_radius);
}
@media (max-width: 1000px) {
  #content .accordion .tab_label {
    font-size: 1.1em;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Seite "Aktuelles"
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#news {
  --teaser_pic_width: 400px;
  margin-top: 2rem;
}
#news .newsblock {
  --_border_radius: 2rem;
  background-color: var(--color_bg_light_grey);
  padding: 3rem;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
  margin-bottom: 3rem;
  @media (max-width: 60rem) {
    & {
      padding: 2rem;
    }
  }
  @media (max-width: 40rem) {
    & {
      padding: 1rem;
    }
  }
}
#news #no_news {
  display: block;
  margin-bottom: 8em;
}
#news .newsblock .contents :last-child {
  margin-bottom: 0;
}
#news .clc {
  overflow: auto;
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  align-content: stretch;
}
#news .clc .col {
  flex-grow: 0;
  flex-shrink: 1;
}
#news .clc .col.pic {
  --_border_radius: 1rem;
  width: var(--teaser_pic_width);
}
#news .clc .col.contents {
  width: calc(100% - var(--teaser_pic_width) - 2em);
}
#news .clc .col.pic img {
  display: block;
  width: auto;
  max-width: 100%;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#news .clc .col.contents h2 {
  margin-top: 0;
}
#news .contents a.fancybox {
  outline: none;
}
#news .contents a.fancybox img {
  max-width: 60%;
}
#news .contents a.fancybox img[style*="float:left"] {
  margin: 0 2em 2em 0;
}
#news .contents a.fancybox img[style*="float:right"] {
  margin: 0 0 2em 2em;
}
#news .flex_gallery {
  --_border_radius: 0.7rem;
  margin-top: var(--text_block_spacer);
  margin-bottom: 0;
}
#news .flex_gallery a {
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
  overflow: hidden;
}
#news .flex_gallery a::after {
  border-radius: inherit;
}
/* #news .news_date {
  display: block;
  float: none;
  clear: both;
  margin-bottom: 2em;
  font-size: 0.8em;
  padding-right: 0.5em;
  font-style: italic;
  text-align: right;
  opacity: 0.4;
} */
@media (max-width: 70rem) {
  #news .clc .col {
    width: 100% !important;
  }
  #news .contents a.fancybox {
    display: inline-block;
    overflow: visible;
    line-height: 0;
  }
  #news .contents a.fancybox img {
    float: none !important;
    clear: both;
    max-width: 100%;
    margin: 0 !important;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Leistungen-Unterseiten
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#warning_notice {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  background-color: #333;
  padding: 0.6rem 1rem;
  width: 100ch;
  max-width: 96%;
  margin: 0 auto var(--text_block_spacer) auto;
  color: #a0d746;
  font-size: 0.85em;
  line-height: 1.4em;
}
#warning_notice * {
  color: inherit;
}
#warning_notice > i {
  font-size: 4em;
}
#warning_notice span {
  font-size: inherit;
  line-height: inherit;
}
@media (max-width: 45rem) {
  #warning_notice {
    align-items: flex-start;
    gap: 1rem;
  }
  #warning_notice > i {
    font-size: 2.5em;
  }
}
@media (max-width: 30rem) {
  #warning_notice {
    flex-direction: column;
    gap: 0.3rem;
  }
}

.side_by_side .media_col.winterdienst img {
  object-position: 0 0;
}
.side_by_side .media_col.hochdruckreinigung img {
  object-position: 0 50%;
}
.side_by_side .media_col.hausmeisterdienste img {
  object-position: 0 0;
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Engagement-Seite
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#engagement_list {
  --_border_radius: 2rem;
  padding: 3rem;
  background-color: var(--color_bg_light_grey);
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#engagement_list .block {
  padding: 2rem;
  border-top-left-radius: 2rem;
  text-align: center;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
  background-color: #fff;
  width: 45rem;
  max-width: 100%;
  margin-inline: auto;
}
#engagement_list .block img {
  display: block;
  max-width: 100%;
  margin-inline: auto;
  margin-block-end: 1.3rem;
}
#engagement_list .block p {
  margin-block-end: 1rem;
}
#engagement_list .block > a.button {
  display: inline-block;
  margin: 0;
}
#engagement_list .block + .block {
  margin-top: 2rem;
}
@media (max-width: 50rem) {
  #engagement_list .block {
    padding: 1rem;
    border-top-left-radius: 1rem;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Kontakt-Seite
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#contact_data {
  --_border_radius: 1rem;
  margin: 2rem 0;
}
#contact_data .col {
  width: 48%;
  text-align: center;
}
#contact_data .col .wrapper {
  display: block;
  text-align: left;
  padding: 1.5rem 2rem;
  line-height: 2em;
  /* background-color: var(--color_cat_blue); */
  background-color: var(--color_bg_light_grey);
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#contact_data .col .wrapper * {
  color: inherit;
}
#contact_data .col .wrapper .label {
  display: inline-block;
  min-width: 3.6em;
}
@media (max-width: 75rem) {
  #contact_data .col {
    max-width: 100%;
    width: 30rem;
    margin-inline: auto;
  }
  #contact_data .col:has(+ .col) .wrapper {
    border-bottom-right-radius: 0;
    padding-block-end: 0;
  }
  #contact_data .col + .col .wrapper {
    border-top-left-radius: 0;
  }
}
#team_data {
  --_border_radius: 1rem;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 2rem;
  margin-inline: auto;
}
#team_data .person {
  padding: 1.07rem;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
  background-color: var(--color_bg_light_grey);
}
#team_data .person:not(:has(img)) {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
#team_data .person img {
  display: block;
  width: 100%;
  height: auto;
  background-color: #777;
  border-top-left-radius: var(--_border_radius);
  border-bottom-right-radius: var(--_border_radius);
}
#team_data .person .name {
  line-height: 1.2em;
  margin-top: 0.8rem;
}
#team_data .person .position {
  font-weight: 350;
  line-height: 1.2em;
}
#team_data .person a {
  display: inline-block;
  text-decoration: none;
  color: inherit;
  line-height: 1.2em;
}
#team_data .person a:hover {
  text-decoration: underline;
}
#team_data .person .position + a {
  margin-top: 0.8rem;
}
#team_data .person .telephone::before {
  content: "\f095";
  font-family: var(--fontawesome);
  font-size: 0.8em;
  display: inline-block;
  width: 1.5em;
  text-align: left;
}
@media (max-width: 45rem) {
  #team_data {
    max-width: 300px;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Jobs
███████████████████████████████████████████████████████████████████████████████████████████████
*/
section.job_listing_section {
  background-color: var(--color_bg_light_grey);
}
.jobs_form_section .formulator {
  max-width: unset;
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Downloads
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#download_list {
  margin: 0 0 1em 0;
  overflow: auto;
}
#download_list h2 {
  margin-top: 1.6em;
  margin-bottom: 0.2em;
}
#download_list h2:first-of-type {
  margin-top: 0;
}
.download_button {
  display: block;
  width: 100%;
  background-color: #555;
  text-decoration: none !important;
  overflow: auto;
  margin-bottom: 0.5em;
  border-radius: 4px;
  -webkit-box-shadow: inset -75px 0px 0px 0px rgba(255, 255, 255, 0.3);
  -moz-box-shadow: inset -75px 0px 0px 0px rgba(255, 255, 255, 0.3);
  box-shadow: inset -75px 0px 0px 0px rgba(255, 255, 255, 0.3);
}
.download_button .title,
.download_button .filesize {
  display: table-cell;
  padding: 0.4em;
}
.download_button .title {
  color: #fff;
}
.download_button .filesize {
  color: #fff;
  text-align: right;
  float: right;
  min-width: 75px;
}
.download_button:hover {
  background-color: var(--color_ci);
}
.download_button:hover .title {
  color: #fff;
}
.download_button:hover .filesize {
  color: #c2e6ff;
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Galerie
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.gallery {
  --_min_thumb_width: 290px;
  --_max_thumb_width: 400px;
  --_thumb_aspect_ratio: 10 / 7;
  --_gap: 0.7rem;
  display: grid;
  grid-template-columns: repeat(
    auto-fill,
    minmax(var(--_min_thumb_width), 1fr)
  );
  justify-content: center;
  justify-items: center;
  gap: var(--_gap);
  margin-inline: auto;
  width: 100%;
}
.gallery.mini {
  --_min_thumb_width: 170px;
  --_max_thumb_width: 200px;
  --_gap: 0.5rem;
  grid-template-columns: repeat(
    auto-fill,
    minmax(var(--_min_thumb_width), 1fr)
  );
  justify-content: start;
  justify-items: start;
  margin-block: 0.4rem;
}
.gallery.maxi {
  grid-template-columns: repeat(
    auto-fill,
    minmax(var(--_min_thumb_width), var(--_max_thumb_width))
  );
  justify-content: flex-start;
}
.gallery a {
  display: block;
  text-decoration: none !important;
  border-radius: 0.35rem;
  overflow: hidden;
  width: 100%;
  min-width: var(--_min_thumb_width);
  max-width: var(--_max_thumb_width);
  background-color: #444;
}
.gallery.mini a {
  border-radius: 0.1rem;
  max-width: unset;
}
@media (max-width: 30rem) {
  .gallery.mini a {
    max-width: var(--_min_thumb_width);
  }
}
.gallery figure {
  display: block;
  width: 100%;
}
.gallery figure img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: var(--_thumb_aspect_ratio);
  object-fit: cover;
}
.gallery a:hover figure img {
  filter: saturate(1.1) contrast(1.2);
}
.gallery figure figcaption {
  display: block;
  padding: 0.3em 0.6em 0.4em 0.6em;
  line-height: 1.3em;
  color: #fff;
  font-style: normal !important;
  font-weight: var(--font_weight_light);
  transition: all 400ms ease;
}
.gallery a:hover figure figcaption {
  background-color: var(--color_ci);
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
  Copyright und KI-Kennzeichnung
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.mcc {
  position: relative;
}
.media_credit {
  font-family: Arial, Verdana, Helvetica, sans-serif !important;
  position: absolute;
  z-index: 1;
  right: 3px;
  top: 3px;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: flex-start;
  gap: 0.2rem;
  cursor: pointer;
}
.media_credit label {
  position: relative;
  font-family: Arial, Verdana, Helvetica, sans-serif !important;
  font-size: 16px;
  font-weight: 300;
  grid-column: 1 / -1 !important;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 0.8ch 1.5ch;
  background-color: #333 !important;
  color: #fff !important;
  line-height: 1em;
  cursor: pointer;
  border-radius: 5rem;
  box-shadow:
    0 0 1px rgba(255, 255, 255, 0.05),
    0 0 2px rgba(255, 255, 255, 0.09),
    0 0 5px rgba(255, 255, 255, 0.14),
    0 0 8px rgba(255, 255, 255, 0.18),
    0 0 13px rgba(255, 255, 255, 0.23);
}
.media_credit label * {
  font-family: inherit;
  color: inherit !important;
}
.media_credit label::before {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.21rem;
  aspect-ratio: 1;
  font-size: 1.15em;
  line-height: 1.05rem;
  box-sizing: border-box;
}
.media_credit .copyright::before {
  content: "\00A9"/ "Copyrightzeichen";
  padding-top: 1px;
  padding-left: 1px;
}
.media_credit .ai::before {
  content: "KI";
  font-size: 0.8em;
}
.media_credit label:has(input[type="checkbox"]:checked)::before {
  justify-content: flex-start;
}
.media_credit label input[type="checkbox"] {
  position: absolute !important;
  top: 0;
  left: 0;
  opacity: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  z-index: 1 !important;
  cursor: pointer;
}
.media_credit label:has(input[type="checkbox"]:checked) {
  padding: 0.2em 0.5em;
  border-radius: 0.4rem;
}
.media_credit label .indicator {
  --focus_outline_size: 3px;
  --focus_outline_offset: 0;
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 9rem;
  outline: 0 var(--focus_outline_style, dashed)
    var(--focus_outline_color, fuchsia);
  outline-offset: var(--focus_outline_offset, 1px);
  pointer-events: none;
}
.media_credit label input[type="checkbox"]:focus-visible ~ .indicator {
  outline-width: var(--focus_outline_size, 4px);
}
.media_credit label span {
  display: none;
  position: unset !important;
  font-size: 0.9em;
  line-height: 1.2em !important;
}
.media_credit label input[type="checkbox"]:checked ~ span {
  display: inline-block;
}
.media_credit .ai:has(input[type="checkbox"]:checked)::before {
  display: none;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Back-to-Top-Button
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#b2t_btn {
  background: #000;
  position: fixed;
  bottom: 1.5%;
  right: 1.5%;
  height: 2em;
  width: 2em;
  border: none;
  border-radius: 99em;
  opacity: 0.6;
  transition: all 0.3s ease;
  box-shadow:
    0px 0px 3.1px rgba(255, 255, 255, 0.062),
    0px 0px 7.4px rgba(255, 255, 255, 0.089),
    0px 0px 14px rgba(255, 255, 255, 0.11),
    0px 0px 25px rgba(255, 255, 255, 0.131),
    0px 0px 46.8px rgba(255, 255, 255, 0.158),
    0px 0px 112px rgba(255, 255, 255, 0.22);
}
#b2t_btn::before {
  content: "";
  display: inline-block;
  position: absolute;
  height: 0.76rem;
  width: 0.76rem;
  border: solid #fff;
  border-width: 0.2rem 0 0 0.2rem;
  transform: rotate(45deg);
  top: 40%;
  left: 50%;
  margin-left: -0.38rem;
  transition: all 0.1s ease;
}
#b2t_btn:hover {
  opacity: 1;
}
#b2t_btn:hover::before {
  margin-top: -0.3rem;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Google Maps On Demand
███████████████████████████████████████████████████████████████████████████████████████████████
*/
.gmod {
  --_border-radius: 1.5rem;
  width: 100%;
  height: 50dvh;
  margin-top: 0;
  margin-bottom: 1em;
  position: relative;
  overflow: hidden;
  border-top-left-radius: var(--_border-radius);
  border-bottom-right-radius: var(--_border-radius);
}
.gmod:hover,
.gmod:focus-within {
  --_border-radius: 0;
}
.gmod > iframe {
  grid-column: inherit !important;
}
.gmod .bg_map {
  position: absolute;
  top: -1%;
  left: -1%;
  height: 102%;
  width: 102%;
  background-image: url("../bilder/gmod-bg.png");
  background-repeat: repeat;
  background-position: 0 0;
}
.gmod .opt_in_banner {
  background-color: rgba(0, 0, 0, 0.8);
  color: #fff;
  padding: 1.5rem 1em;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  text-align: center;
  font-size: 0.9em;
  backdrop-filter: blur(1px);
}
.gmod .opt_in_banner .desc {
  color: #fff;
  text-align: center;
  margin-bottom: 1em;
  line-height: 1.3em;
}
.gmod .opt_in_banner .desc a {
  color: inherit !important;
}
.gmod .opt_in_banner .show_map_btn {
  display: inline-block;
  padding: 0.9em 1.2em;
  margin-top: 0.6rem;
  margin-bottom: 0.2rem;
  background-color: #fff;
  color: #000 !important;
  border: none;
  font-size: 1em;
  line-height: 1.2em;
  cursor: pointer;
  border-radius: 0.4rem;
}
.gmod .opt_in_banner :focus-visible {
  outline: 3px dashed #f0ff67;
  outline-offset: 4px;
}
.gmod .opt_in_banner .show_map_btn:hover {
  background-color: #e8ffee;
  border-radius: 9rem;
}
/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Footer
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#footer {
  background-color: #f4f4f4;
  padding-block: 2rem;
  color: var(--color_grey);
  font-size: 0.9em;
}
#footer * {
  color: inherit;
}
#footer a:hover {
  text-decoration: underline;
}
#footer .grid {
  display: grid;
  align-content: space-between;
  justify-content: space-between;
  align-items: stretch;
  justify-items: stretch;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 3.5rem;
}
#footer .grid .block {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  line-height: 2em;
}
#footer .grid .block * {
  line-height: inherit;
}
#footer .grid .block.logo {
  align-self: center;
}
#footer .grid .block.logo a {
  display: inline-block;
  width: 100%;
}
#footer .grid .block .heading {
  display: block;
  color: var(--color_ci_10m);
  font-weight: var(--font_weight_black);
}
#footer .grid .block.contact .iconized::before {
  font-family: var(--fontawesome);
  font-size: 1em;
  color: var(--color_ci_10m);
  display: inline-block;
  width: 1.7rem;
  text-align: center;
}
#footer .grid .block.contact .iconized.telephone::before {
  content: "\f095";
}
#footer .grid .block.contact .iconized.fax::before {
  content: "\f1ac";
}
#footer .grid .block.contact .iconized.email::before {
  content: "\f0e0";
}
#footer .sm_line {
  margin-top: 1rem;
  border-bottom: 2px solid var(--color_grey);
  text-align: right;
}
#footer .sm_line a {
  text-decoration: none !important;
}
#footer .sm_line a:not(:first-of-type) {
  margin-left: 1em;
}
#footer .sm_line a i {
  font-size: 1.5em;
}
#footer .sm_line a:hover i {
  color: #000;
}
@media (max-width: 95rem) {
  #footer .grid {
    gap: 2rem;
  }
}
@media (max-width: 62rem) {
  #footer .grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
  #footer .grid .block.logo {
    display: none;
  }
}
@media (max-width: 35rem) {
  #footer .grid {
    gap: 0.2rem;
  }
}
@media (max-width: 30rem) {
  #footer .grid {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  #footer .grid .block.contact {
    padding-left: 2.3em;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    Bottom-Line
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#bottom_line {
  background-color: #f4f4f4;
  font-size: 0.9em;
  padding-bottom: 2rem;
}
#bottom_line .copyright {
  float: left;
}
#bottom_line ul {
  float: right;
}
#bottom_line ul li {
  display: inline-block;
}
#bottom_line ul li:not(:first-of-type) {
  margin-left: 1.5em;
}
#bottom_line ul li a:hover {
  text-decoration: underline;
}
@media (max-width: 28rem) {
  #bottom_line .copyright,
  #bottom_line ul {
    float: none;
    display: block;
    width: 100%;
    text-align: center;
  }
  #bottom_line ul {
    margin-top: 1em;
  }
}

/*
███████████████████████████████████████████████████████████████████████████████████████████████
    CWD im Footer
███████████████████████████████████████████████████████████████████████████████████████████████
*/
#cwd {
  padding: 0.5em 1em;
  color: #fff;
  background-color: #222;
  text-align: center;
  font-size: 0.75em;
  line-height: 1.4em;
}
#cwd * {
  color: inherit !important;
  line-height: inherit !important;
  opacity: 0.8;
}
#cwd a {
  text-decoration: none !important;
}
#cwd a:hover {
  text-decoration: underline !important;
  opacity: 1;
}
