/* Stöberhalle www — Frontend v2 */

:root {
	--cream: #faf6f0;
	--cream-dark: #f0e8dc;
	--red: #972c2c;
	--red-deep: #893c35;
	--red-mid: #a3534d;
	--red-light: #b5514b;
	--red-pale: #f5e8e7;
	--accent-warm: #d4a574;
	--ink: #2a2420;
	--ink-muted: #5c534c;
	--white: #ffffff;
	--radius: 14px;
	--radius-sm: 8px;
	--shadow: 0 4px 24px rgba(42, 36, 32, 0.08);
	--shadow-lg: 0 12px 48px rgba(42, 36, 32, 0.12);
	--font-display: "Fraunces", Georgia, serif;
	--font-body: "Source Sans 3", system-ui, sans-serif;
	--max: 1180px;
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; height: 100%; }

body {
	margin: 0;
	overflow-x: hidden;
	font-family: var(--font-body);
	font-size: 1.05rem;
	line-height: 1.65;
	color: var(--ink);
	background: var(--cream);
	min-height: 100%;
}

img { max-width: 100%; height: auto; display: block; }

a {
	color: var(--red);
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

a:hover { color: var(--red-deep); }

.container { width: min(var(--max), 100% - 2.5rem); margin-inline: auto; }

/* —— Header —— */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(250, 246, 240, 0.92);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(42, 36, 32, 0.06);
}

.header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 0.85rem 0;
	position: relative;
}

.logo img { height: 42px; width: auto; }

.site-header nav { flex: 1; display: flex; justify-content: flex-end; }

ul.level0.nav-main,
ul.nav-main {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.25rem 1.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

ul.level0.nav-main a,
ul.nav-main a {
	text-decoration: none;
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--ink);
	padding: 0.35rem 0;
	border-bottom: 2px solid transparent;
	transition: color 0.15s, border-color 0.15s;
}

ul.level0.nav-main a:hover,
ul.level0.nav-main a.is-active,
ul.nav-main a:hover,
ul.nav-main a.is-active {
	color: var(--red);
	border-bottom-color: var(--accent-warm);
}

ul.level0.nav-main a span,
ul.nav-main a span { border: none; }

.nav-toggle {
	display: none;
	background: var(--red);
	color: var(--white);
	border: none;
	border-radius: var(--radius-sm);
	padding: 0.5rem 0.85rem;
	font: inherit;
	font-weight: 600;
	cursor: pointer;
	flex-shrink: 0;
}

/* —— Main / Unterseiten —— */
.site-main { min-height: 40vh; }

.cms-section {
	padding: 3.5rem 0;
}

body:not(.mainpage) .cms-section {
	padding: 2.75rem 0 3.5rem;
	background: linear-gradient(180deg, var(--cream) 0%, var(--cream-dark) 100%);
}

body:not(.mainpage) .cms-page-header {
	text-align: center;
	max-width: 42rem;
	margin-inline: auto;
	border-bottom: none;
	padding-bottom: 0;
}

body:not(.mainpage) .cms-page-header .page-lead {
	margin-inline: auto;
}

/* Textseiten (CMS-Fließtext, FAQ, Formulare) — Karte statt „nackter“ Body */
body:not(.mainpage) .cms-page-body:not(:has(> .hero)):not(:has(> .section)) {
	background: var(--white);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 2rem 1.75rem;
	border: 1px solid rgba(42, 36, 32, 0.06);
}

@media (min-width: 768px) {
	body:not(.mainpage) .cms-page-body:not(:has(> .hero)):not(:has(> .section)) {
		padding: 2.5rem 2.75rem;
	}
}

body:not(.mainpage) .cms-page-body:not(:has(> .hero)):not(:has(> .section)) > :first-child {
	margin-top: 0;
}

body:not(.mainpage) .cms-page-body:not(:has(> .hero)):not(:has(> .section)) > :last-child {
	margin-bottom: 0;
}

/* Startseite (body.mainpage): Shell nur durchreichen, Inhalt bringt eigene Sections */
body.mainpage .cms-shell .cms-page-header {
	display: none;
}

body.mainpage .cms-shell .cms-section {
	padding: 0;
}

body.mainpage .cms-shell .container.cms-page {
	width: 100%;
	max-width: none;
	margin-inline: 0;
	padding: 0;
}

/* Subtemplates ohne CMS-Body (z. B. FAQ): leere Hülle ausblenden */
.cms-shell:not(:has(.cms-page-body > *)) {
	display: none;
}

.cms-page-header:not(:has(h1:not(:empty))) {
	display: none;
	margin: 0;
	padding: 0;
	border: none;
}

.cms-page {
	max-width: 100%;
}

.cms-page-header {
	margin-bottom: 2rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid rgba(42, 36, 32, 0.08);
}

.cms-page-header h1 {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.35rem);
	color: var(--red-deep);
	margin: 0;
	line-height: 1.2;
}

.cms-page-body > .page-lead:first-child {
	margin-top: 0;
}

body.page-gallery .cms-section {
	background: var(--white);
}

body.page-location .cms-page-body {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 2.5rem;
	align-items: start;
}

body.page-location .page-hero-sub {
	grid-column: 1 / -1;
	margin: 0 0 0.5rem;
	border-radius: var(--radius);
	padding: 1.25rem 1.5rem;
}

body.page-location .location-main {
	min-width: 0;
}

.page-header {
	margin-bottom: 2rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid rgba(42, 36, 32, 0.08);
}

.page-header h1 {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.35rem);
	color: var(--red-deep);
	margin: 0;
	line-height: 1.2;
}

.page-lead {
	margin: 0.75rem 0 0;
	font-size: 1.1rem;
	color: var(--ink-muted);
	max-width: 52ch;
}

.sell-steps {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	counter-reset: sell-step;
}

.sell-steps li {
	counter-increment: sell-step;
	background: var(--white);
	border: 1px solid rgba(42, 36, 32, 0.06);
	border-radius: var(--radius);
	padding: 1.25rem 1.25rem 1.25rem 4rem;
	margin-bottom: 0.75rem;
	box-shadow: var(--shadow);
	position: relative;
}

.sell-steps li::before {
	content: counter(sell-step);
	position: absolute;
	left: 1.25rem;
	top: 1.25rem;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	background: var(--red);
	color: var(--white);
	font-weight: 700;
	font-size: 0.9rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sell-steps li strong {
	display: block;
	color: var(--red-deep);
	margin-bottom: 0.35rem;
}

.sell-steps li p {
	margin: 0;
}

.page-hero-sub {
	min-height: 140px;
	display: flex;
	align-items: flex-end;
	padding: 1.25rem 0;
	margin-bottom: 0;
}

.page-hero-sub--luene {
	background: linear-gradient(160deg, #c4685e 0%, var(--red) 100%);
}

.page-hero-sub--bahn {
	background: linear-gradient(160deg, #a85a52 0%, var(--red-deep) 100%);
}

.page-hero-sub .location-tag {
	background: rgba(255, 255, 255, 0.92);
	color: var(--red-deep);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 0.3rem 0.75rem;
	border-radius: 999px;
}

.cms-page h2 {
	font-family: var(--font-display);
	font-size: 1.35rem;
	color: var(--red-deep);
	margin: 2rem 0 0.75rem;
}

.cms-page h3 {
	font-size: 1.1rem;
	color: var(--ink);
	margin: 1.5rem 0 0.5rem;
}

/* CMS-Fließtext — nicht Hero, Sektionen oder Portal-Formular */
.cms-page-body > p,
.cms-page-body > .page-lead,
.cms-page-body > ul li,
.cms-page-body > ol li {
	color: var(--ink-muted);
}

.cms-page ol li { margin-bottom: 0.75rem; }

.cms-page-body > h2:first-child,
.cms-page-body > h3:first-child {
	margin-top: 0;
}

.cms-page-body > p:first-of-type:not(.page-lead) {
	font-size: 1.08rem;
}

.cms-page ul,
.cms-page ol {
	padding-left: 1.25rem;
	margin: 0 0 1rem;
}

.cms-page img {
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow);
	margin: 1rem 0;
}

.cms-page table {
	width: 100%;
	border-collapse: collapse;
	margin: 1rem 0;
}

.cms-page table td {
	padding: 0.35rem 0.5rem;
	vertical-align: top;
}

.cms-page table td:first-child {
	color: var(--ink-muted);
	width: 5rem;
	text-align: right;
	padding-right: 1rem;
}

.cms-page .btn-primary {
	background: var(--red);
	border-color: var(--red);
	color: var(--white);
	border-radius: 0.6em;
	font-weight: 600;
	padding: 0.65rem 1.25rem;
}

.cms-page .btn-primary:hover {
	background: var(--red-deep);
	border-color: var(--red-deep);
	color: var(--white);
}

/* —— Hero —— */
.hero {
	position: relative;
	min-height: clamp(420px, 62vh, 580px);
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	margin-bottom: 0;
}

.hero-bg {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(137, 60, 53, 0.88) 0%, rgba(151, 44, 44, 0.72) 50%, rgba(42, 36, 32, 0.45) 100%);
	background-color: var(--red-deep);
}

.hero-bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.hero-content {
	position: relative;
	padding: 3rem 0 3.5rem;
	color: var(--white);
}

.hero-content p,
.hero-content .hero-lead {
	color: rgba(255, 255, 255, 0.95);
}

.hero-badge {
	display: inline-block;
	background: rgba(255, 255, 255, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 999px;
	padding: 0.35rem 1rem;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}

.hero h1 {
	font-family: var(--font-display);
	font-size: clamp(2.2rem, 5vw, 3.4rem);
	font-weight: 700;
	line-height: 1.15;
	margin: 0 0 1rem;
	max-width: 14ch;
	color: var(--white);
}

.hero-lead {
	font-size: 1.15rem;
	max-width: 52ch;
	margin: 0 0 1.75rem;
	opacity: 0.95;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.35rem;
	border-radius: 0.6em;
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	transition: transform 0.15s, background 0.15s, border-color 0.15s;
}

.btn:hover { transform: translateY(-1px); }

.btn-primary {
	background: var(--white);
	color: var(--red-deep);
	border-color: var(--white);
}

.btn-primary:hover {
	background: var(--red-pale);
	color: var(--red-deep);
}

.btn-outline {
	background: transparent;
	color: var(--white);
	border-color: rgba(255, 255, 255, 0.6);
}

.btn-outline:hover {
	background: rgba(255, 255, 255, 0.12);
	color: var(--white);
}

.btn-brand {
	background: var(--red);
	color: var(--white);
	border-color: var(--red);
}

.btn-brand:hover {
	background: var(--red-deep);
	color: var(--white);
}

/* —— Sections —— */
.section { padding: 3.5rem 0; }
.section-alt { background: var(--white); }

.section-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

.section-header h2 {
	font-family: var(--font-display);
	font-size: clamp(1.6rem, 3vw, 2.1rem);
	margin: 0 0 0.5rem;
	color: var(--red-deep);
}

.section-header p {
	margin: 0 auto;
	max-width: 50ch;
	color: var(--ink-muted);
}

.section-cta { text-align: center; margin-top: 1.5rem; }

/* —— Location cards —— */
.locations {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
}

.location-card {
	background: var(--white);
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow);
	display: flex;
	flex-direction: column;
	border: 1px solid rgba(42, 36, 32, 0.06);
}

.location-card-visual {
	height: 200px;
	background: linear-gradient(160deg, var(--red-light), var(--red-deep));
	position: relative;
	display: flex;
	align-items: flex-end;
	padding: 1.25rem;
}

.location-card-visual.loc-luene {
	background: linear-gradient(160deg, #c4685e 0%, var(--red) 100%);
}

.location-card-visual.loc-bahn {
	background: linear-gradient(160deg, #a85a52 0%, var(--red-deep) 100%);
}

.location-tag {
	background: rgba(255, 255, 255, 0.92);
	color: var(--red-deep);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 0.3rem 0.75rem;
	border-radius: 999px;
}

.location-card-body {
	padding: 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.location-card h3 {
	font-family: var(--font-display);
	font-size: 1.25rem;
	margin: 0 0 0.75rem;
	color: var(--ink);
}

.location-card p {
	margin: 0 0 1rem;
	color: var(--ink-muted);
	flex: 1;
}

.location-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	font-size: 0.88rem;
	color: var(--ink-muted);
	margin-bottom: 1.25rem;
}

.location-meta span::before {
	content: "\25cf";
	color: var(--red-mid);
	margin-right: 0.4rem;
	font-size: 0.6rem;
	vertical-align: middle;
}

/* —— Benefits —— */
.benefits {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.25rem;
}

.benefit {
	background: var(--cream);
	border-radius: var(--radius);
	padding: 1.5rem;
	text-align: center;
	border: 1px solid rgba(42, 36, 32, 0.06);
}

.benefit-icon {
	width: 52px;
	height: 52px;
	margin: 0 auto 1rem;
	border-radius: 50%;
	background: var(--red);
	color: var(--white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
}

.benefit h3 {
	font-size: 1rem;
	margin: 0 0 0.4rem;
	color: var(--red-deep);
}

.benefit p {
	margin: 0;
	font-size: 0.9rem;
	color: var(--ink-muted);
}

/* —— Info strip —— */
.info-strip {
	background: linear-gradient(135deg, var(--red-deep) 0%, var(--red) 100%);
	color: var(--white);
	border-radius: var(--radius);
	padding: 2rem;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 2rem;
	align-items: center;
	box-shadow: var(--shadow-lg);
}

.info-strip h2 {
	font-family: var(--font-display);
	font-size: 1.5rem;
	margin: 0 0 1rem;
	color: var(--white);
}

.info-strip-note {
	margin: 1.25rem 0 0;
	font-size: 0.92rem;
	opacity: 0.85;
}

.hours-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
}

.hours-block h4 {
	margin: 0 0 0.35rem;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--accent-warm);
}

.hours-block p {
	margin: 0;
	font-size: 0.95rem;
	opacity: 0.92;
}

.whatsapp-box {
	text-align: center;
	background: rgba(255, 255, 255, 0.08);
	border-radius: var(--radius-sm);
	padding: 1.25rem;
	min-width: 180px;
}

.whatsapp-qr {
	width: 120px;
	height: auto;
	margin: 0 auto 0.75rem;
	border-radius: var(--radius-sm);
	background: var(--white);
}

.whatsapp-box p {
	margin: 0;
	font-size: 0.85rem;
	opacity: 0.9;
}

/* —— CTA band —— */
.cta-band {
	text-align: center;
	padding: 3rem 2rem;
	background: var(--cream-dark);
	border-radius: var(--radius);
}

.cta-band h2 {
	font-family: var(--font-display);
	font-size: 1.75rem;
	color: var(--red-deep);
	margin: 0 0 0.75rem;
}

.cta-band p {
	margin: 0 0 1.5rem;
	color: var(--ink-muted);
}

/* —— Standort-Seiten —— */
.location-layout {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 2.5rem;
	align-items: start;
}

.location-main .page-lead {
	margin-top: 0;
}

.location-photo {
	margin: 0 0 1.5rem;
}

.location-photo img {
	width: 100%;
	height: auto;
}

.location-note {
	font-style: italic;
	color: var(--ink-muted);
	margin-top: 1rem;
}

.feature-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.75rem;
	margin: 1rem 0 1.5rem;
}

.feature-item {
	background: var(--white);
	border: 1px solid rgba(42, 36, 32, 0.06);
	border-radius: var(--radius-sm);
	padding: 0.85rem 1rem;
	box-shadow: var(--shadow);
}

.feature-item strong {
	display: block;
	color: var(--red-deep);
	font-size: 0.92rem;
	margin-bottom: 0.2rem;
}

.feature-item span {
	font-size: 0.85rem;
	color: var(--ink-muted);
}

.check-list {
	list-style: none;
	padding: 0;
	margin: 1rem 0 2rem;
}

.check-list li {
	position: relative;
	padding-left: 1.5rem;
	margin-bottom: 0.5rem;
	color: var(--ink-muted);
}

.check-list li::before {
	content: "\2713";
	position: absolute;
	left: 0;
	color: var(--red);
	font-weight: 700;
}

.location-aside {
	position: sticky;
	top: 5.5rem;
}

.location-facts {
	background: linear-gradient(135deg, var(--red-deep) 0%, var(--red) 100%);
	color: var(--white);
	border-radius: var(--radius);
	padding: 1.5rem;
	box-shadow: var(--shadow-lg);
	margin-bottom: 1rem;
}

.location-facts h3 {
	font-family: var(--font-display);
	font-size: 1rem;
	margin: 0 0 0.75rem;
	color: var(--accent-warm);
}

.location-facts h3 + dl + h3 {
	margin-top: 1.25rem;
}

.location-facts dl {
	margin: 0;
}

.location-facts dt {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	opacity: 0.8;
	margin-top: 0.65rem;
}

.location-facts dt:first-child { margin-top: 0; }

.location-facts dd {
	margin: 0.15rem 0 0;
	font-size: 0.95rem;
}

.location-facts a {
	color: var(--white);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.location-facts a:hover { color: var(--accent-warm); }

.hours-list {
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 0.95rem;
}

.hours-list li {
	padding: 0.2rem 0;
}

.location-crosslink {
	background: var(--cream-dark);
	border-radius: var(--radius-sm);
	padding: 1.25rem;
	text-align: center;
}

.location-crosslink p {
	margin: 0 0 0.75rem;
	font-size: 0.92rem;
	color: var(--ink-muted);
}

.btn-outline-dark {
	background: transparent;
	color: var(--red-deep);
	border: 2px solid var(--red);
}

.btn-outline-dark:hover {
	background: var(--red-pale);
	color: var(--red-deep);
}

.streetview-cta {
	background: var(--cream-dark);
	border-radius: var(--radius);
	padding: 2rem;
	margin-top: 1.5rem;
	text-align: center;
}

.streetview-cta p {
	margin: 0 0 1.25rem;
	color: var(--ink-muted);
}

.galerie-v2 {
	margin-top: 1.5rem;
}

/* —— Footer —— */
.site-footer {
	background: var(--ink);
	color: rgba(255, 255, 255, 0.75);
	padding: 2.5rem 0 1.5rem;
	margin-top: 0;
}

.footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: 2rem;
	margin-bottom: 2rem;
}

.site-footer h4 {
	color: var(--white);
	margin: 0 0 0.75rem;
	font-size: 0.9rem;
}

.footer-lead {
	margin: 0;
	font-size: 0.9rem;
}

.site-footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer a {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
	font-size: 0.9rem;
	line-height: 2;
}

.site-footer a:hover { color: var(--accent-warm); }

.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding-top: 1rem;
	font-size: 0.82rem;
}

/* —— Carousel (CMS) —— */
.carousel_container {
	max-width: 100%;
	margin: 0 auto;
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow);
}

.carousel_container .carousel-inner .w-100 {
	width: 100%;
	max-width: 100%;
	height: auto;
	object-fit: cover;
	max-height: 480px;
}

.carousel_container .carousel-item { max-height: 480px; }

.carousel_container .carousel-caption {
	background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
	left: 0;
	right: 0;
	bottom: 0;
	padding: 1.5rem 1rem 1rem;
}

.carousel_container .carousel-caption h5 {
	font-family: var(--font-display);
	margin: 0 0 0.25rem;
}

.carousel_container .carousel-caption p { margin: 0; font-size: 0.9rem; }

.carousel-control-prev-icon,
.carousel-control-next-icon { filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.4)); }

/* —— Galerie (CMS) —— */
.galerie ul.picturelist.list {
	display: flex;
	list-style: none;
	flex-wrap: wrap;
	gap: 1rem;
	padding: 0;
	margin: 0;
}

.galerie ul.picturelist.list li {
	border-radius: var(--radius-sm);
	overflow: hidden;
	box-shadow: var(--shadow);
	transition: transform 0.2s, box-shadow 0.2s;
}

.galerie ul.picturelist.list li:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.galerie ul.picturelist.list li a {
	text-decoration: none;
	font-size: 0.85rem;
	color: var(--ink);
}

.galerie ul.picturelist.list li a img {
	filter: grayscale(1);
	transition: filter 0.45s ease, transform 0.25s ease;
}

.galerie ul.picturelist.list li:hover a img {
	filter: grayscale(0);
	transform: scale(1.03);
}

.galerie figure {
	display: block;
	width: 225px;
	margin: 1em 20px;
	border-radius: var(--radius-sm);
	overflow: hidden;
	box-shadow: var(--shadow);
}

/* —— Legacy Grid (alte Unterseiten) —— */
.grid {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 1.5rem;
}

.grid .col1 { grid-column: 1; }
.grid .col2 { grid-column: 2; }

.businesshours {
	background: var(--red-pale);
	border-radius: var(--radius-sm);
	padding: 1rem 1.25rem;
	border-left: 4px solid var(--red);
}

/* —— FAQ —— */
.faq-overview,
.faq-view {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
}

.faq-category-list {
	background: var(--cream);
	border-radius: var(--radius-sm);
	padding: 1rem 1.25rem;
	border: 1px solid rgba(42, 36, 32, 0.06);
}

.faq-view > p a {
	font-weight: 600;
	text-decoration: none;
}

.faq-view > p a:hover { color: var(--red-deep); }
.faq-accordion h2.accordion-header { margin: 0; }

.faq-overview .accordion-button:not(.collapsed),
.faq-view .accordion-button:not(.collapsed) {
	background: var(--red-pale);
	color: var(--red-deep);
}

.faq-overview .accordion-button:focus,
.faq-view .accordion-button:focus {
	box-shadow: 0 0 0 0.2rem rgba(151, 44, 44, 0.2);
}

.faq-overview .accordion-item,
.faq-view .accordion-item {
	border-color: rgba(42, 36, 32, 0.08);
	border-radius: var(--radius-sm) !important;
	overflow: hidden;
	margin-bottom: 0.5rem;
}

.faq-overview a.link-primary,
.faq-view a.link-primary { color: var(--red); }

/* —— Cookie-Modal —— */
#cookieModal .btn-brand { margin-left: 0.25rem; }

#cookieModal .modal-title { color: var(--red-deep); }

/* —— Bootstrap row/col fallback —— */
.site-main .row {
	width: min(var(--max), 100% - 2.5rem);
	margin-left: auto;
	margin-right: auto;
}

.section + .section.section-alt,
.section.section-alt + .section { border-top: none; }

/* —— Responsive —— */
@media (max-width: 900px) {
	.locations { grid-template-columns: 1fr; }
	.benefits { grid-template-columns: repeat(2, 1fr); }
	.info-strip { grid-template-columns: 1fr; }
	.hours-grid { grid-template-columns: 1fr; }
	.footer-grid { grid-template-columns: 1fr; }
	.grid { display: block; }
	.location-layout,
	body.page-location .cms-page-body { grid-template-columns: 1fr; }
	.location-aside { position: static; }
	.feature-grid { grid-template-columns: 1fr; }
}

/* —— Kundenportal-Anfrage (/zugang) —— */
body.zugang .cms-page {
	max-width: 52rem;
}

body.zugang .cms-page-header {
	text-align: center;
}

body.zugang .cms-page-header .page-lead {
	margin-inline: auto;
	max-width: 42ch;
}

body.zugang .portal-access-card {
	background: transparent;
	border: none;
	box-shadow: none;
	padding: 0;
}

.portal-access-card {
	background: var(--white);
	border: 1px solid rgba(42, 36, 32, 0.06);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 1.75rem 1.5rem;
}

@media (min-width: 768px) {
	.portal-access-card {
		padding: 2rem 2.25rem;
	}
}

.portal-access-form.d-none {
	display: none;
}

.portal-access-field {
	margin-bottom: 1.15rem;
}

.portal-access-field--check {
	margin-bottom: 1.5rem;
}

.portal-access-label {
	display: block;
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--ink);
	margin-bottom: 0.4rem;
}

.portal-access-input {
	display: block;
	width: 100%;
	font-family: var(--font-body);
	font-size: 1.05rem;
	line-height: 1.4;
	color: var(--ink);
	background: var(--cream);
	border: 1px solid rgba(42, 36, 32, 0.14);
	border-radius: var(--radius-sm);
	padding: 0.75rem 1rem;
	transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.portal-access-input::placeholder {
	color: rgba(92, 83, 76, 0.55);
}

.portal-access-input:focus {
	border-color: var(--red-mid);
	box-shadow: 0 0 0 3px rgba(151, 44, 44, 0.14);
	outline: none;
	background: var(--white);
}

.portal-access-hint {
	margin: 0.4rem 0 0;
	font-size: 0.9rem;
	color: var(--ink-muted);
}

.portal-access-check {
	display: flex;
	gap: 0.65rem;
	align-items: flex-start;
	cursor: pointer;
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--ink-muted);
}

.portal-access-check input {
	flex-shrink: 0;
	width: 1.1rem;
	height: 1.1rem;
	margin-top: 0.2rem;
	accent-color: var(--red);
}

.portal-access-submit {
	width: 100%;
	font-size: 1.05rem;
	padding: 0.85rem 1.25rem;
}

.portal-access-footnote {
	text-align: center;
	margin: 1.35rem 0 0;
	font-size: 0.92rem;
	color: var(--ink-muted);
}

.portal-access-footnote a {
	font-weight: 600;
}

.portal-access-message {
	padding: 0.85rem 1rem;
	border-radius: var(--radius-sm);
	margin-bottom: 1.15rem;
	font-size: 0.95rem;
	line-height: 1.5;
}

.portal-access-message--error {
	background: var(--red-pale);
	color: var(--red-deep);
	border: 1px solid rgba(151, 44, 44, 0.22);
}

.portal-access-message--success {
	background: #edf5ee;
	color: #2d5a34;
	border: 1px solid rgba(45, 90, 52, 0.2);
}

.portal-access-message--warning {
	background: #fff8e6;
	color: #6b5420;
	border: 1px solid rgba(107, 84, 32, 0.22);
}

/* —— Bootstrap/Legacy: v2-Farben durchsetzen (styles.css vor diesem Sheet) —— */
:root {
	--bs-body-color: var(--ink);
	--bs-body-color-rgb: 42, 36, 32;
	--bs-body-bg: var(--cream);
	--bs-body-bg-rgb: 250, 246, 240;
	--bs-link-color: var(--red);
	--bs-link-hover-color: var(--red-deep);
}

body {
	color: var(--ink);
	background: var(--cream);
}

.btn.btn-brand {
	--bs-btn-bg: var(--red);
	--bs-btn-border-color: var(--red);
	--bs-btn-color: var(--white);
	--bs-btn-hover-bg: var(--red-deep);
	--bs-btn-hover-border-color: var(--red-deep);
	--bs-btn-hover-color: var(--white);
	--bs-btn-active-bg: var(--red-deep);
	--bs-btn-active-border-color: var(--red-deep);
	background-color: var(--red);
	border-color: var(--red);
	color: var(--white);
}

.btn.btn-brand:hover,
.btn.btn-brand:focus-visible {
	background-color: var(--red-deep);
	border-color: var(--red-deep);
	color: var(--white);
}

@media (max-width: 640px) {
	.nav-toggle { display: block; }
	ul.level0.nav-main,
	ul.nav-main {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--cream);
		flex-direction: column;
		align-items: flex-start;
		padding: 1rem 1.25rem;
		border-bottom: 1px solid rgba(42, 36, 32, 0.08);
		box-shadow: var(--shadow);
	}
	ul.level0.nav-main.is-open,
	ul.nav-main.is-open { display: flex; }
	.benefits { grid-template-columns: 1fr; }
	.hero h1 { max-width: none; }
}
