/*
 * Keyless Investments – Frontend Stylesheet
 * --------------------------------------------
 * Wird vom Plugin keyless-investments geladen.
 */

/* ============================================================
 *  Tokens
 * ============================================================ */
:root {
	--kni-color-bg: #ffffff;
	--kni-color-surface: #f7f8fa;
	--kni-color-border: #eef0f4;
	--kni-color-text: #0f172a;
	--kni-color-text-muted: #64748b;
	--kni-color-text-soft: #94a3b8;
	--kni-color-primary: #1d6fdc;
	--kni-color-primary-dark: #0c447c;
	--kni-color-primary-soft: #eaf2ff;
}

/* ============================================================
 *  Container
 * ============================================================ */
.kni-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
	box-sizing: border-box;
}

/* ============================================================
 *  Typografie helpers
 * ============================================================ */
.kni-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--kni-color-primary);
	margin: 0 0 12px;
}

/* ============================================================
 *  Buttons
 * ============================================================ */
.kni-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 22px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
}
.kni-btn--primary {
	background: var(--kni-color-primary);
	color: #fff;
}
.kni-btn--primary:hover {
	background: var(--kni-color-primary-dark);
	color: #fff;
	transform: translateY(-1px);
}
.kni-btn--light {
	background: #fff;
	color: var(--kni-color-primary-dark);
}
.kni-btn--light:hover {
	background: #f1f5f9;
	color: var(--kni-color-primary-dark);
}
.kni-btn--block { width: 100%; }

/* ============================================================
 *  Status-Badges
 * ============================================================ */
.kni-badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: #e2e8f0;
	color: #475569;
}
.kni-badge--planned   { background: #fef3c7; color: #92400e; }
.kni-badge--active    { background: #dcfce7; color: #14532d; }
.kni-badge--placed    { background: #e0e7ff; color: #3730a3; }
.kni-badge--completed { background: #f1f5f9; color: #475569; }

/* ============================================================
 *  Overview / card grid
 * ============================================================ */
.kni-archive {
	padding: 48px 0 80px;
	background: var(--kni-color-surface);
}
.kni-archive__header {
	max-width: 760px;
	margin: 0 0 40px;
}
.kni-archive__title {
	font-size: 38px;
	line-height: 1.15;
	margin: 0 0 14px;
	color: var(--kni-color-text);
	font-weight: 600;
}
.kni-archive__intro {
	font-size: 17px;
	line-height: 1.55;
	color: var(--kni-color-text-muted);
	margin: 0;
}

.kni-grid {
	display: grid;
	gap: 24px;
}
.kni-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.kni-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 900px) {
	.kni-grid--cols-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.kni-grid--cols-2, .kni-grid--cols-3 { grid-template-columns: 1fr; }
}

/* ============================================================
 *  Karte
 * ============================================================ */
.kni-card {
	background: #fff;
	border: 1px solid var(--kni-color-border);
	border-radius: 14px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.kni-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(15, 23, 42, 0.10);
	border-color: #dde3ec;
}
.kni-card__media {
	position: relative;
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--kni-color-surface);
}
.kni-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .35s ease;
}
.kni-card:hover .kni-card__media img { transform: scale(1.04); }
.kni-card__media-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #cbd5e1, #94a3b8);
}
.kni-card__media .kni-badge {
	position: absolute;
	top: 14px;
	left: 14px;
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: blur(4px);
}
.kni-card__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 22px 22px 24px;
	flex: 1 1 auto;
}
.kni-card__meta {
	margin: 0;
	font-size: 12px;
	color: var(--kni-color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-weight: 500;
}
.kni-card__dot { margin: 0 6px; color: var(--kni-color-text-soft); }
.kni-card__title {
	font-size: 22px;
	font-weight: 600;
	line-height: 1.2;
	margin: 0;
	color: var(--kni-color-text);
}
.kni-card__title a {
	color: inherit;
	text-decoration: none;
}
.kni-card__title a:hover { color: var(--kni-color-primary); }
.kni-card__subtitle {
	margin: 0;
	font-size: 14px;
	line-height: 1.5;
	color: var(--kni-color-text-muted);
}
.kni-card__stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin: 12px 0 0;
	padding: 14px 0 0;
	border-top: 1px solid var(--kni-color-border);
}
.kni-card__stats div { margin: 0; }
.kni-card__stats dt {
	font-size: 11px;
	color: var(--kni-color-text-soft);
	margin: 0 0 2px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.kni-card__stats dd {
	margin: 0;
	font-size: 15px;
	font-weight: 600;
	color: var(--kni-color-text);
}
.kni-card__more {
	margin-top: 12px;
	font-size: 13px;
	font-weight: 600;
	color: var(--kni-color-primary);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.kni-card__more:hover { color: var(--kni-color-primary-dark); }
.kni-card__more span { transition: transform .15s ease; display: inline-block; }
.kni-card__more:hover span { transform: translateX(3px); }

/* ============================================================
 *  Pagination & Empty
 * ============================================================ */
.kni-pagination {
	margin-top: 40px;
	display: flex;
	justify-content: center;
	gap: 6px;
}
.kni-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 12px;
	border-radius: 8px;
	background: #fff;
	border: 1px solid var(--kni-color-border);
	color: var(--kni-color-text);
	font-weight: 500;
	text-decoration: none;
}
.kni-pagination .page-numbers.current,
.kni-pagination .page-numbers:hover {
	background: var(--kni-color-primary);
	color: #fff;
	border-color: var(--kni-color-primary);
}

.kni-empty {
	padding: 48px 24px;
	text-align: center;
	color: var(--kni-color-text-muted);
	background: #fff;
	border-radius: 12px;
	border: 1px solid var(--kni-color-border);
}

/* ============================================================
 *  CTA-Band (unter Archiv)
 * ============================================================ */
.kni-cta-band {
	margin-top: 56px;
	background: var(--kni-color-primary-dark);
	color: #fff;
	border-radius: 18px;
	padding: 36px 44px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
.kni-cta-band h2 {
	font-size: 26px;
	margin: 0 0 6px;
	color: #fff;
	font-weight: 600;
}
.kni-cta-band p { margin: 0; opacity: 0.85; font-size: 15px; }

/* ============================================================
 *  Hero (Detailseite)
 * ============================================================ */
.kni-single { background: var(--kni-color-surface); }

.kni-hero {
	position: relative;
	overflow: hidden;
	min-height: 460px;
	background-size: cover;
	background-position: center;
	background-color: var(--kni-color-primary-dark);
	color: #fff;
	display: flex;
	align-items: flex-end;
}
.kni-hero--none { min-height: 320px; }

.kni-hero__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}
@media (max-width: 767px) {
	.kni-hero__video { display: none; }
}

.kni-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(12, 68, 124, 0.15) 0%, rgba(12, 68, 124, 0.88) 100%);
	z-index: 1;
}
.kni-hero__inner {
	position: relative;
	z-index: 2;
	padding: 72px 24px 48px;
	max-width: 1200px;
	margin: 0 auto;
	width: 100%;
}
.kni-hero__status { margin: 0 0 16px; }
.kni-hero__title {
	font-size: clamp(28px, 4vw, 44px);
	line-height: 1.1;
	font-weight: 600;
	color: #fff;
	margin: 0 0 8px;
}
.kni-hero__subtitle {
	font-size: clamp(15px, 1.8vw, 18px);
	color: rgba(255, 255, 255, 0.9);
	margin: 0 0 18px;
	max-width: 700px;
	line-height: 1.5;
}
.kni-hero__meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.85);
}
.kni-hero__meta li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.kni-hero__icon {
	display: inline-flex;
	width: 20px;
	height: 20px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.18);
	font-size: 11px;
}

/* ============================================================
 *  Stats unter Hero
 * ============================================================ */
.kni-stats {
	background: #fff;
	border-bottom: 1px solid var(--kni-color-border);
}
.kni-stats__row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
}
.kni-stat {
	padding: 26px 24px;
	border-right: 1px solid var(--kni-color-border);
}
.kni-stat:last-child { border-right: none; }
.kni-stat__label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--kni-color-text-muted);
	font-weight: 500;
	margin-bottom: 8px;
}
.kni-stat__value {
	font-size: 26px;
	font-weight: 600;
	color: var(--kni-color-text);
	line-height: 1.1;
}
.kni-stat__sub {
	font-size: 11px;
	color: var(--kni-color-text-soft);
	margin-top: 4px;
}

@media (max-width: 900px) {
	.kni-stats__row {
		grid-template-columns: repeat(2, 1fr);
	}
	.kni-stat { border-bottom: 1px solid var(--kni-color-border); }
	.kni-stat:nth-child(even) { border-right: none; }
	.kni-stat:nth-child(2n+3):last-child,
	.kni-stat:nth-last-child(1):nth-child(odd) { border-bottom: none; }
}
@media (max-width: 500px) {
	.kni-stats__row { grid-template-columns: 1fr; }
	.kni-stat { border-right: none; border-bottom: 1px solid var(--kni-color-border); }
	.kni-stat:last-child { border-bottom: none; }
}

/* ============================================================
 *  Body (Detailseite)
 * ============================================================ */
.kni-body { padding: 48px 0 80px; }
.kni-body__inner {
	display: grid;
	grid-template-columns: 1fr 340px;
	gap: 40px;
	align-items: start;
}
@media (max-width: 900px) {
	.kni-body__inner { grid-template-columns: 1fr; }
}

/* ============================================================
 *  Sektionen
 * ============================================================ */
.kni-section {
	margin-bottom: 36px;
	background: #fff;
	border-radius: 14px;
	padding: 28px 32px;
	border: 1px solid var(--kni-color-border);
}
.kni-section__title {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--kni-color-text-muted);
	margin: 0 0 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--kni-color-border);
}
.kni-prose p {
	font-size: 16px;
	line-height: 1.65;
	color: #334155;
	margin: 0 0 14px;
}
.kni-prose ul, .kni-prose ol {
	font-size: 16px;
	line-height: 1.65;
	color: #334155;
}

/* ============================================================
 *  Highlights
 * ============================================================ */
.kni-highlights {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}
@media (max-width: 600px) { .kni-highlights { grid-template-columns: 1fr; } }
.kni-highlights li {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	font-size: 15px;
	color: #334155;
	padding: 14px 16px;
	background: var(--kni-color-surface);
	border-radius: 10px;
	line-height: 1.45;
}
.kni-highlights__icon {
	flex: 0 0 36px;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--kni-color-primary-soft);
	color: var(--kni-color-primary-dark);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 700;
}
/* Pseudo icons via data-icon (no icon-font dependency) */
.kni-highlights__icon[data-icon="shield-check"]::before { content: "✓"; }
.kni-highlights__icon[data-icon="trending-up"]::before  { content: "↗"; }
.kni-highlights__icon[data-icon="map-pin"]::before      { content: "◉"; }
.kni-highlights__icon[data-icon="home"]::before         { content: "⌂"; }
.kni-highlights__icon[data-icon="building"]::before     { content: "▮"; }
.kni-highlights__icon[data-icon="beach"]::before        { content: "≈"; }
.kni-highlights__icon[data-icon="certificate"]::before  { content: "❖"; }
.kni-highlights__icon[data-icon="coin"]::before         { content: "€"; }
.kni-highlights__icon[data-icon="key"]::before          { content: "⚿"; }
.kni-highlights__icon[data-icon="calendar"]::before     { content: "▦"; }
.kni-highlights__icon[data-icon="leaf"]::before         { content: "❦"; }
.kni-highlights__icon[data-icon="star"]::before         { content: "★"; }

/* ============================================================
 *  Galerie
 * ============================================================ */
.kni-gallery-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}
@media (max-width: 600px) {
	.kni-gallery-grid { grid-template-columns: repeat(2, 1fr); }
}
.kni-gallery-grid__item {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: 10px;
	background: var(--kni-color-surface);
}
.kni-gallery-grid__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .35s ease;
}
.kni-gallery-grid__item:hover img { transform: scale(1.06); }

/* Lightbox */
.kni-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.94);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 99999;
	padding: 24px;
	opacity: 0;
	transition: opacity .25s ease;
}
.kni-lightbox.is-open { opacity: 1; }
.kni-lightbox img {
	max-width: 100%;
	max-height: 100%;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}
.kni-lightbox__close,
.kni-lightbox__prev,
.kni-lightbox__next {
	position: absolute;
	background: rgba(255, 255, 255, 0.12);
	border: none;
	color: #fff;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	font-size: 22px;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.kni-lightbox__close { top: 24px; right: 24px; }
.kni-lightbox__prev  { left: 24px; top: 50%; transform: translateY(-50%); }
.kni-lightbox__next  { right: 24px; top: 50%; transform: translateY(-50%); }
.kni-lightbox__close:hover,
.kni-lightbox__prev:hover,
.kni-lightbox__next:hover { background: rgba(255, 255, 255, 0.22); }

/* ============================================================
 *  Sidebar (Detailseite)
 * ============================================================ */
.kni-side__title {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--kni-color-text-muted);
	margin: 0 0 14px;
}
.kni-cta-card {
	background: var(--kni-color-primary-dark);
	color: #fff;
	border-radius: 14px;
	padding: 24px;
	margin-bottom: 18px;
}
.kni-cta-card__title {
	font-size: 18px;
	font-weight: 600;
	color: #fff;
	margin: 0 0 8px;
}
.kni-cta-card__text {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.5;
	margin: 0 0 16px;
}

.kni-docs {
	background: #fff;
	border: 1px solid var(--kni-color-border);
	border-radius: 14px;
	padding: 20px 22px;
	margin-bottom: 18px;
}
.kni-docs__list { list-style: none; margin: 0; padding: 0; }
.kni-docs__list li + li { margin-top: 8px; }
.kni-doc {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 1px solid var(--kni-color-border);
	border-radius: 10px;
	font-size: 13px;
	color: #334155;
	text-decoration: none;
	transition: border-color .15s ease, background .15s ease;
}
.kni-doc:hover {
	border-color: var(--kni-color-primary);
	background: var(--kni-color-primary-soft);
}
.kni-doc__icon {
	flex: 0 0 auto;
	background: #dc2626;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.04em;
	padding: 4px 7px;
	border-radius: 4px;
}
.kni-doc__name {
	flex: 1 1 auto;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: var(--kni-color-text);
	font-weight: 500;
}
.kni-doc__size {
	flex: 0 0 auto;
	font-size: 11px;
	color: var(--kni-color-text-soft);
}

.kni-facts {
	background: #fff;
	border: 1px solid var(--kni-color-border);
	border-radius: 14px;
	padding: 20px 22px;
	margin-bottom: 18px;
}
.kni-facts__list { margin: 0; }
.kni-facts__list div {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 8px 0;
	font-size: 13px;
	border-bottom: 1px dashed var(--kni-color-border);
}
.kni-facts__list div:last-child { border-bottom: none; }
.kni-facts__list dt {
	color: var(--kni-color-text-muted);
	margin: 0;
}
.kni-facts__list dd {
	color: var(--kni-color-text);
	font-weight: 600;
	margin: 0;
	text-align: right;
}

.kni-disclaimer {
	font-size: 11px;
	line-height: 1.5;
	color: var(--kni-color-text-soft);
	padding: 12px 16px;
	background: var(--kni-color-surface);
	border-radius: 8px;
	margin: 0;
}

/* ============================================================
 *  Section-Modifier
 * ============================================================ */
.kni-section--flush {
	padding: 0;
	background: transparent;
	border: none;
	overflow: hidden;
	border-radius: 14px;
}

/* ============================================================
 *  Slider (above description)
 * ============================================================ */
.kni-slider {
	position: relative;
	background: var(--kni-color-surface);
	border-radius: 14px;
	overflow: hidden;
}
.kni-slider__viewport {
	position: relative;
	aspect-ratio: 16 / 9;
	width: 100%;
}
.kni-slider__slide {
	position: absolute;
	inset: 0;
	display: block;
	opacity: 0;
	transition: opacity .4s ease;
	pointer-events: none;
	cursor: zoom-in;
}
.kni-slider__slide.is-active {
	opacity: 1;
	pointer-events: auto;
	z-index: 1;
}
.kni-slider__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.kni-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.92);
	border: none;
	font-size: 26px;
	font-weight: 600;
	color: var(--kni-color-primary-dark);
	cursor: pointer;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .15s ease, transform .15s ease;
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.kni-slider__nav:hover {
	background: #fff;
	transform: translateY(-50%) scale(1.05);
}
.kni-slider__nav--prev { left: 14px; }
.kni-slider__nav--next { right: 14px; }
.kni-slider__dots {
	position: absolute;
	bottom: 16px;
	left: 0;
	right: 0;
	display: flex;
	justify-content: center;
	gap: 8px;
	z-index: 2;
}
.kni-slider__dots button {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: none;
	background: rgba(255, 255, 255, 0.55);
	cursor: pointer;
	padding: 0;
	transition: background .15s ease, transform .15s ease;
}
.kni-slider__dots button:hover { background: rgba(255, 255, 255, 0.8); }
.kni-slider__dots button.is-active {
	background: #fff;
	transform: scale(1.25);
}
.kni-slider__counter {
	position: absolute;
	top: 14px;
	right: 14px;
	background: rgba(15, 23, 42, 0.55);
	color: #fff;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	z-index: 2;
}
.kni-slider--single .kni-slider__slide { position: relative; opacity: 1; pointer-events: auto; }
.kni-slider--single .kni-slider__viewport { aspect-ratio: auto; }

@media (max-width: 600px) {
	.kni-slider__nav { width: 38px; height: 38px; font-size: 20px; }
	.kni-slider__nav--prev { left: 8px; }
	.kni-slider__nav--next { right: 8px; }
}

/* ============================================================
 *  Investors-Page (Landing)
 * ============================================================ */
.kni-ip { background: var(--kni-color-surface); margin: 0 -24px; }
@media (min-width: 768px) { .kni-ip { margin: 0; } }

.kni-eyebrow--light {
	color: rgba(255, 255, 255, 0.85);
}

.kni-ip-section {
	padding: 72px 0;
}
.kni-ip-section--projects,
.kni-ip-section--services {
	background: #fff;
}
.kni-ip-section--why,
.kni-ip-section--process {
	background: var(--kni-color-surface);
}
.kni-ip-section__title {
	font-size: clamp(26px, 3vw, 36px);
	font-weight: 600;
	margin: 0 0 14px;
	color: var(--kni-color-text);
	line-height: 1.2;
}
.kni-ip-section__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 24px;
	margin-bottom: 36px;
	flex-wrap: wrap;
}
.kni-ip-section__more {
	font-size: 14px;
	font-weight: 600;
	color: var(--kni-color-primary);
	text-decoration: none;
	white-space: nowrap;
}
.kni-ip-section__more:hover { color: var(--kni-color-primary-dark); }

/* Hero */
.kni-ip-hero {
	position: relative;
	min-height: 540px;
	background: linear-gradient(135deg, var(--kni-color-primary-dark) 0%, var(--kni-color-primary) 100%);
	background-size: cover;
	background-position: center;
	color: #fff;
	display: flex;
	align-items: center;
}
.kni-ip-hero--has-bg { background-color: var(--kni-color-primary-dark); }
.kni-ip-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(12, 68, 124, 0.85) 0%, rgba(12, 68, 124, 0.55) 100%);
}
.kni-ip-hero__inner {
	position: relative;
	padding: 96px 24px;
}
.kni-ip-hero__title {
	font-size: clamp(34px, 5vw, 56px);
	font-weight: 600;
	line-height: 1.05;
	color: #fff;
	margin: 12px 0 18px;
	max-width: 800px;
}
.kni-ip-hero__sub {
	font-size: clamp(16px, 1.8vw, 19px);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.9);
	max-width: 680px;
	margin: 0 0 32px;
}
.kni-ip-hero__cta {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}
.kni-btn--ghost-light {
	background: transparent;
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.5);
}
.kni-btn--ghost-light:hover {
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	border-color: #fff;
}

/* Why intro + benefits */
.kni-ip-intro {
	max-width: 820px;
	margin: 0 0 48px;
}
.kni-ip-intro__text {
	font-size: 17px;
	line-height: 1.65;
	color: #334155;
	margin: 14px 0 0;
}
.kni-ip-benefits {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
.kni-ip-benefit {
	background: #fff;
	border: 1px solid var(--kni-color-border);
	border-radius: 14px;
	padding: 28px 24px;
	transition: transform .2s ease, box-shadow .2s ease;
}
.kni-ip-benefit:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
}
.kni-ip-benefit__icon {
	display: inline-flex;
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: var(--kni-color-primary-soft);
	color: var(--kni-color-primary-dark);
	align-items: center;
	justify-content: center;
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 18px;
}
.kni-ip-benefit__icon[data-icon="trending-up"]::before { content: "↗"; }
.kni-ip-benefit__icon[data-icon="shield-check"]::before { content: "✓"; }
.kni-ip-benefit__icon[data-icon="star"]::before         { content: "★"; }
.kni-ip-benefit__icon[data-icon="certificate"]::before  { content: "❖"; }
.kni-ip-benefit__title {
	font-size: 18px;
	font-weight: 600;
	margin: 0 0 8px;
	color: var(--kni-color-text);
}
.kni-ip-benefit__text {
	font-size: 14px;
	line-height: 1.55;
	color: var(--kni-color-text-muted);
	margin: 0;
}

@media (max-width: 900px) { .kni-ip-benefits { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .kni-ip-benefits { grid-template-columns: 1fr; } }

/* Process / Steps */
.kni-ip-process {
	list-style: none;
	margin: 36px 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	counter-reset: kniprocess;
}
.kni-ip-process li {
	background: #fff;
	border: 1px solid var(--kni-color-border);
	border-radius: 14px;
	padding: 26px 22px;
	position: relative;
}
.kni-ip-process__num {
	display: inline-block;
	font-size: 28px;
	font-weight: 700;
	color: var(--kni-color-primary);
	margin-bottom: 12px;
	letter-spacing: -0.02em;
}
.kni-ip-process h3 {
	font-size: 17px;
	font-weight: 600;
	margin: 0 0 8px;
	color: var(--kni-color-text);
}
.kni-ip-process p {
	font-size: 14px;
	line-height: 1.55;
	color: var(--kni-color-text-muted);
	margin: 0;
}
@media (max-width: 900px) { .kni-ip-process { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .kni-ip-process { grid-template-columns: 1fr; } }

/* Services */
.kni-ip-services {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 36px;
}
.kni-ip-service {
	padding: 28px 26px;
	border: 1px solid var(--kni-color-border);
	border-radius: 14px;
	background: var(--kni-color-surface);
	border-top: 3px solid var(--kni-color-primary);
}
.kni-ip-service h3 {
	font-size: 19px;
	font-weight: 600;
	margin: 0 0 10px;
	color: var(--kni-color-text);
}
.kni-ip-service p {
	font-size: 14px;
	line-height: 1.6;
	color: var(--kni-color-text-muted);
	margin: 0;
}
@media (max-width: 900px) { .kni-ip-services { grid-template-columns: 1fr; } }

/* Contact */
.kni-ip-section--contact {
	background: var(--kni-color-primary-dark);
	color: #fff;
}
.kni-ip-section--contact .kni-ip-section__title { color: #fff; }
.kni-ip-contact {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 56px;
	align-items: center;
}
.kni-ip-contact__intro h2 {
	font-size: clamp(26px, 3vw, 36px);
	color: #fff;
	margin: 12px 0 14px;
	line-height: 1.2;
	font-weight: 600;
}
.kni-ip-contact__intro p {
	font-size: 16px;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.85);
	margin: 0 0 24px;
	max-width: 480px;
}
.kni-ip-contact__channels {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.kni-ip-channel {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 12px;
	padding: 18px 22px;
}
.kni-ip-channel__icon {
	width: 40px;
	height: 40px;
	flex: 0 0 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.15);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
}
.kni-ip-channel strong {
	display: block;
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 4px;
}
.kni-ip-channel p {
	margin: 0;
	font-size: 15px;
	color: rgba(255, 255, 255, 0.95);
	line-height: 1.5;
}
.kni-ip-channel a { color: #fff; text-decoration: none; border-bottom: 1px dotted rgba(255,255,255,0.4); }
.kni-ip-channel a:hover { border-bottom-color: #fff; }

@media (max-width: 900px) {
	.kni-ip-contact { grid-template-columns: 1fr; gap: 40px; }
}

/* ============================================================
 *  Landing page – additional sections (v1.2)
 * ============================================================ */

/* "Your benefits as an investor" lead above the cards */
.kni-ip-intro__lead {
	margin: 28px 0 0;
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--kni-color-text-muted);
}

/* Hero size variant */
.kni-ip-hero--standard { min-height: 460px; }
.kni-ip-hero--standard .kni-ip-hero__inner { padding: 80px 24px 64px; }

/* Standard-Hero Hintergrund-Pattern wenn kein Bild da ist */
.kni-ip-hero:not(.kni-ip-hero--has-bg) {
	background:
		radial-gradient(circle at 20% 20%, rgba(255,255,255,0.08) 0%, transparent 50%),
		radial-gradient(circle at 80% 80%, rgba(255,255,255,0.05) 0%, transparent 50%),
		linear-gradient(135deg, var(--kni-color-primary-dark) 0%, var(--kni-color-primary) 100%);
}

/* ====== Schwerpunkte / Kategorien ====== */
.kni-ip-section--categories { background: #fff; padding: 72px 0; }

.kni-ip-cats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 40px;
}
@media (max-width: 900px) { .kni-ip-cats { grid-template-columns: 1fr; } }

.kni-ip-cat {
	background: var(--kni-color-surface);
	border-radius: 18px;
	padding: 36px 30px;
	border: 1px solid var(--kni-color-border);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	position: relative;
	overflow: hidden;
}
.kni-ip-cat::after {
	content: "";
	position: absolute;
	left: 0; right: 0; top: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--kni-color-primary), var(--kni-color-primary-dark));
	opacity: 0;
	transition: opacity .25s ease;
}
.kni-ip-cat:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.10);
	border-color: transparent;
}
.kni-ip-cat:hover::after { opacity: 1; }

.kni-ip-cat__icon {
	display: inline-flex;
	width: 56px;
	height: 56px;
	border-radius: 16px;
	background: var(--kni-color-primary-soft);
	align-items: center;
	justify-content: center;
	font-size: 26px;
	line-height: 1;
	margin-bottom: 22px;
}
.kni-ip-cat__title {
	font-size: 21px;
	font-weight: 600;
	margin: 0 0 10px;
	color: var(--kni-color-text);
	line-height: 1.25;
}
.kni-ip-cat__text {
	font-size: 15px;
	line-height: 1.6;
	color: var(--kni-color-text-muted);
	margin: 0;
}

/* ====== Aktuelle Projekte – Empty State ====== */
.kni-ip-empty {
	text-align: center;
	background: #fff;
	border-radius: 14px;
	border: 1px solid var(--kni-color-border);
	padding: 56px 32px;
	margin-top: 24px;
}
.kni-ip-empty p {
	font-size: 16px;
	color: var(--kni-color-text-muted);
	margin: 0 0 24px;
	max-width: 540px;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.55;
}

/* ====== International presence ====== */
.kni-ip-section--international {
	background: var(--kni-color-surface);
	padding: 72px 0;
}
.kni-ip-intl {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 48px;
	align-items: center;
}
@media (max-width: 900px) {
	.kni-ip-intl { grid-template-columns: 1fr; gap: 32px; }
}
.kni-ip-intl__text .kni-ip-intro__text { margin-top: 14px; }
.kni-ip-intl__list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
}
.kni-ip-country {
	display: flex;
	align-items: center;
	gap: 14px;
	background: #fff;
	border: 1px solid var(--kni-color-border);
	border-radius: 12px;
	padding: 18px 22px;
	transition: transform .15s ease, box-shadow .15s ease;
}
.kni-ip-country:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}
.kni-ip-country__flag {
	font-size: 28px;
	line-height: 1;
}
.kni-ip-country__name {
	font-size: 15px;
	font-weight: 600;
	color: var(--kni-color-text);
}

/* ============================================================
 *  Hero YouTube (v1.3)
 * ============================================================ */
.kni-hero__youtube-wrap {
	position: absolute;
	inset: 0;
	overflow: hidden;
	z-index: 0;
	pointer-events: none;
}
.kni-hero__youtube {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100vw;
	height: 56.25vw;          /* 16:9 of viewport width */
	min-width: 177.78vh;      /* 16:9 of viewport height */
	min-height: 100%;
	transform: translate(-50%, -50%);
	border: 0;
	pointer-events: none;
}
@media (max-width: 767px) {
	.kni-hero__youtube-wrap { display: none; }
}

/* ============================================================
 *  Landing-Hero: Video + YouTube (v1.4)
 *  Liegen hinter dem .kni-ip-hero__overlay (blauer Filter).
 * ============================================================ */
.kni-ip-hero { position: relative; overflow: hidden; }

.kni-ip-hero__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
	pointer-events: none;
}

.kni-ip-hero__youtube-wrap {
	position: absolute;
	inset: 0;
	overflow: hidden;
	z-index: 0;
	pointer-events: none;
}
.kni-ip-hero__youtube {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100vw;
	height: 56.25vw;        /* 16:9 of viewport width */
	min-width: 177.78vh;    /* 16:9 of viewport height */
	min-height: 100%;
	transform: translate(-50%, -50%);
	border: 0;
	pointer-events: none;
}

/* Ensure overlay and content sit ABOVE the video */
.kni-ip-hero__overlay { position: absolute; inset: 0; z-index: 1; }
.kni-ip-hero__inner   { position: relative; z-index: 2; }

@media (max-width: 767px) {
	/* Auf Mobil zeigen wir nur das Hintergrundbild (Poster), Video/iframe gespart */
	.kni-ip-hero__video,
	.kni-ip-hero__youtube-wrap { display: none; }
}

/* ============================================================
 *  v1.5 – Mobile Polish + YouTube-Cover + Slider-Progress
 * ============================================================ */

/* --- YouTube-Cover: blockiert Bedienelemente ---------------- */
.kni-hero__youtube-cover,
.kni-ip-hero__youtube-cover {
	position: absolute;
	inset: 0;
	z-index: 2;
	background: transparent;
	cursor: default;
}

/* IFrame-API iframe must inherit the wrap dimensions.
   First rule: selector via wrap iframe because YT API may not preserve the class. */
.kni-hero__youtube-wrap iframe,
.kni-hero__youtube-wrap .kni-hero__youtube,
.kni-ip-hero__youtube-wrap iframe,
.kni-ip-hero__youtube-wrap .kni-ip-hero__youtube {
	position: absolute !important;
	top: 50% !important;
	left: 50% !important;
	width: 100vw !important;
	height: 56.25vw !important;
	min-width: 177.78vh !important;
	min-height: 100% !important;
	transform: translate(-50%, -50%) !important;
	border: 0 !important;
	pointer-events: none !important;
}

/* Auch auf Mobile YouTube/Video abspielen (vorher display:none) */
@media (max-width: 767px) {
	.kni-hero__youtube-wrap,
	.kni-ip-hero__youtube-wrap,
	.kni-hero__video,
	.kni-ip-hero__video { display: block !important; }
}

/* --- Mobile Container-Padding (gegen Theme-Overrides) -------
   Beobachtung: manche Themes resetten die Container-Padding
   below 768px. We enforce it with higher specificity. */
@media (max-width: 767px) {
	.kni-ip .kni-container,
	.kni-ip-hero .kni-ip-hero__inner,
	.kni-ip-section > .kni-container {
		padding-left: 20px !important;
		padding-right: 20px !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}

	/* Reduce hero vertical padding for mobile */
	.kni-ip-hero__inner {
		padding-top: 60px !important;
		padding-bottom: 60px !important;
	}

	/* Section-Vertikal-Padding reduzieren */
	.kni-ip-section { padding: 56px 0 !important; }
	.kni-ip-section--contact { padding: 56px 0 !important; }

	/* Tone down font sizes on mobile */
	.kni-ip-hero__title { font-size: clamp(28px, 9vw, 38px) !important; line-height: 1.1 !important; }
	.kni-ip-hero__sub   { font-size: 15px !important; }
	.kni-ip-section__title { font-size: clamp(22px, 6vw, 30px) !important; line-height: 1.2 !important; }

	/* Prevent buttons from overflowing */
	.kni-ip-hero__cta,
	.kni-ip-contact__intro {
		max-width: 100%;
	}
	.kni-ip-hero__cta .kni-btn,
	.kni-ip-section .kni-btn {
		min-width: 0;
		width: 100%;
		text-align: center;
		justify-content: center;
	}
	.kni-ip-hero__cta { flex-direction: column; gap: 12px; width: 100%; }
}

/* --- Single-Investment-Seiten: Mobile-Padding & -Layout ----- */
@media (max-width: 767px) {
	.kni-container,
	.kni-investment .kni-container,
	.kni-investment-archive .kni-container {
		padding-left: 20px !important;
		padding-right: 20px !important;
		box-sizing: border-box;
		max-width: 100%;
	}

	/* Hero-Stats auf Single nicht horizontal scrollen */
	.kni-hero { min-height: 60vh !important; }
	.kni-stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
	.kni-stats-grid .kni-stat { padding: 14px !important; }
	.kni-stats-grid .kni-stat__label { font-size: 11px !important; }
	.kni-stats-grid .kni-stat__value { font-size: 18px !important; }

	/* Layout: Sidebar unter Hauptspalte */
	.kni-body { grid-template-columns: 1fr !important; gap: 32px !important; }

	/* Highlights und Galerie */
	.kni-highlights { grid-template-columns: 1fr !important; }
	.kni-gallery-grid { grid-template-columns: repeat(2, 1fr) !important; }

	/* Card-Grid auf Archiv-/Liste in 1 Spalte */
	.kni-grid--2,
	.kni-grid--3,
	.kni-grid--4 { grid-template-columns: 1fr !important; }
}

/* --- Abstand Buttons zu Text (alle Investment-Seiten) ------- */
.kni-ip-hero__cta {
	margin-top: 40px;
}
.kni-ip-section .kni-btn,
.kni-ip-contact__intro .kni-btn {
	margin-top: 24px;
}
.kni-ip-intro + .kni-btn,
.kni-ip-intro__text + .kni-btn {
	margin-top: 28px;
}
.kni-hero__cta,
.kni-section--cta .kni-btn {
	margin-top: 28px;
}

/* Erste Section nach Hero etwas Luft geben */
.kni-ip-hero + .kni-ip-section { padding-top: 80px; }
@media (max-width: 767px) {
	.kni-ip-hero + .kni-ip-section { padding-top: 56px; }
}

/* ============================================================
 *  Slider-Modernisierung
 *  – Modernere Pfeile, Progress-Bar unten, Auto-Play (per JS)
 *  – Dots optionally hidden, progress bar takes over
 * ============================================================ */
.kni-slider {
	position: relative;
	overflow: hidden;
	border-radius: 12px;
}

/* Pfeile: subtiler, glasig */
.kni-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(15, 23, 42, 0.55);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.18);
	font-size: 22px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 4;
	transition: background .2s ease, transform .2s ease;
	opacity: 0;
}
.kni-slider:hover .kni-slider__nav,
.kni-slider:focus-within .kni-slider__nav { opacity: 1; }
.kni-slider__nav:hover { background: rgba(29, 111, 220, 0.85); transform: translateY(-50%) scale(1.05); }
.kni-slider__nav--prev { left: 14px; }
.kni-slider__nav--next { right: 14px; }
@media (max-width: 767px) {
	.kni-slider__nav { opacity: 1; width: 38px; height: 38px; font-size: 18px; }
	.kni-slider__nav--prev { left: 8px; }
	.kni-slider__nav--next { right: 8px; }
}

/* Counter rechts oben, dezent */
.kni-slider__counter {
	position: absolute;
	top: 14px;
	right: 14px;
	background: rgba(15, 23, 42, 0.55);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	color: #fff;
	padding: 4px 10px;
	border-radius: 12px;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.04em;
	z-index: 4;
}

/* Dots dezenter (oder ganz ausblenden, da Progress-Bar da ist) */
.kni-slider__dots {
	display: none; /* durch Progress-Bar ersetzt */
}

/* Progress-Bar (per JS injiziert) */
.kni-slider__progress-track {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: rgba(255, 255, 255, 0.18);
	z-index: 3;
}
.kni-slider__progress-bar {
	height: 100%;
	width: 0%;
	background: var(--kni-color-primary, #1d6fdc);
	will-change: width;
}

/* Smoother slide transition */
.kni-slider__slide {
	transition: opacity .5s ease;
}

/* ============================================================
 *  v1.6.1 – YouTube-Poster-Mask + bessere Button-Abstände
 * ============================================================ */

/* Poster-Maske: zeigt das Hintergrundbild,
   bis YouTube wirklich "PLAYING" meldet — und zurück bei PAUSED/BUFFERING/ENDED.
   Damit verschwinden Pause-Symbole und sonstige YT-UI-Blitzer. */
.kni-hero__youtube-poster,
.kni-ip-hero__youtube-poster {
	position: absolute;
	inset: 0;
	z-index: 1;
	background-color: var(--kni-color-primary-dark, #0c447c);
	background-size: cover;
	background-position: center;
	pointer-events: none;
	opacity: 1;
	transition: opacity 0.5s ease;
}
.kni-hero__youtube-poster.is-hidden,
.kni-ip-hero__youtube-poster.is-hidden {
	opacity: 0;
}

/* Cover bleibt oberhalb des Posters, damit Klicks weiter abgefangen werden */
.kni-hero__youtube-cover,
.kni-ip-hero__youtube-cover {
	z-index: 3;
}

/* --- CTA-Card auf Single-Investment-Seite (Sidebar) --- */
.kni-cta-card__title { margin: 0 0 12px; }
.kni-cta-card__text  { margin: 0 0 24px; }
.kni-cta-card .kni-btn,
.kni-cta-card__text + .kni-btn {
	margin-top: 8px;
}

/* --- Sidebar-Abstände allgemein --- */
.kni-side__title { margin-top: 0; margin-bottom: 18px; }
.kni-docs        { margin-top: 32px; }
.kni-facts       { margin-top: 32px; }
.kni-disclaimer  { margin-top: 28px; }

/* --- Landing-Hero: Button-Abstand bumpen --- */
.kni-ip-hero__cta { margin-top: 48px; }
@media (max-width: 767px) {
	.kni-ip-hero__cta { margin-top: 36px; }
}

/* --- Single-Hero: Subtitle-zu-Meta-Abstand --- */
.kni-hero__subtitle  { margin-bottom: 24px; }
.kni-hero__meta      { margin-top: 8px; }

/* --- Stats-Section: mehr Luft vor und nach --- */
.kni-stats { padding: 40px 0; }
@media (max-width: 767px) {
	.kni-stats { padding: 28px 0; }
}

/* ============================================================
 *  v1.7 – Hero meta icons + Custom highlight icons + Video embed
 * ============================================================ */

/* Hero meta: SVG icons stehen jetzt direkt im Markup */
.kni-hero__meta li {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.kni-hero__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 16px;
	height: 16px;
	color: rgba(255, 255, 255, 0.85);
	flex-shrink: 0;
}
.kni-hero__icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

/* Custom Highlight icons (eigene Uploads) */
.kni-highlights__icon--custom {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background: rgba(29, 111, 220, 0.08);
	border-radius: 8px;
	overflow: hidden;
}
.kni-highlights__icon--custom img {
	max-width: 100%;
	max-height: 100%;
	display: block;
	object-fit: contain;
}

/* Video embed unter der Beschreibung */
.kni-video-embed {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #000;
	border-radius: 12px;
	overflow: hidden;
}
.kni-video-embed iframe,
.kni-video-embed video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* Stats-Grid auf Desktop: dynamische Anzahl Kacheln (4 oder 5 inkl. Units) */
@media (min-width: 768px) {
	.kni-stats__row { display: flex; flex-wrap: wrap; gap: 20px; }
	.kni-stats__row .kni-stat { flex: 1 1 0; min-width: 140px; }
}

/* ============================================================
 *  v1.7.1 – Mobile padding fix (aggressive)
 *  Theme bricht aus dem Layout aus → wir zwingen Padding & overflow.
 * ============================================================ */
@media (max-width: 767px) {

	/* Wurzel-Wrapper: keine Overflows nach außen erlauben */
	.kni-ip,
	.kni-investment,
	.kni-investment-archive,
	body.post-type-archive-kni_investment,
	body.single-kni_investment {
		overflow-x: hidden !important;
		max-width: 100vw !important;
	}

	/* Sections: max 100vw und nichts überlappen lassen */
	.kni-ip-hero,
	.kni-ip-section,
	.kni-stats,
	.kni-body,
	.kni-hero {
		max-width: 100vw !important;
		overflow-x: hidden !important;
		box-sizing: border-box !important;
	}

	/* Container-Padding – mit höchster Spezifität */
	body .kni-ip .kni-container,
	body .kni-ip-hero .kni-ip-hero__inner,
	body .kni-ip-section .kni-container,
	body .kni-investment .kni-container,
	body .kni-hero .kni-container,
	body .kni-stats .kni-container,
	body .kni-body .kni-container {
		padding-left: 22px !important;
		padding-right: 22px !important;
		max-width: 100% !important;
		width: 100% !important;
		box-sizing: border-box !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	/* Hero-Texte: kleinere Größen + Bindestrich-Trennung erlauben */
	.kni-ip-hero__title,
	body .kni-ip-hero__title {
		font-size: clamp(24px, 7.5vw, 34px) !important;
		line-height: 1.15 !important;
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
		hyphens: auto !important;
		-webkit-hyphens: auto !important;
		max-width: 100% !important;
	}
	.kni-ip-hero__sub,
	body .kni-ip-hero__sub {
		font-size: 15px !important;
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
		max-width: 100% !important;
	}

	.kni-ip-section__title,
	body .kni-ip-section__title {
		font-size: clamp(20px, 6vw, 26px) !important;
		line-height: 1.2 !important;
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
		hyphens: auto !important;
		max-width: 100% !important;
	}
	.kni-ip-intro__text,
	body .kni-ip-intro__text {
		font-size: 15px !important;
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
		max-width: 100% !important;
	}

	/* Single-Hero gleiche Behandlung */
	.kni-hero__title,
	body .kni-hero__title {
		font-size: clamp(24px, 7vw, 32px) !important;
		line-height: 1.15 !important;
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
		hyphens: auto !important;
		max-width: 100% !important;
	}
	.kni-hero__subtitle,
	body .kni-hero__subtitle {
		font-size: 15px !important;
		word-wrap: break-word !important;
		overflow-wrap: break-word !important;
		max-width: 100% !important;
	}

	/* CTAs: Block-Stack, full-width innerhalb Padding */
	.kni-ip-hero__cta {
		display: flex !important;
		flex-direction: column !important;
		gap: 12px !important;
		width: 100% !important;
		margin-top: 32px !important;
	}
	.kni-ip-hero__cta .kni-btn {
		width: 100% !important;
		text-align: center !important;
		justify-content: center !important;
		box-sizing: border-box !important;
	}
}

/* Single-Investment Stats-Grid: feste 2 Spalten auf Mobile */
@media (max-width: 767px) {
	.kni-stats__row {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 12px !important;
		flex-wrap: initial !important;
	}
	.kni-stats__row .kni-stat {
		min-width: 0 !important;
		padding: 14px !important;
	}
	.kni-stats__row .kni-stat__label { font-size: 11px !important; }
	.kni-stats__row .kni-stat__value { font-size: 18px !important; word-break: break-word !important; }
}
