:root {
    --ki-bg: #000000;
    --ki-bg-deep: #0b1120;
    --ki-bg-soft: rgba(0, 0, 0, 0.82);
    /* Kacheln: Referenz horizontal (dunkles Blau → Navy) */
    --ki-tile-gradient: linear-gradient(90deg, #1a2a4a 0%, #162b4d 38%, #0c1526 72%, #0a0f1a 100%);
    --ki-tile-border: rgba(100, 140, 210, 0.24);
    --ki-tile-icon-bg: #0f1c32;
    --ki-tile-icon-color: #33b5e5;
    --ki-panel: linear-gradient(to bottom, #2b4373, #0e1626);
    --ki-text: #e5e7eb;
    --ki-text-soft: #94a3b8;
    --ki-line: rgba(255, 255, 255, 0.12);
    --ki-accent: #199FCB;
    --ki-accent-2: #1a8fb8;
    --ki-shadow-accent: 0 22px 40px rgba(25, 159, 203, 0.2);
    --ki-shadow-dark: 0 20px 50px rgba(0, 0, 0, 0.28);
    --ki-radius: 18px;
    --ki-radius-lg: 24px;
    --ki-container: 1440px;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body.ki-body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    color: var(--ki-text);
    background: linear-gradient(to bottom, #000000, #000000, #111827);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

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

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea,
select {
    font: inherit;
}

.ki-main {
    min-height: 60vh;
}

.ki-container,
.ki-header__inner,
.ki-footer__inner,
.ki-footer__bottom,
.ki-team .container,
.ki-about .container {
    max-width: var(--ki-container);
    margin: 0 auto;
    padding-left: 32px;
    padding-right: 32px;
}

/* Header */

.ki-header {
    position: sticky;
    top: 0;
    z-index: 40;
    width: 100%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(18px);
}

.ki-header__inner {
    min-height: 96px;
    display: grid;
    grid-template-columns: 280px 1fr auto;
    align-items: center;
    gap: 24px;
}

.ki-header__brand {
    display: inline-flex;
    align-items: center;
}

.ki-header__logo {
    height: 56px;
    width: auto;
    object-fit: contain;
}

/* Navigation */

.ki-nav--desktop {
    display: flex;
    justify-content: center;
    min-width: 0;
}

.ki-nav__list,
.ki-mobile-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ki-nav__list {
    display: flex;
    align-items: center;
    gap: 26px;
}

.ki-nav__item,
.ki-mobile-nav__item {
    position: relative;
}

.ki-nav__link,
.ki-mobile-nav__link {
    position: relative;
    display: inline-block;
    font-weight: 700;
    color: #e5e7eb;
    transition: color 0.25s ease;
    white-space: nowrap;
}

.ki-nav__link {
    font-size: 14px;
    line-height: 1.2;
}

.ki-mobile-nav__link {
    font-size: 16px;
    line-height: 1.35;
    padding-bottom: 6px;
}

.ki-nav__line,
.ki-mobile-nav__line {
    position: absolute;
    left: 0;
    width: 0;
    height: 2px;
    background: linear-gradient(to right, var(--ki-accent), var(--ki-accent-2));
    transition: width 0.25s ease;
}

.ki-nav__line {
    bottom: -6px;
}

.ki-mobile-nav__line {
    bottom: 0;
}

.ki-nav__item:hover .ki-nav__line,
.ki-nav__item.is-active .ki-nav__line,
.ki-mobile-nav__item:hover .ki-mobile-nav__line,
.ki-mobile-nav__item.is-active .ki-mobile-nav__line {
    width: 100%;
}

.ki-nav__item:hover .ki-nav__link,
.ki-nav__item.is-active .ki-nav__link,
.ki-mobile-nav__item:hover .ki-mobile-nav__link,
.ki-mobile-nav__item.is-active .ki-mobile-nav__link {
    color: #ffffff;
}


/* Hauptnavigation Pill-Buttons (Desktop + Mobile-Menü oben) */
.ki-nav__list--pills {
    justify-content: center;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    row-gap: 8px;
}

.ki-nav__item--pill {
    list-style: none;
}

.ki-nav-pill {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    min-height: 36px;
    padding: 6px 14px;
    border-radius: 9999px;
    background: rgba(45, 48, 56, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.16);
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.01em;
    text-decoration: none;
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset;
}

.ki-nav-pill:hover {
    transform: translateY(-1px);
    background: rgba(55, 59, 68, 0.98);
    border-color: rgba(255, 255, 255, 0.22);
    color: #ffffff;
    text-decoration: none;
}

.ki-nav-pill.is-active {
    border-color: rgba(250, 204, 21, 0.45);
    box-shadow: 0 0 0 1px rgba(250, 204, 21, 0.12), 0 6px 14px rgba(0, 0, 0, 0.22);
}

.ki-nav-pill__label {
    white-space: normal;
    text-align: left;
    max-width: 15rem;
}

.ki-nav-pill__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    flex: 0 0 26px;
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #fde047;
}

.ki-nav-pill__icon svg {
    width: 20px;
    height: 20px;
    display: block;
}

.ki-mobile-nav__pills {
    list-style: none;
    margin: 0 0 22px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.ki-mobile-nav__pills li {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ki-nav-pill--mobile {
    width: 100%;
}

/* Buttons */

.ki-header__actions {
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: flex-end;
}

.ki-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 12px 20px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.ki-btn:hover {
    transform: translateY(-1px);
}

.ki-btn--primary {
    color: #ffffff;
    background: linear-gradient(to right, var(--ki-accent), var(--ki-accent-2), var(--ki-accent));
    border: 1px solid rgba(25, 159, 203, 0.35);
    box-shadow: var(--ki-shadow-accent);
}

.ki-header__cta-text--mobile {
    display: none;
}

/* Burger */

.ki-burger {
    display: none;
    width: 44px;
    height: 44px;
    padding: 10px;
    border: 0;
    background: transparent;
    cursor: pointer;
    border-radius: 12px;
}

.ki-burger span {
    display: block;
    width: 100%;
    height: 2px;
    background: #d1d5db;
    margin: 5px 0;
}

/* Mobile menu */

.ki-mobile-menu {
    position: fixed;
    inset: 0;
    z-index: 60;
}

.ki-mobile-menu[hidden] {
    display: none;
}

.ki-mobile-menu__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.82);
    backdrop-filter: blur(12px);
}

.ki-mobile-menu__panel {
    position: absolute;
    top: 0;
    right: 0;
    width: min(85vw, 360px);
    height: 100%;
    background: rgba(0, 0, 0, 0.86);
    border-left: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    flex-direction: column;
    box-shadow: -20px 0 50px rgba(0, 0, 0, 0.35);
}

.ki-mobile-menu__head,
.ki-mobile-menu__footer {
    padding: 20px;
}

.ki-mobile-menu__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.ki-mobile-menu__title {
    font-size: 20px;
    font-weight: 700;
}

.ki-mobile-menu__close {
    border: 0;
    background: transparent;
    color: #ffffff;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.ki-mobile-menu__body {
    flex: 1;
    overflow: auto;
    padding: 20px;
}

.ki-mobile-nav__item + .ki-mobile-nav__item {
    margin-top: 18px;
}

.ki-mobile-menu__cta-wrap {
    margin-top: 28px;
}

.ki-mobile-menu__cta {
    width: 100%;
}

.ki-mobile-menu__footer {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(0, 0, 0, 0.35);
}

.ki-mobile-menu__footer a {
    display: block;
    color: #cbd5e1;
    font-size: 14px;
}

.ki-mobile-menu__footer a + a {
    margin-top: 10px;
}

/* Hero Startseite */

.ki-hero-section {
    padding: 48px 0 80px;
    background: transparent;
}

.ki-hero {
    display: block;
}

.ki-hero__intro {
    max-width: 1180px;
    margin: 0 auto;
    text-align: center;
}

.ki-hero__headline {
    margin: 0;
    font-size: clamp(2.2rem, 6vw, 5.4rem);
    line-height: 1.1;
    letter-spacing: -0.03em;
    font-weight: 900;
    color: #e5e7eb;
}

.ki-hero__accent {
    color: var(--ki-accent);
}

.ki-hero__lead {
    margin: 28px auto 0;
    max-width: 1240px;
    font-size: clamp(1.05rem, 2vw, 1.55rem);
    line-height: 1.15;
    color: #94a3b8;
}

.ki-hero__actions {
    margin-top: 36px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
}

.ki-btn--hero-primary,
.ki-btn--hero-secondary {
    min-height: 58px;
    padding: 0 30px;
    border-radius: 18px;
    font-size: 1.05rem;
    font-weight: 700;
    position: relative;
    overflow: hidden;
}

.ki-btn--hero-primary {
    color: #ffffff;
    background: linear-gradient(to right, #199FCB, #1a8fb8, #199FCB);
    border: 1px solid rgba(25, 159, 203, 0.3);
    box-shadow: 0 22px 40px rgba(25, 159, 203, 0.2);
}

.ki-btn--hero-primary:hover {
    transform: translateY(-1px) scale(1.02);
    box-shadow: 0 22px 40px rgba(25, 159, 203, 0.28);
}

.ki-btn--hero-secondary {
    color: #e2e8f0;
    background: rgba(0, 0, 0, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
}

.ki-btn--hero-secondary:hover {
    transform: translateY(-1px) scale(1.02);
    border-color: rgba(25, 159, 203, 0.45);
    color: #ffffff;
}

.ki-btn--hero-primary span,
.ki-btn--hero-secondary span {
    position: relative;
    z-index: 2;
}

.ki-btn--hero-primary::before,
.ki-btn--hero-secondary::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.ki-btn--hero-primary::before {
    background: linear-gradient(to right, rgba(255, 255, 255, 0.1), transparent, rgba(255, 255, 255, 0.05));
}

.ki-btn--hero-secondary::before {
    background: linear-gradient(to right, rgba(255, 255, 255, 0.05), transparent, rgba(255, 255, 255, 0.05));
}

.ki-btn--hero-primary:hover::before,
.ki-btn--hero-secondary:hover::before {
    opacity: 1;
}

.ki-hero__visual {
    margin-top: 72px;
}

.ki-hero__image-frame {
    position: relative;
    border-radius: 24px;
}

.ki-hero__image-frame::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 24px;
    background: linear-gradient(to top, rgba(15, 23, 42, 0.18), transparent);
    pointer-events: none;
    z-index: 2;
}

.ki-hero__image {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.34);
}

/* Problems / Kacheln */

.ki-problems-section {
    padding: 48px 0 80px;
    background: rgba(0, 0, 0, 0.2);
}

.ki-problems__intro {
    max-width: 1200px;
    margin: 0 auto 56px;
    text-align: center;
}

.ki-problems__headline {
    margin: 0;
    font-size: clamp(2rem, 5vw, 4.2rem);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #e5e7eb;
}

.ki-problems__accent {
    color: var(--ki-accent);
}

.ki-problems__lead {
    max-width: 1080px;
    margin: 28px auto 0;
    font-size: clamp(1rem, 1.8vw, 1.4rem);
    line-height: 1.15;
    color: #94a3b8;
}

.ki-problems-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 38px;
}

/* Vierte Problem-Kachel: exakt gleiche Kantenlage wie drei Spalten darüber */
.ki-problem-card--fullwidth {
    grid-column: 1 / -1;
}

.ki-problem-card {
    min-height: 245px;
    padding: 32px 30px 18px;
    border-radius: 18px;
    background: var(--ki-tile-gradient);
    border: 1px solid var(--ki-tile-border);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 12px 28px rgba(0, 0, 0, 0.22);
    transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.ki-problem-card:hover {
    transform: translateY(-2px);
    border-color: rgba(25, 159, 203, 0.35);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.24);
}

.ki-problem-card__actions {
    margin-top: 18px;
}

.ki-problem-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 14px;
    background: linear-gradient(to right, #199FCB, #1a8fb8);
    color: #ffffff;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid rgba(25, 159, 203, 0.28);
    box-shadow: 0 10px 24px rgba(25, 159, 203, 0.14);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.ki-problem-card__button:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(25, 159, 203, 0.2);
    border-color: rgba(25, 159, 203, 0.4);
}

.ki-problem-card__head {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.ki-problem-card__icon {
    width: 58px;
    height: 58px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ki-tile-icon-bg);
    color: var(--ki-tile-icon-color);
    border: 1px solid rgba(51, 181, 229, 0.22);
    flex: 0 0 58px;
}

.ki-problem-card__title {
    margin: 0;
    font-size: clamp(1.25rem, 1.7vw, 1.8rem);
    line-height: 1.05;
    font-weight: 700;
    color: #ffffff;
}

.ki-problem-card__icon svg {
    width: 28px;
    height: 28px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.ki-problem-card__text {
    margin: 18px 0 0;
    font-size: clamp(1rem, 1.35vw, 1.15rem);
    line-height: 1.2;
    color: #94a3b8;
}

@media (max-width: 1200px) {
    .ki-problems-grid {
        gap: 26px;
    }

    .ki-problem-card {
        min-height: 320px;
        padding: 42px 24px 32px;
    }
}

/* Midtext */

.ki-midtext-section {
    padding: 12px 0 72px;
    background: rgba(0, 0, 0, 0.2);
}

.ki-midtext {
    max-width: 1120px;
    margin: 0 auto;
    text-align: center;
}

.ki-midtext__headline {
    margin: 0;
    font-size: clamp(1.5rem, 2.4vw, 2.2rem);
    line-height: 1.15;
    font-weight: 700;
    color: #cbd5e1;
}

.ki-midtext__text {
    margin: 24px auto 0;
    max-width: 1080px;
    font-size: clamp(1rem, 1.45vw, 1.2rem);
    line-height: 1.2;
    color: #94a3b8;
    text-align: center;
}

/* Funding */

.ki-funding-section {
    padding: 56px 0 86px;
    background: rgba(0, 0, 0, 0.18);
}

.ki-funding {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(420px, 880px);
    gap: 56px;
    align-items: center;
}

.ki-funding__content {
    max-width: 920px;
}

.ki-funding__headline {
    margin: 0;
    font-size: clamp(2.1rem, 5vw, 4.1rem);
    line-height: 1.12;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #e5e7eb;
}

.ki-funding__accent {
    color: var(--ki-accent);
}

.ki-funding__text {
    margin: 30px 0 0;
    max-width: 920px;
    font-size: clamp(1.05rem, 1.9vw, 1.5rem);
    line-height: 1.22;
    color: #cbd5e1;
}

.ki-funding__actions {
    margin-top: 34px;
}

.ki-btn--funding {
    min-height: 46px;
    padding: 0 26px;
    border-radius: 18px;
    background: linear-gradient(to right, #27a9d9, #199FCB);
    color: #ffffff;
    border: 1px solid rgba(25, 159, 203, 0.32);
    box-shadow: 0 14px 28px rgba(25, 159, 203, 0.16);
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.ki-funding__facts {
    display: grid;
    gap: 30px;
}

.ki-funding-card {
    display: flex;
    align-items: center;
    gap: 20px;
    min-height: 132px;
    padding: 30px 30px;
    border-radius: 18px;
    background: var(--ki-tile-gradient);
    border: 1px solid var(--ki-tile-border);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 12px 28px rgba(0, 0, 0, 0.22);
}

.ki-funding-card__icon {
    width: 62px;
    height: 62px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ki-tile-icon-bg);
    color: var(--ki-tile-icon-color);
    border: 1px solid rgba(51, 181, 229, 0.22);
    flex: 0 0 62px;
}

.ki-funding-card__icon svg {
    width: 30px;
    height: 30px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.ki-funding-card__title {
    font-size: clamp(1.4rem, 2vw, 2.05rem);
    line-height: 1.08;
    font-weight: 700;
    color: #ffffff;
}

/* Team */

.ki-team {
    padding: 90px 0;
    background: #000;
}

.ki-team__headline {
    margin: 0 0 22px;
    text-align: center;
    font-size: clamp(2.1rem, 4vw, 4rem);
    line-height: 1.1;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-team__headline span {
    color: #199FCB;
}

.ki-team__intro {
    max-width: 980px;
    margin: 0 auto 56px;
    text-align: center;
    font-size: clamp(1.05rem, 1.7vw, 1.7rem);
    line-height: 1.6;
    color: #cbd5e1;
}

.ki-team__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 48px;
}

.ki-team-card {
    padding: 48px 34px 34px;
    border-radius: 18px;
    text-align: center;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
}

.ki-team-card__media {
    margin-bottom: 28px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.ki-team-card__iconwrap {
    width: 196px;
    height: 196px;
    border-radius: 50%;
    border: 8px solid rgba(25, 159, 203, 0.14);
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(9, 18, 34, 0.08);
}

.ki-team-card__icon {
    width: 74px;
    height: 74px;
    color: #199FCB;
}

.ki-team-card__photo {
    width: 196px;
    height: 196px;
    object-fit: cover;
    border-radius: 50%;
    border: 8px solid rgba(25, 159, 203, 0.14);
    display: block;
}

.ki-team-card__name {
    margin: 0 0 18px;
    font-size: clamp(1.6rem, 2vw, 2.3rem);
    line-height: 1.2;
    font-weight: 700;
    color: #f1f5f9;
}

.ki-team-card__role {
    margin: 0 0 24px;
    font-size: clamp(1.2rem, 1.5vw, 1.8rem);
    line-height: 1.35;
    font-weight: 500;
    color: #199FCB;
}

.ki-team-card__text {
    font-size: clamp(1.05rem, 1.3vw, 1.45rem);
    line-height: 1.7;
    color: #d0d8e4;
}

/* About */

.ki-about {
    padding: 90px 0;
    background: #000;
}

.ki-about__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 70px;
    align-items: start;
}

.ki-about__left {
    padding-top: 8px;
}

.ki-about__headline {
    margin: 0 0 28px;
    font-size: clamp(2.2rem, 4vw, 4.1rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-about__headline-normal {
    color: #f1f5f9;
    margin-right: 10px;
}

.ki-about__headline-highlight {
    color: #199FCB;
}

.ki-about__text {
    max-width: 100%;
    font-size: clamp(1.2rem, 1.65vw, 1.95rem);
    line-height: 1.7;
    color: #d1d8e3;
}

.ki-about__buttonwrap {
    margin-top: 48px;
}

.ki-about__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 340px;
    padding: 18px 36px;
    border-radius: 24px;
    background: linear-gradient(90deg, #1ea7d7 0%, #199fcb 100%);
    color: #fff;
    font-size: 1.15rem;
    line-height: 1.2;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 14px 34px rgba(25, 159, 203, 0.22);
    transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease;
}

.ki-about__button:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 40px rgba(25, 159, 203, 0.28);
    color: #fff;
    text-decoration: none;
}

.ki-about__right {
    display: grid;
    gap: 26px;
}

.ki-about__box {
    padding: 34px 30px;
    border-radius: 16px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
}

.ki-about__box-title {
    margin: 0 0 18px;
    font-size: clamp(1.45rem, 1.8vw, 2rem);
    line-height: 1.2;
    font-weight: 700;
    color: #199FCB;
}

.ki-about__box-text {
    font-size: clamp(1.08rem, 1.35vw, 1.55rem);
    line-height: 1.65;
    color: #d1d8e3;
}

/* CTA Banner */

.ki-cta-banner {
    padding: 70px 0 90px;
    background: #000;
}

.ki-cta-banner__panel {
    position: relative;
    overflow: hidden;
    border-radius: 22px;
    background: linear-gradient(180deg, #2d4677 0%, #091325 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-cta-banner__overlay {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(25, 159, 203, 0.08) 0%, rgba(25, 159, 203, 0) 55%);
    pointer-events: none;
}

.ki-cta-banner__content {
    position: relative;
    z-index: 2;
    max-width: 1100px;
    margin: 0 auto;
    padding: 68px 32px 62px;
    text-align: center;
}

.ki-cta-banner__headline {
    margin: 0;
    font-size: clamp(2.1rem, 4vw, 3.8rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-cta-banner__headline-normal {
    color: #f1f5f9;
}

.ki-cta-banner__headline-highlight {
    color: #199FCB;
}

.ki-cta-banner__text {
    max-width: 980px;
    margin: 28px auto 0;
    font-size: clamp(1.05rem, 1.55vw, 1.45rem);
    line-height: 1.65;
    color: #cbd5e1;
}

.ki-cta-banner__actions {
    margin-top: 36px;
    display: flex;
    justify-content: center;
}

.ki-cta-banner__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 380px;
    min-height: 56px;
    padding: 0 34px;
    border-radius: 22px;
    background: linear-gradient(90deg, #1ea7d7 0%, #199fcb 100%);
    color: #ffffff;
    font-size: 1.05rem;
    line-height: 1;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 14px 34px rgba(25, 159, 203, 0.22);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.ki-cta-banner__button:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 40px rgba(25, 159, 203, 0.28);
    color: #ffffff;
    text-decoration: none;
}

/* Page Hero */

.ki-page-hero {
    padding: 48px 0 64px;
    background: transparent;
}

.ki-page-hero__inner {
    max-width: 980px;
    margin: 0 auto;
    text-align: center;
}

.ki-page-hero__headline {
    margin: 0;
    font-size: clamp(2.2rem, 5vw, 4.4rem);
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: -0.02em;
    background: linear-gradient(to right, #ffffff, #cbd5e1);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.ki-page-hero__text {
    margin: 22px auto 0;
    max-width: 860px;
    font-size: clamp(1.05rem, 1.8vw, 1.55rem);
    line-height: 1.55;
    color: #94a3b8;
}

/* Datenschutz */

.ki-datenschutz-section {
    padding: 48px 0 80px;
    background: #000000;
}

.ki-datenschutz-intro {
    max-width: min(896px, 100%);
    margin: 0 auto 48px;
    text-align: center;
}

.ki-datenschutz-intro__title {
    margin: 0 0 16px;
    font-size: clamp(2.1rem, 4.5vw, 3.1rem);
    line-height: 1.12;
    font-weight: 800;
    letter-spacing: -0.02em;
    background: linear-gradient(to right, #ffffff, #cbd5e1);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.ki-datenschutz-intro__lead {
    margin: 0;
    font-size: clamp(1.05rem, 1.65vw, 1.25rem);
    line-height: 1.5;
    color: #cbd5e1;
}

.ki-datenschutz-stack {
    max-width: min(896px, 100%);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.ki-datenschutz-card {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    background: linear-gradient(to bottom, #2b4373, #0e1626);
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.32);
}

.ki-datenschutz-card::before {
    content: '';
    pointer-events: none;
    position: absolute;
    inset: 0;
    background: radial-gradient(120% 90% at 10% 10%, rgba(25, 159, 203, 0.08), transparent 52%),
        radial-gradient(100% 90% at 90% 95%, rgba(25, 159, 203, 0.07), transparent 45%);
}

.ki-datenschutz-card__inner {
    position: relative;
    padding: 32px 36px 34px;
}

.ki-datenschutz-card__title {
    margin: 0 0 24px;
    font-size: clamp(1.5rem, 2.2vw, 1.85rem);
    line-height: 1.2;
    font-weight: 700;
    color: #ffffff;
}

.ki-datenschutz-blocks {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.ki-datenschutz-block {
    margin: 0;
}

.ki-datenschutz-block__subtitle {
    margin: 0 0 14px;
    font-size: clamp(1.18rem, 1.5vw, 1.35rem);
    font-weight: 600;
    color: #e2e8f0;
}

.ki-datenschutz-block__h4 {
    margin: 0 0 10px;
    font-size: clamp(1.05rem, 1.25vw, 1.15rem);
    font-weight: 600;
    color: #e2e8f0;
}

.ki-datenschutz-block__text {
    margin: 0 0 14px;
    font-size: clamp(0.975rem, 1.2vw, 1.08rem);
    line-height: 1.7;
    color: #cbd5e1;
}

.ki-datenschutz-block__text:last-child {
    margin-bottom: 0;
}

.ki-datenschutz-block__text--tight {
    margin-bottom: 0.5em;
}

.ki-datenschutz-box {
    margin: 14px 0 18px;
    padding: 16px 18px;
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.45);
    border: 1px solid rgba(148, 163, 184, 0.22);
}

.ki-datenschutz-list {
    margin: 0 0 16px;
    padding-left: 1.35rem;
    font-size: clamp(0.975rem, 1.2vw, 1.06rem);
    line-height: 1.65;
    color: #cbd5e1;
}

.ki-datenschutz-list li + li {
    margin-top: 0.5rem;
}

.ki-datenschutz-link {
    color: var(--ki-accent);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.ki-datenschutz-link:hover {
    color: #5ec8ee;
}

.ki-datenschutz-quelle {
    max-width: min(896px, 100%);
    margin: 8px auto 0;
    padding: 16px 36px 14px;
    border-radius: 18px;
    background: linear-gradient(to bottom, rgba(43, 67, 115, 0.45), rgba(14, 22, 38, 0.75));
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.ki-datenschutz-quelle__text {
    margin: 0;
    font-size: 0.875rem;
    color: #94a3b8;
}

.ki-datenschutz-actions {
    margin: 40px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.ki-datenschutz-fallback {
    max-width: min(896px, 100%);
    margin: 0 auto;
    padding: 20px;
    border-radius: 12px;
    background: rgba(127, 29, 29, 0.12);
    border: 1px solid rgba(248, 113, 113, 0.35);
    color: #fecaca;
}

@media (max-width: 576px) {
    .ki-datenschutz-card__inner {
        padding: 24px 22px 26px;
    }

    .ki-datenschutz-intro {
        margin-bottom: 36px;
    }
}

/* Impressum */

.ki-impressum-section {
    padding: 48px 0 80px;
    background: #000000;
}

.ki-impressum {
    max-width: 720px;
    margin: 0 auto;
    padding: 42px 40px 40px;
    border-radius: 20px;
    background: rgba(17, 17, 17, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.09);
    box-shadow: 0 28px 64px rgba(0, 0, 0, 0.45);
    box-sizing: border-box;
}

.ki-impressum__title {
    margin: 0 0 28px;
    font-size: clamp(2rem, 4vw, 2.75rem);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #ffffff;
}

.ki-impressum__address {
    margin: 0 0 32px;
    font-size: clamp(1rem, 1.35vw, 1.125rem);
    line-height: 1.65;
    font-style: normal;
    color: #f1f5f9;
}

.ki-impressum__block {
    margin-top: 28px;
}

.ki-impressum__subhead {
    margin: 0 0 14px;
    font-size: clamp(1.05rem, 1.35vw, 1.25rem);
    font-weight: 700;
    line-height: 1.35;
    color: #ffffff;
}

.ki-impressum__line {
    margin: 8px 0 0;
    font-size: clamp(1rem, 1.3vw, 1.08rem);
    line-height: 1.65;
    color: #e2e8f0;
}

.ki-impressum__line span:first-child {
    margin-right: 0.35em;
    color: #cbd5e1;
}

.ki-impressum__body {
    margin: 0;
    font-size: clamp(1rem, 1.3vw, 1.08rem);
    line-height: 1.65;
    color: #e2e8f0;
}

.ki-impressum__link {
    color: var(--ki-accent);
    text-decoration: none;
    font-weight: 600;
}

.ki-impressum__link:hover {
    text-decoration: underline;
    color: #5ec8ee;
}

.ki-impressum__footer {
    margin-top: 36px;
}

.ki-impressum__rule {
    margin: 0 0 18px;
    border: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.ki-impressum__source {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.55;
    color: #94a3b8;
}

.ki-impressum__source span {
    margin-right: 0.35em;
}

.ki-impressum__back {
    margin: 36px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media (max-width: 576px) {
    .ki-impressum {
        padding: 32px 22px 28px;
    }
}

/* Booking */

.ki-booking-section {
    padding: 48px 0 80px;
    background: rgba(0, 0, 0, 0.2);
}

.ki-booking-card {
    max-width: 1100px;
    margin: 0 auto;
    border-radius: 20px;
    background: linear-gradient(to bottom, #2b4373, #0e1626);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.28);
}

.ki-booking-card__content {
    padding: 28px 24px 30px;
}

.ki-booking-card__icon {
    width: 52px;
    height: 52px;
    margin: 0 auto 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(25, 159, 203, 0.16);
    color: #199FCB;
}

.ki-booking-card__icon svg {
    width: 26px;
    height: 26px;
}

.ki-booking-card__headline {
    margin: 0;
    text-align: center;
    font-size: clamp(1.3rem, 2vw, 1.9rem);
    line-height: 1.2;
    font-weight: 700;
    color: #e5e7eb;
}

.ki-booking-card__subline {
    margin: 14px auto 24px;
    max-width: 760px;
    text-align: center;
    font-size: clamp(1rem, 1.35vw, 1.12rem);
    line-height: 1.6;
    color: #cbd5e1;
}

.ki-booking-card__embed {
    border-radius: 16px;
    overflow: hidden;
}

.ki-booking-card__embed iframe {
    display: block;
    width: 100%;
    border: 0;
    background: #ffffff;
}

.ki-booking-card__placeholder {
    min-height: 420px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 28px;
    text-align: center;
    border-radius: 16px;
    background: rgba(0, 0, 0, 0.18);
    border: 1px dashed rgba(255, 255, 255, 0.18);
    color: #cbd5e1;
}

.ki-booking-card__placeholder p {
    margin: 6px 0;
}

/* Contact Cards */

.ki-contact-cards-section {
    padding: 48px 0 72px;
    background: rgba(0, 0, 0, 0.2);
}

.ki-contact-cards-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 32px;
    max-width: 1100px;
    margin: 0 auto;
}

.ki-contact-card {
    display: block;
    border-radius: 18px;
    background: linear-gradient(to bottom, #2b4373, #0e1626);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.28);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.ki-contact-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 24px 50px rgba(25, 159, 203, 0.12);
    border-color: rgba(25, 159, 203, 0.32);
}

.ki-contact-card__content {
    padding: 26px 24px;
    text-align: center;
}

.ki-contact-card__icon {
    width: 48px;
    height: 48px;
    margin: 0 auto 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(25, 159, 203, 0.16);
    color: #199FCB;
}

.ki-contact-card__icon svg {
    width: 24px;
    height: 24px;
}

.ki-contact-card__title {
    margin: 0 0 10px;
    font-size: clamp(1.2rem, 1.8vw, 1.5rem);
    line-height: 1.2;
    font-weight: 700;
    color: #e5e7eb;
}

.ki-contact-card__text {
    margin: 0;
    font-size: clamp(0.98rem, 1.2vw, 1.08rem);
    line-height: 1.5;
    color: #94a3b8;
    word-break: break-word;
}

/* About Teaser */

.ki-about-teaser-section {
    padding: 48px 0 80px;
    background: transparent;
}

.ki-about-teaser {
    max-width: 1200px;
    margin: 0 auto;
    padding: 42px 28px 44px;
    text-align: center;
    border-radius: 24px;
    background: linear-gradient(to bottom, #2b4373, #0e1626);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.28);
}

.ki-about-teaser__headline {
    margin: 0;
    font-size: clamp(2rem, 4vw, 4rem);
    line-height: 1.12;
    font-weight: 800;
    color: #e5e7eb;
}

.ki-about-teaser__text {
    max-width: 920px;
    margin: 22px auto 0;
    font-size: clamp(1rem, 1.5vw, 1.35rem);
    line-height: 1.65;
    color: #94a3b8;
}

.ki-about-teaser__actions {
    margin-top: 30px;
    display: flex;
    justify-content: center;
}

.ki-about-teaser__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 32px;
    border-radius: 20px;
    background: linear-gradient(to right, #199FCB, #1a8fb8, #199FCB);
    border: 1px solid rgba(25, 159, 203, 0.3);
    box-shadow: 0 22px 40px rgba(25, 159, 203, 0.2);
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    text-decoration: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.ki-about-teaser__button:hover {
    transform: translateY(-1px) scale(1.02);
    box-shadow: 0 22px 40px rgba(25, 159, 203, 0.28);
    color: #fff;
    text-decoration: none;
}

/* Leistungs-Boxen untereinander */

.ki-leistungs-boxes {
    padding: 48px 0 80px;
    background: rgba(0, 0, 0, 0.18);
}

.ki-leistungs-boxes__intro {
    max-width: 1200px;
    margin: 0 auto 56px;
    text-align: center;
}

.ki-leistungs-boxes__headline {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-leistungs-boxes__text {
    margin: 28px auto 0;
    max-width: 1080px;
    font-size: clamp(1rem, 1.4vw, 1.2rem);
    line-height: 1.65;
    color: #cbd5e1;
}

.ki-leistungs-boxes__list {
    width: 100%;
    max-width: none;
    margin: 0 auto;
    display: grid;
    gap: 39px;
}

.ki-leistungs-boxes__item {
    padding: 34px 30px;
    border-radius: 18px;
    background: var(--ki-tile-gradient);
    border: 1px solid var(--ki-tile-border);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03), 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-leistungs-boxes__item-title {
    margin: 0 0 16px;
    font-size: clamp(1.35rem, 1.8vw, 1.9rem);
    line-height: 1.2;
    font-weight: 700;
    color: #ffffff;
}

.ki-leistungs-boxes__item-text {
    font-size: clamp(1rem, 1.2vw, 1.12rem);
    line-height: 1.7;
    color: #d1d8e3;
}

.ki-leistungs-boxes__item-actions {
    margin-top: 22px;
}

.ki-leistungs-boxes__item-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 20px;
    border-radius: 16px;
    background: linear-gradient(to right, #199FCB, #1a8fb8);
    color: #ffffff;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    border: 1px solid rgba(25, 159, 203, 0.28);
    box-shadow: 0 10px 24px rgba(25, 159, 203, 0.14);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.ki-leistungs-boxes__item-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(25, 159, 203, 0.2);
    border-color: rgba(25, 159, 203, 0.4);
    color: #ffffff;
    text-decoration: none;
}

/* Footer */

.ki-footer {
    background: #000000;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 56px;
    padding-bottom: 28px;
}

.ki-footer__inner {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 32px;
}

.ki-footer__logo {
    height: 42px;
    width: auto;
    margin-bottom: 18px;
}

.ki-footer__text,
.ki-footer__contact a,
.ki-footer__col ul a,
.ki-footer__bottom,
.ki-footer__bottom nav a {
    color: var(--ki-text-soft);
}

.ki-footer__contact a {
    display: block;
    margin-top: 8px;
}

.ki-footer__col h3 {
    margin-top: 0;
    margin-bottom: 14px;
    color: var(--ki-text);
    font-size: 18px;
}

.ki-footer__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ki-footer__col li + li {
    margin-top: 10px;
}

.ki-footer__bottom {
    margin-top: 40px;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    font-size: 14px;
}

.ki-footer__bottom nav {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
}

/* Responsive */

@media (max-width: 1200px) {
    .ki-header__inner {
        grid-template-columns: 240px 1fr auto;
    }

    .ki-nav__list {
        gap: 20px;
    }

    .ki-funding {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .ki-funding__content {
        max-width: none;
    }

    .ki-funding__facts {
        gap: 22px;
    }

    .ki-problems-grid {
        gap: 26px;
    }

    .ki-problem-card {
        min-height: 320px;
        padding: 42px 24px 32px;
    }
}

@media (max-width: 1199px) {
    .ki-about__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .ki-about__text {
        max-width: none;
    }

    .ki-about__right {
        max-width: 100%;
    }
}

@media (max-width: 992px) {
    .ki-container,
    .ki-header__inner,
    .ki-footer__inner,
    .ki-footer__bottom,
    .ki-team .container,
    .ki-about .container {
        padding-left: 20px;
        padding-right: 20px;
    }

    .ki-header__inner {
        min-height: 80px;
        grid-template-columns: 1fr auto;
    }

    .ki-nav--desktop,
    .ki-header__cta {
        display: none;
    }

    .ki-burger {
        display: block;
    }

    .ki-header__logo {
        height: 40px;
    }

    .ki-hero-section {
        padding: 32px 0 60px;
    }

    .ki-hero__lead {
        margin-top: 22px;
    }

    .ki-hero__actions {
        margin-top: 28px;
        gap: 16px;
    }

    .ki-hero__visual {
        margin-top: 48px;
    }

    .ki-problems-section {
        padding: 36px 0 60px;
    }

    .ki-problems__intro {
        margin-bottom: 40px;
    }

    .ki-problems-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .ki-problem-card {
        min-height: 0;
    }

    .ki-midtext-section {
        padding: 4px 0 52px;
    }

    .ki-midtext__text {
        margin-top: 18px;
    }

    .ki-funding-section {
        padding: 42px 0 64px;
    }

    .ki-funding-card {
        min-height: 110px;
        padding: 24px 22px;
    }

    .ki-funding-card__title {
        font-size: clamp(1.2rem, 1.7vw, 1.6rem);
    }

    .ki-team {
        padding: 70px 0;
    }

    .ki-team__grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .ki-team-card {
        padding: 38px 24px 28px;
    }

    .ki-team-card__iconwrap,
    .ki-team-card__photo {
        width: 160px;
        height: 160px;
    }

    .ki-team-card__icon {
        width: 62px;
        height: 62px;
    }

    .ki-cta-banner {
        padding: 56px 0 72px;
    }

    .ki-cta-banner__content {
        padding: 54px 24px 50px;
    }

    .ki-cta-banner__text {
        margin-top: 22px;
    }

    .ki-cta-banner__actions {
        margin-top: 30px;
    }

    .ki-page-hero {
        padding: 40px 0 56px;
    }

    .ki-page-hero__text {
        margin-top: 18px;
    }

    .ki-booking-section {
        padding: 40px 0 64px;
    }

    .ki-booking-card__content {
        padding: 24px 18px 22px;
    }

    .ki-contact-cards-section {
        padding: 40px 0 60px;
    }

    .ki-contact-cards-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .ki-about-teaser-section {
        padding: 40px 0 64px;
    }

    .ki-about-teaser {
        padding: 32px 22px 34px;
    }

    .ki-leistungs-boxes {
        padding: 40px 0 64px;
    }

    .ki-leistungs-boxes__intro {
        margin-bottom: 40px;
    }

    .ki-leistungs-boxes__list {
        gap: 33px;
    }

    .ki-leistungs-boxes__item {
        padding: 26px 22px;
    }

    .ki-footer__inner {
        grid-template-columns: 1fr;
    }

    .ki-footer__bottom {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767px) {
    .ki-about {
        padding: 70px 0;
    }

    .ki-about__button {
        width: 100%;
        min-width: 0;
        padding: 16px 24px;
        border-radius: 20px;
        font-size: 1.05rem;
    }

    .ki-about__box {
        padding: 24px 20px;
        border-radius: 14px;
    }
}

@media (max-width: 575px) {
    .ki-container,
    .ki-header__inner,
    .ki-footer__inner,
    .ki-footer__bottom,
    .ki-team .container,
    .ki-about .container {
        padding-left: 16px;
        padding-right: 16px;
    }

    .ki-header__inner {
        min-height: 64px;
    }

    .ki-header__logo {
        height: 32px;
    }

    .ki-hero__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .ki-btn--hero-primary,
    .ki-btn--hero-secondary {
        width: 100%;
        min-height: 54px;
    }

    .ki-hero__visual {
        margin-top: 36px;
    }

    .ki-funding-card {
        gap: 16px;
    }

    .ki-funding-card__icon {
        width: 56px;
        height: 56px;
        flex: 0 0 56px;
    }

    .ki-team__intro {
        margin-bottom: 36px;
    }

    .ki-team-card {
        border-radius: 16px;
    }

    .ki-cta-banner__panel {
        border-radius: 18px;
    }

    .ki-cta-banner__content {
        padding: 40px 18px 36px;
    }

    .ki-cta-banner__button {
        width: 100%;
        min-width: 0;
        min-height: 52px;
        padding: 0 22px;
        border-radius: 18px;
    }

    .ki-page-hero {
        padding: 32px 0 44px;
    }

    .ki-booking-card {
        border-radius: 16px;
    }

    .ki-booking-card__embed {
        border-radius: 12px;
    }

    .ki-contact-card {
        border-radius: 16px;
    }

    .ki-contact-card__content {
        padding: 22px 18px;
    }

    .ki-about-teaser {
        padding: 26px 16px 28px;
        border-radius: 18px;
    }

    .ki-about-teaser__button {
        width: 100%;
        min-height: 52px;
        padding: 0 22px;
        border-radius: 18px;
    }

    .ki-leistungs-boxes__item {
        padding: 22px 18px;
        border-radius: 16px;
    }
}

.ki-service-hero {
    padding: 56px 0 90px;
    background: #000;
}

.ki-service-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(420px, 0.85fr);
    gap: 72px;
    align-items: center;
}

.ki-service-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(4, 10, 20, 0.5);
    color: #dbe3ee;
    font-size: 0.95rem;
    font-weight: 600;
}

.ki-service-hero__eyebrow-icon {
    color: #199FCB;
    line-height: 1;
}

.ki-service-hero__headline {
    margin: 34px 0 0;
    font-size: clamp(2.7rem, 5.3vw, 5.2rem);
    line-height: 1.08;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: #f3f6fb;
}

.ki-service-hero__text {
    margin-top: 34px;
    max-width: 1120px;
    font-size: clamp(1.12rem, 1.6vw, 1.35rem);
    line-height: 1.65;
    color: #c3cfdd;
}

.ki-service-hero__actions {
    margin-top: 34px;
}

.ki-service-hero__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    padding: 0 32px;
    border-radius: 22px;
    background: linear-gradient(to right, #199FCB, #1a8fb8, #199FCB);
    color: #fff;
    font-size: 1.05rem;
    font-weight: 700;
    text-decoration: none;
    border: 1px solid rgba(25, 159, 203, 0.3);
    box-shadow: 0 18px 36px rgba(25, 159, 203, 0.18);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.ki-service-hero__button:hover {
    transform: translateY(-1px);
    box-shadow: 0 22px 40px rgba(25, 159, 203, 0.24);
    color: #fff;
    text-decoration: none;
}

.ki-service-hero__badges {
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
}

.ki-service-hero__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 0 22px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(4, 10, 20, 0.45);
    color: #d8e0ea;
    font-size: 0.98rem;
    line-height: 1.2;
}

.ki-service-hero__panel {
    padding: 34px 32px 32px;
    border-radius: 22px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-service-hero__panel-eyebrow {
    font-size: 0.95rem;
    font-weight: 700;
    color: #199FCB;
}

.ki-service-hero__panel-headline {
    margin: 18px 0 0;
    font-size: clamp(2rem, 2.4vw, 3rem);
    line-height: 1.15;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-service-hero__panel-text {
    margin-top: 24px;
    font-size: clamp(1.05rem, 1.3vw, 1.25rem);
    line-height: 1.65;
    color: #d2dbea;
}

.ki-service-hero__benefit {
    margin-top: 22px;
    padding: 18px 20px;
    border-radius: 18px;
    background: linear-gradient(to right, rgba(8, 18, 38, 0.95), rgba(7, 16, 34, 0.92));
    border: 1px solid rgba(255, 255, 255, 0.04);
    color: #d6deea;
    font-size: 1.02rem;
    line-height: 1.5;
}

.ki-service-hero__benefit strong {
    color: #ffffff;
    font-weight: 800;
}

@media (max-width: 1200px) {
    .ki-service-hero__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}

@media (max-width: 992px) {
    .ki-service-hero {
        padding: 44px 0 70px;
    }

    .ki-service-hero__headline {
        margin-top: 24px;
    }

    .ki-service-hero__text {
        margin-top: 24px;
    }

    .ki-service-hero__badges {
        margin-top: 36px;
    }

    .ki-service-hero__panel {
        padding: 28px 24px 24px;
    }
}

@media (max-width: 575px) {
    .ki-service-hero__button {
        width: 100%;
        min-height: 54px;
    }

    .ki-service-hero__badges {
        gap: 12px;
    }

    .ki-service-hero__badge {
        width: 100%;
        justify-content: center;
        padding: 12px 16px;
        min-height: 0;
    }

    .ki-service-hero__panel {
        border-radius: 18px;
        padding: 24px 18px 18px;
    }

    .ki-service-hero__benefit {
        border-radius: 14px;
        padding: 16px 16px;
    }
}

.ki-flow-cards {
    padding: 48px 0 88px;
    background: #000;
}

.ki-flow-cards__headline {
    margin: 0 0 42px;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f3f6fb;
}

.ki-flow-cards__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 42px 40px;
    align-items: start;
}

.ki-flow-cards__item {
    min-height: 188px;
    padding: 30px 30px 28px;
    border-radius: 22px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-flow-cards__head {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 22px;
}

.ki-flow-cards__icon {
    width: 28px;
    height: 28px;
    color: #199FCB;
    flex: 0 0 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ki-flow-cards__icon svg {
    width: 28px;
    height: 28px;
}

.ki-flow-cards__title {
    margin: 0;
    font-size: clamp(1.45rem, 1.7vw, 2rem);
    line-height: 1.2;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-flow-cards__text {
    font-size: clamp(1.02rem, 1.2vw, 1.2rem);
    line-height: 1.65;
    color: #d0d8e4;
}

@media (max-width: 1200px) {
    .ki-flow-cards__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .ki-flow-cards {
        padding: 40px 0 64px;
    }

    .ki-flow-cards__headline {
        margin-bottom: 28px;
    }

    .ki-flow-cards__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .ki-flow-cards__item {
        min-height: 0;
        padding: 24px 20px 22px;
        border-radius: 18px;
    }
}

.ki-flow-mini {
    background: #000;
}

.ki-flow-mini--with-headline {
    padding: 48px 0 0;
}

.ki-flow-mini--compact {
    padding: 34px 0 0;
}

.ki-flow-mini__headline {
    margin: 0 0 34px;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f3f6fb;
}

.ki-flow-mini__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 34px 34px;
    align-items: start;
}

.ki-flow-mini__item {
    min-height: 188px;
    padding: 30px 30px 28px;
    border-radius: 22px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-flow-mini__head {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 22px;
}

.ki-flow-mini__icon {
    width: 28px;
    height: 28px;
    color: #199FCB;
    flex: 0 0 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ki-flow-mini__icon svg {
    width: 28px;
    height: 28px;
}

.ki-flow-mini__title {
    margin: 0;
    font-size: clamp(1.45rem, 1.7vw, 2rem);
    line-height: 1.2;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-flow-mini__text {
    font-size: clamp(1.02rem, 1.2vw, 1.2rem);
    line-height: 1.65;
    color: #d0d8e4;
}

@media (max-width: 1200px) {
    .ki-flow-mini__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .ki-flow-mini--with-headline {
        padding: 40px 0 0;
    }

    .ki-flow-mini--compact {
        padding: 24px 0 0;
    }

    .ki-flow-mini__headline {
        margin-bottom: 24px;
    }

    .ki-flow-mini__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .ki-flow-mini__item {
        min-height: 0;
        padding: 24px 20px 22px;
        border-radius: 18px;
    }
}

.ki-benefits-list {
    padding: 56px 0 88px;
    background: #000;
}

.ki-benefits-list__headline {
    margin: 0 0 40px;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f3f6fb;
}

.ki-benefits-list__items {
    display: grid;
    gap: 34px;
}

.ki-benefits-list__item {
    display: flex;
    align-items: center;
    gap: 22px;
    min-height: 98px;
    padding: 24px 30px;
    border-radius: 22px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-benefits-list__check {
    flex: 0 0 auto;
    font-size: 1.25rem;
    line-height: 1;
    color: #1eb2df;
}

.ki-benefits-list__text {
    font-size: clamp(1.08rem, 1.25vw, 1.4rem);
    line-height: 1.55;
    color: #d3dceb;
}

.ki-benefits-list__text strong {
    color: #ffffff;
    font-weight: 800;
}

@media (max-width: 767px) {
    .ki-benefits-list {
        padding: 44px 0 64px;
    }

    .ki-benefits-list__headline {
        margin-bottom: 28px;
    }

    .ki-benefits-list__items {
        gap: 22px;
    }

    .ki-benefits-list__item {
        align-items: flex-start;
        min-height: 0;
        padding: 20px 18px;
        border-radius: 18px;
        gap: 14px;
    }

    .ki-benefits-list__text {
        font-size: 1rem;
    }
}

.ki-savings-calculator {
    padding: 56px 0 88px;
    background: #000;
}

.ki-savings-calculator__panel {
    padding: 44px 46px 48px;
    border-radius: 26px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-savings-calculator__headline {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.5rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f3f6fb;
}

.ki-savings-calculator__intro {
    margin-top: 18px;
    font-size: clamp(1rem, 1.3vw, 1.22rem);
    line-height: 1.6;
    color: #d0d8e4;
}

.ki-savings-calculator__grid {
    margin-top: 36px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 0.95fr);
    gap: 36px;
    align-items: start;
}

.ki-savings-calculator__form {
    display: grid;
    gap: 26px;
}

.ki-savings-calculator__field label {
    display: block;
    margin-bottom: 10px;
    font-size: 1rem;
    font-weight: 500;
    color: #dbe4ef;
}

.ki-savings-calculator__field input {
    width: 100%;
    min-height: 58px;
    padding: 14px 18px;
    border-radius: 18px;
    border: 1px solid rgba(18, 185, 240, 0.18);
    background: rgba(4, 10, 20, 0.88);
    color: #f3f6fb;
    font-size: 1.05rem;
    outline: none;
}

.ki-savings-calculator__field input:focus {
    border-color: rgba(30, 178, 223, 0.65);
    box-shadow: 0 0 0 2px rgba(30, 178, 223, 0.12);
}

.ki-savings-calculator__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 60px;
    padding: 0 28px;
    border-radius: 18px;
    border: 1px solid rgba(30, 178, 223, 0.75);
    background: linear-gradient(to right, rgba(7, 18, 37, 0.95), rgba(10, 24, 50, 0.95));
    color: #1eb2df;
    font-size: 1.05rem;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ki-savings-calculator__button:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(30, 178, 223, 0.12);
}

.ki-savings-calculator__results {
    min-height: 100%;
    padding: 30px 28px;
    border-radius: 22px;
    background: linear-gradient(to bottom, rgba(8, 18, 38, 0.96), rgba(7, 16, 34, 0.96));
    border: 1px solid rgba(30, 178, 223, 0.22);
}

.ki-savings-calculator__result-block + .ki-savings-calculator__result-block {
    margin-top: 28px;
}

.ki-savings-calculator__result-label {
    font-size: clamp(1.15rem, 1.4vw, 1.45rem);
    line-height: 1.4;
    font-weight: 700;
    color: #f3f6fb;
}

.ki-savings-calculator__result-value {
    margin-top: 14px;
    font-size: clamp(1.8rem, 2.6vw, 2.7rem);
    line-height: 1.1;
    font-weight: 800;
    color: #1eb2df;
}

.ki-savings-calculator__hint {
    margin-top: 34px;
    font-size: 0.98rem;
    line-height: 1.6;
    color: #a8b6c9;
}

@media (max-width: 992px) {
    .ki-savings-calculator {
        padding: 44px 0 64px;
    }

    .ki-savings-calculator__panel {
        padding: 30px 22px 32px;
        border-radius: 20px;
    }

    .ki-savings-calculator__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .ki-savings-calculator__results {
        padding: 24px 20px;
        border-radius: 18px;
    }
}

.ki-service-hero-simple {
    padding: 56px 0 88px;
    background: #000;
}

.ki-service-hero-simple__inner {
    max-width: 1220px;
}

.ki-service-hero-simple__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(4, 10, 20, 0.5);
    color: #dbe3ee;
    font-size: 0.95rem;
    font-weight: 600;
}

.ki-service-hero-simple__eyebrow-icon {
    color: #199FCB;
    line-height: 1;
}

.ki-service-hero-simple__headline {
    margin: 34px 0 0;
    max-width: 1100px;
    font-size: clamp(2.7rem, 5.6vw, 5.4rem);
    line-height: 1.08;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: #f3f6fb;
}

.ki-service-hero-simple__text {
    margin-top: 34px;
    max-width: 1180px;
    font-size: clamp(1.12rem, 1.6vw, 1.35rem);
    line-height: 1.65;
    color: #c3cfdd;
}

@media (max-width: 992px) {
    .ki-service-hero-simple {
        padding: 44px 0 70px;
    }

    .ki-service-hero-simple__headline {
        margin-top: 24px;
    }

    .ki-service-hero-simple__text {
        margin-top: 24px;
    }
}

@media (max-width: 575px) {
    .ki-service-hero-simple__headline {
        font-size: clamp(2.2rem, 10vw, 3.5rem);
    }

    .ki-service-hero-simple__text {
        font-size: 1.02rem;
    }
}

.ki-price-overview {
    padding: 56px 0 88px;
    background: #000;
}

.ki-price-overview__headline {
    margin: 0 0 42px;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.12;
    font-weight: 800;
    color: #f3f6fb;
}

.ki-price-overview__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 38px;
}

.ki-price-overview__card {
    min-height: 100%;
    padding: 30px 30px 26px;
    border-radius: 24px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-price-overview__card-title {
    margin: 0 0 28px;
    font-size: clamp(1.55rem, 1.8vw, 2.1rem);
    line-height: 1.2;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-price-overview__rows {
    display: grid;
    gap: 0;
}

.ki-price-overview__row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 20px;
    align-items: center;
    padding: 26px 0;
    border-top: 1px dashed rgba(255, 255, 255, 0.08);
}

.ki-price-overview__row:first-child {
    border-top: 0;
    padding-top: 8px;
}

.ki-price-overview__label {
    font-size: clamp(1.08rem, 1.2vw, 1.3rem);
    line-height: 1.5;
    color: #d0d8e4;
}

.ki-price-overview__price {
    text-align: right;
    white-space: nowrap;
    font-size: clamp(1.2rem, 1.4vw, 1.5rem);
    line-height: 1.2;
    font-weight: 800;
    color: #f3f6fb;
}

@media (max-width: 992px) {
    .ki-price-overview {
        padding: 44px 0 64px;
    }

    .ki-price-overview__headline {
        margin-bottom: 28px;
    }

    .ki-price-overview__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .ki-price-overview__card {
        padding: 24px 20px 20px;
        border-radius: 18px;
    }

    .ki-price-overview__card-title {
        margin-bottom: 18px;
    }

    .ki-price-overview__row {
        padding: 20px 0;
        gap: 14px;
    }
}

@media (max-width: 575px) {
    .ki-price-overview__row {
        grid-template-columns: 1fr;
    }

    .ki-price-overview__price {
        text-align: left;
    }
}

.ki-price-single {
    padding: 36px 0 88px;
    background: #000;
}

.ki-price-single__card {
    padding: 30px 34px 26px;
    border-radius: 24px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-price-single__headline {
    margin: 0 0 28px;
    font-size: clamp(1.6rem, 2vw, 2.2rem);
    line-height: 1.2;
    font-weight: 800;
    color: #f1f5f9;
}

.ki-price-single__rows {
    display: grid;
    gap: 0;
}

.ki-price-single__row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 20px;
    align-items: center;
    padding: 26px 0;
    border-top: 1px dashed rgba(255, 255, 255, 0.08);
}

.ki-price-single__row:first-child {
    border-top: 0;
    padding-top: 8px;
}

.ki-price-single__label {
    font-size: clamp(1.08rem, 1.2vw, 1.3rem);
    line-height: 1.5;
    color: #d0d8e4;
}

.ki-price-single__price {
    text-align: right;
    white-space: nowrap;
    font-size: clamp(1.2rem, 1.4vw, 1.5rem);
    line-height: 1.2;
    font-weight: 800;
    color: #1eb2df;
}

@media (max-width: 992px) {
    .ki-price-single {
        padding: 24px 0 64px;
    }

    .ki-price-single__card {
        padding: 24px 20px 20px;
        border-radius: 18px;
    }

    .ki-price-single__headline {
        margin-bottom: 18px;
    }

    .ki-price-single__row {
        padding: 20px 0;
        gap: 14px;
    }
}

@media (max-width: 575px) {
    .ki-price-single__row {
        grid-template-columns: 1fr;
    }

    .ki-price-single__price {
        text-align: left;
    }
}

.ki-maintcalc {
    padding: 36px 0 88px;
    background: #000;
}

.ki-maintcalc__panel {
    padding: 34px 34px 32px;
    border-radius: 26px;
    background: linear-gradient(180deg, #2d4677 0%, #0b1423 100%);
    border: 1px solid rgba(82, 112, 170, 0.35);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.24);
}

.ki-maintcalc__headline {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.8rem);
    line-height: 1.15;
    font-weight: 800;
    color: #f3f6fb;
}

.ki-maintcalc__intro {
    margin-top: 18px;
    font-size: clamp(1rem, 1.25vw, 1.16rem);
    line-height: 1.6;
    color: #d0d8e4;
}

.ki-maintcalc__grid {
    margin-top: 30px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 0.95fr);
    gap: 32px;
    align-items: start;
}

.ki-maintcalc__form {
    display: grid;
    gap: 20px;
}

.ki-maintcalc__field label {
    display: block;
    margin-bottom: 8px;
    font-size: 1rem;
    color: #dbe4ef;
}

.ki-maintcalc__input {
    width: 100%;
    min-height: 56px;
    padding: 14px 18px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(20, 38, 70, 0.78);
    color: #f3f6fb;
    font-size: 1.05rem;
    outline: none;
}

.ki-maintcalc__input:focus {
    border-color: rgba(30, 178, 223, 0.65);
    box-shadow: 0 0 0 2px rgba(30, 178, 223, 0.12);
}

.ki-maintcalc__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 28px;
    border-radius: 16px;
    border: 1px solid rgba(30, 178, 223, 0.8);
    background: linear-gradient(to right, rgba(7, 18, 37, 0.96), rgba(10, 24, 50, 0.96));
    color: #1eb2df;
    font-size: 1.05rem;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ki-maintcalc__button:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(30, 178, 223, 0.12);
}

.ki-maintcalc__results {
    min-height: 100%;
    padding: 28px 26px;
    border-radius: 22px;
    background: linear-gradient(to bottom, rgba(8, 18, 38, 0.96), rgba(7, 16, 34, 0.96));
    border: 1px solid rgba(30, 178, 223, 0.22);
}

.ki-maintcalc__result-block + .ki-maintcalc__result-block {
    margin-top: 26px;
}

.ki-maintcalc__result-label {
    font-size: clamp(1.12rem, 1.35vw, 1.38rem);
    line-height: 1.4;
    font-weight: 700;
    color: #f3f6fb;
}

.ki-maintcalc__result-value {
    margin-top: 12px;
    font-size: clamp(1.7rem, 2.4vw, 2.5rem);
    line-height: 1.1;
    font-weight: 800;
    color: #1eb2df;
}

.ki-maintcalc__hint {
    margin-top: 32px;
    font-size: 0.98rem;
    line-height: 1.6;
    color: #a8b6c9;
}

@media (max-width: 992px) {
    .ki-maintcalc {
        padding: 24px 0 64px;
    }

    .ki-maintcalc__panel {
        padding: 24px 20px 22px;
        border-radius: 18px;
    }

    .ki-maintcalc__grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .ki-maintcalc__results {
        padding: 22px 18px;
        border-radius: 18px;
    }
}

/* ki_cybersecurity: zweispaltig */
.ki-problems-section.ki-cybersecurity {
    background: #06080d;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr) !important;
    gap: 1.75rem !important;
    align-items: start;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid > .ki-cybersecurity-grid__left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
    min-width: 0;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__headline {
    margin: 0;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__actions {
    margin: 0;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid > .ki-cybersecurity-grid__right {
    display: grid;
    gap: 1.05rem;
    min-width: 0;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__panel {
    padding: 1.15rem 1.2rem !important;
    border-radius: 1rem;
    border: 1px solid rgba(51, 130, 200, 0.35);
    background: var(--ki-tile-gradient) !important;
    box-shadow: 0 12px 30px rgba(3, 16, 34, 0.46), inset 0 1px 0 rgba(255, 255, 255, 0.06);
    text-align: left;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__panel-inner {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    height: 62px;
    border-radius: 12px;
    flex: 0 0 62px;
    flex-shrink: 0;
    color: var(--ki-tile-icon-color);
    background: var(--ki-tile-icon-bg);
    border: 1px solid rgba(51, 181, 229, 0.22);
    box-shadow: 0 0 0 1px rgba(10, 24, 39, 0.45), 0 8px 16px rgba(0, 0, 0, 0.35);
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__icon svg {
    display: block;
    width: 38px !important;
    height: 38px !important;
    max-width: none;
    max-height: none;
    flex-shrink: 0;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__panel-content {
    flex: 1 1 auto;
    min-width: 0;
    text-align: left;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__lead {
    margin: 0;
    color: inherit;
    line-height: 1.55;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__list {
    margin: 0;
    padding-left: 1.05rem;
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__list li::marker {
    color: var(--ki-tile-icon-color);
}

.ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__list li + li {
    margin-top: 0.4rem;
}

@media (max-width: 900px) {
    .ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid {
        grid-template-columns: 1fr !important;
        gap: 1.2rem !important;
    }

    .ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid > .ki-cybersecurity-grid__right {
        gap: 0.85rem;
        width: 100%;
    }

    .ki-problems-section.ki-cybersecurity .ki-cybersecurity-grid__panel {
        width: 100%;
    }
}

