/*
Theme Name: Astra Child - Mähroboter Shop
Theme URI: https://wpastra.com/
Template: astra
Author: Brainstorm Force
Author URI: https://wpastra.com/about/
Description: Astra Child Theme für einen deutschen Mähroboter-Onlineshop (WooCommerce). Enthält Ankündigungsleiste, Sticky-Header, Hero-Video, Produkt-, Vorteils- und Testimonial-Bereiche sowie einen erweiterten Footer mit Newsletter.
Tags: custom-menu,custom-logo,e-commerce,custom-colors,translation-ready
Version: 1.0.0
Text Domain: astra-child
*/

/* ==========================================================================
   0. DESIGN TOKENS
   ========================================================================== */

:root {
	--mr-color-primary: #2d5a27;
	--mr-color-primary-dark: #1f3f1c;
	--mr-color-primary-light: #e6efe5;
	--mr-color-accent: #f5b942;
	--mr-color-white: #ffffff;
	--mr-color-light-gray: #f5f6f4;
	--mr-color-gray: #6b7280;
	--mr-color-border: #e3e6e1;
	--mr-color-text: #20271f;
	--mr-color-sale: #dc3545;

	--mr-font-heading: 'Poppins', sans-serif;
	--mr-font-body: 'Inter', sans-serif;

	--mr-radius: 10px;
	--mr-shadow: 0 10px 30px rgba(45, 90, 39, 0.08);
	--mr-container: 1280px;

	--mr-announcement-height: 40px;
	--mr-header-height: 84px;
}

/* ==========================================================================
   1. BASE / RESET
   ========================================================================== */

body {
	font-family: var(--mr-font-body);
	color: var(--mr-color-text);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--mr-font-heading);
	color: var(--mr-color-primary-dark);
	font-weight: 600;
}

a {
	transition: color 0.2s ease, background-color 0.2s ease, opacity 0.2s ease;
}

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

/* Astra's .ast-container is a flex row (for sidebar layouts). Our homepage
   template has no #primary/#secondary columns, so force it back to a normal
   block so the sections stack full-width instead of sitting side by side. */
body.page-template-template-homepage-php .ast-container {
	display: block;
	max-width: none;
	padding: 0;
}

/* Same as above, for the custom shop / product archive template
   (woocommerce/archive-product.php). */
body.woocommerce-shop .ast-container,
body.tax-product_cat .ast-container,
body.tax-product_tag .ast-container,
body.tax-product_attribute .ast-container {
	display: block;
	max-width: none;
	padding: 0;
}

/* Same as above, for the custom single post template (single.php). */
body.single-post .ast-container {
	display: block;
	max-width: none;
	padding: 0;
}

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

.mr-section {
	padding: 80px 0;
}

.mr-section-header {
	text-align: center;
	max-width: 680px;
	margin: 0 auto 48px;
}

.mr-section-header .mr-eyebrow {
	display: inline-block;
	color: var(--mr-color-primary);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 13px;
	margin-bottom: 12px;
}

.mr-section-header h2 {
	font-size: clamp(28px, 4vw, 40px);
	margin: 0 0 12px;
}

.mr-section-header p {
	color: var(--mr-color-gray);
	font-size: 17px;
	line-height: 1.7;
	margin: 0;
}

.mr-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 32px;
	border-radius: var(--mr-radius);
	font-weight: 600;
	font-size: 15px;
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	font-family: var(--mr-font-body);
}

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

.mr-btn-primary:hover {
	background-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
}

.mr-btn-outline {
	background-color: transparent;
	border-color: var(--mr-color-white);
	color: var(--mr-color-white);
}

.mr-btn-outline:hover {
	background-color: var(--mr-color-white);
	color: var(--mr-color-primary-dark);
}

.mr-btn-secondary {
	background-color: var(--mr-color-white);
	color: var(--mr-color-primary-dark);
	border-color: var(--mr-color-border);
}

.mr-btn-secondary:hover {
	border-color: var(--mr-color-primary);
	color: var(--mr-color-primary);
}

/* ==========================================================================
   2. ANKÜNDIGUNGSLEISTE (ANNOUNCEMENT BAR)
   ========================================================================== */

.mr-announcement-bar {
	background-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
	overflow: hidden;
	height: var(--mr-announcement-height);
	display: flex;
	align-items: center;
	position: relative;
}

.mr-announcement-bar a {
	color: var(--mr-color-white);
}

.mr-announcement-track {
	display: flex;
	align-items: center;
	white-space: nowrap;
	animation: mr-marquee 28s linear infinite;
	will-change: transform;
}

.mr-announcement-bar:hover .mr-announcement-track {
	animation-play-state: paused;
}

.mr-announcement-track span {
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.02em;
	padding: 0 40px;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.mr-announcement-track span::before {
	content: '🌱';
	font-size: 14px;
}

@keyframes mr-marquee {
	0% { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
	.mr-announcement-track {
		animation: none;
	}
}

/* ==========================================================================
   3. STICKY HEADER
   ========================================================================== */

.mr-header {
	position: sticky;
	top: 0;
	z-index: 999;
	background-color: var(--mr-color-white);
	border-bottom: 1px solid var(--mr-color-border);
}

.mr-header-inner {
	max-width: var(--mr-container);
	margin: 0 auto;
	padding: 0 24px;
	height: var(--mr-header-height);
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 24px;
	transition: height 0.25s ease;
}

.mr-header.is-stuck .mr-header-inner {
	height: 64px;
	box-shadow: var(--mr-shadow);
}

/* Logo */
.mr-header-logo {
	display: flex;
	align-items: center;
	justify-self: start;
}

.mr-header-logo img {
	max-height: 48px;
	width: auto;
	transition: max-height 0.25s ease;
}

.mr-header.is-stuck .mr-header-logo img {
	max-height: 38px;
}

.mr-header-logo .mr-logo-text {
	font-family: var(--mr-font-heading);
	font-size: 22px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
	text-decoration: none;
	white-space: nowrap;
}

.mr-header-logo .mr-logo-text span {
	color: var(--mr-color-primary);
}

/* Navigation (centre) */
.mr-header-nav {
	justify-self: center;
}

.mr-menu {
	display: flex;
	align-items: center;
	gap: 32px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mr-menu li a {
	color: var(--mr-color-text);
	text-decoration: none;
	font-weight: 500;
	font-size: 15px;
	padding: 8px 0;
	position: relative;
}

.mr-menu li a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 2px;
	background-color: var(--mr-color-primary);
	transition: width 0.2s ease;
}

.mr-menu li a:hover,
.mr-menu li.current-menu-item a {
	color: var(--mr-color-primary);
}

.mr-menu li a:hover::after,
.mr-menu li.current-menu-item a::after {
	width: 100%;
}

.mr-menu li.menu-item-has-children {
	position: relative;
}

.mr-menu .sub-menu {
	list-style: none;
	margin: 0;
	padding: 12px;
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--mr-color-white);
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	box-shadow: var(--mr-shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: all 0.2s ease;
	z-index: 10;
}

.mr-menu li.menu-item-has-children:hover .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.mr-menu .sub-menu li a {
	display: block;
	padding: 8px 12px;
	border-radius: 6px;
	font-size: 14px;
}

.mr-menu .sub-menu li a:hover {
	background-color: var(--mr-color-light-gray);
}

.mr-menu .sub-menu li a::after {
	display: none;
}

/* Icônes (droite) */
.mr-header-icons {
	display: flex;
	align-items: center;
	gap: 18px;
	justify-self: end;
}

.mr-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	color: var(--mr-color-primary-dark);
	background: transparent;
	border: none;
	cursor: pointer;
	position: relative;
	text-decoration: none;
	padding: 0;
}

.mr-icon-btn:hover {
	background-color: var(--mr-color-light-gray);
	color: var(--mr-color-primary);
}

.mr-icon-btn svg {
	width: 22px;
	height: 22px;
	stroke: currentColor;
	fill: none;
}

.mr-cart-count {
	position: absolute;
	top: 0;
	right: 0;
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	font-size: 11px;
	font-weight: 700;
	min-width: 18px;
	height: 18px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	padding: 0 4px;
}

/* Search overlay */
.mr-search-form {
	position: absolute;
	top: 100%;
	right: 0;
	left: 0;
	background: var(--mr-color-white);
	border-bottom: 1px solid var(--mr-color-border);
	box-shadow: var(--mr-shadow);
	padding: 20px 24px;
	display: none;
}

.mr-search-form.is-open {
	display: block;
}

.mr-search-form form {
	max-width: var(--mr-container);
	margin: 0 auto;
	display: flex;
	gap: 12px;
}

.mr-search-form input[type="search"] {
	flex: 1;
	padding: 12px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	font-size: 15px;
}

/* Mobile menu toggle */
.mr-menu-toggle {
	display: none;
	width: 40px;
	height: 40px;
	border: none;
	background: transparent;
	cursor: pointer;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	padding: 0;
}

.mr-menu-toggle span {
	display: block;
	width: 22px;
	height: 2px;
	background-color: var(--mr-color-primary-dark);
	transition: all 0.25s ease;
}

.mr-header.is-menu-open .mr-menu-toggle span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.mr-header.is-menu-open .mr-menu-toggle span:nth-child(2) {
	opacity: 0;
}

.mr-header.is-menu-open .mr-menu-toggle span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ==========================================================================
   4. HERO SECTION (VIDEO)
   ========================================================================== */

.mr-hero {
	position: relative;
	min-height: calc(100vh - var(--mr-header-height) - var(--mr-announcement-height));
	overflow: hidden;
	background-color: var(--mr-color-primary-dark);
}

.mr-hero-slides {
	position: absolute;
	inset: 0;
}

.mr-hero-slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	background-size: cover;
	background-position: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 1.2s ease;
	z-index: 0;
}

.mr-hero-slide.is-active {
	opacity: 1;
	visibility: visible;
	z-index: 1;
}

.mr-hero-media {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}

.mr-hero-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(15, 31, 13, 0) 45%, rgba(15, 31, 13, 0.75) 100%),
		linear-gradient(90deg, rgba(15, 31, 13, 0.55) 0%, rgba(15, 31, 13, 0) 60%);
	z-index: 1;
}

.mr-hero-content {
	position: relative;
	z-index: 2;
	text-align: left;
	max-width: 780px;
	padding: 0 24px 80px;
	color: var(--mr-color-white);
}

.mr-hero-content .mr-eyebrow {
	display: block;
	color: var(--mr-color-white);
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 16px;
}

.mr-hero-content h1 {
	color: var(--mr-color-white);
	font-size: clamp(32px, 5.5vw, 60px);
	font-weight: 800;
	line-height: 1.12;
	margin: 0 0 20px;
}

.mr-hero-content p {
	font-size: clamp(16px, 2vw, 19px);
	line-height: 1.7;
	margin: 0 0 36px;
	color: rgba(255, 255, 255, 0.9);
	max-width: 520px;
}

.mr-hero-actions {
	display: flex;
	gap: 16px;
	justify-content: flex-start;
	flex-wrap: wrap;
}

.mr-hero-actions .mr-btn-primary {
	background-color: var(--mr-color-white);
	color: var(--mr-color-primary-dark);
}

.mr-hero-actions .mr-btn-primary:hover {
	background-color: var(--mr-color-accent);
	color: var(--mr-color-primary-dark);
}

.mr-hero-dots {
	position: absolute;
	right: 32px;
	bottom: 40px;
	z-index: 3;
	display: flex;
	gap: 10px;
}

.mr-hero-dot {
	width: 40px;
	height: 40px;
	padding: 0;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.5);
	background-color: rgba(255, 255, 255, 0.08);
	color: var(--mr-color-white);
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.mr-hero-dot:hover,
.mr-hero-dot.is-active {
	background-color: var(--mr-color-white);
	color: var(--mr-color-primary-dark);
	border-color: var(--mr-color-white);
}

.mr-hero-scroll {
	position: absolute;
	bottom: 28px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	color: var(--mr-color-white);
	opacity: 0.8;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	animation: mr-bounce 2.4s ease-in-out infinite;
}

@keyframes mr-bounce {
	0%, 100% { transform: translate(-50%, 0); }
	50% { transform: translate(-50%, 8px); }
}

/* ==========================================================================
   5. FEATURED PRODUCTS
   ========================================================================== */

.mr-products {
	background-color: var(--mr-color-white);
}

.mr-products-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 24px;
	margin-bottom: 40px;
}

.mr-products-heading .mr-eyebrow {
	display: inline-block;
	color: var(--mr-color-primary);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 13px;
	margin-bottom: 12px;
}

.mr-products-heading h2 {
	font-size: clamp(28px, 4vw, 40px);
	margin: 0;
}

.mr-products-viewall {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding-bottom: 6px;
	font-weight: 600;
	font-size: 15px;
	color: var(--mr-color-primary-dark);
	text-decoration: none;
	white-space: nowrap;
}

.mr-products-viewall svg {
	transition: transform 0.2s ease;
}

.mr-products-viewall:hover {
	color: var(--mr-color-primary);
}

.mr-products-viewall:hover svg {
	transform: translateX(4px);
}

.mr-products-track {
	display: flex;
	gap: 24px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 4px;
	cursor: grab;
}

.mr-products-track.is-dragging {
	scroll-snap-type: none;
	scroll-behavior: auto;
	cursor: grabbing;
	user-select: none;
}

.mr-products-track.is-dragging .mr-product-card {
	pointer-events: none;
}

.mr-products-track::-webkit-scrollbar {
	display: none;
}

.mr-product-card {
	flex: 0 0 calc((100% - 24px * 4) / 5);
	scroll-snap-align: start;
	display: flex;
	flex-direction: column;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	overflow: hidden;
	background-color: var(--mr-color-white);
	color: inherit;
	text-decoration: none;
	transition: box-shadow 0.25s ease, transform 0.25s ease;
	position: relative;
}

.mr-product-card:hover {
	box-shadow: var(--mr-shadow);
	transform: translateY(-4px);
}

.mr-product-card-link {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.mr-product-badges {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 2;
	display: flex;
	gap: 8px;
}

.mr-product-badge {
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	font-size: 12px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
}

.mr-product-badge--stock {
	background-color: var(--mr-color-text);
}

.mr-product-image {
	position: relative;
	aspect-ratio: 1 / 1;
	background-color: var(--mr-color-light-gray);
	overflow: hidden;
}

.mr-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.mr-product-card:hover .mr-product-image img {
	transform: scale(1.05);
}

.mr-product-quickadd {
	position: absolute;
	right: 12px;
	bottom: 12px;
	z-index: 3;
	width: 44px;
	height: 44px;
}

.mr-product-quickadd-btn {
	position: absolute !important;
	inset: 0 !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100% !important;
	height: 100% !important;
	min-width: 0 !important;
	min-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	border-radius: 50%;
	background-color: var(--mr-color-primary-dark) !important;
	color: transparent !important;
	font-size: 0 !important;
	line-height: 0 !important;
	box-shadow: var(--mr-shadow);
	opacity: 0;
	transform: translateY(10px) scale(0.9);
	transition: opacity 0.25s ease, transform 0.25s ease, background-color 0.2s ease;
	cursor: pointer;
}

.mr-product-card:hover .mr-product-quickadd-btn,
.mr-product-quickadd-btn:focus-visible,
.mr-product-quickadd-btn.added {
	opacity: 1;
	transform: translateY(0) scale(1);
}

.mr-product-quickadd-btn:hover,
.mr-product-quickadd-btn.added {
	background-color: var(--mr-color-primary) !important;
}

.mr-product-quickadd-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: var(--mr-color-white);
	pointer-events: none;
}

.mr-product-quickadd-btn.loading .mr-product-quickadd-icon {
	animation: mr-spin 0.7s linear infinite;
}

.mr-product-quickadd .added_to_cart {
	display: none;
}

@keyframes mr-spin {
	to {
		transform: translate(-50%, -50%) rotate(360deg);
	}
}

@media (hover: none) {
	.mr-product-quickadd-btn {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.mr-product-body {
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1;
}

.mr-product-title {
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
	margin: 0;
	color: var(--mr-color-text);
}

.mr-product-card:hover .mr-product-title {
	color: var(--mr-color-primary);
}

.mr-product-price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	font-size: 15px;
	font-weight: 700;
	color: var(--mr-color-text);
}

.mr-product-price ins {
	order: -1;
	color: var(--mr-color-sale);
	text-decoration: none;
}

.mr-product-price del {
	color: var(--mr-color-gray);
	font-weight: 400;
	font-size: 12.5px;
	text-decoration: line-through;
}

.mr-product-stock {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 11.5px;
	color: var(--mr-color-primary);
	margin-top: auto;
}

.mr-product-stock.is-outofstock {
	color: var(--mr-color-gray);
}

.mr-products-controls {
	display: flex;
	align-items: center;
	gap: 24px;
	margin-top: 32px;
}

.mr-products-progress {
	position: relative;
	flex: 1;
	height: 2px;
	background-color: var(--mr-color-border);
	border-radius: 999px;
	overflow: hidden;
}

.mr-products-progress-bar {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 25%;
	background-color: var(--mr-color-primary-dark);
	border-radius: 999px;
	transition: transform 0.2s ease, width 0.2s ease;
}

.mr-products-arrows {
	display: flex;
	gap: 10px;
	flex-shrink: 0;
}

.mr-products-arrow {
	width: 44px;
	height: 44px;
	padding: 0;
	border-radius: 50%;
	border: 1px solid var(--mr-color-border);
	background-color: var(--mr-color-white);
	color: var(--mr-color-text);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.mr-products-arrow:hover {
	background-color: var(--mr-color-primary-dark);
	border-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
}

.mr-products-arrow:disabled {
	opacity: 0.35;
	cursor: default;
}

.mr-products-arrow:disabled:hover {
	background-color: var(--mr-color-white);
	border-color: var(--mr-color-border);
	color: var(--mr-color-text);
}

.mr-products-empty {
	text-align: center;
	color: var(--mr-color-gray);
	padding: 40px 0;
}

/* ==========================================================================
   5b. VIDEO SHOWCASE
   ========================================================================== */

.mr-video-showcase {
	position: relative;
	height: 90vh;
	min-height: 480px;
	max-height: 900px;
	overflow: hidden;
	background-color: var(--mr-color-text);
	background-size: cover;
	background-position: center;
}

.mr-video-showcase-media {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (max-width: 768px) {
	.mr-video-showcase {
		height: 60vh;
		min-height: 320px;
	}
}

/* ==========================================================================
   6. VORTEILE / ADVANTAGES
   ========================================================================== */

.mr-advantages {
	position: relative;
	overflow: hidden;
	background-color: var(--mr-color-light-gray);
}

.mr-advantages::before,
.mr-advantages::after {
	content: '';
	position: absolute;
	width: 360px;
	height: 360px;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, var(--mr-color-primary-light), transparent 70%);
	pointer-events: none;
}

.mr-advantages::before {
	top: -160px;
	right: -120px;
}

.mr-advantages::after {
	bottom: -180px;
	left: -140px;
}

.mr-advantages .mr-container {
	position: relative;
	z-index: 1;
}

.mr-advantages-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
	counter-reset: mr-advantage;
}

.mr-advantage-card {
	position: relative;
	overflow: hidden;
	background-color: var(--mr-color-white);
	border-radius: var(--mr-radius);
	padding: 40px 28px 32px;
	text-align: center;
	border: 1px solid var(--mr-color-border);
	counter-increment: mr-advantage;
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.mr-advantage-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--mr-color-primary), var(--mr-color-accent));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.35s ease;
}

.mr-advantage-card::after {
	content: counter(mr-advantage, decimal-leading-zero);
	position: absolute;
	top: 16px;
	right: 20px;
	font-family: var(--mr-font-heading);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.05em;
	color: var(--mr-color-border);
}

.mr-advantage-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--mr-shadow);
	border-color: transparent;
}

.mr-advantage-card:hover::before {
	transform: scaleX(1);
}

.mr-advantage-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 68px;
	height: 68px;
	margin: 0 auto 22px;
	border-radius: 50%;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
	transition: background-color 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.mr-advantage-card:hover .mr-advantage-icon {
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	transform: scale(1.08) rotate(-6deg);
}

.mr-advantage-icon svg {
	width: 30px;
	height: 30px;
	stroke: currentColor;
	fill: none;
	stroke-width: 1.8;
}

.mr-advantage-card h3 {
	font-size: 18px;
	margin: 0 0 10px;
}

.mr-advantage-card p {
	font-size: 14.5px;
	line-height: 1.7;
	color: var(--mr-color-gray);
	margin: 0;
}

/* ==========================================================================
   7. TESTIMONIALS
   ========================================================================== */

.mr-testimonials {
	background-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
}

.mr-testimonials .mr-section-header h2,
.mr-testimonials .mr-section-header .mr-eyebrow {
	color: var(--mr-color-white);
}

.mr-testimonials .mr-section-header p {
	color: rgba(255, 255, 255, 0.75);
}

.mr-testimonials-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

.mr-testimonial-card {
	background-color: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--mr-radius);
	padding: 32px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.mr-testimonial-stars {
	color: var(--mr-color-accent);
	letter-spacing: 3px;
	font-size: 16px;
}

.mr-testimonial-text {
	font-size: 15.5px;
	line-height: 1.8;
	color: rgba(255, 255, 255, 0.9);
	margin: 0;
	flex: 1;
}

.mr-testimonial-author {
	display: flex;
	align-items: center;
	gap: 14px;
}

.mr-testimonial-avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 16px;
	flex-shrink: 0;
}

.mr-testimonial-author strong {
	display: block;
	font-size: 15px;
	color: var(--mr-color-white);
}

.mr-testimonial-author span {
	display: block;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.6);
}

/* ==========================================================================
   8. CTA BAND
   ========================================================================== */

.mr-cta {
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	text-align: center;
}

.mr-cta h2 {
	color: var(--mr-color-white);
	font-size: clamp(26px, 4vw, 36px);
	margin: 0 0 16px;
}

.mr-cta p {
	color: rgba(255, 255, 255, 0.85);
	max-width: 600px;
	margin: 0 auto 32px;
	font-size: 16px;
	line-height: 1.7;
}

/* ==========================================================================
   9. FOOTER
   ========================================================================== */

.mr-footer {
	background-color: var(--mr-color-primary-dark);
	color: rgba(255, 255, 255, 0.85);
}

/* Newsletter band */
.mr-footer-newsletter {
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	padding: 56px 0;
}

.mr-footer-newsletter-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
}

.mr-footer-newsletter-text h3 {
	color: var(--mr-color-white);
	font-size: 24px;
	margin: 0 0 8px;
}

.mr-footer-newsletter-text p {
	margin: 0;
	color: rgba(255, 255, 255, 0.7);
	max-width: 480px;
	line-height: 1.6;
	font-size: 14.5px;
}

.mr-newsletter-form {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	flex: 0 0 auto;
	width: 100%;
	max-width: 460px;
}

.mr-newsletter-form input[type="email"] {
	flex: 1;
	min-width: 220px;
	padding: 14px 18px;
	border-radius: var(--mr-radius);
	border: 1px solid rgba(255, 255, 255, 0.2);
	background-color: rgba(255, 255, 255, 0.06);
	color: var(--mr-color-white);
	font-size: 15px;
}

.mr-newsletter-form input[type="email"]::placeholder {
	color: rgba(255, 255, 255, 0.5);
}

.mr-newsletter-form button {
	background-color: var(--mr-color-accent);
	color: var(--mr-color-primary-dark);
	border: none;
}

.mr-newsletter-form button:hover {
	opacity: 0.9;
}

.mr-newsletter-message {
	width: 100%;
	font-size: 13.5px;
	margin-top: 8px;
}

.mr-newsletter-message.is-success {
	color: #9ee6a0;
}

.mr-newsletter-message.is-error {
	color: #f3a3a3;
}

/* Footer columns */
.mr-footer-columns {
	padding: 56px 0;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
	gap: 40px;
}

.mr-footer-col h4 {
	color: var(--mr-color-white);
	font-size: 16px;
	margin: 0 0 20px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.mr-footer-col p {
	font-size: 14px;
	line-height: 1.8;
	margin: 0 0 16px;
	color: rgba(255, 255, 255, 0.7);
}

.mr-footer-col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.mr-footer-col ul a {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
	font-size: 14px;
}

.mr-footer-col ul a:hover {
	color: var(--mr-color-white);
}

.mr-footer-brand .mr-logo-text {
	font-family: var(--mr-font-heading);
	font-size: 22px;
	font-weight: 700;
	color: var(--mr-color-white);
	text-decoration: none;
	display: inline-block;
	margin-bottom: 16px;
}

.mr-footer-brand .mr-logo-text span {
	color: var(--mr-color-accent);
}

.mr-footer-contact li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.7);
}

.mr-footer-contact li svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	margin-top: 2px;
	stroke: var(--mr-color-accent);
	fill: none;
}

.mr-footer-contact li a {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
}

.mr-footer-contact li a:hover {
	color: var(--mr-color-white);
}

.mr-social-icons {
	display: flex;
	gap: 12px;
	margin-top: 20px;
}

.mr-social-icons a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.08);
	color: var(--mr-color-white);
	transition: background-color 0.2s ease;
}

.mr-social-icons a:hover {
	background-color: var(--mr-color-primary);
}

.mr-social-icons svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

/* Bottom bar */
.mr-footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding: 24px 0;
}

.mr-footer-bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.mr-footer-bottom p {
	margin: 0;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.55);
}

.mr-footer-legal-menu {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 0;
	padding: 0;
}

.mr-footer-legal-menu a {
	color: rgba(255, 255, 255, 0.6);
	text-decoration: none;
	font-size: 13px;
}

.mr-footer-legal-menu a:hover {
	color: var(--mr-color-white);
}

/* ==========================================================================
   9b. SHOP PAGE (PRODUCT ARCHIVE)
   ========================================================================== */

/*
 * Astra makes .ast-container a row flexbox on single page templates,
 * which places the shop grid and the info bar side by side instead of
 * stacking them. Restore block stacking for the Zubehör page.
 */
.page-template-template-zubehoer .ast-container {
	display: block;
}

.mr-shop {
	padding-top: 48px;
}

.mr-shop-header {
	max-width: 760px;
	margin: 0 auto 40px;
	text-align: center;
}

.mr-shop-header .mr-eyebrow {
	display: inline-block;
	color: var(--mr-color-primary);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 13px;
	margin-bottom: 12px;
}

.mr-shop-title {
	font-size: clamp(28px, 4vw, 40px);
	margin: 0 0 12px;
}

.mr-shop-intro {
	color: var(--mr-color-gray);
	font-size: 16px;
	line-height: 1.7;
	margin: 0;
}

/* ---- Layout: sidebar + grid ------------------------------------------- */

.mr-shop-layout {
	display: grid;
	grid-template-columns: 272px 1fr;
	gap: 40px;
	align-items: start;
}

.mr-shop-sidebar {
	position: sticky;
	top: calc(var(--mr-header-height) + 24px);
}

.mr-shop-filter-toggle {
	display: none;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 14px 18px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
	color: var(--mr-color-text);
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 15px;
	cursor: pointer;
	position: relative;
}

.mr-shop-filter-toggle:hover,
.mr-shop-filter-toggle:focus,
.mr-shop-filter-toggle:focus-visible {
	background-color: var(--mr-color-white) !important;
	border-color: var(--mr-color-primary) !important;
	color: var(--mr-color-text) !important;
	outline: none;
}

.mr-shop-filter-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--mr-color-accent);
	margin-left: auto;
}

/* ---- Filter form -------------------------------------------------------- */

.mr-shop-filters {
	display: flex;
	flex-direction: column;
	padding: 24px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
}

.mr-shop-filters-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--mr-color-text);
	font-size: 17px;
	font-weight: 700;
	padding-bottom: 16px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--mr-color-border);
}

/* ---- Accordion filter groups ------------------------------------------- */

.mr-shop-filter-group {
	border-bottom: 1px solid var(--mr-color-border);
}

.mr-shop-filter-group:last-of-type {
	border-bottom: none;
}

.mr-shop-filter-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 16px 0;
	margin: 0;
	border: none;
	background: none;
	font-family: var(--mr-font-body);
	font-size: 15px;
	font-weight: 700;
	color: var(--mr-color-text);
	text-align: left;
	cursor: pointer;
}

.mr-shop-filter-head:hover,
.mr-shop-filter-head:focus,
.mr-shop-filter-head:focus-visible {
	background-color: transparent !important;
	color: var(--mr-color-text) !important;
	outline: none;
}

.mr-shop-filter-head:hover {
	color: var(--mr-color-primary) !important;
}

.mr-shop-filter-chevron {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	color: var(--mr-color-gray);
	transition: transform 0.2s ease;
}

.mr-shop-filter-group.is-open .mr-shop-filter-chevron {
	transform: rotate(180deg);
}

.mr-shop-filter-body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.25s ease;
}

.mr-shop-filter-group.is-open .mr-shop-filter-body {
	max-height: 420px;
}

.mr-shop-filter-body-inner {
	padding-bottom: 20px;
}

.mr-shop-filter-options {
	display: flex;
	flex-direction: column;
	gap: 10px;
	max-height: 220px;
	overflow-y: auto;
	padding-right: 4px;
}

.mr-shop-checkbox {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--mr-color-text);
	cursor: pointer;
}

.mr-shop-checkbox input {
	width: 16px;
	height: 16px;
	accent-color: var(--mr-color-primary);
	cursor: pointer;
	flex-shrink: 0;
}

.mr-shop-checkbox span {
	flex: 1;
}

.mr-shop-checkbox small {
	color: var(--mr-color-gray);
	font-size: 12px;
}

.mr-shop-price-inputs {
	display: flex;
	align-items: center;
	gap: 10px;
}

.mr-shop-price-inputs label {
	flex: 1;
}

.mr-shop-price-inputs input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	font-family: var(--mr-font-body);
	font-size: 13px;
	color: var(--mr-color-text);
	background-color: var(--mr-color-light-gray);
}

.mr-shop-price-inputs input:focus {
	outline: none;
	border-color: var(--mr-color-primary);
	background-color: var(--mr-color-white);
}

.mr-shop-price-sep {
	color: var(--mr-color-gray);
}

/* ---- Stock toggle switch ------------------------------------------------ */

.mr-shop-filter-group--switch {
	padding: 16px 0;
}

.mr-shop-switch {
	display: flex;
	align-items: center;
	gap: 12px;
	cursor: pointer;
	font-size: 14px;
	color: var(--mr-color-text);
}

.mr-shop-switch input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.mr-shop-switch-track {
	position: relative;
	flex-shrink: 0;
	width: 40px;
	height: 24px;
	border-radius: 999px;
	background-color: var(--mr-color-border);
	transition: background-color 0.2s ease;
}

.mr-shop-switch-track::before {
	content: '';
	position: absolute;
	top: 3px;
	left: 3px;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background-color: var(--mr-color-white);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
	transition: transform 0.2s ease;
}

.mr-shop-switch input:checked + .mr-shop-switch-track {
	background-color: var(--mr-color-primary);
}

.mr-shop-switch input:checked + .mr-shop-switch-track::before {
	transform: translateX(16px);
}

.mr-shop-switch input:focus-visible + .mr-shop-switch-track {
	outline: 2px solid var(--mr-color-primary);
	outline-offset: 2px;
}

/* ---- Filter actions ------------------------------------------------------ */

.mr-shop-filter-actions {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-top: 20px;
}

.mr-shop-filter-actions .mr-btn {
	width: 100%;
	padding: 12px 24px;
}

.mr-shop-filter-reset {
	text-align: center;
	font-size: 13px;
	font-weight: 600;
	color: var(--mr-color-gray);
	text-decoration: underline;
}

.mr-shop-filter-reset:hover {
	color: var(--mr-color-primary);
}

/* ---- Toolbar (result count + sorting) ------------------------------------ */

.mr-shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--mr-color-border);
}

.mr-shop-toolbar .woocommerce-result-count {
	margin: 0;
	color: var(--mr-color-gray);
	font-size: 14px;
}

.mr-shop-toolbar .woocommerce-ordering {
	margin: 0;
}

.mr-shop-toolbar .orderby {
	appearance: none;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	padding: 10px 36px 10px 14px;
	font-family: var(--mr-font-body);
	font-size: 14px;
	color: var(--mr-color-text);
	background-color: var(--mr-color-white);
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 10px center;
	background-size: 18px;
}

.mr-shop-toolbar .orderby:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

.woocommerce-notices-wrapper:empty {
	display: none;
}

/* ---- Product grid ---------------------------------------------------------- */

.mr-shop-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mr-shop-grid-item {
	margin: 0;
}

.mr-shop-grid .mr-product-card {
	height: 100%;
}

/* ---- "No products found" message ------------------------------------------- */

.mr-shop-main .woocommerce-info {
	margin: 0;
	padding: 32px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	color: var(--mr-color-text);
	text-align: center;
	list-style: none;
}

.mr-shop-main .woocommerce-info::before {
	display: none;
}

/* ---- Pagination -------------------------------------------------------------- */

.woocommerce-pagination {
	margin-top: 48px;
}

.woocommerce-pagination .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mr-shop-main .woocommerce-pagination .page-numbers li {
	margin: 0;
	display: flex;
	border: none;
	overflow: visible;
}

.mr-shop-main .woocommerce-pagination .page-numbers a,
.mr-shop-main .woocommerce-pagination .page-numbers span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 6px;
	border: none;
	border-radius: 50%;
	background-color: var(--mr-color-light-gray);
	color: var(--mr-color-text);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.mr-shop-main .woocommerce-pagination .page-numbers a:hover {
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
	transform: translateY(-2px);
}

.mr-shop-main .woocommerce-pagination .page-numbers .current {
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	box-shadow: 0 8px 16px -6px rgba(45, 90, 39, 0.45);
}

.mr-shop-main .woocommerce-pagination .page-numbers .dots {
	background-color: transparent;
	color: var(--mr-color-gray);
}

.mr-shop-main .woocommerce-pagination .page-numbers .prev,
.mr-shop-main .woocommerce-pagination .page-numbers .next {
	background-color: var(--mr-color-white);
	border: 1px solid var(--mr-color-border);
	font-size: 0;
}

.woocommerce-pagination .page-numbers .prev::before,
.woocommerce-pagination .page-numbers .next::before {
	content: '';
	width: 18px;
	height: 18px;
	background-color: var(--mr-color-text);
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3Cpolyline points='12 5 19 12 12 19'/%3E%3C/svg%3E");
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	transition: background-color 0.2s ease;
}

.woocommerce-pagination .page-numbers .prev::before {
	transform: scaleX(-1);
}

.mr-shop-main .woocommerce-pagination .page-numbers .prev:hover,
.mr-shop-main .woocommerce-pagination .page-numbers .next:hover {
	background-color: var(--mr-color-primary);
	border-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	transform: translateY(-2px);
}

.woocommerce-pagination .page-numbers .prev:hover::before,
.woocommerce-pagination .page-numbers .next:hover::before {
	background-color: var(--mr-color-white);
}

/* ==========================================================================
   9c. SHOP INFO BAR
   ========================================================================== */

.mr-shop-infobar {
	margin-top: 24px;
	padding: 64px 0;
	border-top: 1px solid var(--mr-color-border);
	background-color: var(--mr-color-white);
}

.mr-shop-infobar-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
}

.mr-shop-infobar-item {
	text-align: center;
}

.mr-shop-infobar-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	margin: 0 auto 16px;
	border-radius: 50%;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
}

.mr-shop-infobar-item h3 {
	font-size: 16px;
	margin: 0 0 8px;
}

.mr-shop-infobar-item p {
	font-size: 14px;
	line-height: 1.6;
	color: var(--mr-color-gray);
	margin: 0;
}

.mr-shop-infobar-item p a {
	color: var(--mr-color-primary-dark);
	font-weight: 600;
	text-decoration: underline;
}

.mr-shop-infobar-item p a:hover {
	color: var(--mr-color-primary);
}

/* ==========================================================================
   9c. RATGEBER PAGE (GUIDE HUB)
   ========================================================================== */

.page-template-template-ratgeber .ast-container {
	display: block;
}

.mr-ratgeber-topics {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.mr-ratgeber-topic-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 32px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
	text-decoration: none;
	color: var(--mr-color-text);
	transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}

.mr-ratgeber-topic-card:hover {
	box-shadow: var(--mr-shadow);
	transform: translateY(-4px);
	border-color: var(--mr-color-primary-light);
}

.mr-ratgeber-topic-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
}

.mr-ratgeber-topic-card h2 {
	font-size: 19px;
	margin: 0;
}

.mr-ratgeber-topic-card p {
	color: var(--mr-color-gray);
	font-size: 15px;
	line-height: 1.6;
	margin: 0;
	flex: 1;
}

.mr-ratgeber-topic-count {
	font-size: 13px;
	font-weight: 600;
	color: var(--mr-color-primary);
}

.mr-ratgeber-articles {
	background-color: var(--mr-color-light-gray);
}

.mr-ratgeber-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mr-ratgeber-grid-item {
	margin: 0;
}

.mr-article-card {
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	overflow: hidden;
	background-color: var(--mr-color-white);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.mr-article-card:hover {
	box-shadow: var(--mr-shadow);
	transform: translateY(-4px);
}

.mr-article-card-link {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.mr-article-image {
	position: relative;
	aspect-ratio: 16 / 9;
	background-color: var(--mr-color-light-gray);
	overflow: hidden;
}

.mr-article-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.mr-article-card:hover .mr-article-image img {
	transform: scale(1.05);
}

.mr-article-badge {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 2;
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	font-size: 12px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
}

.mr-article-body {
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}

.mr-article-date {
	font-size: 13px;
	color: var(--mr-color-gray);
}

.mr-article-title {
	font-size: 17px;
	font-weight: 600;
	margin: 0;
	color: var(--mr-color-text);
	line-height: 1.4;
}

.mr-article-card:hover .mr-article-title {
	color: var(--mr-color-primary);
}

.mr-article-excerpt {
	color: var(--mr-color-gray);
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
	flex: 1;
}

.mr-article-readmore {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	font-weight: 600;
	color: var(--mr-color-primary);
	margin-top: 4px;
}

/* ==========================================================================
   9d. ÜBER UNS PAGE (ABOUT)
   ========================================================================== */

.page-template-template-ueber-uns .ast-container {
	display: block;
}

.mr-about-header {
	padding-bottom: 0;
}

.mr-about-story-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}

.mr-about-story-image img {
	border-radius: var(--mr-radius);
	box-shadow: var(--mr-shadow);
	width: 100%;
}

.mr-about-story-content .mr-eyebrow {
	display: inline-block;
	color: var(--mr-color-primary);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 13px;
	margin-bottom: 12px;
}

.mr-about-story-content h2 {
	font-size: clamp(26px, 4vw, 36px);
	margin: 0 0 16px;
}

.mr-about-story-content p {
	color: var(--mr-color-gray);
	font-size: 16px;
	line-height: 1.8;
	margin: 0 0 16px;
}

.mr-about-story-content p:last-child {
	margin-bottom: 0;
}

.mr-about-stats {
	background-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
}

.mr-about-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	text-align: center;
}

.mr-about-stat-number {
	font-family: var(--mr-font-heading);
	font-size: clamp(32px, 5vw, 44px);
	font-weight: 700;
	color: var(--mr-color-accent);
	margin: 0 0 8px;
}

.mr-about-stat-label {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.75);
	margin: 0;
}

/* ==========================================================================
   9e. KONTAKT PAGE
   ========================================================================== */

.page-template-template-kontakt .ast-container {
	display: block;
}

.mr-contact-layout {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 32px;
	align-items: start;
}

.mr-contact-form-card {
	background-color: var(--mr-color-white);
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	padding: 40px;
}

.mr-contact-form-card h2 {
	font-size: 22px;
	margin: 0 0 8px;
}

.mr-contact-form-card > p {
	color: var(--mr-color-gray);
	font-size: 15px;
	line-height: 1.7;
	margin: 0 0 28px;
}

.mr-contact-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.mr-form-group {
	margin-bottom: 20px;
}

.mr-form-group label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 8px;
	color: var(--mr-color-text);
}

.mr-form-group input,
.mr-form-group select,
.mr-form-group textarea {
	width: 100%;
	padding: 13px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	font-family: var(--mr-font-body);
	font-size: 15px;
	color: var(--mr-color-text);
	background-color: var(--mr-color-light-gray);
}

.mr-form-group textarea {
	resize: vertical;
	min-height: 140px;
}

.mr-form-group input:focus,
.mr-form-group select:focus,
.mr-form-group textarea:focus {
	outline: none;
	border-color: var(--mr-color-primary);
	background-color: var(--mr-color-white);
}

.mr-contact-message {
	font-size: 14px;
	margin-top: 16px;
}

.mr-contact-message.is-success {
	color: var(--mr-color-primary);
}

.mr-contact-message.is-error {
	color: #c0392b;
}

.mr-contact-info-list {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.mr-contact-info-item {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	background-color: var(--mr-color-white);
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	padding: 24px;
}

.mr-contact-info-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	border-radius: 50%;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
}

.mr-contact-info-icon svg {
	width: 22px;
	height: 22px;
	stroke: currentColor;
	fill: none;
	stroke-width: 1.8;
}

.mr-contact-info-item h3 {
	font-size: 16px;
	margin: 0 0 6px;
}

.mr-contact-info-item p {
	color: var(--mr-color-gray);
	font-size: 14.5px;
	line-height: 1.6;
	margin: 0;
}

.mr-contact-info-item a {
	color: var(--mr-color-gray);
	text-decoration: none;
}

.mr-contact-info-item a:hover {
	color: var(--mr-color-primary);
}

/* ==========================================================================
   9f. EINZELPRODUKTSEITE (SINGLE PRODUCT)
   ========================================================================== */

body.single-product .ast-container {
	max-width: var(--mr-container);
	padding: 0 24px;
}

body.single-product #primary {
	padding: 48px 0 80px;
}

/* ---- Layout: gallery | summary ------------------------------------------ */

.woocommerce div.product {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 56px;
	margin-bottom: 0;
}

.woocommerce div.product div.images,
.woocommerce div.product div.summary {
	width: 100% !important;
	float: none !important;
	margin: 0;
	overflow: hidden;
}

.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .upsells.products,
.woocommerce div.product .related.products {
	grid-column: 1 / -1;
}

/* ---- Gallery -------------------------------------------------------------- */

.woocommerce-product-gallery__wrapper {
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	overflow: hidden;
	background-color: var(--mr-color-light-gray);
}

.woocommerce-product-gallery__image img {
	border-radius: var(--mr-radius);
}

.woocommerce div.product .ast-onsale-card {
	background-color: var(--mr-color-accent) !important;
	color: var(--mr-color-primary-dark) !important;
	font-family: var(--mr-font-body);
	font-weight: 700;
	box-shadow: none;
}

.flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin: 16px 0 0;
	padding: 0;
	list-style: none;
}

.flex-control-thumbs li {
	width: 84px !important;
	height: 84px;
	list-style: none;
}

.flex-control-thumbs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--mr-radius);
	border: 2px solid transparent;
	opacity: 0.7;
	cursor: pointer;
	transition: opacity 0.2s ease, border-color 0.2s ease;
}

.flex-control-thumbs img.flex-active,
.flex-control-thumbs img:hover {
	opacity: 1;
	border-color: var(--mr-color-primary);
}

/* ---- Breadcrumb, category, title ------------------------------------------- */

.woocommerce-breadcrumb {
	margin: 0 0 16px;
	color: var(--mr-color-gray);
	font-size: 13px;
}

.woocommerce-breadcrumb a {
	color: var(--mr-color-gray);
	text-decoration: none;
	transition: color 0.2s ease;
}

.woocommerce-breadcrumb a:hover {
	color: var(--mr-color-primary);
}

span.single-product-category {
	display: inline-block;
	margin-bottom: 12px;
	color: var(--mr-color-primary);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

span.single-product-category a {
	color: inherit;
	text-decoration: none;
}

.product_title.entry-title {
	margin: 0 0 16px;
	color: var(--mr-color-primary-dark);
	font-size: clamp(28px, 4vw, 38px);
	line-height: 1.2;
}

/* ---- Price & rating --------------------------------------------------------- */

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	margin: 0 0 20px;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-size: 28px;
	font-weight: 700;
}

.woocommerce div.product p.price:empty {
	display: none;
}

.woocommerce div.product p.price del {
	margin-right: 10px;
	color: var(--mr-color-gray);
	font-weight: 500;
	font-size: 18px;
	opacity: 0.7;
}

.woocommerce div.product p.price ins {
	color: var(--mr-color-primary);
	text-decoration: none;
}

.woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 20px;
}

.woocommerce-product-rating .star-rating {
	color: var(--mr-color-accent);
}

.woocommerce-product-rating .woocommerce-review-link {
	color: var(--mr-color-gray);
	font-size: 13px;
	text-decoration: none;
}

/* ---- Short description -------------------------------------------------------- */

.woocommerce-product-details__short-description {
	margin: 0 0 28px;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--mr-color-border);
	color: var(--mr-color-gray);
	font-size: 16px;
	line-height: 1.8;
}

.woocommerce-product-details__short-description p:last-child {
	margin-bottom: 0;
}

.woocommerce-product-details__short-description:empty {
	display: none;
}

/* ---- Key feature highlights ----------------------------------------------------- */

.mr-product-highlights {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px 24px;
	margin: 0 0 28px;
	padding: 0 0 28px;
	border-bottom: 1px solid var(--mr-color-border);
	list-style: none;
}

.mr-product-highlights li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--mr-color-text);
	font-size: 15px;
	line-height: 1.5;
}

.mr-product-highlights svg {
	flex-shrink: 0;
	margin-top: 1px;
	padding: 3px;
	border-radius: 50%;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
}

/* ---- Delivery estimate ------------------------------------------------------------ */

.mr-product-delivery {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: -8px 0 20px;
	color: var(--mr-color-primary);
	font-size: 14px;
	font-weight: 600;
}

.mr-product-delivery svg {
	flex-shrink: 0;
}

/* ---- Trust bar ---------------------------------------------------------------------- */

.mr-product-trustbar {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin: 0;
	padding: 24px 0 0;
	border-top: 1px solid var(--mr-color-border);
	list-style: none;
}

.mr-product-trustbar li {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 0 4px;
	text-align: center;
	color: var(--mr-color-gray);
	font-size: 12.5px;
	font-weight: 600;
	line-height: 1.4;
}

.mr-product-trustbar svg {
	color: var(--mr-color-primary);
}

/* ---- Variations ----------------------------------------------------------------- */

.woocommerce div.product table.variations {
	width: 100%;
	margin-bottom: 24px;
}

.woocommerce div.product table.variations tr {
	display: flex;
	flex-direction: column;
	margin-bottom: 16px;
}

.woocommerce div.product table.variations th.label {
	padding: 0 0 10px;
	color: var(--mr-color-text);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-align: left;
}

.woocommerce div.product table.variations td.value {
	padding: 0;
}

.woocommerce div.product table.variations select {
	width: 100%;
	padding: 13px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 18px;
	appearance: none;
	font-family: var(--mr-font-body);
	font-size: 15px;
	color: var(--mr-color-text);
}

.woocommerce div.product table.variations select:focus {
	outline: none;
	border-color: var(--mr-color-primary);
	background-color: var(--mr-color-white);
}

.woocommerce div.product .reset_variations {
	display: inline-block;
	margin-top: 8px;
	color: var(--mr-color-gray);
	font-size: 13px;
	text-decoration: underline;
}

.woocommerce div.product .woocommerce-variation-price .price {
	font-size: 24px;
}

/* ---- Quantity & add to cart ------------------------------------------------------ */

.woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 12px;
	margin: 0 0 28px;
}

.woocommerce div.product form.cart .quantity {
	display: flex;
	margin: 0;
}

.woocommerce div.product form.cart .quantity .qty {
	width: 90px;
	height: 100%;
	padding: 0 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	font-family: var(--mr-font-body);
	font-size: 16px;
	text-align: center;
	color: var(--mr-color-text);
}

.woocommerce div.product form.cart .quantity .qty:focus {
	outline: none;
	border-color: var(--mr-color-primary);
	background-color: var(--mr-color-white);
}

.woocommerce div.product .single_add_to_cart_button {
	flex: 1;
	min-width: 200px;
	min-height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 32px;
	border: 2px solid transparent;
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 15px;
	transition: background-color 0.2s ease;
}

.woocommerce div.product .single_add_to_cart_button:hover {
	background-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
}

.woocommerce div.product .single_add_to_cart_button.disabled,
.woocommerce div.product .single_add_to_cart_button.disabled:hover {
	background-color: var(--mr-color-border) !important;
	color: var(--mr-color-gray) !important;
	cursor: not-allowed;
}

/* ---- Stock status ----------------------------------------------------------------- */

.woocommerce div.product p.stock {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 28px;
	padding: 10px 18px;
	border-radius: 999px;
	font-size: 13.5px;
	font-weight: 600;
}

.woocommerce div.product p.stock::before {
	content: '';
	width: 8px;
	height: 8px;
	flex-shrink: 0;
	border-radius: 50%;
	background-color: currentColor;
}

.woocommerce div.product p.stock.in-stock {
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
}

.woocommerce div.product p.stock.out-of-stock,
.woocommerce div.product p.stock.available-on-backorder {
	background-color: #fbe9e7;
	color: #c0392b;
}

/* ---- Product meta ------------------------------------------------------------------- */

.woocommerce div.product .product_meta {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 4px;
	padding-top: 24px;
	border-top: 1px solid var(--mr-color-border);
	color: var(--mr-color-gray);
	font-size: 13.5px;
}

.woocommerce div.product .product_meta a {
	color: var(--mr-color-gray);
	text-decoration: none;
	transition: color 0.2s ease;
}

.woocommerce div.product .product_meta a:hover {
	color: var(--mr-color-primary);
}

.woocommerce div.product .product_meta .tagged_as {
	display: none;
}

/* ---- Tabs --------------------------------------------------------------------------- */

.woocommerce-tabs {
	margin-top: 72px;
	padding-top: 48px;
	border-top: 1px solid var(--mr-color-border);
}

.woocommerce-tabs ul.tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	width: fit-content;
	margin: 0;
	padding: 6px;
	list-style: none;
	background-color: var(--mr-color-light-gray);
	border-radius: var(--mr-radius);
}

.woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0;
}

.woocommerce-tabs ul.tabs li a {
	display: inline-flex;
	align-items: center;
	padding: 11px 22px;
	border-radius: calc(var(--mr-radius) - 3px);
	color: var(--mr-color-gray);
	font-family: var(--mr-font-heading);
	font-weight: 600;
	font-size: 15px;
	text-decoration: none;
	transition: color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
	color: var(--mr-color-primary-dark);
	background-color: var(--mr-color-white);
	box-shadow: var(--mr-shadow);
}

.woocommerce-tabs ul.tabs li.active::before,
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs::before {
	display: none !important;
}

.woocommerce-Tabs-panel {
	max-width: 760px;
	margin-top: 28px;
	padding: 32px;
	background-color: var(--mr-color-white);
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	color: var(--mr-color-gray);
	font-size: 16px;
	line-height: 1.8;
}

.woocommerce-Tabs-panel h2 {
	margin: 0 0 20px;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-size: 24px;
}

table.woocommerce-product-attributes {
	width: 100%;
	max-width: 640px;
	border: none !important;
	border-collapse: collapse;
}

table.woocommerce-product-attributes tr:nth-child(even) {
	background-color: var(--mr-color-light-gray);
}

table.woocommerce-product-attributes th,
table.woocommerce-product-attributes td {
	padding: 14px 18px;
	border: none !important;
	font-size: 14.5px;
	text-align: left;
}

table.woocommerce-product-attributes th {
	width: 220px !important;
	color: var(--mr-color-text);
	font-weight: 600;
}

table.woocommerce-product-attributes td p {
	margin: 0;
	color: var(--mr-color-gray);
}

/* ---- Product reviews ---------------------------------------------------------------- */

.woocommerce-noreviews {
	margin: 0 0 28px;
}

#review_form_wrapper {
	margin-top: 28px;
	padding-top: 28px;
	border-top: 1px solid var(--mr-color-border);
}

.woocommerce-Reviews #respond {
	border: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}

.woocommerce-Reviews #review_form {
	border: none !important;
	padding-top: 0 !important;
}

.woocommerce-Reviews #respond .comment-reply-title {
	display: block;
	margin: 0 0 20px;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-size: 22px;
	font-weight: 700;
}

.woocommerce-Reviews #respond .comment-reply-title small {
	margin-left: 12px;
	font-family: var(--mr-font-body);
	font-size: 13px;
	font-weight: 400;
}

.woocommerce-Reviews .comment-notes,
.woocommerce-Reviews .comment-form-cookies-consent {
	font-size: 13px;
	color: var(--mr-color-gray);
}

.woocommerce-Reviews .comment-form-rating label,
.woocommerce-Reviews .comment-form-comment label,
.woocommerce-Reviews .comment-form-author label,
.woocommerce-Reviews .comment-form-email label {
	display: block;
	margin-bottom: 8px;
	color: var(--mr-color-text);
	font-weight: 600;
	font-size: 14px;
}

.woocommerce-Reviews .comment-form-rating {
	margin-bottom: 16px;
}

.woocommerce-Reviews .comment-form-rating p.stars a {
	font-size: 18px;
}

.woocommerce-Reviews #commentform input[type="text"],
.woocommerce-Reviews #commentform input[type="email"],
.woocommerce-Reviews #commentform textarea {
	display: block;
	width: 100%;
	padding: 12px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	font-family: var(--mr-font-body);
	font-size: 15px;
	color: var(--mr-color-text);
	background-color: var(--mr-color-white);
	transition: border-color 0.2s ease;
}

.woocommerce-Reviews #commentform input[type="text"]:focus,
.woocommerce-Reviews #commentform input[type="email"]:focus,
.woocommerce-Reviews #commentform textarea:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

.woocommerce-Reviews .comment-form-cookies-consent {
	display: flex;
	align-items: center;
	gap: 8px;
}

.woocommerce-Reviews .comment-form-cookies-consent input {
	width: auto;
	accent-color: var(--mr-color-primary);
}

.woocommerce-Reviews #commentform .form-submit input#submit,
.woocommerce-Reviews #commentform p.form-submit input#submit {
	display: inline-flex;
	align-items: center;
	background-color: var(--mr-color-primary) !important;
	color: var(--mr-color-white) !important;
	border: none;
	border-radius: var(--mr-radius);
	padding: 12px 28px;
	font-family: var(--mr-font-body);
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.woocommerce-Reviews #commentform .form-submit input#submit:hover {
	background-color: var(--mr-color-primary-dark) !important;
}

/* ---- Related products ------------------------------------------------------------------ */

.woocommerce div.product .related.products {
	margin-top: 72px;
	padding-top: 48px;
	border-top: 1px solid var(--mr-color-border);
}

.mr-related-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.mr-related-grid .mr-product-card {
	height: 100%;
}

/* ==========================================================================
   9g. WARENKORB (CART)
   ========================================================================== */

body.woocommerce-cart .ast-container {
	max-width: var(--mr-container);
	padding: 0 24px;
}

body.woocommerce-cart #primary {
	padding: 48px 0 80px;
}

body.woocommerce-cart .entry-header {
	margin: 0 0 32px;
}

body.woocommerce-cart .entry-title {
	margin: 0;
	font-size: clamp(28px, 4vw, 38px);
}

/* ---- Layout: items | totals ------------------------------------------------ */

.wc-block-components-sidebar-layout.wc-block-cart {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 32px;
	align-items: flex-start;
}

.wc-block-components-main.wc-block-cart__main,
.wc-block-components-sidebar.wc-block-cart__sidebar {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	float: none !important;
}

/* ---- Cart items table -------------------------------------------------------- */

.wc-block-cart-items {
	display: block;
	width: 100%;
	border-collapse: collapse;
}

.wc-block-cart-items thead {
	display: none;
}

.wc-block-cart-items tbody {
	display: block;
}

.wc-block-cart-items__row {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	padding: 24px 0;
	border-bottom: 1px solid var(--mr-color-border);
}

.wc-block-cart-items__row:first-child {
	padding-top: 0;
}

.wc-block-cart-items__row:last-child {
	border-bottom: none;
}

.wc-block-cart-item__image {
	display: block;
	flex-shrink: 0;
}

.wc-block-cart-item__image img {
	width: 96px;
	height: 96px;
	object-fit: cover;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
}

.wc-block-cart-item__product {
	display: block;
	flex: 1;
	min-width: 0;
}

.wc-block-cart-item__total {
	display: block;
	flex-shrink: 0;
	padding-top: 2px;
	text-align: right;
	font-family: var(--mr-font-heading);
	font-weight: 700;
	font-size: 17px;
	color: var(--mr-color-primary-dark);
}

/* ---- Product name, price, description --------------------------------------- */

.wc-block-components-product-name {
	display: block;
	margin: 0 0 6px;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-weight: 600;
	font-size: 16px;
	line-height: 1.4;
	text-decoration: none;
}

.wc-block-components-product-name:hover {
	color: var(--mr-color-primary);
}

.wc-block-cart-item__prices {
	margin: 0 0 10px;
}

.wc-block-cart-item__prices .wc-block-components-product-price {
	color: var(--mr-color-gray);
	font-size: 14px;
	font-weight: 500;
}

.wc-block-cart-item__prices .wc-block-components-product-price__regular {
	margin-right: 6px;
	text-decoration: line-through;
	opacity: 0.7;
}

.wc-block-cart-item__prices .wc-block-components-product-price__value.is-discounted {
	color: var(--mr-color-primary);
	font-weight: 600;
}

.wc-block-components-product-metadata__description {
	margin: 0 0 14px;
	color: var(--mr-color-gray);
	font-size: 13.5px;
	line-height: 1.6;
}

.wc-block-components-product-metadata__description p {
	margin: 0;
}

.wc-block-cart-item__total .wc-block-components-product-price__regular {
	display: block;
	margin-bottom: 4px;
	color: var(--mr-color-gray);
	font-size: 13px;
	font-weight: 500;
	text-decoration: line-through;
	opacity: 0.7;
}

.wc-block-cart-item__total .wc-block-components-product-price__value.is-discounted {
	color: var(--mr-color-primary);
}

.wc-block-components-sale-badge {
	display: inline-block;
	margin-top: 8px;
	padding: 4px 10px;
	border-radius: 999px;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary);
	font-size: 11.5px;
	font-weight: 700;
	white-space: nowrap;
}

/* ---- Quantity selector & remove button --------------------------------------- */

.wc-block-cart-item__quantity {
	display: flex;
	align-items: center;
	gap: 16px;
}

.wc-block-components-quantity-selector {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--mr-color-border);
	border-radius: 999px;
	background-color: var(--mr-color-light-gray);
	overflow: hidden;
}

.wc-block-components-quantity-selector__button {
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	color: var(--mr-color-text);
	font-size: 16px;
	line-height: 1;
	cursor: pointer;
	transition: color 0.2s ease;
}

.wc-block-components-quantity-selector__button:hover:not(:disabled) {
	color: var(--mr-color-primary);
}

.wc-block-components-quantity-selector__button:disabled {
	color: var(--mr-color-border);
	cursor: not-allowed;
}

.wc-block-components-quantity-selector__input {
	width: 40px;
	height: 36px;
	border: none;
	background: transparent;
	padding: 0;
	font-family: var(--mr-font-body);
	font-size: 15px;
	text-align: center;
	color: var(--mr-color-text);
}

.wc-block-components-quantity-selector__input:focus {
	outline: none;
}

.wc-block-cart-item__remove-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	color: var(--mr-color-gray);
	cursor: pointer;
	transition: color 0.2s ease;
}

.wc-block-cart-item__remove-link:hover {
	color: #c0392b;
}

.wc-block-cart-item__remove-link svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

/* ---- Totals sidebar ------------------------------------------------------------ */

.wc-block-components-sidebar.wc-block-cart__sidebar {
	padding: 28px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	position: sticky;
	top: 24px;
}

.wc-block-cart .wc-block-components-sidebar .wc-block-cart__totals-title {
	display: block !important;
	margin: 0 0 20px;
	padding: 0;
	font-family: var(--mr-font-heading);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.3;
	text-transform: none;
	color: var(--mr-color-primary-dark);
}

.wp-block-woocommerce-cart-order-summary-totals-block {
	border-top: none;
	padding-bottom: 0;
}

.wp-block-woocommerce-cart-order-summary-coupon-form-block {
	border-top: none !important;
	padding: 0 !important;
}

.wc-block-components-totals-coupon {
	margin-bottom: 4px;
}

.wc-block-components-panel__button {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: none;
	background: transparent;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 14px;
	cursor: pointer;
}

.wc-block-components-panel__button-icon {
	width: 18px;
	height: 18px;
	fill: currentColor;
	flex-shrink: 0;
}

.wc-block-components-totals-coupon__form {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin-top: 14px;
}

.wc-block-components-totals-coupon__input {
	flex: 1;
}

.wc-block-components-text-input {
	position: relative;
}

.wc-block-components-text-input input {
	width: 100%;
	height: 46px;
	padding: 0 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
	font-family: var(--mr-font-body);
	font-size: 14.5px;
	color: var(--mr-color-text);
}

.wc-block-components-text-input input:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

.wc-block-components-text-input label {
	position: absolute;
	top: 50%;
	left: 16px;
	margin: 0;
	padding: 0 4px;
	color: var(--mr-color-gray);
	font-size: 14.5px;
	pointer-events: none;
	transform: translateY(-50%);
	transition: all 0.15s ease;
}

.wc-block-components-text-input input:focus ~ label,
.wc-block-components-text-input.is-active label {
	top: 0;
	background-color: var(--mr-color-white);
	color: var(--mr-color-primary);
	transform: translateY(-50%) scale(0.85);
}

.wc-block-components-totals-coupon__button {
	flex-shrink: 0;
	height: 46px;
	padding: 0 20px;
	border: none;
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary-dark) !important;
	color: var(--mr-color-white) !important;
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 14px;
}

.wc-block-components-totals-coupon__button:disabled {
	background-color: var(--mr-color-border) !important;
	color: var(--mr-color-gray) !important;
	cursor: not-allowed;
}

.wc-block-components-totals-item {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
	font-size: 14.5px;
	color: var(--mr-color-text);
}

.wc-block-components-totals-item__label {
	color: var(--mr-color-gray);
}

.wc-block-components-totals-footer-item {
	margin: 16px 0 0;
	padding-top: 16px;
	border-top: 1px solid var(--mr-color-border);
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	font-family: var(--mr-font-heading);
	font-weight: 700;
	font-size: 19px;
	color: var(--mr-color-primary-dark);
}

/* ---- Checkout button ------------------------------------------------------------ */

.wc-block-cart__submit-button.wp-element-button {
	display: flex;
	width: 100%;
	min-height: 52px;
	align-items: center;
	justify-content: center;
	margin-top: 24px;
	border: none;
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary) !important;
	color: var(--mr-color-white) !important;
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 15px;
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.wc-block-cart__submit-button.wp-element-button:hover {
	background-color: var(--mr-color-primary-dark) !important;
}

/* ---- Empty cart ------------------------------------------------------------------- */

.wp-block-woocommerce-empty-cart-block {
	padding: 32px 0;
	text-align: center;
}

.wc-block-cart__empty-cart__title {
	margin-bottom: 8px;
}

.wp-block-woocommerce-empty-cart-block .wp-block-separator {
	max-width: 120px;
	margin: 32px auto;
}

.wp-block-woocommerce-empty-cart-block h2:last-of-type {
	margin-bottom: 32px;
}

/* ---- "Nouveau dans la boutique" product grid -------------------------------------- */

.wc-block-grid__products {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: left;
}

.wc-block-grid__product {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	overflow: hidden;
	background-color: var(--mr-color-white);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.wc-block-grid__product:hover {
	box-shadow: var(--mr-shadow);
	transform: translateY(-4px);
}

.wc-block-grid__product-link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.wc-block-grid__product-onsale {
	position: absolute;
	top: 14px;
	left: 14px;
	z-index: 1;
	padding: 6px 12px;
	border-radius: 999px;
	background-color: var(--mr-color-accent) !important;
	color: var(--mr-color-primary-dark) !important;
	font-size: 12px;
	font-weight: 700;
}

.wc-block-grid__product-onsale .screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
}

.wc-block-grid__product-image img {
	aspect-ratio: 1;
	width: 100%;
	object-fit: cover;
	background-color: var(--mr-color-light-gray);
}

.wc-block-grid__product-title {
	margin: 16px 16px 4px;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-weight: 600;
	font-size: 15px;
	line-height: 1.4;
}

.wc-block-grid__product-price {
	margin: 0 16px 16px;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-weight: 700;
	font-size: 16px;
}

.wc-block-grid__product-price del {
	margin-right: 6px;
	color: var(--mr-color-gray);
	font-weight: 500;
	font-size: 13px;
	opacity: 0.7;
}

.wc-block-grid__product-price ins {
	color: var(--mr-color-primary);
	text-decoration: none;
}

.wc-block-grid__product-add-to-cart {
	width: calc(100% - 32px);
	align-self: stretch;
	margin: 0 16px 16px;
}

.wc-block-grid__product-add-to-cart .wp-block-button__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 44px;
	padding: 0 16px;
	border: none;
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary) !important;
	color: var(--mr-color-white) !important;
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.wc-block-grid__product-add-to-cart .wp-block-button__link:hover {
	background-color: var(--mr-color-primary-dark) !important;
}

/* ==========================================================================
   9h. KASSE (CHECKOUT)
   ========================================================================== */

body.woocommerce-checkout .ast-container {
	max-width: var(--mr-container);
	padding: 0 24px;
}

body.woocommerce-checkout #primary {
	padding: 48px 0 80px;
}

body.woocommerce-checkout .entry-header {
	margin: 0 0 32px;
}

body.woocommerce-checkout .entry-title {
	margin: 0;
	font-size: clamp(28px, 4vw, 38px);
}

/* ---- Layout: form | order summary ------------------------------------------- */

.wc-block-components-sidebar-layout.wc-block-checkout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 32px;
	align-items: flex-start;
}

.wc-block-components-main.wc-block-checkout__main,
.wc-block-components-sidebar.wc-block-checkout__sidebar {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	float: none !important;
}

/* ---- Checkout steps ----------------------------------------------------------- */

.wc-block-components-checkout-step {
	padding: 28px 0;
	border-bottom: 1px solid var(--mr-color-border);
}

#contact-fields.wc-block-components-checkout-step {
	padding-top: 0;
}

.wc-block-checkout__actions.wc-block-components-checkout-step {
	border-bottom: none;
	padding-bottom: 0;
}

.wc-block-components-checkout-step__heading-container {
	margin: 0 0 20px;
}

.wc-block-components-checkout-step__title {
	margin: 0;
	font-family: var(--mr-font-heading);
	font-size: 20px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

/* ---- Address form --------------------------------------------------------------- */

.wc-block-components-address-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

.wc-block-components-address-form > * {
	grid-column: span 2;
}

.wc-block-components-address-form__first_name,
.wc-block-components-address-form__last_name,
.wc-block-components-address-form__postcode,
.wc-block-components-address-form__city {
	grid-column: span 1;
}

.wc-block-components-address-form__address_2-toggle {
	display: inline-block;
	margin: -6px 0 0;
	color: var(--mr-color-primary);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
}

.wc-block-components-address-form__address_2-toggle:hover {
	color: var(--mr-color-primary-dark);
}

/* ---- Select dropdowns (country, state) ------------------------------------------ */

.wc-blocks-components-select__container {
	position: relative;
}

.wc-blocks-components-select__select {
	width: 100%;
	height: 46px;
	padding: 0 40px 0 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
	font-family: var(--mr-font-body);
	font-size: 14.5px;
	color: var(--mr-color-text);
	appearance: none;
}

.wc-blocks-components-select__select:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

.wc-blocks-components-select__label {
	position: absolute;
	top: -8px;
	left: 12px;
	z-index: 1;
	padding: 0 4px;
	background-color: var(--mr-color-white);
	color: var(--mr-color-gray);
	font-size: 12px;
	line-height: 1;
}

.wc-blocks-components-select__expand {
	position: absolute;
	top: 50%;
	right: 14px;
	width: 18px;
	height: 18px;
	transform: translateY(-50%);
	fill: var(--mr-color-gray);
	pointer-events: none;
}

/* ---- Saved address card ---------------------------------------------------------- */

.wc-block-components-address-card {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	font-size: 14px;
	line-height: 1.6;
	color: var(--mr-color-text);
}

.wc-block-components-address-card__edit {
	flex-shrink: 0;
	color: var(--mr-color-primary);
	font-weight: 600;
	font-size: 13px;
	text-decoration: underline;
	cursor: pointer;
}

.wc-block-components-address-card__edit:hover {
	color: var(--mr-color-primary-dark);
}

/* ---- Checkboxes (order note, terms) ------------------------------------------------ */

.wc-block-components-checkbox label {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--mr-color-text);
	font-size: 14px;
	cursor: pointer;
}

.wc-block-components-checkbox svg {
	fill: var(--mr-color-primary);
}

/* ---- Notices (e.g. no payment method available) -------------------------------------- */

.wc-block-components-notice-banner {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 14px 16px;
	border-radius: var(--mr-radius);
	font-size: 13.5px;
	line-height: 1.6;
}

.wc-block-components-notice-banner svg {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	fill: currentColor;
}

.wc-block-components-notice-banner.is-error {
	border: 1px solid #f5c2c0;
	background-color: #fdeeed;
	color: #b3261e;
}

/* ---- Order note / terms ------------------------------------------------------------------ */

.wc-block-checkout__terms {
	padding-top: 4px;
	color: var(--mr-color-gray);
	font-size: 13px;
	line-height: 1.6;
}

.wc-block-checkout__terms a {
	color: var(--mr-color-primary);
	text-decoration: underline;
}

/* ---- Place order button -------------------------------------------------------------------- */

.wc-block-components-checkout-place-order-button.wp-element-button {
	display: flex;
	width: 100%;
	min-height: 52px;
	align-items: center;
	justify-content: center;
	border: none;
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary) !important;
	color: var(--mr-color-white) !important;
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 15px;
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.wc-block-components-checkout-place-order-button.wp-element-button:hover {
	background-color: var(--mr-color-primary-dark) !important;
}

/* ---- Order summary sidebar -------------------------------------------------------------------- */

.wc-block-components-sidebar.wc-block-checkout__sidebar {
	padding: 28px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	position: sticky;
	top: 24px;
}

.wc-block-components-checkout-order-summary__title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin: 0 0 20px;
}

.wc-block-components-checkout-order-summary__title-text {
	margin: 0;
	font-family: var(--mr-font-heading);
	font-size: 20px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

.wc-block-components-checkout-order-summary__title-price {
	font-family: var(--mr-font-heading);
	font-size: 16px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

.wc-block-components-checkout-order-summary__title-icon svg {
	width: 18px;
	height: 18px;
	fill: var(--mr-color-gray);
}

.wp-block-woocommerce-checkout-order-summary-coupon-form-block {
	border-top: none !important;
	padding: 0 !important;
}

.wp-block-woocommerce-checkout-order-summary-totals-block {
	border-top: none;
	padding-bottom: 0;
}

/* ---- Order summary items (mini cart items) -------------------------------------------------- */

.wc-block-components-order-summary-item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px 0;
	border-bottom: 1px solid var(--mr-color-border);
}

.wc-block-components-order-summary__content .wc-block-components-order-summary-item:first-child {
	padding-top: 0;
}

.wc-block-components-order-summary-item__image {
	position: relative;
	flex-shrink: 0;
}

.wc-block-components-order-summary-item__image img {
	width: 48px;
	height: 48px;
	object-fit: cover;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
}

.wc-block-components-order-summary-item__quantity {
	position: absolute;
	top: -8px;
	right: -8px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background-color: var(--mr-color-primary-dark) !important;
	color: var(--mr-color-white) !important;
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
}

.wc-block-components-order-summary-item__description {
	flex: 1;
	min-width: 0;
}

.wc-block-components-order-summary-item__description .wc-block-components-product-name {
	margin: 0 0 4px;
	font-size: 13.5px;
}

.wc-block-components-order-summary-item__description .wc-block-cart-item__prices {
	margin: 0 0 4px;
}

.wc-block-components-order-summary-item__description .wc-block-components-product-metadata__description {
	display: -webkit-box;
	margin: 0;
	overflow: hidden;
	font-size: 12px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
}

.wc-block-components-order-summary-item__total-price {
	flex-shrink: 0;
	padding-top: 2px;
	font-family: var(--mr-font-heading);
	font-weight: 700;
	font-size: 14px;
	color: var(--mr-color-primary-dark);
	text-align: right;
}

/* ==========================================================================
   9i. BESTELLUNG ERHALTEN (ORDER RECEIVED)
   ========================================================================== */

body.woocommerce-order-received .woocommerce-order {
	max-width: 760px;
	margin: 0 auto;
}

/* ---- Success notice ----------------------------------------------------------- */

.woocommerce-order .woocommerce-thankyou-order-received {
	position: relative;
	margin: 0 0 28px;
	padding: 18px 20px 18px 56px;
	border: 1px solid var(--mr-color-primary);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 15px;
	list-style: none;
}

.woocommerce-order .woocommerce-thankyou-order-received::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 20px;
	width: 22px;
	height: 22px;
	transform: translateY(-50%);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232d5a27' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'%3E%3C/path%3E%3Cpolyline points='22 4 12 14.01 9 17'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
}

/* ---- Order overview (number, date, total, payment) ----------------------------- */

.woocommerce-order-overview {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
	margin: 0 0 32px;
	padding: 20px 24px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	list-style: none;
}

.woocommerce-order-overview li {
	flex: 1 1 auto;
	min-width: 120px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--mr-color-gray);
}

.woocommerce-order-overview li strong {
	display: block;
	margin-top: 4px;
	font-family: var(--mr-font-heading);
	font-size: 16px;
	font-weight: 700;
	letter-spacing: normal;
	text-transform: none;
	color: var(--mr-color-primary-dark);
}

/* ---- Order details table -------------------------------------------------------- */

.woocommerce-order-details {
	padding: 28px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
}

.woocommerce-order-details__title {
	margin: 0 0 20px;
	font-family: var(--mr-font-heading);
	font-size: 20px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

.woocommerce-table.shop_table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
	color: var(--mr-color-text);
}

.woocommerce-table.shop_table th,
.woocommerce-table.shop_table td {
	padding: 12px 0;
	border-bottom: 1px solid var(--mr-color-border);
	text-align: left;
}

.woocommerce-table.shop_table thead th {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--mr-color-gray);
}

.woocommerce-table.shop_table .product-name a {
	color: var(--mr-color-primary-dark);
	font-weight: 600;
	text-decoration: none;
}

.woocommerce-table.shop_table .product-name a:hover {
	color: var(--mr-color-primary);
}

.woocommerce-table.shop_table .product-name .product-quantity {
	color: var(--mr-color-gray);
	font-weight: 400;
}

.woocommerce-table.shop_table th.product-total,
.woocommerce-table.shop_table td.product-total {
	text-align: right;
}

.woocommerce-table.shop_table tfoot th {
	font-weight: 400;
	color: var(--mr-color-gray);
}

.woocommerce-table.shop_table tfoot td {
	text-align: right;
	font-weight: 600;
}

.woocommerce-table.shop_table tfoot tr:last-child th,
.woocommerce-table.shop_table tfoot tr:last-child td {
	padding-top: 16px;
	border-bottom: none;
	font-family: var(--mr-font-heading);
	font-size: 18px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

/* ==========================================================================
   9j. MEIN KONTO (MY ACCOUNT)
   ========================================================================== */

body.woocommerce-account .ast-container {
	max-width: var(--mr-container);
	padding: 0 24px;
}

body.woocommerce-account #primary {
	padding: 48px 0 80px;
}

body.woocommerce-account .entry-header {
	margin: 0 0 32px;
}

body.woocommerce-account .entry-title {
	margin: 0;
	font-size: clamp(28px, 4vw, 38px);
}

/* ---- Layout: navigation | content ----------------------------------------------- */

body.woocommerce-account .woocommerce {
	display: grid;
	grid-template-columns: 240px minmax(0, 1fr);
	gap: 32px;
	align-items: start;
}

body.woocommerce-account .woocommerce::before,
body.woocommerce-account .woocommerce::after {
	content: none;
	display: none;
}

body.woocommerce-account .woocommerce-MyAccount-navigation,
body.woocommerce-account .woocommerce-MyAccount-content {
	float: none;
	width: 100%;
}

/* ---- Account navigation ----------------------------------------------------------- */

.woocommerce-MyAccount-navigation {
	position: sticky;
	top: 24px;
	padding: 8px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
}

.woocommerce-MyAccount-navigation ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.woocommerce-MyAccount-navigation-link a {
	display: block;
	padding: 12px 16px;
	border-radius: calc(var(--mr-radius) - 4px);
	color: var(--mr-color-text);
	font-family: var(--mr-font-body);
	font-weight: 500;
	font-size: 14.5px;
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.woocommerce-MyAccount-navigation-link a:hover {
	background-color: var(--mr-color-white);
	color: var(--mr-color-primary);
}

.woocommerce-MyAccount-navigation-link.is-active a {
	background-color: var(--mr-color-primary) !important;
	color: var(--mr-color-white) !important;
	font-weight: 600;
}

.woocommerce-MyAccount-navigation-link--customer-logout {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid var(--mr-color-border);
}

.woocommerce-MyAccount-navigation-link--customer-logout a {
	color: var(--mr-color-gray);
}

/* ---- Content area -------------------------------------------------------------------- */

.woocommerce-MyAccount-content {
	min-width: 0;
	font-family: var(--mr-font-body);
	font-size: 15px;
	line-height: 1.7;
	color: var(--mr-color-text);
}

.woocommerce-MyAccount-content > p:first-of-type {
	margin-top: 0;
}

.woocommerce-MyAccount-content a {
	color: var(--mr-color-primary);
	font-weight: 600;
	text-decoration: underline;
}

.woocommerce-MyAccount-content a:hover {
	color: var(--mr-color-primary-dark);
}

.woocommerce-MyAccount-content h2 {
	margin: 0 0 20px;
	font-family: var(--mr-font-heading);
	font-size: 20px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

/* ---- Notices ("noch keine Bestellung", etc.) ----------------------------------------- */

.woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-MyAccount-content .woocommerce-error {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: 0;
	padding: 22px 28px;
	border: 1px solid var(--mr-color-border);
	border-left: 4px solid var(--mr-color-primary);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
	color: var(--mr-color-text);
	font-size: 15px;
	list-style: none;
}

.woocommerce-MyAccount-content .woocommerce-info::before,
.woocommerce-MyAccount-content .woocommerce-message::before,
.woocommerce-MyAccount-content .woocommerce-error::before {
	display: none;
}

.woocommerce-MyAccount-content .woocommerce-error {
	border-left-color: #c0392b;
	background-color: #fdeeed;
}

/* ---- Buttons -------------------------------------------------------------------------- */

.woocommerce-MyAccount-content .button,
.woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-MyAccount-content button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 13px 28px;
	border: none;
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-primary) !important;
	color: var(--mr-color-white) !important;
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 14.5px;
	text-decoration: none !important;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.woocommerce-MyAccount-content .button:hover,
.woocommerce-MyAccount-content .woocommerce-Button:hover,
.woocommerce-MyAccount-content button[type="submit"]:hover {
	background-color: var(--mr-color-primary-dark) !important;
}

/* ---- Forms (edit account, addresses) --------------------------------------------------- */

.woocommerce-MyAccount-content .form-row label {
	display: block;
	margin: 0 0 6px;
	font-family: var(--mr-font-body);
	font-weight: 600;
	font-size: 13.5px;
	color: var(--mr-color-text);
}

.woocommerce-MyAccount-content .form-row label .required {
	color: #c0392b;
	text-decoration: none;
}

.woocommerce-MyAccount-content .form-row label .optional {
	font-weight: 400;
	color: var(--mr-color-gray);
}

.woocommerce-MyAccount-content .form-row .input-text,
.woocommerce-MyAccount-content .form-row select {
	width: 100%;
	height: 46px;
	padding: 0 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-white);
	font-family: var(--mr-font-body);
	font-size: 14.5px;
	color: var(--mr-color-text);
}

.woocommerce-MyAccount-content .form-row .input-text:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

.woocommerce-MyAccount-content fieldset {
	margin: 24px 0 0;
	padding: 24px 0 0;
	border: none;
	border-top: 1px solid var(--mr-color-border);
}

.woocommerce-MyAccount-content fieldset legend {
	width: 100%;
	margin: 0 0 16px;
	padding: 0;
	font-family: var(--mr-font-heading);
	font-size: 16px;
	font-weight: 700;
	color: var(--mr-color-primary-dark);
}

.woocommerce-MyAccount-content .password-input {
	position: relative;
	display: block;
}

.woocommerce-MyAccount-content .password-input .input-text {
	padding-right: 44px;
}

.woocommerce-MyAccount-content .show-password-input {
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
}

/* ---- Select2 dropdowns (country, state) -------------------------------------------------- */

.woocommerce-MyAccount-content .select2-container .select2-selection--single {
	height: 46px !important;
	border: 1px solid var(--mr-color-border) !important;
	border-radius: var(--mr-radius) !important;
	background-color: var(--mr-color-white) !important;
}

.woocommerce-MyAccount-content .select2-container .select2-selection__rendered {
	padding-left: 16px;
	line-height: 44px !important;
	font-family: var(--mr-font-body);
	font-size: 14.5px;
	color: var(--mr-color-text) !important;
}

.woocommerce-MyAccount-content .select2-container .select2-selection__arrow {
	height: 44px !important;
	right: 12px;
}

.woocommerce-MyAccount-content .select2-container--open .select2-selection--single,
.woocommerce-MyAccount-content .select2-container--focus .select2-selection--single {
	border-color: var(--mr-color-primary) !important;
}

/* ---- Address cards ------------------------------------------------------------------------ */

.woocommerce-Addresses.col2-set {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	margin-top: 8px;
}

.woocommerce-Addresses.col2-set::before,
.woocommerce-Addresses.col2-set::after {
	content: none;
	display: none;
}

body.woocommerce-account .woocommerce-Addresses.col2-set .woocommerce-Address {
	float: none;
	width: 100%;
	padding: 24px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	background-color: var(--mr-color-light-gray);
}

.woocommerce-Address-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 0 0 12px;
}

.woocommerce-Address-title h2 {
	margin: 0;
	font-size: 17px;
}

.woocommerce-Address-title .edit {
	flex-shrink: 0;
	color: var(--mr-color-primary);
	font-size: 13px;
	font-weight: 600;
	text-decoration: underline;
}

.woocommerce-Address-title .edit:hover {
	color: var(--mr-color-primary-dark);
}

.woocommerce-Address address {
	margin: 0;
	font-style: normal;
	font-size: 14px;
	line-height: 1.7;
	color: var(--mr-color-gray);
}

/* ---- Orders table -------------------------------------------------------------------------- */

.woocommerce-orders-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.woocommerce-orders-table thead th {
	padding: 12px 16px;
	border-bottom: 1px solid var(--mr-color-border);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--mr-color-gray);
	text-align: left;
}

.woocommerce-orders-table tbody td,
.woocommerce-orders-table tbody th {
	padding: 16px;
	border-bottom: 1px solid var(--mr-color-border);
	font-weight: 400;
	text-align: left;
}

.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions {
	text-align: right;
	white-space: nowrap;
}

.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions .button {
	margin-left: 8px;
	padding: 8px 18px;
	font-size: 13px;
}

.woocommerce-orders-table .order-status {
	display: inline-flex;
	align-items: center;
	padding: 4px 12px;
	border-radius: 999px;
	background-color: var(--mr-color-primary-light);
	color: var(--mr-color-primary-dark);
	font-size: 12px;
	font-weight: 600;
}

/* ---- Login / Register / Lost password forms (logged-out) ---------------- */

body.woocommerce-account .woocommerce-form-login,
body.woocommerce-account .woocommerce-form-register,
body.woocommerce-account .woocommerce-ResetPassword {
	background-color: var(--mr-color-white);
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	box-shadow: var(--mr-shadow);
	padding: 32px;
	max-width: 480px;
}

body.woocommerce-account .woocommerce-form-login .form-row,
body.woocommerce-account .woocommerce-form-register .form-row,
body.woocommerce-account .woocommerce-ResetPassword .form-row {
	margin-bottom: 20px;
}

body.woocommerce-account .woocommerce-form-login label,
body.woocommerce-account .woocommerce-form-register label,
body.woocommerce-account .woocommerce-ResetPassword label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	font-size: 14px;
}

body.woocommerce-account .woocommerce-form-login .required,
body.woocommerce-account .woocommerce-form-register .required,
body.woocommerce-account .woocommerce-ResetPassword .required {
	color: #d4593a;
	text-decoration: none;
}

body.woocommerce-account .woocommerce-form-login .input-text,
body.woocommerce-account .woocommerce-form-register .input-text,
body.woocommerce-account .woocommerce-ResetPassword .input-text {
	display: block;
	width: 100%;
	padding: 12px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	font-family: var(--mr-font-body);
	font-size: 15px;
	color: var(--mr-color-text);
	background-color: var(--mr-color-white);
	transition: border-color 0.2s ease;
}

body.woocommerce-account .woocommerce-form-login .input-text:focus,
body.woocommerce-account .woocommerce-form-register .input-text:focus,
body.woocommerce-account .woocommerce-ResetPassword .input-text:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

body.woocommerce-account .woocommerce-form-login .password-input,
body.woocommerce-account .woocommerce-form-register .password-input {
	position: relative;
	display: block;
}

body.woocommerce-account .woocommerce-form-login .show-password-input,
body.woocommerce-account .woocommerce-form-register .show-password-input {
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
	cursor: pointer;
}

body.woocommerce-account .woocommerce-form-login__rememberme {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	font-weight: 400;
	font-size: 14px;
	cursor: pointer;
}

body.woocommerce-account .woocommerce-form-login__rememberme input {
	width: auto;
	margin: 0;
	accent-color: var(--mr-color-primary);
}

body.woocommerce-account .woocommerce-form-login .woocommerce-button,
body.woocommerce-account .woocommerce-form-register .woocommerce-Button,
body.woocommerce-account .woocommerce-ResetPassword .woocommerce-Button {
	display: inline-block;
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	border: none;
	border-radius: var(--mr-radius);
	padding: 12px 28px;
	font-family: var(--mr-font-body);
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

body.woocommerce-account .woocommerce-form-login .woocommerce-button:hover,
body.woocommerce-account .woocommerce-form-register .woocommerce-Button:hover,
body.woocommerce-account .woocommerce-ResetPassword .woocommerce-Button:hover {
	background-color: var(--mr-color-primary-dark);
}

body.woocommerce-account .woocommerce-LostPassword {
	margin: 16px 0 0;
	font-size: 14px;
}

body.woocommerce-account .woocommerce-LostPassword a {
	color: var(--mr-color-primary);
	text-decoration: underline;
}

body.woocommerce-account .woocommerce-LostPassword a:hover {
	color: var(--mr-color-primary-dark);
}

/* ==========================================================================
   9k. RECHTLICHE SEITEN (LEGAL PAGES)
   ========================================================================== */

body.mr-legal-page .ast-container {
	padding-top: 56px;
	padding-bottom: 80px;
}

body.mr-legal-page .entry-header,
body.mr-legal-page .entry-content {
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

body.mr-legal-page .entry-title {
	font-size: clamp(28px, 4vw, 40px);
	margin: 0 0 32px;
}

body.mr-legal-page .entry-content h2 {
	font-size: 22px;
	line-height: 1.3;
	margin: 40px 0 12px;
}

body.mr-legal-page .entry-content h2:first-child {
	margin-top: 0;
}

body.mr-legal-page .entry-content h3 {
	font-size: 18px;
	line-height: 1.3;
	margin: 24px 0 8px;
}

body.mr-legal-page .entry-content p {
	font-size: 16px;
	line-height: 1.8;
	margin: 0 0 16px;
}

body.mr-legal-page .entry-content ul,
body.mr-legal-page .entry-content ol {
	font-size: 16px;
	line-height: 1.8;
	margin: 0 0 16px;
	padding-left: 24px;
}

body.mr-legal-page .entry-content li {
	margin-bottom: 8px;
}

body.mr-legal-page .entry-content li::marker {
	color: var(--mr-color-primary);
}

body.mr-legal-page .entry-content a {
	color: var(--mr-color-primary);
	text-decoration: underline;
}

body.mr-legal-page .entry-content a:hover {
	color: var(--mr-color-primary-dark);
}

body.mr-legal-page .entry-content strong {
	color: var(--mr-color-primary-dark);
	font-weight: 600;
}

/* ==========================================================================
   9l. RATGEBER ARTIKEL (SINGLE POST)
   ========================================================================== */

/* Astra's "Separate Containers" layout adds a grey page background with
   white boxed/shadowed cards around the article and comments. Flatten this
   to match the rest of the site's plain white background. */
body.single-post.ast-separate-container {
	background-color: var(--mr-color-white);
}

body.single-post .ast-article-single,
body.single-post .ast-separate-container .comments-area,
body.single-post .ast-separate-container .comment-respond {
	background-color: transparent;
	box-shadow: none;
	padding: 0;
	border-radius: 0;
}

body.single-post .ast-container {
	max-width: 800px;
	padding-top: 56px;
	padding-bottom: 80px;
}

body.single-post .entry-header {
	margin-bottom: 32px;
}

body.single-post .entry-title {
	font-size: clamp(28px, 4vw, 40px);
	line-height: 1.25;
	margin: 0 0 12px;
}

body.single-post .entry-meta {
	font-size: 14px;
	color: var(--mr-color-gray);
	padding-bottom: 24px;
	border-bottom: 1px solid var(--mr-color-border);
}

body.single-post .entry-meta a {
	color: var(--mr-color-gray);
}

body.single-post .entry-meta a:hover {
	color: var(--mr-color-primary);
}

body.single-post .entry-content {
	margin-top: 32px;
}

body.single-post .entry-content h2 {
	font-size: 24px;
	line-height: 1.3;
	margin: 40px 0 12px;
}

body.single-post .entry-content h2:first-child {
	margin-top: 0;
}

body.single-post .entry-content h3 {
	font-size: 19px;
	line-height: 1.3;
	margin: 24px 0 8px;
}

body.single-post .entry-content p {
	font-size: 16px;
	line-height: 1.8;
	margin: 0 0 16px;
}

body.single-post .entry-content ul,
body.single-post .entry-content ol {
	font-size: 16px;
	line-height: 1.8;
	margin: 0 0 16px;
	padding-left: 24px;
}

body.single-post .entry-content li {
	margin-bottom: 8px;
}

body.single-post .entry-content li::marker {
	color: var(--mr-color-primary);
}

body.single-post .entry-content a {
	color: var(--mr-color-primary);
	text-decoration: underline;
}

body.single-post .entry-content a:hover {
	color: var(--mr-color-primary-dark);
}

body.single-post .entry-content strong {
	color: var(--mr-color-primary-dark);
	font-weight: 600;
}

body.single-post .entry-content img {
	border-radius: var(--mr-radius);
	margin: 16px 0;
}

body.single-post .entry-content blockquote {
	margin: 24px 0;
	padding: 16px 24px;
	border-left: 4px solid var(--mr-color-primary);
	background-color: var(--mr-color-light-gray);
	border-radius: 0 var(--mr-radius) var(--mr-radius) 0;
	font-style: italic;
	color: var(--mr-color-text);
}

/* ---- Post navigation (prev / next) --------------------------------------- */

body.single-post .navigation.post-navigation {
	margin-top: 48px;
}

body.single-post .navigation.post-navigation .nav-links {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

body.single-post .navigation.post-navigation .nav-previous,
body.single-post .navigation.post-navigation .nav-next {
	width: 100% !important;
	min-width: 0;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	padding: 20px 24px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.single-post .navigation.post-navigation .nav-previous:hover,
body.single-post .navigation.post-navigation .nav-next:hover {
	border-color: var(--mr-color-primary);
	box-shadow: var(--mr-shadow);
}

body.single-post .navigation.post-navigation .nav-next {
	text-align: right;
}

body.single-post .navigation.post-navigation a {
	display: block;
	width: 100%;
	max-width: 100%;
	text-decoration: none;
}

body.single-post .navigation.post-navigation .ast-post-nav {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
	color: var(--mr-color-primary);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

body.single-post .navigation.post-navigation .ast-post-nav svg {
	width: 14px;
	height: 14px;
	fill: currentColor;
}

body.single-post .navigation.post-navigation p {
	margin: 8px 0 0;
	color: var(--mr-color-primary-dark);
	font-family: var(--mr-font-heading);
	font-weight: 600;
	font-size: 15px;
	line-height: 1.4;
	white-space: normal;
}

/* ---- Comments ------------------------------------------------------------- */

body.single-post .comments-area {
	margin-top: 56px;
	padding-top: 40px;
	border-top: 1px solid var(--mr-color-border);
}

body.single-post .comment-reply-title {
	font-size: 22px;
	margin: 0 0 20px;
}

body.single-post .comment-form p {
	margin-bottom: 16px;
}

body.single-post .comment-form label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	font-size: 14px;
}

body.single-post .comment-form input[type="text"],
body.single-post .comment-form input[type="email"],
body.single-post .comment-form input[type="url"],
body.single-post .comment-form textarea {
	display: block;
	width: 100%;
	padding: 12px 16px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	font-family: var(--mr-font-body);
	font-size: 15px;
	color: var(--mr-color-text);
	background-color: var(--mr-color-white);
	transition: border-color 0.2s ease;
}

body.single-post .comment-form input[type="text"]:focus,
body.single-post .comment-form input[type="email"]:focus,
body.single-post .comment-form input[type="url"]:focus,
body.single-post .comment-form textarea:focus {
	outline: none;
	border-color: var(--mr-color-primary);
}

body.single-post .comment-form-cookies-consent {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
}

body.single-post .comment-form-cookies-consent input {
	width: auto;
	accent-color: var(--mr-color-primary);
}

body.single-post #submit {
	display: inline-block;
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	border: none;
	border-radius: var(--mr-radius);
	padding: 12px 28px;
	font-family: var(--mr-font-body);
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

body.single-post #submit:hover {
	background-color: var(--mr-color-primary-dark);
}

/* ==========================================================================
   9b. ARTICLE (single.php)
   ========================================================================== */

.mr-article {
	padding: 48px 0 80px;
}

.mr-article-container {
	max-width: 760px;
	margin: 0 auto;
}

.mr-article-header {
	margin-bottom: 32px;
}

.mr-article-eyebrow {
	display: inline-block;
	background-color: var(--mr-color-primary);
	color: var(--mr-color-white);
	font-size: 12px;
	font-weight: 600;
	padding: 6px 14px;
	border-radius: 999px;
	text-decoration: none;
	margin-bottom: 16px;
}

.mr-article-eyebrow:hover {
	background-color: var(--mr-color-primary-dark);
	color: var(--mr-color-white);
}

.mr-article-title-main {
	font-size: clamp(28px, 4vw, 40px);
	line-height: 1.25;
	margin: 0 0 16px;
}

.mr-article-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--mr-color-gray);
	padding-bottom: 24px;
	border-bottom: 1px solid var(--mr-color-border);
}

.mr-article-meta-author {
	font-weight: 600;
	color: var(--mr-color-text);
}

.mr-article-thumbnail {
	margin: 32px 0;
	border-radius: var(--mr-radius);
	overflow: hidden;
}

.mr-article-thumbnail img {
	width: 100%;
	height: auto;
	display: block;
}

/* ---- Article content typography ----------------------------------------- */

.mr-article-body-content {
	font-size: 16px;
	line-height: 1.8;
	color: var(--mr-color-text);
}

.mr-article-body-content > * + * {
	margin-top: 20px;
}

.mr-article-body-content h2,
.mr-article-body-content h3,
.mr-article-body-content h4 {
	margin-top: 40px;
	margin-bottom: 4px;
	line-height: 1.3;
}

.mr-article-body-content h2 {
	font-size: 26px;
}

.mr-article-body-content h3 {
	font-size: 21px;
}

.mr-article-body-content h4 {
	font-size: 18px;
}

.mr-article-body-content p {
	margin: 0;
}

.mr-article-body-content a {
	color: var(--mr-color-primary);
	text-decoration: underline;
}

.mr-article-body-content a:hover {
	color: var(--mr-color-primary-dark);
}

.mr-article-body-content ul,
.mr-article-body-content ol {
	padding-left: 24px;
	margin: 0;
}

.mr-article-body-content li + li {
	margin-top: 8px;
}

.mr-article-body-content li::marker {
	color: var(--mr-color-primary);
	font-weight: 600;
}

.mr-article-body-content blockquote {
	margin: 0;
	padding: 16px 24px;
	border-left: 4px solid var(--mr-color-primary);
	background-color: var(--mr-color-light-gray);
	border-radius: 0 var(--mr-radius) var(--mr-radius) 0;
	color: var(--mr-color-gray);
	font-style: italic;
}

.mr-article-body-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--mr-radius);
}

/* ==========================================================================
   10. RESPONSIVE
   ========================================================================== */

@media (max-width: 1024px) {
	.mr-product-card {
		flex: 0 0 calc((100% - 24px * 2) / 3.2);
	}

	.mr-advantages-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.mr-testimonials-grid {
		grid-template-columns: repeat(1, 1fr);
	}

	.mr-footer-columns {
		grid-template-columns: 1fr 1fr;
	}

	.mr-shop-layout {
		grid-template-columns: 232px 1fr;
		gap: 28px;
	}

	.mr-shop-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.mr-shop-infobar-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 40px 24px;
	}

	.mr-ratgeber-topics,
	.mr-ratgeber-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.mr-about-stats-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 32px 24px;
	}

	.mr-contact-layout {
		grid-template-columns: 1fr;
	}

	.woocommerce div.product {
		grid-template-columns: minmax(0, 1fr);
		gap: 32px;
	}

	.mr-related-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.wc-block-grid__products {
		grid-template-columns: repeat(2, 1fr);
	}

	.wc-block-components-sidebar-layout.wc-block-cart {
		grid-template-columns: minmax(0, 1fr);
		gap: 24px;
	}

	.wc-block-components-sidebar.wc-block-cart__sidebar {
		position: static;
	}

	.wc-block-components-sidebar-layout.wc-block-checkout {
		grid-template-columns: minmax(0, 1fr);
		gap: 24px;
	}

	.wc-block-components-sidebar.wc-block-checkout__sidebar {
		position: static;
	}

	body.woocommerce-account .woocommerce {
		grid-template-columns: minmax(0, 1fr);
		gap: 24px;
	}

	.woocommerce-MyAccount-navigation {
		position: static;
	}

	.woocommerce-MyAccount-navigation ul {
		display: flex;
		flex-wrap: wrap;
		gap: 4px;
	}

	.woocommerce-MyAccount-navigation-link {
		flex: 1 1 auto;
	}

	.woocommerce-MyAccount-navigation-link a {
		text-align: center;
	}

	.woocommerce-MyAccount-navigation-link--customer-logout {
		margin-top: 0;
		padding-top: 0;
		border-top: none;
	}
}

@media (max-width: 880px) {
	.mr-header-inner {
		grid-template-columns: auto 1fr auto;
		padding: 0 16px;
		gap: 12px;
	}

	.mr-header-logo .mr-logo-text {
		font-size: 18px;
	}

	.mr-header-icons {
		gap: 6px;
	}

	.mr-icon-btn,
	.mr-menu-toggle {
		width: 36px;
		height: 36px;
	}

	.mr-icon-btn svg {
		width: 20px;
		height: 20px;
	}

	.mr-header-nav {
		position: fixed;
		top: calc(var(--mr-announcement-height) + 64px);
		left: 0;
		right: 0;
		bottom: 0;
		background-color: var(--mr-color-white);
		padding: 24px;
		transform: translateX(-100%);
		transition: transform 0.3s ease;
		overflow-y: auto;
		justify-self: stretch;
	}

	body.has-announcement-bar .mr-header-nav {
		top: calc(var(--mr-announcement-height) + 64px);
	}

	.mr-header.is-menu-open .mr-header-nav {
		transform: translateX(0);
	}

	.mr-menu {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
		width: 100%;
	}

	.mr-menu li {
		width: 100%;
	}

	.mr-menu li a {
		display: block;
		padding: 14px 4px;
		width: 100%;
	}

	.mr-menu .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		display: none;
		box-shadow: none;
		border: none;
		padding-left: 16px;
		margin-top: 4px;
	}

	.mr-header.is-menu-open .mr-menu .sub-menu.is-open {
		display: block;
	}

	.mr-menu-toggle {
		display: flex;
	}

	.mr-shop-layout {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	.mr-shop-sidebar {
		position: static;
	}

	.mr-shop-filter-toggle {
		display: flex;
	}

	.mr-shop-filters-panel {
		display: none;
		margin-top: 12px;
	}

	.mr-shop-filters-panel.is-open {
		display: block;
	}
}

@media (max-width: 768px) {
	.mr-section {
		padding: 56px 0;
	}

	.mr-hero-dots {
		right: 16px;
		bottom: 24px;
		gap: 8px;
	}

	.mr-hero-dot {
		width: 32px;
		height: 32px;
		font-size: 12px;
	}

	.mr-hero-scroll {
		display: none;
	}

	.mr-products-track {
		gap: 16px;
	}

	.mr-product-card {
		flex: 0 0 calc((100% - 16px) / 1.6);
	}

	.mr-advantages-grid {
		grid-template-columns: 1fr;
	}

	.mr-footer-columns {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.mr-footer-newsletter-inner {
		flex-direction: column;
		align-items: flex-start;
	}

	.mr-footer-bottom-inner {
		flex-direction: column;
		text-align: center;
	}

	.mr-shop-grid {
		grid-template-columns: 1fr;
	}

	.mr-shop-infobar-grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.mr-shop-toolbar {
		flex-direction: column;
		align-items: flex-start;
	}

	.mr-ratgeber-topics,
	.mr-ratgeber-grid {
		grid-template-columns: 1fr;
	}

	.mr-about-story-grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.mr-about-stats-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	.mr-contact-form-card {
		padding: 28px;
	}

	.mr-contact-form-row {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.woocommerce-tabs {
		margin-top: 48px;
		padding-top: 32px;
	}

	.woocommerce-tabs ul.tabs {
		width: 100%;
	}

	.woocommerce-tabs ul.tabs li a {
		flex: 1;
		justify-content: center;
		padding: 11px 14px;
	}

	.woocommerce-Tabs-panel {
		padding: 24px;
	}

	.mr-product-trustbar {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px 16px;
	}

	.woocommerce div.product .related.products {
		margin-top: 48px;
		padding-top: 32px;
	}

	.mr-related-grid {
		grid-template-columns: 1fr;
	}

	.wc-block-grid__products {
		grid-template-columns: 1fr;
	}

	.wc-block-cart-items__row {
		flex-wrap: wrap;
	}

	.wc-block-cart-item__total {
		flex-basis: 100%;
		padding-top: 0;
		padding-left: 116px;
		text-align: left;
	}

	.wc-block-components-sidebar.wc-block-cart__sidebar {
		padding: 24px;
	}

	.wc-block-components-sidebar.wc-block-checkout__sidebar {
		padding: 24px;
	}

	.wc-block-components-address-form {
		grid-template-columns: 1fr;
	}

	.wc-block-components-address-form > * {
		grid-column: span 1;
	}

	.woocommerce-order-overview {
		gap: 16px;
		padding: 16px 20px;
	}

	.woocommerce-order-details {
		padding: 20px;
	}

	.woocommerce-Addresses.col2-set {
		grid-template-columns: 1fr;
	}

	.woocommerce-orders-table thead {
		display: none;
	}

	.woocommerce-orders-table tbody tr {
		display: block;
		padding: 16px 0;
		border-bottom: 1px solid var(--mr-color-border);
	}

	.woocommerce-orders-table tbody td,
	body.woocommerce-account .woocommerce-orders-table.shop_table_responsive tbody th {
		display: flex;
		justify-content: space-between;
		gap: 12px;
		padding: 4px 0;
		border-bottom: none;
		text-align: right;
	}

	.woocommerce-orders-table tbody td::before,
	.woocommerce-orders-table tbody th::before {
		content: attr(data-title);
		font-weight: 600;
		color: var(--mr-color-gray);
		text-align: left;
	}

	.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions {
		justify-content: flex-start;
		flex-wrap: wrap;
		padding-top: 8px;
	}

	.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions .button {
		margin-left: 0;
		margin-right: 8px;
	}

	body.mr-legal-page .ast-container {
		padding-top: 32px;
		padding-bottom: 48px;
	}

	body.mr-legal-page .entry-title {
		margin-bottom: 20px;
	}

	body.mr-legal-page .entry-content h2 {
		margin: 28px 0 10px;
	}

	body.single-post .ast-container {
		padding-top: 32px;
		padding-bottom: 48px;
	}

	body.single-post .entry-content h2 {
		margin: 28px 0 10px;
	}

	body.single-post .navigation.post-navigation .nav-links {
		grid-template-columns: 1fr;
	}

	body.single-post .navigation.post-navigation .nav-next {
		text-align: left;
	}
}

@media (max-width: 480px) {
	.mr-product-card {
		flex: 0 0 80%;
	}

	.mr-hero-actions {
		flex-direction: column;
		width: 100%;
	}

	.mr-hero-actions .mr-btn {
		width: 100%;
	}

	.mr-product-highlights,
	.mr-product-trustbar {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   11. COOKIE-CONSENT-BANNER
   ========================================================================== */

/* `[hidden]` loses to author rules that set `display` with equal specificity
   (e.g. .mr-cookie-banner-options { display: grid }), so re-assert it here. */
.mr-cookie-banner [hidden] {
	display: none;
}

.mr-footer-cookie-settings {
	background: none;
	border: none;
	padding: 0;
	color: rgba(255, 255, 255, 0.6);
	font-size: 13px;
	font-family: var(--mr-font-body);
	text-decoration: underline;
	cursor: pointer;
	transition: color 0.2s ease;
}

.mr-footer-cookie-settings:hover {
	color: var(--mr-color-white);
}

.mr-cookie-banner {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 999;
	background-color: var(--mr-color-white);
	border-top: 1px solid var(--mr-color-border);
	box-shadow: 0 -10px 30px rgba(45, 90, 39, 0.12);
}

.mr-cookie-banner-inner {
	max-width: var(--mr-container);
	margin: 0 auto;
	padding: 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
}

.mr-cookie-banner-text h2 {
	font-size: 18px;
	margin: 0 0 8px;
}

.mr-cookie-banner-text p {
	margin: 0;
	font-size: 14px;
	line-height: 1.7;
	color: var(--mr-color-gray);
	max-width: 720px;
}

.mr-cookie-banner-text p a {
	color: var(--mr-color-primary);
	text-decoration: underline;
}

.mr-cookie-banner-text p a:hover {
	color: var(--mr-color-primary-dark);
}

.mr-cookie-banner-options {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-top: 16px;
}

.mr-cookie-option {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px;
	border: 1px solid var(--mr-color-border);
	border-radius: var(--mr-radius);
	cursor: pointer;
}

.mr-cookie-option input {
	margin-top: 4px;
	accent-color: var(--mr-color-primary);
}

.mr-cookie-option strong {
	display: block;
	font-family: var(--mr-font-heading);
	color: var(--mr-color-primary-dark);
	font-size: 14px;
	margin-bottom: 4px;
}

.mr-cookie-option small {
	display: block;
	color: var(--mr-color-gray);
	font-size: 12px;
	line-height: 1.5;
}

.mr-cookie-banner-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	flex-shrink: 0;
}

.mr-cookie-banner-actions .mr-btn {
	padding: 12px 24px;
	font-size: 14px;
	white-space: nowrap;
}

@media (max-width: 1024px) {
	.mr-cookie-banner-inner {
		flex-direction: column;
		align-items: stretch;
	}

	.mr-cookie-banner-actions {
		justify-content: flex-start;
	}
}

@media (max-width: 600px) {
	.mr-cookie-banner-inner {
		padding: 20px;
	}

	.mr-cookie-banner-options {
		grid-template-columns: 1fr;
	}

	.mr-cookie-banner-actions .mr-btn {
		flex: 1 1 auto;
	}
}
