/*
Theme Name:        Königswieser 2026
Theme URI:         https://www.koenigswieser.com/
Description:       Greenfield Classic-Theme für KGD-Website-Relaunch 2026. Tokens + Komponenten basieren auf dem Königswieser Design System (Handoff 2026-05-06). Bordeaux + erdige Sand-Neutrals, Josefin Sans / PT Serif, Mobile-First. Theme liefert nur die Hülle — alle Inhalte kommen aus Gutenberg-Blöcken im kw-blocks-Plugin.
Author:            Königswieser Gerätetechnik GmbH
Author URI:        https://www.koenigswieser.com/
Version:           0.1.3
Requires at least: 6.6
Requires PHP:      8.1
Tested up to:      6.9
License:           GPL-2.0-or-later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       koenigswieser
Tags:              classic, custom-colors, custom-menu, custom-logo, threaded-comments, translation-ready, wide-blocks
*/

/* Theme entrypoint — Komponenten-Styles via wp_enqueue_style() in inc/enqueue.php.
   Hier nur kleine Overrides die zu spät kommen oder WP-Core-Markup adressieren. */

/* WP Custom-Logo: get_custom_logo() rendert .custom-logo-link > img.custom-logo
   — outside unserer .kw-header-logo Selektor-Reichweite. Hier rein-zwingen. */
.custom-logo-link,
.kw-header-logo,
.kw-header-inner > a:first-child {
	display: inline-flex;
	align-items: center;
	max-width: 220px;
	flex-shrink: 0;
}
.custom-logo-link img,
.custom-logo,
.kw-header-logo img,
.kw-header-inner > a:first-child img {
	max-width: 220px;
	max-height: 56px;
	width: auto;
	height: auto;
	display: block;
	object-fit: contain;
}

/* Skip-Link nur bei Fokus sichtbar (sonst verkleidet als screen-reader-text) */
.kw-skip-link:focus {
	position: absolute;
	top: 8px;
	left: 8px;
	z-index: 100000;
	background: var(--kw-bordeaux);
	color: #fff;
	padding: 8px 14px;
	border-radius: 6px;
	clip: auto !important;
	width: auto;
	height: auto;
}

/* index.php-Fallback Title nur dann zeigen, wenn KEINE Gutenberg-Inhalte da sind. */
.kw-main--default .kw-article__title:only-child + .kw-article__content:empty,
.kw-main--default:has(.kw-article__content > .wp-block-cover) .kw-article__title {
	display: none;
}

/* === Desktop-Nav Selector-Scope ===
   components.css hat `.kw-nav-desktop ul { display:flex }` was AUCH Sub-Menüs
   matched. Hier beschränken auf direkte Kinder + Sub-Menüs verstecken. */
.kw-nav-desktop > ul {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 2px;
	flex-wrap: nowrap;
}
.kw-nav-desktop ul ul,
.kw-nav-desktop .sub-menu,
.kw-nav-desktop > ul > li > ul {
	display: none;
}
.kw-nav-desktop > ul > li > a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 0.7em 0.9em;
	color: var(--kw-body-text);
	text-decoration: none;
	font-family: var(--kw-font-display);
	font-size: 15px;
	font-weight: 600;
	white-space: nowrap;
	transition: color 0.2s;
}
.kw-nav-desktop > ul > li > a:hover,
.kw-nav-desktop > ul > li.open > a,
.kw-nav-desktop > ul > li.current-menu-item > a {
	color: var(--kw-bordeaux);
}

/* Top-Bar Service-Layer: Items dürfen nicht abgeschnitten werden */
.kw-topbar { overflow: visible !important; }
.kw-topbar-inner { overflow: visible !important; }

/* Top-Bar Sub-Menus (WP rendert Service mit Children inline → in Dropdown wandeln) */
.kw-topbar-utils > li {
	position: relative;
}
.kw-topbar-utils > li > ul.sub-menu,
.kw-topbar-utils ul ul {
	display: none;
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	min-width: 220px;
	background: #fff;
	border: 1px solid var(--kw-border);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(0,0,0,0.12);
	list-style: none;
	margin: 0;
	padding: 6px;
	z-index: 1100;
	white-space: nowrap;
}
.kw-topbar-utils > li:hover > ul.sub-menu,
.kw-topbar-utils > li:focus-within > ul.sub-menu {
	display: block;
}
.kw-topbar-utils > li > ul.sub-menu li {
	display: block;
}
.kw-topbar-utils > li > ul.sub-menu li a {
	display: block;
	padding: 9px 12px;
	border-radius: 5px;
	font-family: var(--kw-font-body);
	font-size: 14px;
	color: var(--kw-body-text);
	text-decoration: none;
}
.kw-topbar-utils > li > ul.sub-menu li a:hover {
	background: var(--kw-cream);
	color: var(--kw-bordeaux);
}
/* Hover-Brücke: schliesst den 6px-Gap zwischen Li und Dropdown */
.kw-topbar-utils > li.menu-item-has-children::before {
	content: '';
	display: block;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	height: 6px;
}

/* Caret-Indikator für Items mit Children */
.kw-topbar-utils > li.menu-item-has-children > a::after {
	content: '▾';
	display: inline-block;
	margin-left: 4px;
	font-size: 0.85em;
	color: var(--kw-text-muted);
}

/* Header-CTA — Padding/Width verträglicher */
.kw-header-cta {
	white-space: nowrap;
	padding: 10px 18px;
	font-size: 13px;
}
.kw-header-cta .kw-cta-label {
	font-weight: 700;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	font-size: 12px;
}
.kw-header-cta .kw-cta-sub {
	font-size: 11px;
	opacity: 0.85;
	margin-top: 2px;
}

/* === Single-Seilwinde Hero / Section additions === */
.kw-product__hero {
	background-color: var(--kw-bordeaux-dark); /* Fallback wenn kein bild_hero */
}
.kw-product__hero-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center 40%;
	z-index: 1;
}
.kw-product__hero-overlay {
	z-index: 2;
}
.kw-product__hero-inner {
	z-index: 3;
}
.kw-product__hero-ctas {
	display: flex;
	gap: 14px;
	margin-top: 24px;
	flex-wrap: wrap;
}
.kw-product__hero-award {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 18px;
	font-family: var(--kw-font-display);
	font-size: 13px;
	font-weight: 600;
	color: var(--kw-sand);
	background: rgba(0,0,0,0.25);
	padding: 6px 12px;
	border-radius: 4px;
}
.kw-product__hero-award .kw-trust-star { color: #FFB100; }

.kw-section { padding: 80px 32px; }
.kw-product__section-inner { max-width: 1100px; margin: 0 auto; }
.kw-section--cream { background: var(--kw-cream); }
.kw-section--bordeaux { background: var(--kw-gradient-cta); color: #fff; }

.kw-section-heading--inverted { color: #fff !important; }
.kw-section-heading--inverted::after { background: var(--kw-sand) !important; }
.kw-lead--inverted { color: rgba(255,255,255,0.9); text-align: center; max-width: 700px; margin: 0 auto 28px; }

.kw-product__usp-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	list-style: none;
	margin: 32px 0 0;
	padding: 0;
}
.kw-product__usp-title {
	font-family: var(--kw-font-display);
	font-size: 20px;
	font-weight: 600;
	margin: 0 0 12px;
	color: var(--kw-bordeaux);
}
.kw-product__usp-body { font-size: 15px; line-height: 1.6; }

.kw-product__ausstattung-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
}
.kw-product__ausstattung-list {
	list-style: none;
	margin: 16px 0 0;
	padding: 0;
}
.kw-product__ausstattung-list li {
	padding: 8px 0;
	border-bottom: 1px solid var(--kw-border);
	display: flex;
	align-items: center;
	gap: 10px;
}
.kw-product__ausstattung-marker { color: var(--kw-bordeaux); font-size: 18px; }
.kw-product__ausstattung-list--optional .kw-product__ausstattung-marker { color: var(--kw-text-muted); }

.kw-product__inquiry { text-align: center; }

@media (max-width: 768px) {
	.kw-product__usp-list,
	.kw-product__ausstattung-grid { grid-template-columns: 1fr; gap: 32px; }
	.kw-section { padding: 56px 20px; }
}

/* === Card Slimmer (Filter-Hub-Pages) ===
   WARUM: SSOT-Freisteller liegen im 4:5-Ratio (Studio-Cutout, portrait).
   Container 4:5 + object-fit cover, damit das Freisteller-Motiv die Card
   randlos fuellt. Placeholder (SKUs ohne Freisteller-Bild) bleibt klein
   zentriert mit object-fit contain. Aenderung Issue #317.

   WARUM kein !important (Issue #369): Root-Cause war eine globale Regel
   `.kw-card__image { width:100%; height:100%; object-fit:cover }` aus
   plugins/kw-blocks/css/kw-blocks.css, die fuer das card-grid Block-IMG
   gedacht war, aber den Archive-Wrapper-DIV kollabiert hat. Die wurde dort
   auf `.kw-card__image-wrap .kw-card__image` ge-scoped. Damit reicht hier
   die natuerliche Selektor-Spezifitaet (0,2,0) und kein !important. */
.kw-swf__grid .kw-card,
.kw-archive .kw-card {
	width: 100%;
	max-width: 380px;
	margin: 0 auto;
	min-width: 0; /* damit grid-cell nicht ueberlaeuft */
}
.kw-swf__grid .kw-card__image,
.kw-archive .kw-card__image {
	width: 100%;
	height: auto; /* WARUM Issue #345: ohne explizites height:auto erbt der
	                 Wrapper die Hoehe vom inner <img height:100%> bzw. dem
	                 Flex-Column-Stretch — dann ueberschreibt das das
	                 aspect-ratio und die Bildflaeche verzerrt pro Reihe. */
	min-height: 0; /* Flex-implizites min-content darf nicht groesser als
	                  aspect-ratio-Hoehe werden. */
	aspect-ratio: 4 / 5;
	flex: 0 0 auto; /* Bild bleibt fix, Body absorbiert Reihen-Differenz. */
	overflow: hidden;
	background: var(--kw-cream-dark);
	padding: 0;
	box-sizing: border-box;
	position: relative;
}
.kw-swf__grid .kw-card__image img:not(.kw-card__image-placeholder),
.kw-archive .kw-card__image img:not(.kw-card__image-placeholder) {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}
/* Placeholder bleibt klein zentriert fuer SKUs ohne Freisteller */
.kw-swf__grid .kw-card__image .kw-card__image-placeholder,
.kw-archive .kw-card__image .kw-card__image-placeholder {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 50%;
	max-height: 60%;
	height: auto;
	object-fit: contain;
	opacity: 0.4;
}
.kw-swf__grid .kw-card__body,
.kw-archive .kw-card__body {
	padding: 18px 20px;
	flex: 1 1 auto; /* WARUM Issue #345: Body waechst, Bild bleibt fix —
	                   so gleichen sich Card-Hoehen aus, ohne das Bild-Ratio zu brechen. */
}

/* === Series-Grid Card-Width Fix (kw-blocks SeriesGrid Block, BEM) ===
   Section wieder als block (NICHT als grid, sonst werden inner zu grid-items). */
.kw-series-grid {
	display: block !important;
	grid-template-columns: none !important;
}
.kw-series-grid__inner {
	max-width: 1280px !important;
	margin: 0 auto !important;
	padding: 0 24px !important;
	width: 100% !important;
}
.kw-series-grid__list,
ul.kw-series-grid__list {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 32px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	align-items: stretch !important;
}
.kw-series-grid__item {
	width: auto !important;
	max-width: 100% !important;
	min-width: 0 !important;
	margin: 0 !important;
	flex: 0 0 auto !important;
}
.kw-series-grid__link {
	display: flex !important;
	flex-direction: column !important;
	width: 100% !important;
}
.kw-series-grid__body {
	width: 100% !important;
	min-width: 0 !important;
}
.kw-series-grid__body p {
	max-width: 100% !important;
	word-break: normal !important;
	hyphens: auto;
}
@media (max-width: 768px) {
	.kw-series-grid__list,
	ul.kw-series-grid__list { grid-template-columns: 1fr !important; }
}

/* === USP-Bar Placeholder-Icon — KGD Brand-SVGs (1972-Set) === */
.kw-usp-bar__icon-wrap--placeholder {
	width: 64px !important;
	height: 64px !important;
	margin: 0 auto 14px !important;
	border-radius: 0 !important;
	background: transparent !important;
	background-position: center !important;
	background-repeat: no-repeat !important;
	background-size: contain !important;
	opacity: 1 !important;
	display: block !important;
}
/* USP-Bar Items mit echten Trust-Icons aus dem 1972-Set */
.kw-usp-bar__item:nth-child(1) .kw-usp-bar__icon-wrap--placeholder {
	background-image: url('/wp-content/themes/koenigswieser-2026/assets/icons/icon-1972.svg') !important;
}
.kw-usp-bar__item:nth-child(2) .kw-usp-bar__icon-wrap--placeholder {
	background-image: url('/wp-content/themes/koenigswieser-2026/assets/icons/icon-erster-platz.svg') !important;
}
/* AT-Item: Österreich-Flagge als Emoji-Glyph (kein dezidiertes SVG vorhanden) */
.kw-usp-bar__item:nth-child(3) .kw-usp-bar__icon-wrap--placeholder {
	background-image: none !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 48px !important;
	line-height: 1 !important;
}
.kw-usp-bar__item:nth-child(3) .kw-usp-bar__icon-wrap--placeholder::after {
	content: '🇦🇹';
	display: block;
	line-height: 1;
}
.kw-usp-bar__item:nth-child(4) .kw-usp-bar__icon-wrap--placeholder {
	background-image: url('/wp-content/themes/koenigswieser-2026/assets/icons/icon-garantie-lebenslang.svg') !important;
}

/* === Series-Grid Bauart-Cards: Trommel-Icons aus 1972-Set === */
.kw-series-grid__media {
	background-color: var(--kw-cream);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 60% auto;
	min-height: 220px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.kw-series-grid__link[href$="mechanische-seilwinde/"] .kw-series-grid__media {
	background-image: url('/wp-content/themes/koenigswieser-2026/assets/icons/icon-bauart-mechanisch.svg');
}
.kw-series-grid__link[href$="laengstrommelwinde/"] .kw-series-grid__media {
	background-image: url('/wp-content/themes/koenigswieser-2026/assets/icons/icon-bauart-laengstrommel.svg');
}
.kw-series-grid__link[href$="quertrommelwinde/"] .kw-series-grid__media {
	background-image: url('/wp-content/themes/koenigswieser-2026/assets/icons/icon-bauart-quertrommel.svg');
}

/* === „Foto folgt" Placeholder mit Wald-Bild ===
   kw-blocks Card-Grid render.php zeigt <div class="kw-placeholder-img">Foto folgt</div>
   bei leerem card_image. Statt grauer Fläche: Wald-Bild mit dezenter Beschriftung. */
.kw-placeholder-img {
	background-image: linear-gradient(rgba(0,0,0,0.35), rgba(0,0,0,0.45)), url('/wp-content/uploads/2026/05/404-wald.jpg') !important;
	background-size: cover !important;
	background-position: center 40% !important;
	background-repeat: no-repeat !important;
	color: rgba(255,255,255,0.8) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-family: var(--kw-font-display) !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 1.5px !important;
	text-transform: uppercase !important;
	min-height: 240px !important;
	border-radius: 8px;
}

/* === Hero-Wald-Fallback ===
   Wald-Foto als ::before Pseudo-Layer NUR für Heroes ohne eigenes BG-Image
   (Archiv/Page-Hero ohne ACF-Image). Combined-Hero rendert sein BG selbst —
   dort kein Wald-Overlay. */
.kw-banner-dark,
.kw-archive-hero,
.kw-page-hero {
	position: relative;
	overflow: hidden;
}
.kw-banner-dark::before,
.kw-archive-hero::before,
.kw-page-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url('/wp-content/uploads/2026/05/404-wald.jpg');
	background-size: cover;
	background-position: center 40%;
	background-repeat: no-repeat;
	opacity: 0.55;
	z-index: 0;
	pointer-events: none;
}
.kw-banner-dark > *,
.kw-archive-hero > *,
.kw-page-hero > * {
	position: relative;
	z-index: 1;
}

/* === 404 (Wald-Hero) === */
.kw-404 {
	background: var(--kw-cream);
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 80px 32px;
}
.kw-404__inner { max-width: 640px; }
.kw-404__hero {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 3 / 2;
	object-fit: cover;
	margin: 0 auto 32px;
	border-radius: 12px;
}
.kw-404__rueckegasse {
	color: var(--kw-bordeaux);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.kw-404__rueckegasse:hover { color: var(--kw-bordeaux-dark); }
.kw-404__number {
	font-family: var(--kw-font-display);
	font-size: 120px;
	font-weight: 700;
	color: var(--kw-bordeaux);
	line-height: 1;
	margin-bottom: 16px;
}
.kw-404__title {
	font-size: var(--kw-text-2xl);
	color: var(--kw-body-text);
	margin-bottom: 16px;
}
.kw-404__text {
	font-size: var(--kw-text-base);
	color: var(--kw-body-text);
	line-height: 1.8;
	margin-bottom: 32px;
}
.kw-404__links {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 48px;
}
.kw-404__categories {
	border-top: 1px solid rgba(76,71,38,0.12);
	padding-top: 32px;
}
.kw-404__subtext {
	font-family: var(--kw-font-display);
	font-size: var(--kw-text-sm);
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--kw-sand);
	margin-bottom: 16px;
}
.kw-404__tags {
	display: flex;
	gap: 10px;
	justify-content: center;
	flex-wrap: wrap;
}
.kw-404__tags a {
	background: var(--kw-white);
	color: var(--kw-body-text);
	padding: 8px 16px;
	border-radius: 8px;
	font-family: var(--kw-font-display);
	font-size: 13px;
	text-decoration: none;
	font-weight: 600;
	transition: all var(--kw-transition);
	box-shadow: var(--kw-shadow-sm);
}
.kw-404__tags a:hover {
	background: var(--kw-bordeaux);
	color: #fff;
	transform: translateY(-2px);
}

/* === Mega-Menu Layout (Flat-WP-Menu mit kw-mega-col-N Klassen) ===
   WP-Menu ist flach, jedes Item hat Klasse .kw-mega-col-1/2/3 für Spalten-
   Zuordnung + .kw-mega-heading für Section-Header. */
.kw-mega-wrap {
	background: #fff;
	border-top: 1px solid var(--kw-border);
	box-shadow: 0 16px 32px rgba(0,0,0,0.08);
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 999;
}
.kw-mega-wrap[hidden] { display: none; }
.kw-header { position: relative; }

.kw-mega-wrap > ul.kw-mega-list {
	max-width: 1240px !important;
	margin: 0 auto !important;
	padding: 32px !important;
	display: block !important;
	column-count: 3 !important;
	column-gap: 48px !important;
	column-fill: balance !important;
	list-style: none !important;
	flex-direction: unset !important;
	grid-template-columns: unset !important;
}
.kw-mega-wrap > ul.kw-mega-list > li {
	break-inside: avoid !important;
	page-break-inside: avoid !important;
	-webkit-column-break-inside: avoid !important;
}
/* Section-Header startet neue Spalte (außer erste) */
.kw-mega-wrap > ul.kw-mega-list > li.kw-mega-heading {
	break-before: column !important;
	page-break-before: column !important;
	-webkit-column-break-before: column !important;
}
.kw-mega-wrap > ul.kw-mega-list > li.kw-mega-heading:first-child {
	break-before: avoid !important;
	page-break-before: avoid !important;
	-webkit-column-break-before: avoid !important;
}

/* Section-Heading */
.kw-mega-wrap > ul.kw-mega-list > li.kw-mega-heading {
	margin-top: 0;
	margin-bottom: 8px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--kw-border);
}
.kw-mega-wrap > ul.kw-mega-list > li.kw-mega-heading > a {
	font-family: var(--kw-font-display) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 1.5px !important;
	color: var(--kw-bordeaux) !important;
	text-decoration: none !important;
	cursor: default;
	pointer-events: none;
}
/* Erste Heading in jeder Spalte: kein top margin */
.kw-mega-wrap > ul.kw-mega-list > li.kw-mega-heading + li.kw-mega-heading,
.kw-mega-wrap > ul.kw-mega-list > li.kw-mega-heading:not(:first-child) {
	margin-top: 0;
}
.kw-mega-wrap > ul.kw-mega-list > li:not(.kw-mega-heading) > a {
	display: block !important;
	padding: 8px 12px !important;
	margin: 0 -12px !important;
	border-radius: 6px !important;
	font-family: var(--kw-font-body) !important;
	font-size: 15px !important;
	font-weight: 400 !important;
	color: var(--kw-body-text) !important;
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	transition: background 0.15s, color 0.15s !important;
}
.kw-mega-wrap > ul.kw-mega-list > li:not(.kw-mega-heading) > a:hover {
	background: var(--kw-cream) !important;
	color: var(--kw-bordeaux) !important;
}

/* === Mobile / Desktop Toggle === */
@media (max-width: 879px) {
	.kw-topbar { display: none; }
	.kw-nav-desktop { display: none; }
	.kw-burger { display: flex !important; }
	.kw-header-cta { display: none; }  /* CTA wandert in Drawer via JS */
}
@media (min-width: 880px) {
	.kw-burger { display: none !important; }
}

/* === Archive Card-Grid Responsive (Issue #261) ===
   Mobile-First: 1 Spalte <600px, 2 Spalten 600–879px, 3 Spalten ≥880px.
   Karten dürfen nicht überlappen / Text nicht abgeschnitten werden. */
@media (max-width: 879px) {
	.kw-archive .kw-card-grid,
	.kw-swf__grid {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 16px !important;
	}
	.kw-swf__grid .kw-card,
	.kw-archive .kw-card {
		max-width: none;
		width: 100%;
	}
	.kw-swf__grid .kw-card__body,
	.kw-archive .kw-card__body {
		padding: 14px 16px;
	}
}
@media (max-width: 599px) {
	.kw-archive .kw-card-grid,
	.kw-swf__grid {
		grid-template-columns: 1fr !important;
		gap: 16px !important;
	}
	.kw-swf__grid .kw-card,
	.kw-archive .kw-card {
		max-width: 420px;
		margin-left: auto;
		margin-right: auto;
	}
	.kw-swf__grid .kw-card__image,
	.kw-archive .kw-card__image {
		/* Mobile: gleicher Freisteller-Ratio wie Desktop (Issue #317). */
		aspect-ratio: 4 / 5;
	}
	.kw-archive .kw-card__title { font-size: 19px; }
	.kw-archive .kw-card__tagline { font-size: 14px; line-height: 1.5; }
	.kw-archive .kw-card__badges { flex-wrap: wrap; gap: 6px; }
	.kw-archive__hero h1 { font-size: 30px; }
}
