/*
 * Design-Tokens, abgeleitet aus der Produktion immobilien-sofortkauf.de
 * (OceanWP-Primary + Elementor-Global-Kit, Stand 16.06.2026):
 *   Marken-Rot #c02a2a · Rot dunkel #990b01 · Gold #fed022 · Ink #141414
 *   Body „Roboto", Headings „Roboto Slab".
 */
:root {
	--hcms-brand: #c0423c;
	--hcms-brand-dark: #990b01;
	--hcms-gold: #fed022;
	--hcms-ink: #141414;
	--hcms-muted: #5b5b5b;
	--hcms-line: rgba(0, 0, 0, 0.1);
	--hcms-surface: #ffffff;
	--hcms-subtle: #f5f5f5;
	--hcms-brand-tint: #f6e9e9;
	--hcms-font-body: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
	--hcms-font-head: "Roboto Slab", Georgia, "Times New Roman", serif;
	/* immonex-Card-Schrift der Produktion */
	--hcms-font-card: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.herbert-cms-grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(var(--hcms-cols, 3), minmax(0, 1fr));
}
.herbert-cms-grid.cols-1 { --hcms-cols: 1; }
.herbert-cms-grid.cols-2 { --hcms-cols: 2; }
.herbert-cms-grid.cols-3 { --hcms-cols: 3; }
.herbert-cms-grid.cols-4 { --hcms-cols: 4; }
.herbert-cms-grid.cols-5 { --hcms-cols: 5; }
.herbert-cms-grid.cols-6 { --hcms-cols: 6; }

@media (max-width: 1024px) { .herbert-cms-grid { --hcms-cols: 2; } }
@media (max-width: 600px) { .herbert-cms-grid { --hcms-cols: 1; } }

.herbert-cms-card {
	border: 0;
	border-radius: 0 0 8px 8px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
	display: flex;
	flex-direction: column;
}
.herbert-cms-card__media { position: relative; aspect-ratio: 1.46; background: #f2f2f2; overflow: hidden; }
.herbert-cms-card__media.is-portrait { aspect-ratio: 1 / 1; }
.herbert-cms-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Blurred-Fill: unscharfer Hintergrund + scharfes Foto (contain), nichts abgeschnitten */
.herbert-cms-card__media-fill {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-size: cover;
	background-position: center;
	filter: blur(16px) saturate(1.15);
	transform: scale(1.18);
}
.herbert-cms-card__media .herbert-cms-card__media-img {
	position: absolute;
	inset: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	object-fit: contain;
	aspect-ratio: auto;
}
.herbert-cms-card__body { padding: 0.9rem 1rem 1.1rem; }
.herbert-cms-card__title { margin: 0 0 0.25rem; font-family: var(--hcms-font-card); font-weight: 700; font-size: 0.88rem; line-height: 1.4; }
.herbert-cms-card__title a { text-decoration: none; color: var(--hcms-ink); }
.herbert-cms-card__title a:hover { color: var(--hcms-brand); }
.herbert-cms-card__meta { margin: 0 0 0.5rem; color: #666; font-size: 0.9rem; }
.herbert-cms-card__facts { display: flex; gap: 0.75rem; font-weight: 600; margin: 0; }
.herbert-cms-card__facts .price { color: var(--hcms-brand-dark); }
.herbert-cms-card__desc { margin: 0.4rem 0 0; color: #444; font-size: 0.9rem; }
.herbert-cms-empty { color: #666; font-style: italic; }
.herbert-cms-error {
	border: 1px solid #d63638;
	background: #fcf0f1;
	color: #8a1f21;
	padding: 0.5rem 0.75rem;
	border-radius: 4px;
	font-size: 0.9rem;
}

.herbert-cms-shell {
	width: min(1180px, calc(100% - 2rem));
	margin: 2rem auto 4rem;
	font-family: var(--hcms-font-body);
	color: var(--hcms-ink);
}

.herbert-cms-page-header,
.herbert-cms-detail__header {
	margin-bottom: 1.5rem;
}

.herbert-cms-kicker {
	margin: 0 0 0.45rem;
	color: var(--hcms-brand);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.herbert-cms-page-title {
	margin: 0;
	font-family: var(--hcms-font-head);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.5rem);
	line-height: 1.04;
	color: var(--hcms-ink);
}

.herbert-cms-page-lead {
	margin: 0.6rem 0 0;
	max-width: 60ch;
	color: #555;
	font-size: 1.05rem;
	line-height: 1.6;
}

.herbert-cms-archive {
	margin-top: 1.75rem;
}

.herbert-cms-card--local .herbert-cms-card__media {
	display: block;
	text-decoration: none;
}

.herbert-cms-card--local .herbert-cms-card__media img {
	aspect-ratio: 4 / 3;
}

.herbert-cms-detail {
	display: grid;
	grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.8fr);
	gap: 1.5rem;
	align-items: start;
}

.herbert-cms-detail__image,
.herbert-cms-detail__image--empty {
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: 14px;
	background: #f2f2f2;
	object-fit: cover;
	display: grid;
	place-items: center;
	color: #666;
	font-weight: 600;
}

.herbert-cms-detail__sidebar {
	padding: 1.1rem 1.15rem 1.25rem;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
}

.herbert-cms-detail__price strong {
	display: block;
	font-family: var(--hcms-font-head);
	font-size: 1.85rem;
	line-height: 1.1;
	color: var(--hcms-brand-dark);
}

.herbert-cms-detail__facts {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.55rem 0.9rem;
	margin: 1rem 0 0;
}

.herbert-cms-detail__facts dt {
	color: #666;
	font-weight: 600;
}

.herbert-cms-detail__facts dd {
	margin: 0;
	font-weight: 700;
}

.herbert-cms-detail__content {
	margin-top: 1.5rem;
	padding: 1.25rem 0 0;
	font-size: 1.03rem;
	line-height: 1.75;
}

.herbert-cms-detail__back {
	margin: 1.25rem 0 0;
}
.herbert-cms-detail__back a,
.herbert-cms-empty a { color: var(--hcms-brand); font-weight: 600; }
.herbert-cms-detail__back a:hover,
.herbert-cms-empty a:hover { color: var(--hcms-brand-dark); }

@media (max-width: 900px) {
	.herbert-cms-detail {
		grid-template-columns: 1fr;
	}
}

/* Taxonomie-Badges (Single-Header + Card-Overlay) */
.herbert-cms-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0.9rem 0 0;
	padding: 0;
	list-style: none;
}
.herbert-cms-badges li { margin: 0; }
.herbert-cms-badge {
	display: inline-block;
	padding: 0.28rem 0.7rem;
	border-radius: 999px;
	background: var(--hcms-brand-tint);
	color: var(--hcms-brand-dark);
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-decoration: none;
	line-height: 1.2;
}
a.herbert-cms-badge:hover { background: var(--hcms-brand); color: #fff; }

.herbert-cms-card__media { position: relative; }
.herbert-cms-badge--overlay {
	position: absolute;
	top: 0.6rem;
	left: 0.6rem;
	z-index: 2;
	background: var(--hcms-brand);
	color: #fff;
}

/* ----------------------------------------------------------------- */
/* Teaser-Card im immonex-Stil ([herbert_properties])                 */
/* ----------------------------------------------------------------- */
.herbert-cms-card--teaser { font-family: var(--hcms-font-card); color: #666; }
.herbert-cms-card--teaser .herbert-cms-card__media { aspect-ratio: 1.46; display: block; }
/* Produktion nutzt object-fit:cover (Beschnitt) — kein Blurred-Fill */
.herbert-cms-card--teaser .herbert-cms-card__media-fill { display: none; }
.herbert-cms-card--teaser .herbert-cms-card__media .herbert-cms-card__media-img {
	position: static;
	object-fit: cover;
	aspect-ratio: auto;
}

/* Ribbon „ZU VERKAUFEN" oben rechts */
.herbert-cms-ribbon {
	position: absolute;
	top: 0.85rem;
	right: 0;
	z-index: 2;
	background: #c0423c;
	color: #fff;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0.3rem 0.7rem;
}

/* Body */
.herbert-cms-card--teaser .herbert-cms-card__body { flex: 1 1 auto; padding: 1rem; }

.herbert-cms-card--teaser .herbert-cms-card__title { margin-bottom: 0.45rem; font-size: 0.88rem; line-height: 1.4; }
.herbert-cms-card--teaser .herbert-cms-card__title,
.herbert-cms-card--teaser .herbert-cms-card__title a { font-family: var(--hcms-font-card); color: #ba2a2a; }
.herbert-cms-card--teaser .herbert-cms-card__title a:hover { color: #9e2424; }

/* Typ-/Ort-Zeilen mit Icon (klein, grau wie Produktion) */
.herbert-cms-card__line {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	margin: 0 0 0.25rem;
	color: #666;
	font-size: 0.8rem;
}
.hcms-ic { width: 0.95rem; height: 0.95rem; flex: 0 0 auto; color: #666; }

.herbert-cms-card--teaser .herbert-cms-card__desc {
	margin: 0.7rem 0 0;
	color: #666;
	font-size: 0.8rem;
	line-height: 1.6;
}

/* Faktenzeile: Fläche · Grundstück · Zimmer (Footer mit Trennlinie) */
.herbert-cms-card__iconfacts {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	gap: 0.4rem 0.6rem;
	margin: 0.85rem 0 0;
	padding: 0.85rem 0 0;
	border-top: 1px solid #e5e5e5;
	list-style: none;
}
.herbert-cms-card__iconfacts li {
	display: flex;
	align-items: center;
	gap: 0.3rem;
	margin: 0;
	color: #666;
	font-size: 0.8rem;
	font-weight: 400;
}
.herbert-cms-card__iconfacts .hcms-ic { width: 0.95rem; height: 0.95rem; color: #666; }

/* Preisbalken unten (immonex-Gradient, weiß zentriert) */
.herbert-cms-card__pricebar {
	display: block;
	margin-top: auto;
	background: linear-gradient(60deg, #d13535 50%, #9e2424);
	color: #f8f8f8;
	text-align: center;
	font-family: var(--hcms-font-card);
	font-weight: 600;
	font-size: 0.82rem;
	padding: 0.45rem 1rem;
	text-decoration: none;
}
.herbert-cms-card__pricebar:hover { filter: brightness(0.95); color: #fff; }

/* Galerie unter dem Hero */
.herbert-cms-detail__gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.6rem;
	margin: 0.75rem 0 0;
	padding: 0;
	list-style: none;
}
.herbert-cms-gallery__item { margin: 0; }
.herbert-cms-gallery__item a {
	display: block;
	aspect-ratio: 4 / 3;
	border-radius: 8px;
	overflow: hidden;
	background: #f2f2f2;
}
.herbert-cms-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
@media (max-width: 600px) {
	.herbert-cms-detail__gallery { grid-template-columns: repeat(3, 1fr); }
}

/* Ausstattungsliste in der Sidebar */
.herbert-cms-detail__features { margin: 1.1rem 0 0; }
.herbert-cms-features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	margin: 0.5rem 0 0;
	padding: 0;
	list-style: none;
}
.herbert-cms-features li {
	padding: 0.22rem 0.6rem;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	font-size: 0.85rem;
	color: #444;
}

/* === Referenzen-Landing-Slider: 1:1 von Produktion übernommen ============
   Quelle: immobilien-sofortkauf.de /wp-content/plugins/moern-referenzen/
   assets/css/frontend.css. NICHT nachgebaut/geraten — exakt repliziert.
   Home-Shortcode [moern_referenzen_small] rendert dieses Markup. */
.moern-reference-card {
	border: 1px solid #e5e5e5;
	padding: 12px;
	background: #fff;
}
.moern-reference-media img {
	width: 100%;
	height: auto;
	display: block;
}
.moern-reference-rating {
	margin-top: 10px;
	color: #f2a900;
	font-size: 20px;
	line-height: 1;
}
.moern-reference-text {
	margin: 12px 0 0;
	font-family: var(--moern-font-family, inherit);
	font-size: var(--moern-font-size, 16px);
	line-height: var(--moern-line-height, 1.5);
	font-weight: var(--moern-font-weight, 400);
	font-style: var(--moern-font-style, normal);
	color: var(--moern-text-color, #222222);
	text-align: var(--moern-text-align, left);
	max-height: var(--moern-text-max-height, 160px);
	overflow-y: auto;
	padding-right: 6px;
}
.moern-landing-slider {
	--moern-landing-visible: 3;
	--moern-landing-gap: 16px;
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 12px;
	align-items: center;
	margin: 28px 0;
}
.moern-landing-viewport {
	overflow: hidden;
}
.moern-landing-track {
	display: flex;
	gap: var(--moern-landing-gap, 16px);
	transition: transform 0.45s ease;
	will-change: transform;
}
.moern-landing-track .moern-reference-card {
	flex: 0 0 calc((100% - (var(--moern-landing-gap, 16px) * (var(--moern-landing-visible, 3) - 1))) / var(--moern-landing-visible, 3));
	box-sizing: border-box;
}
.moern-landing-arrow {
	width: 42px;
	height: 42px;
	border-radius: 999px;
	border: 1px solid #d0d0d0;
	background: #fff;
	color: #111;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	line-height: 1;
}
.moern-landing-arrow:hover,
.moern-landing-arrow:focus-visible {
	border-color: #222;
	outline: none;
}
@media (max-width: 700px) {
	.moern-landing-slider {
		grid-template-columns: 1fr;
	}
	.moern-landing-slider .moern-landing-arrow {
		display: none;
	}
}
/* Grid-Layout der Referenzen-Seite /referenzen/ (ebenfalls 1:1 von Produktion). */
.moern-referenzen {
	display: grid;
	gap: 20px;
	margin: 24px 0;
}
.moern-layout-grid {
	grid-template-columns: repeat(var(--moern-columns, 3), minmax(0, 1fr));
}
.moern-layout-list {
	grid-template-columns: 1fr;
}
.moern-layout-list .moern-reference-card {
	width: min(100%, var(--moern-list-width, 100%));
	margin: 0 auto;
}
.moern-pagination ul {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	gap: 8px;
	padding: 0;
}
@media (max-width: 900px) {
	.moern-layout-grid {
		grid-template-columns: 1fr;
	}
}
