/* 
Theme Name: Saredi 2026
Version: v.1.0
Description: Custom Theme for saredi.ch
Author: Roman Hospenthal, RHOdesign
Author URI: http://www.rhodesign.ch/
*/

@import 'css/reset.css';
@import 'css/grid.css';
@import 'css/plugins.css';
@import 'css/helpers.css';




[id] { scroll-margin-top: 80px;}
@media (max-width: 991px) {
[id] { scroll-margin-top: 30px;}
}


/* ------------------------------------------------------------ *\
	Variablen
\* ------------------------------------------------------------ */
:root {
    --fz-html: 62.5%;
    --fw-base: 400;
    --ff-base: 'Hind', sans-serif;
    --base-background: var(--saredi--blau);

    --saredi--blau: #0096e6; /* rgba(0, 150, 230, 1) */
    --saredi--gelb: #fff000; /* rgba(255, 240, 0, 1) */
    --footer: #142337; /* rgba(20, 35, 55, 1) */
    --dunkelblau: #1e3c5a; /* rgba(30, 60, 90, 1) */
    --grau-240: #f2f0ee; /* rgba(242, 240, 238, 1) */
    --grau-220: #dcdad8; /* rgba(220, 218, 216, 1) */
    --grau-160: #a0a0a0; /* rgba(160, 160, 160, 1) */
    --weiss: #ffffff; /* rgba(255, 255, 255, 1) */
    --schwarz: #000000; /* rgba(0, 0, 0, 1) */
    --hellblau: #ebf1f5; /* rgba(235, 241, 245, 1) */

    /* Line heights */
    --line-height-xs: 1;
    --line-height-sm: 1.2;
    --line-height-md: 1.4;
    --line-height-lg: 1.5;
    --line-height-xl: 1.6;
/*
--heading-90: clamp(5rem, calc(2.95vw + 39.33pt), 9rem);
--heading-60: clamp(4rem, calc(1.473vw + 35.67pt), 6rem);
--heading-36: clamp(2.8rem, calc(0.589vw + 25.87pt), 3.6rem);
--heading-28: clamp(2.2rem, calc(0.442vw + 20.4pt), 2.8rem);
--heading-22: clamp(1.8rem, calc(0.295vw + 17pt), 2.2rem);
--link-22: clamp(1.8rem, calc(0.295vw + 17pt), 2.2rem);
--paragraph-22: clamp(1.8rem, calc(0.295vw + 17pt), 2.2rem);
--paragraph-18: 1.8rem;
--paragraph-16: 1.6rem;
 */  

    
/*375 */
--heading-90: clamp(4rem, 5.848vw + 2.5307rem, 9rem);
--heading-60: clamp(3.2rem, 3.4568vw + 2.1759rem, 6rem);
--heading-36: clamp(2.8rem, .9877vw + 2.5074rem, 3.6rem);
--heading-28: clamp(2.2rem, .7407vw + 1.9806rem, 2.8rem);
--paragraph-22: clamp(1.8rem, .4938vw + 1.6537rem, 2.2rem);
--paragraph-18: 1.8rem;
--paragraph-16: 1.6rem; 
}

/*
--heading-90: 90px;
--heading-36: 36px;
--heading-28: 28px;
--heading-22: 22px;
--heading-18: 18px;
--paragraph-22: 22px;
--paragraph-18: 18px;
--link-22: 22px;
*/

/* ------------------------------------------------------------ *\
	Schriftgrössen Export aus Figma
\* ------------------------------------------------------------ */
.Heading90Pt {font-size: 90px; font-family: Hind, sans-serif; font-weight: 500; line-height: 1;}
.Heading36Pt {font-size: 36px; font-family: Hind, sans-serif; font-weight: 400; line-height: 1.2; letter-spacing: 0;}
.Heading28Pt {font-size: 28px; font-family: Hind, sans-serif; font-weight: 400; line-height: 1.2;}
.Heading22Pt {font-size: 22px; font-family: Hind, sans-serif; font-weight: 500; line-height: 1.4;}
.Heading18Pt {font-size: 18px; font-family: Hind, sans-serif; font-weight: undefined; line-height: 1.4;}
.Lead28Pt {font-size: 28px; font-family: Hind, sans-serif; font-weight: 400; line-height: 1.4;}
.Paragraph22Pt {font-size: 22px; font-family: Hind, sans-serif; font-weight: 400; line-height: 1.4;}
.Paragraph18Pt {font-size: 18px; font-family: Hind, sans-serif; font-weight: 400; line-height: 1.4;}
.Link22Pt {font-size: 22px; font-family: Hind, sans-serif; font-weight: 400; line-height: 1.4;}
@media(max-width: 1199px) {.Heading90Pt {font-size: 64px;}}
@media(max-width: 991px) {.Heading90Pt {font-size: 50px;} .Heading36Pt {font-size: 2.8rem;} .Lead28Pt {font-size: 2.2rem;}}



/* ------------------------------------------------------------ *\
	Hintergrundfarben
\* ------------------------------------------------------------ */
.bg-saredi-blau { background-color: var(--saredi--blau);}
.bg-saredi-gelb { background-color: var(--saredi--gelb);}
.bg-footer {  background-color: var(--footer);}
.bg-dunkelblau { background-color: var(--dunkelblau);}
.bg-grau240 { background-color: var(--grau-240);}
.bg-grau220 { background-color: var(--grau-220);}
.bg-grau160 { background-color: var(--grau-160);}
.bg-weiss { background-color: var(-weiss);}
.bg-schwarz { background-color: var(-schwarz);}
.bg-hellblau {  background-color: var(--hellblau);}



/* ------------------------------------------------------------ *\
    Fonts
\* ------------------------------------------------------------ */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Hind';
  font-style: normal;
  font-weight: 300;
  src: url('fonts/hind-v18-latin-300.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/hind-v18-latin-300.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Hind';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/hind-v18-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/hind-v18-latin-regular.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Hind';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/hind-v18-latin-500.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/hind-v18-latin-500.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Hind';
  font-style: normal;
  font-weight: 600;
  src: url('fonts/hind-v18-latin-600.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/hind-v18-latin-600.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Hind';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/hind-v18-latin-700.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/hind-v18-latin-700.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}




/* ------------------------------------------------------------ *\
	Margins
\* ------------------------------------------------------------ */
.abstand-kein { margin-bottom: 0px;}
.abstand-mini { margin-bottom: 30px;}
.abstand-klein { margin-bottom: 80px;}
.abstand-mittel { margin-bottom: 120px;}      
.abstand-gross { margin-bottom: 150px;}
.abstand-extra { margin-bottom: 200px;}
.abstand-maximal { margin-bottom: 250px;}

@media (max-width: 1199px) {
.abstand-klein { margin-bottom: 70px;}
.abstand-mittel { margin-bottom: 100px;}      
.abstand-gross { margin-bottom: 125px;}
.abstand-extra { margin-bottom: 175px;}
.abstand-maximal { margin-bottom: 225px;}
}

@media (max-width: 767px) {
.abstand-klein { margin-bottom: 60px;}
.abstand-mittel { margin-bottom: 80px;}  
.abstand-gross { margin-bottom: 100px;}
.abstand-extra { margin-bottom: 150px;}
.abstand-maximal { margin-bottom: 200px;}
}

@media (max-width: 575px) {
.abstand-klein { margin-bottom: 40px;}
.abstand-mittel { margin-bottom: 55px;}  
.abstand-gross { margin-bottom: 70px;}
.abstand-extra { margin-bottom: 100px;}
.abstand-maximal { margin-bottom: 150px;}
}

.abstan-single-referenz-slider { margin-bottom: 66px;}
@media (max-width: 1199px) {
.abstan-single-referenz-slider { margin-bottom: 50px;}
}

@media (max-width: 767px) {
.abstan-single-referenz-slider { margin-bottom: 40px;}
}



/* ------------------------------------------------------------ *\
	BASE
\* ------------------------------------------------------------ */
html { font-size: var(--fz-html);}
body {
    min-width: 320px;
    font-family: var(--ff-base);
    font-weight: var(--fw-base);
    font-size: var(--paragraph-22);
    line-height: var(--line-height-md);
    color: var(--schwarz);
    background-color: var(--base-background);
    letter-spacing: 0.01em;
    transition: background-color .5s ease;
}

body.has-menu-open {  overflow: hidden;}

a { color: inherit; text-decoration: underline;}
@media (hover: hover) {
a:where(:hover, :focus-visible) { text-decoration: none;}
}

a[href^='tel'] { text-decoration: none;}



p,
ul,
ol,
dl,
hr,
table,
blockquote {
  margin-bottom: calc(var(--line-height-lg) * 0.8em);
}

h1[class],
h2[class],
h3[class],
h4[class],
h5[class],
h6[class],
h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child,
p:last-child,
ul:last-child,
ol:last-child,
dl:last-child,
table:last-child,
blockquote:last-child {
  margin-bottom: 0;
}

strong {font-weight: 600; font-family: var(--ff-base);}






.main {padding-top: 10rem}
@media(max-width: 1199px) {
.main {padding-top: 8rem;}
}
@media(max-width: 991px) {
.main {padding-top: 6rem;}
}
@media(max-width: 575px) {
.main {padding-top: 5rem;}
}
.main.main-no-top-padding {padding-top: 0}




/* ------------------------------------------------------------ *\
	Container
\* ------------------------------------------------------------ */

.container {  --container-max-width: 172rem; --container-gutter: 4rem; max-width: calc(var(--container-max-width) + var(--container-gutter) * 2); padding-inline: var(--container-gutter); margin-inline: auto;  width: 100%;}

.container--fluid { max-width: none;}

@media (max-width: 991px) { 
.container {  --container-gutter: 3rem;}
}
@media (max-width: 767px) {
.container { --container-gutter: 2rem; }
}


/* ------------------------------------------------------------ *\
	Headings
\* ------------------------------------------------------------ */
h1,
h2,
h3,
h4,
h5,
h6 {
    margin-bottom: calc(var(--line-height-lg) * 0.5em);
    font-family: var(--ff-base);
    font-weight: 400;
}

h1 { font-size: var(--heading-90); line-height: var(--line-height-xs); font-weight: 500; letter-spacing: -0.01em;}
h2 { font-size: var(--heading-36); line-height: var(--line-height-sm); color: var(--dunkelblau);}
h3 { font-size: var(--heading-28); line-height: var(--line-height-sm);}
h4 { font-size: var(--paragraph-22); line-height: var(--line-height-md);}
h5 { font-size: var(--paragraph-18); line-height: var(--line-height-md);}


.text-white {  color: var(--weiss) !important;}
.brightfont 


/* ------------------------------------------------------------ *\
  Wrapper
\* ------------------------------------------------------------ */
/* ------------------------------------------------------------ */
/* Wrapper Grundstruktur */
.wrapper {
    position: relative;
    min-height: 100svh;
    overflow: clip;
    isolation: isolate;
}

/* Overlay-Pseudo-Element */
.wrapper:before {
    content: '';
    pointer-events: none;
    z-index: 99;
    position: fixed;
    top: var(--header-height);
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.75);
    transition: opacity 0.3s ease-out;
    opacity: 0;
}

/* Desktop: Overlay erscheint beim Hover */
@media (min-width: 992px) {
    .wrapper:has(.nav .menu-item-has-children:hover):before {
        opacity: 1;
    }

    /* Optional: Overlay deaktivieren, falls .no-hover-overlay gesetzt */
    .wrapper.no-hover-overlay:before {
        opacity: 0 !important;
        content: none !important;
    }
}

/* Mobile: Kein Overlay, auch bei geöffnetem Submenu */
@media (max-width: 991px) {
    .wrapper {
        padding-top: var(--header-height);
    }

    .wrapper:has(.nav .menu-item-has-children.is-open):before {
        opacity: 0; /* Mobile Submenu zeigt kein Overlay */
    }

    .wrapper.no-hover-overlay:before {
        opacity: 0 !important;
        content: none !important;
    }
}





/* ------------------------------------------------------------ *\
  Header
\* ------------------------------------------------------------ */
.header {padding-block: 2rem 5.5rem; position: relative; width: 100%; z-index: 100; background-color: transparent; transition: background-color 0.3s ease-in;}
.header:before {content: ''; position: absolute; top: 100%; left: 0; width: 100vw; height: var(--sub-menu-height, 0px); background-color: var(--saredi--blau); pointer-events: none; transition: height 0.3s ease;}
.header .header__inner {display: flex; justify-content: space-between; align-items: flex-end;}
.header .header__nav-inner {display: contents;}
.header .header__logo {display: inline-block; max-width: 20rem; transition: opacity .3s;}
.header .header__logo img {width: 100%; height: 100%; object-fit: contain;}
.header .header__nav {text-align: right; display: flex; flex-direction: column; gap: 2.3rem; margin-left: auto;}
@media (max-width: 1399px) {
.header {padding-block: 2rem;} 
.header .header__nav {gap: 0.6rem;}
}
@media (max-width: 1199px) {
.header .header__logo {max-width: 18rem;}
}
@media (max-width: 991px) {
.header {position: fixed; top: 0; left: 0;} 
.header.is-open {background-color: var(--saredi--blau);} 
.header--scroll .header__logo {opacity: 0;} 
.header.is-open.header--scroll .header__logo {opacity: 1;} 
.header:before {content: none;} 
.header .header__inner {align-items: center;} 
.header.is-open .header__nav {opacity: 1; pointer-events: auto;} 
.header .header__nav {display: block; padding-block: 6rem; position: absolute; top: calc(100% - 1px); left: 0; width: 100%; background-color: var(--saredi--blau); isolation: isolate; pointer-events: none; opacity: 0; height: calc(101dvh - 100%); overflow: auto; transition: opacity 0.3s ease-in; padding-inline: 2rem; text-align: left;} 
.header .header__nav-inner {display: flex; flex-direction: column-reverse; overflow: hidden; align-items: flex-start;}
}
@media (max-width: 767px) {
.header .header__logo {max-width: 15rem;}
}






/* ------------------------------------------------------------ *\
  Nav
\* ------------------------------------------------------------ */
.nav { margin-right: -3rem; }
.nav > ul { display: flex; color: var(--weiss); font-size: 2.2rem; }

.nav .nav__btn {
  border: none;
  background: none;
  display: none;
  transition: transform 0.2s;
}

.nav a {
  padding: 1rem 3rem;
  line-height: 1.1;
  display: block;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 12px;
  transition: text-decoration-color 0.3s;
}

.nav a:hover,
.nav li.menu-item-has-children:hover > a {
  text-decoration-color: currentColor;
}

.nav .menu-item-has-children { position: relative; }

.nav .menu-item-has-children:before {
  content: '';
  position: absolute;
  bottom: -3rem;
  left: 0;
  height: 3rem;
  width: 100%;
  pointer-events: none;
}

/* Desktop Hover Submenu */
.nav .menu-item-has-children:hover .sub-menu {
  opacity: 1;
  pointer-events: auto;
}

.nav .menu-item-has-children:hover:before {
  pointer-events: auto;
}

/* Aktive States */
.nav > ul > li.current_page_item > a { color: var(--weiss); }
.nav .sub-menu li.current_page_item > a { color: var(--saredi--gelb); }

.nav li.menu-item-has-children.current_page_item > a,
.nav li.menu-item-has-children.current-page-parent > a {
  text-decoration-color: currentColor;
}

/* ------------------------------------------------------------ */

@media (max-width: 1199px) {
  .nav a { padding-inline: 2rem; }
}

/* ============================================================
   🔥 MOBILE NAV – INTERACTION FIX INTEGRIERT
============================================================ */

@media (max-width: 991px) {

  /* --- NAV GRUNDZUSTAND (GESCHLOSSEN) --- */
  .nav {
    letter-spacing: 0.02em;
    width: 100%;

    opacity: 0;
    pointer-events: none;   /* ❗ verhindert Ghost-Klicks */
    visibility: hidden;     /* ❗ verhindert Fokus */
    transform: translateY(-1rem);
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0.25s;
  }

  /* --- NAV OFFEN --- */
  body.has-menu-open .nav {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transform: translateY(0);
    transition: opacity 0.25s ease, transform 0.25s ease;
  }

  .nav ul {
    flex-direction: column;
    text-align: left;
    font-size: 2.8rem;
    font-weight: 400;
    width: 100%;
  }

  .nav a {
    text-decoration: none;
    padding-inline: 0;
    padding-block: 1.1rem;
  }

  .nav li.menu-item-has-children {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }

  .nav .sub-menu { flex-basis: 100%; }

  .nav .nav__btn {
    display: block;
    width: 2rem;
    margin-right: 1.2rem;
  }

  .nav .nav__btn img {
    width: 100%;
    object-fit: contain;
  }

  .nav li.menu-item-has-children.is-open .nav__btn {
    transform: rotate(180deg);
  }

  .nav li.menu-item-has-children > a {
    position: relative;
    padding-right: 5rem;
    width: 100%;
  }

  .nav li.menu-item-has-children > a:before {
    content: '';
    position: absolute;
    top: 50%;
    right: 2.5rem;
    width: 1.2rem;
    height: 1.2rem;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    transform: translateY(-50%) rotate(45deg);
    transition: transform 0.2s;
  }

  .nav li.menu-item-has-children.current-page-parent > a { color: var(--saredi--gelb); }
  .nav > ul > li.current_page_item > a { color: var(--saredi--gelb); }
}

/* Visibility Helpers */
.nav li.desktophidden { display: none; }
.nav li.desktopvisible { display: flex; }

@media (max-width: 991px) {
  .nav li.mobilevisible { display: block; }
}


/* ------------------------------------------------------------ *\
  SUB MENU
\* ------------------------------------------------------------ */

.sub-menu {
  --offset: 2rem;
  position: absolute;
  top: calc(100% + var(--offset));
  left: 0;
  width: max-content;
  padding-bottom: 6rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease-out;
  z-index: 2;
}

ul.sub-menu {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-size: 2.4rem;
  text-align: left;
}

.sub-menu a {
  transition: padding 0.2s;
  text-decoration: none;
}

.sub-menu a:hover { padding-left: 4rem; }

/* ============================================================
   MOBILE SUBMENU
============================================================ */

@media (max-width: 991px) {

  .sub-menu {
    position: static;
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.35s ease, padding 0.25s ease;
    padding: 0 0 0 2rem;
    opacity: 1;
    pointer-events: auto;
  }

  .menu-item-has-children.is-open > .sub-menu {
    max-height: 500px;
    padding-top: 0.4rem;
    padding-bottom: 1.4rem;
  }

  .sub-menu a:hover { padding-left: 0; }
}










/* ------------------------------------------------------------ *\
  Nav alt
\* ------------------------------------------------------------ */
.nav--alt { justify-content: flex-end; margin-right: -2rem;  }
.nav--alt > ul { justify-content: flex-end; font-size: var(--paragraph-16); color: var(--dunkelblau); font-weight: 500;  }
.nav--alt a { padding-inline: 2rem; transition: opacity 0.2s; text-decoration: none;  }
.nav--alt a:hover { opacity: 0.6;  }

/* Nav alt aktiv */
.nav--alt li.current_page_item  a { color: var(--dunkelblau) !important;  opacity: 0.6;  }


@media (max-width: 991px) {
.nav--alt { display: none}
.nav--alt { justify-content: flex-start;  }
.nav--alt ul { font-size: 2.8rem; color: var(--weiss); font-weight: 400;  }
.nav--alt a { padding-inline: 0;  }
}


/* ------------------------------------------------------------ *\
  Nav trigger
\* ------------------------------------------------------------ */
.nav-trigger { position: relative; display: none; width: 4.4rem; height: 4rem;  }
.nav-trigger span { position: absolute; left: 0; display: block; height: 0.2rem; width: 4.4rem; background: #fff; transition: top 0.2s 0.25s, left 0.2s 0.1s, opacity 0.2s 0.1s, transform 0.2s 0s; left: 50%; transform: translate(-50%);  }
.nav-trigger.light span { background-color: #fff;  }
.nav-trigger.dark span { background-color: #1e3c5a;  }

.nav-trigger span:nth-child(1) { top: 1.4rem;  }
.nav-trigger span:nth-child(2) { top: 2.6rem;  }
.nav-trigger span:nth-child(3) { top: 3rem;  }

.nav-trigger.is-active span { background: #fff; transition: background 0.2s, top 0.2s, left 0.2s 0.1s, opacity 0.2s 0.1s, transform 0.2s 0.25s;  }
.nav-trigger.is-active span:nth-child(2), .nav-trigger.is-active span:nth-child(1) { top: 2rem;  }
.nav-trigger.is-active span:nth-child(1) { transform: translateX(-50%) rotate(45deg);  }
.nav-trigger.is-active span:nth-child(2) { transform: translateX(-50%) rotate(-45deg);  }

@media (max-width: 991px) {
.nav-trigger { display: block;  }
}








/* ------------------------------------------------------------ *\
  Home hero
\* ------------------------------------------------------------ */
.home-hero {--section-threshold: 800px;}
.home-hero .home-hero__main {position: relative; min-height: 100rem; isolation: isolate; display: flex; align-items: flex-end; color: var(--weiss); padding-block: 10rem;}
.home-hero h1 { margin-bottom: 3rem; }
.home-hero .home-hero__media {position: absolute; top: 0; left: 0; height: 100%; width: calc(100% - (-50vw + var(--container-max-width) / 2)); margin-left: calc(-50vw + var(--container-max-width) / 2); z-index: -1; overflow: hidden;}
.home-hero .home-hero__media:before {content: ''; position: absolute; top: 0; left: 0; width: 101%; height: 100%; background: linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%); opacity: 0.6;}
.home-hero .home-hero__content {width: 100%; font-weight: 500; padding-left: 1.8rem;}
.home-hero .home-hero__content p {margin-bottom: 3rem;}
.home-hero .home-hero__media > * {width: 100%; height: 100%; object-fit: cover;}
.home-hero .home-hero__actions {display: flex; align-items: center; gap: 3rem; flex-wrap: wrap; margin-top: 3rem;}

@media (max-width: 1800px) {
.home-hero .home-hero__main {min-height: 80rem;}
.home-hero .home-hero__media {margin-left: calc(var(--container-gutter) * -1); width: calc(100% + calc(var(--container-gutter)));}
}

@media (max-width: 991px) {
    .home-hero {padding-top: 0.6rem; letter-spacing: 0.02em;}
    .home-hero h1 {margin-bottom: 6rem;}
    .home-hero .home-hero__main {min-height: 63rem; padding-block: 4rem;}
    .home-hero .home-hero__actions {gap: 1rem; margin-top: 3rem;}
    .home-hero .home-hero__content {padding-left: 1.4rem;}
}

@media (max-width: 767px) {
    .home-hero .home-hero__content {padding-left: 0;}
}

@media (max-width: 575px) {
    .home-hero {--section-threshold: 800px;}
    .home-hero .home-hero__main {padding-block: 0 0.6rem; min-height: 79rem;}
    .home-hero .home-hero__media {height: calc(100% - 15rem);}
    
    
body.firstscroll .home-hero .home-hero__content p{color: var(--dunkelblau);}

body.firstscroll .home-hero .home-hero__content .btn-outline-primary {
  --bs-btn-font-size: 1.8rem;
  --bs-btn-color: var(--dunkelblau);
  --bs-btn-border-color: var(--dunkelblau);
  --bs-btn-hover-color: var(--saredi--blau);
  --bs-btn-hover-border-color: var(--saredi--blau); 
}
}



/* ------------------------------------------------------------ *\
    Hero alt
\* ------------------------------------------------------------ */
.hero-alt { font-size: var(--heading-28); color: var(--dunkelblau); letter-spacing: 0.01em; }
.hero-alt .ubertitel {font-size: var(--paragraph-22); margin-bottom: 1.5rem;}
.hero-alt h1 { margin-bottom: 5rem;}
.hero-alt h1:last-child {margin-bottom: 0;}
.hero-alt__actions {display: flex; flex-wrap: wrap; gap: 3rem; margin-top: 3rem;}

.hero-alt.hero_kontakt h1 { margin-bottom: 10rem;}
@media (max-width: 991px) {
.hero-alt.hero_kontakt h1 { margin-bottom: 6rem;}
}

.hero-alt h1 { color: var(--weiss);}
body.firstscroll .hero-alt h1{
color: var(--dunkelblau);
}




/* ------------------------------------------------------------ *\  
  Titel mit Lead    
\* ------------------------------------------------------------ */
.titel_mit_lead { font-size: var(--heading-28); line-height: var(--line-height-md); color: var(--dunkelblau);letter-spacing: 0.013em;}
@media (max-width: 991px) {
.titel_mit_lead { }
.titel_mit_lead h2 { margin-bottom: 3rem;}
}



/* ------------------------------------------------------------ *\
	SECTRION TEXT
\* ------------------------------------------------------------ */

.section-text ul { list-style: none; padding: 0; margin: 0 0 25px 0;}
.section-text ul li { display: flex; align-items: flex-start; gap: 15px; padding-bottom: 8px;}
.section-text ul li::before { content: ""; flex: 0 0 20px; height: 1px; margin-top: 0.7em; /* vertikale Ausrichtung zum Text */ background: var(--saredi--blau);}

.section-text ol {
  list-style: none;
  counter-reset: my-awesome-counter;
  margin: 0 0 25px 0;
  padding: 0;
}

.section-text ol li {
  counter-increment: my-awesome-counter;
  padding-bottom: 8px;

  position: relative;      /* wichtig für absolutes Positionieren */
  padding-left: 2em;       /* Platz für die Zahl schaffen */
}

.section-text ol li::before {
  content: counter(my-awesome-counter) ".";
  position: absolute;
  left: 0;                 /* Zahl ganz links innerhalb des li */
  width: 2em;              /* Breite des Nummernblocks */
  text-align: left;       /* Zahlen rechtsbündig, damit 1 und 10 sauber stehen */
}


.section-text a { color: var(--saredi--blau); text-decoration: none }
.section-text a:hover { color: var(--dunkelblau); }





/* ------------------------------------------------------------ *\  
  Einzelfoto    
\* ------------------------------------------------------------ */
.section-foto img {width: 100%}
.section-foto .einzelfoto-foto { height: 100%; }
.section-foto .einzelfoto-foto img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 575px) {
.section-foto .container100 .einzelfoto-foto { aspect-ratio: 3/4; }
.section-foto .browser100 .einzelfoto-foto { aspect-ratio: 3/4; }
.section-foto .fotocontent .einzelfoto-foto { aspect-ratio: 1/1; }
}




/* ------------------------------------------------------------ *\  
  Video    
\* ------------------------------------------------------------ */
.section-video .video { width: 100%; height: 100%;}
.section-video .video video { width: 100%; height: 100%; object-fit: cover; display: block;}

@media (max-width: 575px) {
.section-video .container100 .video { aspect-ratio: 3/4; }
.section-video .browser100 .video { aspect-ratio: 3/4; }
.section-video .fotocontent .video { aspect-ratio: 1/1; }
}




/* ------------------------------------------------------------ *\  
  Deeplinks with icons    
\* ------------------------------------------------------------ */
.deeplinks-with-icons .deeplinks-with-icons__inner { background-color: var(--grau-240); padding-block: 8rem 9.4rem; }
.deeplinks-with-icons .deeplinks-with-icons__icon { text-align: center; padding-right: 3rem; }
.deeplinks-with-icons .deeplinks-with-icons__icon img { width: 12rem; height: auto; }
.deeplinks-with-icons .deeplinks-with-icons__item { padding-inline: 12rem; display: block; text-decoration: none; }
.deeplinks-with-icons .deeplinks-with-icons__item-inner { display: block;text-decoration: none; transition: background-color 0.3s; padding-block: 1rem; }
.deeplinks-with-icons .deeplinks-with-icons__arrow { margin-left: 50%; }
.deeplinks-with-icons .deeplinks-with-icons__item-inner:hover { background-color: rgba(255, 255, 255, 0.3); }
.deeplinks-with-icons .deeplinks-with-icons__item-inner:hover h2 { margin-left: 2rem; }
.deeplinks-with-icons .deeplinks-with-icons__item-inner:hover .deeplinks-with-icons__arrow { width: 8rem; }
.deeplinks-with-icons .deeplinks-with-icons__item:not(:last-child) .deeplinks-with-icons__item-inner { border-bottom: 1px solid var(--weiss); }
.deeplinks-with-icons h2 { padding-left: 7%; margin-bottom: 0; color : var(--saredi--blau); transition: margin 0.2s; }

@media (max-width: 1699px) {
.deeplinks-with-icons .deeplinks-with-icons__arrow { margin-left: 10%; }
}

@media (max-width: 1399px) {
.deeplinks-with-icons .deeplinks-with-icons__inner { padding-block: 6rem; }
.deeplinks-with-icons .deeplinks-with-icons__item { padding-inline: 8rem; }
}

@media (max-width: 1199px) {
.deeplinks-with-icons .deeplinks-with-icons__inner { padding-block: 3rem; }
.deeplinks-with-icons .deeplinks-with-icons__item { padding-inline: 4rem; }
.deeplinks-with-icons .deeplinks-with-icons__arrow { margin-left: 0; }
.deeplinks-with-icons .deeplinks-with-icons__icon { padding-right: 0; }
.deeplinks-with-icons .deeplinks-with-icons__icon img { width: 10rem;  }
}

@media (max-width: 991px) {
.deeplinks-with-icons h2 { padding-left: 0; }
.deeplinks-with-icons .row { --bs-gutter: 1rem; }
.deeplinks-with-icons .deeplinks-with-icons__item { padding-inline: 2rem; }
.deeplinks-with-icons .deeplinks-with-icons__item-inner:hover .deeplinks-with-icons__arrow { width: 4rem; }
.deeplinks-with-icons .deeplinks-with-icons__icon img { width: 8rem;  }
}
@media (max-width: 767px) {
.deeplinks-with-icons h2 { font-size: var(--paragraph-22);}
.deeplinks-with-icons .deeplinks-with-icons__item-inner:hover h2 { margin-left: 1rem; }
}
@media (max-width: 575px) {
.deeplinks-with-icons .deeplinks-with-icons__inner { padding-block: 2rem; }
.deeplinks-with-icons .deeplinks-with-icons__item { padding-inline: 1.5rem; }
.deeplinks-with-icons .row .icon-col { min-width: 7rem; width: 7rem; flex-shrink: 0; }
.deeplinks-with-icons .deeplinks-with-icons__item-inner:hover .deeplinks-with-icons__arrow { width: 3.2rem; }
}

@media (max-width: 375px) {
.deeplinks-with-icons .icon-arrow { width: 2.4rem; }
}



/* ------------------------------------------------------------ *\  
  Deeplinks ohne icons    
\* ------------------------------------------------------------ */
.deeplinks-with-icons.ohne-icon .deeplinks-with-icons__item-inner .row {  min-height: 12rem; align-items: center; display: flex; }
.deeplinks-with-icons.ohne-icon h2 { padding-left: 2.5%;}

@media (max-width: 1199px) {
.deeplinks-with-icons.ohne-icon .deeplinks-with-icons__item-inner .row { min-height: 10rem;}
}

@media (max-width: 991px) {
.deeplinks-with-icons.ohne-icon .deeplinks-with-icons__item-inner .row {min-height: 8rem;}
}

@media (max-width: 575px) {
.deeplinks-with-icons.ohne-icon .deeplinks-with-icons__item-inner .row {min-height: 6rem;}
}










/* ------------------------------------------------------------ *\
    teaser-text-with-image
\* ------------------------------------------------------------ */
.teaser-text-with-image + .teaser-text-with-image {  }
.teaser-text-with-image .teaser-text-with-image__inner { background-color: var(--grau-240); }
.teaser-text-with-image .teaser-text-with-image__image { height: 100%;}

.teaser-text-with-image .teaser-text-with-image__image img { width: 100%; height: 100%; object-fit: cover; }

.teaser-text-with-image .teaser-text-with-image__content { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; margin: auto; max-width: 53rem; height: 100%; padding-right: 5rem; padding-block: 5rem; }
.teaser-text-with-image h3 { margin-bottom: 3rem; color: var(--dunkelblau); }
.teaser-text-with-image p { margin-bottom: 4rem; }

/* teasercontent-reversed */
.teasercontent-reversed .teaser-text-with-image__content { padding-right: 0; padding-left: 5.2rem; }



/* Bildspalte darf NICHT die Höhe bestimmen */
.teaser-text-with-image__image {
  display: flex; position: relative;
}

/* Ratio steuert nur Bildfenster */
.teaser-text-with-image__image::before {
  content: "";
  display: block;
  padding-top: calc(21 / 32 * 100%); /* 32:21 Ratio */
}

/* Bild wird darübergelegt */
.teaser-text-with-image__image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 767.98px) {
  .teaser-text-with-image__image::before {
    padding-top: 100%; /* optional 1:1 */
  }
}


@media (max-width: 991px) {
.teaser-text-with-image + .teaser-text-with-image { }
.teaser-text-with-image h3 { margin-bottom: 2rem; }
.teaser-text-with-image p { margin-bottom: 2rem; }
.teaser-text-with-image .teaser-text-with-image__content { padding-right: 2rem; }
.teasercontent-reversed .teaser-text-with-image__content { padding-left: 2rem; padding-right: 0; }
}

@media (max-width: 767px) {
.teaser-text-with-image .teaser-text-with-image__content {  max-width: unset;}
.teaser-text-with-image .teaser-text-with-image__content { padding-right: 2rem; padding-left: 2rem; }
.teasercontent-reversed .teaser-text-with-image__content { padding-right: 2rem; padding-left: 2rem; }
}

@media (max-width: 575px) {
.teaser-text-with-image .teaser-text-with-image__content { padding: 3.5rem 2.5rem 3.5rem 2.5rem;}
.teaser-text-with-image__image { aspect-ratio: 1/1; }
}





/* ------------------------------------------------------------ *\
    Section main
\* ------------------------------------------------------------ */
.section-refs {   }
.section-refs .section__aside { position: sticky; top: 4rem; left: 0;  }
.section-refs .row { --bs-gutter-y: 10rem;  }

@media(max-width: 1399px) {
.section-refs {   }
}
@media(max-width: 991px) {
.section-refs {  }
.section-refs .row { --bs-gutter-y: 5rem;  }
}
@media(max-width: 575px) {
  .section-refs .row { --bs-gutter-y: 3rem;  }
}



/* ------------------------------------------------------------ *\
    Journal with cards
\* ------------------------------------------------------------ */
.journal-with-cards .journal-with-cards__head { text-align: center; margin-bottom: 10rem; }
.journal-with-cards .journal-with-cards__head h2 { color: var(--dunkelblau); }
.journal-with-cards .journal-with-cards__actions { margin-top: 10rem; text-align: center; }
.journal-with-cards .row { --bs-gutter-y: 10rem; }

@media (max-width: 991px) {
.journal-with-cards .row { --bs-gutter-y: 5rem; }
.journal-with-cards .journal-with-cards__head { margin-bottom: 8rem; }
}
@media (max-width: 767px) {
.journal-with-cards .journal-with-cards__head { margin-bottom: 6rem; }
}
@media (max-width: 575px) {
.journal-with-cards .row { --bs-gutter-y: 3rem; }
}


.lightfont .journal-with-cards.section-refs h2 {color: var(--weiss)}



/* ------------------------------------------------------------ *\
    Card
\* ------------------------------------------------------------ */
.card { background-color: var(--weiss); text-decoration: none; display: flex;
  flex-direction: column;
  width: 100%; height: 100%}
.card-img-wrapper { aspect-ratio: 540/400; overflow: hidden; }
.card-img-wrapper img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.2s; }
.card:hover .card-img-wrapper img { transform: scale(1.05); }

.card .card-content { padding: 4rem 6rem 5.5rem 6rem; min-height: 30rem; flex: 1; display: flex; flex-direction: column; justify-content: space-between}
.card .card-content-inner { }
.card .card-subtitle { color: var(--grau-160); font-size: var(--paragraph-18); font-weight: 600; margin-bottom: 1.2rem; }
.card .card-text { margin-bottom: 3rem; }
.card .card-icon { width: 4rem;  }

.card .card-icon:before { background-color: var(--grau-160); }
.card .card-icon:after { border-color: var(--grau-160); width: 1.8rem; height: 1.8rem; }
.card:hover .card-icon { width: 5rem; }
.card:hover .card-icon:before { background-color: var(--saredi--blau); }
.card:hover .card-icon:after { border-color: var(--saredi--blau); }

@media (max-width: 1399px) {
.card .card-content { padding: 3.4rem 4rem 4rem 4rem; min-height: auto; }
}

@media (max-width: 1199px) {
.card .card-content { padding-inline: 3rem; }
}

@media (max-width: 991px) {
.card .card-content { padding-inline: 2rem; }
.card .card-text { margin-bottom: 2rem; }
}

@media (max-width: 767px) {
.card .card-content { padding: 4.5rem 4em 3rem 4rem; }
.card .card-subtitle { font-size: var(--paragraph-16); margin-bottom: 0.8rem; }
.card .card-text { margin-bottom: 3rem; }
.card .card-icon { width: 3rem; }
.card .card-icon:after { width: 1.4rem; height: 1.4rem; }
}

@media (max-width: 575px) {
/*.card-img-wrapper { aspect-ratio: 4/3; }*/
.card .card-content { padding: 3.5rem 2.5em 3rem 2.5rem; }
}









/* ------------------------------------------------------------ *\
    Nav aside
\* ------------------------------------------------------------ */
.nav-aside {font-size: var(--paragraph-22); color: var(--weiss); line-height: 1.4; display: block;}
.nav-aside .nav__dropdown {display: grid; grid-template-rows: 0fr; transition: grid-template-rows .2s, padding .2s; padding-left: 3rem;}
.nav-aside .nav__dropdown ul {overflow: hidden;}
.nav-aside ul li + li {margin-top: .8rem;}
.nav-aside a {text-decoration: none; transition: color .2s;}
.nav-aside a:hover {color: var(--saredi--gelb);}
.nav-aside li.is-open .nav__dropdown {grid-template-rows: 1fr; padding-block: 1rem 1.6rem;}
.nav-aside li.is-open > a {color: var(--saredi--gelb);}
.nav-aside li a.selected {color: var(--saredi--gelb);}

.filter-toggle {display: none }
@media(max-width:991px) {
.nav-aside .nav__dropdown {padding-left: 1.6rem;}
}

@media(max-width:767px) {
.nav-aside {  display: none; padding-top: 30px}
.filter-toggle { display: inline-block;   }
}





/* ------------------------------------------------------------ *\
    Article
\* ------------------------------------------------------------ */
.article { position: relative; z-index: 0; display: flex; align-items: flex-end; padding: 2rem; color: var(--weiss); text-decoration: none; overflow: hidden; aspect-ratio: 1/1.427;  }
.article:hover .article__image img { transform: scale(1.05);  }
.article:hover .article__content { padding-left: 1.6rem;  }
.article .article__image { position: absolute; top: 0; left: 0; width: 100%; height: 100%;  }
.article .article__image:before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(190deg,rgba(255, 255, 255, 0) 37%, rgba(0, 0, 0, 1) 125%); z-index: 1;  }
.article .article__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .2s;  }
.article .article__content { position: relative; z-index: 1; transition: padding .2s;  }
.article .article__content span { display: block;  }
@media(max-width: 1399px) {
  .article:hover .article__content { padding-left: .6rem;  }
}




/* ------------------------------------------------------------ *\
    Text
\* ------------------------------------------------------------ */

.text {
    padding-block: 15rem 20rem;
}

.text p:not(:last-child) {
    margin-bottom: 3rem;
}

@media (max-width: 991px) {
    .text {
        padding-block: 12rem;
    }

    .text p:not(:last-child) {
        margin-bottom: 2.2rem;
    }
}










/* ------------------------------------------------------------ *\
    Call to action
\* ------------------------------------------------------------ */
.call-to-action { position: relative; display: flex; align-items: center; min-height: 64rem; padding-block: 6rem; isolation: isolate; }
.call-to-action:before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(90deg, rgba(255, 240, 0, 1) 39%, rgba(255, 240, 0, 0) 84%); }
.call-to-action h2 { font-size: var(--heading-60); color: var(--dunkelblau); margin-bottom: 3rem; }
.call-to-action .call-to-action__image { position: absolute; top: 0; right: 0; width: 66%; height: 100%; z-index: -1; }
.call-to-action .call-to-action__image img { width: 100%; height: 100%; object-fit: cover; }
.call-to-action .call-to-action__content { position: relative; font-size:  var(--heading-28); max-width: 54rem; color: var(--dunkelblau); padding-bottom: 5.5rem; }
.call-to-action p { margin-bottom: 6rem; }

@media (max-width: 767px) {
.call-to-action { align-items: flex-start; min-height: 54.6rem; }
.call-to-action p { margin-bottom: 3rem; }
.call-to-action:before { background: linear-gradient(180deg, rgba(255, 240, 0, 1) 54%, rgba(255, 240, 0, 0) 84%); }
.call-to-action .call-to-action__image { width: 100%; height: 50%; top: auto; bottom: 0; }
.call-to-action .call-to-action__content {  }
}




/* ------------------------------------------------------------ *\
	People module
\* ------------------------------------------------------------ */
.team {}
.team .team__items {--bs-gutter-y: 5rem;}
.team .team__inner {background-color: var(--hellblau); padding-block: 10rem 12rem; padding-inline: 15.4rem;}
.team .team__inner.col-xl-9 {max-width: 127.8rem;}
.team .team__image {max-width: 24.5rem; border-radius: 50%; overflow: hidden; flex-shrink: 0; aspect-ratio: 1/1;}
.team .team__image img {width: 100%; height: 100%; object-fit: cover; display: block}
.team .team__title {color: var(--dunkelblau); margin-bottom: 5rem;}
.team .team__item {display: flex; align-items: center; gap: 5rem;}
.team .team__content {font-size: var(--paragraph-22); flex: 1;}
.team .team__content h4 {font-weight: 500; margin-bottom: 0;}
.team .team__contact {margin-top: 3rem; display: flex; flex-direction: column;}
.team .team__contact a {text-decoration: underline; text-decoration-color: transparent; transition: text-decoration-color .3s; text-underline-offset: 3px;}
.team .team__contact a[href^='mailto:'] {color: var(--saredi--blau);}
.team .team__contact a:hover {text-decoration-color: currentColor;}

.team .team__inner--alt {padding-inline: 0; padding-block: 0; background-color: transparent;}
.team .team__inner--alt .team__image {max-width: 30rem;}
.team .team__item--alt {display: flex; flex-direction: column; gap: 4rem;}

@media (max-width: 1539px) {
    .team .team__image {width: 18rem; height: 18rem;}
}

@media (max-width: 1399px) {
    .team {}
    .team .team__inner {padding: 6rem;}
    .team .team__item {gap: 2rem;}
}

@media (max-width: 1199px) {
    .team .team__items {--bs-gutter-y: 7.5rem;}
    .team .team__inner {padding-inline: 4rem;}
    .team .team__image {width: 18rem; height: 18rem;}
    .team .team__inner--alt {padding: 0; padding-inline: 0;}
}

@media (max-width: 991px) {
    .team .team__content {flex: 1;}
}

@media (max-width: 767px) {
    .team .team__title {text-align: center; margin-bottom: 3rem;}
    .team .team__item {display: block; text-align: center;}
    .team .team__image {margin-inline: auto; margin-bottom: 2rem;}
}
@media (max-width: 575px) {
    .team .team__inner {padding: 4rem 2rem;}
    .team .team__inner--alt {padding: 0; }
}



/* ------------------------------------------------------------ *\
	Slick slider
\* ------------------------------------------------------------ */
.slick-slider-wrapper .slick-slider__slide {display: flex;}
.slick-slider-wrapper .slider__clip {position: relative;}
.slick-slider-wrapper .slider__image {display: flex; background-color: var(--grau-240);}
.slick-slider-wrapper .slider__image img {width: 74.4%; aspect-ratio: 1278/760; object-fit: cover;}
.slick-slider-wrapper figcaption {width: 25.6%;  padding: 4rem; font-size: var(--paragraph-18); color: var(--dunkelblau);}
.slick-slider-wrapper .slider__controls {position: absolute; bottom: 3rem; right: 4rem; display: flex; gap: 2rem;}
.slick-slider-wrapper .slider__prev, .slick-slider-wrapper .slider__next {background: none; border: none; outline: none;}
.slick-slider-wrapper .slider__controls svg {border-radius: 50%;}
.slick-slider-wrapper button:hover svg {background: #fff;}

@media (max-width: 991px) {
    .slick-slider-wrapper {}
    
    .slick-slider-wrapper figcaption {padding: 2rem; font-size: var(--paragraph-16);}
    .slick-slider-wrapper .slider__controls {bottom: 2rem; right: 2rem;}
}

@media (max-width: 767px) {
    .slick-slider-wrapper {}
    .slick-slider-wrapper .slider__image {display: block;}
    .slick-slider-wrapper .slider__image img {width: 100%;}
    .slick-slider-wrapper figcaption {padding-block: 4rem; width: 100%;}
    .slick-slider-wrapper .slider__controls {position: static; justify-content: center; margin-top: 2rem;}
}

@media (max-width: 575px) {
.slick-slider-wrapper figcaption {padding: 2.5rem; }
.slick-slider-wrapper .slider__image img {aspect-ratio: 1/1;}
}





/* ------------------------------------------------------------ *\
	Testimonial
\* ------------------------------------------------------------ */
.testimonial::before { content: ""; display: block; height: 10rem; /* Gleicher Wert wie margin-top vom Bild */}

.testimonial .testimonial__inner {background-color: var(--grau-240); display: flex; flex-direction: column; color: var(--dunkelblau); text-align: center; letter-spacing: 0; padding-bottom: 10rem; padding-inline: 3rem;}
.testimonial blockquote { font-size: var(--heading-36); margin-bottom: 3rem; max-width: 142rem; margin-inline: auto; }
.testimonial .testimonial__image {width: 20rem; height: 20rem; margin-top: -10rem; margin-bottom: 4rem; margin-inline: auto; border-radius: 50%; overflow: hidden;}
.testimonial .testimonial__image img {width: 100%; height: 100%; object-fit: cover;}
.testimonial .testimonial__author {font-size: var(--paragraph-18); }

@media(max-width: 991px) {
 .testimonial {padding-block: 8rem;}
.testimonial .testimonial__image {width: 16rem; height: 16rem; margin-top: -8rem;}
    
.testimonial::before { height: 8rem; /* Gleicher Wert wie margin-top vom Bild */}
}
@media(max-width: 767px) {
.testimonial .testimonial__inner {padding-inline: 1.8rem; padding-bottom: 5rem;}
}






/* ------------------------------------------------------------ *\
	Facts
\* ------------------------------------------------------------ */
.facts {color: var(--weiss); }
.darkfont .facts {color: var(--schwarz);}

.facts .facts__inner {max-width: 144rem; margin: 0 auto;}
.facts .facts__items {display: flex; flex-wrap: wrap; margin-inline: -2rem; row-gap: 14rem;}
.facts .facts__item {width: 50%; line-height: 1.45; padding-inline: 2rem;}
.facts .facts__item:first-child {margin-right: auto;}
.facts .facts__item:nth-child(even) {margin-top: 15rem;}
.facts .facts__item:nth-child(3) .facts__item-inner {margin-left: auto; margin-right: 0;}
.facts .facts__item:nth-child(4) .facts__item-inner {margin-left: auto; margin-right: 0;}
.facts .facts__item-inner {max-width: 40rem; text-align: center;}
.facts .facts__title {text-align: center; margin-bottom: 15rem;}

.facts .facts__title h2 {color: var(--weiss);}
.darkfont .facts__title h2 {color: var(--dunkelblau);}

.facts h3 {color: var(--saredi--blau); font-size: 15rem; margin-bottom: 4.2rem; font-weight: 300}

@media(max-width: 1399px) {
	.facts {}
	.facts .facts__title {margin-bottom: 10rem;}
	.facts h3 {font-size: 12rem;}
}

@media(max-width: 1199px) {
	.facts {}
	.facts .facts__title {margin-bottom: 8rem;}
	.facts h3 {font-size: 8rem;}
}

@media(max-width: 991px) {
	.facts {}
	.facts .facts__items {row-gap: 8rem;}
	.facts .facts__title {margin-bottom: 6rem;}
}

@media(max-width: 767px) {
	.facts .facts__items {row-gap: 6rem;}
	.facts .facts__item {width: 100%; margin-top: 0 !important;}
	.facts .facts__item-inner {margin-left: 0 !important; margin-right: auto !important;}
	.facts .facts__item:nth-child(even) .facts__item-inner {margin-left: auto !important; margin-right: 0 !important;}
}






/* ------------------------------------------------------------ *\
  Buttons
\* ------------------------------------------------------------ */
.btn {
    --bs-btn-font-size: 1.6rem;
    --bs-btn-padding-x: 1.2rem;
    --bs-btn-padding-y: 1rem;
}

.btn-outline-primary {
    --bs-btn-font-size: 1.8rem;
    --bs-btn-color: var(--weiss);
    --bs-btn-border-color: var(--weiss);
    --bs-btn-hover-color: var(--weiss);
    --bs-btn-hover-bg: #c2c2c226;
    --bs-btn-hover-border-color: var(--weiss);
    --bs-btn-border-radius: 999rem;
    --bs-btn-padding-x: 3.8rem;
    --bs-btn-padding-y: 1.2rem;

    border: 1px solid;
}

.btn-outline-secondary {
    --bs-btn-color: var(--saredi--blau);
    --bs-btn-border-color: var(--saredi--blau);
    --bs-btn-hover-color: var(--saredi--blau);
    --bs-btn-hover-bg: #c2c2c226;
    --bs-btn-hover-border-color: var(--saredi--blau);
    --bs-btn-border-radius: 999rem;
    --bs-btn-padding-x: 1.8rem;
    --bs-btn-padding-y: 0.7rem;

    border: 1px solid;
}

.btn-lg {
    --bs-btn-font-size: 1.8rem;
    --bs-btn-padding-x: 4rem;
    --bs-btn-padding-y: 1.2rem;
}

@media (max-width: 991px) {
    .btn-outline-primary {
        letter-spacing: 0.04em;
    }

    .btn-lg {
        --bs-btn-font-size: 1.6rem;
        --bs-btn-padding-y: 0.6rem;
        --bs-btn-padding-x: 2rem;
    }
}



.btn-white {
    --bs-btn-border-color: var(--weiss);
    --bs-btn-color: var(--weiss);
    --bs-btn-hover-border-color: var(--weiss);
    --bs-btn-hover-color: var(--weiss);
}

body.firstscroll .btn-white{
    --bs-btn-border-color: var(--saredi--blau);
    --bs-btn-color: var(--saredi--blau);
    --bs-btn-hover-border-color: var(--saredi--blau);
    --bs-btn-hover-color: var(--saredi--blau);
}
body.firstscroll .btn-white svg path{
fill: var(--saredi--blau);
}




.buttonrow {display: flex; gap: 30px; flex-wrap: wrap }
@media (max-width: 1199px) {
.buttonrow {gap: 20px }
}
@media (max-width: 767px) {
.buttonrow {gap: 10px }
}


/* ------------------------------------------------------------ *\
    Icon arrow
\* ------------------------------------------------------------ */

.icon-arrow {
    position: relative;
    width: 6rem;
    height: 3.6rem;
    display: block;
    transition: width 0.2s;
}

.icon-arrow:before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: var(--saredi--blau);
    transform: translateY(-50%);
    transition: background-color 0.2s;
}

.icon-arrow:after {
    content: '';
    position: absolute;
    top: 50%;
    right: 2px;
    width: 2.6rem;
    height: 2.6rem;
    border-top: 2px solid var(--saredi--blau);
    border-right: 2px solid var(--saredi--blau);
    transform: translateY(-50%) rotate(45deg);
    transition: border-color 0.2s;
}

@media (max-width: 991px) {
    .icon-arrow {
        width: 3rem;
    }

    .icon-arrow:after {
        width: 1.4rem;
        height: 1.4rem;
    }
}











/* ------------------------------------------------------------ *\
	Section Accordion
\* ------------------------------------------------------------ */
.section-accordion {}
.accordion { border-bottom: 1px solid var(--grau-220); margin-top: -10px}

.accordion-trigger { font-size: var(--heading-28); color: var(--dunkelblau); border-top: 1px solid var(--grau-220); padding: 30px 0 28px; display: block; width: 100%; clear: both; position: relative; cursor: pointer; transition: all .3s;}
.accordion-trigger:first-of-type { border-top: none;}

.accordion-trigger:hover { color: var(--saredi--blau);}
.accordion-trigger-active { border-bottom: none; color: #000;}


.accordion-trigger-open:before {content: "";position: absolute;display: block;right: 0px; top: 50%; width: 30px; height: 0; border-top: 2px solid var(--grau-160);transform: rotate(0deg);transform-origin: center;transition: all .3s ease;}
.accordion-trigger-open:after {content: "";position: absolute;display: block;margin: auto; right: 0px; top: 2px; bottom: 0;width: 30px; height: 0; border-top: 2px solid var(--grau-160); transform: rotate(90deg);transform-origin: center;transition: all .3s ease;}

.accordion-trigger:hover .accordion-trigger-open:before {border-top: 2px solid var(--dunkelblau); }
.accordion-trigger:hover .accordion-trigger-open:after {border-top: 2px solid var(--dunkelblau); }

.accordion-trigger-active .accordion-trigger-open:before {border-top: 2px solid #000;transform: rotate(45deg);}
.accordion-trigger-active .accordion-trigger-open:after {border-top: 2px solid #000;transform: rotate(-45deg); }

.accordion-content {padding: 0 0 40px 0; -webkit-animation:fadeOut .8s ease-out;animation:fadeOut .8s ease-out;  }
.accordion-content.open {-webkit-animation:fadeIn .8s ease-out;animation:fadeIn .8s ease-out}

@media (max-width: 991px) {
}
@media (max-width: 575px) {
.accordion-trigger { padding: 20px 0 18px; }
.accordion-trigger-open:before { width: 20px;}
.accordion-trigger-open:after {width: 20px;}
}




/* ------------------------------------------------------------ *\
	Dokument Download-Liste
\* ------------------------------------------------------------ */
.section-downloads {}

ul.dokument-download { list-style: none; margin-bottom: 0;}
ul.dokument-download li {border-bottom: 1px solid var(--grau-220); padding: 20px 0; position: relative}
ul.dokument-download li a {position: relative; text-decoration:none;  color: var(--saredi--blau); display: block; padding-right: 0px; transition: all .3s;}
ul.dokument-download li a:hover {color: var(--schwarz);}

ul.dokument-download li a {font-size: var(--paragraph-18); display: flex; justify-content: space-between; }

ul.dokument-download li a .filetype { font-size: 14px; display: inline-flex; align-items: center;      /* vertikal zentriert */ justify-content: center;  /* horizontal zentriert */ padding: 2px 12px 0; border-radius: 2rem; border: 1px solid var(--saredi--blau); color: var(--saredi--blau); text-transform: uppercase; letter-spacing: 0.1em; transition: all .3s;}

ul.dokument-download li a:hover .filetype {  border: 1px solid var(--schwarz);; color: var(--schwarz);;}



/* ------------------------------------------------------------ *\
	Section Meilensteine
\* ------------------------------------------------------------ */
.section-meilensteine {}
.row.meilensetein { border-bottom: 1px solid var(--weiss); padding: 50px 0; }
body.firstscroll .row.meilensetein {  border-bottom: 1px solid var(--saredi--blau); }
.row.meilensetein:first-of-type { padding-top: 0;}
.row.meilensetein:last-of-type { border-bottom: none;}

.meilenstein-jahr { font-size: var(--heading-90); color: var(--weiss); line-height: var(--line-height-xs); font-weight: 300}
body.firstscroll .meilenstein-jahr { color: var(--saredi--blau); }


.meilenstein-text { font-size: var(--heading-28); color: var(--weiss); }
.darkfont .meilenstein-text { color: var(--schwarz); }

@media (max-width: 991px) {
.row.meilensetein { padding: 40px 0; }
}
@media (max-width: 575px) {
.row.meilensetein { padding: 30px 0; }
}




/* ------------------------------------------------------------ *\
    Footer
\* ------------------------------------------------------------ */

.footer {background-color: #142337; color: var(--weiss); padding-block: 7rem 9rem;}
.footer .footer__inner {margin-bottom: 7.2rem;}
.footer .footer__logo {display: inline-block; margin-bottom: 3rem;}
.footer .footer__logo img {width: 50px;}

.footer .footer__address {font-size:  var(--paragraph-18); margin-bottom: 3rem; display: flex; flex-direction: column; align-items: flex-start;}
.footer .footer__address a {display: inline-block; text-decoration: none; transition: color .3s;}
.footer .footer__address a:hover {color: var(--saredi--blau);}

.footer .footer__nav {display: flex; padding-top: 1rem; gap: 5rem;}
.footer .footer__nav ul {flex: 1;}
.footer .footer__nav a {width: 100%; display: block; text-decoration: none; border-bottom: 1px solid var(--dunkelblau); padding-bottom: 0.6rem; margin-bottom: 0.6rem; transition: border-color 0.2s;}

.footer .footer__nav a:hover {color: var(--saredi--gelb);}
.footer .footer__nav li.current_page_item a {color: var(--saredi--gelb);}

.footer .footer__socials {display: flex; gap: 3rem;}
.footer .footer__socials a {display: block; text-decoration: none; transition: transform 0.2s;}
.footer .footer__socials a:hover {transform: scale(1.1);}
.footer .footer__scroll-btn {display: flex; align-items: center; justify-content: center; border-radius: 50%; width: 5rem; height: 5rem; background-color: rgba(255, 255, 255, 10%); margin-left: auto; transition: background-color .3s;}
.footer .footer__scroll-btn:hover {background-color: var(--saredi--blau);}
.footer .footer__scroll-btn img {max-width: 1.2rem;}

@media (max-width: 767px) {
.footer {padding-block: 4rem 8rem;}
.footer .footer__inner {margin-bottom: 8.2rem;}
.footer .footer__logo {max-width: 4rem;}
.footer .footer__nav a {padding-bottom: 0.3rem;}
.footer .footer__nav {gap: 2rem; padding-top: 3rem;}
.footer .footer__socials {gap: 2rem;}
}
@media (max-width: 374px) {
.footer .footer__nav a {font-size: var(--paragraph-16);}
}



/* Pagination */
.portfolionavigation { margin: 0 auto; padding: 45px 0 0; border-top: 1px solid var(--grau-220); display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;}

.portfolionavigation.infinite { 
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.portfolionavigation.not-infinite {}
.portfolionavigation.not-infinite .previous_post_link  {-ms-flex-item-align:start;align-self:flex-start; }
.portfolionavigation.not-infinite .next_post_link  {-ms-flex-item-align:end;align-self:flex-end;margin-left: auto;}
.portfolionavigation.not-infinite .post_overview {-ms-flex-item-align:cente;-ms-grid-row-align:center;align-self:center;margin-left: auto;}


/* post_overview absolut zentrieren */
.post_overview {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}


.portfolionavigation a {display:block; color: var(--grau-160); font-size: var(--heading-28); text-decoration: none; display: flex; gap: 20px; 
  align-items: center;}
.portfolionavigation a:hover { color: var(--saredi--blau); }
.portfolionavigation a:hover .paginationicon { stroke:var(--saredi--blau) !important}

.portfolionavigation svg {
  overflow: visible; padding: 1px;
}

@media (max-width: 991px) {
.portfolionavigation { padding: 35px 0 0; }
.portfolionavigation a {font-size: var(--heading-22);}

}
@media (max-width: 767px) {
.portfolionavigation { padding: 25px 0 0; }
.portfolionavigation a span {display: none}
}





.referenzdetails {}
.referenzdetails-row {border-bottom: 1px solid var(--grau-220); padding: 12px 0; font-size: var(--paragraph-18);}
.referenzdetails-row .titel {font-weight: 600;}
.referenzdetails-row .content {padding-left: 5.9%;}
@media (max-width: 991px) {
.referenzdetails-row .content {padding-left: calc(var(--bs-gutter-x) * 0.5);}

}







/* **************************************************
			    		CONTACT
************************************************** */
div.wpcf7 {margin: 0;padding: 0; width: 100%;}
span.wpcf7-form-control-wrap { position: relative; }

.wpcf7 form input, .wpcf7 form textarea {  
width:100%; box-sizing: border-box; 
margin: 0 0 20px 0;
padding: 20px 30px;
border-radius: 5px;
border: 1px solid var(--grau-220);
background: var(--weiss);
color: var(--grau-160);
font-size: var(--paragraph-18);
line-height: var(--line-height-sm);
transition: all 0.3s ease;
}
.wpcf7 form input:hover, form textarea:hover {outline:none; border: 1px solid var(--saredi--blau);}
.wpcf7 form input:focus, form textarea:focus {outline:none; border: 1px solid var(--saredi--blau); }

.wpcf7 form textarea {height: 150px; resize: none}

::-webkit-input-placeholder { color: #C5C5C5 !important; opacity: 1; }
::-moz-placeholder { color: #C5C5C5 !important; opacity: 1; }
:-ms-input-placeholder { color: #C5C5C5 !important; opacity: 1; }
:-moz-placeholder { color: #C5C5C5 !important; opacity: 1; }

.wpcf7 form input:focus::-webkit-input-placeholder { color:transparent !important;}
.wpcf7 form input:focus:-moz-placeholder { /* Firefox 18- */ color:transparent !important; }
.wpcf7 form input:focus::-moz-placeholder {  /* Firefox 19+ */ color:transparent !important; }
.wpcf7 form input:focus:-ms-input-placeholder {   color:transparent !important;}

.wpcf7 form input[type=submit] {
width: auto; vertical-align: middle; text-align: center; cursor: pointer; text-decoration: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; 
line-height:1;
font-size: var(--fontsize-xs);
padding:1.5rem 4rem; 
background: transparent; 
border-radius: 200px;
border: 1px solid var(--saredi--blau);
border-radius:20rem; 
color: var(--saredi--blau);
font-size: var(--paragraph-18);
letter-spacing: 0.18px;
transition: all .3s ease;
margin-top: 2rem;
margin-bottom: 0
}
.wpcf7 form input[type=submit]:hover {background: var(--saredi--blau);  color: var(--weiss);}

.wpcf7 form input.wpcf7-not-valid {border: 1px solid var(--saredi--blau); }

.wpcf7 .wpcf7-submit:disabled{ cursor: not-allowed;opacity: .15; }
.wpcf7 .wpcf7-submit:disabled:hover {background: unset;  color: unset;}


/* WPCF7 */
div.wpcf7-mail-sent-ok,
div.wpcf7-mail-sent-ng,
div.wpcf7-spam-blocked,
div.wpcf7-validation-errors,
div.screen-reader-response {border: 0px !important; padding: 0px !important; margin: 0 0 25px 0 !important;}

div.wpcf7-mail-sent-ok ul,
div.wpcf7-mail-sent-ng ul,
div.wpcf7-spam-blocked ul,
div.wpcf7-validation-errors ul,
div.screen-reader-response ul{display: none;}

div.wpcf7-response-output {
color: var(--dunkelblau);
margin: 10px 0 25px 0 !important;
padding: 0 !important;
border: none !important;
font-size: var(--heading-28); 
line-height: var(--line-height-md)
}

.wpcf7-form.sent .wpcf7-response-output {}
.wpcf7-form.invalid .wpcf7-response-output {}

span.wpcf7-not-valid-tip { color: var(--saredi--blau) !important; font-size: 14px !important; display: block; margin: -15px 0 5px 0 !important;}
input.wpcf7-not-valid {outline:none; border: 1px solid #000;}






/* SELECT*/
.select-wrapper { position: relative; width: 100%; margin-bottom: 20px;}
.select-wrapper:after { pointer-events: none; position: absolute; display: block; content: ''; width: 12px; height: 12px; top: 50%; right: 20px; margin-top: -3px; border-bottom: 1px solid var(--grau-160); border-right: 1px solid var(--grau-160); transform: rotate(45deg) translateY(-50%); transition: all .4s ease-in-out; transform-origin: 50% 0; }

.wpcf7-form select{
background: var(--weiss); border: 1px solid var(--grau-220); color:var(--grau-160); border-radius: 5px; font-size: var(--paragraph-18); padding: 20px 20px;
width:100%;  border-radius:0;outline:0; -webkit-appearance:none; -moz-appearance:none; appearance:none; font-family: inherit;  cursor: pointer;}
.wpcf7-form select:focus {}
.wpcf7-form select::-ms-expand{display:none;}
.wpcf7-form select:focus::-ms-value { background-color: transparent;}





/* RADIO BUTTONS */
.wpcf7-list-item {display: block; margin: 0 30px 10px 0!important;}
.wpcf7-form .wpcf7-radio { display: block; overflow: hidden; margin: 5px 0 20px;}
.wpcf7-radio .wpcf7-list-item {display: inline-block;}
.wpcf7-radio .wpcf7-list-item + .wpcf7-list-item {margin-left: 35px !important}
.wpcf7-form .wpcf7-radio .wpcf7-list-item-label { display: inline-flex;;}
.wpcf7-form .wpcf7-radio label { position: relative; cursor: pointer; color: var(--grau-160);font-size: var(--paragraph-18);}
.wpcf7-form .wpcf7-radio input[type=radio] {position: relative; visibility: hidden; display: none}

.wpcf7-form .wpcf7-radio input[type=radio] + span:before { content: ''; border-radius: 100%; height: 20px; width: 20px; border: 1px solid var(--grau-160); margin-right: 20px;}
.wpcf7-form .wpcf7-radio input[type=radio] + span:after { display: block; position: absolute; content: '';  border-radius: 100%; height: 10px; width: 10px; top: 5px; left: 5px; visibility: hidden;}

.wpcf7-form .wpcf7-radio input[type=radio]:checked + span:before { background: transparent;}
.wpcf7-form .wpcf7-radio input[type=radio]:checked + span:after { background: var(--grau-160); visibility: visible;}

@media (max-width: 575px) {
.wpcf7-form .wpcf7-radio { margin-top:15px}
.wpcf7-radio .wpcf7-list-item {display: block;}
.wpcf7-radio .wpcf7-list-item + .wpcf7-list-item {margin-left: 0 !important}
.wpcf7-form .wpcf7-radio input[type=radio] + span:after { top: 1px; }
}



/* CHECKBOXES */
.wpcf7-checkbox { display: block; overflow: hidden; margin: 5px 0 25px;}
.wpcf7-checkbox .wpcf7-list-item {display: inline-block;}
.wpcf7-checkbox .wpcf7-list-item + .wpcf7-list-item {margin-left: 35px !important}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item-label { display: inline-flex; align-items: center;}
.wpcf7-form .wpcf7-checkbox label { position: relative; cursor: pointer; color: var(--grau-160);font-size: var(--paragraph-18);}
.wpcf7-form .wpcf7-checkbox input[type=checkbox] {position: relative; visibility: hidden; display: none}

.wpcf7-form .wpcf7-checkbox input[type=checkbox] + span:before { content: ''; height: 20px; width: 20px; min-height: 20px; min-width: 20px; border: 1px solid var(--grau-160); background:#FFF; margin-right: 20px;}
.wpcf7-form .wpcf7-checkbox input[type=checkbox] + span:after { display: block; position: absolute; content: '';  height: 10px; width: 10px; top: 5px; left: 5px; 
border: 1px solid var(--grau-220) visibility: hidden;}

.wpcf7-form .wpcf7-checkbox input[type=checkbox]:checked + span:before {}
.wpcf7-form .wpcf7-checkbox input[type=checkbox]:checked + span:after { background: var(--grau-160); visibility: visible;}

@media (max-width: 575px) {
.wpcf7-checkbox {margin-top: 15px;}
.wpcf7-checkbox .wpcf7-list-item {display: block;}
.wpcf7-checkbox .wpcf7-list-item + .wpcf7-list-item {margin-left: 0 !important}
.wpcf7-form .wpcf7-checkbox input[type=checkbox] + span:after { top: 1px;}
}



/* ACCEPTANCE */
.wpcf7-acceptance .wpcf7-list-item-label { display: inline-block; text-indent: -44px; margin-left: 44px;}
.wpcf7-acceptance .wpcf7-list-item-label label { position: relative; cursor: pointer;}
.wpcf7-acceptance .wpcf7-list-item input[type=checkbox] {position: relative; visibility: hidden; display: none}

.wpcf7-acceptance .wpcf7-list-item {position: relative; margin: 0 0 5px !important;}

.wpcf7-acceptance .wpcf7-list-item input[type=checkbox] + span:before { content: ''; height: 24px; width: 24px;
 border: none; background:#FFF;margin-right: 20px; margin-top: 0; display: inline-block;position: relative; top: 3px;}

.wpcf7-acceptance .wpcf7-list-item input[type=checkbox] + span:before { content: ''; height: 20px; width: 20px; min-height: 20px; min-width: 20px; 1px solid var(--grau-160); background:#FFF; margin-right: 20px;}
.wpcf7-acceptance .wpcf7-list-item input[type=checkbox] + span:after { display: flex; position: absolute; content: ''; height: 10px; width: 10px; top: 9px; left: 5px; visibility: hidden;}

.wpcf7-acceptance .wpcf7-list-item input[type=checkbox]:checked + span:before {}
.wpcf7-acceptance .wpcf7-list-item input[type=checkbox]:checked + span:after { 
background: #1F3582; background-size: cover; visibility: visible;
}

.wpcf7-acceptance a {color: #E2724E !important}



/* Felder mit readonly: Ändere Hintergrundfarbe und entferne Hover-/Cursor-Effekte */
input[readonly] {
    cursor: default
}

/* Entferne Hover-Effekte */
input[readonly]:hover,
input[readonly]:focus{
border: 1px solid rgba(122, 167, 186, 0.2) !important;
}

