/* MG ImmoConnect – Frontend (v0.2)
 * Konsumiert ausschließlich die --mgic-* Tokens aus theme.css (ACSS-bewusst).
 * Drei List-View-Templates: .mgic-card--classic | --overlay | --editorial
 * -------------------------------------------------------------------------- */

.mgic { color: var(--mgic-text); font-family: var(--mgic-body-font); }

/* Spezifität-Schutz: Theme-/ACSS-Heading-Styles (h2/h3 …) dürfen unsere Card-/Block-Typo NICHT
   überschreiben. Mit .mgic-Präfix gewinnen unsere Token-basierten Größen/Farben zuverlässig. */
.mgic .mgic-card__title { font-family: var(--mgic-heading-font); font-size: var(--mgic-title-size); font-weight: 700; line-height: 1.3; color: var(--mgic-card-title-color, var(--mgic-heading)); margin: 0; overflow-wrap: anywhere; }
.mgic .mgic-card--editorial .mgic-card__title { font-size: var(--h4, var(--mgic-title-size)); }
.mgic .mgic-card--overlay .mgic-card__title { color: var(--mgic-card-title-color, #fff); }
.mgic .mgic-price { font-size: var(--mgic-price-size); color: var(--mgic-card-price-color, var(--mgic-primary)); }
.mgic .mgic-card--classic .mgic-price { font-size: var(--text-l, var(--mgic-price-size)); }
.mgic .mgic-block h2, .mgic .mgic-cta h2 { font-size: var(--mgic-h2); color: var(--mgic-heading); }
.mgic .mgic-block h3 { font-size: var(--mgic-h3); color: var(--mgic-heading); }
.mgic .mgic-single__title { font-size: var(--mgic-h1); color: var(--mgic-heading); }
.mgic *, .mgic *::before, .mgic *::after { box-sizing: border-box; }

/* ----- Grid ----------------------------------------------------------------*/
.mgic-list { display: grid; gap: var(--mgic-gap); grid-template-columns: repeat(3, 1fr); }
.mgic-cols-1 { grid-template-columns: 1fr; }
.mgic-cols-2 { grid-template-columns: repeat(2, 1fr); }
.mgic-cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) { .mgic-list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .mgic-list { grid-template-columns: 1fr; } }
.mgic-empty { color: var(--mgic-text-muted); grid-column: 1 / -1; }

/* Pagination – schlichte Leiste: nur border-top + Padding, randlose Buttons (keine Boxen). */
.mgic-pagination { margin-top: var(--space-l, 2rem); padding-top: 18px; border-top: 1px solid var(--mgic-border); }
.mgic-pagination ul.page-numbers { list-style: none; display: flex; flex-wrap: wrap; gap: 4px; padding: 0; margin: 0; justify-content: center; }
.mgic-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px; border: 0; border-radius: var(--mgic-radius-s); background: transparent; color: var(--mgic-text); text-decoration: none; font-weight: 600; font-size: var(--mgic-fact-size); transition: background .15s ease, color .15s ease; }
.mgic-pagination a.page-numbers:hover { background: var(--mgic-surface-alt); color: var(--mgic-primary); }
.mgic-pagination .page-numbers.current { background: var(--mgic-primary); color: var(--mgic-primary-contrast); }
.mgic-pagination .page-numbers.dots { background: transparent; }

/* ----- Gemeinsame Card-Basis ----------------------------------------------*/
.mgic-card {
	position: relative;
	background: var(--mgic-card-surface, var(--mgic-surface));
	border: 1px solid var(--mgic-border);
	border-radius: var(--mgic-radius);
	overflow: hidden;
	transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.mgic-card:hover { box-shadow: var(--mgic-shadow-hover); transform: translateY(-3px); }
.mgic-card a { color: inherit; text-decoration: none; }
.mgic-card__media { position: relative; display: block; aspect-ratio: 4 / 3; background: var(--mgic-surface-alt); }
/* Gesperrte Detailseiten (z. B. Referenzen ohne Einzelansicht): Card ist nicht verlinkt -> kein Klick-Cursor. */
.mgic-card a:not([href]) { cursor: default; }
.mgic-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mgic-card__noimage { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }

.mgic-badge {
	position: absolute; top: 14px; left: 14px;
	display: inline-flex; align-items: center; gap: .35em;
	background: var(--mgic-card-badge-bg, var(--mgic-primary)); color: var(--mgic-primary-contrast);
	font-size: var(--mgic-fact-size); font-weight: 700; letter-spacing: .02em;
	padding: .4em .85em; border-radius: var(--mgic-radius-pill);
}
.mgic-badge--rent { background: var(--mgic-heading); }
/* Status-Farben: zu verkaufen/vermieten = grün, reserviert = orange, verkauft/vermietet = rot. */
.mgic-badge--available { background: var(--success, #1a7f37); color: #fff; }
.mgic-badge--reserved { background: var(--warning, #e8a72e); color: var(--primary-ultra-dark, #3d2a00); }
.mgic-badge--sold { background: var(--danger, #c92a2a); color: #fff; }
/* Marketing-Badges (zusätzlich zum Status), aus CRM-user_defined-Flags. Sitzen links unter dem Status-Badge. */
.mgic-flags { position: absolute; top: 50px; left: 14px; display: flex; flex-wrap: wrap; gap: 6px; max-width: 72%; z-index: 2; pointer-events: none; }
.mgic-flag { font-size: 11px; font-weight: 700; letter-spacing: .02em; line-height: 1.3; padding: 3px 8px; border-radius: var(--mgic-radius-pill); color: #fff; background: var(--mgic-primary); box-shadow: 0 1px 4px rgba(0,0,0,.18); }
.mgic-flag--courtagefrei { background: var(--success, #1a7f37); }
.mgic-flag--preisreduziert { background: #d6453d; }
.mgic-flag--neu { background: #2563eb; }
.mgic-flag--top { background: var(--mgic-card-badge-bg, var(--mgic-primary)); color: var(--mgic-primary-contrast); }
.mgic-flag--exklusiv { background: #1f2430; }
.mgic-flag--tagesangebot { background: #7c3aed; }
/* Detailseiten-Status-Pillen einheitlich zur Übersicht einfärben (Pill + psum-Statuspunkt). */
.mgic-pill.mgic-status--available { background: var(--success, #1a7f37); color: #fff; }
.mgic-pill.mgic-status--reserved { background: var(--warning, #e8a72e); color: var(--primary-ultra-dark, #3d2a00); }
.mgic-pill.mgic-status--sold { background: var(--danger, #c92a2a); color: #fff; }
.mgic-psum__status.mgic-status--reserved::before { background: var(--warning, #e8a72e); }
.mgic-psum__status.mgic-status--sold::before { background: var(--danger, #c92a2a); }
.mgic .mgic-card__loc { display: flex; align-items: center; gap: 5px; margin: 8px 0 0; color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }
.mgic .mgic-card__loc .mgic-ico { width: 15px; height: 15px; flex: 0 0 auto; }

.mgic-fav {
	position: absolute; top: 12px; right: 12px; z-index: 3;
	width: 36px; height: 36px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(255,255,255,.95); color: var(--mgic-primary);
	border: 0; cursor: pointer; box-shadow: var(--mgic-shadow);
	transition: background .15s ease, transform .15s ease;
}
.mgic-fav:hover { transform: scale(1.08); background: #fff; }
.mgic-fav svg { width: 18px; height: 18px; }
.mgic-photocount {
	position: absolute; bottom: 12px; right: 12px; z-index: 3;
	background: rgba(0,0,0,.6); color: #fff; font-size: var(--mgic-fact-size); font-weight: 600;
	padding: .35em .7em; border-radius: var(--mgic-radius-pill);
	display: inline-flex; align-items: center; gap: .4em; backdrop-filter: blur(2px);
}
.mgic-photocount svg { width: 14px; height: 14px; }

/* Fakten-Zeile (Betten / Bäder / Fläche) – in allen Templates gleich --------*/
.mgic-facts { display: flex; flex-wrap: wrap; gap: var(--mgic-pad-s); align-items: center; }
.mgic-fact { display: inline-flex; align-items: center; gap: .45em; font-size: var(--mgic-fact-size); color: var(--mgic-card-meta-color, var(--mgic-text-muted)); font-weight: 500; }
.mgic-fact svg { width: 1.2em; height: 1.2em; flex: none; stroke: currentColor; }
.mgic-price { font-size: var(--mgic-price-size); font-weight: 800; color: var(--mgic-card-price-color, var(--mgic-primary)); line-height: 1.1; white-space: nowrap; }
/* „/ Monat"-Zusatz bei Mietobjekten – dezenter als der Preis, erbt dessen Farbe. */
.mgic-price__period { font-size: .55em; font-weight: 600; opacity: .8; white-space: nowrap; }
.mgic-card--classic .mgic-card__row { flex-wrap: wrap; }
.mgic-card__title { font-family: var(--mgic-heading-font); font-size: var(--mgic-title-size); font-weight: 700; color: var(--mgic-card-title-color, var(--mgic-heading)); margin: 0; line-height: 1.3; overflow-wrap: anywhere; }
.mgic-card__loc { display: inline-flex; align-items: center; gap: .35em; color: var(--mgic-card-meta-color, var(--mgic-text-muted)); font-size: var(--mgic-fact-size); }
.mgic-card__loc svg { width: 1em; height: 1em; stroke: currentColor; }

/* ===========================================================================
   TEMPLATE 1 – CLASSIC  (hell, luftig; klare Hierarchie: Titel → Preis → Lage → Fakten)
   =========================================================================*/
.mgic-card--classic .mgic-card__body { padding: var(--mgic-pad); display: grid; gap: var(--space-s, .5rem); }
/* Titel + Preis untereinander stapeln (Preis prominent), nicht nebeneinander gedrückt. */
.mgic-card--classic .mgic-card__row { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-s, .5rem); }
.mgic-card--classic .mgic-card__title { font-size: var(--mgic-title-size); line-height: 1.3; }
.mgic-card--classic .mgic-price { font-size: var(--text-l, var(--mgic-price-size)); }
.mgic-card--classic .mgic-card__loc { margin-top: -.1rem; }
.mgic-card--classic .mgic-facts { margin-top: .25rem; padding-top: .85rem; border-top: 1px solid var(--mgic-border); }

/* Aktiver Merken-Zustand (Herz gefüllt). */
.mgic-fav.is-active { color: #e3344d; }
.mgic-fav.is-active svg { fill: currentColor; }
/* Merkliste-Ansicht ([mgic-favorites]) */
.mgic-favorites__empty { padding: 32px 24px; text-align: center; color: var(--mgic-text-muted, #5b6573); background: var(--mgic-surface-alt, #f4f5f7); border-radius: var(--mgic-radius, 14px); font-size: var(--mgic-label-size, 1rem); }

/* ===========================================================================
   TEMPLATE – MINIMAL  (clean, Airbnb-Stil: Bild + Merken, Titel, Ort, Chip-Pills, Preis)
   =========================================================================*/
.mgic-card--minimal { border-color: var(--mgic-border); border-radius: var(--mgic-radius); }
.mgic-card--minimal .mgic-card__media { aspect-ratio: 16 / 11; }
.mgic-card--minimal .mgic-card__body { padding: 14px 16px 16px; display: grid; gap: 8px; }
.mgic-card--minimal .mgic-card__title { font-size: var(--mgic-title-size); line-height: 1.25; margin: 0; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
.mgic-card--minimal .mgic-card__loc { display: block; color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); margin: -2px 0 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mgic-card--minimal .mgic-card__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.mgic-card--minimal .mgic-card__chip { display: inline-flex; align-items: center; gap: .45em; font-size: var(--mgic-fact-size); color: var(--mgic-text); font-weight: 500; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); padding: .35em .7em; }
.mgic-card--minimal .mgic-card__chip svg { width: 1.15em; height: 1.15em; flex: none; color: var(--mgic-text-muted); stroke: currentColor; }
.mgic-card--minimal .mgic-card__foot { margin-top: 4px; padding-top: 12px; border-top: 1px solid var(--mgic-border); }
.mgic-card--minimal .mgic-price small { font-size: .62em; font-weight: 600; color: var(--mgic-text-muted); }

/* ===========================================================================
   TEMPLATE 2 – OVERLAY  (Premium; Preis/Titel auf dem Bild, Fakten-Leiste unten)
   =========================================================================*/
.mgic-card--overlay .mgic-card__media { aspect-ratio: 3 / 2.3; }
.mgic-card--overlay .mgic-card__media::after {
	content: ""; position: absolute; inset: 0; z-index: 1;
	background: linear-gradient(to top, rgba(15,20,30,.88) 0%, rgba(15,20,30,.45) 32%, rgba(15,20,30,0) 62%);
}
.mgic-card--overlay .mgic-card__overlay {
	position: absolute; left: 16px; right: 16px; bottom: 14px; z-index: 2; color: #fff;
	display: flex; flex-direction: column; gap: 4px;
}
.mgic-card--overlay .mgic-card__overlay .mgic-card__loc {
	order: -1; align-self: flex-start; color: #fff;
	background: rgba(0,0,0,.4); backdrop-filter: blur(4px);
	padding: .3em .7em; border-radius: var(--mgic-radius-pill); margin-bottom: 4px;
}
.mgic-card--overlay .mgic-card__title { color: var(--mgic-card-title-color, #fff); font-size: var(--mgic-title-size); line-height: 1.2;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
	text-shadow: 0 1px 12px rgba(0,0,0,.4); }
.mgic-card--overlay .mgic-price { color: var(--mgic-card-price-color, #fff); font-size: var(--mgic-price-size); margin-top: 2px; text-shadow: 0 1px 12px rgba(0,0,0,.45); }
/* Footer = schlichte Leiste (border-top, keine Box): Ansprechpartner oben rechts, Attribute darunter. */
.mgic-card--overlay .mgic-card__footer {
	display: flex; flex-direction: column; gap: 10px;
	padding: 11px var(--mgic-pad) 14px; border-top: 1px solid var(--mgic-border);
}
.mgic-card--overlay .mgic-card__agent {
	align-self: flex-end; order: -1;
	font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); white-space: nowrap;
	max-width: 100%; overflow: hidden; text-overflow: ellipsis;
}
.mgic-card--overlay .mgic-card__agent::before { content: "👤"; margin-right: .35em; opacity: .6; font-size: .85em; }
.mgic-card--overlay .mgic-facts { gap: 8px 16px; }
/* Im Overlay liegen Preis/Titel unten -> Foto-Zähler + Merken nach oben. */
.mgic-card--overlay .mgic-photocount { top: 12px; bottom: auto; right: 12px; }
.mgic-card--overlay .mgic-fav { right: 60px; }

/* ===========================================================================
   TEMPLATE 3 – EDITORIAL  (Magazin; großer Titel, Excerpt, Footer mit Trennern)
   =========================================================================*/
.mgic-card--editorial { border: 0; background: var(--mgic-card-surface, transparent); overflow: visible; }
/* Karte selbst nicht anheben – die Bewegung passiert auf dem Bild (Zoom + leichter Tilt). */
.mgic-card--editorial:hover { transform: none; box-shadow: none; }
.mgic-card--editorial .mgic-card__media { border-radius: var(--mgic-radius); aspect-ratio: 16 / 10; overflow: hidden; transition: box-shadow .35s ease, transform .45s cubic-bezier(.2,.7,.2,1); }
.mgic-card--editorial .mgic-card__media img { transition: transform .55s cubic-bezier(.2,.7,.2,1); transform-origin: 50% 55%; will-change: transform; }
/* Moderner, weicher Schatten + leichter Zoom & Tilt auf dem Bild. */
.mgic-card--editorial:hover .mgic-card__media { box-shadow: 0 22px 45px -18px rgba(20,28,45,.40), 0 8px 18px -10px rgba(20,28,45,.25); transform: translateY(-3px); }
.mgic-card--editorial:hover .mgic-card__media img { transform: scale(1.07) rotate(-1.5deg); }
@media (prefers-reduced-motion: reduce) {
	.mgic-card--editorial .mgic-card__media, .mgic-card--editorial .mgic-card__media img { transition: none; }
	.mgic-card--editorial:hover .mgic-card__media img { transform: none; }
}
.mgic-card--editorial .mgic-card__body { padding: var(--mgic-pad) 2px 2px; display: grid; gap: var(--space-s, .5rem); }
.mgic-card--editorial .mgic-card__priceline { display: flex; align-items: center; gap: var(--space-s, .8rem); }
.mgic-card--editorial .mgic-card__time { font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); }
.mgic-card--editorial .mgic-card__title { font-size: var(--h4, var(--mgic-title-size)); }
.mgic-card--editorial .mgic-card__excerpt { color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); line-height: 1.55; margin: 0;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mgic-card--editorial .mgic-facts { margin-top: .4rem; border-top: 1px solid var(--mgic-border); padding-top: .8rem; gap: 0; }
.mgic-card--editorial .mgic-fact { padding: 0 1rem; border-left: 1px solid var(--mgic-border); }
.mgic-card--editorial .mgic-fact:first-child { padding-left: 0; border-left: 0; }

/* ===========================================================================
   TEMPLATE – GLASS V1  (Vollbild-Foto, Glassmorphism-Panel, Ansprechpartner-Pill)
   =========================================================================*/
.mgic-card--glassv1 { position: relative; border: 0; border-radius: 20px; overflow: hidden; background: var(--mgic-surface-alt); }
.mgic-card--glassv1 .mgic-card__media { aspect-ratio: 4 / 3.5; border-radius: 20px; }
.mgic-card--glassv1 .mgic-card__media::after {
	content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
	background: linear-gradient(to top, rgba(15,20,30,.30) 0%, rgba(15,20,30,0) 42%);
}
/* Ansprechpartner-Pill oben rechts (Glas). */
.mgic-card--glassv1 .mgic-card__agentpill {
	position: absolute; top: 14px; right: 58px; z-index: 4; max-width: calc(100% - 72px);
	display: inline-flex; align-items: center; gap: 8px; padding: 5px 13px 5px 5px;
	background: rgba(20,24,32,.28); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
	border: 1px solid rgba(255,255,255,.22); border-radius: 999px; box-shadow: 0 4px 16px rgba(0,0,0,.18);
	color: var(--white, #fff); font-weight: 600; font-size: var(--mgic-fact-size); line-height: 1;
	text-shadow: 0 1px 6px rgba(0,0,0,.35);
}
.mgic-card--glassv1 .mgic-card__agentpill .mgic-avatar { width: 32px; height: 32px; }
.mgic-card--glassv1 .mgic-card__agentpill .mgic-avatar--initials { font-size: .8rem; }
.mgic-card--glassv1 .mgic-card__agentname { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* Merken-Herz rechts NEBEN der Ansprechpartner-Pill (beide in der oberen Reihe). */
.mgic-card--glassv1 .mgic-fav { top: 16px; right: 14px; }
/* Glas-Panel unten. */
.mgic-card--glassv1 .mgic-card__glass {
	position: absolute; left: 14px; right: 14px; bottom: 14px; z-index: 3;
	display: grid; gap: 5px; padding: 15px 17px;
	background: rgb(255 255 255 / 10%); backdrop-filter: blur(27px); -webkit-backdrop-filter: blur(27px);
	border: 1px solid rgba(255,255,255,.20); border-radius: var(--radius, 18px); overflow: hidden;
	box-shadow: 0 8px 32px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.5), inset 0 -1px 0 rgba(255,255,255,.1);
}
/* Oberer Licht-Rand (wie in der Vorlage). */
.mgic-card--glassv1 .mgic-card__glass::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; pointer-events: none;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.8), transparent);
}
/* Linker Licht-Rand. */
.mgic-card--glassv1 .mgic-card__glass::after {
	content: ""; position: absolute; top: 0; left: 0; width: 1px; height: 100%; pointer-events: none;
	background: linear-gradient(180deg, rgba(255,255,255,.8), transparent, rgba(255,255,255,.3));
}
.mgic-card--glassv1 .mgic-card__title {
	font-size: var(--h4, var(--mgic-title-size)); line-height: 1.2; margin: 0;
	color: var(--white, #fff); text-shadow: 0 1px 10px rgba(0,0,0,.45);
	display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
}
.mgic-card--glassv1 .mgic-card__title a { color: inherit; }
.mgic-card--glassv1 .mgic-card__loc { color: var(--white, #fff); font-weight: 500; text-shadow: 0 1px 8px rgba(0,0,0,.4); }
.mgic-card--glassv1 .mgic-card__loc svg { opacity: .95; }
.mgic-card--glassv1 .mgic-card__glassrow { display: flex; align-items: center; gap: 10px; margin-top: 3px; min-height: 26px; }
.mgic-card--glassv1 .mgic-card__glassrow .mgic-eclass--card { flex: 0 0 auto; }
.mgic-card--glassv1 .mgic-price {
	margin-left: auto; font-size: var(--h3, var(--mgic-price-size)); line-height: 1.1;
	color: var(--white, #fff); font-weight: 800; text-shadow: 0 1px 10px rgba(0,0,0,.45);
}

/* Card „Prestige" – Premium: Serif-Titel, Standort-Tab am Bild, Outline-Fakten, Footer Preis + Gold-CTA. */
.mgic-card--prestige { background: var(--mgic-card-surface, var(--mgic-surface, #fff)); border: 0; border-radius: var(--mgic-radius, 16px); box-shadow: var(--mgic-shadow); padding: var(--space-xs, .5rem); overflow: visible; }
.mgic-card--prestige .mgic-card__media { aspect-ratio: 16 / 11; border-radius: var(--mgic-radius, 14px); overflow: visible; position: relative; }
.mgic-card--prestige .mgic-card__media img { border-radius: var(--mgic-radius, 14px); }
.mgic-card--prestige .mgic-card__locpill {
	position: absolute; left: 0; bottom: 0; z-index: 2; display: inline-flex; align-items: center;
	column-gap: var(--space-xs, .5rem); padding: var(--space-xs, .4rem) var(--space-s, .8rem);
	background-color: var(--white, #fff); color: var(--mgic-heading); font-size: var(--mgic-fact-size);
	font-weight: 600; border-top-right-radius: var(--radius-m, 14px);
}
/* Standort-Pill „Notch": konkave Ecken via Kreis + Box-Shadow in Hintergrundfarbe (oben-links + unten-rechts). */
.mgic-card--prestige .mgic-card__locpill::before, .mgic-card--prestige .mgic-card__locpill::after {
	content: ''; position: absolute; width: calc(2 * var(--radius-value, 14px)); height: calc(2 * var(--radius-value, 14px));
	background-color: transparent; border-radius: 50%;
	box-shadow: calc(-1 * var(--radius-value, 14px)) var(--radius-value, 14px) var(--color-background, var(--white, #fff));
}
.mgic-card--prestige .mgic-card__locpill::before { top: 0; left: 0; transform: translateY(-100%); }
.mgic-card--prestige .mgic-card__locpill::after { right: 0; bottom: 0; transform: translateX(100%); }
.mgic-card--prestige .mgic-card__locpill svg { width: 1em; height: 1em; flex: 0 0 auto; }
.mgic-card--prestige .mgic-card__body { padding: var(--space-s, .85rem) 0 0; display: grid; gap: 10px; }
.mgic-card--prestige .mgic-card__title { font-family: inherit; font-size: var(--h4, 1.4rem); font-weight: 700; margin: 0; line-height: 1.2; }
.mgic-card--prestige .mgic-card__title a { color: var(--mgic-heading); text-decoration: none; }
.mgic-card--prestige .mgic-card__excerpt { color: var(--mgic-text-muted); margin: 0; font-size: var(--mgic-label-size); line-height: 1.5; }
.mgic-card--prestige .mgic-facts { display: flex; flex-wrap: wrap; gap: 10px; margin: 2px 0; }
.mgic-card--prestige .mgic-fact { border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-pill, 999px); padding: .5em 1.05em; background: var(--mgic-surface, #fff); font-weight: 600; }
.mgic-card--prestige .mgic-card__footer { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 6px; flex-wrap: wrap; }
.mgic-card--prestige .mgic-card__footer .mgic-price { font-size: var(--h4, 1.35rem); font-weight: 800; color: var(--mgic-heading); }
.mgic-card--prestige .mgic-card__cta {
	display: inline-flex; align-items: center; gap: .5em; background: var(--mgic-primary);
	color: var(--mgic-primary-contrast); font-weight: 700; padding: .8em 1.5em; border-radius: 8px;
	text-decoration: none; white-space: nowrap; transition: filter .15s ease;
}
.mgic-card--prestige .mgic-card__cta svg { width: 1.05em; height: 1.05em; }
.mgic-card--prestige .mgic-card__cta:hover { filter: brightness(.93); }

/* ===========================================================================
   SINGLE  (modernes Detailseiten-Layout)
   =========================================================================*/
/* Auf Content-Breite begrenzt und zentriert (wie der Rest der Seite). */
.mgic-single { width: 100%; max-width: var(--width-content, 1140px); margin-left: auto; margin-right: auto; }

/* Breadcrumb (alle Detail-Templates) – UX: Rückweg zur Objektübersicht.
   margin: 0 auto … behält die .mgic-single-Zentrierung (auto links/rechts), Gutter für Mobile. */
.mgic-breadcrumb {
	display: flex; align-items: center; flex-wrap: wrap; gap: 8px 16px;
	padding-inline: var(--gutter, 1rem); margin: 0 auto var(--space-s, .85rem);
	font-size: var(--mgic-fact-size); color: var(--mgic-text-muted);
}
.mgic-breadcrumb__back { display: inline-flex; align-items: center; gap: 4px; font-weight: 600; color: var(--mgic-primary); text-decoration: none; }
.mgic-breadcrumb__back:hover { text-decoration: underline; }
.mgic-breadcrumb__trail { display: inline-flex; align-items: center; flex-wrap: wrap; gap: 4px 8px; min-width: 0; }
.mgic-breadcrumb__crumb { display: inline-flex; align-items: center; gap: 5px; color: var(--mgic-text-muted); text-decoration: none; }
a.mgic-breadcrumb__crumb:hover { color: var(--mgic-primary); }
.mgic-breadcrumb__crumb--current { color: var(--mgic-heading); font-weight: 600; max-width: 46ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mgic-breadcrumb .mgic-ico { width: 1.05em; height: 1.05em; }
.mgic-breadcrumb__chev { display: inline-flex; color: var(--mgic-border); }
.mgic-breadcrumb__chev .mgic-ico { width: 14px; height: 14px; }
@media (max-width: 600px) { .mgic-breadcrumb__trail { display: none; } } /* mobil nur „Zurück" zeigen */

/* Sticky-Header-Offset: das erste MG-Element (Breadcrumb bzw. Portal-Top-Bar) unter einen
   überlappenden sticky/fixed Header schieben. Per KLASSE (nicht :first-child), weil unsere Sektionen
   im Bricks-Post-Content-Wrapper liegen und :first-child dort oft nicht greift. --mgic-header-offset
   kommt aus den Einstellungen (feste px) oder von Automatic.css (--header-height); Standard 0. */
.mgic-breadcrumb,
.mgic-portal-topbar { padding-top: var(--mgic-header-offset, 0px); }
/* In der Portal-Top-Bar steckt die Breadcrumb -> nur die Top-Bar bekommt den Offset, nicht doppelt. */
.mgic-portal-topbar .mgic-breadcrumb { padding-top: 0; }
/* Anker-Sprünge (#mgic-kontakt) nicht unter den Header rutschen lassen. */
.mgic-single[id], .mgic-single__contact, #mgic-kontakt { scroll-margin-top: calc(var(--mgic-header-offset, 0px) + 16px); }

/* Hero-Galerie (1 groß + 2 seitlich gestapelt) */
.mgic-gallery { display: grid; grid-template-columns: 2.1fr 1fr; gap: 10px; margin: 0; align-items: stretch; }
.mgic-gallery__hero { position: relative; padding: 0; border: 0; cursor: pointer; background: var(--mgic-surface-alt); border-radius: var(--mgic-radius); overflow: hidden; aspect-ratio: 3 / 2; }
.mgic-gallery__hero img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.mgic-gallery__hero:hover img { transform: scale(1.03); }
.mgic-gallery__hero .mgic-badge { top: 16px; left: 16px; z-index: 2; }
/* Flex statt Grid -> Seiten-Thumbs füllen exakt die Hero-Höhe (keine Versätze). */
.mgic-gallery__side { display: flex; flex-direction: column; gap: 10px; }
.mgic-gallery__thumb { position: relative; flex: 1 1 0; min-height: 0; padding: 0; border: 0; cursor: pointer; border-radius: var(--mgic-radius-s); overflow: hidden; background: var(--mgic-surface-alt); }
.mgic-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mgic-gallery__thumb.is-more::after { content: ""; position: absolute; inset: 0; background: rgba(15,20,30,.55); }
.mgic-gallery__count { position: absolute; inset: 0; z-index: 2; display: flex; align-items: center; justify-content: center; gap: .4em; color: #fff; font-weight: 700; font-size: var(--mgic-label-size); }
.mgic-gallery__count svg { width: 1.1em; height: 1.1em; }
@media (max-width: 780px) { .mgic-gallery { grid-template-columns: 1fr; } .mgic-gallery__side { flex-direction: row; } }

/* Lightbox */
.mgic-lightbox { position: fixed; inset: 0; z-index: 99999; background: rgba(10,14,20,.94); display: flex; align-items: center; justify-content: center; }
.mgic-lightbox[hidden] { display: none; }
.mgic-lightbox__content { display: flex; flex-direction: column; align-items: center; gap: 12px; max-width: 92vw; }
.mgic-lightbox__stage { margin: 0; text-align: center; }
.mgic-lightbox__stage img { max-width: 92vw; max-height: 74vh; object-fit: contain; border-radius: 6px; opacity: 0; transition: opacity .28s ease, transform .28s ease; transform: scale(.985); }
.mgic-lightbox__stage img.is-in { transform: scale(1); }
.mgic-lightbox__stage figcaption { color: rgba(255,255,255,.85); font-size: var(--mgic-label-size); margin-top: 10px; }
/* Thumbnail-Leiste: zeigt ~5-6 Kacheln, der Rest wird angeschnitten (Peek) und ist scroll-/wischbar.
   Heller, dezenter Custom-Scrollbalken; per Maus ziehbar, auf Touch natives Wischen. */
.mgic-lightbox__thumbs {
	display: flex; gap: 8px; max-width: min(92vw, 660px);
	overflow-x: auto; overflow-y: hidden; padding: 6px 2px 12px;
	scroll-behavior: smooth; scroll-snap-type: x proximity; cursor: grab;
	-webkit-overflow-scrolling: touch; overscroll-behavior-x: contain;
	scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.45) rgba(255,255,255,.12);
}
.mgic-lightbox__thumbs.is-dragging { cursor: grabbing; scroll-behavior: auto; }
.mgic-lightbox__thumbs::-webkit-scrollbar { height: 6px; }
.mgic-lightbox__thumbs::-webkit-scrollbar-track { background: rgba(255,255,255,.12); border-radius: 999px; }
.mgic-lightbox__thumbs::-webkit-scrollbar-thumb { background: rgba(255,255,255,.45); border-radius: 999px; }
.mgic-lightbox__thumbs::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.7); }
.mgic-lightbox__thumbs img {
	width: 92px; height: 64px; object-fit: cover; border-radius: 8px; cursor: pointer; flex: none;
	opacity: .55; border: 2px solid transparent; scroll-snap-align: center;
	transition: opacity .15s ease, border-color .15s ease, transform .15s ease;
	-webkit-user-drag: none; user-select: none;
}
.mgic-lightbox__thumbs img:hover { opacity: .9; transform: translateY(-2px); }
.mgic-lightbox__thumbs img.is-active { opacity: 1; border-color: #fff; transform: translateY(-2px); box-shadow: 0 4px 14px rgba(0,0,0,.4); }
@media (max-width: 600px) { .mgic-lightbox__thumbs img { width: 78px; height: 58px; } }
.mgic-lightbox__close { position: absolute; top: 18px; right: 24px; background: none; border: 0; color: #fff; font-size: var(--h1, 2.4rem); line-height: 1; cursor: pointer; z-index: 2; }
.mgic-lightbox__nav {
	position: absolute; top: 50%; transform: translateY(-50%);
	display: flex; align-items: center; justify-content: center;
	background: rgba(255,255,255,.14); color: #fff; border: 0;
	width: 56px; height: 56px; border-radius: 50%; cursor: pointer; z-index: 2;
	transition: background .15s ease;
}
.mgic-lightbox__nav:hover { background: rgba(255,255,255,.3); }
.mgic-lightbox__nav svg { width: 26px; height: 26px; stroke: #fff; stroke-width: 2.2; fill: none; }
.mgic-lightbox__prev { left: 3vw; }
.mgic-lightbox__next { right: 3vw; }
@media (max-width: 600px) { .mgic-lightbox__prev { left: 8px; } .mgic-lightbox__next { right: 8px; } .mgic-lightbox__nav { width: 44px; height: 44px; } }

/* Makler-Avatar (Foto oder Initialen) */
.mgic-avatar { border-radius: 50%; object-fit: cover; flex: none; }
.mgic-avatar--initials { display: inline-flex; align-items: center; justify-content: center; background: var(--mgic-surface-alt); color: var(--mgic-primary); font-weight: 700; font-size: 1rem; }

/* Layout: Inhalt + Sticky-Sidebar */
.mgic-single__layout { display: grid; grid-template-columns: 1fr 350px; gap: 40px; align-items: start; }
@media (max-width: 920px) { .mgic-single__layout { grid-template-columns: 1fr; } }

/* Header: Titel links, Preis rechts */
.mgic-single__header { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; padding-bottom: 22px; border-bottom: 1px solid var(--mgic-border); margin-bottom: 24px; }
.mgic-pill { display: inline-block; background: var(--mgic-surface-alt); color: var(--mgic-primary); font-weight: 700; font-size: var(--mgic-fact-size); padding: .35em .9em; border-radius: var(--mgic-radius-pill); margin-bottom: 12px; }
.mgic-single__title { font-family: var(--mgic-heading-font); font-size: var(--mgic-h1); line-height: 1.12; color: var(--mgic-heading); margin: 0 0 10px; }
.mgic-single__address { display: inline-flex; align-items: center; gap: .4em; color: var(--mgic-text-muted); font-size: var(--mgic-label-size); margin: 0; }
.mgic-single__address svg { width: 1.1em; height: 1.1em; }
.mgic-single__priceblock { text-align: left; }
.mgic-single__priceblock .mgic-price { font-size: var(--mgic-h1); display: block; line-height: 1.1; }
.mgic-single__pricelabel { display: block; color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); margin-bottom: 2px; }

/* Eckdaten-Icon-Card */
.mgic-eckdaten {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
	background: var(--mgic-border); border: 1px solid var(--mgic-border);
	border-radius: var(--mgic-radius); overflow: hidden; margin-bottom: var(--space-m, 1.75rem);
}
.mgic-eckdaten__cell { display: flex; align-items: center; gap: 10px; padding: 12px 14px; background: var(--mgic-surface); }
.mgic-eckdaten__icon { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; background: var(--mgic-surface-alt); color: var(--mgic-primary); flex: none; }
.mgic-eckdaten__icon svg { width: 17px; height: 17px; }
.mgic-eckdaten__label { display: block; color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }
.mgic-eckdaten__value { display: block; color: var(--mgic-heading); font-weight: 700; font-size: var(--mgic-label-size); }
@media (max-width: 768px) { .mgic-eckdaten { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px) { .mgic-eckdaten { grid-template-columns: 1fr; } }

/* Nur Bottom-Margin -> erster Abschnitt sitzt bündig oben (= Höhe der Makler-Card). */
/* Inhaltsblöcke (divs, keine sections) */
.mgic-block { margin: 0 0 var(--space-l, 2rem); }
.mgic-block:last-child { margin-bottom: 0; }
.mgic-block h2, .mgic-cta h2 { font-family: var(--mgic-heading-font); font-size: var(--mgic-h2); color: var(--mgic-heading); margin: 0 0 16px; }
.mgic-block h3 { font-family: var(--mgic-heading-font); font-size: var(--mgic-h3); color: var(--mgic-heading); margin: 22px 0 10px; }
.mgic-notice { padding: 12px 16px; border-radius: var(--mgic-radius); font-size: var(--mgic-label-size); font-weight: 600; margin: 0 0 var(--space-m, 1.5rem); }
.mgic-notice--reserved { background: #fdf3e6; color: #a15c00; border: 1px solid #f3d9ad; }
/* Hauptregionen: jede Sektion ist top-level (kein <article>-Wrapper) und trägt selbst .mgic-single
   (zentriert auf Content-Breite). ACSS gibt jeder Top-Level-<section> automatisch
   padding-block: var(--section-padding-block) + padding-inline: var(--gutter). Wir setzen
   --section-padding-block auf 0 (den vertikalen Abstand steuern wir selbst per margin) und LASSEN den
   Gutter (padding-inline) erhalten -> Body-Content bleibt nicht ganz fullwidth. Inneres Card-Padding
   (z. B. .mgic-stage-summary, .mgic-card-panel) bleibt unberührt, da es eigenes padding setzt. */
section.mgic-single { --section-padding-block: 0px; }
section.mgic-single + section.mgic-single { margin-top: var(--space-l, 2.25rem); }
/* Letzte Sektion (egal ob „Das könnte Sie auch interessieren" oder das Kontaktformular) immer mit
   Abstand nach unten – sonst klebt die letzte Sektion am Footer. :last-of-type ignoriert das
   nachgestellte (versteckte) Lightbox-<div>, da es kein <section> ist. */
section.mgic-single:last-of-type { margin-bottom: var(--space-l, 2.25rem); }
.mgic-prose { font-size: var(--mgic-label-size); line-height: 1.65; color: var(--mgic-text); }
.mgic-prose ul { padding-left: 1.2em; }
.mgic-prose li { margin: .3em 0; }
.mgic-prose > :last-child { margin-bottom: 0; }
.mgic-prose p:empty { display: none; }
.mgic-muted { color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }

.mgic-card-panel { border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius); padding: var(--mgic-pad); background: var(--mgic-surface); }

/* Ausstattung gruppiert (Innen / Außen / Energie & Technik / Weitere) */
.mgic-feat-group + .mgic-feat-group { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--mgic-border); }
.mgic-feat-group__title { font-family: var(--mgic-heading-font); font-size: var(--mgic-fact-size); text-transform: uppercase; letter-spacing: .06em; color: var(--mgic-text-muted); font-weight: 700; margin: 0 0 10px; }

/* Areas & Lot Tabelle */
.mgic-detail-table { width: 100%; border-collapse: collapse; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius); overflow: hidden; }
.mgic-detail-table tr:nth-child(odd) { background: var(--mgic-surface-alt); }
.mgic-detail-table th, .mgic-detail-table td { padding: 13px 18px; font-size: var(--mgic-label-size); text-align: left; }
.mgic-detail-table th { color: var(--mgic-text-muted); font-weight: 500; width: 40%; font-size: var(--mgic-fact-size); }
.mgic-detail-table td { color: var(--mgic-heading); font-weight: 600; text-align: right; }

.mgic-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.mgic-chip { display: inline-flex; align-items: center; gap: .5em; padding: .5em 1em; border-radius: var(--mgic-radius-pill); background: var(--mgic-primary-light); color: var(--mgic-heading); font-size: var(--mgic-fact-size); font-weight: 600; }
.mgic-chip .mgic-ico { width: 1.15em; height: 1.15em; flex: none; color: var(--mgic-primary); }

.mgic-energy { width: 100%; height: auto; max-width: 640px; }
.mgic-map { height: 340px; width: 100%; border-radius: var(--mgic-radius); overflow: hidden; border: 1px solid var(--mgic-border); }
/* Lage-Karte im Detail-Block von Beschreibung/Überschrift absetzen. */
.mgic-block .mgic-map { margin-top: var(--space-m, 1.25rem); }
/* Drittanbieter-Control (Leaflet/OSM-Attribution) – bewusst feste 10px Rechtstext-Größe, keine Content-Schrift. */
.mgic-map .leaflet-control-attribution { font-size: 10px; }

/* DSGVO Consent-Overlay (Klick-zum-Laden): solange sichtbar, werden KEINE OSM-Kacheln geladen. */
.mgic-map-consent {
	position: absolute; inset: 0; z-index: 5;
	display: flex; align-items: center; justify-content: center; padding: 16px; text-align: center;
	background-color: var(--mgic-surface-alt, #eef1f4);
	background-image: repeating-linear-gradient( 45deg, transparent, transparent 12px, rgba(0,0,0,.025) 12px, rgba(0,0,0,.025) 24px );
}
.mgic-map-consent__box {
	max-width: 360px; display: flex; flex-direction: column; align-items: center; gap: 10px;
	background: var(--mgic-surface, #fff); border: 1px solid var(--mgic-border);
	border-radius: var(--mgic-radius); padding: 18px 20px; box-shadow: var(--mgic-shadow);
}
.mgic-map-consent__text { margin: 0; font-size: var(--mgic-fact-size); line-height: 1.5; color: var(--mgic-text); }
.mgic-map-consent__btn {
	cursor: pointer; border: 0; border-radius: var(--mgic-btn-radius, var(--mgic-radius-s));
	background: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff);
	font-weight: 700; font-size: var(--mgic-label-size); padding: .6em 1.4em; min-height: 40px;
}
.mgic-map-consent__btn:hover { filter: brightness(1.06); }
.mgic-map-consent__link { font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); text-decoration: underline; }

/* Sticky-Sidebar – Top-Offset berücksichtigt einen evtl. fixierten Header. */
.mgic-single__aside { position: sticky; top: calc(var(--mgic-header-offset, 0px) + 24px); display: grid; gap: 18px; }
@media (max-width: 920px) { .mgic-single__aside { position: static; } }

.mgic-agentcard, .mgic-pricecard { border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius); padding: var(--mgic-pad); background: var(--mgic-surface); box-shadow: var(--mgic-shadow); }
/* Preis-Card visuell hervorheben (klarer Conversion-Anker in der Sidebar). */
.mgic-pricecard { border: 2px solid var(--mgic-primary); }
.mgic-agentcard__role { font-weight: 600; color: var(--mgic-text); }
.mgic-agentcard__rows .mgic-agentcard__val { margin-left: auto; text-align: right; color: var(--mgic-heading); font-size: var(--mgic-label-size); font-weight: 600; white-space: normal; flex: 1 1 auto; }
.mgic-agentcard__head { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.mgic-agentcard__id strong { display: block; color: var(--mgic-heading); font-size: var(--mgic-h3); font-weight: 700; line-height: 1.2; }
.mgic-agentcard__id span { display: block; color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }
.mgic-agentcard__rows { list-style: none; margin: 0 0 16px; padding: 0; }
/* Icon + Label oben ausrichten (Wert kann mehrzeilig umbrechen, z. B. lange E-Mail) – sonst „rutscht" das Label. */
.mgic-agentcard__rows li { display: flex; align-items: flex-start; gap: 8px; padding: 10px 0; border-top: 1px solid var(--mgic-border); }
.mgic-agentcard__rows svg { width: 17px; height: 17px; color: var(--mgic-primary); flex: none; align-self: flex-start; margin-top: 1px; }
/* Label klein (text-s) + einzeilig, damit es nie umbricht; Wert text-m, lange E-Mails dürfen umbrechen. */
.mgic-agentcard__rows span { color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); white-space: nowrap; flex: none; }
.mgic-agentcard__rows a { margin-left: auto; text-align: right; color: var(--mgic-heading); font-size: var(--mgic-label-size); font-weight: 600; text-decoration: none; word-break: break-word; }
.mgic-agentcard__rows a:hover { color: var(--mgic-primary); }

.mgic-pricecard__label { color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }
.mgic-pricecard__price { font-size: var(--mgic-h2); font-weight: 800; color: var(--mgic-primary); line-height: 1.1; margin-bottom: 14px; }
.mgic-pricecard__status { color: var(--mgic-text); }
.mgic-pricecard__hint { padding: 11px 14px; border-radius: var(--mgic-radius-s); background: #fdf3e6; color: #a15c00; font-size: var(--mgic-fact-size); font-weight: 600; text-align: center; }
.mgic-pricecard__facts { list-style: none; margin: 0 0 16px; padding: 0; }
.mgic-pricecard__facts li { display: flex; justify-content: space-between; gap: 12px; padding: 9px 0; border-top: 1px solid var(--mgic-border); font-size: var(--mgic-label-size); }
.mgic-pricecard__facts span { color: var(--mgic-text-muted); }
.mgic-pricecard__facts b { color: var(--mgic-heading); text-align: right; }
/* Provisions-Zeile: Label + (oft langer) Text kleiner und nicht fett. ACSS --text-s, sonst Design-System. */
.mgic-pricecard__prov span,
.mgic-pricecard__prov b { font-size: var(--text-s, var(--mgic-fact-size, .9rem)); }
.mgic-pricecard__prov b { font-weight: 400; }
/* Kräftigerer Conversion-CTA in der Preis-Card (nur für den Plugin-Button, nicht für ACSS-Buttons). */
.mgic-pricecard .mgic-btn.mgic-btn--block { font-size: var(--mgic-label-size); font-weight: 800; padding: .95em 1.4em; box-shadow: 0 6px 16px rgba(0,0,0,.12); letter-spacing: .01em; }

/* Kontaktbereich auf den mitgelieferten Detailseiten: auf die Content-Breite begrenzt und zentriert
   (nicht über die volle Seitenbreite). Das Formular (.mgic-form-wrap, width:100%) skaliert darin mit. */
.mgic-single__contact { max-width: var(--content-width, 1140px); margin-left: auto; margin-right: auto; }
/* Portal-Template: Kontaktformular füllt 100% der Inhaltsspalte (mgic-portal-content), nicht zentriert/begrenzt. */
.mgic .mgic-portal-content .mgic-single__contact, .mgic .mgic-single__contact--portal { max-width: none; margin-left: 0; margin-right: 0; width: 100%; }
.mgic .mgic-single__contact--portal { margin-top: var(--mgic-gap, 24px); }

/* ----- Template „stage" (Full-Width-Hero + Summary-Card) ------------------ */
.mgic-single--stage .mgic-stage-hero { position: relative; border-radius: var(--mgic-radius); overflow: hidden; }
.mgic-stage-hero__main { display: block; width: 100%; padding: 0; border: 0; cursor: pointer; aspect-ratio: 16 / 9; background: var(--mgic-surface-alt); position: relative; }
.mgic-stage-hero__main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mgic-stage-hero__main .mgic-badge { top: 16px; left: 16px; z-index: 2; }
.mgic-stage-strip { position: absolute; left: 16px; bottom: 16px; display: flex; gap: 8px; z-index: 2; }
.mgic-stage-strip__thumb { width: 74px; height: 56px; padding: 0; border: 2px solid rgba(255,255,255,.85); border-radius: 6px; overflow: hidden; cursor: pointer; position: relative; background: none; }
.mgic-stage-strip__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mgic-stage-strip__thumb.is-more::after { content: ""; position: absolute; inset: 0; background: rgba(15,20,30,.6); }
.mgic-stage-strip__more { position: absolute; inset: 0; z-index: 2; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: var(--mgic-fact-size); }

/* Kein Negativ-Overlap mehr (verdeckte sonst den Thumbnail-Strip + verschob das Layout).
   WICHTIG: kein margin-inline setzen – sonst überschreibt es das margin-inline:auto von .mgic-single
   und die Card klebt links statt zentriert unter dem Hero. Vertikalabstand kommt aus der Sibling-Regel. */
.mgic-stage-summary { border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius); padding: var(--mgic-pad); background: var(--mgic-surface); box-shadow: var(--mgic-shadow); }
.mgic-stage-summary__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; }
.mgic-stage-facts { display: flex; flex-wrap: wrap; gap: 12px 28px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--mgic-border); }
.mgic-stage-fact { display: inline-flex; align-items: center; gap: .5em; font-size: var(--mgic-label-size); color: var(--mgic-text); }
.mgic-stage-fact b { color: var(--mgic-heading); }
.mgic-stage-fact svg { width: 1.3em; height: 1.3em; color: var(--mgic-primary); }
@media (max-width: 600px) { .mgic-stage-strip { display: none; } }

/* ===========================================================================
   Template „portal" (Homes.com-/Zillow-Stil)
   =========================================================================*/
/* Top-Bar: Breadcrumb links, Aktionen (Merken/Teilen) rechts. */
.mgic-portal-topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px 16px; flex-wrap: wrap; padding-inline: var(--gutter, 1rem); margin: 0 auto var(--space-s, .85rem); }
.mgic-portal-topbar .mgic-breadcrumb { margin: 0; padding: 0; max-width: none; flex: 1 1 auto; min-width: 0; }
.mgic-portal-actions { display: flex; gap: 8px; flex: none; }
.mgic-portal-action { display: inline-flex; align-items: center; gap: 6px; background: none; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-pill); padding: .45em .95em; font-size: var(--mgic-fact-size); font-weight: 600; color: var(--mgic-text); cursor: pointer; transition: color .15s ease, border-color .15s ease, background .15s ease; }
.mgic-portal-action:hover { border-color: var(--mgic-primary); color: var(--mgic-primary); }
.mgic-portal-action svg { width: 16px; height: 16px; }
.mgic-portal-action.is-active { color: var(--mgic-primary); border-color: var(--mgic-primary); background: var(--mgic-primary-light); }

/* Galerie als EIN Grid: Hero spannt 2x2 (links), 4 Thumbnails füllen die rechten 2 Spalten.
   Feste aspect-ratio gibt allen Zeilen eine definierte Höhe -> keine inhaltsbasierte Aufblähung,
   kein Überlappen (das frühere verschachtelte Grid war die Ursache). */
.mgic-pgallery { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(2, 1fr); gap: 10px; aspect-ratio: 2 / 1; }
.mgic-pgallery__hero, .mgic-pgallery__cell { position: relative; padding: 0; border: 0; cursor: pointer; overflow: hidden; background: var(--mgic-surface-alt); min-height: 0; }
.mgic-pgallery__hero { grid-column: 1 / 3; grid-row: 1 / 3; border-radius: var(--mgic-radius); }
.mgic-pgallery__cell { border-radius: var(--mgic-radius-s); }
.mgic-pgallery__hero img, .mgic-pgallery__cell img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.mgic-pgallery__hero:hover img { transform: scale(1.03); }
.mgic-pgallery__cell:hover img { transform: scale(1.04); }
.mgic-pgallery__hero .mgic-badge { top: 16px; left: 16px; z-index: 2; }
.mgic-pgallery__count { position: absolute; right: 12px; bottom: 12px; z-index: 3; display: inline-flex; align-items: center; gap: .4em; color: #fff; font-weight: 600; font-size: var(--mgic-fact-size); background: rgba(15,20,30,.78); padding: .4em .8em; border-radius: var(--mgic-radius-pill); }
.mgic-pgallery__count svg { width: 1.15em; height: 1.15em; }
/* Einzelbild (keine Thumbnails): Hero über die volle Breite. */
.mgic-pgallery.is-single { grid-template-columns: 1fr; grid-template-rows: 1fr; aspect-ratio: 16 / 9; }
.mgic-pgallery.is-single .mgic-pgallery__hero { grid-column: 1 / -1; grid-row: 1 / -1; }
@media (max-width: 780px) {
	/* Hero volle Breite oben, darunter eine Reihe mit 4 Thumbnails. */
	.mgic-pgallery { grid-template-rows: auto auto; aspect-ratio: auto; }
	.mgic-pgallery__hero { grid-column: 1 / -1; grid-row: auto; aspect-ratio: 3 / 2; }
	.mgic-pgallery__cell { grid-row: 2; aspect-ratio: 1 / 1; }
}

/* Body-Layout: links Content-Spalte, rechts RESERVIERTE Sidebar (Agent/Preis), sticky.
   So bleibt die Ansprechpartner-Spalte über die volle Höhe frei – Content läuft nie darunter. */
.mgic-portal-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 40px; align-items: start; }
.mgic-portal-content { min-width: 0; }
.mgic-portal-aside { position: sticky; top: calc(var(--mgic-header-offset, 0px) + 24px); display: grid; gap: 18px; }
@media (max-width: 980px) { .mgic-portal-grid { grid-template-columns: 1fr; } .mgic-portal-aside { position: static; } }

/* Detail-Reihen: Überschrift links (1fr), Content rechts breiter (≈2,2fr); Trennlinie oben. */
.mgic-prow { display: grid; grid-template-columns: minmax(140px, 1fr) 2.2fr; gap: 14px 36px; align-items: start; padding-top: 24px; margin-top: 24px; border-top: 1px solid var(--mgic-border); }
.mgic-prow__head h2 { font-family: var(--mgic-heading-font); font-size: var(--mgic-h3); color: var(--mgic-heading); margin: 0; line-height: 1.2; }
/* Bei Reihen mit Panel (Fakten/Energie) startet der Inhalt erst nach dem Panel-Innenabstand –
   die linke Überschrift entsprechend nach unten ausrichten, damit sie mit den Panel-Titeln fluchtet. */
/* Panel in den Detail-Reihen = linke Trennlinie statt Box, Inhalt oben bündig mit der Überschrift. */
.mgic-prow__body .mgic-card-panel { border: 0; border-left: 1px solid var(--mgic-border); border-radius: 0; padding: 0 0 0 var(--mgic-pad); background: var(--mgic-surface); }
@media (max-width: 700px) { .mgic-prow__body .mgic-card-panel { border-left: 0; padding-left: 0; } }
.mgic-prow__body { min-width: 0; }
.mgic-prow__body > :first-child { margin-top: 0; }
.mgic-prow__body h3 { font-family: var(--mgic-heading-font); font-size: var(--mgic-label-size); color: var(--mgic-heading); margin: 0 0 8px; }
@media (max-width: 700px) { .mgic-prow { grid-template-columns: 1fr; gap: 8px; padding-top: 18px; margin-top: 18px; } }

/* Volle-Breite-Sektionen (Empfehlungen/Kontakt) mit eigener Überschrift. */
section.mgic-single--portal > h2 { font-family: var(--mgic-heading-font); font-size: var(--mgic-h2); color: var(--mgic-heading); margin: 0 0 16px; }
/* Seitenende: Abstand vor der nächsten (Bricks-)Sektion. */
.mgic-single--portal.mgic-reco, .mgic-single--portal.mgic-single__contact { margin-bottom: var(--space-l, 2.25rem); }

/* Summary: Status, großer Preis + Key-Stats, Adresse, H1-Titel. */
.mgic-psum { padding-bottom: 20px; border-bottom: 1px solid var(--mgic-border); margin-bottom: var(--space-m, 1.75rem); }
.mgic-psum__status { display: inline-flex; align-items: center; gap: .5em; font-size: var(--mgic-fact-size); font-weight: 600; color: var(--mgic-heading); }
.mgic-psum__status::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: #1bbf6b; flex: none; }
.mgic-psum__row { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px 36px; flex-wrap: wrap; margin-top: 8px; }
.mgic-psum__price { font-size: var(--mgic-h1); line-height: 1.05; color: var(--mgic-heading); display: block; }
.mgic-psum .mgic-single__address { margin-top: 8px; }
.mgic-pstats { display: flex; gap: 26px; list-style: none; margin: 0; padding: 0; }
.mgic-pstats li { display: flex; flex-direction: column; }
.mgic-pstats b { font-size: var(--mgic-h3); color: var(--mgic-heading); font-weight: 700; line-height: 1.1; }
.mgic-pstats span { font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); }
.mgic-psum__title { font-family: var(--mgic-heading-font); font-size: var(--mgic-h3); color: var(--mgic-heading); font-weight: 600; margin: 16px 0 0; line-height: 1.2; }

/* Cleanes Fakten-Grid (kein Icon-Kreis/Border): Icon+Label oben, Wert darunter. */
.mgic-pfacts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px 28px; }
.mgic-pfacts__item { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.mgic-pfacts__head { display: inline-flex; align-items: center; gap: 7px; font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); }
.mgic-pfacts__head svg { width: 15px; height: 15px; color: var(--mgic-primary); flex: none; }
.mgic-pfacts__val { font-size: var(--mgic-label-size); font-weight: 700; color: var(--mgic-heading); }
@media (max-width: 768px) { .mgic-pfacts { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 380px) { .mgic-pfacts { grid-template-columns: 1fr; } }

/* „Das Besondere": Highlight-Chips über der Beschreibung. */
.mgic-special__chips { margin-bottom: 14px; gap: 8px; }

/* „Fakten & Ausstattung": kategorisiertes Panel, passt sich der Content-Spaltenbreite an (100%). */
.mgic-factgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 22px 36px; }
.mgic-factgrid__title { font-family: var(--mgic-heading-font); font-size: var(--mgic-label-size); color: var(--mgic-heading); font-weight: 700; margin: 0 0 8px; padding-bottom: 6px; border-bottom: 1px solid var(--mgic-border); }
.mgic-factgrid__list { list-style: none; margin: 0; padding: 0; }
.mgic-factgrid__list li { display: flex; justify-content: space-between; gap: 16px; padding: 6px 0; font-size: var(--mgic-fact-size); }
.mgic-factgrid__list span { color: var(--mgic-text-muted); }
.mgic-factgrid__list b { color: var(--mgic-heading); font-weight: 600; text-align: right; }
@media (max-width: 600px) { .mgic-factgrid { grid-template-columns: 1fr; gap: 18px; } }

/* „Das könnte Sie auch interessieren" – nutzt das Card-Grid (.mgic-list). */
.mgic-reco .mgic-list { margin: 0; }
.mgic-reco > h2 { margin: 0 0 var(--space-m, 1.5rem) !important; }

/* ===========================================================================
   KONTAKTFORMULARE (.mgic-form) – design-token-gestylt
   =========================================================================*/
.mgic-form-wrap { width: 100%; }
.mgic-form__heading { font-family: var(--mgic-heading-font); font-size: var(--mgic-h3); color: var(--mgic-heading); margin: 0 0 14px; }
.mgic-form { display: grid; gap: 14px; }
.mgic-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 520px) { .mgic-form__row { grid-template-columns: 1fr; } }
.mgic-form__field { display: grid; gap: 6px; min-width: 0; }
.mgic-form__field--narrow { max-width: 240px; }
.mgic-form__range { display: flex; align-items: center; gap: 8px; }
.mgic-form__range input { flex: 1 1 0; min-width: 0; }
.mgic-form__range span { color: var(--mgic-text-muted); flex: 0 0 auto; }
.mgic-form__checks { display: flex; flex-wrap: wrap; gap: 8px 18px; }
.mgic-form__checks .mgic-form__check { flex: 0 1 auto; }
.mgic-form label { font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); font-weight: 600; }
.mgic-form input[type="text"], .mgic-form input[type="email"], .mgic-form input[type="tel"], .mgic-form input[type="number"], .mgic-form select, .mgic-form textarea {
	width: 100%; height: 48px; font: inherit; color: var(--mgic-text); background-color: var(--mgic-surface);
	border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); padding: 0 .9em; line-height: normal;
	box-sizing: border-box; transition: border-color .15s ease, box-shadow .15s ease;
}
/* Selects: einheitlicher, sichtbarer Pfeil (native appearance wird von vielen Themes entfernt). */
.mgic-form select {
	appearance: none; -webkit-appearance: none; -moz-appearance: none; cursor: pointer; padding-right: 2.5em;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23646970' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right .9em center;
}
.mgic-form select::-ms-expand { display: none; }
.mgic-form input:focus, .mgic-form select:focus, .mgic-form textarea:focus {
	outline: 0; border-color: var(--mgic-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--mgic-primary) 18%, transparent);
}
.mgic-form textarea { height: auto; padding: .7em .9em; resize: vertical; min-height: 110px; }
.mgic-form__range { align-items: center; }
.mgic-form__range input { height: 48px; }
.mgic-form__range span { display: inline-flex; align-items: center; justify-content: center; align-self: stretch; line-height: 1; }
.mgic-form__req { color: var(--mgic-primary); }
.mgic-form__check { display: flex; align-items: flex-start; gap: 10px; font-size: var(--mgic-fact-size); color: var(--mgic-text); font-weight: 400; cursor: pointer; }
.mgic-form__check input { margin-top: 3px; flex: none; }
.mgic-form__check a { color: var(--mgic-primary); text-decoration: underline; }
.mgic-form__check--consent span { line-height: 1.45; }
.mgic-form__error { display: flex; align-items: center; gap: 5px; margin-top: 5px; color: #c0392b; font-size: var(--mgic-fact-size); font-weight: 600; }
.mgic-form__error svg { flex: none; }
.mgic-form-alert { padding: 11px 14px; border-radius: var(--mgic-radius-s); background: #fdecea; color: #b32d2e; font-size: var(--mgic-fact-size); font-weight: 600; margin-bottom: 12px; }
.mgic-form-alert__list { margin: 6px 0 0; padding-left: 1.25em; font-weight: 500; }
.mgic-form-alert__list li { margin: 2px 0; }
.mgic-form-success { display: flex; align-items: center; gap: 12px; padding: 16px 18px; border-radius: var(--mgic-radius); background: var(--mgic-primary-light); color: var(--mgic-heading); font-weight: 600; }
.mgic-form-success svg { width: 22px; height: 22px; color: var(--mgic-success, #1f7a3d); flex: none; }
.mgic-form-success__icon { display: inline-flex; }
.mgic-form-success__icon svg { width: 40px; height: 40px; }

/* Inline-Validierung: rote Felder. */
.mgic-form__field.is-invalid input, .mgic-form__field.is-invalid select, .mgic-form__field.is-invalid textarea,
.mgic-form__range.is-invalid input, .mgic-form__check.is-invalid input {
	border-color: #c0392b !important; box-shadow: 0 0 0 3px rgba(192, 57, 43, .12);
}
.mgic-form__check.is-invalid span { color: #c0392b; }

/* Schüttel-Animation bei Fehler. */
.mgic-shake { animation: mgicShake .4s ease; }
@keyframes mgicShake { 10%,90%{transform:translateX(-1px)} 20%,80%{transform:translateX(2px)} 30%,50%,70%{transform:translateX(-5px)} 40%,60%{transform:translateX(5px)} }

/* Absenden-Button: Lade-Spinner. */
.mgic-form button.is-loading, .mgic-form [type="submit"].is-loading { position: relative; color: transparent !important; pointer-events: none; }
.mgic-form button.is-loading::after, .mgic-form [type="submit"].is-loading::after {
	content: ""; position: absolute; top: 50%; left: 50%; width: 18px; height: 18px; margin: -9px 0 0 -9px;
	border: 2px solid rgba(255, 255, 255, .55); border-top-color: #fff; border-radius: 50%; animation: mgicSpin .6s linear infinite;
}
@keyframes mgicSpin { to { transform: rotate(360deg); } }

/* Danke-Meldung sanft einblenden. */
.mgic-form-success--reveal { animation: mgicReveal .4s ease; }
@keyframes mgicReveal { from { opacity: 0; transform: translateY(10px) scale(.98); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .mgic-shake, .mgic-form-success--reveal { animation: none; } }
/* Honeypot: für Menschen unsichtbar (nicht display:none, damit Bots es ausfüllen). */
.mgic-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* ===========================================================================
   FILTERBAR (modern, mobil-tauglich)
   =========================================================================*/
.mgic-filterbar { margin: 0 0 28px; }
.mgic-filterbar__mobile, .mgic-filterbar__close, .mgic-filterbar__head { display: none; }
.mgic-filterbar__panel {
	display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
	background: var(--mgic-surface); border: 1px solid var(--mgic-border);
	border-radius: var(--mgic-radius); padding: 10px; box-shadow: var(--mgic-shadow);
}
/* Aktionen IMMER auf eigener Zeile (rechtsbündig) – so verschiebt das Erscheinen von „Zurücksetzen"
   die Filter-Controls nicht mehr und das Layout bleibt stabil. */
.mgic-filterbar__actions { display: flex; align-items: center; justify-content: flex-end; gap: 14px; flex: 1 1 100%; }
.mgic-filter-reset { color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); text-decoration: none; white-space: nowrap; }
.mgic-filter-reset:hover { color: var(--mgic-primary); }

/* „Weitere Filter" in der Leiste: Toggle in der Aktionszeile + aufklappbare Sekundär-Zeile (volle Breite). */
.mgic-filterbar__more-btn { display: inline-flex; align-items: center; gap: 6px; background: none; border: 0; color: var(--mgic-text); font-weight: 600; font-size: var(--mgic-fact-size); cursor: pointer; padding: 0 4px; white-space: nowrap; }
.mgic-filterbar__more-btn:hover, .mgic-filterbar__more-btn[aria-expanded="true"] { color: var(--mgic-primary); }
.mgic-filterbar__more-btn svg { width: 18px; height: 18px; }
.mgic-filterbar__more { flex: 1 1 100%; display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-top: 4px; padding-top: 12px; border-top: 1px solid var(--mgic-border); }
.mgic-filterbar__more[hidden] { display: none; }

/* Umkreissuche: Ort-Input + km-Select als eine Einheit (NICHT wachsen lassen, sonst stretcht das Feld). */
.mgic-umkreis { display: inline-flex; align-items: stretch; gap: 6px; flex: 0 1 240px; min-width: 200px; }
.mgic-umkreis__input { flex: 1 1 auto; min-width: 110px; }
.mgic-umkreis__km { flex: 0 0 auto; max-width: 96px; }

/* Ort/Region (Dropdown) + Umkreis (reines km-Dropdown) direkt nebeneinander als eine Einheit.
   Höhere Spezifität als .mgic-filterbar__panel .mgic-filter-control, damit das Ort-Dropdown wirklich
   breit/lesbar ist (sonst zeigt das <select> nur den Pfeil). */
.mgic .mgic-ortwrap { display: inline-flex; align-items: stretch; gap: 6px; flex: 1 1 280px; min-width: 220px; max-width: 360px; }
.mgic-filterbar__panel .mgic-ortwrap .mgic-ortwrap__ort,
.mgic .mgic-ortwrap .mgic-ortwrap__ort { flex: 1 1 auto; width: auto; min-width: 140px; max-width: none; }
.mgic-filterbar__panel .mgic-ortwrap .mgic-ortwrap__km,
.mgic .mgic-ortwrap .mgic-ortwrap__km { flex: 0 0 auto; width: auto; min-width: 96px; max-width: 130px; }

/* Status-Filter: einfache Checkbox-Liste im Popover (analog Energieklasse, aber ohne Badge). */
.mgic-scheck { display: flex; align-items: center; gap: 7px; margin: 0; cursor: pointer; white-space: nowrap; font-size: var(--mgic-fact-size, .9rem); }
.mgic-scheck input { width: auto; margin: 0; padding: 0; border: 0; cursor: pointer; }
.mgic-pop__panel--checks .mgic-scheck { flex: 0 0 100%; }

/* Cluster-Karte ([mgic-map]) */
.mgic-map { width: 100%; min-height: 280px; margin-bottom: var(--mgic-gap); border-radius: var(--mgic-radius); overflow: hidden; border: 1px solid var(--mgic-border); z-index: 0; }

/* Cluster-Bubbles + Einzel-Punkte in der Akzentfarbe (statt Standard-Grün/Gelb). */
.mgic-map .mgic-cluster { background: color-mix(in srgb, var(--mgic-primary) 28%, transparent); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.mgic-map .mgic-cluster__inner { width: 72%; height: 72%; border-radius: 50%; background: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; box-shadow: 0 1px 6px rgba(0,0,0,.25); }
.mgic-map .mgic-map-pin__dot { display: block; width: 18px; height: 18px; border-radius: 50%; background: var(--mgic-primary); border: 2px solid #fff; box-shadow: 0 1px 5px rgba(0,0,0,.35); }

/* Popup */
.mgic-map-popup .leaflet-popup-content { margin: 0; width: 250px !important; }
.mgic-map-popup .leaflet-popup-content-wrapper { padding: 0; border-radius: var(--mgic-radius); overflow: hidden; }
.mgic-map-pop { display: block; text-decoration: none; color: var(--mgic-text); }
.mgic-map-pop__img { display: block; width: 100%; height: 110px; background-size: cover; background-position: center; background-color: var(--mgic-surface-alt); }
.mgic-map-pop__body { display: flex; flex-direction: column; gap: 3px; padding: 10px 12px; }
.mgic-map-pop__body strong { color: var(--mgic-heading); font-size: var(--mgic-label-size); line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mgic-map-pop__loc { color: var(--mgic-text-muted); font-size: var(--mgic-fact-size); }
.mgic-map-pop__price { color: var(--mgic-primary); font-weight: 800; font-size: var(--mgic-label-size); margin-top: 2px; }

.mgic-segment { display: inline-flex; flex: 0 0 auto; width: auto; background: var(--mgic-surface-alt); border-radius: var(--mgic-radius-pill); padding: 3px; }
.mgic-segment label { cursor: pointer; margin: 0; }
.mgic-segment input { position: absolute; opacity: 0; pointer-events: none; }
.mgic-segment span { display: block; padding: .5em 1.1em; border-radius: var(--mgic-radius-pill); font-size: var(--mgic-fact-size); font-weight: 600; color: var(--mgic-text-muted); transition: all .15s ease; white-space: nowrap; }
.mgic-segment input:checked + span { background: var(--mgic-surface); color: var(--mgic-primary); box-shadow: var(--mgic-shadow); }

/* Controls dürfen NICHT vom Theme auf width:100% gezwungen werden (sonst stacken sie). */
.mgic-filterbar__panel .mgic-filter-control { flex: 0 1 auto; width: auto; max-width: 220px; min-height: 0; margin: 0; padding: .62em .95em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-pill); background: var(--mgic-surface); color: var(--mgic-text); font: inherit; font-size: var(--mgic-fact-size); line-height: 1.3; cursor: pointer; box-shadow: none; }
.mgic-filterbar__panel input.mgic-filter-control { flex: 0 1 210px; min-width: 150px; max-width: 240px; cursor: text; }
.mgic-filter-control:focus { outline: 2px solid var(--mgic-primary); outline-offset: 1px; }

.mgic-pop { position: relative; }
.mgic-pop__btn { display: inline-flex; align-items: center; gap: .4em; }
.mgic-pop__btn svg { width: 1em; height: 1em; transform: rotate(90deg); transition: transform .15s ease; }
.mgic-pop.is-open .mgic-pop__btn svg { transform: rotate(-90deg); }
.mgic-pop__panel { position: absolute; top: calc(100% + 6px); left: 0; z-index: 20; display: none; align-items: center; gap: 8px; background: var(--mgic-surface); border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius); padding: 12px; box-shadow: var(--mgic-shadow-hover); }
.mgic-pop.is-open .mgic-pop__panel { display: flex; }
.mgic-pop__panel input { width: 96px; padding: .5em .6em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface); color: var(--mgic-text); font: inherit; }
/* Energieklasse-Popover nutzt <select> (von/bis) – gleiches Erscheinungsbild wie die Inputs + sichtbarer Pfeil. */
.mgic-pop__panel select { width: 110px; height: 44px; padding: 0 2.2em 0 .7em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background-color: var(--mgic-surface); color: var(--mgic-text); font: inherit; cursor: pointer; appearance: none; -webkit-appearance: none; -moz-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23646970' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .7em center; }
.mgic-pop__panel select::-ms-expand { display: none; }
.mgic-pop__panel > span { flex: 0 0 auto; color: var(--mgic-text-muted); }

/* Energieklasse-Filter: Checkboxen mit Farb-Badge (Popover + Panel). */
.mgic-pop__panel--checks { flex-wrap: wrap; align-items: flex-start; gap: 8px; max-width: 340px; }
.mgic-pop__panel--checks input { width: auto; padding: 0; border: 0; }
.mgic-echecks { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.mgic-echeck { position: relative; display: inline-flex; margin: 0; cursor: pointer; }
.mgic-echeck input { position: absolute; inset: 0; margin: 0; opacity: 0; cursor: pointer; }
.mgic-echeck input:not(:checked) + .mgic-eclass { opacity: .4; }
.mgic-echeck:hover .mgic-eclass { opacity: 1; }
.mgic-echeck input:checked + .mgic-eclass { box-shadow: 0 0 0 2px var(--mgic-surface, #fff), 0 0 0 4px var(--mgic-eclass-bg, #999); }
.mgic-echeck input:focus-visible + .mgic-eclass { outline: 2px solid var(--mgic-primary); outline-offset: 2px; }
/* Effizienzklassen-Badge (Buchstabe in Klassenfarbe) – auch in Cards genutzt. */
.mgic-eclass { display: inline-flex; align-items: center; justify-content: center; min-width: 34px; height: 28px; padding: 0 9px; border-radius: 6px; background: var(--mgic-eclass-bg, #999); color: var(--mgic-eclass-fg, #fff); font-weight: 800; font-size: 13px; line-height: 1; transition: opacity .12s ease, box-shadow .12s ease; }
.mgic-eclass__letter { transform: translateY(-1px); }
/* In Cards etwas kompakter, passt sich in die Fakten-/Chip-Zeile ein. */
.mgic-eclass--card { min-width: 27px; height: 21px; padding: 0 7px; font-size: 11px; border-radius: 5px; }
.mgic-facts .mgic-eclass--card { margin-left: auto; }

@media (max-width: 860px) {
	.mgic-filterbar__mobile { display: inline-flex; align-items: center; gap: .5em; padding: .75em 1.3em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-pill); background: var(--mgic-surface); color: var(--mgic-text); font-weight: 600; cursor: pointer; box-shadow: var(--mgic-shadow); }
	.mgic-filterbar__mobile svg { width: 1.15em; height: 1.15em; stroke: var(--mgic-primary); }
	.mgic-filterbar__panel { display: none; }
	.mgic-filterbar.is-open .mgic-filterbar__panel { display: flex; position: fixed; inset: 0; z-index: 99999; flex-direction: column; align-items: stretch; border-radius: 0; padding: 20px; overflow-y: auto; box-shadow: none; gap: 14px; }
	.mgic-filterbar.is-open .mgic-filterbar__head { display: flex; justify-content: space-between; align-items: center; }
	.mgic-filterbar.is-open .mgic-filterbar__close { display: block; background: none; border: 0; font-size: 1.9rem; line-height: 1; cursor: pointer; color: var(--mgic-text-muted); }
	.mgic-filterbar.is-open .mgic-segment label { flex: 1; text-align: center; }
	.mgic-filterbar.is-open .mgic-segment, .mgic-filterbar.is-open .mgic-filter-control { width: 100%; }
	/* Im mobilen Overlay alle Filter zeigen – „Weitere Filter"-Umschalter dort überflüssig. */
	.mgic-filterbar.is-open .mgic-filterbar__more[hidden] { display: flex; }
	.mgic-filterbar.is-open .mgic-filterbar__more { flex-direction: column; align-items: stretch; border-top: 0; padding-top: 0; margin-top: 0; }
	.mgic-filterbar.is-open .mgic-filterbar__more-btn { display: none; }
	.mgic-filterbar.is-open .mgic-pop__panel { position: static; display: flex; box-shadow: none; border: 0; padding: 4px 0; }
	.mgic-filterbar.is-open .mgic-pop__panel input, .mgic-filterbar.is-open .mgic-pop__panel select { flex: 1; width: auto; }
	.mgic-filterbar.is-open .mgic-filterbar__actions { margin: auto 0 0; flex: 0 0 auto; justify-content: stretch; }
	.mgic-filterbar.is-open .mgic-btn { flex: 1; }
}

.mgic-contact-form { display: grid; gap: 12px; max-width: 560px; }
.mgic-contact-form input, .mgic-contact-form textarea {
	padding: .75em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s);
	width: 100%; background: var(--mgic-surface); color: var(--mgic-text); font: inherit;
}
.mgic-contact-form textarea { min-height: 120px; }
.mgic-contact-success { background: color-mix(in srgb, var(--mgic-success) 12%, white); border: 1px solid var(--mgic-success); color: var(--mgic-success); padding: 12px 16px; border-radius: var(--mgic-radius-s); }

/* === Mobile-Härtung: Touch-Komfort & Overflow-Schutz (Mehrheit der Nutzer am Handy) === */
@media (max-width: 600px) {
	.mgic-detail-table th, .mgic-detail-table td { padding: 11px 12px; }
	.mgic-stage-facts { gap: 10px 18px; }
	.mgic-single__layout { gap: 20px; }
	/* 16px verhindert iOS-Auto-Zoom beim Fokus auf Formularfelder. */
	.mgic-contact-form input, .mgic-contact-form textarea, .mgic-pop__panel input { font-size: 16px; }
	/* 44px Touch-Ziel (Apple HIG / WCAG 2.5.5). */
	.mgic-pagination .page-numbers { min-width: 44px; height: 44px; }
	.mgic-btn, .mgic-filterbar__mobile, .mgic-gallery__hero, .mgic-stage-hero__main { min-height: 44px; }
}

/* ---------- Highlights: Video-Embed ---------- */
.mgic .mgic-video { position: relative; width: 100%; aspect-ratio: 16 / 9; border-radius: var(--mgic-radius); overflow: hidden; background: #000; }
.mgic .mgic-video iframe, .mgic .mgic-video video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.mgic .mgic-video-link a { display: inline-flex; align-items: center; gap: .45em; font-weight: 600; color: var(--mgic-primary); }

/* DSGVO-Consent-Platzhalter (Click-to-load) – vor Zustimmung kein Anbieter-Request */
.mgic .mgic-embed-consent { background: linear-gradient(135deg, #1e293b, #0f172a); }
.mgic .mgic-embed-consent__inner { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 9px; text-align: center; padding: 5% 24px; color: #fff; }
.mgic .mgic-embed-consent__play { color: rgba(255,255,255,.9); line-height: 0; }
.mgic .mgic-embed-consent__play svg { width: clamp(34px, 8vw, 54px); height: auto; }
.mgic .mgic-embed-consent__title { margin: 0; font-size: var(--mgic-label-size); font-weight: 700; }
.mgic .mgic-embed-consent__notice { margin: 0; max-width: 540px; font-size: var(--mgic-fact-size); line-height: 1.45; color: rgba(255,255,255,.82); }
.mgic .mgic-embed-consent__btn { margin-top: 2px; border: 0; cursor: pointer; background: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff); font-weight: 700; font-size: var(--mgic-label-size); padding: .7em 1.3em; border-radius: var(--mgic-radius); }
.mgic .mgic-embed-consent__all { border: 0; background: none; cursor: pointer; color: rgba(255,255,255,.72); text-decoration: underline; font-size: var(--mgic-fact-size); padding: 2px 6px; }
.mgic .mgic-embed-consent .mgic-video-link a { color: #fff; }

/* ---------- Dokumente: Downloadliste ---------- */
.mgic .mgic-docs { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.mgic .mgic-docs__item { margin: 0; }
.mgic .mgic-docs__link { display: flex; align-items: center; gap: .7em; padding: 12px 14px; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface, #fff); color: var(--mgic-text); text-decoration: none; font-weight: 600; transition: border-color .15s ease, background .15s ease, color .15s ease; }
.mgic .mgic-docs__link:hover { border-color: var(--mgic-primary); background: var(--mgic-surface-alt); color: var(--mgic-primary); }
.mgic .mgic-docs__link .mgic-ico { flex: 0 0 auto; width: 22px; height: 22px; color: var(--mgic-primary); }
.mgic .mgic-docs__title { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mgic .mgic-docs__ext { flex: 0 0 auto; font-size: var(--mgic-fact-size); font-weight: 700; color: var(--mgic-muted, #646970); border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-pill); padding: .15em .6em; }

/* ---------- Listen-Kopf: Anzahl + Sortierung (über der Objektliste) ---------- */
.mgic .mgic-listhead { display: flex; align-items: center; justify-content: space-between; gap: 14px 18px; flex-wrap: wrap; margin: 0 0 var(--space-m, 1.25rem); }
.mgic .mgic-listhead__count { margin: 0; font-size: var(--mgic-h4); color: var(--mgic-heading); font-weight: 600; }
.mgic .mgic-listhead__count strong { color: var(--mgic-primary); font-weight: 800; }
.mgic .mgic-listsort { display: inline-flex; align-items: center; gap: 10px; margin: 0; }
.mgic .mgic-listsort__label { font-size: var(--mgic-fact-size); color: var(--mgic-text-muted); font-weight: 600; white-space: nowrap; }
.mgic .mgic-listsort__select { position: relative; display: inline-block; }
.mgic .mgic-listsort__select::after { content: ""; position: absolute; right: 16px; top: 50%; width: 8px; height: 8px; border-right: 2px solid var(--mgic-text-muted); border-bottom: 2px solid var(--mgic-text-muted); transform: translateY(-70%) rotate(45deg); pointer-events: none; }
.mgic .mgic-listsort select { min-width: 190px; height: 44px; padding: 0 40px 0 16px; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface, #fff); color: var(--mgic-heading); font-size: var(--mgic-label-size); font-weight: 600; cursor: pointer; appearance: none; -webkit-appearance: none; -moz-appearance: none; transition: border-color .15s ease, box-shadow .15s ease; }
.mgic .mgic-listsort select::-ms-expand { display: none; }
.mgic .mgic-listsort select:hover { border-color: var(--mgic-primary); }
.mgic .mgic-listsort select:focus { outline: none; border-color: var(--mgic-primary); box-shadow: 0 0 0 3px var(--mgic-primary-light, rgba(0,0,0,.06)); }

/* MG-Bricks-Element-Wrapper füllt IMMER die Breite seines (Flex-)Block-Containers – egal ob dessen
   align-items auf stretch/center/flex-start steht. Verhindert den Breiten-Sprung beim Auf-/Zuklappen
   der Filter (Element schrumpfte sonst auf Inhaltsbreite). Nutzt die Container-Breite, nicht die Seite. */
.mgic-bricks-el { align-self: stretch; width: 100%; min-width: 0; box-sizing: border-box; }

/* ---------- Filter-Template „Panel" (Tabs oben + beschriftete Felder + Weitere Filter) ---------- */
.mgic .mgic-filterpanel { width: 100%; max-width: 100%; box-sizing: border-box; background: var(--mgic-surface, #fff); border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius); box-shadow: var(--mgic-shadow); margin: 0 0 var(--space-l, 2.25rem); }
.mgic .mgic-filterpanel__tabs { display: flex; gap: 4px; padding: 8px 8px 0; }
.mgic .mgic-filterpanel__tab input { position: absolute; opacity: 0; width: 0; height: 0; }
.mgic .mgic-filterpanel__tab span { display: inline-block; padding: 10px 24px; border-radius: 12px 12px 0 0; font-weight: 600; font-size: var(--mgic-label-size); color: var(--mgic-text-muted); background: var(--mgic-surface-alt, rgba(0,0,0,.04)); cursor: pointer; transition: color .15s ease, background .15s ease; }
.mgic .mgic-filterpanel__tab input:checked + span { color: var(--mgic-heading); background: transparent; font-weight: 800; }
.mgic .mgic-filterpanel__tab input:focus-visible + span { outline: 2px solid var(--mgic-primary); outline-offset: 2px; }
.mgic .mgic-filterpanel__body { padding: 16px 20px 20px; }
.mgic .mgic-filterpanel__fields { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 14px 18px; }
.mgic .mgic-filterpanel__field { display: flex; flex-direction: column; gap: 6px; flex: 1 1 200px; min-width: 150px; }
.mgic .mgic-filterpanel__label { font-size: var(--mgic-fact-size); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--mgic-text-muted); }
.mgic .mgic-filterpanel__control { width: 100%; height: 46px; padding: 0 14px; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface, #fff); color: var(--mgic-text); font-size: var(--mgic-label-size); }
.mgic .mgic-filterpanel__control:focus { outline: none; border-color: var(--mgic-primary); box-shadow: 0 0 0 3px var(--mgic-primary-light, rgba(0,0,0,.06)); }
.mgic .mgic-filterpanel__actions { display: flex; align-items: center; gap: 14px; flex: 0 0 auto; margin-left: auto; }
.mgic .mgic-filterpanel__more-btn { display: inline-flex; align-items: center; gap: 7px; background: none; border: 0; color: var(--mgic-text); font-size: var(--mgic-label-size); font-weight: 600; cursor: pointer; padding: 0 4px; }
.mgic .mgic-filterpanel__more-btn:hover { color: var(--mgic-primary); }
.mgic .mgic-filterpanel__more-btn .mgic-ico { width: 18px; height: 18px; }
.mgic .mgic-filterpanel__more-btn[aria-expanded="true"] { color: var(--mgic-primary); }
.mgic .mgic-filterpanel__more { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 14px 18px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--mgic-border); }
.mgic .mgic-filterpanel__more[hidden] { display: none; }
.mgic .mgic-filterpanel__range { display: flex; align-items: center; gap: 8px; }
.mgic .mgic-filterpanel__range > input, .mgic .mgic-filterpanel__range > select { flex: 1 1 0; width: 100%; min-width: 0; height: 46px; padding: 0 12px; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface, #fff); color: var(--mgic-text); font-size: var(--mgic-label-size); }
.mgic .mgic-filterpanel__range > span { flex: 0 0 auto; color: var(--mgic-text-muted); }
/* Umkreis-Combo: PLZ-Eingabe + km-Auswahl in EINEM Feld (gehören sichtbar zusammen). */
.mgic .mgic-filterpanel__combo { display: flex; align-items: stretch; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface, #fff); overflow: hidden; }
.mgic .mgic-filterpanel__combo:focus-within { border-color: var(--mgic-primary); box-shadow: 0 0 0 3px var(--mgic-primary-light, rgba(0,0,0,.06)); }
.mgic .mgic-filterpanel__combo input { flex: 1 1 auto; min-width: 0; height: 44px; padding: 0 14px; border: 0; background: transparent; color: var(--mgic-text); font-size: var(--mgic-label-size); }
.mgic .mgic-filterpanel__combo input:focus { outline: none; }
/* Ort/Region (breites Dropdown) + Umkreis (schmales km-Dropdown) als zwei normale Selects nebeneinander.
   Beide nutzen .mgic-filterpanel__control (Höhe/Padding/Rahmen) – das Ort-Dropdown wächst, das km-Dropdown ist fix. */
.mgic .mgic-filterpanel__ortrow { display: flex; align-items: stretch; gap: 8px; }
.mgic .mgic-filterpanel__ortrow .mgic-fp-ort-select { flex: 1 1 auto; width: auto; min-width: 0; }
.mgic .mgic-filterpanel__ortrow .mgic-fp-km-select { flex: 0 0 120px; width: 120px; min-width: 120px; }
/* Ort/Region breit + lesbar, Umkreis kompakt daneben (eigene Felder mit Label). */
.mgic .mgic-filterpanel__field--ort { flex: 2 1 280px; min-width: 220px; }
.mgic .mgic-filterpanel__field--umkreis { flex: 0 1 150px; min-width: 130px; }
.mgic .mgic-filterpanel__reset { display: inline-flex; align-items: center; color: #c92a2a; font-weight: 700; font-size: var(--mgic-label-size); text-decoration: none; white-space: nowrap; padding: 0 4px; }
.mgic .mgic-filterpanel__reset:hover { text-decoration: underline; color: #a51111; }
@media (max-width: 600px) {
	.mgic .mgic-filterpanel__fields { align-items: stretch; }
	.mgic .mgic-filterpanel__field { flex: 1 1 100%; }
	.mgic .mgic-filterpanel__actions { margin-left: 0; width: 100%; justify-content: space-between; }
	.mgic .mgic-filterpanel__control, .mgic .mgic-filterpanel__range input { height: 48px; font-size: 16px; }
}

/* ---------- Formular: Trust-Zeile unter dem Absenden-Button ---------- */
.mgic .mgic-form__trust { display: flex; align-items: center; justify-content: center; gap: 7px; margin: 12px 0 0; color: var(--mgic-text-muted, #646970); font-size: var(--mgic-fact-size); line-height: 1.4; text-align: left; }
.mgic .mgic-form__trust .mgic-ico { width: 16px; height: 16px; flex: 0 0 auto; color: var(--mgic-primary); }

/* ---------- Schnellsuche (Vorfilter-Box) – nutzt die Plugin-/ACSS-Tokens ---------- */
.mgic .mgic-schnellsuche { background: var(--mgic-surface, #fff); border: 1px solid var(--mgic-border, #e3e6ea); border-radius: var(--mgic-radius, 14px); padding: clamp(1.25rem, 3vw, 2rem); max-width: 640px; }
.mgic .mgic-schnellsuche__header { display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap; margin-bottom: .4rem; }
.mgic .mgic-schnellsuche__count { font-size: clamp(1.8rem, 4vw, 2.4rem); font-weight: 800; line-height: 1; letter-spacing: -.02em; color: var(--mgic-primary); }
.mgic .mgic-schnellsuche__title { font-size: clamp(1.05rem, 2.4vw, 1.35rem); font-weight: 700; text-transform: uppercase; letter-spacing: .02em; color: var(--mgic-heading, #323a4d); }
.mgic .mgic-schnellsuche__subtitle { margin: 0 0 1.5rem; color: var(--mgic-text, #3a4151); line-height: 1.5; }
.mgic .mgic-schnellsuche__section { margin-bottom: 1.4rem; }
.mgic .mgic-schnellsuche__label { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--mgic-text-muted, #5b6573); margin-bottom: .65rem; }
.mgic .mgic-schnellsuche__toggles { display: flex; flex-wrap: wrap; gap: .5rem; }
.mgic .mgic-ss-toggle { padding: .55rem 1.25rem; border: 1px solid var(--mgic-border, #e3e6ea); border-radius: var(--mgic-radius-s, .5rem); background: var(--mgic-surface-alt, #f4f5f7); color: var(--mgic-text, #3a4151); font: inherit; font-size: .9rem; font-weight: 500; line-height: 1.4; white-space: nowrap; cursor: pointer; transition: background .15s ease, color .15s ease, border-color .15s ease; }
.mgic .mgic-ss-toggle:hover { border-color: var(--mgic-primary); color: var(--mgic-primary); }
.mgic .mgic-ss-toggle.is-active { background: var(--mgic-primary); border-color: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff); }
.mgic .mgic-schnellsuche__submit { display: inline-flex; align-items: center; gap: .5rem; margin-top: .4rem; padding: .85rem 2rem; border: none; border-radius: var(--mgic-radius-s, .5rem); background: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff); font: inherit; font-size: .9rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; cursor: pointer; transition: background .15s ease; }
.mgic .mgic-schnellsuche__submit:hover { background: var(--mgic-primary-hover, var(--mgic-primary)); }
@media (max-width: 480px) { .mgic .mgic-ss-toggle { padding: .5rem 1rem; font-size: .85rem; } }

/* ---------- Filter-Template „Minimal" (Leiste + Off-Canvas-Drawer mit Slidern & Histogramm) ---------- */
.mgic .mgic-fmini { margin: 0 0 24px; }
.mgic .mgic-fmini__bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.mgic .mgic-fmini__market { flex: 0 1 auto; }
.mgic .mgic-fmini__open { display: inline-flex; align-items: center; gap: 7px; padding: .7em 1.25em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-pill); background: var(--mgic-surface); color: var(--mgic-text); font: inherit; font-weight: 600; cursor: pointer; box-shadow: var(--mgic-shadow); }
.mgic .mgic-fmini__open:hover { border-color: var(--mgic-primary); color: var(--mgic-primary); }
.mgic .mgic-fmini__open svg { width: 18px; height: 18px; }
.mgic .mgic-fmini__go { margin-left: auto; }

/* Overlay + Drawer */
.mgic .mgic-fmini__overlay { position: fixed; inset: 0; z-index: 100000; background: rgba(20,24,33,.45); opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease; }
.mgic .mgic-fmini.is-open .mgic-fmini__overlay { opacity: 1; visibility: visible; }
.mgic .mgic-fmini__drawer { position: fixed; top: 0; right: 0; z-index: 100001; display: flex; flex-direction: column; width: min(440px, 100%); height: 100%; background: var(--mgic-surface, #fff); box-shadow: -8px 0 40px rgba(0,0,0,.18); transform: translateX(100%); visibility: hidden; transition: transform .28s cubic-bezier(.4,0,.2,1), visibility .28s ease; }
.mgic .mgic-fmini.is-open .mgic-fmini__drawer { transform: none; visibility: visible; }
.mgic .mgic-fmini__head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--mgic-border); }
.mgic .mgic-fmini__head strong { font-size: 1.15rem; color: var(--mgic-heading); }
.mgic .mgic-fmini__close { background: none; border: 0; font-size: 1.9rem; line-height: 1; color: var(--mgic-text-muted); cursor: pointer; }
.mgic .mgic-fmini__close:hover { color: var(--mgic-primary); }
.mgic .mgic-fmini__body { flex: 1 1 auto; overflow-y: auto; padding: 8px 22px 22px; }
.mgic .mgic-fmini__sec { padding: 18px 0; border-bottom: 1px solid var(--mgic-border); }
.mgic .mgic-fmini__sec:last-child { border-bottom: 0; }
.mgic .mgic-fmini__h { margin: 0 0 14px; font-size: 1rem; color: var(--mgic-heading); display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.mgic .mgic-fmini__hint { font-size: .85rem; font-weight: 500; color: var(--mgic-primary); }
.mgic .mgic-fmini__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 22px; border-top: 1px solid var(--mgic-border); }
.mgic .mgic-fmini__clear { color: var(--mgic-text-muted); font-weight: 600; text-decoration: none; }
.mgic .mgic-fmini__clear:hover { color: var(--mgic-primary); }

/* Property-Type-Pills */
.mgic .mgic-fmini__pills { display: flex; flex-wrap: wrap; gap: 8px; }
.mgic .mgic-fmini__pill input { position: absolute; opacity: 0; width: 0; height: 0; }
.mgic .mgic-fmini__pill span { display: inline-block; padding: .5em 1.05em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); color: var(--mgic-text); font-size: .9rem; font-weight: 500; cursor: pointer; transition: all .15s ease; }
.mgic .mgic-fmini__pill input:checked + span { border-color: var(--mgic-primary); color: var(--mgic-primary); background: var(--mgic-primary-light, rgba(0,0,0,.04)); font-weight: 700; }
.mgic .mgic-fmini__pill input:focus-visible + span { outline: 2px solid var(--mgic-primary); outline-offset: 2px; }

/* Segmente (Zimmer/Bäder) – Buttonreihe */
.mgic .mgic-fmini__seg2 { display: flex; flex-wrap: wrap; gap: 6px; }
.mgic .mgic-fmini__seg2 label { margin: 0; }
.mgic .mgic-fmini__seg2 input { position: absolute; opacity: 0; width: 0; height: 0; }
.mgic .mgic-fmini__seg2 span { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; padding: .45em .75em; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); color: var(--mgic-text); font-size: .9rem; font-weight: 500; cursor: pointer; transition: all .15s ease; }
.mgic .mgic-fmini__seg2 input:checked + span { background: var(--mgic-primary); border-color: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff); font-weight: 700; }
.mgic .mgic-fmini__seg2 input:focus-visible + span { outline: 2px solid var(--mgic-primary); outline-offset: 2px; }

/* Range-Slider (Preis dual + Größe single) + Histogramm + Bubbles */
.mgic .mgic-fmini__range { position: relative; height: 92px; padding-top: 52px; }
.mgic .mgic-fmini__range--single { height: 44px; padding-top: 4px; }
.mgic .mgic-fmini__hist { position: absolute; top: 0; left: 0; right: 0; height: 46px; }
.mgic .mgic-fmini__hist svg { width: 100%; height: 100%; display: block; overflow: visible; }
.mgic .mgic-fmini__track { position: absolute; left: 8px; right: 8px; top: 58px; height: 5px; border-radius: 3px; background: var(--mgic-border); }
.mgic .mgic-fmini__range--single .mgic-fmini__track { top: 18px; }
.mgic .mgic-fmini__track-sel { position: absolute; top: 0; height: 100%; border-radius: 3px; background: var(--mgic-primary); }
.mgic .mgic-fmini__rinput { position: absolute; left: 0; right: 0; top: 46px; width: 100%; height: 28px; margin: 0; padding: 0; background: none; pointer-events: none; -webkit-appearance: none; appearance: none; }
.mgic .mgic-fmini__range--single .mgic-fmini__rinput { top: 6px; pointer-events: auto; }
.mgic .mgic-fmini__rinput::-webkit-slider-runnable-track { background: none; border: 0; height: 28px; }
.mgic .mgic-fmini__rinput::-moz-range-track { background: none; border: 0; height: 28px; }
.mgic .mgic-fmini__rinput::-webkit-slider-thumb { pointer-events: auto; -webkit-appearance: none; width: 22px; height: 22px; margin-top: 3px; border-radius: 50%; background: var(--mgic-primary); border: 3px solid var(--mgic-surface, #fff); box-shadow: 0 1px 6px rgba(0,0,0,.25); cursor: pointer; }
.mgic .mgic-fmini__rinput::-moz-range-thumb { pointer-events: auto; width: 20px; height: 20px; border-radius: 50%; background: var(--mgic-primary); border: 3px solid var(--mgic-surface, #fff); box-shadow: 0 1px 6px rgba(0,0,0,.25); cursor: pointer; }
.mgic .mgic-fmini__bubble { position: absolute; top: 76px; transform: translateX(-50%); white-space: nowrap; background: var(--mgic-primary); color: var(--mgic-primary-contrast, #fff); font-size: .78rem; font-weight: 700; padding: 3px 9px; border-radius: var(--mgic-radius-pill); pointer-events: none; }
.mgic .mgic-fmini__range--single .mgic-fmini__bubble { top: 30px; }
/* Zu wenige Objekte für ein aussagekräftiges Histogramm -> kompakter Slider ohne Chart. */
.mgic .mgic-fmini__range.is-flat { padding-top: 6px; height: 58px; }
.mgic .mgic-fmini__range.is-flat .mgic-fmini__hist { display: none; }
.mgic .mgic-fmini__range.is-flat .mgic-fmini__track { top: 20px; }
.mgic .mgic-fmini__range.is-flat .mgic-fmini__rinput { top: 8px; }
.mgic .mgic-fmini__range.is-flat .mgic-fmini__bubble { top: 34px; }
.mgic .mgic-fmini__minmax { display: flex; gap: 12px; margin-top: 30px; }
.mgic .mgic-fmini__minmax label { flex: 1 1 0; display: flex; flex-direction: column; gap: 4px; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--mgic-text-muted); }
.mgic .mgic-fmini__minmax input { height: 44px; padding: 0 12px; border: 1px solid var(--mgic-border); border-radius: var(--mgic-radius-s); background: var(--mgic-surface, #fff); color: var(--mgic-text); font: inherit; font-size: .95rem; }
.mgic .mgic-fmini__minmax input:focus { outline: none; border-color: var(--mgic-primary); box-shadow: 0 0 0 3px var(--mgic-primary-light, rgba(0,0,0,.06)); }

@media (max-width: 600px) {
	.mgic .mgic-fmini__drawer { width: 100%; }
	.mgic .mgic-fmini__go { margin-left: 0; width: 100%; }
}
