/*
Theme Name: Food King
Theme URI: https://food-king.de
Author: Food King
Description: Landing-Page Theme – All-in-One Gastro-Kassensystem (Tailwind / Inter)
Version: 2.0
*/

/* WP Admin-Bar: fixierte Kopfzeile nach unten, Abstandshalter erhöhen */
.admin-bar #fk-site-header {
	top: var(--wp-admin--admin-bar--height, 32px);
}

.admin-bar .fk-header-spacer {
	height: calc(7.25rem + var(--wp-admin--admin-bar--height, 32px));
}

.hero-gradient {
	background:
		radial-gradient(circle at 0% 0%, rgba(255, 92, 0, 0.05) 0%, transparent 40%),
		radial-gradient(circle at 100% 100%, rgba(255, 184, 0, 0.05) 0%, transparent 40%),
		#ffffff;
}

/* Startseite Hero: Tablet-Dashboard-Mockup (Animationen) */
@keyframes fk-hero-grow-bar {
	0% {
		transform: scaleY(0);
		opacity: 0;
	}
	100% {
		transform: scaleY(1);
		opacity: 1;
	}
}

.fk-hero-tablet-mockup .fk-hero-demo-bar {
	animation: fk-hero-grow-bar 1.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
	transform-origin: bottom;
}

@keyframes fk-hero-slide-in-order {
	0%,
	10% {
		transform: translateX(-120%);
		opacity: 0;
		max-height: 0;
		margin-bottom: 0;
		padding-top: 0;
		padding-bottom: 0;
		padding-left: 0;
		padding-right: 0;
	}
	15% {
		transform: translateX(0);
		opacity: 1;
		max-height: 120px;
		margin-bottom: 8px;
		padding: 8px;
	}
	95% {
		transform: translateX(0);
		opacity: 1;
		max-height: 120px;
		margin-bottom: 8px;
		padding: 8px;
	}
	100% {
		transform: translateX(120%);
		opacity: 0;
		max-height: 0;
		margin-bottom: 0;
		padding-top: 0;
		padding-bottom: 0;
		padding-left: 0;
		padding-right: 0;
	}
}

.fk-hero-tablet-mockup .fk-hero-demo-new-order {
	animation: fk-hero-slide-in-order 8s infinite;
	overflow: hidden;
	box-sizing: border-box;
}

@keyframes fk-hero-progress-run {
	0% {
		width: 10%;
	}
	80%,
	100% {
		width: 100%;
	}
}

.fk-hero-tablet-mockup .fk-hero-demo-progress {
	animation: fk-hero-progress-run 8s infinite ease-in-out;
}

@keyframes fk-hero-status-change {
	0%,
	40% {
		background-color: #fef08a;
		color: #854d0e;
	}
	45%,
	100% {
		background-color: #bbf7d0;
		color: #166534;
	}
}

.fk-hero-tablet-mockup .fk-hero-demo-status {
	animation: fk-hero-status-change 8s infinite;
}

@media (prefers-reduced-motion: reduce) {
	.fk-hero-tablet-mockup .fk-hero-demo-bar {
		animation: none;
		opacity: 1;
		transform: scaleY(1);
	}

	#fk-hero-mockup .animate-float-hero {
		animation: none !important;
	}

	.fk-hero-tablet-mockup .fk-hero-demo-new-order {
		animation: none;
		transform: none;
		opacity: 1;
		max-height: none;
		margin-bottom: 0.5rem;
		padding: 0.5rem;
	}

	.fk-hero-tablet-mockup .fk-hero-demo-progress {
		animation: none;
		width: 100%;
	}

	.fk-hero-tablet-mockup .fk-hero-demo-status {
		animation: none;
		background-color: #fef08a;
		color: #854d0e;
	}
}

/* Stammgästen-Mock: iPhone Light Mode + Glas-Push (Food King) */
#fk-eigene-app .fk-ios-screen {
	font-family:
		-apple-system,
		BlinkMacSystemFont,
		'SF Pro Text',
		'SF Pro Display',
		'Segoe UI',
		system-ui,
		sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

#fk-eigene-app .fk-eigene-lock-screen--light {
	background-color: #ffffff;
	background-image:
		radial-gradient(at 0% 0%, hsla(210, 100%, 90%, 1) 0, transparent 50%),
		radial-gradient(at 100% 0%, hsla(340, 100%, 92%, 1) 0, transparent 50%),
		radial-gradient(at 50% 100%, hsla(220, 100%, 95%, 1) 0, transparent 50%);
}

html.dark #fk-eigene-app .fk-eigene-lock-screen--light {
	background-color: transparent;
	background-image:
		linear-gradient(160deg, #1e2a4a 0%, #3b2a5a 40%, #1a1a1a 100%),
		radial-gradient(at 0% 0%, hsla(253, 16%, 7%, 1) 0, transparent 50%),
		radial-gradient(at 50% 0%, hsla(225, 39%, 30%, 1) 0, transparent 50%),
		radial-gradient(at 100% 0%, hsla(339, 49%, 30%, 1) 0, transparent 50%);
}

/* Island: Light = Pulse (scale), Dark = Expand (Breite/Höhe) — kompakter als echtes Gerät */
html:not(.dark) #fk-eigene-app .fk-eigene-lock-island {
	left: 50%;
	width: min(26%, 76px);
	height: clamp(14px, 4vmin, 22px);
	transform: translateX(-50%);
	transition:
		transform 0.6s cubic-bezier(0.19, 1, 0.22, 1),
		box-shadow 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

html:not(.dark) #fk-eigene-app .fk-eigene-lock-island.fk-eigene-island--pulse {
	transform: translateX(-50%) scale(1.04);
	box-shadow: 0 0 16px rgba(0, 0, 0, 0.08);
}

html.dark #fk-eigene-app .fk-eigene-lock-island {
	left: 50%;
	width: min(27%, 84px);
	height: clamp(16px, 4.2vmin, 26px);
	transform: translateX(-50%);
	border-radius: 9999px;
	transition:
		width 0.6s cubic-bezier(0.19, 1, 0.22, 1),
		height 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

html.dark #fk-eigene-app .fk-eigene-lock-island.fk-eigene-island--expand {
	width: min(30%, 94px);
	height: clamp(17px, 4.5vmin, 28px);
}

/* Push-Stapel: Platz für Lock-Shortcuts + Home-Bar */
html:not(.dark) #fk-eigene-app #fk-eigene-notification-center {
	top: 4.75rem;
	bottom: 6.25rem;
}

html.dark #fk-eigene-app #fk-eigene-notification-center {
	top: 4.7rem;
	bottom: 5.6rem;
}

#fk-eigene-app #fk-eigene-notification-center {
	overflow: hidden;
	justify-content: flex-start;
}

#fk-eigene-app .fk-eigene-lock-notif {
	background: rgba(255, 255, 255, 0.65);
	border: 1px solid rgba(255, 255, 255, 0.4);
	border-radius: 15px;
	padding: 9px 11px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
	opacity: 0;
	transform: translateY(14px) scale(0.94);
	flex-shrink: 0;
	transition:
		opacity 0.75s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.75s cubic-bezier(0.16, 1, 0.3, 1),
		filter 0.75s cubic-bezier(0.16, 1, 0.3, 1);
}

@supports (backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px)) {
	#fk-eigene-app .fk-eigene-lock-notif {
		backdrop-filter: blur(30px) saturate(190%);
		-webkit-backdrop-filter: blur(30px) saturate(190%);
	}
}

/* Dark: Premium-Loop (dunkles Glas, weiße Schrift, Prototyp-Timings/Mesh passend zu JS) */
html.dark #fk-eigene-app .fk-eigene-lock-notif {
	background: rgba(255, 255, 255, 0.15);
	border: 0.5px solid rgba(255, 255, 255, 0.18);
	border-radius: 18px;
	padding: 11px 13px;
	box-shadow: none;
	transform: translateY(12px) scale(0.96);
	transition:
		opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.7s cubic-bezier(0.16, 1, 0.3, 1),
		filter 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

@supports (backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px)) {
	html.dark #fk-eigene-app .fk-eigene-lock-notif {
		backdrop-filter: blur(25px) saturate(180%);
		-webkit-backdrop-filter: blur(25px) saturate(180%);
	}
}

html.dark #fk-eigene-app .fk-eigene-lock-notif.is-out {
	transform: translateY(-16px) scale(0.9);
	filter: blur(10px);
}

html.dark #fk-eigene-app .fk-eigene-lock-notif__header {
	margin-bottom: 5px;
}

html.dark #fk-eigene-app .fk-eigene-lock-notif__icon {
	width: 22px;
	height: 22px;
	font-size: 13px;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

html.dark #fk-eigene-app .fk-eigene-lock-notif__app {
	font-size: 11px;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.65);
}

html.dark #fk-eigene-app .fk-eigene-lock-notif__time {
	font-size: 10px;
	color: rgba(255, 255, 255, 0.65);
}

html.dark #fk-eigene-app .fk-eigene-lock-notif__title {
	font-size: 13px;
	color: #ffffff;
	margin-bottom: 2px;
}

html.dark #fk-eigene-app .fk-eigene-lock-notif__body {
	font-size: 12px;
	color: #ffffff;
	opacity: 0.9;
	line-height: 1.3;
}

html.dark #fk-eigene-app .fk-eigene-lock-icon-circle--light {
	width: clamp(42px, 12vmin, 50px);
	height: clamp(42px, 12vmin, 50px);
	background: rgba(0, 0, 0, 0.3);
	box-shadow: none;
}

html.dark #fk-eigene-app .fk-eigene-lock-icon-emoji {
	font-size: clamp(1.05rem, 5vmin, 1.25rem);
}

#fk-eigene-app .fk-eigene-lock-notif.is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
}

#fk-eigene-app .fk-eigene-lock-notif.is-out {
	opacity: 0;
	transform: scale(0.9);
	filter: blur(12px);
}

#fk-eigene-app .fk-eigene-lock-notif__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 4px;
}

#fk-eigene-app .fk-eigene-lock-notif__meta {
	display: flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
}

#fk-eigene-app .fk-eigene-lock-notif__icon {
	width: 20px;
	height: 20px;
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	line-height: 1;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
	flex-shrink: 0;
}

#fk-eigene-app .fk-eigene-lock-notif__app {
	font-size: 10px;
	font-weight: 600;
	color: #86868b;
	letter-spacing: -0.2px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

#fk-eigene-app .fk-eigene-lock-notif__time {
	font-size: 9px;
	color: #86868b;
	flex-shrink: 0;
}

#fk-eigene-app .fk-eigene-lock-notif__title {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: -0.25px;
	margin-bottom: 1px;
	color: #1d1d1f;
	line-height: 1.25;
}

#fk-eigene-app .fk-eigene-lock-notif__body {
	font-size: 11px;
	color: #1d1d1f;
	opacity: 0.8;
	line-height: 1.35;
}

#fk-eigene-app .fk-eigene-lock-icon-circle--light {
	width: clamp(38px, 11vmin, 46px);
	height: clamp(38px, 11vmin, 46px);
	background: rgba(255, 255, 255, 0.4);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

#fk-eigene-app .fk-eigene-lock-icon-emoji {
	font-size: clamp(1rem, 4.5vmin, 1.15rem);
	line-height: 1;
}

@supports not (overflow: clip) {
	#fk-eigene-app .fk-eigene-phone-shell {
		overflow-x: hidden;
	}
}

/* Shop AI Landing (radial mesh, Referenz 2026) */
.hero-mesh {
	background-color: #ffffff;
	background-image:
		radial-gradient(at 0% 0%, rgba(255, 92, 0, 0.08) 0, transparent 50%),
		radial-gradient(at 100% 100%, rgba(255, 184, 0, 0.08) 0, transparent 50%);
}

/* Abläufe Landing (heller Mesh, Glass-Karten) */
.hero-light-mesh {
	background-color: #f8fafc;
	background-image:
		radial-gradient(at 0% 0%, rgba(255, 92, 0, 0.05) 0, transparent 40%),
		radial-gradient(at 100% 100%, rgba(255, 184, 0, 0.05) 0, transparent 40%);
}

.glass-light {
	background: rgba(255, 255, 255, 0.7);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border: 1px solid rgba(0, 0, 0, 0.05);
}

.ui-shadow {
	box-shadow: 0 40px 100px rgba(15, 23, 42, 0.12);
}

/* Preise-Unterseite (Pricing Hero) */
.pricing-card {
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.pricing-card:hover {
	transform: translateY(-12px);
	box-shadow: 0 40px 80px rgba(2, 6, 23, 0.1);
}

.glass-premium {
	background: rgba(255, 255, 255, 0.8);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border: 1px solid rgba(0, 0, 0, 0.05);
}

/* Alt: animierter Orange-Verlauf (z. B. Legacy-Bereiche) */
.hero-gradient-animated {
	background: linear-gradient(-45deg, #ff5c00, #ffb800, #c24100, #ffa500);
	background-size: 400% 400%;
}

/* Sticky Navigation (Landing / global, Referenz 2026) */
.glass-header {
	background: rgba(255, 255, 255, 0.7);
	backdrop-filter: blur(15px) saturate(160%);
	-webkit-backdrop-filter: blur(15px) saturate(160%);
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.nav-link {
	position: relative;
	font-weight: 600;
	color: #475569;
	transition: color 0.3s ease;
}

.nav-link:hover {
	color: #ff5c00;
}

.nav-link::after {
	content: '';
	position: absolute;
	width: 0;
	height: 2px;
	bottom: -4px;
	left: 0;
	background-color: #ff5c00;
	transition: width 0.3s ease;
}

.nav-link:hover::after {
	width: 100%;
}

.btn-glow:hover {
	box-shadow: 0 0 20px rgba(255, 92, 0, 0.3);
	transform: translateY(-1px);
}

.mesh-gradient {
	background-color: #f8fafc;
	background-image:
		radial-gradient(at 0% 0%, rgba(255, 92, 0, 0.1) 0px, transparent 50%),
		radial-gradient(at 100% 100%, rgba(255, 184, 0, 0.1) 0px, transparent 50%),
		radial-gradient(at 100% 0%, rgba(255, 92, 0, 0.05) 0px, transparent 50%);
}

.hero-shape {
	border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
}

/* Mobile Fullscreen-Navigation */
.fk-mobile-panel {
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
	transition:
		opacity 0.2s ease,
		visibility 0.2s ease;
}

.fk-mobile-panel.fk-mobile-panel--open {
	visibility: visible;
	opacity: 1;
	pointer-events: auto;
}

body.fk-mobile-nav-open {
	overflow: hidden;
}

.sr-only {
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	border: 0;
}

/* Startseite: POS Video Showcase (#system) – gleiche Schrift wie übrige Startseite (Inter / font-sans) */
.fk-pos-showcase-mesh {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background:
		radial-gradient(at 0% 0%, rgba(255, 92, 0, 0.03) 0px, transparent 50%),
		radial-gradient(at 100% 100%, rgba(255, 184, 0, 0.03) 0px, transparent 50%);
}

.fk-pos-showcase .fk-glass-card {
	background: rgba(255, 255, 255, 0.7);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.8);
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.03);
	transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.fk-pos-showcase .fk-glass-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(255, 92, 0, 0.2);
}

/* POS-Showcase: Hochformat 9:16 (Demo-Clips / Shorts — mehr Höhe im Raster als 16:9) */
.fk-pos-showcase .fk-video-viewport {
	position: relative;
	width: 100%;
	aspect-ratio: 9 / 16;
	border-radius: 2rem;
	overflow: hidden;
	background: #000;
	-webkit-mask-image: -webkit-radial-gradient(white, black);
	mask-image: radial-gradient(white, black);
}

.fk-pos-showcase .fk-video-viewport iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.fk-pos-showcase .fk-btn-primary {
	display: inline-block;
	background: #0f172a;
	color: #fff;
	transition: all 0.3s ease;
	box-shadow: 0 10px 20px -5px rgba(15, 23, 42, 0.2);
	text-decoration: none;
}

.fk-pos-showcase .fk-btn-primary:hover {
	background: #ff5c00;
	transform: scale(1.02);
	box-shadow: 0 10px 20px -5px rgba(255, 92, 0, 0.3);
	color: #fff;
}

.fk-pos-showcase .fk-btn-outline {
	display: inline-block;
	text-decoration: none;
	transition: background-color 0.2s ease, border-color 0.2s ease;
}

.fk-pos-showcase .fk-btn-outline:hover {
	background: #f1f5f9;
}

/* Startseite: einheitliche Fließtext-Typo (Inter / Referenz: ruhige Größe, klares Raster) */
body.hero-gradient {
	font-feature-settings:
		'kern' 1,
		'liga' 1;
}

/* Absatz unter Sektions-Überschriften – eine Größe für alle Intro-Texte */
.fk-section-lead {
	font-size: clamp(1rem, 0.96rem + 0.35vw, 1.125rem);
	line-height: 1.65;
	letter-spacing: -0.011em;
	font-weight: 400;
}

/* Kartentext / Feature-Beschreibungen – eine Stufe kleiner als Lead, nicht „medium“-gewichtet */
.fk-card-copy {
	font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
	line-height: 1.6;
	letter-spacing: -0.008em;
	font-weight: 400;
}

/* Startseite: Gastro-Revolution – einheitliche Display-Überschriften */
.fk-headline-display {
	font-size: clamp(2.5rem, 6.5vw, 5.5rem);
	line-height: 0.9;
	letter-spacing: -0.04em;
	font-weight: 900;
}

/* Blog-Übersicht: Magazine-Hero (Überschriftengradient) */
.fk-blog-hero-headline {
	font-size: clamp(2.5rem, 8vw, 6rem);
	line-height: 0.85;
	letter-spacing: -0.05em;
	font-weight: 800;
}

.fk-text-gradient-magazine {
	background: linear-gradient(135deg, #0f172a 0%, #ff5c00 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

html.dark .fk-text-gradient-magazine {
	background: linear-gradient(135deg, #f1f5f9 0%, #ff8c42 55%, #ff5c00 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}


/* Einzelbeitrag / Standardseiten: gleiche Familie, etwas kleiner bei langen Titeln */
.fk-headline-display--article {
	font-size: clamp(2rem, 4.5vw, 3rem);
	line-height: 1.08;
	letter-spacing: -0.035em;
	font-weight: 800;
}

#fk-kitchen-ai-white .fk-reveal {
	opacity: 0;
	transform: translateY(40px);
	transition:
		opacity 0.9s cubic-bezier(0.17, 0.55, 0.55, 1),
		transform 0.9s cubic-bezier(0.17, 0.55, 0.55, 1);
}

#fk-kitchen-ai-white .fk-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.fk-text-gradient {
	background: linear-gradient(to right, #ff5c00, #ffb800);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* Hellgrauer Raster-Hintergrund (Kitchen AI, Provision u. a.) */
.fk-kitchen-pattern {
	background-color: #f9fafb;
	background-image:
		linear-gradient(#e5e7eb 1px, transparent 1px),
		linear-gradient(90deg, #e5e7eb 1px, transparent 1px);
	background-size: 40px 40px;
}

.fk-kitchen-ai-white .fk-kitchen-ticket {
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%);
	transition: all 0.3s ease;
}

.fk-kitchen-ai-white .fk-kitchen-custom-scroll::-webkit-scrollbar {
	width: 4px;
}

.fk-kitchen-ai-white .fk-kitchen-custom-scroll::-webkit-scrollbar-thumb {
	background: #e5e7eb;
	border-radius: 10px;
}

/* Kitchen-KDS: Scrollbar im Dark etwas sichtbarer */
html.dark .fk-kitchen-ai-white .fk-kitchen-custom-scroll::-webkit-scrollbar-thumb {
	background: rgba(255, 92, 0, 0.35);
	border-radius: 10px;
}

/* Shop AI + Kitchen: etwas wärmeres Mesh im Dark (weniger „matschiges“ Grau) */
html.dark #fk-shop-ai {
	background-color: #030712 !important;
	background-image:
		radial-gradient(at 15% 20%, rgba(255, 92, 0, 0.16) 0px, transparent 48%),
		radial-gradient(at 85% 75%, rgba(255, 184, 0, 0.09) 0px, transparent 52%);
}

html.dark #fk-kitchen-ai-white.fk-kitchen-ai-white {
	background-color: #020617;
	background-image:
		radial-gradient(at 18% 12%, rgba(255, 92, 0, 0.2) 0px, transparent 46%),
		radial-gradient(at 92% 88%, rgba(255, 184, 0, 0.11) 0px, transparent 50%),
		radial-gradient(at 48% 42%, rgba(255, 255, 255, 0.025) 0px, transparent 58%);
}

/* Sanfter Hintergrund-Glow (Betriebssystem-Kopfbereich) */
.bg-glow {
	position: absolute;
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(255, 92, 0, 0.15) 0%, rgba(255, 184, 0, 0) 70%);
	top: -100px;
	right: -100px;
	z-index: -1;
	border-radius: 50%;
}

/* Platzhalter-Grafiken (Betriebssystem-Unterseite, Z-Pattern) */
.image-placeholder {
	background: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
	border: 2px dashed #d1d5db;
}

/* Blog: Pagination */
.fk-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	padding: 0.5rem 0.75rem;
	border-radius: 9999px;
	font-size: 0.875rem;
	font-weight: 600;
	background: #f3f4f6;
	color: #374151;
	transition: background-color 0.15s, color 0.15s;
}
.fk-pagination a.page-numbers:hover {
	background: #ff5c00;
	color: #fff;
}
.fk-pagination span.page-numbers.current {
	background: #111827;
	color: #fff;
}
.fk-pagination .prev.page-numbers,
.fk-pagination .next.page-numbers {
	min-width: auto;
	padding-left: 1rem;
	padding-right: 1rem;
}

/* Kontaktseite: Neural-Interface-Karte */
.fk-neural-ai-card {
	background: rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(25px) saturate(200%);
	-webkit-backdrop-filter: blur(25px) saturate(200%);
	border: 1px solid rgba(0, 0, 0, 0.05);
	border-radius: 40px;
	box-shadow:
		0 50px 100px -20px rgba(0, 0, 0, 0.05),
		0 30px 60px -30px rgba(0, 0, 0, 0.1);
	transition: transform 0.15s ease-out;
	transform-style: preserve-3d;
}

.fk-neural-badge {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 9px;
	padding: 4px 10px;
	border-radius: 100px;
	background: rgba(0, 0, 0, 0.03);
	border: 1px solid rgba(0, 0, 0, 0.05);
	animation: fkSlideInBadge 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes fkSlideInBadge {
	from {
		transform: translateX(20px);
		opacity: 0;
	}
	to {
		transform: translateX(0);
		opacity: 1;
	}
}

.fk-neural-input {
	width: 100%;
	padding: 20px;
	background: #f8fafc;
	border: 1px solid transparent;
	border-radius: 20px;
	font-weight: 500;
	transition:
		background 0.3s cubic-bezier(0.4, 0, 0.2, 1),
		border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
		box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1),
		transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fk-neural-input:focus {
	background: #ffffff;
	border-color: #ff5c00;
	box-shadow: 0 10px 30px -10px rgba(255, 92, 0, 0.15);
	outline: none;
	transform: translateY(-2px);
}

.fk-neural-btn-main {
	background: #000;
	color: #fff;
	padding: 20px;
	border-radius: 20px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	transition: all 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	cursor: pointer;
	border: none;
}

.fk-neural-btn-main:hover {
	transform: scale(1.02);
	background: #ff5c00;
	box-shadow: 0 20px 40px -10px rgba(255, 92, 0, 0.3);
}

.fk-neural-btn-wa {
	background: #fff;
	color: #25d366;
	border: 2px solid #25d366;
	padding: 18px;
	border-radius: 20px;
	font-weight: 700;
	text-transform: uppercase;
	transition: all 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	cursor: pointer;
}

.fk-neural-btn-wa:hover {
	background: #25d366;
	color: #fff;
	box-shadow: 0 20px 40px -10px rgba(37, 211, 102, 0.3);
}

.fk-neural-loading-line {
	height: 2px;
	background: linear-gradient(90deg, transparent, #ff5c00, transparent);
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	animation: fkLoadingMove 2s infinite linear;
}

@keyframes fkLoadingMove {
	0% {
		transform: translateX(-100%);
	}
	100% {
		transform: translateX(100%);
	}
}

@media (prefers-reduced-motion: reduce) {
	.fk-neural-badge {
		animation: none;
	}
	.fk-neural-loading-line {
		animation: none;
		opacity: 0;
	}
}

/* Startseite Preise: Monatlich/Jährlich Switch */
#fk-preise .fk-preise-mode-btn.fk-preise-mode--active {
	background: linear-gradient(135deg, #ff5c00 0%, #ea580c 100%);
	color: #fff;
	box-shadow: 0 10px 25px -8px rgba(255, 92, 0, 0.45);
}
#fk-preise .fk-preise-mode-btn:not(.fk-preise-mode--active):hover {
	color: #0f172a;
	background: rgba(248, 250, 252, 0.9);
}

/* Skip-Link (sichtbar bei Tastaturfokus) */
.fk-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	width: 1px;
	height: 1px;
	overflow: hidden;
	z-index: 100000;
}
.fk-skip-link:focus {
	position: fixed;
	left: 1rem;
	top: 1rem;
	width: auto;
	height: auto;
	padding: 0.75rem 1.25rem;
	overflow: visible;
	background: #ff5c00;
	color: #fff;
	font-weight: 700;
	font-size: 0.875rem;
	border-radius: 0.75rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
	outline: 2px solid #fff;
	outline-offset: 2px;
}

#main.fk-main:focus {
	outline: none;
}
#main.fk-main:focus-visible {
	outline: 3px solid #ff5c00;
	outline-offset: 4px;
}

/*
 * Dunkelmodus — „Deep Black + LED / Glas“
 * Tiefschwarz, Orange-/Gelb-Glows, Frosted Glass überall wo vorher flaches Slate war.
 */
html.dark .hero-gradient {
	background:
		radial-gradient(ellipse 140% 90% at 50% -25%, rgba(255, 92, 0, 0.35) 0%, transparent 58%),
		radial-gradient(ellipse 70% 55% at 100% 15%, rgba(255, 184, 0, 0.14) 0%, transparent 55%),
		radial-gradient(ellipse 55% 45% at 0% 85%, rgba(255, 92, 0, 0.12) 0%, transparent 50%),
		radial-gradient(circle at 50% 120%, rgba(255, 92, 0, 0.06) 0%, transparent 45%),
		linear-gradient(180deg, #030712 0%, #020617 38%, #000000 100%);
}

html.dark body.hero-gradient,
html.dark body.bg-brand-light {
	color: #e8eef6 !important;
}

html.dark body.bg-brand-light {
	background-color: #020617 !important;
}

html.dark .glass-header {
	background: rgba(2, 6, 12, 0.55);
	backdrop-filter: blur(22px) saturate(180%);
	-webkit-backdrop-filter: blur(22px) saturate(180%);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	box-shadow:
		0 4px 32px rgba(0, 0, 0, 0.65),
		inset 0 -1px 0 rgba(255, 92, 0, 0.22),
		0 0 48px -18px rgba(255, 92, 0, 0.35);
}

html.dark .nav-link {
	color: #cbd5e1;
	text-shadow: 0 0 24px rgba(255, 92, 0, 0.06);
}

html.dark .nav-link:hover {
	color: #ffb800;
	text-shadow: 0 0 20px rgba(255, 184, 0, 0.35);
}

html.dark .hero-light-mesh {
	background-color: #020617;
	background-image:
		radial-gradient(at 15% 10%, rgba(255, 92, 0, 0.22) 0px, transparent 42%),
		radial-gradient(at 90% 90%, rgba(255, 184, 0, 0.12) 0px, transparent 48%),
		radial-gradient(at 50% 50%, rgba(255, 255, 255, 0.03) 0px, transparent 60%);
}

html.dark .mesh-gradient {
	background-color: #020617;
	background-image:
		radial-gradient(at 0% 0%, rgba(255, 92, 0, 0.2) 0px, transparent 52%),
		radial-gradient(at 100% 100%, rgba(255, 184, 0, 0.14) 0px, transparent 52%),
		radial-gradient(at 50% 30%, rgba(255, 92, 0, 0.06) 0px, transparent 55%);
}

html.dark .fk-kitchen-pattern {
	background-color: #020617;
	background-image:
		linear-gradient(rgba(255, 140, 60, 0.07) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 140, 60, 0.07) 1px, transparent 1px);
	background-size: 40px 40px;
}

html.dark .glass-light,
html.dark .glass-premium {
	background: rgba(8, 12, 22, 0.58);
	backdrop-filter: blur(22px) saturate(165%);
	-webkit-backdrop-filter: blur(22px) saturate(165%);
	border: 1px solid rgba(255, 255, 255, 0.09);
	box-shadow:
		0 8px 40px rgba(0, 0, 0, 0.55),
		inset 0 1px 0 rgba(255, 255, 255, 0.1),
		0 0 36px -14px rgba(255, 92, 0, 0.25);
}

html.dark .fk-pos-showcase {
	background-color: #020617 !important;
	color: #f1f5f9 !important;
	border-top-color: rgba(255, 92, 0, 0.18);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

html.dark .fk-pos-showcase-mesh {
	background:
		radial-gradient(at 12% 18%, rgba(255, 92, 0, 0.18) 0px, transparent 52%),
		radial-gradient(at 88% 82%, rgba(255, 184, 0, 0.1) 0px, transparent 52%);
}

html.dark .fk-pos-showcase .fk-glass-card {
	background: rgba(6, 10, 20, 0.72);
	backdrop-filter: blur(18px) saturate(150%);
	-webkit-backdrop-filter: blur(18px) saturate(150%);
	border: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow:
		0 8px 36px rgba(0, 0, 0, 0.55),
		inset 0 1px 0 rgba(255, 255, 255, 0.08),
		0 0 40px -16px rgba(255, 92, 0, 0.28);
}

html.dark .fk-pos-showcase .fk-glass-card:hover {
	box-shadow:
		0 24px 48px rgba(0, 0, 0, 0.55),
		inset 0 1px 0 rgba(255, 255, 255, 0.12),
		0 0 52px -12px rgba(255, 92, 0, 0.45);
	border-color: rgba(255, 92, 0, 0.45);
}

html.dark .fk-neural-ai-card {
	background: rgba(5, 9, 18, 0.78);
	backdrop-filter: blur(24px) saturate(175%);
	-webkit-backdrop-filter: blur(24px) saturate(175%);
	border: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow:
		0 16px 56px rgba(0, 0, 0, 0.55),
		inset 0 1px 0 rgba(255, 255, 255, 0.1),
		0 0 48px -14px rgba(255, 92, 0, 0.3);
}

html.dark .fk-neural-input {
	background: rgba(3, 7, 15, 0.85);
	border: 1px solid rgba(255, 255, 255, 0.06);
	color: #f1f5f9;
	box-shadow: inset 0 0 24px rgba(255, 92, 0, 0.04);
}

html.dark .fk-neural-input:focus {
	background: rgba(8, 14, 26, 0.95);
	border-color: rgba(255, 92, 0, 0.45);
	box-shadow:
		inset 0 0 28px rgba(255, 92, 0, 0.08),
		0 0 28px rgba(255, 92, 0, 0.18);
}

html.dark .fk-neural-btn-wa {
	background: rgba(10, 16, 28, 0.9);
	border-color: rgba(37, 211, 102, 0.35);
	box-shadow: 0 0 28px rgba(37, 211, 102, 0.12);
}

html.dark #fk-preise .fk-preise-mode-btn:not(.fk-preise-mode--active):hover {
	color: #f8fafc;
	background: rgba(255, 255, 255, 0.06);
	box-shadow: inset 0 0 20px rgba(255, 92, 0, 0.08);
}

html.dark footer.bg-gradient-to-b {
	background: linear-gradient(to bottom, #030712, #000000) !important;
	border-top-color: rgba(255, 92, 0, 0.15);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

html.dark .fk-pagination .page-numbers {
	background: rgba(15, 23, 42, 0.65);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	color: #cbd5e1;
	border: 1px solid rgba(255, 255, 255, 0.06);
	box-shadow: 0 0 20px rgba(255, 92, 0, 0.06);
}

html.dark .fk-pagination span.page-numbers.current {
	background: linear-gradient(145deg, rgba(255, 92, 0, 0.95), rgba(255, 140, 60, 0.9));
	color: #020617;
	border-color: rgba(255, 184, 0, 0.5);
	box-shadow: 0 0 28px rgba(255, 92, 0, 0.35);
}

html.dark .image-placeholder {
	background: linear-gradient(135deg, rgba(255, 92, 0, 0.08) 0%, rgba(15, 23, 42, 0.95) 50%, #020617 100%);
	border-color: rgba(255, 255, 255, 0.08);
	box-shadow: inset 0 0 40px rgba(255, 92, 0, 0.06);
}

/* Tailwind „bg-white“ → Glas-Karten statt flachem Slate */
html.dark .bg-white {
	background: rgba(6, 10, 20, 0.62) !important;
	backdrop-filter: blur(22px) saturate(165%);
	-webkit-backdrop-filter: blur(22px) saturate(165%);
	border-color: rgba(255, 255, 255, 0.07) !important;
	box-shadow:
		0 8px 36px rgba(0, 0, 0, 0.5),
		inset 0 1px 0 rgba(255, 255, 255, 0.09),
		0 0 44px -18px rgba(255, 92, 0, 0.22);
}

html.dark .fk-mobile-panel {
	background: rgba(2, 6, 14, 0.92) !important;
	backdrop-filter: blur(28px) saturate(170%);
	-webkit-backdrop-filter: blur(28px) saturate(170%);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html.dark section.border-gray-100,
html.dark .border-gray-100 {
	border-color: rgba(255, 92, 0, 0.12) !important;
}

html.dark .border-gray-200 {
	border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Business-Karte & dunkle Flächen: tieferes Schwarz + Orange-Randlicht */
html.dark .bg-brand-dark {
	background: linear-gradient(165deg, #070d18 0%, #000000 55%, #030306 100%) !important;
	box-shadow:
		0 0 0 1px rgba(255, 92, 0, 0.18),
		0 16px 56px rgba(0, 0, 0, 0.75),
		inset 0 1px 0 rgba(255, 255, 255, 0.07),
		0 0 60px -14px rgba(255, 92, 0, 0.28);
}

html.dark .fk-text-gradient {
	filter: drop-shadow(0 0 16px rgba(255, 92, 0, 0.45));
}

html.dark .bg-brand-orange:hover {
	box-shadow: 0 8px 36px rgba(255, 92, 0, 0.45);
}

/*
 * Text: Tailwind-CSS lädt nach diesem Stylesheet — explizite Utilities
 * (text-brand-dark, text-gray-*, …) überschreiben sonst die Body-Farbe.
 */
html.dark body.text-brand-dark {
	color: #e2e8f0 !important;
}

html.dark .text-brand-dark {
	color: #f1f5f9 !important;
}

html.dark .text-brand-dark\/80 {
	color: rgb(241 245 249 / 0.88) !important;
}

html.dark .text-brand-dark\/60 {
	color: rgb(241 245 249 / 0.72) !important;
}

html.dark .text-gray-300 {
	color: #cbd5e1 !important;
}

html.dark .text-gray-400 {
	color: #94a3b8 !important;
}

html.dark .text-gray-500 {
	color: #94a3b8 !important;
}

html.dark .text-gray-600 {
	color: #cbd5e1 !important;
}

html.dark .text-gray-700 {
	color: #e2e8f0 !important;
}

html.dark .text-slate-400 {
	color: #94a3b8 !important;
}

html.dark .text-slate-500 {
	color: #94a3b8 !important;
}

html.dark .text-slate-600 {
	color: #cbd5e1 !important;
}

html.dark .text-slate-700 {
	color: #e2e8f0 !important;
}

html.dark .text-slate-900 {
	color: #f1f5f9 !important;
}

html.dark .text-\[\#0F172A\] {
	color: #f1f5f9 !important;
}

/* Gelbe Markenflächen: dunkle Schrift für Kontrast */
html.dark .bg-brand-yellow .text-brand-dark,
html.dark .bg-brand-yellow.text-brand-dark,
html.dark .from-brand-yellow .text-brand-dark {
	color: #020617 !important;
}
