/*--------------------------------------------------------------
Naturheilpraxis – moderne Design-Schicht (2.0)
----------------------------------------------------------------
Lädt nach style.css und verwandelt das klassische Colinear-Layout
in ein modernes, warmes Praxis-Design: vollflächige Bänder,
sticky Header mit Termin-Button, Hero-Sektion, Karten-Raster,
dunkler Praxis-Footer und sanfte Scroll-Animationen.

Inhalt:
 1. Basis & Typografie
 2. Layout (volle Breite, Container)
 3. Topbar
 4. Header & Navigation
 5. Buttons & Kicker
 6. Sektionen
 7. Hero
 8. Karten (Leistungen, Aktuelles)
 9. Patientenstimmen
10. Über die Praxis
11. Kontakt-Band & Kontakt-Karten
12. Seitenkopf (Leistungen-Archiv & Einzelansicht)
13. Öffnungszeiten
14. Footer
15. Back-to-top
16. Scroll-Animationen
--------------------------------------------------------------*/

/*--------------------------------------------------------------
 1. Basis & Typografie
--------------------------------------------------------------*/
body,
button,
input,
select,
textarea {
	font-family: var(--font-body);
}
body {
	color: var(--ink);
	font-size: 17px;
	line-height: 1.7;
}
h1, h2, h3, h4, h5, h6,
.site-title {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--ink-dark);
	letter-spacing: -0.015em;
}
.entry-content a,
.comment-content a {
	text-decoration: underline;
	text-decoration-color: rgba(110, 146, 119, 0.45);
	text-underline-offset: 3px;
}
.entry-content a:hover,
.comment-content a:hover {
	text-decoration-color: currentColor;
}
.pxs-icon {
	flex-shrink: 0;
	vertical-align: -0.15em;
}

/*--------------------------------------------------------------
 2. Layout (volle Breite, Container)
--------------------------------------------------------------*/
.site {
	background: transparent;
	border-radius: 0;
	box-shadow: none;
	margin: 0;
	max-width: none;
	padding: 0;
	width: 100%;
}
.pxs-container {
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	max-width: 1200px;
	padding-left: 24px;
	padding-right: 24px;
	width: 100%;
}
/* Blog- und Seiteninhalte behalten ihre gewohnte Lesebreite. */
.site-content {
	box-sizing: content-box;
	margin: 0 auto;
	padding: 32px 24px 0;
}
@media screen and (min-width: 864px) {
	.site-content {
		max-width: 768px;
		padding: 40px 48px 0;
	}
}
@media screen and (min-width: 1056px) {
	.site-content {
		max-width: 912px;
	}
}
@media screen and (min-width: 1272px) {
	.site-content {
		max-width: 1176px;
	}
}
/* Startseite & Leistungs-Ansichten: Sektionen über die volle Breite. */
.praxis-front .site-content {
	max-width: none;
	padding: 0;
}
/* Footer-Widget-Bereich mittig begrenzen. */
.widget-area-footer {
	box-sizing: border-box;
	margin: 0 auto;
	max-width: 1200px;
	padding: 48px 24px 16px;
}

/*--------------------------------------------------------------
 3. Topbar
--------------------------------------------------------------*/
.pxs-topbar {
	background: var(--ink-dark);
	color: rgba(255, 255, 255, 0.85);
	font-size: 13.5px;
}
.pxs-topbar-inner {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 20px;
	justify-content: space-between;
	padding-bottom: 9px;
	padding-top: 9px;
}
.pxs-topbar a {
	align-items: center;
	color: inherit;
	display: inline-flex;
	font-weight: 600;
	gap: 7px;
	transition: color var(--transition);
}
.pxs-topbar a:hover,
.pxs-topbar a:focus {
	color: #fff;
}
.pxs-topbar .pxs-icon {
	color: #b9d3bf;
}
.pxs-topbar-kontakt {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 6px 22px;
}
.pxs-topbar-adresse {
	align-items: center;
	display: inline-flex;
	gap: 7px;
}
@media screen and (max-width: 767px) {
	.pxs-topbar-adresse {
		display: none;
	}
}

/*--------------------------------------------------------------
 4. Header & Navigation
--------------------------------------------------------------*/
.site-header {
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	background: rgba(255, 255, 255, 0.92);
	border-bottom: 1px solid var(--border);
	position: sticky;
	top: 0;
	transition: box-shadow var(--transition);
	z-index: 1000;
}
.site-header.pxs-gescrollt {
	box-shadow: var(--shadow-sm);
}
.admin-bar .site-header {
	top: 32px;
}
@media screen and (max-width: 782px) {
	.admin-bar .site-header {
		top: 46px;
	}
}
.pxs-header-inner {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 14px;
	padding-bottom: 12px;
	padding-top: 12px;
}
.site-header .site-branding {
	flex: 1 1 auto;
	float: none;
	margin: 0;
	min-width: 0;
	padding: 0;
	text-align: left;
	width: auto;
}
.site-branding .custom-logo-link {
	display: inline-block;
	line-height: 0;
}
.site-branding img,
.site-branding .custom-logo {
	border-radius: 0;
	display: block;
	height: auto;
	max-height: 60px;
	width: auto;
}
.site-header .site-title {
	font-size: 26px;
	line-height: 1.2;
	margin: 0;
	padding: 0;
}
.site-header .site-description {
	display: none;
}
.site-header .header-image {
	margin: 0;
	padding-bottom: 20px;
}

/* Termin-Button im Header */
.pxs-header-cta {
	font-size: 14.5px;
	order: 3;
	padding: 10px 18px;
}

/* Navigation – mobil: Menü als schwebende Karte unter dem Header */
.site-header .main-navigation {
	border: 0;
	clear: none;
	margin: 0;
	order: 2;
	padding: 0;
	width: auto;
}
.menu-toggle {
	align-items: center;
	background: var(--accent-soft);
	border: 1px solid rgba(110, 146, 119, 0.4);
	border-radius: 12px;
	box-shadow: none;
	color: var(--accent-dark);
	display: flex;
	height: 44px;
	justify-content: center;
	padding: 0;
	width: 44px;
}
.menu-toggle:hover,
.menu-toggle:focus,
.menu-toggle.toggled {
	background: var(--accent);
	box-shadow: none;
	color: #fff;
	transform: none;
}
.main-navigation.toggled ul {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	left: 16px;
	overflow: hidden;
	padding: 10px;
	position: absolute;
	right: 16px;
	top: calc(100% + 8px);
	z-index: 999;
}
.main-navigation li {
	border-bottom: 0;
}
.main-navigation ul a {
	border-radius: var(--radius);
	color: var(--ink);
	font-weight: 600;
	padding: 11px 16px;
	transition: background var(--transition), color var(--transition);
}
.main-navigation ul a:active,
.main-navigation ul a:focus,
.main-navigation ul a:hover {
	background: var(--accent-soft);
	color: var(--accent-dark);
}
.main-navigation .current_page_item > a,
.main-navigation .current-menu-item > a {
	background: var(--accent);
	color: #fff;
}
.main-navigation.toggled ul ul {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	padding: 0 0 0 18px;
	position: static;
}
.dropdown-toggle {
	background: transparent;
	border: 0;
	border-radius: var(--radius);
	box-shadow: none;
	color: var(--accent-dark);
	right: 6px;
	top: 2px;
}
.dropdown-toggle:active,
.dropdown-toggle:focus,
.dropdown-toggle:hover {
	background: var(--accent-soft);
	color: var(--accent-dark);
	transform: none;
}

/* Navigation – Desktop: horizontale Leiste im Header */
@media screen and (min-width: 864px) {
	.menu-toggle {
		display: none;
	}
	.site-header .main-navigation {
		margin-left: auto;
		order: 2;
	}
	.pxs-header-cta {
		order: 3;
	}
	.main-navigation ul,
	.main-navigation.toggled ul {
		align-items: center;
		background: transparent;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-end;
		overflow: visible;
		padding: 0;
		position: static;
	}
	.main-navigation li {
		float: none;
		margin: 0 2px;
	}
	.site-header .main-navigation a {
		border-radius: var(--radius-pill);
		color: var(--ink);
		font-weight: 600;
		padding: 9px 16px;
	}
	.main-navigation a:active,
	.main-navigation a:focus,
	.main-navigation a:hover,
	.main-navigation li:hover > a {
		background: var(--accent-soft);
		color: var(--accent-dark);
	}
	.main-navigation .current_page_item > a,
	.main-navigation .current-menu-item > a,
	.main-navigation .current_page_ancestor > a {
		background: var(--accent);
		color: #fff;
	}
	/* Dropdown als helle Karte */
	.main-navigation ul ul,
	.main-navigation.toggled ul ul {
		background: #fff;
		border: 1px solid var(--border);
		border-radius: var(--radius);
		box-shadow: var(--shadow);
		display: block;
		padding: 8px;
		position: absolute;
	}
	.main-navigation ul ul li {
		border-bottom: 0;
		margin: 2px 0;
	}
	.main-navigation ul ul a {
		border-radius: var(--radius);
		color: var(--ink);
		padding: 8px 16px;
		width: 220px;
	}
	.main-navigation ul ul a:active,
	.main-navigation ul ul a:focus,
	.main-navigation ul ul a:hover,
	.main-navigation ul ul li:hover > a {
		background: var(--accent-soft);
		color: var(--accent-dark);
	}
}

/*--------------------------------------------------------------
 5. Buttons & Kicker
--------------------------------------------------------------*/
.pxs-btn,
.pxs-btn:visited {
	align-items: center;
	border-radius: var(--radius-pill);
	display: inline-flex;
	font-size: 15px;
	font-weight: 700;
	gap: 9px;
	line-height: 1.2;
	padding: 12px 24px;
	text-decoration: none;
	transition: background var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.pxs-btn-primary,
.pxs-btn-primary:visited {
	background: var(--accent);
	box-shadow: var(--shadow-sm);
	color: #fff;
}
.pxs-btn-primary:hover,
.pxs-btn-primary:focus,
.pxs-btn-primary:active {
	background: var(--accent-dark);
	box-shadow: var(--shadow);
	color: #fff;
	transform: translateY(-2px);
}
.pxs-btn-ghost,
.pxs-btn-ghost:visited {
	border: 1.5px solid rgba(110, 146, 119, 0.55);
	color: var(--accent-dark);
	font-weight: 700;
}
.pxs-btn-ghost:hover,
.pxs-btn-ghost:focus,
.pxs-btn-ghost:active {
	background: var(--accent-soft);
	border-color: var(--accent);
	color: var(--accent-dark);
	transform: translateY(-2px);
}
.pxs-btn-gross {
	font-size: 16.5px;
	padding: 15px 30px;
}
/* Heller Button auf dunklen Flächen (Kontakt-Band, Footer) */
.pxs-btn-hell,
.pxs-btn-hell:visited,
.pxs-btn-invert,
.pxs-btn-invert:visited {
	background: #fff;
	box-shadow: var(--shadow-sm);
	color: var(--accent-dark);
}
.pxs-btn-hell:hover,
.pxs-btn-hell:focus,
.pxs-btn-invert:hover,
.pxs-btn-invert:focus {
	background: var(--sand);
	color: var(--ink-dark);
	transform: translateY(-2px);
}
.pxs-kicker {
	align-items: center;
	background: var(--accent-soft);
	border-radius: var(--radius-pill);
	color: var(--accent-dark);
	display: inline-flex;
	font-size: 13px;
	font-weight: 700;
	gap: 7px;
	letter-spacing: 0.07em;
	padding: 7px 15px;
	text-transform: uppercase;
}
.pxs-mehr-link {
	align-items: center;
	color: var(--accent-dark);
	display: inline-flex;
	font-size: 15px;
	font-weight: 700;
	gap: 7px;
}
.pxs-mehr-link .pxs-icon {
	transition: transform var(--transition);
}
a.pxs-mehr-link:hover,
a.pxs-mehr-link:focus {
	color: var(--accent);
}
a.pxs-mehr-link:hover .pxs-icon,
a.pxs-mehr-link:focus .pxs-icon,
.pxs-karte:hover .pxs-mehr-link .pxs-icon {
	transform: translateX(4px);
}

/*--------------------------------------------------------------
 6. Sektionen
--------------------------------------------------------------*/
.pxs-section {
	padding: 72px 0;
}
.pxs-section-kopf {
	align-items: flex-end;
	display: flex;
	flex-wrap: wrap;
	gap: 14px 24px;
	justify-content: space-between;
	margin-bottom: 40px;
}
.pxs-section-titel {
	font-size: clamp(28px, 4vw, 40px);
	line-height: 1.15;
	margin: 0;
}
.pxs-section-untertitel {
	color: var(--muted);
	font-size: 18px;
	margin: 12px auto 26px;
	max-width: 560px;
}
.pxs-section-kopf-zentriert {
	display: block;
	margin-bottom: 44px;
	text-align: center;
}
.pxs-section-ueber,
.pxs-section-seiteninhalt {
	background: #fff;
}
.pxs-section-testimonials {
	background: linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
}
.pxs-seiteninhalt {
	max-width: 820px;
}

/*--------------------------------------------------------------
 7. Hero
--------------------------------------------------------------*/
.pxs-hero {
	background: linear-gradient(180deg, var(--sand) 0%, var(--surface) 85%);
	overflow: hidden;
	position: relative;
}
.pxs-hero-deko {
	inset: 0;
	pointer-events: none;
	position: absolute;
}
.pxs-hero-deko::before,
.pxs-hero-deko::after {
	border-radius: 50%;
	content: "";
	position: absolute;
}
.pxs-hero-deko::before {
	background: radial-gradient(circle at center, rgba(110, 146, 119, 0.20), transparent 65%);
	height: 560px;
	right: -140px;
	top: -180px;
	width: 560px;
}
.pxs-hero-deko::after {
	background: radial-gradient(circle at center, rgba(201, 141, 107, 0.13), transparent 65%);
	bottom: -200px;
	height: 500px;
	left: -160px;
	width: 500px;
}
.pxs-hero-inner {
	align-items: center;
	display: grid;
	gap: 48px;
	padding-bottom: 64px;
	padding-top: 56px;
	position: relative;
}
@media screen and (min-width: 900px) {
	.pxs-hero-inner {
		gap: 64px;
		grid-template-columns: 1.15fr 0.85fr;
		padding-bottom: 96px;
		padding-top: 88px;
	}
}
.pxs-hero-titel {
	font-size: clamp(34px, 5.2vw, 58px);
	font-weight: 600;
	line-height: 1.1;
	margin: 22px 0 18px;
}
.pxs-hero-untertitel {
	color: var(--text-soft);
	font-size: clamp(17px, 2vw, 19.5px);
	line-height: 1.7;
	margin: 0 0 30px;
	max-width: 560px;
}
.pxs-hero-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}
.pxs-hero-hinweis {
	align-items: center;
	color: var(--muted);
	display: flex;
	font-size: 14.5px;
	gap: 8px;
	margin: 24px 0 0;
}
.pxs-hero-bild {
	margin: 0 auto;
	max-width: 460px;
	width: 100%;
}
.pxs-hero-foto,
.pxs-hero-illustration {
	border-radius: 58% 42% 44% 56% / 52% 47% 53% 48%;
	box-shadow: var(--shadow-lg);
}
.pxs-hero-foto {
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}
.pxs-hero-illustration {
	align-items: center;
	aspect-ratio: 1 / 0.95;
	background: linear-gradient(150deg, var(--accent-soft) 0%, #d8e5d4 55%, var(--surface-2) 100%);
	box-shadow: var(--shadow);
	color: rgba(80, 112, 90, 0.55);
	display: flex;
	justify-content: center;
}

/*--------------------------------------------------------------
 8. Karten (Leistungen, Aktuelles)
--------------------------------------------------------------*/
.pxs-grid {
	display: grid;
	gap: 26px;
}
.pxs-leistungen-grid,
.pxs-aktuelles-grid {
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.pxs-karte {
	background: #fff;
	border: 1px solid var(--border);
	border-bottom: 1px solid var(--border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	margin: 0;
	overflow: hidden;
	padding: 0;
	transition: transform var(--transition), box-shadow var(--transition);
}
.pxs-karte:hover {
	box-shadow: var(--shadow);
	transform: translateY(-5px);
}
.pxs-karte-bild {
	display: block;
	line-height: 0;
	overflow: hidden;
}
.pxs-karte-bild img {
	aspect-ratio: 32 / 21;
	border-radius: 0;
	display: block;
	height: auto;
	object-fit: cover;
	transition: transform 0.45s ease;
	width: 100%;
}
.pxs-karte:hover .pxs-karte-bild img {
	transform: scale(1.045);
}
.pxs-karte-icon {
	align-items: center;
	background: var(--accent-soft);
	border-radius: 16px;
	color: var(--accent-dark);
	display: flex;
	height: 64px;
	justify-content: center;
	margin: 26px 26px 0;
	width: 64px;
}
.pxs-karte-inhalt {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 10px;
	padding: 22px 26px 26px;
}
.pxs-karte-titel {
	font-size: 21px;
	line-height: 1.3;
	margin: 0;
}
.pxs-karte-titel a,
.pxs-karte-titel a:visited {
	color: var(--ink-dark);
	font-weight: 600;
}
.pxs-karte-titel a:hover,
.pxs-karte-titel a:focus {
	color: var(--accent-dark);
}
.pxs-karte-text {
	color: var(--muted);
	font-size: 15.5px;
	line-height: 1.65;
	margin: 0;
}
.pxs-karte-meta {
	color: var(--accent-dark);
	font-size: 12.5px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.pxs-karte .pxs-mehr-link {
	margin-top: auto;
	padding-top: 6px;
}

/*--------------------------------------------------------------
 9. Patientenstimmen
--------------------------------------------------------------*/
.pxs-testimonials-grid {
	align-items: stretch;
	grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
}
.pxs-testimonial {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	margin: 0;
	padding: 30px 30px 26px;
}
.pxs-testimonial-mark {
	color: var(--accent);
	font-family: var(--font-heading);
	font-size: 64px;
	line-height: 0.6;
	margin-bottom: 16px;
	opacity: 0.35;
}
.pxs-testimonial-text {
	background: transparent;
	border: 0;
	border-radius: 0;
	color: var(--ink);
	font-size: 16.5px;
	font-style: normal;
	line-height: 1.7;
	margin: 0 0 18px;
	padding: 0;
}
.pxs-testimonial-text p {
	margin: 0 0 0.6em;
}
.pxs-testimonial-text p:last-child {
	margin-bottom: 0;
}
.pxs-testimonial-meta {
	border-top: 1px solid var(--border);
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-top: auto;
	padding-top: 14px;
}
.pxs-testimonial-name {
	color: var(--ink-dark);
	font-weight: 700;
}
.pxs-testimonial-sub {
	color: var(--muted);
	font-size: 14px;
}

/*--------------------------------------------------------------
10. Über die Praxis
--------------------------------------------------------------*/
.pxs-ueber-inner {
	align-items: center;
	display: grid;
	gap: 44px;
}
@media screen and (min-width: 900px) {
	.pxs-ueber-inner {
		gap: 72px;
		grid-template-columns: 0.9fr 1.1fr;
	}
}
.pxs-ueber-bild img {
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow);
	display: block;
	height: auto;
	width: 100%;
}
.pxs-ueber-text .pxs-section-titel {
	margin: 18px 0 16px;
}
.pxs-ueber-text p {
	color: var(--text-soft);
	font-size: 17px;
	line-height: 1.75;
	margin: 0 0 26px;
}

/*--------------------------------------------------------------
11. Kontakt-Band & Kontakt-Karten
--------------------------------------------------------------*/
.pxs-section-kontakt {
	background:
		radial-gradient(circle at 85% 10%, rgba(110, 146, 119, 0.25), transparent 45%),
		radial-gradient(circle at 10% 95%, rgba(201, 141, 107, 0.12), transparent 45%),
		var(--ink-dark);
	color: rgba(255, 255, 255, 0.85);
}
.pxs-section-kontakt .pxs-section-titel {
	color: #fff;
}
.pxs-section-kontakt .pxs-section-untertitel {
	color: rgba(255, 255, 255, 0.72);
}
.pxs-kontakt-grid {
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	margin-top: 48px;
}
/* Standard (helle Seiten, z. B. per Shortcode) */
.pxs-kontakt-karte {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	padding: 26px 28px;
}
.pxs-kontakt-icon {
	align-items: center;
	background: var(--accent-soft);
	border-radius: 14px;
	color: var(--accent-dark);
	display: inline-flex;
	justify-content: center;
	padding: 11px;
}
.pxs-kontakt-titel {
	font-size: 19px;
	margin: 14px 0 8px;
}
.pxs-kontakt-karte p {
	margin: 0;
}
.pxs-kontakt-karte a {
	font-weight: 700;
}
/* Variante auf dem dunklen Band */
.pxs-section-kontakt .pxs-kontakt-karte {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.14);
	box-shadow: none;
	color: rgba(255, 255, 255, 0.82);
}
.pxs-section-kontakt .pxs-kontakt-icon {
	background: rgba(255, 255, 255, 0.1);
	color: #cfe3d3;
}
.pxs-section-kontakt .pxs-kontakt-titel {
	color: #fff;
}
.pxs-section-kontakt .pxs-kontakt-karte a,
.pxs-section-kontakt .pxs-kontakt-karte a:visited {
	color: #fff;
}
.pxs-section-kontakt .pxs-kontakt-karte a:hover,
.pxs-section-kontakt .pxs-kontakt-karte a:focus {
	color: #cfe3d3;
}

/*--------------------------------------------------------------
12. Seitenkopf (Leistungen-Archiv & Einzelansicht)
--------------------------------------------------------------*/
.pxs-seiten-kopf {
	background: linear-gradient(180deg, var(--sand) 0%, var(--surface) 100%);
	padding: 56px 0 48px;
}
.pxs-seiten-titel {
	font-size: clamp(32px, 4.5vw, 46px);
	line-height: 1.12;
	margin: 16px 0 10px;
}
.pxs-seiten-intro {
	color: var(--text-soft);
	font-size: 18px;
	margin: 0;
	max-width: 640px;
}
.pxs-zurueck-link,
.pxs-zurueck-link:visited {
	color: var(--accent-dark);
	display: inline-block;
	font-size: 14.5px;
	font-weight: 700;
	margin-bottom: 10px;
}
.pxs-zurueck-link:hover,
.pxs-zurueck-link:focus {
	color: var(--accent);
}
.pxs-leistung-bild img {
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow);
	display: block;
	height: auto;
	margin-bottom: 32px;
	width: 100%;
}
.pxs-archiv-leistungen .posts-navigation {
	border-top: 0;
	margin-top: 40px;
}

/*--------------------------------------------------------------
13. Öffnungszeiten
--------------------------------------------------------------*/
.pxs-oeffnungszeiten {
	border: 0;
	border-collapse: collapse;
	font-size: 15px;
	margin: 0;
	width: 100%;
}
.pxs-oeffnungszeiten th,
.pxs-oeffnungszeiten td {
	background: transparent;
	border: 0;
	padding: 6px 0;
}
.pxs-oeffnungszeiten th {
	color: inherit;
	font-weight: 700;
	padding-right: 16px;
	text-align: left;
	text-transform: none;
}
.pxs-oeffnungszeiten td {
	text-align: right;
	white-space: nowrap;
}
.pxs-oeffnungszeiten tr + tr th,
.pxs-oeffnungszeiten tr + tr td {
	border-top: 1px dashed rgba(121, 133, 124, 0.35);
}
.pxs-oeffnungszeiten-hinweis {
	color: var(--muted);
	font-size: 14px;
	font-style: italic;
	margin: 12px 0 0;
}

/*--------------------------------------------------------------
14. Footer
--------------------------------------------------------------*/
.site-footer {
	background:
		radial-gradient(circle at 90% 0%, rgba(110, 146, 119, 0.18), transparent 40%),
		var(--ink-dark);
	border-top: 0;
	color: rgba(255, 255, 255, 0.75);
	font-size: 15px;
	line-height: 1.7;
	margin-top: 0;
	padding: 0;
	text-align: left;
}
.pxs-footer-grid {
	display: grid;
	gap: 44px;
	padding-bottom: 56px;
	padding-top: 64px;
}
@media screen and (min-width: 800px) {
	.pxs-footer-grid {
		gap: 56px;
		grid-template-columns: 1.25fr 1fr 1fr;
	}
}
.pxs-footer-titel {
	color: #fff;
	font-size: 19px;
	margin: 0 0 16px;
}
.pxs-footer-brand .pxs-footer-titel {
	font-size: 23px;
	margin: 14px 0 10px;
}
.pxs-footer-logo {
	background: rgba(255, 255, 255, 0.08);
	border-radius: 14px;
	color: #b9d3bf;
	display: inline-flex;
	padding: 12px;
}
.pxs-footer-text {
	color: rgba(255, 255, 255, 0.6);
	margin: 0 0 22px;
	max-width: 340px;
}
.pxs-footer-kontakt {
	display: flex;
	flex-direction: column;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.pxs-footer-kontakt li {
	align-items: flex-start;
	display: flex;
	gap: 10px;
}
.pxs-footer-kontakt .pxs-icon {
	color: #b9d3bf;
	margin-top: 4px;
}
.site-footer a,
.site-footer a:visited {
	color: rgba(255, 255, 255, 0.85);
	font-weight: 600;
}
.site-footer a:hover,
.site-footer a:focus,
.site-footer a:active {
	color: #cfe3d3;
}
/* Heller Termin-Button behält dunkle Schrift auf dem dunklen Footer. */
.site-footer a.pxs-btn-invert,
.site-footer a.pxs-btn-invert:visited {
	color: var(--accent-dark);
}
.site-footer a.pxs-btn-invert:hover,
.site-footer a.pxs-btn-invert:focus {
	color: var(--ink-dark);
}
.site-footer .pxs-oeffnungszeiten th {
	color: #fff;
}
.site-footer .pxs-oeffnungszeiten td {
	color: rgba(255, 255, 255, 0.7);
}
.site-footer .pxs-oeffnungszeiten tr + tr th,
.site-footer .pxs-oeffnungszeiten tr + tr td {
	border-top-color: rgba(255, 255, 255, 0.15);
}
.site-footer .pxs-oeffnungszeiten-hinweis {
	color: rgba(255, 255, 255, 0.55);
}
.pxs-footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.pxs-footer-bottom-inner {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 24px;
	justify-content: space-between;
	padding-bottom: 20px;
	padding-top: 20px;
}
.site-footer .site-info {
	color: rgba(255, 255, 255, 0.55);
	font-size: 14px;
}
.pxs-legal-nav ul {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 22px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.pxs-legal-nav a,
.pxs-legal-nav a:visited {
	color: rgba(255, 255, 255, 0.65);
	font-size: 14px;
	font-weight: 600;
}
.pxs-legal-nav a:hover,
.pxs-legal-nav a:focus {
	color: #fff;
}

/*--------------------------------------------------------------
15. Back-to-top
--------------------------------------------------------------*/
.pxs-back-to-top {
	align-items: center;
	background: var(--accent);
	border: 0;
	border-radius: 50%;
	bottom: 22px;
	box-shadow: var(--shadow);
	color: #fff;
	display: flex;
	height: 46px;
	justify-content: center;
	opacity: 0;
	padding: 0;
	pointer-events: none;
	position: fixed;
	right: 22px;
	transform: translateY(12px);
	transition: opacity 0.3s ease, transform 0.3s ease, background 0.3s ease;
	width: 46px;
	z-index: 900;
}
.pxs-back-to-top.pxs-sichtbar {
	opacity: 1;
	pointer-events: auto;
	transform: none;
}
.pxs-back-to-top:hover,
.pxs-back-to-top:focus {
	background: var(--accent-dark);
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}

/*--------------------------------------------------------------
16. Scroll-Animationen
--------------------------------------------------------------*/
.pxs-js .pxs-reveal {
	opacity: 0;
	transform: translateY(26px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}
.pxs-js .pxs-reveal.pxs-sichtbar {
	opacity: 1;
	transform: none;
}
/* Karten im Raster leicht versetzt einblenden */
.pxs-js .pxs-grid .pxs-reveal:nth-child(2) { transition-delay: 0.08s; }
.pxs-js .pxs-grid .pxs-reveal:nth-child(3) { transition-delay: 0.16s; }
.pxs-js .pxs-grid .pxs-reveal:nth-child(4) { transition-delay: 0.24s; }
.pxs-js .pxs-grid .pxs-reveal:nth-child(5) { transition-delay: 0.32s; }
.pxs-js .pxs-grid .pxs-reveal:nth-child(6) { transition-delay: 0.4s; }
@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
	.pxs-js .pxs-reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}
	.pxs-karte,
	.pxs-btn,
	.pxs-back-to-top {
		transition: none;
	}
}
