/* =============================================================================
   KMP Digital — Blocks
   Namespaced Styles für alle Seiten-Blöcke.
   Jeder Block hat ein eigenes Präfix → kein Konflikt, egal was daneben läuft.
   ============================================================================= */

/* =============================================================================
   PRODUKT-SEITE (p1 – p6)
   ============================================================================= */

/* P1 — Hero ---------------------------------------------------------------- */
.p1 { background: var(--kmp-dark); color: #fff; }

.p1__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-8);
	align-items: center;
	padding-block: var(--block-py);
}
@media (max-width: 768px) {
	.p1__inner { grid-template-columns: 1fr; }
	.p1__media { order: -1; }
}

.p1__eyebrow {
	font-size: var(--fs-eyebrow);
	font-weight: var(--fw-bold);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--kmp-purple);
	margin: 0 0 var(--space-3);
}
.p1__title {
	font-size: var(--fs-display);
	font-weight: var(--fw-black);
	letter-spacing: -0.02em;
	color: #fff;
	margin: 0 0 var(--space-5);
}
.p1__lead {
	font-size: var(--fs-lead);
	color: rgba(255,255,255,0.8);
	line-height: var(--lh-loose);
	margin: 0 0 var(--space-6);
	max-width: 52ch;
}
.p1__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-bottom: var(--space-5);
}
.p1__meta {
	list-style: none;
	padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: var(--space-2);
}
.p1__meta li a {
	font-size: var(--fs-small);
	color: rgba(255,255,255,0.55);
	text-decoration: none;
	border: 1px solid rgba(255,255,255,0.2);
	border-radius: var(--r-full);
	padding: var(--space-1) var(--space-3);
	transition: all var(--dur-fast);
}
.p1__meta li a:hover { color: #fff; border-color: rgba(255,255,255,0.5); }

.p1__media {
	border-radius: var(--r-xl);
	overflow: hidden;
	background: rgba(255,255,255,0.05);
}
.p1__media img { width: 100%; height: auto; display: block; }
.p1__media-placeholder {
	aspect-ratio: 4/3;
	background: rgba(255,255,255,0.08);
}

/* P2 — Specs --------------------------------------------------------------- */
.p2 { background: var(--kmp-white); }

.p2__inner { padding-block: var(--block-py); }

.p2__head { text-align: center; margin-bottom: var(--space-7); }
.p2__title { color: var(--kmp-dark); }

.p2__list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 0;
	border: 1px solid var(--kmp-line);
	border-radius: var(--r-lg);
	overflow: hidden;
}
.p2__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-4);
	padding: var(--space-4) var(--space-5);
	border-bottom: 1px solid var(--kmp-line);
	background: #fff;
	transition: background var(--dur-fast);
}
.p2__row:last-child { border-bottom: 0; }
.p2__row:hover { background: var(--kmp-light); }
.p2__label {
	font-weight: var(--fw-semibold);
	color: var(--kmp-ink-2);
	font-size: var(--fs-small);
	flex: 0 0 auto;
}
.p2__value {
	color: var(--kmp-dark);
	font-weight: var(--fw-medium);
	text-align: right;
}

/* P3 — Features ------------------------------------------------------------ */
.p3 { background: var(--kmp-dark); color: #fff; }

.p3__inner { padding-block: var(--block-py); }

.p3__head { text-align: center; margin-bottom: var(--space-7); }
.p3__title { color: #fff; }

.p3__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-5);
}
@media (max-width: 768px) { .p3__grid { grid-template-columns: 1fr; } }

.p3__card {
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: var(--r-lg);
	padding: var(--space-6);
	transition: transform var(--dur-base) var(--ease-out), background var(--dur-base);
}
.p3__card:hover {
	transform: translateY(-4px);
	background: rgba(255,255,255,0.1);
}
.p3__icon {
	width: 48px; height: 48px;
	margin-bottom: var(--space-4);
}
.p3__icon--text {
	display: block;
	font-size: 2rem;
	margin-bottom: var(--space-4);
}
.p3__card-title {
	color: #fff;
	font-size: var(--fs-h3);
	margin: 0 0 var(--space-3);
}
.p3__card-text {
	color: rgba(255,255,255,0.7);
	font-size: var(--fs-small);
	line-height: var(--lh-loose);
	margin: 0;
}

/* P4 — Zubehör ------------------------------------------------------------- */
.p4 { background: var(--kmp-light); }

.p4__inner { padding-block: var(--block-py); }

.p4__head { margin-bottom: var(--space-7); }
.p4__title { color: var(--kmp-dark); }

.p4__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: var(--space-5);
}

.p4__card {
	background: #fff;
	border-radius: var(--r-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	box-shadow: var(--sh-md);
	transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
	display: flex; flex-direction: column;
}
.p4__card:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }

.p4__media {
	aspect-ratio: 4/3;
	background: var(--kmp-light);
	overflow: hidden;
}
.p4__media img { width: 100%; height: 100%; object-fit: cover; }
.p4__media-placeholder { width: 100%; height: 100%; background: var(--kmp-light); }

.p4__body {
	padding: var(--space-4);
	display: flex; flex-direction: column; gap: var(--space-2);
	flex: 1;
}
.p4__card-title { font-size: 1rem; font-weight: var(--fw-bold); color: var(--kmp-dark); margin: 0; }
.p4__card-text  { font-size: var(--fs-small); color: var(--kmp-ink-2); margin: 0; }
.p4__link       { font-size: var(--fs-small); font-weight: var(--fw-semibold); color: var(--kmp-purple); margin-top: auto; }

/* P5 — SEO-Text ------------------------------------------------------------ */
.p5 { background: var(--kmp-white); }

.p5__inner { padding-block: var(--block-py); }

.p5__copy {
	max-width: 72ch;
	margin-inline: auto;
}

/* P6 — Downloads ----------------------------------------------------------- */
.p6 { background: var(--kmp-dark); color: #fff; }

.p6__inner { padding-block: var(--block-py); }

.p6__head { margin-bottom: var(--space-6); }
.p6__title { color: #fff; }

.p6__list {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: var(--space-3);
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.p6__link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	background: rgba(255,255,255,0.07);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--r-md);
	padding: var(--space-4) var(--space-5);
	text-decoration: none;
	color: #fff;
	transition: background var(--dur-fast), transform var(--dur-fast);
}
.p6__link:hover { background: rgba(255,255,255,0.13); transform: translateY(-2px); color: #fff; }
.p6__link-title { font-weight: var(--fw-semibold); }
.p6__link-meta  { font-size: var(--fs-small); color: rgba(255,255,255,0.5); white-space: nowrap; }

/* =============================================================================
   CTA — globaler Kontakt-Block (Produkt, Kategorie, Hersteller)
   ============================================================================= */
.cta { background: var(--kmp-dark); color: #fff; }

.cta__inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--space-8);
	align-items: center;
	padding-block: var(--block-py);
}
@media (max-width: 768px) {
	.cta__inner { grid-template-columns: 1fr; }
}

.cta__title { color: #fff; font-size: var(--fs-h2); margin: 0 0 var(--space-3); }
.cta__lead  { color: rgba(255,255,255,0.75); max-width: 54ch; margin: 0; }

.cta__actions {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	flex-shrink: 0;
}
@media (max-width: 768px) { .cta__actions { flex-direction: row; flex-wrap: wrap; } }

/* =============================================================================
   HERSTELLERSEITE (h1 – h2)
   ============================================================================= */
.h1 { background: var(--kmp-dark); color: #fff; }
.h1__inner { padding-block: var(--block-py); max-width: 760px; }
.h1__title { color: #fff; font-size: var(--fs-display); font-weight: var(--fw-black); }
.h1__lead  { color: rgba(255,255,255,0.78); font-size: var(--fs-lead); max-width: 58ch; margin: 0; }

.h2 { background: var(--kmp-light); }
.h2__inner { padding-block: var(--block-py); }
.h2__head  { margin-bottom: var(--space-7); }
.h2__title { color: var(--kmp-dark); }
.h2__grid  {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--space-5);
}

/* =============================================================================
   KATEGORIESEITE (k1 – k3)
   ============================================================================= */
.k1 { background: var(--kmp-dark); color: #fff; }
.k1__inner { padding-block: var(--block-py); max-width: 760px; }
.k1__title { color: #fff; font-size: var(--fs-display); font-weight: var(--fw-black); }
.k1__lead  { color: rgba(255,255,255,0.78); font-size: var(--fs-lead); max-width: 58ch; margin: 0; }

.k2 { background: var(--kmp-white); }
.k2__inner { padding-block: var(--block-py); }
.k2__grid  {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--space-5);
}

.k3 { background: var(--kmp-light); }
.k3__inner {
	padding-block: var(--block-py);
	max-width: 72ch;
	margin-inline: auto;
}

/* =============================================================================
   ARCHIV-SEITE (a1 – a2)
   ============================================================================= */
.a1 { background: var(--kmp-dark); color: #fff; }
.a1__inner { padding-block: var(--block-py); max-width: 760px; }
.a1__title { color: #fff; font-size: var(--fs-display); font-weight: var(--fw-black); }
.a1__lead  { color: rgba(255,255,255,0.78); font-size: var(--fs-lead); max-width: 58ch; margin: 0; }

.a2 { background: var(--kmp-light); }
.a2__inner { padding-block: var(--block-py); }
.a2__grid  {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--space-5);
}
