@import url(reset.css);

html,
body {
    width: 100%;
    overflow-x: hidden;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  padding: 0;
}

:target {
  scroll-margin-top: 100px;
}

.dsa-secure-plugin iframe {
    height: 870px;
}

/*-----------FONTS-----------*/
/* jost-100 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 100;
  src: url('../fonts/jost-v20-latin-100.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-100italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 100;
  src: url('../fonts/jost-v20-latin-100italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/jost-v20-latin-200.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-200italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 200;
  src: url('../fonts/jost-v20-latin-200italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/jost-v20-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-300italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 300;
  src: url('../fonts/jost-v20-latin-300italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/jost-v20-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/jost-v20-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/jost-v20-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-500italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 500;
  src: url('../fonts/jost-v20-latin-500italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/jost-v20-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-600italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 600;
  src: url('../fonts/jost-v20-latin-600italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/jost-v20-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-700italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 700;
  src: url('../fonts/jost-v20-latin-700italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/jost-v20-latin-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-800italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 800;
  src: url('../fonts/jost-v20-latin-800italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/jost-v20-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* jost-900italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Jost';
  font-style: italic;
  font-weight: 900;
  src: url('../fonts/jost-v20-latin-900italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}


.container {
  max-width: 1580px;
  padding-inline: clamp(24px, 5vw, 170px);
  margin: 0 auto;
}


/*-----------FONTGESTALTUNG-----------*/


body {
  font-family: 'Jost', sans-serif;
  color: #1d2a7a;
  overflow-x:visible;
}

p {
  font-size: 16px; 
  font-weight: 300; 
  margin-bottom: 20px;
  line-height: 22px;
}

a {
  font-weight: 300;
  text-decoration: none; 
  cursor: pointer;
  color: white;
}

a:hover {
  text-decoration: underline;
}

h1 {
  font-family: 'Jost', sans-serif;
  font-size: 60px;
  font-weight: 500;
  text-shadow: 0px 0px 8px rgb(0 0 0 / 40%);
}

h1 span{
  font-size: 35px;
  font-weight: 600;
  line-height: 4px;
}

/*-----------NAVI-----------*/


.logo {
  background: url("../images/logo.png") no-repeat; 
  background-size: contain;
  height: 70px; 
  width: 312px; 
  position: fixed;
  top: 8px;
  left: 5%;
  z-index: 3;
} 

nav {
  position: fixed;
  top: 0;
  border-radius: 2px;
  width: 100%;
  text-align: right; 
  padding: 22px 0; 
  z-index: 100;
}

nav ul {
  margin: 12px 7%;
}

nav ul li {
  display: inline-block; 
  margin: 0 1%; 
}

nav ul li a {
  text-decoration: none; 
  font-size: 18px; 
  color: white;
  font-weight: 600;
  padding: 12px 24px;
  border-bottom: none;
  text-shadow: 0px 0px 8px rgb(0 0 0 / 30%);
}

nav ul li a:hover {
  background-color: rgba(81, 81, 151, 0.14);
  padding: 12px 24px;
  color: #fff;
  border-radius: 62px;
  text-decoration-line: none;
  transition: 0.5s;
}

nav ul li strong {
  color: #1d2a7a; 
  font-weight: 600;
}

.navi {
  display: none;
}

.header-info {
  position: fixed;
  top: 20px;
  right: 50px;
  z-index: 200;
}

.header-info__toggle {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #F18722;
  color: #fff;
  font-weight: 700;
  border: none;
  cursor: pointer;
  font-size: 20px;
}

.header-info__toggle:hover {
  background: #BE6917;}

.header-info__panel {
  position: absolute;
  top: 55px;
  right: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: #fff;
  padding: 12px;
  border-radius: 16px;
  box-shadow: 0 10px 25px rgba(0,0,0,.15);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all .3s ease;
}

.header-info.active .header-info__panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.header-info__item {
  position: relative;
  font-size: 22px;
  text-decoration: none;
  color: #5b5fa7;
  cursor: pointer;
}

.header-info__tooltip {
  position: absolute;
  right: 55px;
  top: 50%;
  transform: translateY(-50%);
  background: #5b5fa7;
  color: #fff;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 14px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
}

.header-info__item:hover .header-info__tooltip {
  opacity: 1;
  pointer-events: auto;
}

@media (hover: hover) {
  .header-info__item--hours:hover .header-info__tooltip {
    opacity: 1;
    pointer-events: auto;
  }
}

.header-info__item--hours.active .header-info__tooltip {
  opacity: 1;
  pointer-events: auto;
}

/* =========================
   BURGER + FULLSCREEN NAV (existing classes)
========================= */

.burger-nav{
  position: fixed;
  right: 24px;
  top: 18px;
  z-index: 9999;
  width: 56px;
  height: 56px;
  background: #FFF;
  border: 0;
  border-radius: 12px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.burger-nav__line{
  position: absolute;
  width: 30px;
  height: 3px;
  background: #1d2a7a;
  border-radius: 999px;
  transition: transform .35s ease, opacity .2s ease;
}

.burger-nav__line:nth-child(1){ transform: translateY(-9px); }
.burger-nav__line:nth-child(2){ transform: translateY(0); }
.burger-nav__line:nth-child(3){ transform: translateY(9px); }


.burger-nav-anim .burger-nav__line:nth-child(1){
  transform: translateY(0) rotate(45deg);
}
.burger-nav-anim .burger-nav__line:nth-child(2){
  opacity: 0;
}
.burger-nav-anim .burger-nav__line:nth-child(3){
  transform: translateY(0) rotate(-45deg);
}

/* fullscreen nav */
.full-screen-nav{
  position: fixed;
  width: 100%;
  z-index: 9998;
  background: #eceef6;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .35s ease, visibility .35s ease;
}


.full-screen-nav.fadeIn{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}


.full-screen-nav ul{
  margin: 0;
  padding: 80px 24px 24px;
  list-style: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 14px;
}

.full-screen-nav ul li a{
  display: inline-block;
  padding: 14px 18px;
  font-size: 30px;
  color: #1d2a7a;
  text-decoration: none;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .35s ease, transform .35s ease;
}

.full-screen-nav ul li a.fadeUp{
  opacity: 1;
  transform: translateY(0);
}


.fadeIn {
  opacity: 1 !important; 
  visibility: visible !important;
  transform: translateY(0px);
}

.fadeUp {
  opacity: 1 !important; 
  margin-top: 0 !important;
}
@media (max-width: 1100px) {
  nav ul li a {
    padding: 12px 15px;
  }
  nav ul li{
    margin: 0;
  }
  nav ul {
    margin: 12px 10%;
  }

}

@media (max-width: 870px){

  h1 {
    font-size: 42px;
  }

  nav{
    display:none;
  }
  .navi{
    display:block;
  }
  .header-info {
    top: 90px;
    right: 30px;
  }
  h1 span {
    font-size: 26px;}
}

@media (max-width: 390px){
 h1 {
    font-size: 32px;
  }
      h1 span {
        font-size: 20px;
    }
  h2 {
    font-size: 34px;
  }
  h3 {font-size: 26px;}
}

/*----------- HERO -----------*/

.logo {
    background: url(../images/logo.png) no-repeat;
    background-size: contain;
    height: 90px;
    width: 312px;
    position: fixed;
    top: 8px;
    left: 5%;
    z-index: 999;
}

.hero {
  background: url(../images/header.jpg);
  width: 100%;
  height: 100vh;
  object-fit: cover;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

.stoerer {
  position: absolute;
  display: flex;
  flex-direction: column;
  z-index: 2;
  top: 50%;
  left: 10%;
  transform: translateY(-50%);
  width: min(90vw, 770px);
  color: #fff;
  line-height: 1.0;
}

.btn:hover {
  background-color: #BE6917; 
  color: #fff; 
  text-decoration: none;
}

.btn { 
  background-color: #FF7F00; 
  text-align: center; 
  color: #fff; 
  border-radius: 27px; 
  padding: 17px 30px;
  transition: 0.5s; 
  font-size: 21px;
  font-weight: 500;
} 

.stoerer > .btn {
  padding: 17px 30px;
  font-size: 20px;
  width: fit-content;
  margin-top: 30px;
}

/* =========================
   ABOUT HERO
========================= */

.about-hero {
  background: #eceef6;
  padding: 60px 0;
  color: #0b1c6b;
}

.about-hero__wrapper {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: 56px;
  margin: 50px 0 100px;
}

.about-hero__media img {
  width: 100%;
  border-radius: 28px;
}

.about-hero__media {
  flex: 0 0 44%;
}
.about-hero__content {
  flex: 1;
}

.about-hero__headline {
  margin-bottom: 16px;
  font-size: 30px;
}

.about-hero__kicker {
  margin: 0 0 8px;
  font-weight: 700;
}

.about-hero__title {
  margin: 0;
}

.about-hero__text p {
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.55;
}

.about-hero .btn {
  display: inline-block;
  margin-top: 18px;
}

@media (max-width: 900px) {
  .about-hero__wrapper {
    flex-direction: column;
    gap: 24px;
  }

  .about-hero__content,
  .about-hero__media {
    width: 100%;
  }
  .about-hero__media {
    text-align: center;
  }

  .about-hero__media img {
    width: 80%;
  }
}

/* =========================
   TEAM
========================= */

.team {
  background: #c9cbe4;
  padding: 80px 0;
}

.team__header {
  text-align: center;
  margin-bottom: 56px;
}

.team__title {
  margin: 0 0 8px;
  font-size: 32px;
  font-weight: 700;
  color: #1d2a7a;
}

.team__subtitle {
  margin: 0;
  font-size: 16px;
  color: #1d2a7a;
}

.team__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 150px;
}

.team-card {
  position: relative;
  text-align: center;
  cursor: pointer;
}

.team-card__content {
  max-height: 0;
  overflow: hidden;
  transition: .5s ease;
  opacity: 0;
}
.team-card__list {
  margin: 0;
  padding-left: 20px;
  text-align: left;
  list-style: disc;
}

.team-card__list li {
  margin-bottom: 10px;
  line-height: 1.5;
}


.team-card.active .team-card__content {
  max-height: 400px;
  opacity: 1;
  margin-top: 15px;
  width: 100%;
}

.team-card__toggle {
  transition: transform .6s ease;
}

.team-card.active .team-card__toggle {
  transform: rotate(180deg);
}

.team-card__title {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
}

.team-card__toggle {
  position: absolute;
  bottom: -28px;
  border: none;
  background: transparent;
  cursor: pointer;
}

.team-card__image {
  width: 95%;
}

.team-card__info {
  background: #5b5fa7;
  color: #fff;
  padding: 20px;
  border-radius: 28px;
  margin-top: -10px;
  position: relative;
  min-height: 150px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
  z-index: 2;
}
.team-card__info::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -40px;
  width: 100%;
  height: 100%;
  background: rgba(91, 95, 167, 0.35);
  border-radius: 28px;
  transform: translateX(-50%);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
  z-index: -1;
}

.team-card__name {
  margin: 0 0 6px;
  font-size: 22px;
  font-weight: 700;
}

.team-card__role {
  margin: 0;
  font-size: 20px;
  line-height: 1.4;
}

.team-card__toggle {
  position: absolute;
  bottom: -33px;
  border: none;
  background: transparent;
  cursor: pointer;
}

@media (max-width: 1500px) {
  .team__grid {
    gap: 100px;
  }
}

@media (max-width: 1100px) {
  .team__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 700px) {
  .team__grid {
    grid-template-columns: 1fr;
  }

  .team-card__image {
    width: 50%;
  }
}


/* =========================
   SERVICES
========================= */

.services {
  background: #c9cbe4;
  padding: 60px 30px;
  border-radius: 28px;
}

.services__header {
  text-align: center;
  margin-bottom: 56px;
}

.services__title {
  margin: 0 0 8px;
  font-size: 32px;
  font-weight: 700;
  color: #1d2a7a;
}

.services__subtitle {
  margin: 0;
  font-size: 30px;
  color: #1d2a7a;
}

.services__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 56px 40px;
}

.service-card {
  text-align: center;
  cursor: pointer;
}

.service-card__box {
  position: relative;
  background: #5b5fa7;
  color: #fff;
  border-radius: 28px;
  padding: 15px 10px 15px;
  min-height: 100px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 1;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
  transition: all .4s ease;
}

.service-card__box::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -32px;
  width: 100%;
  height: 100%;
  background: rgba(91, 95, 167, 0.35);
  border-radius: 28px;
  transform: translateX(-50%);
  z-index: -1;
}

.service-card__content {
  max-height: 0;
  overflow: hidden;
  transition: .6s ease;
  opacity: 0;
}
.service-card__list {
  margin: 0;
  padding-left: 24px;
  text-align: left;
  list-style: disc;
}

.service-card__list li {
  margin-bottom: 10px;
  line-height: 1.5;
  font-weight: 300;
}


.service-card.active .service-card__content {
max-height: 400px;
opacity: 1;
margin-top: 15px;
}

.service-card__toggle {
transition: transform .2s ease;
}

.service-card.active .service-card__toggle {
transform: rotate(180deg);
}

.service-card__title {
margin: 0;
font-size: 18px;
font-weight: 400;
line-height: 1.4;
}

.service-card__toggle {
position: absolute;
bottom: -28px;
border: none;
background: transparent;
cursor: pointer;
}

@media (max-width: 1300px) {
.services__grid {
grid-template-columns: repeat(2, 1fr);
}
}

@media (max-width: 1100px) {
.services__grid {
grid-template-columns: repeat(2, 1fr);
}
}

@media (max-width: 700px) {
.services__grid {
grid-template-columns: 1fr;
}
}


/* =========================
SERVICES VISUAL
========================= */

.services-visual {
  background-image: url("../images/services-consulting.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  height: 650px;
  background-attachment: fixed;
}

@media (max-width: 900px) {
  .services-visual {
    height: 300px;
  }
}


/* =========================
   TOOLS
========================= */

.tools {
  background: #eceef6;
  padding: 80px 0;
  color: #0b1c6b;
}

.tools .container {
  max-width: 1380px;
}

.tools__header {
  text-align: center;
  margin-bottom: 56px;
}

.tools__title {
  margin: 0 0 8px;
  font-size: 32px;
  font-weight: 700;
  color: #1d2a7a;
}

.tools__subtitle {
  margin: 0;
  font-size: 16px;
  color: #1d2a7a;
}

.tools__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

.tool-card {
  position: relative;
  background: rgba(91, 95, 167, 0.35);
  border-radius: 28px;
  padding: 54px 24px 56px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
}

.tool-card__kicker {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0;
  background: #8F8FC1;;
  color: #fff;
  border-radius: 999px;
  padding: 20px;
  font-size: 16px;
  font-weight: 500;
  text-align: center;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
}

.tool-card__text {
  margin: 10px 0 14px;
  font-size: 16px;
  line-height: 1.5;
  color: #ffffff;
}

.tool-card__action {
  position: absolute;
  right: 8px;
  bottom: 8px;

  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}


.tool-card {
  transition: transform .35s cubic-bezier(.2,.8,.2,1),
  box-shadow .35s cubic-bezier(.2,.8,.2,1);
  cursor: pointer;
}

.tool-card.is-open {
  transform: translateY(-6px);
  box-shadow: 0 22px 45px rgba(0,0,0,.25);
}

.tool-card__more {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(12px);
  transition: max-height .8s cubic-bezier(.2,.8,.2,1),
  opacity .3s ease,
  transform .35s ease;
}

.tool-card.is-open .tool-card__more {
  max-height: 300px; /* можна збільшити */
  opacity: 1;
  transform: translateY(0);
}

.tool-card__action svg {
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
}

.tool-card.is-open .tool-card__action svg {
  transform: rotate(180deg);
}




@media (max-width: 1100px) {
  .tools__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 700px) {
  .tools__grid {
    grid-template-columns: 1fr;
  }
}


/* =========================
   CONTACT
========================= */

.contact{
  background: #4b4ea1;
  padding: 90px 0;
  color: #fff;
}

.contact__wrapper{
  display: flex;
  align-items: center;
  gap: 64px;
}

.contact__content{
  width: 48%;
}

.contact__media{
  width: 52%;
  border-radius: 28px;
  overflow: hidden;
}

.contact__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.contact__kicker{
  margin: 0 0 8px;
  font-size: 30px;
  font-weight: 700;
}

.contact__title{
  margin: 0 0 28px;
  font-size: 30px;
  line-height: 30px;
}

.contact__box{
  max-width: 520px;
}

.contact__person,
.contact__address{
  margin: 0 0 18px;
  font-size: 18px;
  line-height: 1.45;
}

.contact__list{
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.contact__item{
  display: flex;
  gap: 14px;
  align-items: center;
}

.contact__icon{
  display: flex;
  flex-direction: column;
}

.contact__value{
  font-size: 18px;
  line-height: 1.45;
}

.contact__link{
  color: #fff;
  text-decoration: none;
}

.contact__link:hover{
  text-decoration: underline;
}

.contact__cta{
  margin-top: 34px;
  display: inline-block;
}

/* responsive */
@media (max-width: 1000px){
  .contact__wrapper{
    flex-direction: column;
    gap: 32px;
  }

  .contact__content,
  .contact__media{
    width: 100%;
  }

  .contact__media{
    border-radius: 28px;
  }
}

/* =========================
   SUBNAV
========================= */


.legal-bar {
  position: fixed;
  bottom: 0;
  left: 70%;
  transform: translateX(-50%);
  background: #ffffff;
  padding: 12px 25px;
  border-radius: 25px 25px 0 0;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;
  gap: 14px;
  z-index: 9999;
}

.legal-bar a {
  text-decoration: none;
  font-weight: 600;
  color: #2b2f7f;
  font-size: 18px;
  transition: opacity .2s ease;
}

.legal-bar a:hover {
  opacity: 0.7;
}

.legal-bar__divider {
  color: #2b2f7f;
}

.legal-page {
  background: #f3f4fb;
  padding: 100px 0;
  color: #2b2f7f;
}

.legal-page__title {
  font-size: 48px;
  font-weight: 700;
  margin-bottom: 60px;
  color: #2b2f7f;
  text-shadow: none;
}

.legal-page__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
}

.legal-page__block h2 {
  font-size: 22px;
  margin-bottom: 20px;
  color: #2b2f7f;
}

.legal-page__block p {
  margin-bottom: 12px;
  line-height: 1.6;
}

.legal-page__block strong {
  color: #5b5fa7;
  font-weight: 600;
}

.legal-page a {
  color: #f58220;
  text-decoration: none;
  font-weight: 500;
  transition: opacity .2s ease;
}

.legal-page a:hover {
  opacity: .7;
}

.legal-page ul {
  list-style: none;
  padding: 0;
}

.legal-page ul li {
  margin-bottom: 10px;
}


@media (max-width: 760px) {
  .legal-bar {
    left: 50%;
  }
}





iframe {
  margin: 100px 0;
   width: 100%;
    height: 400px;
    border: 0;
    display: block;
}




/* COOKIE */
.cookie-page1,.cookie-page2,.cookie-page2.show-page{transition:visibility,opacity .5s linear}
.cookie-overlay-headline,.dsa-cookie-notice-form fieldset p{margin-bottom:15px;text-align:center}
.clear{clear:both}
.cookie-overlay-dsa.show-cookie{display:block}
.cookie-overlay-dsa{display:none;background-color:rgba(0,0,0,.6);position:fixed;z-index:99999999;top:-100px;left:0;height:100vh;width:100vw;line-height:20px}
.dsa-cookie-notice-form{min-height:300px;width:500px;position:absolute;top:40%;left:50%;transform:translateX(-50%);background:#4B0209 url(../images/bildmarke-dunkel.svg) left bottom -70px/400px no-repeat;color:#fff;padding:2%; border-radius: 32px;}
.dsa-cookie-notice-form .cookie-item{width:33.33%;float:left;text-align:center}
.cookie-overlay-headline{display:block;font-size:24px;font-weight:600}
.dsa-cookie-button{display:block;margin:0 50px 5px;background:#f8f8f8;padding:10px 20px;text-align:center;text-decoration:none;color:#000}
#dsa-check-all.dsa-cookie-button{background:#fff;margin-top:15px; border-radius: 40px;}
.dsa-cookie-notice-form input[type=checkbox]{display:none}
.dsa-cookie-notice-form input[type=checkbox]+label::before{width: 15px; height: 15px; border: 1px solid #D8D4D2; background: #fff; display: block; content: ""; margin: 10px auto; border-radius: 50%;}
.dsa-cookie-notice-form input[type=checkbox]:checked+label::before,
.dsa-cookie-notice-form input[type=checkbox]:disabled+label::before{box-shadow:inset 0 0 0 3px #fff;background:#4B0209}
.cookie-end-links{width:80%;margin:auto;text-align:center}
.cookie-notice-link{display:inline-block;text-align:center;margin:10px auto 0;color:#fff !important;text-decoration:none}

@media (max-width:550px){
  .dsa-cookie-notice-form{width:85%;padding:5%}
}
@media (max-height:570px){
  .dsa-cookie-notice-form{top:20%}
}
/* COOKIE ENDE */

#formular > iframe {
  width: 100%;
  height: 1060px;
  border: unset;
}



.unterschtrich {
  text-decoration-line: underline;
  text-underline-offset: 1px;
}

#impressum-map {
    height: 300px !important;
    width: 80% !important;
    margin: 0 auto;
    border-radius: 0 !important;
}

.aktuelles-section {
    position: relative;
    z-index: 20;
    padding: 80px 0;
    background: #eceef6;
}

.aktuelles-section .container {
    position: relative;
    z-index: 21;
}


.mm_index .moses_index_item a {
    color: #0b1c6b !important;
    margin-bottom: 22px !important;
    font-family: 'Jost' I !important;
    font-size: 18px !important;
}