/* =========================================================
   Thüringer Markenwelt – main.css
   1:1 portiert aus dem HTML-Mockup. Dark Theme,
   Roboto / Roboto Serif, grüne Akzente.
   ========================================================= */

*, *::before, *::after { box-sizing: border-box; }
html {
	scroll-behavior: smooth;
	background-color: var(--bg-deep);
	overscroll-behavior: none;
}

:root {
	/* === Brand ============================================ */
	--green:             #007F00;
	--green-bright:      #009b00;                       /* Hover-Stufe (heller, nicht dunkler) */
	--green-tint-low:    rgba(0, 127, 0, 0.08);         /* Hover-BG auf dunklem Theme */
	--green-tint-mid:    rgba(0, 127, 0, 0.12);         /* Active-State BG */
	--green-tint-high:   rgba(0, 127, 0, 0.15);         /* Atmosphäre, Chip-BG, Glow-Inhalt */

	/* === Surfaces (Dark Theme) ============================ */
	--bg:                #16181B;                       /* Body-Oberkante */
	--bg-deep:           #0c0d0f;                       /* Body-Unterkante + Karten + Inputs */
	--bg-raised:         #0f1215;                       /* Chip-Surface (Logo-Slider, Payment-Icons) */
	--bg-raised-hover:   #14181c;                       /* Chip-Hover */
	--card-border:       #23272c;                       /* Karten-/Input-Rahmen */
	--border-soft:       rgba(255, 255, 255, 0.18);     /* subtile Trenner / Tag-Border auf dunkel */
	--surface-soft:      rgba(255, 255, 255, 0.05);     /* Hover-Overlay, Code-Hintergrund */
	--inner-highlight:   rgba(255, 255, 255, 0.15);     /* inset-shadow auf gefüllten Buttons */

	/* === Text ============================================= */
	--text:              #FFFFFF;
	--text-soft:         rgba(255, 255, 255, 0.85);     /* Lead, Body, Description */
	--text-mute:         rgba(255, 255, 255, 0.6);      /* Meta, Footer, Sort-Labels */
	--text-dim:          rgba(255, 255, 255, 0.4);      /* Placeholder, Counter */

	/* === Radii ============================================ */
	--radius-sm:         6px;                           /* Inputs, kleine Tags, Pagination */
	--radius-md:         8px;                           /* Buttons, Nav-Links, Search, Icon-Buttons, Sozials */
	--radius-lg:         12px;                          /* Karten, Container */
	--radius-pill:       999px;                         /* Echte Pill-Form: Chips, Cart-Count */

	/* === Shadows ========================================== */
	--shadow-glow:       0 16px 40px rgba(0, 127, 0, 0.18);  /* Card-Hover */

	/* === Type-Scale ======================================= */
	--text-xs:           12px;                          /* Badges, Tags, Counter, Micro */
	--text-sm:           14px;                          /* Meta, Footer, kleines Body */
	--text-base:         16px;                          /* Body Default */
	--text-md:           18px;                          /* Lead, größeres Body, Marke-Desc */
	--text-lg:           20px;                          /* H3, Produktpreis */
	--text-xl:           24px;                          /* Mobile-Section-Heads, Gift-H3 */
	--text-2xl:          28px;                          /* Gift-H3 Desktop */
	--text-3xl:          32px;                          /* Section-Heads Desktop, Story-H2 */
	/* Hero-Headline ist fluide via clamp() — kein --text-4xl-Token nötig */

	--leading-tight:     1.15;                          /* Hero, große Display-Headlines */
	--leading-base:      1.5;                           /* Body */

	/* === Motion =========================================== */
	--ease:              ease;                          /* CSS-Standard, konsistent mit Vorgängerversion */
	--duration-sm:       0.2s;                          /* Hover-Color/Border, Inputs */
	--duration-md:       0.3s;                          /* Card-Hover-Lifts, Box-Shadow */
	--duration-lg:       0.6s;                          /* Bild-Scale-Zoom auf Hover */

	/* === Focus ============================================ */
	--focus-ring:        2px solid var(--green);
	--focus-ring-offset: 2px;

	/* === Spacing-Scale ==================================== */
	--space-1:           4px;                           /* hairline gaps */
	--space-2:           8px;                           /* tight gaps, icon-text */
	--space-3:           12px;                          /* small gaps, button-internal */
	--space-4:           16px;                          /* default rhythm, body-margin */
	--space-5:           24px;                          /* component-padding, grid-gaps */
	--space-6:           32px;                          /* card-padding, large gaps */
	--space-7:           48px;                          /* section-internal */
	--space-8:           64px;                          /* section-padding-large */

	/* === Layout =========================================== */
	--container-width:   1350px;
	--container-gutter:  32px;                          /* Seitenränder Container, Header, Footer (mehr Atemraum) */

	/* === z-index-Skala ==================================== */
	--z-below:           -1;                            /* dekorative ::before-Layer */
	--z-header:          100;                           /* Sticky-Header */
	--z-overlay:         200;                           /* Fullscreen-Overlay-Nav */
	--z-toggle:          250;                           /* Burger-Toggle über Overlay */
	--z-skiplink:        9999;                          /* Skip-Link (höchste Priorität) */
}

/* Container-Gutter pro Breakpoint — auf Mobile großzügiger als vorher */
@media (max-width: 767px) { :root { --container-gutter: 28px; } }
@media (max-width: 480px) { :root { --container-gutter: 22px; } }

body {
	margin: 0;
	font-family: 'Roboto', system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
	font-size: var(--text-base);
	line-height: var(--leading-base);
	color: var(--text);
	background-color: var(--bg-deep);
	background-image:
		radial-gradient(1200px 700px at 50% -10%, rgba(60, 65, 70, 0.15), transparent 70%),
		linear-gradient(180deg, var(--bg) 0%, var(--bg-deep) 100%);
	background-attachment: fixed;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: clip;
}
html { scroll-padding-top: 24px; } /* Sticky-Offset für Anker-Sprünge */

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, p { margin: 0; }

/* ============ ACCESSIBILITY: Focus + Motion ============
   Global :focus-visible (Tastaturnutzer sehen jetzt einen
   konsistenten grünen Outline auf allen interaktiven
   Elementen — Buttons, Links, Inputs, Pagination, Chips).
   Mouse-Klick zeigt nichts (:focus-visible matched nur bei
   Keyboard-Focus). */
:where( a, button, input, select, textarea, [tabindex] ):focus-visible {
	outline: var(--focus-ring);
	outline-offset: var(--focus-ring-offset);
	border-radius: var(--radius-sm);
}

/* prefers-reduced-motion: alle Bewegungen ausschalten oder
   massiv dämpfen — Hover-Lifts, Reveal-Animationen, Mask-
   Transitionen, Marquee. Respektiert die System-Präferenz. */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* ============ SECTION BLEED VARIANTS ============
   Vier semantische Stufen, wie stark eine Section über die
   vorherige hochzieht (negativer margin-top für Mask-Overlap).
   Section-Widgets wählen die Variante via Klasse; reorderbar
   im Elementor-Editor, weil die Section nicht mehr auf einen
   konkreten Nachbarn verdrahtet ist.
     bleed-none  – kein Overlap
     bleed-sm    – leicht  (z. B. Vor-Ort)
     bleed-md    – mittel  (Hero)
     bleed-lg    – stark   (Shop, Marken)
     bleed-xl    – maximal (Story, Anfahrt)
*/
.thmw-section--bleed-none { margin-top: 0; }
.thmw-section--bleed-sm   { margin-top: -2em; }
.thmw-section--bleed-md   { margin-top: -6em; }
.thmw-section--bleed-lg   { margin-top: -10em; }
.thmw-section--bleed-xl   { margin-top: -13em; }

@media (max-width: 1024px) {
	.thmw-section--bleed-md   { margin-top: -4em; }
	.thmw-section--bleed-lg   { margin-top: -7em; }
	.thmw-section--bleed-xl   { margin-top: -10em; }
}
@media (max-width: 767px) {
	.thmw-section--bleed-md   { margin-top: 0; }
	.thmw-section--bleed-lg   { margin-top: -5em; }
	.thmw-section--bleed-xl   { margin-top: -6em; }
}

.container {
	max-width: var(--container-width);
	margin: 0 auto;
	padding: 0 var(--container-gutter);
	width: 100%;
}

/* Skip-Link / SR */
.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px; width: 1px; overflow: hidden;
	white-space: nowrap;
}
.skip-link {
	position: absolute; left: -9999px; top: 8px; z-index: var(--z-skiplink);
	background: var(--green); color: var(--text); padding: 10px 14px; border-radius: var(--radius-sm);
}
.skip-link:focus { left: 8px; }

/* ============ HEADER ============ */
.site-header {
	position: sticky;
	top: 0;
	z-index: var(--z-header);
	padding: 1em 0;
	border-bottom: 1px solid transparent;
	transition: border-color var(--duration-sm) var(--ease), padding var(--duration-sm) var(--ease);
	/* Wichtig: KEIN backdrop-filter / transform / filter direkt auf
	   .site-header – sonst würde sie zum Containing-Block für die
	   position:fixed Overlay-Nav (und der Hintergrund würde fehlen). */
}
.site-header::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: var(--z-below);
	background-color: transparent;
	-webkit-backdrop-filter: saturate(140%) blur(10px);
	backdrop-filter: saturate(140%) blur(10px);
	opacity: 0;
	transition: opacity var(--duration-sm) var(--ease), background-color var(--duration-sm) var(--ease);
	pointer-events: none;
}
.site-header.is-scrolled::before {
	opacity: 1;
	background-color: rgba(12, 13, 15, 0.85);
}
.site-header.is-scrolled {
	border-bottom-color: var(--card-border);
	padding: 0.6em 0;
}
.header-inner {
	max-width: var(--container-width);
	margin: 0 auto;
	padding: 0 var(--container-gutter);
	display: flex;
	align-items: center;
	gap: var(--space-6);
	position: relative;
	z-index: 1;
}
.brand {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	flex-shrink: 0;
}
.brand-logo {
	width: 60px; height: 60px;
	flex-shrink: 0;
}
.brand-logo img {
	width: 100%; height: 100%;
	object-fit: contain;
	display: block;
}
.brand-name {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-md);
	font-weight: 700;
	color: var(--text);
	line-height: 1.2;
}

.header-nav {
	flex: 1;
	display: flex;
	justify-content: center;
}
/* Brand-Block nur im Fullscreen-Overlay anzeigen (Desktop versteckt) */
.header-nav__brand { display: none; }
.nav-list {
	display: flex;
	gap: var(--space-2);                /* sichtbarer Atemraum zwischen Items */
	list-style: none;
	margin: 0; padding: 0;
}
.nav-list li { list-style: none; }
.nav-list a {
	color: var(--text);
	font-family: 'Roboto', sans-serif;
	font-weight: 600;
	font-size: var(--text-base);
	padding: 8px 14px;
	border-radius: var(--radius-md);            /* konsistent mit Buttons */
	transition: color var(--duration-sm) var(--ease),
	            background-color var(--duration-sm) var(--ease);
	display: inline-block;
}
.nav-list a:hover {
	color: var(--green);                        /* nur Color-Shift, kein BG-Tint */
}

/* Active-State des Menüs:
   – .is-active     → vom ScrollSpy (OnePager-Anker)
   – current-menu-* → automatisch von WordPress
                      (Archive, Single-Pages, Custom Posts)
   Solider Pill mit kräftigerem Tint + Schrift bleibt weiß
   für maximalen Kontrast gegen den grünen Hintergrund. */
.nav-list .is-active > a,
.nav-list a.is-active,
.nav-list .current-menu-item > a,
.nav-list .current-menu-parent > a,
.nav-list .current-menu-ancestor > a,
.nav-list .current_page_item > a,
.nav-list .current-page-ancestor > a {
	color: var(--text);
	background: var(--green);
}
.nav-list .is-active > a:hover,
.nav-list a.is-active:hover,
.nav-list .current-menu-item > a:hover,
.nav-list .current-menu-parent > a:hover,
.nav-list .current-menu-ancestor > a:hover,
.nav-list .current_page_item > a:hover,
.nav-list .current-page-ancestor > a:hover {
	color: var(--text);
	background: var(--green-bright);            /* Hover auf Active = leicht heller */
}

.header-actions {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	flex-shrink: 0;
}
.search-box {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	height: 42px;
	padding: 0 14px;
	border-radius: var(--radius-md);
	background: rgba(12,13,15,0.6);
	border: 1px solid var(--card-border);
	width: 240px;
	transition: border-color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease), width var(--duration-md) var(--ease);
}
.search-box:focus-within {
	border-color: var(--green);
	background: rgba(12,13,15,0.9);
	width: 280px;
}
.search-box svg {
	width: 16px; height: 16px;
	fill: var(--text-mute);
	flex-shrink: 0;
}
.search-box input {
	flex: 1;
	background: transparent;
	border: none;
	outline: none;
	color: var(--text);
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-sm);
	min-width: 0;
}
.search-box input::placeholder { color: var(--text-dim); }

.icon-btn {
	display: grid;
	place-items: center;
	width: 42px; height: 42px;
	border-radius: var(--radius-md);
	background: rgba(12,13,15,0.6);
	border: 1px solid var(--card-border);
	color: var(--text);
	cursor: pointer;
	position: relative;
	transition: background var(--duration-sm) var(--ease), border-color var(--duration-sm) var(--ease), color var(--duration-sm) var(--ease);
}
.icon-btn:hover {
	background: var(--green-tint-mid);
	border-color: rgba(0,127,0,0.5);
	color: var(--green);
}
.icon-btn svg { width: 18px; height: 18px; fill: currentColor; }
.cart-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	height: 42px;
	padding: 0 16px 0 14px;
	border-radius: var(--radius-md);
	background: var(--green);
	border: none;
	color: var(--text);
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-sm);
	font-weight: 600;
	cursor: pointer;
	box-shadow: inset 0 1px 0 var(--inner-highlight);
	transition: transform var(--duration-sm) var(--ease), background-color var(--duration-sm) var(--ease), box-shadow var(--duration-md) var(--ease);
	text-decoration: none;
}
.cart-btn:hover {
	transform: translateY(-1px);
	background: var(--green-bright);
	box-shadow: inset 0 1px 0 var(--inner-highlight), 0 8px 20px rgba(0, 127, 0, 0.3);
	color: var(--text);
}
.cart-btn svg { width: 18px; height: 18px; fill: currentColor; }
.cart-count {
	background: var(--border-soft);
	padding: 2px 7px;
	border-radius: var(--radius-pill);
	font-size: var(--text-xs);
	font-weight: 700;
}

/* "Im Laden besuchen" Button im Header (Shop deaktiviert) */
/* Header-Visit-Button: Glass-Effect-Override für Header-Kontext.
   Eigenständigerer Look auf dem Hero-Bild als der nackte Ghost-Border —
   semi-transparenter dunkler BG + backdrop-blur gibt dem Button Tiefe. */
.header-actions__visit {
	padding: 10px 18px;
	font-size: var(--text-sm);
	background: rgba(12, 13, 15, 0.55);
	border-color: rgba(255, 255, 255, 0.25);
	-webkit-backdrop-filter: saturate(140%) blur(8px);
	backdrop-filter: saturate(140%) blur(8px);
}
.header-actions__visit:hover {
	background: rgba(12, 13, 15, 0.78);
	border-color: rgba(255, 255, 255, 0.5);
}

.menu-toggle {
	display: none;
	background: none;
	border: none;
	color: var(--text);
	cursor: pointer;
	padding: 8px;
	position: relative;
	z-index: var(--z-toggle);
}
.menu-toggle svg { width: 28px; height: 28px; fill: currentColor; }
.menu-toggle .menu-toggle__icon--bars  { display: block; }
.menu-toggle .menu-toggle__icon--close { display: none; }
body.thmw-menu-open .menu-toggle .menu-toggle__icon--bars  { display: none; }
body.thmw-menu-open .menu-toggle .menu-toggle__icon--close { display: block; }
body.thmw-menu-open { overflow: hidden; }

/* ============ HERO ============ */
.hero {
	position: relative;
	min-height: 819px;
	padding: 6em 0 4em;
	display: flex;
	flex-direction: column;
	justify-content: center;
	background-position: center center;
	background-size: cover;
	-webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 75%, transparent 100%);
	mask-image: linear-gradient(to bottom, #000 0%, #000 75%, transparent 100%);
}
.hero::before {
	content: '';
	position: absolute;
	inset: 0;
	/* weicher Übergang: Vier-Stop-Gradient mit Zwischenwert statt harter Kante bei 55% */
	background-image: linear-gradient(90deg,
		var(--bg) 0%,
		var(--bg) 35%,
		rgba(22, 24, 27, 0.7) 65%,
		rgba(22, 24, 27, 0.2) 100%);
	pointer-events: none;
}
.hero .container {
	position: relative;
	z-index: 2;
	padding-top: 7em;
}
.hero h1 {
	font-family: 'Roboto Serif', serif;
	font-size: clamp(1.625rem, 2.4vw + 1rem, 3rem);   /* fluid 26px ↔ 48px */
	font-weight: 700;
	line-height: var(--leading-tight);
	color: var(--text);
}
.hero p.lead {
	width: 48%;
	max-width: 48%;
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-lg);
	font-weight: 400;
	line-height: 28px;
	color: var(--text);
	margin-top: 24px;
}
.hero-cta {
	margin-top: 28px;
	display: flex;
	gap: var(--space-3);
	flex-wrap: wrap;
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-3);
	background: var(--green);                              /* flat – kein Y2K-Gradient mehr */
	color: var(--text);
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	font-weight: 600;
	line-height: 1.2;
	padding: var(--space-4) var(--space-6);                /* 16/32 px — Token-basiert */
	border-radius: var(--radius-md);                       /* 8px statt 6 – freundlicher */
	border: 1px solid transparent;                         /* gleiche Box wie ghost — keine Größen-Shifts */
	cursor: pointer;
	box-shadow: inset 0 1px 0 var(--inner-highlight);      /* subtle Inner-Highlight für Tiefe */
	transition: transform var(--duration-sm) var(--ease),
	            box-shadow var(--duration-md) var(--ease),
	            background-color var(--duration-sm) var(--ease),
	            border-color var(--duration-sm) var(--ease);
	text-decoration: none;
}
.btn:hover {
	transform: translateY(-2px);
	background: var(--green-bright);                       /* heller statt dunkler */
	box-shadow: inset 0 1px 0 var(--inner-highlight),
	            var(--shadow-glow);
	color: var(--text);
}
.btn:active {
	transform: translateY(0);
	box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.25);        /* gedrückt */
}
.btn svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; }

.btn-ghost {
	background: var(--surface-soft);                       /* dezenter Eigenkörper (5% weiß) statt fully transparent */
	color: var(--text);
	border-color: var(--border-soft);                      /* gleiche Border-Box wie .btn (18% weiß) */
	box-shadow: none;
}
.btn-ghost:hover {
	background: rgba(255, 255, 255, 0.10);                 /* neutraler Tone-Up, kein Brand-Pop */
	border-color: rgba(255, 255, 255, 0.55);
	box-shadow: none;
	color: var(--text);
}
.btn-ghost:active { box-shadow: none; transform: translateY(0); }

/* ============ LOGO SLIDER ============ */
.logo-section {
	position: relative;
	z-index: 3;
	padding: 24px 0;
}
.logo-slider {
	overflow: hidden;
	padding: 16px 8px;
	border-radius: var(--radius-lg);
	border: 1px solid var(--card-border);
	-webkit-mask-image: linear-gradient(to right, transparent 0%, #000 3%, #000 97%, transparent 100%);
	mask-image: linear-gradient(to right, transparent 0%, #000 3%, #000 97%, transparent 100%);
}
.logo-track {
	display: flex;
	align-items: center;
	gap: var(--space-7);
	width: max-content;
	animation: logo-marquee 26s linear infinite;
}
.logo-slider:hover .logo-track { animation-play-state: paused; }
.logo-chip {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 240px;
	height: 110px;
	padding: 16px 20px;
	border-radius: var(--radius-lg);
	background: var(--bg-raised);
	border: 1px solid var(--card-border);
	transition: border-color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease), transform var(--duration-sm) var(--ease);
	text-decoration: none;
	overflow: hidden;
}
/* Slider: Logo passt sich proportional in 200×70 ein (Seitenverhältnis
   bleibt erhalten — wie ursprünglich). */
.logo-chip img {
	max-width: 200px;
	max-height: 70px;
	width: auto;
	height: auto;
	object-fit: contain;
	filter: grayscale(1) contrast(1.05) opacity(0.85);
	transition: filter var(--duration-sm) var(--ease), transform var(--duration-sm) var(--ease);
}
a.logo-chip:hover {
	border-color: rgba(0,127,0,0.5);
	background: var(--bg-raised-hover);
	transform: translateY(-2px);
}
.logo-chip:hover img {
	filter: none;
}

@media (max-width: 767px) {
	.logo-chip { width: 190px; height: 95px; padding: 14px 16px; }
	.logo-chip img { max-width: 158px; max-height: 60px; width: auto; height: auto; }
}
@keyframes logo-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
/* Marquee respektiert prefers-reduced-motion über die globale Regel oben
   (animation-duration: 0.01ms !important) — kein eigener Block mehr nötig. */

/* ============ SECTION HEADERS ============ */
.section-head { margin-bottom: 3em; }
.section-head-row {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	/* margin-bottom auf 0 — Spacing zur Subtitle gehört zur Subtitle (Single Source of Truth) */
}
.section-icon svg {
	width: 41px; height: 41px;
	fill: var(--green);
	display: block;
}
.section-head h1,
.section-head h2,
.section-head h3,
.section-head h4,
.section-head h5,
.section-head h6,
.section-head .section-head-row > p,
.section-head .section-head-row > div {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-3xl);
	font-weight: 700;
	line-height: 42px;
	color: var(--text);
	margin: 0;
}
.section-head .subtitle {
	width: 48%;
	max-width: 48%;
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	font-weight: 400;
	line-height: 24px;
	color: var(--text);
	margin-top: var(--space-5);             /* 24px Atemraum unter dem H2 (vorher 8) */
}
.section-head-with-link {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: var(--space-6);
	flex-wrap: wrap;
}
.view-all-link {
	color: var(--green);
	font-weight: 600;
	font-size: var(--text-sm);
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding-bottom: 4px;
	border-bottom: 1px solid transparent;
	transition: border-color var(--duration-sm) var(--ease), gap var(--duration-sm) var(--ease);
	flex-shrink: 0;
}
.view-all-link:hover {
	border-color: var(--green);
	gap: var(--space-3);
	color: var(--green);
}
.view-all-link svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2; }
.accent { color: var(--green); }

/* ============ THEMENWELT ============ */
.themenwelt {
	position: relative;
	padding: 6em 0 13em;
	/* Sanfte Edges: 2.5 % Fade-Zone mit Smooth-Alpha-Zwischenstop,
	   damit Section-Heading und Karten nicht in der Fade-Zone landen
	   (vorher 10 % – Heading wurde sichtbar transparent). */
	-webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 1%, #000 2.5%, #000 97.5%, rgba(0,0,0,0.6) 99%, transparent 100%);
	mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 1%, #000 2.5%, #000 97.5%, rgba(0,0,0,0.6) 99%, transparent 100%);
}

/* Optionaler Einleitungs-Absatz unter dem Section-Heading.
   Sitzt zwischen .section-head und .card-grid — leitet den Themen-
   bereich textlich ein, falls die Subtitle allein zu knapp ist. */
.themenwelt__intro {
	max-width: 70ch;
	margin: -1.25em 0 var(--space-7);   /* −1.25em: rückt enger an die Subtitle */
	font-size: var(--text-md);
	line-height: var(--leading-base);
	color: var(--text-soft);
}

.card-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-6);
}

.card {
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transition: transform var(--duration-md) var(--ease), border-color var(--duration-md) var(--ease), box-shadow var(--duration-md) var(--ease);
	cursor: pointer;
	position: relative;
	color: var(--text);
}
.card:hover {
	transform: translateY(-4px);
	border-color: var(--green);
	box-shadow: var(--shadow-glow);
}
.card-image {
	width: 100%;
	height: 233px;
	overflow: hidden;
	border-radius: 12px 12px 0 0;
	position: relative;
}
.card-image img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center center;
	transition: transform var(--duration-md) var(--ease);
}
/* Subtile Tiefe: dunkler Bottom-Fade auf dem Karten-Bild, damit
   das Bild visuell in die Karten-Body übergeht statt hart abzukanten. */
.card-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0) 50%,
		rgba(0, 0, 0, 0.35) 90%,
		rgba(0, 0, 0, 0.55) 100%
	);
	pointer-events: none;
	transition: opacity var(--duration-md) var(--ease);
}
.card:hover .card-image::after { opacity: 0.7; }
.card:hover .card-image img { transform: scale(1.05); }
.card-count {
	position: absolute;
	top: 14px; right: 14px;
	background: rgba(12,13,15,0.85);
	border: 1px solid var(--inner-highlight);
	padding: 5px 10px;
	border-radius: var(--radius-sm);
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--text);
	letter-spacing: 0.04em;
	backdrop-filter: blur(6px);
}
.card-body {
	padding: 2em;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.card-body h3 {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-lg);
	font-weight: 700;
	line-height: 24px;
	color: var(--text);
}
.card-body p {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	font-weight: 400;
	line-height: 24px;
	color: var(--text);
	margin-top: 8px;
}

/* ============ SHOP ============ */
.shop {
	position: relative;
	padding: 5em 0 8em;
	-webkit-mask-image: linear-gradient(to bottom, transparent 0%, transparent 4%, #000 10%, #000 90%, transparent 96%, transparent 100%);
	mask-image: linear-gradient(to bottom, transparent 0%, transparent 4%, #000 10%, #000 90%, transparent 96%, transparent 100%);
}

.shop-layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: var(--space-6);
	align-items: start;
}

.shop-sidebar {
	position: sticky;
	top: 24px;
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	padding: 24px;
}
.sidebar-block { margin-bottom: 28px; }
.sidebar-block:last-child { margin-bottom: 0; }
.sidebar-block h4 {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-sm);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-soft);
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--card-border);
}
.cat-list {
	list-style: none;
	margin: 0; padding: 0;
}
.cat-list li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 9px 0;
	cursor: pointer;
	font-size: var(--text-sm);
	color: var(--text-soft);
	transition: color var(--duration-sm) var(--ease), padding-left var(--duration-sm) var(--ease);
	border-bottom: 1px solid rgba(35,39,44,0.5);
}
.cat-list li:last-child { border-bottom: none; }
.cat-list li:hover {
	color: var(--green);
	padding-left: 4px;
}
.cat-list li.active {
	color: var(--green);
	font-weight: 600;
}
.cat-list li.active::before {
	content: '';
	width: 3px;
	height: 16px;
	background: var(--green);
	margin-right: 8px;
	margin-left: -4px;
	flex-shrink: 0;
}
.cat-list .cat-num {
	font-size: var(--text-xs);
	color: var(--text-dim);
	font-weight: 500;
}

.price-range {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	font-size: var(--text-sm);
	color: var(--text-mute);
}
.price-input-row {
	display: flex;
	gap: var(--space-2);
}
.price-input {
	flex: 1;
	padding: 8px 10px;
	background: rgba(22,24,27,0.6);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-sm);
	color: var(--text);
	font-size: var(--text-sm);
	outline: none;
}
.price-input:focus { border-color: var(--green); }

.brand-checks {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.brand-checks label {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	cursor: pointer;
	font-size: var(--text-sm);
	color: var(--text-soft);
	transition: color var(--duration-sm) var(--ease);
}
.brand-checks label:hover { color: var(--green); }
.brand-checks input[type="checkbox"] {
	appearance: none;
	width: 16px; height: 16px;
	border: 1px solid #3a3f44; /* heller als --card-border, damit Checkbox auf dunkler Sidebar erkennbar bleibt */
	border-radius: var(--radius-sm);
	background: rgba(22,24,27,0.6);
	cursor: pointer;
	display: grid;
	place-items: center;
	flex-shrink: 0;
}
.brand-checks input[type="checkbox"]:checked {
	background: var(--green);
	border-color: var(--green);
}
.brand-checks input[type="checkbox"]:checked::after {
	content: '';
	width: 9px; height: 5px;
	border-left: 2px solid var(--text);
	border-bottom: 2px solid var(--text);
	transform: rotate(-45deg) translate(1px,-1px);
}

.sidebar-cta {
	width: 100%;
	justify-content: center;
	padding: 12px 16px;
	font-size: var(--text-sm);
	margin-top: 4px;
}

.shop-main {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}
.shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	padding: 14px 18px;
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	flex-wrap: wrap;
}
.shop-results {
	font-size: var(--text-sm);
	color: var(--text-mute);
}
.shop-results b { color: var(--text); font-weight: 700; }
.shop-sort {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: var(--text-sm);
	color: var(--text-mute);
}
.shop-sort select {
	background: rgba(22,24,27,0.7);
	color: var(--text);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-sm);
	padding: 8px 28px 8px 12px;
	font-family: inherit;
	font-size: var(--text-sm);
	cursor: pointer;
	outline: none;
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23ffffff80'><path d='M7 10l5 5 5-5z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 6px center;
}
.shop-sort select:focus { border-color: var(--green); }

.product-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-5);
}

.product-card {
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform var(--duration-md) var(--ease), border-color var(--duration-md) var(--ease), box-shadow var(--duration-md) var(--ease);
	cursor: pointer;
	position: relative;
}
.product-card:hover {
	transform: translateY(-4px);
	border-color: var(--green);
	box-shadow: var(--shadow-glow);
}
.product-image {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: linear-gradient(180deg, #1a1d20 0%, var(--bg-raised) 100%); /* einmaliger Highlight-Stop für Produktbild-Fallback */
}
.product-image img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform var(--duration-lg) var(--ease);
}
.product-card:hover .product-image img { transform: scale(1.06); }

.product-tags {
	position: absolute;
	top: 14px; left: 14px;
	display: flex;
	gap: var(--space-2);
	z-index: 2;
}
.product-tag {
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text);
	padding: 5px 9px;
	border-radius: var(--radius-sm);
	background: var(--green);
}
.product-tag.dark {
	background: rgba(12,13,15,0.85);
	border: 1px solid var(--border-soft);
	backdrop-filter: blur(6px);
}

.product-quickadd {
	position: absolute;
	bottom: 14px; right: 14px;
	width: 40px; height: 40px;
	border-radius: var(--radius-md);
	background: var(--green);
	border: none;
	color: var(--text);
	cursor: pointer;
	display: grid;
	place-items: center;
	opacity: 0;
	transform: translateY(8px);
	box-shadow: inset 0 1px 0 var(--inner-highlight);
	transition: opacity var(--duration-md) var(--ease), transform var(--duration-md) var(--ease), background-color var(--duration-sm) var(--ease);
	z-index: 2;
}
.product-card:hover .product-quickadd {
	opacity: 1;
	transform: translateY(0);
}
.product-quickadd:hover { background: var(--green-bright); }
.product-quickadd svg { width: 18px; height: 18px; fill: currentColor; }

.product-body {
	padding: 18px 20px 20px;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.product-brand {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--text-mute);
	margin-bottom: 6px;
}
.product-name {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-md);
	font-weight: 600;
	line-height: 24px;
	color: var(--text);
	margin-bottom: 12px;
	flex: 1;
}
.product-footer {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--space-3);
	padding-top: 14px;
	border-top: 1px solid rgba(35,39,44,0.7);
}
.product-price {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-lg);
	font-weight: 700;
	color: var(--text);
	line-height: 1;
}
.product-unit {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-xs);
	font-weight: 400;
	color: var(--text-mute);
	margin-top: 4px;
	display: block;
}

.shop-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	margin-top: 1.5em;
}
.shop-pagination button {
	width: 38px; height: 38px;
	border-radius: var(--radius-sm);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	color: var(--text-soft);
	font-family: inherit;
	font-size: var(--text-sm);
	font-weight: 600;
	cursor: pointer;
	transition: border-color var(--duration-sm) var(--ease), color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease);
}
.shop-pagination button:hover:not(.active) {
	border-color: var(--green);
	color: var(--text);
}
.shop-pagination button.active,
.shop-pagination button.active:hover {
	background: var(--green);
	border-color: var(--green);
	color: var(--text);
}

/* ============ MARKEN ============ */
.marken {
	position: relative;
	margin-bottom: 5em;
	padding: 12em 0;
	background-size: cover;
	background-position: center center;
	-webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 6%, #000 12%, #000 88%, rgba(0,0,0,0.6) 94%, transparent 100%);
	mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 6%, #000 12%, #000 88%, rgba(0,0,0,0.6) 94%, transparent 100%);
}
.marken::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.55) 100%);
	pointer-events: none;
}
.marken > .container { position: relative; z-index: 2; }

.marken-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}
.brand-card {
	border-radius: var(--radius-lg);
	background: rgba(12,13,15,0.92);
	border: 1px solid var(--card-border);
	display: grid;
	grid-template-columns: 1fr 2fr 1fr;
	align-items: center;
	transition: transform var(--duration-md) var(--ease), border-color var(--duration-md) var(--ease), box-shadow var(--duration-md) var(--ease);
	backdrop-filter: blur(4px);
	color: var(--text);
	text-decoration: none;
	cursor: pointer;
}
.brand-card:hover {
	transform: translateY(-3px);
	border-color: var(--green);
	box-shadow: var(--shadow-glow);
	color: var(--text);
}
.brand-card-cta .btn {
	pointer-events: none; /* Klick gehört der ganzen Karte */
}
.brand-card-logo {
	padding: 2em;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 150px;                 /* feste Höhe → alle Logo-Zellen exakt gleich */
}
/* Fester, für alle identischer Logo-Slot (220×84). Jedes Logo wird per
   object-fit:contain eingepasst — Seitenverhältnis bleibt, der SLOT ist
   konstant, daher wirken alle Karten gleich (eine Höhe, eingepasst). */
.brand-card-logo img {
	width: 220px;
	height: 84px;
	max-width: 100%;
	object-fit: contain;
	object-position: center;
}
.brand-card-text {
	padding: 2em;
	display: flex;
	flex-direction: column;
}
.brand-card-text h2,
.brand-card-text h3 {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-lg);
	font-weight: 700;
	line-height: 24px;
	color: var(--text);
	margin: 0;
}
.brand-card-text p {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	font-weight: 400;
	line-height: 24px;
	color: var(--text);
	margin-top: 8px;
}
.brand-card-cta {
	padding: 2em;
	display: flex;
	justify-content: center;
}

.marken-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	margin-top: 2em;
	position: relative;
	z-index: 3;
}
.marken-pagination button {
	min-width: 32px;
	height: 32px;
	padding: 0 8px;
	border-radius: var(--radius-sm);
	background: rgba(12,13,15,0.85);
	border: 1px solid var(--card-border);
	color: var(--text-soft);
	font-family: inherit;
	font-size: var(--text-sm);
	font-weight: 600;
	cursor: pointer;
	transition: border-color var(--duration-sm) var(--ease), color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease);
}
.marken-pagination button:hover:not(:disabled):not(.active) {
	border-color: var(--green);
	color: var(--text);
}
.marken-pagination button.active,
.marken-pagination button.active:hover {
	background: var(--green);
	border-color: var(--green);
	color: var(--text);
}
.marken-pagination button:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

/* ============ GESCHENKE ============ */
.geschenke {
	position: relative;
	padding: 4em 0;
}
.gift-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-6);
}
.gift-card {
	position: relative;
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	overflow: hidden;
	min-height: 320px;
	display: flex;
	align-items: flex-end;
	cursor: pointer;
	transition: transform var(--duration-md) var(--ease), border-color var(--duration-md) var(--ease);
}
.gift-card:hover {
	transform: translateY(-3px);
	border-color: var(--green);
}
.gift-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform var(--duration-lg) var(--ease);
	background-image: var(--gift-bg, none);
}
.gift-card:hover::before { transform: scale(1.04); }
.gift-content {
	position: relative;
	padding: 32px;
	z-index: 2;
	width: 100%;
}
.gift-eyebrow {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--text-mute);
	margin-bottom: 10px;
	display: block;
}
.gift-card h3 {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-2xl);
	font-weight: 700;
	line-height: 34px;
	color: var(--text);
	margin-bottom: 12px;
	max-width: 80%;
}
.gift-card p {
	font-size: var(--text-sm);
	line-height: 22px;
	color: var(--text-soft);
	margin-bottom: 20px;
	max-width: 90%;
}
.gift-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
}
.gift-price {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-md);
	font-weight: 700;
	color: var(--text);
}
.gift-price small {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-xs);
	font-weight: 400;
	color: var(--text-mute);
	margin-right: 4px;
}
.gift-link {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--green);
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	transition: gap var(--duration-sm) var(--ease);
}
.gift-card:hover .gift-link { gap: var(--space-3); }
.gift-link svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 2; }

/* ============ VOR ORT ============ */
.vor-ort {
	position: relative;
	margin-bottom: 8em;
	padding: 6em 0 11em;
	-webkit-mask-image: linear-gradient(to bottom, transparent 0%, transparent 4%, #000 10%, #000 90%, transparent 96%, transparent 100%);
	mask-image: linear-gradient(to bottom, transparent 0%, transparent 4%, #000 10%, #000 90%, transparent 96%, transparent 100%);
}
.vor-ort-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-6);
}
.vor-ort-text {
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	padding: 2em;
}
.vor-ort-text p {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	line-height: 24px;
	color: var(--text);
	margin-bottom: 1em;
}
.vor-ort-text p:last-child { margin-bottom: 0; }

.vor-ort-image {
	border-radius: var(--radius-lg);
	border: 1px solid var(--card-border);
	background-size: cover;
	background-position: center center;
	min-height: 400px;
}

/* ============ STORY ============ */
.story {
	position: relative;
	margin-bottom: 13em;
	padding: 8em 0 14em;
	display: flex;
	flex-direction: column;
	justify-content: center;
	background-size: cover;
	background-position: center center;
	-webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 6%, #000 12%, #000 88%, rgba(0,0,0,0.6) 94%, transparent 100%);
	mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 6%, #000 12%, #000 88%, rgba(0,0,0,0.6) 94%, transparent 100%);
}
.story::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: linear-gradient(90deg, rgba(0,0,0,0.82) 9%, rgba(22,24,27,0.61) 100%);
	pointer-events: none;
}
.story > .container { position: relative; z-index: 2; }

.story h2 {
	width: 60%;
	max-width: 60%;
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-3xl);
	font-weight: 700;
	line-height: 42px;
	color: var(--text);
}
.story-text {
	width: 73%;
	max-width: 73%;
	margin-top: 8px;
}
.story-text p {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	font-weight: 400;
	line-height: 24px;
	color: var(--text);
	margin-bottom: 1em;
}
.story-text p:last-child { margin-bottom: 0; }

/* ============ TEXT-BLOCK (Impressum, Datenschutz, AGB, …) ============ */
.text-section {
	position: relative;
}
.text-section--pt-s { padding-top: 2em; }
.text-section--pt-m { padding-top: 4em; }
.text-section--pt-l { padding-top: 6em; }
.text-section--pb-s { padding-bottom: 2em; }
.text-section--pb-m { padding-bottom: 4em; }
.text-section--pb-l { padding-bottom: 6em; }

.thmw-text {
	color: var(--text);
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-base);
	line-height: 26px;
}
.thmw-text--card {
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-lg);
	padding: 2em;
}
.thmw-text--narrow {
	max-width: 80ch;
}

.thmw-text > *:first-child { margin-top: 0; }
.thmw-text > *:last-child  { margin-bottom: 0; }

.thmw-text p {
	color: var(--text-soft);
	font-size: var(--text-base);
	line-height: 26px;
	margin: 0 0 1em;
}
.thmw-text strong, .thmw-text b { color: var(--text); font-weight: 700; }
/* Links in allen redaktionellen Rich-Text-Bereichen einheitlich
   unterstrichen: Text-Block-Widget, Single-Marke-Content, WP-Seiten. */
.thmw-text a,
.thmw-marke__content a,
.thmw-page-content a {
	color: var(--green);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
	transition: color var(--duration-sm) var(--ease);
}
.thmw-text a:hover,
.thmw-marke__content a:hover,
.thmw-page-content a:hover { color: var(--text); }

.thmw-text h1, .thmw-text h2, .thmw-text h3,
.thmw-text h4, .thmw-text h5, .thmw-text h6 {
	font-family: 'Roboto Serif', serif;
	color: var(--text);
	font-weight: 700;
	line-height: 1.25;
	margin: 1.5em 0 .5em;
}
.thmw-text h1 { font-size: var(--text-2xl); }
.thmw-text h2 { font-size: var(--text-xl); }
.thmw-text h3 { font-size: var(--text-lg); }
.thmw-text h4 { font-size: var(--text-md); }
.thmw-text h5 { font-size: var(--text-base); letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-soft); }
.thmw-text h6 { font-size: var(--text-sm); letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute); }
.thmw-text > h1:first-child,
.thmw-text > h2:first-child,
.thmw-text > h3:first-child { margin-top: 0; }

.thmw-text ul, .thmw-text ol {
	color: var(--text-soft);
	margin: 0 0 1em;
	padding-left: 1.4em;
}
.thmw-text ul li, .thmw-text ol li {
	margin-bottom: 0.4em;
	line-height: 1.55;
}
.thmw-text ul li::marker { color: var(--text-mute); }

.thmw-text blockquote {
	margin: 1.5em 0;
	padding: 1em 1.25em;
	border-left: 3px solid var(--green);
	background: var(--green-tint-low);
	border-radius: 0 8px 8px 0;
	color: var(--text-soft);
	font-style: italic;
}

.thmw-text hr {
	border: 0;
	border-top: 1px solid var(--card-border);
	margin: 2em 0;
}

.thmw-text table {
	width: 100%;
	border-collapse: collapse;
	margin: 1em 0;
	font-size: var(--text-sm);
}
.thmw-text th, .thmw-text td {
	border: 1px solid var(--card-border);
	padding: 10px 14px;
	text-align: left;
	vertical-align: top;
}
.thmw-text th {
	background: rgba(255,255,255,0.03);
	color: var(--text);
	font-weight: 600;
}

.thmw-text code, .thmw-text pre {
	font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
	background: var(--surface-soft);
	color: var(--text);
	border-radius: var(--radius-sm);
}
.thmw-text code { padding: 2px 6px; font-size: .9em; }
.thmw-text pre  { padding: 1em; overflow-x: auto; line-height: 1.5; margin: 1em 0; }

@media (max-width: 767px) {
	.thmw-text--card { padding: 1.5em; }
	.thmw-text h1 { font-size: var(--text-xl); }
	.thmw-text h2 { font-size: var(--text-lg); }
	.thmw-text h3 { font-size: var(--text-md); }
}

/* ============ ANFAHRT ============ */
.anfahrt {
	position: relative;
	padding: 6em 0;
	-webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 4%, #000 10%, #000 100%);
	mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.6) 4%, #000 10%, #000 100%);
}
.anfahrt-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-6);
}
.anfahrt-text {
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	padding: 2em;
}
.anfahrt-text p {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-md);
	line-height: 24px;
	color: var(--text);
	margin-bottom: 0.6em;
}
.anfahrt-text p b { color: var(--text); font-weight: 700; }
.anfahrt-text .heading-p { margin-top: 1.2em; font-weight: 700; }
.anfahrt-text .heading-p:first-child { margin-top: 0; }

.anfahrt-map {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	min-height: 561px;
}
/* Loading-Hintergrund im Theme-Look — nur sichtbar während .is-loading. */
.anfahrt-map::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(400px 280px at 50% 45%, var(--green-tint-low), transparent 70%),
		var(--bg-deep);
	opacity: 0;
	transition: opacity var(--duration-md) var(--ease);
	pointer-events: none;
	z-index: 1;
}
/* Spinner + Text — signalisiert klar „lädt" statt nur dunkler Kasten. */
.anfahrt-map::after {
	content: 'Karte wird geladen …';
	position: absolute;
	left: 0; right: 0;
	top: calc(50% + 28px);
	text-align: center;
	font-size: var(--text-sm);
	color: var(--text-mute);
	letter-spacing: 0.04em;
	opacity: 0;
	transition: opacity var(--duration-md) var(--ease);
	pointer-events: none;
	z-index: 2;
}
.anfahrt-map.is-loading::before,
.anfahrt-map.is-loading::after { opacity: 1; }
/* CSS-Spinner, zentriert, nur im Loading-State */
.anfahrt-map.is-loading .anfahrt-map__spinner {
	position: absolute;
	top: 50%; left: 50%;
	width: 36px; height: 36px;
	margin: -34px 0 0 -18px;
	border: 3px solid var(--card-border);
	border-top-color: var(--green);
	border-radius: var(--radius-pill);
	animation: thmw-spin 0.8s linear infinite;
	z-index: 2;
}
@keyframes thmw-spin { to { transform: rotate(360deg); } }

.anfahrt-map iframe {
	position: relative;
	width: 100%;
	height: 561px;
	border: 0;
	display: block;
	z-index: 0;
	opacity: 1;
	transition: opacity var(--duration-md) var(--ease);
}
.anfahrt-map.is-loading iframe { opacity: 0; }

/* ============ FOOTER ============ */
.site-footer {
	padding: 4em 0 2em;
}
.site-footer--shop { border-top: 1px solid var(--card-border); }
.footer-grid {
	max-width: var(--container-width);
	margin: 0 auto 3em;
	padding: 0 var(--container-gutter);
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 3em;
}
.footer-brand p {
	margin-top: 20px;
	font-size: var(--text-sm);
	line-height: 22px;
	color: var(--text-mute);
	max-width: 320px;
}
.footer-col h5 {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-base);
	font-weight: 700;
	color: var(--text);
	margin: 0 0 18px;
}
.footer-col ul {
	list-style: none;
	padding: 0; margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.footer-col a {
	font-size: var(--text-sm);
	color: var(--text-mute);
	transition: color var(--duration-sm) var(--ease);
}
.footer-col a:hover { color: var(--green); }

.footer-bottom {
	max-width: var(--container-width);
	margin: 0 auto;
	padding: 24px var(--container-gutter) 0;
	border-top: 1px solid var(--card-border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-5);
	flex-wrap: wrap;
	font-size: var(--text-sm);
	color: var(--text-mute);
}
.footer-bottom a { color: inherit; }
.footer-bottom a:hover { color: var(--green); }
.payment-icons {
	display: flex;
	gap: var(--space-2);
	align-items: center;
}
.payment-icons span {
	padding: 4px 10px;
	background: var(--bg-raised-hover);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-sm);
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--text-mute);
	letter-spacing: 0.04em;
}

/* Schlanker Footer (Shop deaktiviert) – nur eine Zeile in Inhaltsbreite */
.site-footer--simple { padding: 0; border: 0; }
.site-footer--simple .footer-simple__bottom {
	border-top: 1px solid var(--card-border);
	padding: 18px var(--container-gutter);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-4);
	flex-wrap: wrap;
	font-size: var(--text-sm);
	color: var(--text-mute);
}
.footer-simple__legal { display: inline-flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; }
/* wp_nav_menu gibt <li> aus — Listenpunkte/Margins killen */
.footer-simple__legal ul,
.footer-simple__legal li { list-style: none; margin: 0; padding: 0; display: contents; }
.footer-simple__legal a { color: inherit; transition: color var(--duration-sm) var(--ease); }
.footer-simple__legal a:hover { color: var(--green); }
@media (max-width: 640px) {
	.site-footer--simple .footer-simple__bottom { flex-direction: column; gap: var(--space-2); text-align: center; }
}

/* ============ 404 ============ */
.thmw-404 {
	position: relative;
	padding: 6em 0 7em;
	overflow: hidden;
}
.thmw-404::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(800px 500px at 50% 20%, var(--green-tint-high), transparent 70%);
	pointer-events: none;
	z-index: 0;
}
.thmw-404__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.thmw-404__eyebrow {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--text-mute);
	margin-bottom: 12px;
}
.thmw-404__big {
	font-family: 'Roboto Serif', serif;
	font-weight: 800;
	font-size: clamp(120px, 22vw, 280px);
	line-height: 0.9;
	letter-spacing: -0.04em;
	background: linear-gradient(180deg, var(--text) 0%, rgba(255,255,255,0.35) 60%, rgba(255,255,255,0.05) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	margin-bottom: 14px;
	user-select: none;
}
.thmw-404__title {
	font-family: 'Roboto Serif', serif;
	font-size: clamp(28px, 3vw + 1rem, 44px);
	line-height: 1.15;
	font-weight: 700;
	color: var(--text);
	margin: 0 0 14px;
	max-width: 22ch;
}
.thmw-404__lead {
	font-size: var(--text-md);
	line-height: 26px;
	color: var(--text-soft);
	max-width: 56ch;
	margin: 0 0 28px;
}
.thmw-404__cta {
	display: flex;
	gap: var(--space-3);
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: var(--space-8);
}
.thmw-404__search {
	width: 100%;
	max-width: 520px;
	display: flex;
	align-items: center;
	gap: var(--space-3);
	padding: 8px 8px 8px 16px;
	background: rgba(12,13,15,0.7);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-lg);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	margin-bottom: var(--space-8);
	transition: border-color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease);
}
.thmw-404__search:focus-within {
	border-color: var(--green);
	background: rgba(12,13,15,0.9);
}
.thmw-404__search svg {
	width: 18px; height: 18px;
	fill: var(--text-mute);
	flex-shrink: 0;
}
.thmw-404__search input {
	flex: 1;
	min-width: 0;
	background: transparent;
	border: 0;
	outline: 0;
	color: var(--text);
	font-family: inherit;
	font-size: var(--text-sm);
	padding: 8px 0;
}
.thmw-404__search input::placeholder { color: var(--text-dim); }
.thmw-404__search .btn {
	padding: 10px 18px;
	font-size: var(--text-sm);
	flex-shrink: 0;
}
.thmw-404__suggest { width: 100%; }
.thmw-404__suggest-title {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-md);
	font-weight: 600;
	color: var(--text-mute);
	margin-bottom: 18px;
}
.thmw-404__suggest-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-5);
}
.thmw-404__suggest-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-3);
	padding: 1.5em 1.25em;
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	color: var(--text);
	transition: transform var(--duration-sm) var(--ease), border-color var(--duration-sm) var(--ease), box-shadow var(--duration-sm) var(--ease);
	text-decoration: none;
}
.thmw-404__suggest-card:hover {
	transform: translateY(-3px);
	border-color: var(--green);
	box-shadow: var(--shadow-glow);
	color: var(--text);
}
.thmw-404__suggest-logo {
	display: grid;
	place-items: center;
	width: 100%;
	height: 64px;
}
.thmw-404__suggest-logo img {
	max-height: 56px;
	max-width: 100%;
	width: auto;
	object-fit: contain;
}
.thmw-404__suggest-name {
	font-family: 'Roboto Serif', serif;
	font-size: var(--text-base);
	font-weight: 700;
}
.thmw-404__suggest-slogan {
	font-size: var(--text-xs);
	color: var(--text-mute);
	letter-spacing: 0.04em;
}
@media (max-width: 767px) {
	.thmw-404 { padding: 4em 0 5em; }
	.thmw-404__suggest-grid { grid-template-columns: 1fr; }
	.thmw-404__search { flex-direction: column; gap: var(--space-2); padding: 12px; }
	.thmw-404__search .btn { width: 100%; justify-content: center; }
}

/* =========================================================
   SINGLE / ARCHIVE / SOCIAL-ICONS
   ========================================================= */
.thmw-single, .thmw-archive {
	padding: 4em 0 6em;
}
.thmw-page-title { color: var(--text); font-family: 'Roboto Serif', serif; font-size: var(--text-3xl); line-height: 42px; }

/* ============ SINGLE MARKE ============ */
.thmw-marke__head {
	display: grid;
	grid-template-columns: 340px 1fr;
	gap: 3em;
	padding: 2.5em;
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	align-items: center;
	position: relative;
	overflow: hidden;
}
/* Subtle grüner Vignette-Hot-Spot im Header — gibt der Marke Identität ohne Bild */
.thmw-marke__head::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(600px 400px at 15% 20%, var(--green-tint-low), transparent 60%);
	pointer-events: none;
	z-index: 0;
}
.thmw-marke__head > * { position: relative; z-index: 1; }

.thmw-marke__logo {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 220px;
	padding: var(--space-5);
	background: var(--bg-raised);
	border-radius: var(--radius-md);
	border: 1px solid var(--card-border);
}
.thmw-marke__logo img {
	max-height: 200px;
	width: auto;
	max-width: 100%;
	object-fit: contain;
}
.thmw-marke__eyebrow {
	font-family: 'Roboto', sans-serif;
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--text-mute);
	margin-bottom: var(--space-3);
}
.thmw-marke__title {
	font-family: 'Roboto Serif', serif;
	font-size: clamp(1.75rem, 1.5vw + 1.25rem, 2.5rem);  /* fluid 28 ↔ 40 px */
	line-height: var(--leading-tight);
	color: var(--text);
	font-weight: 700;
	margin: 0 0 var(--space-4);
}
.thmw-marke__desc {
	font-size: var(--text-md);
	line-height: var(--leading-base);
	color: var(--text-soft);
	margin-bottom: var(--space-5);
}
.thmw-marke__themen {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-bottom: var(--space-5);
}
.thmw-chip {
	display: inline-flex;
	align-items: center;
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.04em;
	color: var(--text-soft);
	background: var(--green-tint-low);
	border: 1px solid var(--green-tint-high);
	text-decoration: none;
	transition: background var(--duration-sm) var(--ease), color var(--duration-sm) var(--ease);
}
.thmw-chip:hover {
	background: var(--green-tint-mid);
	color: var(--text);
}

.thmw-marke__cta { margin-top: var(--space-5); }

.thmw-marke__content {
	margin-top: var(--space-7);
	padding: 2.5em;
	border-radius: var(--radius-lg);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	color: var(--text);
	width: 100%;
	max-width: none;
}
.thmw-marke__content p,
.thmw-marke__content li {
	font-size: var(--text-md);
	line-height: var(--leading-base);
	color: var(--text-soft);
}
.thmw-marke__content > *:first-child { margin-top: 0; }
.thmw-marke__content > *:last-child  { margin-bottom: 0; }
.thmw-marke__content h2,
.thmw-marke__content h3 {
	font-family: 'Roboto Serif', serif;
	color: var(--text);
	margin-top: 1.4em;
	margin-bottom: .4em;
}
.thmw-marke__content h2 { font-size: var(--text-2xl); }
.thmw-marke__content h3 { font-size: var(--text-xl); }

.thmw-marke__nav {
	margin-top: var(--space-7);
	display: flex;
	justify-content: space-between;
	gap: var(--space-4);
	flex-wrap: wrap;
	font-size: var(--text-sm);
	color: var(--text-mute);
}
.thmw-marke__nav a {
	color: var(--text-soft);
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 10px 16px;
	border-radius: var(--radius-md);
	background: var(--bg-deep);
	border: 1px solid var(--card-border);
	transition: border-color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease), color var(--duration-sm) var(--ease);
}
.thmw-marke__nav a:hover {
	color: var(--text);
	border-color: var(--green);
	background: var(--green-tint-low);
}
/* "Alle Marken"-Anker in der Mitte, optisch akzentuiert.
   Doppel-Class-Selektor für höhere Spezifität (überschreibt .thmw-marke__nav a). */
.thmw-marke__nav .thmw-marke__nav-archive {
	font-weight: 600;
	color: var(--green);
}
.thmw-marke__nav .thmw-marke__nav-archive:hover {
	color: var(--text);
	background: var(--green);
	border-color: var(--green);
}

/* Social-Icons */
.thmw-socials {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-bottom: 1.25em;
}
.thmw-social {
	display: inline-grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border-radius: var(--radius-md);
	background: rgba(12,13,15,0.8);
	border: 1px solid var(--card-border);
	color: var(--text);
	transition: transform var(--duration-sm) var(--ease), border-color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease), color var(--duration-sm) var(--ease);
}
.thmw-social svg { width: 20px; height: 20px; display: block; }
.thmw-social:hover {
	transform: translateY(-2px);
	border-color: var(--green);
	background: var(--green-tint-high);
	color: var(--text);
}

/* Markenwelt-Stil auf Marken-Übersicht: Social-Icons in Brand-Card */
.thmw-brand-card-socials {
	display: flex;
	gap: var(--space-2);
	margin-top: 8px;
}
.thmw-brand-card-socials .thmw-social {
	width: 32px; height: 32px;
}
.thmw-brand-card-socials .thmw-social svg { width: 14px; height: 14px; }

@media (max-width: 767px) {
	.thmw-marke__head { grid-template-columns: 1fr; padding: 1.5em; }
	.thmw-marke__logo { min-height: 140px; }
	.thmw-marke__title { font-size: var(--text-2xl); }
}

/* =========================================================
   RESPONSIVE BREAKPOINTS
   ≥1200  · Desktop Large (Default)
   ≤1200  · Desktop Small
   ≤1024  · Tablet (Burger erscheint, Sidebar fällt unter Main)
   ≤767   · Mobile
   ≤480   · Sehr klein
   ========================================================= */

/* ----- ≤1200 ----- */
@media (max-width: 1200px) {
	.product-grid { grid-template-columns: repeat(2, 1fr); }
	.search-box { width: 180px; }
	.header-inner { gap: var(--space-5); }
	.brand-name { font-size: var(--text-md); }
}

/* ----- ≤1024 (Tablet) ----- */
@media (max-width: 1024px) {
	/* Header: Burger statt Inline-Nav, Burger rechts */
	.header-nav { display: none; }
	.menu-toggle { display: inline-flex; align-items: center; justify-content: center; margin-left: auto; }
	.search-box { display: none; }
	.cart-btn span:not(.cart-count) { display: none; }
	.cart-btn { padding: 0 14px; }
	.icon-btn { width: 40px; height: 40px; }
	/* "Im Laden besuchen"-Button auf Mobile/Tablet ausblenden */
	.header-actions__visit { display: none; }

	/* Sektions-Masken deaktivieren – auf kürzeren Sektionen
	   würden 10–12 % Fade-Zone die Headlines anschneiden */
	.themenwelt, .shop, .marken, .vor-ort, .story, .anfahrt {
		-webkit-mask-image: none;
		mask-image: none;
	}
	/* Hero-Mask kann subtiler bleiben */
	.hero {
		-webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 90%, transparent 100%);
		mask-image: linear-gradient(to bottom, #000 0%, #000 90%, transparent 100%);
	}

	/* Fullscreen-Overlay-Menü */
	/* Brand-Block im Overlay: aktiviert wenn .header-nav.open
	   (Default-Versteckung steht oben global bei .header-nav__brand) */
	.header-nav.open .header-nav__brand {
		display: flex;
		align-items: center;
		gap: var(--space-3);
		margin-bottom: var(--space-7);
		text-decoration: none;
		opacity: 0;
		transform: translateY(-8px);
		animation: thmw-nav-item-in var(--duration-md) var(--ease) forwards;
	}
	.header-nav.open .header-nav__brand .brand-logo {
		width: 56px; height: 56px; flex-shrink: 0;
	}
	.header-nav.open .header-nav__brand .brand-logo img {
		width: 100%; height: 100%; object-fit: contain;
	}
	.header-nav.open .header-nav__brand .brand-name {
		font-family: 'Roboto Serif', serif;
		font-size: var(--text-md);
		font-weight: 700;
		color: var(--text);
	}

	.header-nav.open {
		display: flex;
		position: fixed;
		inset: 0;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		/* Dunkler & richer: solid + grüne Vignette im Zentrum */
		background:
			radial-gradient(800px 600px at 50% 35%, rgba(0, 127, 0, 0.10), transparent 70%),
			var(--bg-deep);
		-webkit-backdrop-filter: saturate(140%) blur(20px);
		backdrop-filter: saturate(140%) blur(20px);
		padding: 80px var(--container-gutter) 40px;
		z-index: var(--z-overlay);
		animation: thmw-overlay-in var(--duration-sm) ease-out both;
	}
	.header-nav.open .nav-list {
		flex-direction: column;
		gap: var(--space-1);
		width: 100%;
		max-width: 380px;
		text-align: center;
	}
	/* Stagger-Entry pro Item — eleganter Aufbau statt alles auf einmal. */
	.header-nav.open .nav-list li {
		opacity: 0;
		transform: translateY(10px);
		animation: thmw-nav-item-in var(--duration-md) var(--ease) forwards;
	}
	.header-nav.open .nav-list li:nth-child(1) { animation-delay: 0.06s; }
	.header-nav.open .nav-list li:nth-child(2) { animation-delay: 0.12s; }
	.header-nav.open .nav-list li:nth-child(3) { animation-delay: 0.18s; }
	.header-nav.open .nav-list li:nth-child(4) { animation-delay: 0.24s; }
	.header-nav.open .nav-list li:nth-child(5) { animation-delay: 0.30s; }
	.header-nav.open .nav-list li:nth-child(6) { animation-delay: 0.36s; }
	.header-nav.open .nav-list li:nth-child(7) { animation-delay: 0.42s; }
	.header-nav.open .nav-list li:nth-child(8) { animation-delay: 0.48s; }
	.header-nav.open .nav-list a {
		display: block;
		padding: 16px 20px;
		font-family: 'Roboto Serif', serif;
		font-size: var(--text-2xl);                    /* 28px statt 24 — mehr Präsenz */
		font-weight: 600;
		border-radius: var(--radius-md);               /* konsistent mit Desktop-Nav */
		border-bottom: 1px solid rgba(255, 255, 255, 0.06);
		transition: color var(--duration-sm) var(--ease), background var(--duration-sm) var(--ease);
	}
	.header-nav.open .nav-list a:hover {
		color: var(--green);
		background: var(--green-tint-low);
	}
	/* Active-State im Overlay: prominenter grüner Akzent */
	.header-nav.open .nav-list .is-active > a,
	.header-nav.open .nav-list a.is-active,
	.header-nav.open .nav-list .current-menu-item > a,
	.header-nav.open .nav-list .current-menu-parent > a,
	.header-nav.open .nav-list .current-menu-ancestor > a,
	.header-nav.open .nav-list .current_page_item > a,
	.header-nav.open .nav-list .current-page-ancestor > a {
		color: var(--green);
		background: var(--green-tint-mid);
	}
	.header-nav.open .nav-list li:last-child a { border-bottom: 0; }
	/* (Pill-Style aus Desktop wird im Overlay automatisch geerbt — keine separaten ::after-Regeln nötig) */

	/* Hero / Sektionen: weniger negative Margins → keine Überlappungen */
	.hero { min-height: 640px; padding: 5em 0 3em; }
	.hero .container { padding-top: 5em; }
	/* hero h1 nutzt clamp() — kein BP-Override mehr nötig */
	.hero p.lead { width: 70%; max-width: 70%; font-size: var(--text-md); }

	.section-head h2 { font-size: var(--text-2xl); line-height: 36px; }
	.section-head .subtitle { width: 70%; max-width: 70%; font-size: var(--text-base); }
	.section-head-with-link { gap: var(--space-4); }
	.section-icon svg { width: 34px; height: 34px; }

	.themenwelt { padding: 4em 0 10em; }
	.card-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
	.card-image { height: 200px; }

	.shop { padding: 4em 0 6em; }
	.shop-layout { grid-template-columns: 1fr; }
	.shop-sidebar { position: static; }

	.marken { padding: 9em 0 4em; }
	.brand-card { grid-template-columns: 1fr; text-align: center; }
	.brand-card-logo { justify-content: center; padding: 2em 2em 0; height: 130px; }
	.brand-card-text { padding: 1.5em 2em; }
	.brand-card-text p { max-width: 60ch; margin-left: auto; margin-right: auto; }
	.brand-card-cta { padding: 0 2em 2em; }

	.story { padding: 7em 0 10em; }
	.story h2, .story-text { width: 80%; max-width: 80%; }

	.anfahrt { padding: 4em 0; }
	.anfahrt-map iframe { height: 460px; }

	.footer-grid { grid-template-columns: 1fr 1fr; gap: var(--space-6); }

	/* Single-Marke: Logo links / Text rechts wird einspaltig */
	.thmw-marke__head { grid-template-columns: 1fr; gap: var(--space-5); padding: 1.75em; }
	.thmw-marke__logo { min-height: 160px; }

	/* 404 Suggest: 3 Spalten → 2 */
	.thmw-404__suggest-grid { grid-template-columns: repeat(2, 1fr); }
}
@keyframes thmw-overlay-in {
	from { opacity: 0; transform: scale(0.98); }
	to   { opacity: 1; transform: scale(1); }
}
@keyframes thmw-nav-item-in {
	to { opacity: 1; transform: translateY(0); }
}

/* ----- ≤767 (Mobile) ----- */
@media (max-width: 767px) {
	html { scroll-padding-top: 80px; }

	/* Container-Gutter folgt jetzt --container-gutter (auto 22px @767) */
	.header-inner { gap: var(--space-3); }
	.site-footer--simple .footer-simple__bottom { padding: 14px var(--container-gutter); }
	.brand-logo { width: 48px; height: 48px; }
	.brand-name { font-size: var(--text-sm); }
	.icon-btn { width: 38px; height: 38px; }
	.cart-btn { height: 38px; padding: 0 10px; gap: var(--space-2); }
	.menu-toggle { padding: 6px; }
	.menu-toggle svg { width: 26px; height: 26px; }

	/* Header: auf Mobile IMMER solider dunkler Hintergrund
	   (kein Glass-Effekt am Seitenanfang, sonst überlagern
	    Logo/Burger das Hero-Bild) */
	.site-header::before {
		opacity: 1;
		background-color: var(--bg-deep);
		-webkit-backdrop-filter: none;
		backdrop-filter: none;
	}
	.site-header.is-scrolled {
		border-bottom-color: var(--card-border);
	}

	/* Hero komplett kompakt – kein Negativ-Overlap mit dem Header */
	.hero {
		min-height: auto;
		margin-top: 0;
		padding: 3em 0;
	}
	/* Mobile-Overlay: oben kräftig für Headline-Lesbarkeit, mehr Atemraum
	   in der Mitte, unten leichte Resttönung. Sanfterer Range als vorher. */
	.hero::before {
		background-image: linear-gradient(180deg,
			rgba(12, 13, 15, 0.85) 0%,
			rgba(12, 13, 15, 0.75) 30%,
			rgba(12, 13, 15, 0.55) 70%,
			rgba(12, 13, 15, 0.35) 100%);
	}
	.hero .container { padding-top: 3em; }
	/* hero h1 nutzt clamp() — kein BP-Override mehr nötig */
	.hero p.lead { width: 100%; max-width: 100%; font-size: var(--text-base); line-height: 24px; }
	.hero-cta { gap: var(--space-3); }
	.hero-cta .btn { width: 100%; justify-content: center; padding: 13px 20px; font-size: var(--text-base); }

	/* Logo-Slider */
	.logo-section { padding: 16px 0; }
	.logo-slider { padding: 12px 6px; }
	.logo-track { gap: var(--space-6); }

	/* Section-Heading */
	.section-head { margin-bottom: 1.5em; }
	.section-head-row { gap: var(--space-3); }
	.section-icon svg { width: 28px; height: 28px; }
	.section-head h2 { font-size: var(--text-xl); line-height: 30px; }
	.section-head .subtitle { width: 100%; max-width: 100%; font-size: var(--text-base); line-height: 24px; }
	.section-head-with-link { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
	.view-all-link { font-size: var(--text-sm); }

	/* Themenwelt */
	.themenwelt { padding: 3em 0 7em; }
	.card-grid { grid-template-columns: 1fr; gap: var(--space-4); }
	.card-image { height: 200px; }
	.card-body { padding: 1.5em; }
	.card-body h3 { font-size: var(--text-md); line-height: 22px; }
	.card-body p { font-size: var(--text-base); line-height: 22px; }

	/* Shop */
	.shop { padding: 3em 0 5em; }
	.shop-layout { gap: var(--space-5); }
	.shop-sidebar { padding: 18px; }
	.shop-toolbar { padding: 12px 14px; gap: var(--space-3); }
	.shop-toolbar .shop-results { font-size: var(--text-sm); }
	.shop-sort { font-size: var(--text-sm); gap: var(--space-2); }
	.product-grid { grid-template-columns: 1fr; gap: var(--space-4); }
	.shop-pagination button { width: 36px; height: 36px; font-size: var(--text-sm); }

	/* Marken */
	.marken { padding: 6em 0 3em; margin-bottom: 3em; }
	.brand-card-logo { padding: 1.5em 1.5em 0; height: 120px; }
	.brand-card-logo img { width: 200px; height: 72px; max-width: 100%; object-fit: contain; }
	.brand-card-text { padding: 1em 1.5em; }
	.brand-card-text h3 { font-size: var(--text-md); line-height: 22px; }
	.brand-card-text p { font-size: var(--text-base); line-height: 22px; }
	.brand-card-cta { padding: 0 1.5em 1.5em; }
	.brand-card-cta .btn { width: 100%; justify-content: center; }
	.marken-pagination { flex-wrap: wrap; }
	.marken-pagination button { width: 36px; height: 36px; font-size: var(--text-sm); }

	/* Geschenke */
	.geschenke { padding: 2.5em 0; }
	.gift-grid { grid-template-columns: 1fr; gap: var(--space-5); }
	.gift-card { min-height: 260px; }
	.gift-content { padding: 22px; }
	.gift-card h3 { font-size: var(--text-xl); line-height: 28px; max-width: 100%; }
	.gift-card p { font-size: var(--text-base); line-height: 22px; max-width: 100%; }
	.gift-bottom { flex-direction: column; align-items: flex-start; gap: var(--space-3); }

	/* Vor-Ort */
	.vor-ort { padding: 3em 0 6em; margin-bottom: 3em; }
	.vor-ort-grid { grid-template-columns: 1fr; gap: var(--space-5); }
	.vor-ort-text { padding: 1.5em; }
	.vor-ort-text p { font-size: var(--text-base); line-height: 22px; }
	.vor-ort-image { min-height: 220px; }

	/* Story */
	.story { padding: 5em 0 7em; margin-bottom: 4em; }
	.story h2 { width: 100%; max-width: 100%; font-size: var(--text-xl); line-height: 30px; }
	.story-text { width: 100%; max-width: 100%; }
	.story-text p { font-size: var(--text-base); line-height: 22px; }

	/* Anfahrt */
	.anfahrt { padding: 3em 0 4em; }
	.anfahrt-grid { grid-template-columns: 1fr; gap: var(--space-5); }
	.anfahrt-text { padding: 1.5em; }
	.anfahrt-text p { font-size: var(--text-base); line-height: 22px; }
	.anfahrt-map iframe { height: 320px; }

	/* Footer (Gutter via --container-gutter) */
	.site-footer { padding: 3em 0 1.5em; }
	.footer-grid { grid-template-columns: 1fr; gap: 1.75em; }
	.footer-bottom {
		flex-direction: column; align-items: flex-start; gap: var(--space-3);
		padding: 18px var(--container-gutter) 0;
	}
	.payment-icons { flex-wrap: wrap; }
	.site-footer--simple .footer-simple__bottom {
		flex-direction: column;
		gap: var(--space-2);
		text-align: center;
	}
	.footer-simple__legal { gap: var(--space-3); }

	/* Single Marke */
	.thmw-marke__head { padding: 1.25em; gap: var(--space-5); }
	.thmw-marke__logo { min-height: 130px; padding: .75em; }
	.thmw-marke__logo img { max-height: 110px; }
	.thmw-marke__title { font-size: var(--text-2xl); }
	.thmw-marke__desc { font-size: var(--text-base); line-height: 22px; }
	.thmw-marke__content { padding: 1.5em; margin-top: 1.5em; }
	.thmw-marke__content p, .thmw-marke__content li { font-size: var(--text-base); }

	/* 404 */
	.thmw-404 { padding: 3em 0 4em; }
	.thmw-404__big { font-size: clamp(96px, 28vw, 180px); }
	.thmw-404__title { font-size: var(--text-2xl); line-height: 32px; }
	.thmw-404__lead { font-size: var(--text-base); line-height: 22px; }
	.thmw-404__cta { width: 100%; flex-direction: column; }
	.thmw-404__cta .btn { width: 100%; justify-content: center; }
	.thmw-404__suggest-grid { grid-template-columns: 1fr; }
}

/* ----- ≤480 (sehr klein) ----- */
@media (max-width: 480px) {
	.brand-name { display: none; }   /* nur Logo */
	.cart-count { padding: 1px 6px; font-size: var(--text-xs); }

	/* hero h1 nutzt clamp() — kein BP-Override mehr nötig */
	.section-head h2 { font-size: var(--text-lg); line-height: 26px; }

	.gift-card { min-height: 240px; }
	.gift-card h3 { font-size: var(--text-md); line-height: 24px; }

	.shop-pagination button { width: 32px; height: 32px; }
	.marken-pagination button { width: 32px; height: 32px; min-width: 32px; padding: 0 6px; }

	.thmw-marke__title { font-size: var(--text-xl); }
	.thmw-404__big { font-size: clamp(80px, 26vw, 140px); }
}

/* ----- Hover deaktivieren auf Touch-Geräten ----- */
@media (hover: none) {
	.card:hover { transform: none; box-shadow: none; }
	.brand-card:hover { transform: none; }
	.product-card:hover { transform: none; box-shadow: none; }
	.gift-card:hover { transform: none; }
	.thmw-404__suggest-card:hover { transform: none; box-shadow: none; }
	.logo-chip:hover img { filter: grayscale(1) contrast(1.05) opacity(0.85); transform: none; }
}
