@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@300;400;500&display=swap");

* {
	box-sizing: border-box;
}

:focus:not(:focus-visible) {
	outline: none;
}

h1:focus,
h2:focus,
h3:focus,
h4:focus,
h5:focus,
h6:focus {
	outline: none;
}

:root {
	--background-main: #ffffff;
	--background-top: #b8a79f;
	--background-footer: #b8a79f;
	--color-top: #ffffff;
	--color-footer: #ffffff;
	--color-top-highlight: #fafafa;
	--color-footer-highlight: #fafafa;
	--color-text: #404040;
	--color-highlight: #4d3b2f;
	/* Fallback values for browsers without color-mix support (e.g. older Firefox builds). */
	--surface: #fbf8f6;
	--surface-soft: #fdfbfa;
	--border: #d8d0cc;
	--muted: #6b6765;
	--link: #5a4336;
	--button-bg: var(--color-highlight);
	--button-fg: #ffffff;
	--button-bg-hover: #3f3027;
	--danger: #c24d5b;
	--radius: 14px;
}

@supports (color: color-mix(in srgb, #000000 50%, #ffffff)) {
	:root {
		--surface: color-mix(in srgb, var(--background-main) 92%, var(--background-top));
		--surface-soft: color-mix(in srgb, var(--background-main) 96%, var(--background-top));
		--border: color-mix(in srgb, var(--color-highlight) 22%, var(--background-main));
		--muted: color-mix(in srgb, var(--color-text) 65%, var(--background-main));
		--link: color-mix(in srgb, var(--color-highlight) 88%, var(--background-main));
		--button-bg-hover: color-mix(in srgb, var(--color-highlight) 86%, #000000);
	}
}

html,
body {
	margin: 0;
	padding: 0;
	font-family: "Open Sans", Segoe UI, system-ui, -apple-system, sans-serif;
	color: var(--color-text);
	background: var(--background-main);
	min-height: 100%;
	line-height: 1.55;
	text-decoration: none;
}

a {
	color: var(--link);
	text-decoration: none;
}

	a:hover,
	a:focus {
		text-decoration: none;
	}

.site-shell {
	min-height: 100vh;
	display: grid;
	grid-template-rows: auto 1fr auto;
}

.site-header {
	background: var(--background-top);
	border-bottom: 1px solid var(--border);
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--color-top) !important;
}

.brand-main-logo-wrap {
	height: 100px;
	max-width: 100px;
	max-height: 100px;
	aspect-ratio: 633 / 906 ;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.2rem;
	border-radius: 10px;
	background: var(--background-top);
	flex: 0 0 auto;
}

.brand-main-logo {
	height: 100%;
	width: auto;
	max-width: 100%;
	object-fit: contain;
	display: block;
}

.brand-text-block {
	display: flex;
	flex-direction: column;
	line-height: 1.1;
	gap: 0.2rem;
}

.brand-name-block {
	display: block;
	font-size: 1.02rem;
	font-weight: 700;
	color: var(--color-top);
}

.brand-slogan-block {
	display: block;
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: var(--color-top-highlight);
}

.top-navbar {
	background: var(--background-top);
	padding: 0.95rem 0;
}


.top-navbar .navbar-toggler {
	border-color: var(--border);
}

.top-navbar .navbar-toggler:focus {
	box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--color-highlight) 35%, var(--background-main));
}

.top-navbar .navbar-toggler-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(64,64,64,0.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.top-nav-list {
	gap: 0.4rem;
	margin: 0 auto;
}

.nav-sep {
	list-style: none;
	width: 1px;
	height: 1.1rem;
	background: color-mix(in srgb, var(--color-top) 38%, transparent);
	align-self: center;
	flex-shrink: 0;
	margin: 0 0.25rem;
}

.top-menu-shell {
	display: flex;
	align-items: center;
	width: 100%;
}

.top-nav-center {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	flex-wrap: wrap;
}

.top-auth-actions {
	display: flex;
	align-items: center;
	gap: 0.45rem;
}

.top-nav-right {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	gap: 0.45rem;
}

.top-nav-link {
	padding: 0.65rem 0.9rem;
	border-radius: 0;
	background: transparent;
	border: none;
	border-bottom: 2px solid transparent;
	color: var(--color-top) !important;
	font-weight: 500;
	font-size: 0.88rem;
	transition: color 0.22s ease, border-color 0.22s ease;
	text-decoration: none;
	box-shadow: none;
}

.top-nav-link:hover,
.top-nav-link:focus {
	color: var(--color-top-highlight) !important;
	background: transparent;
	border-bottom-color: color-mix(in srgb, var(--color-top) 55%, transparent);
	text-decoration: none;
	box-shadow: none;
}

.top-nav-link.active {
	border-bottom-color: var(--color-top-highlight);
	color: var(--color-top-highlight) !important;
	font-weight: 600;
}

.top-auth-link {
	border-bottom: 2px solid transparent;
}

.site-main {
	padding: 1.5rem;
	background: var(--background-main);
}

.site-footer {
	background: var(--background-footer);
	border-top: 1px solid var(--border);
	color: var(--color-footer);
}

.footer-inner {
	min-height: 72px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.7rem;
	font-size: 0.92rem;
}

.footer-brand {
	font-weight: 700;
	color: var(--color-footer-highlight);
}

.footer-contact,
.footer-links {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--color-footer);
}

.footer-contact a {
	color: inherit;
}

.container-section {
	max-width: 1200px;
	margin: 0 auto 1.25rem;
	padding: 1.35rem;
	border: 1px solid var(--border);
	border-radius: var(--radius);
	background: var(--surface);
}

.page-content h1,
.page-content h2,
.page-content h3 {
	line-height: 1.2;
	color: var(--color-highlight);
}

.page-content p {
	color: var(--muted);
}

.contact-strip {
	border-bottom: 1px solid var(--border);
	padding-bottom: 0.75rem;
	margin-bottom: 1rem;
}

.contact-strip-inner {
	display: flex;
	gap: 0.65rem;
	align-items: center;
	color: var(--muted);
	font-size: 0.92rem;
}

.eyebrow {
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-size: 0.78rem;
	font-weight: 700;
	color: color-mix(in srgb, var(--color-highlight) 78%, var(--background-main));
}

.hero {
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 1.4rem;
	margin-bottom: 1.1rem;
	background: linear-gradient(145deg, var(--surface) 20%, color-mix(in srgb, var(--background-top) 35%, var(--background-main)) 100%);
}

.hero h1 {
	margin-top: 0.35rem;
	margin-bottom: 0.55rem;
	font-size: clamp(1.8rem, 2.7vw, 2.6rem);
}

.hero-actions {
	margin-top: 0.95rem;
	display: flex;
	gap: 0.55rem;
	flex-wrap: wrap;
}

.card-grid {
	display: grid;
	gap: 0.9rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.card {
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 1rem;
	background: var(--surface-soft);
}

.card h2 {
	margin-top: 0;
	font-size: 1.1rem;
	color: var(--color-highlight);
}

.admin-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 320px minmax(0, 1fr);
}

.css-layout {
	display: grid;
	gap: 1rem;
	grid-template-columns: 260px minmax(0, 1fr);
}

.dashboard-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.dashboard-card {
	border: 1px solid var(--border);
	border-radius: 12px;
	background: var(--surface-soft);
	padding: 0.85rem;
}

.dashboard-card h3 {
	margin: 0 0 0.7rem;
	font-size: 1rem;
	color: var(--color-highlight);
}

.dashboard-metric-row {
	display: grid;
	grid-template-columns: minmax(90px, 1.6fr) minmax(120px, 3fr) auto;
	gap: 0.45rem;
	align-items: center;
	margin-bottom: 0.45rem;
}

.dashboard-metric-label {
	font-size: 0.82rem;
	color: var(--muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.dashboard-metric-bar-wrap {
	height: 10px;
	background: color-mix(in srgb, var(--background-main) 86%, var(--background-top));
	border-radius: 999px;
	overflow: hidden;
}

.dashboard-metric-bar {
	height: 100%;
	background: var(--color-highlight);
	border-radius: 999px;
}

.dashboard-metric-count {
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--color-text);
}

.panel {
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 1rem;
	background: var(--surface-soft);
}

.panel-header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

.list {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.list-item {
	text-align: left;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: color-mix(in srgb, var(--background-main) 87%, var(--background-top));
	color: var(--color-text);
	cursor: pointer;
	padding: 0.6rem;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.list-item span {
	color: var(--muted);
	font-size: 0.86rem;
}

.list-item.active {
	border-color: var(--color-highlight);
	background: color-mix(in srgb, var(--background-top) 58%, var(--background-main));
}

.stack {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.label {
	font-size: 0.92rem;
	color: var(--muted);
}

.input {
	width: 100%;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--background-main);
	color: var(--color-text);
	padding: 0.55rem 0.7rem;
}

.color-input {
	padding: 0.25rem;
	height: 44px;
}

.theme-grid {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.textarea {
	min-height: 280px;
	resize: vertical;
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.css-textarea {
	min-height: 360px;
}

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

.button {
	border: 1px solid var(--border);
	border-radius: 10px;
	color: var(--color-text);
	background: color-mix(in srgb, var(--background-main) 88%, var(--background-top));
	padding: 0.52rem 0.75rem;
	cursor: pointer;
}

.button:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.button-primary {
	border-color: var(--button-bg);
	background: var(--button-bg);
	color: var(--button-fg);
}

.button-primary:hover,
.button-primary:focus {
	background: var(--button-bg-hover);
}

.button-danger {
	border-color: var(--danger);
	color: #ffe9ec;
	background: color-mix(in srgb, var(--danger) 75%, var(--background-main));
}

.preview {
	margin-top: 1rem;
}

.preview-surface {
	border: 1px dashed var(--border);
	border-radius: 10px;
	padding: 0.8rem;
	background: var(--background-main);
}

.status {
	margin: 0;
	color: var(--color-highlight);
}

.status.error {
	color: var(--danger);
}

.api-status-badge {
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	font-size: 0.78rem;
	font-weight: 700;
	border: 1px solid var(--border);
}

.api-status-badge.healthy {
	background: color-mix(in srgb, #2ea44f 28%, var(--background-main));
	color: #d9ffe3;
	border-color: color-mix(in srgb, #2ea44f 50%, var(--border));
}

.api-status-badge.unhealthy {
	background: color-mix(in srgb, var(--danger) 30%, var(--background-main));
	color: #ffe9ec;
	border-color: color-mix(in srgb, var(--danger) 55%, var(--border));
}

.mt {
	margin-top: 0.6rem;
}

.fm-hero {
	padding: 1.5rem;
	border: 1px solid var(--border);
	border-radius: 14px;
	background: linear-gradient(145deg, var(--surface) 10%, color-mix(in srgb, var(--background-top) 38%, var(--background-main)) 100%);
	margin-bottom: 1rem;
}

.fm-kicker {
	margin: 0 0 0.5rem;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.11em;
	color: color-mix(in srgb, var(--color-highlight) 78%, var(--background-main));
}

.fm-hero h1 {
	margin: 0;
	font-size: clamp(2rem, 3.3vw, 3rem);
	line-height: 1.06;
	color: var(--color-highlight);
}

.fm-lead {
	margin-top: 0.9rem;
	font-size: 1.04rem;
	max-width: 75ch;
	color: var(--color-text);
}

.fm-section {
	margin-bottom: 1rem;
	padding: 1.1rem 1.2rem;
	border: 1px solid var(--border);
	border-radius: 12px;
	background: var(--surface-soft);
}

.fm-section h2 {
	margin-top: 0;
	margin-bottom: 0.6rem;
	font-size: clamp(1.3rem, 2.2vw, 1.7rem);
	line-height: 1.2;
	color: var(--color-highlight);
}

.fm-section p {
	margin: 0 0 0.65rem;
	color: var(--muted);
	max-width: 76ch;
}

.fm-section p:last-child {
	margin-bottom: 0;
}

.fm-grid {
	display: grid;
	gap: 0.9rem;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	background: transparent;
	border: 0;
	padding: 0;
}

.fm-card {
	border: 1px solid var(--border);
	border-radius: 12px;
	background: var(--surface-soft);
	padding: 1rem;
}

.fm-card-highlight {
	background: color-mix(in srgb, var(--background-main) 72%, var(--background-top));
	display: grid;
	align-items: center;
}

.fm-quote {
	font-size: 1.18rem;
	line-height: 1.35;
	font-weight: 600;
	color: var(--color-highlight) !important;
}

.fm-accent {
	background: color-mix(in srgb, var(--background-main) 74%, var(--background-top));
}

.fm-cta {
	text-align: center;
	background: linear-gradient(160deg, color-mix(in srgb, var(--background-main) 88%, var(--background-top)) 10%, var(--surface-soft) 100%);
}

.fm-cta p {
	margin-left: auto;
	margin-right: auto;
}

.fm-claim {
	font-size: 1.22rem;
	font-weight: 700;
	color: var(--color-highlight) !important;
	letter-spacing: 0.02em;
}

.fm-claim-sub {
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: color-mix(in srgb, var(--color-highlight) 82%, var(--background-main)) !important;
}

.fm-final {
	font-size: 1.12rem;
	font-weight: 700;
	color: var(--color-highlight) !important;
}

.page-content-home {
	max-width: none;
	margin: 0;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
}

.ds-home {
	--ds-sand: var(--background-top);
	--ds-sand-light: #e7dfdb;
	--ds-sand-dark: #7f6758;
	--ds-white: #ffffff;
	--ds-cream: #f8f3f1;
	--ds-charcoal: var(--color-highlight);
	--ds-text: var(--color-text);
	--ds-text-muted: #78716d;
	font-family: "Jost", "Open Sans", Segoe UI, system-ui, -apple-system, sans-serif;
	background: var(--ds-cream);
	color: var(--ds-text);
	font-weight: 300;
	overflow-x: hidden;
	margin: -1.5rem;
}

.ds-home * {
	box-sizing: border-box;
}

.ds-home em {
	font-style: italic;
}

.ds-page {
	--ds-sand: var(--background-top);
	--ds-sand-light: #e7dfdb;
	--ds-sand-dark: #7f6758;
	--ds-white: #ffffff;
	--ds-cream: #f8f3f1;
	--ds-charcoal: var(--color-highlight);
	--ds-text: var(--color-text);
	--ds-text-muted: #78716d;
	font-family: "Jost", "Open Sans", Segoe UI, system-ui, -apple-system, sans-serif;
	background: var(--ds-cream);
	color: var(--ds-text);
	font-weight: 300;
	margin: -1.5rem;
}

.ds-page * {
	box-sizing: border-box;
}

.ds-page em {
	font-style: italic;
}

@supports (color: color-mix(in srgb, #000000 50%, #ffffff)) {
	.ds-home,
	.ds-page {
		--ds-sand-light: color-mix(in srgb, var(--background-top) 72%, #ffffff);
		--ds-sand-dark: color-mix(in srgb, var(--background-top) 80%, var(--color-highlight));
		--ds-cream: color-mix(in srgb, var(--background-main) 92%, var(--background-top));
		--ds-text-muted: color-mix(in srgb, var(--color-text) 72%, var(--background-main));
	}
}

.ds-hero {
	min-height: min(92vh, 980px);
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.ds-hero-left {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 6rem 5rem 6rem 4rem;
	animation: fadeUp 1s ease 0.15s both;
}

.ds-eyebrow {
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ds-sand);
	margin: 0 0 1.8rem;
	font-weight: 400;
}

.ds-title {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(3rem, 5vw, 5.2rem);
	font-weight: 300;
	line-height: 1.1;
	color: var(--ds-charcoal);
	margin: 0 0 2rem;
}

.ds-title em {
	color: var(--ds-sand);
}

.ds-subtitle {
	font-size: 1rem;
	line-height: 1.8;
	color: var(--ds-text-muted);
	max-width: 420px;
	margin: 0 0 3rem;
}

.ds-actions {
	display: flex;
	gap: 1.2rem;
	align-items: center;
	flex-wrap: wrap;
}

.ds-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	padding: 1rem 2.2rem;
	font-family: "Jost", sans-serif;
	font-size: 0.8rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	transition: all 0.3s ease;
	cursor: pointer;
	border: 1px solid transparent;
}

.ds-btn-primary {
	background: var(--ds-charcoal);
	color: var(--ds-white);
}

.ds-btn-primary:hover,
.ds-btn-primary:focus {
	background: var(--ds-sand-dark);
	color: var(--ds-white);
	transform: translateY(-2px);
}

.ds-btn-ghost {
	background: transparent;
	color: var(--ds-text-muted);
	border-color: var(--ds-sand-light);
}

.ds-btn-ghost:hover,
.ds-btn-ghost:focus {
	border-color: var(--ds-sand);
	color: var(--ds-sand-dark);
}

.ds-hero-right {
	position: relative;
	overflow: hidden;
	animation: fadeIn 1.2s ease 0.35s both;
}

.ds-hero-image {
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden;
}

.ds-hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.ds-hero-badge {
	position: absolute;
	bottom: 3rem;
	left: 3rem;
	background: var(--ds-white);
	padding: 1.4rem 2rem;
	border-left: 3px solid var(--ds-sand);
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.08);
}

.ds-hero-badge .num {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 2.4rem;
	font-weight: 300;
	color: var(--ds-charcoal);
	display: block;
	line-height: 1;
}

.ds-hero-badge .label {
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ds-text-muted);
	margin-top: 0.3rem;
	display: block;
}

.ds-intro-strip {
	background: var(--ds-charcoal);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2.5rem;
	padding: 1.9rem 4rem;
	overflow-x: auto;
	scrollbar-width: thin;
}

.ds-intro-item {
	color: color-mix(in srgb, var(--ds-white) 62%, transparent);
	font-size: 0.75rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	white-space: nowrap;
	font-weight: 400;
}

.ds-intro-divider {
	width: 1px;
	height: 20px;
	background: rgba(255, 255, 255, 0.15);
	flex: 0 0 auto;
}

.ds-section {
	padding: 7rem 4rem;
}

.ds-section-header {
	margin-bottom: 4rem;
}

.ds-section-eyebrow {
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ds-sand);
	margin: 0 0 1rem;
	font-weight: 400;
}

.ds-section-title {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2.2rem, 3.5vw, 3.4rem);
	font-weight: 300;
	line-height: 1.2;
	color: var(--ds-charcoal);
	margin: 0;
}

.ds-section-title em {
	font-style: italic;
}

.ds-services-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 2px;
	background: color-mix(in srgb, var(--ds-sand-light) 50%, transparent);
}

.ds-service-card {
	background: var(--ds-white);
	padding: 3rem 2.6rem;
	position: relative;
	overflow: hidden;
	transition: transform 0.4s ease;
	cursor: default;
	min-height: 250px;
}

.ds-service-card::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: var(--ds-sand);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.4s ease;
}

.ds-service-card:hover {
	transform: translateY(-4px);
}

.ds-service-card:hover::after {
	transform: scaleX(1);
}

.ds-service-num {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 4rem;
	font-weight: 300;
	color: color-mix(in srgb, var(--ds-sand) 28%, transparent);
	position: absolute;
	top: 1.5rem;
	right: 2rem;
	line-height: 1;
	user-select: none;
}

.ds-service-name {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.5rem;
	font-weight: 400;
	color: var(--ds-charcoal);
	margin: 0 0 0.9rem;
	max-width: 22ch;
}

.ds-service-desc {
	font-size: 0.88rem;
	line-height: 1.75;
	color: var(--ds-text-muted);
	margin: 0;
	max-width: 38ch;
}

.ds-tabs {
	margin-top: 1.5rem;
}

.ds-tabs-disclosure {
	margin: 0;
	padding: 0;
	border: 0;
}

.ds-tabs-summary {
	display: none;
}

.ds-tabs-list {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.35rem;
	margin-bottom: 1.25rem;
	overflow-x: auto;
	padding-bottom: 0.1rem;
	scrollbar-width: thin;
}

.ds-tab-button {
	background: transparent;
	border: none;
	border-bottom: 2px solid transparent;
	border-radius: 0;
	color: var(--ds-text-muted);
	padding: 0.8rem 1rem;
	font-family: "Jost", sans-serif;
	font-size: 0.88rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.25;
	text-transform: none;
	white-space: nowrap;
	cursor: pointer;
	transition: color 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

.ds-tab-button:hover,
.ds-tab-button:focus-visible {
	background: color-mix(in srgb, var(--ds-white) 68%, transparent);
	border-bottom-color: color-mix(in srgb, var(--ds-sand) 58%, transparent);
	color: var(--ds-charcoal);
	outline: none;
}

.ds-tab-button.is-active {
	background: transparent;
	border-bottom-color: var(--ds-sand-dark);
	color: var(--ds-charcoal);
	font-weight: 600;
}

.ds-tab-panel {
	background: color-mix(in srgb, var(--ds-white) 96%, var(--ds-cream));
	border: 1px solid color-mix(in srgb, var(--ds-sand) 26%, transparent);
}

.ds-service-card-tab {
	min-height: 0;
	cursor: default;
	padding: 2.6rem;
	transform: none;
}

.ds-service-card-tab:hover {
	transform: none;
}

.ds-service-card-tab::after {
	transform: scaleX(1);
}

.ds-tab-intro {
	max-width: 70ch;
	margin-bottom: 1rem;
}

.ds-tab-list {
	margin: 0 0 1.4rem;
	padding-left: 1.2rem;
	display: grid;
	gap: 0.45rem;
	color: var(--ds-text-muted);
	font-size: 0.9rem;
	line-height: 1.75;
}

.ds-tab-list li::marker {
	color: var(--ds-sand);
}

.ds-tab-outro {
	max-width: 70ch;
	font-weight: 400;
	color: var(--ds-charcoal);
}

.ds-course-lead {
	font-size: 0.98rem;
	line-height: 1.85;
	color: var(--ds-text-muted);
	max-width: 72ch;
	margin: 0;
}

.ds-courses-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.4rem;
}

.ds-course-card {
	background: color-mix(in srgb, var(--ds-white) 98%, var(--ds-cream));
	border-top: 2px solid var(--ds-sand-light);
	border: 1px solid color-mix(in srgb, var(--ds-sand-dark) 16%, transparent);
	padding: 2.4rem;
	box-shadow: 0 14px 28px color-mix(in srgb, var(--ds-charcoal) 8%, transparent);
	transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

.ds-course-card:hover {
	border-color: var(--ds-sand);
	box-shadow: 0 18px 36px color-mix(in srgb, var(--ds-charcoal) 12%, transparent);
	transform: translateY(-2px);
}

.ds-course-label {
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ds-sand-dark);
	margin: 0 0 0.9rem;
}

.ds-course-subtitle {
	font-size: 0.82rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ds-text-muted);
	margin: -0.25rem 0 1rem;
}

.ds-course-intro {
	max-width: 65ch;
	margin-bottom: 1rem;
}

.ds-course-tagline {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.2rem;
	font-style: italic;
	color: var(--ds-sand);
	margin: 1.4rem 0 0;
}

.ds-course-investment {
	background: color-mix(in srgb, var(--ds-white) 58%, var(--ds-cream));
}

.ds-courses-grid-investment {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ds-course-card-investment {
	padding: 2rem;
}

.ds-course-price {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 2rem;
	font-weight: 300;
	color: var(--ds-charcoal);
	margin: 0 0 1rem;
}

.ds-about {
	background: var(--ds-white);
}

.ds-about-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6rem;
	align-items: center;
	padding: 7rem 4rem;
}

.ds-about-image-wrap {
	position: relative;
}

.ds-about-image {
	width: 100%;
	aspect-ratio: 3 / 4;
	position: relative;
	overflow: hidden;
}

.ds-about-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.ds-about-accent {
	position: absolute;
	bottom: -2rem;
	right: -2rem;
	width: 200px;
	height: 200px;
	background: var(--ds-cream);
	border: 1px solid var(--ds-sand-light);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 1.5rem;
}

.ds-about-accent-num {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 3rem;
	font-weight: 300;
	color: var(--ds-charcoal);
	line-height: 1;
}

.ds-about-accent-label {
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ds-text-muted);
	margin-top: 0.4rem;
}

.ds-about-text .ds-section-header {
	margin-bottom: 2rem;
}

.ds-about-body {
	font-size: 0.92rem;
	line-height: 1.9;
	color: var(--ds-text-muted);
	margin: 0 0 1.4rem;
}

.ds-about-signature {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.8rem;
	font-style: italic;
	color: var(--ds-sand);
	margin-top: 2rem;
}

.ds-process {
	background: var(--ds-charcoal);
	color: var(--ds-white);
}

.ds-process .ds-section-title {
	color: var(--ds-white);
}

.ds-process .ds-section-eyebrow {
	color: var(--ds-sand-light);
}

.ds-process-steps {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0;
	margin-top: 3.5rem;
	border-left: 1px solid rgba(255, 255, 255, 0.08);
}

.ds-process-step {
	padding: 2.5rem;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
}

.ds-process-step-num {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 5rem;
	font-weight: 300;
	color: color-mix(in srgb, var(--ds-sand) 22%, transparent);
	line-height: 1;
	margin-bottom: 1.5rem;
	user-select: none;
}

.ds-process-step-title {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.4rem;
	margin: 0 0 0.8rem;
	color: var(--ds-white);
}

.ds-process-step-desc {
	margin: 0;
	font-size: 0.85rem;
	line-height: 1.75;
	color: color-mix(in srgb, var(--ds-white) 45%, transparent);
}

.ds-testimonials {
	background: var(--ds-cream);
}

.ds-testimonials-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
	margin-top: 3rem;
}

.ds-testimonial-card {
	background: var(--ds-white);
	padding: 2.4rem;
	border-top: 2px solid var(--ds-sand-light);
	transition: border-color 0.3s;
}

.ds-testimonial-card:hover {
	border-color: var(--ds-sand);
}

.ds-testimonial-stars {
	color: var(--ds-sand);
	font-size: 0.9rem;
	margin-bottom: 1.2rem;
}

.ds-testimonial-text {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.15rem;
	font-style: italic;
	font-weight: 300;
	line-height: 1.7;
	color: var(--ds-charcoal);
	margin: 0 0 1.8rem;
}

.ds-testimonial-author {
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ds-sand-dark);
}

.ds-booking {
	background: color-mix(in srgb, var(--ds-sand) 86%, var(--ds-charcoal));
}

.ds-booking-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 5rem;
	align-items: center;
	padding: 7rem 4rem;
}

.ds-booking-text .ds-section-eyebrow {
	color: rgba(255, 255, 255, 0.74);
}

.ds-booking-text .ds-section-title {
	color: var(--ds-white);
}

.ds-booking-body {
	font-size: 0.92rem;
	line-height: 1.9;
	color: rgba(255, 255, 255, 0.9);
	margin-top: 1.5rem;
}

.ds-booking-form {
	background: var(--ds-white);
	padding: 3rem;
	border: 1px solid color-mix(in srgb, var(--ds-charcoal) 12%, transparent);
	box-shadow: 0 16px 34px color-mix(in srgb, var(--ds-charcoal) 12%, transparent);
}

.ds-form-group {
	margin-bottom: 1.4rem;
}

.ds-form-group label {
	display: block;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ds-charcoal);
	margin-bottom: 0.5rem;
	font-weight: 500;
}

.ds-form-group input,
.ds-form-group select,
.ds-form-group textarea {
	width: 100%;
	border: 1px solid color-mix(in srgb, var(--ds-sand) 45%, transparent);
	padding: 0.8rem 1rem;
	font-family: "Jost", sans-serif;
	font-size: 0.9rem;
	color: var(--ds-text);
	background: var(--ds-white);
	outline: none;
	transition: border-color 0.3s, box-shadow 0.3s;
	border-radius: 0;
}

.ds-form-group input::placeholder,
.ds-form-group textarea::placeholder {
	color: color-mix(in srgb, var(--ds-text) 62%, var(--ds-white));
}

.ds-form-group input:focus,
.ds-form-group select:focus,
.ds-form-group textarea:focus {
	border-color: var(--ds-sand);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ds-sand) 22%, transparent);
}

.ds-form-group textarea {
	resize: vertical;
}

.ds-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.ds-btn-form {
	width: 100%;
	background: var(--ds-charcoal);
	color: var(--ds-white);
	border: none;
	padding: 1.1rem;
	cursor: pointer;
	font-family: "Jost", sans-serif;
	font-size: 0.8rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	transition: background 0.3s;
}

.ds-btn-form:hover,
.ds-btn-form:focus {
	background: var(--ds-sand-dark);
}

.ds-reveal {
	opacity: 0;
	transform: translateY(24px);
	animation: fadeUp 0.75s ease forwards;
}

.ds-reveal-delay-1 {
	animation-delay: 0.1s;
}

.ds-reveal-delay-2 {
	animation-delay: 0.2s;
}

.ds-reveal-delay-3 {
	animation-delay: 0.3s;
}

@media (max-width: 1024px) {
	.admin-grid,
	.css-layout {
		grid-template-columns: 1fr;
	}

	.footer-inner,
	.contact-strip-inner {
		flex-wrap: wrap;
	}

	.brand-main-logo-wrap {
		width: 72px;
	}

	.brand-name-block {
		font-size: 0.92rem;
	}

	.brand-slogan-block {
		font-size: 0.68rem;
	}

	.top-menu-shell {
		align-items: flex-start;
		flex-direction: column;
		gap: 0.6rem;
	}

	.top-nav-list {
		margin: 0;
		justify-content: flex-start;
	}

	.nav-sep {
		width: 100%;
		height: 1px;
		margin: 0.25rem 0;
	}

	.top-nav-center {
		flex: 0 0 auto;
		width: 100%;
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-start;
		gap: 0.25rem;
	}

	.top-nav-right {
		width: 100%;
		border-top: 1px solid color-mix(in srgb, var(--color-top) 22%, transparent);
		padding-top: 0.5rem;
		margin-top: 0.1rem;
	}

	.top-auth-actions {
		justify-content: flex-start;
	}

	.ds-home {
		margin: -1rem;
	}

	.ds-page {
		margin: -1rem;
	}

	.ds-hero,
	.ds-about-inner,
	.ds-booking-inner {
		grid-template-columns: 1fr;
	}

	.ds-hero-right {
		aspect-ratio: 16 / 9;
		min-height: 280px;
	}

	.ds-hero-left,
	.ds-section,
	.ds-about-inner,
	.ds-booking-inner {
		padding: 4rem 2rem;
	}

	.ds-intro-strip {
		justify-content: flex-start;
		padding: 1.4rem 2rem;
		gap: 1.4rem;
	}

	.ds-services-grid,
	.ds-testimonials-grid,
	.ds-process-steps,
	.ds-courses-grid,
	.ds-courses-grid-investment {
		grid-template-columns: 1fr 1fr;
	}

	.ds-process-step {
		padding: 2rem;
	}

	.ds-tabs-list {
		gap: 0.2rem;
	}

	.ds-about-accent {
		right: 1rem;
		bottom: 1rem;
		width: 160px;
		height: 160px;
	}

	.ds-booking-form {
		padding: 2rem;
	}
}

@media (max-width: 640px) {
	.ds-home {
		margin: -0.75rem;
	}

	.ds-page {
		margin: -0.75rem;
	}

	.ds-hero-left,
	.ds-section,
	.ds-about-inner,
	.ds-booking-inner {
		padding: 3rem 1.2rem;
	}

	.ds-hero-right {
		aspect-ratio: 4 / 3;
		min-height: 220px;
	}

	.ds-title {
		font-size: clamp(2.2rem, 12vw, 3.3rem);
	}

	.ds-actions,
	.ds-form-row {
		grid-template-columns: 1fr;
		display: grid;
	}

	.top-auth-actions {
		width: 100%;
		flex-wrap: wrap;
	}

	.top-auth-link {
		width: auto;
		text-align: left;
	}

	.footer-inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.5rem;
	}

	.footer-contact,
	.footer-links {
		flex-wrap: wrap;
	}

	.ds-hero-badge {
		left: 1rem;
		bottom: 1rem;
		padding: 1rem 1.2rem;
	}

	.ds-services-grid,
	.ds-testimonials-grid,
	.ds-process-steps,
	.ds-courses-grid,
	.ds-courses-grid-investment {
		grid-template-columns: 1fr;
	}

	.ds-tab-button {
		width: 100%;
		text-align: left;
		font-size: 0.88rem;
		padding: 0.72rem 0.75rem;
	}

	.ds-tabs-summary {
		display: block;
		list-style: none;
		cursor: pointer;
		margin-bottom: 0.75rem;
		padding: 0.72rem 0.85rem;
		border: 1px solid color-mix(in srgb, var(--ds-sand) 36%, transparent);
		background: color-mix(in srgb, var(--ds-white) 95%, var(--ds-cream));
		color: var(--ds-charcoal);
		font-family: "Jost", sans-serif;
		font-size: 0.86rem;
		font-weight: 500;
	}

	.ds-tabs-summary::-webkit-details-marker {
		display: none;
	}

	.ds-tabs-disclosure:not([open]) .ds-tabs-list {
		display: none;
	}

	.ds-tabs-list {
		display: grid;
		grid-template-columns: 1fr;
		overflow: visible;
		border-bottom: none;
	}

}

/* ═══════════════════════════════════════════════════
   TabControl – tc-  (Flowbite-inspired, alle Varianten)
   ═══════════════════════════════════════════════════ */

/* Wrapper */
.tc-tabs {
	display: block;
}

.tc-tabs--vertical {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
}

/* ── Tab-Liste ── */
.tc-tab-list {
	display: flex;
	align-items: flex-end;
	overflow: visible;
}

/* Default: Hintergrund-Highlight auf dem aktiven Tab */
.tc-tab-list--default {
	gap: 0.25rem;
	flex-wrap: wrap;
	border-bottom: 1px solid var(--border);
	padding-bottom: 0;
	margin-bottom: 1rem;
}

/* Underline: Unterstrich beim aktiven Tab */
.tc-tab-list--underline {
	gap: 0;
	border-bottom: 1px solid var(--border);
	margin-bottom: 1rem;
}

/* Pills: gerundete Pill-Form */
.tc-tab-list--pills {
	gap: 0.4rem;
	flex-wrap: wrap;
	align-items: center;
	border-bottom: none;
	margin-bottom: 1rem;
}

/* Vertical: senkrechte Liste links */
.tc-tab-list--vertical {
	flex-direction: column;
	align-items: stretch;
	flex-shrink: 0;
	min-width: 11rem;
	gap: 0.3rem;
	overflow-x: visible;
	border-bottom: none;
}

/* Full Width: gleich breite Tabs über volle Breite */
.tc-tab-list--fullwidth {
	gap: 0;
	border: 1px solid var(--border);
	border-radius: calc(var(--radius) * 0.45);
	overflow: hidden;
	margin-bottom: 1rem;
}

/* ── Basis-Button ── */
.tc-tab-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: none;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.25;
	white-space: nowrap;
	color: var(--muted);
	transition: color 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.tc-tab-btn:focus-visible {
	outline: 2px solid var(--color-highlight);
	outline-offset: 2px;
	border-radius: 4px;
}

.tc-tab-btn svg {
	width: 1em;
	height: 1em;
	flex-shrink: 0;
}

/* Disabled */
.tc-tab-btn.is-disabled {
	color: color-mix(in srgb, var(--muted) 45%, transparent);
	cursor: not-allowed;
	pointer-events: none;
}

/* ── Default ── */
.tc-tab-btn--default {
	padding: 0.75rem 1rem;
	border-radius: calc(var(--radius) * 0.4) calc(var(--radius) * 0.4) 0 0;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
}

.tc-tab-btn--default:hover:not(.is-disabled) {
	color: var(--color-text);
	background: color-mix(in srgb, var(--border) 25%, transparent);
}

.tc-tab-btn--default.is-active {
	color: var(--color-highlight);
	background: var(--surface);
	border-bottom-color: var(--color-highlight);
}

/* ── Underline ── */
.tc-tab-btn--underline {
	padding: 0.75rem 1rem;
	border-bottom: 2px solid transparent;
	border-radius: calc(var(--radius) * 0.4) calc(var(--radius) * 0.4) 0 0;
	margin-bottom: -1px;
	background: transparent;
}

.tc-tab-btn--underline:hover:not(.is-disabled) {
	color: var(--color-highlight);
	border-bottom-color: color-mix(in srgb, var(--color-highlight) 40%, transparent);
}

.tc-tab-btn--underline.is-active {
	color: var(--color-highlight);
	border-bottom-color: var(--color-highlight);
}

/* ── Pills ── */
.tc-tab-btn--pills {
	padding: 0.5rem 1.1rem;
	border-radius: calc(var(--radius) * 0.5);
	border: none;
	background: transparent;
}

.tc-tab-btn--pills:hover:not(.is-disabled) {
	color: var(--color-text);
	background: var(--surface);
}

.tc-tab-btn--pills.is-active {
	color: var(--button-fg);
	background: var(--button-bg);
}

/* ── Vertical ── */
.tc-tab-btn--vertical {
	display: flex;
	width: 100%;
	padding: 0.65rem 1rem;
	border-radius: calc(var(--radius) * 0.45);
	text-align: left;
	background: transparent;
}

.tc-tab-btn--vertical:hover:not(.is-disabled) {
	color: var(--color-text);
	background: var(--surface);
}

.tc-tab-btn--vertical.is-active {
	color: var(--button-fg);
	background: var(--button-bg);
}

/* ── Full Width ── */
.tc-tab-btn--fullwidth {
	flex: 1;
	justify-content: center;
	padding: 0.65rem 1rem;
	border: none;
	border-right: 1px solid var(--border);
	border-radius: 0;
	background: var(--surface-soft);
}

.tc-tab-btn--fullwidth:last-child {
	border-right: none;
}

.tc-tab-btn--fullwidth:hover:not(.is-disabled) {
	color: var(--color-text);
	background: var(--surface);
}

.tc-tab-btn--fullwidth.is-active {
	color: var(--color-highlight);
	background: color-mix(in srgb, var(--color-highlight) 8%, var(--surface-soft));
	font-weight: 600;
}

/* ── Tab-Panel ── */
.tc-tab-panel {
	padding: 1.25rem;
	background: var(--surface-soft);
	border: 1px solid var(--border);
	border-radius: calc(var(--radius) * 0.45);
}

.tc-tabs--vertical .tc-tab-panel {
	flex: 1;
	min-width: 0;
}

/* ── Responsive ── */
@media (max-width: 640px) {
	.tc-tabs--vertical {
		flex-direction: column;
	}

	.tc-tab-list--vertical {
		flex-direction: row;
		flex-wrap: nowrap;
		min-width: 0;
		overflow-x: auto;
		border-bottom: 1px solid var(--border);
		padding-bottom: 0.5rem;
		gap: 0.3rem;
	}

	.tc-tab-btn--vertical {
		width: auto;
		white-space: nowrap;
	}

	.tc-tab-list--fullwidth {
		flex-wrap: wrap;
	}

	.tc-tab-btn--fullwidth {
		flex-basis: 50%;
		border-bottom: 1px solid var(--border);
	}

	.ds-about-accent {
		position: static;
		margin-top: 1rem;
		width: 100%;
		height: auto;
		padding: 1.2rem;
	}

	.ds-booking-form {
		padding: 1.3rem;
	}
}

/* ── Auth Pages (Login / Register / Admin Login) ──────────────────────── */

.auth-shell {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: calc(100vh - 180px);
	padding: 3rem 1rem;
	gap: 1.5rem;
	background: linear-gradient(
		160deg,
		var(--surface-soft) 0%,
		color-mix(in srgb, var(--background-top) 22%, var(--background-main)) 100%
	);
}

.auth-card {
	width: 100%;
	max-width: 440px;
	margin-inline: auto;
	background: var(--background-main);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 2.8rem 2.4rem 2.4rem;
	box-shadow: 0 12px 48px color-mix(in srgb, var(--color-highlight) 10%, transparent);
}

.auth-eyebrow {
	font-family: "Jost", "Open Sans", sans-serif;
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0 0 0.65rem;
	font-weight: 400;
}

.auth-title {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2rem, 4vw, 2.7rem);
	font-weight: 300;
	line-height: 1.1;
	color: var(--color-highlight);
	margin: 0 0 0.45rem;
}

.auth-subtitle {
	font-size: 0.9rem;
	color: var(--muted);
	margin: 0 0 1.8rem;
	line-height: 1.6;
}

.auth-separator {
	height: 1px;
	background: var(--border);
	margin: 1.8rem 0;
}

.auth-footer-note {
	font-size: 0.87rem;
	color: var(--muted);
	text-align: center;
	margin: 1.6rem 0 0;
}

.auth-footer-note a {
	color: var(--link);
	font-weight: 500;
}

.auth-status {
	margin: 1rem 0 0;
	padding: 0.65rem 0.85rem;
	border-radius: 8px;
	font-size: 0.88rem;
	border: 1px solid var(--border);
	background: var(--surface);
	color: var(--color-text);
}

.auth-status.error {
	border-color: color-mix(in srgb, var(--danger) 45%, var(--border));
	background: color-mix(in srgb, var(--danger) 8%, var(--background-main));
	color: var(--danger);
}

.auth-admin-badge {
	display: inline-flex;
	align-items: center;
	font-size: 0.7rem;
	font-family: "Jost", "Open Sans", sans-serif;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 500;
	color: color-mix(in srgb, var(--color-highlight) 80%, var(--background-top));
	background: color-mix(in srgb, var(--background-top) 20%, var(--background-main));
	border: 1px solid var(--border);
	border-radius: 999px;
	padding: 0.28rem 0.9rem;
	margin-bottom: 1rem;
}

.auth-info-row {
	font-size: 0.9rem;
	color: var(--muted);
	padding: 0.65rem 0.9rem;
	border: 1px solid var(--border);
	border-radius: 8px;
	background: var(--surface);
	margin-bottom: 1.2rem;
}

.auth-info-row strong {
	color: var(--color-text);
	font-weight: 600;
}

/* ── Admin Navigation ─────────────────────────────────────────────────── */

.admin-nav-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.admin-nav-link {
	display: inline-block;
	padding: 0.45rem 0.85rem;
	border-radius: var(--radius);
	border: 1px solid transparent;
	color: var(--color-text);
	font-size: 0.88rem;
	font-weight: 500;
	text-decoration: none;
	transition: background 0.18s, color 0.18s, border-color 0.18s;
	white-space: nowrap;
}

.admin-nav-link:hover,
.admin-nav-link:focus {
	background: color-mix(in srgb, var(--color-highlight) 10%, transparent);
	color: var(--color-highlight);
	border-color: color-mix(in srgb, var(--color-highlight) 28%, transparent);
	text-decoration: none;
}

.admin-nav-link.active {
	background: color-mix(in srgb, var(--color-highlight) 12%, transparent);
	color: var(--color-highlight);
	border-color: color-mix(in srgb, var(--color-highlight) 38%, transparent);
	font-weight: 600;
}

/* ── User Menu Dropdown ───────────────────────────────────────────────── */

.user-menu {
	position: relative;
}

.user-menu-trigger {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}

.user-menu-trigger::after {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 4px solid currentColor;
	opacity: 0.65;
	margin-left: 0.2rem;
	transition: transform 0.2s ease;
	flex-shrink: 0;
}

.user-menu:hover .user-menu-trigger::after,
.user-menu:focus-within .user-menu-trigger::after {
	transform: rotate(180deg);
}

.user-menu-dropdown {
	position: absolute;
	right: 0;
	top: 100%;
	min-width: 230px;
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
	transition-delay: 0.08s;
	pointer-events: none;
}

.user-menu-dropdown::before {
	content: '';
	position: absolute;
	top: -0.6rem;
	left: 0;
	right: 0;
	height: 0.6rem;
}

.user-menu:hover .user-menu-dropdown,
.user-menu:focus-within .user-menu-dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition-delay: 0s;
	pointer-events: auto;
}

.user-menu-inner {
	background: var(--background-main);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	box-shadow: 0 8px 32px color-mix(in srgb, var(--color-highlight) 12%, transparent);
	overflow: hidden;
}

.user-menu-header {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1rem;
	background: color-mix(in srgb, var(--background-top) 15%, var(--background-main));
}

.user-avatar {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--color-highlight);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: "Jost", "Open Sans", sans-serif;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.06em;
}

.user-meta {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
	min-width: 0;
}

.user-meta-name {
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--color-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.user-meta-role {
	font-size: 0.72rem;
	color: var(--muted);
	letter-spacing: 0.09em;
	text-transform: uppercase;
}

.user-menu-divider {
	height: 1px;
	background: var(--border);
}

.user-menu-body {
	padding: 0.3rem 0;
}

.user-menu-item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	width: 100%;
	padding: 0.65rem 1rem;
	font-size: 0.88rem;
	font-family: inherit;
	color: var(--color-text);
	background: transparent;
	border: none;
	cursor: pointer;
	text-align: left;
	text-decoration: none;
	transition: background 0.15s;
	line-height: 1;
}

.user-menu-item:hover,
.user-menu-item:focus {
	background: var(--surface);
	color: var(--color-text);
	text-decoration: none;
}

.user-menu-item-danger {
	color: var(--danger);
}

.user-menu-item-danger:hover,
.user-menu-item-danger:focus {
	background: color-mix(in srgb, var(--danger) 7%, var(--background-main));
	color: var(--danger);
}

/* ══════════════════════════════════════════════════════════════
   Storyboard  (sb-*)
   ══════════════════════════════════════════════════════════════ */

/* Inhaltsverzeichnis / Sprungmarken */
.sb-toc {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.75rem;
}

.sb-toc a {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	border-radius: var(--radius);
	border: 1px solid var(--border);
	font-size: 0.85rem;
	color: var(--color-highlight);
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.sb-toc a:hover,
.sb-toc a:focus {
	background: var(--color-highlight);
	color: #fff;
}

/* Sektions-Titel mit Dateipfad */
.sb-title {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.75rem;
	font-size: 1.1rem;
	font-weight: 600;
	margin-bottom: 0.35rem;
}

.sb-path {
	font-family: monospace;
	font-size: 0.8rem;
	font-weight: 400;
	color: var(--text-muted, #888);
}

/* Kurzbeschreibung */
.sb-desc {
	font-size: 0.9rem;
	color: var(--text-muted, #888);
	margin-bottom: 1.25rem;
}

/* Einzelner Varianten-Block */
.sb-block {
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 1.25rem;
	margin-bottom: 1.5rem;
	background: var(--background-surface, var(--background-main));
}

.sb-block:last-child {
	margin-bottom: 0;
}

/* Block-Kopfzeile: Badge + Code */
.sb-block-header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.6rem;
	margin-bottom: 1rem;
}

/* Badge-Pille */
.sb-badge {
	display: inline-block;
	padding: 0.2rem 0.65rem;
	border-radius: 999px;
	background: var(--color-highlight);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	white-space: nowrap;
}

.sb-badge--secondary {
	background: var(--text-muted, #888);
}

/* Inline-Code-Schnipsel */
.sb-code {
	font-family: monospace;
	font-size: 0.8rem;
	color: var(--text-muted, #888);
}

/* Hinweis-Box */
.sb-hint {
	font-size: 0.85rem;
	padding: 0.6rem 0.9rem;
	border-left: 3px solid var(--border);
	background: color-mix(in srgb, var(--border) 15%, transparent);
	border-radius: 0 var(--radius) var(--radius) 0;
	margin-bottom: 0.75rem;
}

.sb-hint--info {
	border-left-color: var(--color-highlight);
	background: color-mix(in srgb, var(--color-highlight) 8%, transparent);
}

/* Schematische DoctolibWidget-Darstellung */
.sb-doctolib-mockup {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.5rem;
	padding: 1rem;
	border: 1px dashed var(--border);
	border-radius: var(--radius);
	background: color-mix(in srgb, var(--border) 10%, transparent);
}

.sb-doctolib-mockup p {
	font-size: 0.8rem;
	color: var(--text-muted, #888);
	margin: 0;
}

.sb-doctolib-mockup-screen {
	width: 100%;
	height: 80px;
	border: 1px solid var(--border);
	border-radius: var(--radius);
	position: relative;
	background: var(--background-main);
}

.sb-doctolib-mockup-widget {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	gap: 0.35rem;
	background: var(--color-highlight);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	padding: 0.4rem 0.65rem;
	border-radius: var(--radius) 0 0 var(--radius);
}

.sb-doctolib-mockup-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #fff;
	opacity: 0.8;
}

/* UserDropdown-Wrapper */
.sb-userdropdown-wrap {
	display: flex;
	justify-content: flex-end;
	padding: 0.5rem;
	border: 1px solid var(--border);
	border-radius: var(--radius);
	background: var(--background-main);
}

/* ── TopNav (tc-tab-list--topnav, tc-tab-btn--topnav) ── */
.tc-tab-list--topnav {
	gap: 2px;
	padding: 4px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	align-items: center;
	margin-bottom: 1.25rem;
	overflow-x: auto;
	scrollbar-width: thin;
}

.tc-tab-btn--topnav {
	padding: 0.52rem 1rem;
	border-radius: 7px;
	border: 1px solid transparent;
	background: transparent;
	color: var(--muted);
	font-size: 0.875rem;
	font-weight: 500;
	white-space: nowrap;
	transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.tc-tab-btn--topnav:hover:not(.is-disabled) {
	background: color-mix(in srgb, var(--background-main) 78%, var(--surface));
	color: var(--color-text);
}

.tc-tab-btn--topnav.is-active {
	background: var(--background-main);
	color: var(--color-highlight);
	border-color: var(--border);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
	font-weight: 600;
}

/* ══════════════════════════════════════════════════════════════
   Admin-Shell  (adm-*)
   ══════════════════════════════════════════════════════════════ */

/* Gate – unauthenticated / unauthorized screen */
.adm-gate {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	background: var(--surface);
}

.adm-gate-card {
	text-align: center;
	max-width: 400px;
	padding: 3rem 2.5rem;
	background: var(--background-main);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}

.adm-gate-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-highlight) 10%, transparent);
	color: var(--color-highlight);
	margin-bottom: 1.5rem;
}

.adm-gate-icon--warn {
	background: color-mix(in srgb, var(--danger) 10%, transparent);
	color: var(--danger);
}

.adm-gate-title {
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--color-highlight);
	margin: 0 0 0.6rem;
}

.adm-gate-desc {
	color: var(--muted);
	font-size: 0.92rem;
	margin: 0 0 2rem;
	line-height: 1.6;
}

.adm-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.6rem 1.4rem;
	border-radius: 8px;
	border: 1px solid var(--border);
	background: var(--surface);
	color: var(--color-text);
	font-size: 0.88rem;
	font-weight: 500;
	text-decoration: none;
	cursor: pointer;
	transition: background 0.18s, border-color 0.18s;
}

.adm-btn:hover,
.adm-btn:focus {
	background: color-mix(in srgb, var(--border) 30%, var(--background-main));
	text-decoration: none;
}

.adm-btn--primary {
	background: var(--button-bg);
	border-color: var(--button-bg);
	color: var(--button-fg);
}

.adm-btn--primary:hover,
.adm-btn--primary:focus {
	background: var(--button-bg-hover);
	border-color: var(--button-bg-hover);
	color: var(--button-fg);
}

/* Shell */
.adm-shell {
	--adm-sidebar-w: 240px;
	--adm-sidebar-bg: #1a1d2e;
	--adm-sidebar-text: rgba(255, 255, 255, 0.58);
	--adm-sidebar-hover-bg: rgba(255, 255, 255, 0.07);
	--adm-sidebar-hover-text: rgba(255, 255, 255, 0.92);
	--adm-sidebar-active-bg: rgba(255, 255, 255, 0.11);
	--adm-sidebar-active-text: #ffffff;
	--adm-sidebar-border: rgba(255, 255, 255, 0.06);
	--adm-sidebar-accent: #c4b5b0;
	--adm-content-bg: #f0f2f6;
	display: grid;
	grid-template-columns: var(--adm-sidebar-w) 1fr;
	min-height: 100vh;
}

/* Sidebar */
.adm-sidebar {
	background: var(--adm-sidebar-bg);
	display: flex;
	flex-direction: column;
	position: sticky;
	top: 0;
	height: 100vh;
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}

/* Brand */
.adm-sidebar-brand {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1.35rem 1.25rem 1.2rem;
	border-bottom: 1px solid var(--adm-sidebar-border);
	flex-shrink: 0;
}

.adm-brand-logo {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 8px;
	color: var(--adm-sidebar-accent);
}

.adm-brand-text {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
	min-width: 0;
}

.adm-brand-name {
	font-size: 0.95rem;
	font-weight: 700;
	color: #ffffff;
	letter-spacing: 0.02em;
	line-height: 1.2;
}

.adm-brand-sub {
	font-size: 0.67rem;
	font-weight: 400;
	color: var(--adm-sidebar-text);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* Nav */
.adm-nav {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 0.85rem 0.75rem;
	gap: 0.15rem;
}

.adm-nav-item {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	padding: 0.62rem 0.85rem;
	border-radius: 8px;
	color: var(--adm-sidebar-text);
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	transition: background 0.18s, color 0.18s;
	border: 1px solid transparent;
	white-space: nowrap;
	overflow: hidden;
}

.adm-nav-item svg {
	width: 1.05rem;
	height: 1.05rem;
	flex-shrink: 0;
	opacity: 0.7;
	transition: opacity 0.18s;
}

.adm-nav-item:hover,
.adm-nav-item:focus {
	background: var(--adm-sidebar-hover-bg);
	color: var(--adm-sidebar-hover-text);
	text-decoration: none;
}

.adm-nav-item:hover svg,
.adm-nav-item:focus svg {
	opacity: 0.95;
}

.adm-nav-item.is-active {
	background: var(--adm-sidebar-active-bg);
	color: var(--adm-sidebar-active-text);
	border-color: rgba(255, 255, 255, 0.07);
	font-weight: 600;
}

.adm-nav-item.is-active svg {
	opacity: 1;
	color: var(--adm-sidebar-accent);
}

/* Sidebar Footer */
.adm-sidebar-footer {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.9rem 1.1rem;
	border-top: 1px solid var(--adm-sidebar-border);
	flex-shrink: 0;
}

.adm-user {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 0.6rem;
	min-width: 0;
}

.adm-user-avatar {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.1);
	color: var(--adm-sidebar-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.74rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

.adm-user-info {
	display: flex;
	flex-direction: column;
	gap: 0.05rem;
	min-width: 0;
	overflow: hidden;
}

.adm-user-name {
	font-size: 0.82rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.85);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.adm-user-role {
	font-size: 0.67rem;
	color: var(--adm-sidebar-text);
	text-transform: uppercase;
	letter-spacing: 0.09em;
}

.adm-signout-btn {
	flex-shrink: 0;
	width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 7px;
	color: var(--adm-sidebar-text);
	cursor: pointer;
	transition: background 0.18s, color 0.18s, border-color 0.18s;
	padding: 0;
}

.adm-signout-btn:hover,
.adm-signout-btn:focus {
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.88);
	border-color: rgba(255, 255, 255, 0.1);
}

.adm-signout-btn svg {
	width: 0.95rem;
	height: 0.95rem;
}

/* Main + Content */
.adm-main {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	background: var(--adm-content-bg);
	overflow-x: hidden;
}

.adm-content {
	flex: 1;
	padding: 1.5rem;
}

.adm-content > .container-section:last-child {
	margin-bottom: 0;
}

/* Responsive */
@media (max-width: 768px) {
	.adm-shell {
		grid-template-columns: 1fr;
	}

	.adm-sidebar {
		position: static;
		height: auto;
		flex-direction: row;
		align-items: center;
		overflow-x: auto;
		overflow-y: visible;
		scrollbar-width: none;
	}

	.adm-sidebar::-webkit-scrollbar {
		display: none;
	}

	.adm-sidebar-brand {
		border-bottom: none;
		border-right: 1px solid var(--adm-sidebar-border);
		padding: 0.7rem 1rem;
		flex-shrink: 0;
	}

	.adm-brand-sub {
		display: none;
	}

	.adm-nav {
		flex-direction: row;
		padding: 0 0.5rem;
		flex-wrap: nowrap;
		overflow-x: visible;
		gap: 0.1rem;
		flex: 1;
	}

	.adm-sidebar-footer {
		flex-shrink: 0;
		border-top: none;
		border-left: 1px solid var(--adm-sidebar-border);
		padding: 0.5rem 0.75rem;
	}

	.adm-user-info {
		display: none;
	}

	.adm-content {
		padding: 1rem;
	}
}

