/* ==========================================================================
   Sovedyret Theme — Main Stylesheet
   Version: 1.0.0
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Custom Properties
   -------------------------------------------------------------------------- */

:root {
	/* Brand colours */
	--color-primary:        #1a7a4a;
	--color-primary-dark:   #135c38;
	--color-primary-light:  #e8f5ee;
	--color-accent:         #f0a500;
	--color-accent-dark:    #c88700;

	/* Neutrals */
	--color-text:           #1a1a1a;
	--color-text-muted:     #666666;
	--color-border:         #e0e0e0;
	--color-bg:             #ffffff;
	--color-bg-subtle:      #f7f7f7;
	--color-bg-dark:        #1a1a1a;

	/* Typography */
	--font-sans:            -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;
	--font-size-base:       16px;
	--line-height-base:     1.6;
	--font-size-sm:         0.875rem;
	--font-size-lg:         1.125rem;
	--font-size-xl:         1.25rem;
	--font-size-2xl:        1.5rem;
	--font-size-3xl:        2rem;

	/* Spacing */
	--space-xs:             0.25rem;
	--space-sm:             0.5rem;
	--space-md:             1rem;
	--space-lg:             1.5rem;
	--space-xl:             2rem;
	--space-2xl:            3rem;
	--space-3xl:            4rem;

	/* Layout */
	--container-max:        1280px;
	--container-padding:    1.25rem;
	--border-radius:        6px;
	--border-radius-lg:     12px;

	/* Shadows */
	--shadow-sm:            0 1px 3px rgba(0,0,0,.08);
	--shadow-md:            0 4px 12px rgba(0,0,0,.10);
	--shadow-lg:            0 8px 24px rgba(0,0,0,.12);

	/* Transitions */
	--transition-fast:      150ms ease;
	--transition-base:      250ms ease;
}

/* --------------------------------------------------------------------------
   2. Reset & Base
   -------------------------------------------------------------------------- */

*, *::before, *::after {
	box-sizing: border-box;
}

html {
	font-size: var(--font-size-base);
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: var(--line-height-base);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
}

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

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

a:hover, a:focus {
	text-decoration: underline;
	color: var(--color-primary-dark);
}

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 var(--space-md);
	line-height: 1.2;
	font-weight: 700;
	color: var(--color-text);
}

h1 { font-size: var(--font-size-3xl); }
h2 { font-size: var(--font-size-2xl); }
h3 { font-size: var(--font-size-xl); }
h4 { font-size: var(--font-size-lg); }

p {
	margin: 0 0 var(--space-md);
}

ul, ol {
	margin: 0 0 var(--space-md);
	padding-left: var(--space-lg);
}

table {
	border-collapse: collapse;
	width: 100%;
}

input, select, textarea, button {
	font-family: inherit;
	font-size: inherit;
}

/* --------------------------------------------------------------------------
   3. Accessibility
   -------------------------------------------------------------------------- */

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

.skip-link {
	position: absolute;
	top: -40px;
	left: var(--space-md);
	background: var(--color-primary);
	color: #fff;
	padding: var(--space-sm) var(--space-md);
	border-radius: var(--border-radius);
	z-index: 9999;
	transition: top var(--transition-fast);
}

.skip-link:focus {
	top: var(--space-md);
}

/* --------------------------------------------------------------------------
   4. Layout
   -------------------------------------------------------------------------- */

.container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}

.site-content {
	min-height: 60vh;
}

body:not(.home) .site-content {
	padding-top: var(--space-xl);
}

.main-content.has-sidebar > .container {
	display: grid;
	grid-template-columns: 1fr 280px;
	gap: var(--space-2xl);
	align-items: start;
}

.main-content.no-sidebar > .container {
	max-width: 1080px;
}

.content-area {
	min-width: 0; /* prevent grid blowout */
}

/* --------------------------------------------------------------------------
   5. Buttons
   -------------------------------------------------------------------------- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	padding: 0.625rem 1.25rem;
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1.2;
	border: 2px solid transparent;
	border-radius: var(--border-radius);
	cursor: pointer;
	transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
	text-decoration: none;
	white-space: nowrap;
}

.btn:focus-visible {
	outline: 3px solid var(--color-accent);
	outline-offset: 2px;
}

.btn--primary {
	background-color: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

.btn--primary:hover,
.btn--primary:focus {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff;
	text-decoration: none;
}

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

.btn--outline:hover,
.btn--outline:focus {
	background-color: var(--color-primary);
	color: #fff;
	text-decoration: none;
}

/* --------------------------------------------------------------------------
   6. Site Header
   -------------------------------------------------------------------------- */

.site-header {
	background: var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	position: sticky;
	top: 0;
	z-index: 200;
}

.site-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--space-lg);
	padding-block: var(--space-lg);
}

.site-header__logo a,
.site-header__site-title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	color: var(--color-text);
	text-decoration: none;
}

.site-header__logo img {
	max-height: 100px;
	width: auto;
}

.site-header__search {
	max-width: 480px;
	width: 100%;
	justify-self: center;
}

.site-header__search .search-field,
.site-header__search input[type="search"] {
	width: 100%;
	padding: 0.5rem 1rem;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	background: var(--color-bg-subtle);
	font-size: var(--font-size-sm);
	transition: border-color var(--transition-fast);
}

.site-header__search .search-field:focus,
.site-header__search input[type="search"]:focus {
	outline: none;
	border-color: var(--color-primary);
	background: var(--color-bg);
}

.site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

.site-header__cart {
	position: relative;
	display: flex;
	align-items: center;
	color: var(--color-text);
	padding: var(--space-xs);
}

.site-header__cart-count {
	position: absolute;
	top: -4px;
	right: -4px;
	background: var(--color-primary);
	color: #fff;
	font-size: 0.6875rem;
	font-weight: 700;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* --------------------------------------------------------------------------
   7. Navigation
   -------------------------------------------------------------------------- */

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

.site-nav .container {
	padding-block: 0;
}

.site-nav__menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0;
}

.site-nav__menu > li > a {
	display: block;
	padding: 0.75rem 1rem;
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
	text-decoration: none;
	transition: color var(--transition-fast), background-color var(--transition-fast);
}

.site-nav__menu > li > a:hover,
.site-nav__menu > li.current-menu-item > a,
.site-nav__menu > li.current-menu-ancestor > a {
	color: var(--color-primary);
	background-color: var(--color-primary-light);
}

/* Dropdown */
.site-nav__menu li {
	position: relative;
}

.site-nav__menu .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	box-shadow: var(--shadow-md);
	min-width: 200px;
	z-index: 100;
	padding: var(--space-xs) 0;
	list-style: none;
	margin: 0;
}

.site-nav__menu li:hover > .sub-menu,
.site-nav__menu li:focus-within > .sub-menu {
	display: block;
}

.site-nav__menu .sub-menu a {
	display: block;
	padding: 0.5rem 1rem;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	text-decoration: none;
}

.site-nav__menu .sub-menu a:hover {
	background: var(--color-bg-subtle);
	color: var(--color-primary);
}

/* Hamburger */
.mobile-menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	background: none;
	border: none;
	padding: var(--space-xs);
	cursor: pointer;
}

.hamburger-line {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--color-text);
	transition: transform var(--transition-fast), opacity var(--transition-fast);
}

/* Mobile menu */
.mobile-menu {
	display: none;
	background: var(--color-bg);
	border-top: 1px solid var(--color-border);
	padding: var(--space-md);
}

.mobile-menu.is-open {
	display: block;
}

.mobile-menu__list,
.mobile-menu__list .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-menu__list a {
	display: block;
	padding: 0.625rem 0;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-border);
	font-weight: 500;
}

.mobile-menu__list .sub-menu a {
	padding-left: var(--space-lg);
	font-weight: 400;
	font-size: var(--font-size-sm);
}

/* Nav caret button for touch dropdown (Phase 4, injected by JS) */
.nav-caret {
	background: none;
	border: none;
	padding: 4px 6px;
	cursor: pointer;
	color: var(--color-text-muted);
	vertical-align: middle;
	line-height: 1;
	display: inline-flex;
	align-items: center;
}
.site-nav__menu li.sub-open > .sub-menu { display: block; }
.nav-caret svg { transition: transform var(--transition-fast); }
.site-nav__menu li.sub-open > .nav-caret svg { transform: rotate(180deg); }

/* --------------------------------------------------------------------------
   8. Product Grid & Cards
   -------------------------------------------------------------------------- */

.products.columns-4,
ul.products.columns-4 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-lg);
	list-style: none;
	margin: 0 0 var(--space-xl);
	padding: 0;
}

.products.columns-3,
ul.products.columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.product-card {
	display: flex;
	flex-direction: column;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

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

.product-card__image-link {
	position: relative;
	display: block;
	aspect-ratio: 1;
	overflow: hidden;
	background: var(--color-bg-subtle);
}

.product-card__image-link img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: var(--space-sm);
	transition: transform var(--transition-base);
}

.product-card:hover .product-card__image-link img {
	transform: scale(1.04);
}

.product-card__body {
	flex: 1;
	padding: var(--space-md);
}

.product-card__title {
	font-size: 0.9375rem;
	font-weight: 600;
	margin: 0 0 var(--space-xs);
	line-height: 1.3;
}

.product-card__title a {
	color: var(--color-text);
	text-decoration: none;
}

.product-card__title a:hover {
	color: var(--color-primary);
}

.product-card__price-label {
	font-size: var(--font-size-sm);
	color: var(--color-primary);
	font-weight: 600;
	margin: var(--space-xs) 0 0;
}

.product-card__footer {
	padding: var(--space-sm) var(--space-md) var(--space-md);
}

.product-card__footer .btn,
.product-card__footer .button,
.product-card__footer .add_to_cart_button {
	width: 100%;
	justify-content: center;
}

/* Sale badge */
.onsale {
	position: absolute;
	top: var(--space-sm);
	left: var(--space-sm);
	background: var(--color-accent);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 999px;
	z-index: 1;
}

/* --------------------------------------------------------------------------
   9. Single Product
   -------------------------------------------------------------------------- */

.single-product-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto;
	gap: var(--space-2xl);
}

.woocommerce-product-gallery {
	position: relative;
}
/* FlexSlider gallery — replaces WooCommerce default gallery CSS (disabled via filter) */
.woocommerce-product-gallery__wrapper {
	transition: all cubic-bezier(.795, -.035, 0, 1) .5s;
	margin: 0;
	padding: 0;
}

.woocommerce-product-gallery__image:nth-child(n+2) {
	width: 25%;
	display: inline-block;
}

.woocommerce-product-gallery__image a {
	display: block;
}

.flex-control-thumbs {
	overflow: hidden;
	zoom: 1;
	margin: 0;
	padding: 0;
	list-style: none;
}

.flex-control-thumbs li {
	width: 25%;
	float: left;
	margin: 0;
	list-style: none;
}

.flex-control-thumbs li img {
	cursor: pointer;
	opacity: .5;
	margin: 0;
	display: block;
	width: 100%;
}

.flex-control-thumbs li img.flex-active,
.flex-control-thumbs li img:hover {
	opacity: 1;
}

.woocommerce-product-gallery--columns-4 .flex-control-thumbs li:nth-child(4n+1) {
	clear: left;
}


.single-product-layout__media {
	position: relative;
	grid-column: 1;
	grid-row: 1;
}

.single-product-layout__summary {
	grid-column: 2;
	grid-row: 1;
}

.single-product-layout__tabs {
	grid-column: 1 / -1;
	grid-row: 2;
}

/* Product title */
.single-product .product_title {
	font-size: var(--font-size-3xl);
	margin-bottom: var(--space-md);
}

/* Product price */
.single-product .price {
	font-size: var(--font-size-2xl);
	color: var(--color-primary);
	font-weight: 700;
	margin-bottom: var(--space-lg);
}

/* Add to cart / external product button */
.single-product .cart .single_add_to_cart_button,
.single-product a.single_add_to_cart_button {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	background-color: var(--color-primary);
	color: #fff;
	border: none;
	border-radius: var(--border-radius);
	padding: 0.875rem 1.75rem;
	font-size: 1.0625rem;
	font-weight: 700;
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--transition-fast);
}

.single-product .cart .single_add_to_cart_button:hover,
.single-product a.single_add_to_cart_button:hover {
	background-color: var(--color-primary-dark);
	text-decoration: none;
	color: #fff;
}

/* --------------------------------------------------------------------------
   10. Price Overview (Datafeedr / prisoversigt)
   -------------------------------------------------------------------------- */

.price-overview {
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	margin-bottom: var(--space-xl);
}

.price-overview__header {
	background: var(--color-bg-subtle);
	padding: var(--space-md) var(--space-lg);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
}

.price-overview__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin: 0;
}

.price-overview__trust-note {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin: 0;
}

/* Price overview row layout (Phase 3) is in woocommerce.css */

.price-overview--empty {
	padding: var(--space-xl);
}

.price-overview__fallback-text {
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

.price-overview__related-products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: var(--space-md);
}

/* --------------------------------------------------------------------------
   11. Sidebar
   -------------------------------------------------------------------------- */

.sidebar {
	min-width: 0;
}

.sidebar .widget {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: var(--space-lg);
	margin-bottom: var(--space-md);
}

.sidebar .widget__title {
	font-size: 1rem;
	font-weight: 700;
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 2px solid var(--color-primary);
}

.sidebar .widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.sidebar .widget ul li {
	padding: var(--space-xs) 0;
	border-bottom: 1px solid var(--color-border);
}

.sidebar .widget ul li:last-child {
	border-bottom: none;
}

.sidebar .widget ul li a {
	font-size: var(--font-size-sm);
	color: var(--color-text);
}

.sidebar .widget ul li a:hover {
	color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   12. Footer
   -------------------------------------------------------------------------- */

.site-footer {
	background: var(--color-bg-dark);
	color: #ccc;
	margin-top: var(--space-3xl);
	padding: var(--space-2xl) 0 var(--space-xl);
}

.site-footer a {
	color: #fff;
	text-decoration: none;
}

.site-footer a:hover {
	text-decoration: underline;
}

.site-footer__widgets {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--space-xl);
	margin-bottom: var(--space-2xl);
}

.site-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-md);
	padding-top: var(--space-lg);
	border-top: 1px solid rgba(255,255,255,.1);
	font-size: var(--font-size-sm);
}

.site-footer__nav {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer__disclaimer {
	color: #888;
	font-size: 0.75rem;
	margin: 0;
	width: 100%;
}

/* --------------------------------------------------------------------------
   13. Breadcrumb
   -------------------------------------------------------------------------- */

.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-xs);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

.breadcrumb a {
	color: var(--color-text-muted);
}

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

.breadcrumb__sep {
	color: var(--color-border);
}

/* --------------------------------------------------------------------------
   14. WooCommerce utility overrides
   -------------------------------------------------------------------------- */

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: var(--border-radius);
	padding: var(--space-md) var(--space-lg);
	margin-bottom: var(--space-md);
	list-style: none;
}

.woocommerce-message { background: var(--color-primary-light); border-left: 4px solid var(--color-primary); }
.woocommerce-error   { background: #fef2f2; border-left: 4px solid #dc2626; }
.woocommerce-info    { background: #eff6ff; border-left: 4px solid #2563eb; }

/* Ordering / result count */
.woocommerce-result-count {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
}

.woocommerce-ordering select {
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: var(--space-xs) var(--space-md);
	background: var(--color-bg);
}

/* Pagination */
.woocommerce-pagination {
	margin-top: var(--space-xl);
}

.woocommerce-pagination ul {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-pagination a,
.woocommerce-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: 0 var(--space-sm);
	font-size: var(--font-size-sm);
}

.woocommerce-pagination .current {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   15. Responsive
   -------------------------------------------------------------------------- */

@media (max-width: 1024px) {
	.products.columns-4,
	ul.products.columns-4 {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	:root {
		--font-size-3xl: 1.5rem;
		--font-size-2xl: 1.25rem;
	}

	.main-content.has-sidebar > .container {
		grid-template-columns: 1fr;
	}

	.sidebar {
		display: none; /* hidden on mobile — hamburger menu covers nav */
	}

	.products.columns-4,
	ul.products.columns-4,
	.products.columns-3,
	ul.products.columns-3 {
		grid-template-columns: repeat(2, 1fr);
	}

	.single-product-layout {
		grid-template-columns: 1fr;
	}

	.single-product-layout__media,
	.single-product-layout__summary {
		grid-column: 1;
	}

	.single-product-layout__media { grid-row: 1; }
	.single-product-layout__summary { grid-row: 2; }
	.single-product-layout__tabs { grid-row: 3; }

	.site-header__inner {
		grid-template-columns: auto auto;
	}

	.site-header__search {
		display: none; /* toggled in JS if needed */
	}

	.site-nav {
		display: none; /* replaced by mobile menu */
	}

	.mobile-menu-toggle {
		display: flex;
	}


	.site-footer__bottom {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (max-width: 480px) {
	.products.columns-4,
	ul.products.columns-4,
	.products.columns-3,
	ul.products.columns-3 {
		grid-template-columns: 1fr 1fr;
	}
}
/* ==========================================================================
   Sovedyret Theme — Additions & Optimisations
   Phase 6: Logo · Breadcrumb fix · Sale badge · Mega menu · Blog · Personality
   ========================================================================== */

/* --------------------------------------------------------------------------
   A. Typography upgrade — Fraunces for headings, Inter for body
   -------------------------------------------------------------------------- */

:root {
	--font-heading: 'Fraunces', Georgia, 'Times New Roman', serif;
	--font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	/* Warmer accent for personality */
	--color-accent:         #f59e0b;
	--color-accent-dark:    #d97706;
	/* Sale colour */
	--color-sale:           #dc2626;
	--color-sale-dark:      #b91c1c;
}

h1, h2, h3 {
	font-family: var(--font-heading);
	font-weight: 700;
}

h4, h5, h6 {
	font-family: var(--font-sans);
}

/* Page headings on archive / category pages */
.page-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-3xl);
	color: var(--color-text);
	margin-bottom: var(--space-lg);
}

/* --------------------------------------------------------------------------
   B. Logo SVG
   -------------------------------------------------------------------------- */

.site-header__logo-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}

.site-header__logo-link:hover,
.site-header__logo-link:focus {
	text-decoration: none;
	opacity: 0.85;
}

.site-logo-svg {
	display: block;
	overflow: visible;
}

/* --------------------------------------------------------------------------
   C. Breadcrumb — fixed alignment and proper styling
   -------------------------------------------------------------------------- */

/* WooCommerce wraps the nav in .woocommerce-breadcrumb — cover both classes */
.breadcrumb,
.woocommerce-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;   /* baseline keeps text and separators on the same line */
	gap: 0.25rem 0.375rem;
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	padding: 0.5rem 0;
	margin-bottom: var(--space-lg);
	line-height: 1.4;
}

.breadcrumb a,
.woocommerce-breadcrumb a {
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.breadcrumb a:hover,
.woocommerce-breadcrumb a:hover {
	color: var(--color-primary);
	text-decoration: underline;
}

.breadcrumb__sep,
.woocommerce-breadcrumb .sep {
	color: var(--color-border);
	user-select: none;
	padding: 0 0.1rem;
}

/* Ensure last crumb (current page) is slightly bolder */
.woocommerce-breadcrumb > span:last-of-type,
.breadcrumb > span:last-of-type {
	color: var(--color-text);
	font-weight: 500;
}

/* --------------------------------------------------------------------------
   D. Sale badge — prominent, red, percentage-based
   -------------------------------------------------------------------------- */

.onsale {
	position: absolute;
	top: var(--space-sm);
	left: var(--space-sm);
	background: var(--color-sale);
	color: #fff;
	font-family: var(--font-sans);
	font-size: 0.8125rem;
	font-weight: 800;
	line-height: 1;
	padding: 0.3125rem 0.625rem;
	border-radius: 4px;
	z-index: 2;
	letter-spacing: 0.01em;
	box-shadow: 0 2px 6px rgba(220, 38, 38, 0.35);
	pointer-events: none;
}

.onsale.onsale--pct {
	font-size: 0.9375rem;
	padding: 0.375rem 0.75rem;
}

/* Sale price strikethrough on product cards */
.product-card del,
.price del {
	color: var(--color-text-muted);
	font-size: 0.85em;
	opacity: 0.8;
}

.product-card ins,
.price ins {
	color: var(--color-sale);
	font-weight: 700;
	text-decoration: none;
}

/* Sale ribbon on single product */
.single-product .onsale {
	top: var(--space-md);
	left: var(--space-md);
	font-size: 1rem;
	padding: 0.5rem 1rem;
	border-radius: 6px;
}

/* --------------------------------------------------------------------------
   E. Navigation — mega menu upgrade
   -------------------------------------------------------------------------- */

/* First level: give nav items some breathing room */
.site-nav__menu > li > a {
	padding: 0.8125rem 1rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-text);
	white-space: nowrap;
}

/* Active item indicator */
.site-nav__menu > li.current-menu-item > a,
.site-nav__menu > li.current-menu-ancestor > a {
	color: var(--color-primary);
	background-color: transparent;
	border-bottom: 2px solid var(--color-primary);
}

.site-nav__menu > li > a:hover {
	color: var(--color-primary);
	background-color: transparent;
}

/* Mega dropdown — wide multi-column panel */
.site-nav__menu > li {
	position: static; /* Break out of the li scope for mega menus */
}

.site-nav__menu > li > .sub-menu {
	/* Full container width, aligned to container */
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	width: 100%;
	min-width: auto;
	background: var(--color-bg);
	border: none;
	border-top: 3px solid var(--color-primary);
	border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
	box-shadow: 0 8px 32px rgba(0,0,0,0.12);
	padding: var(--space-xl) 0;
	z-index: 300;
	/* Multi-column grid */
	display: none;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: var(--space-xs) var(--space-md);
	max-width: var(--container-max);
	margin-inline: auto;
}

/* Offset to align with container padding */
.site-nav > .container {
	position: relative;
}

.site-nav__menu > li:hover > .sub-menu,
.site-nav__menu > li:focus-within > .sub-menu,
.site-nav__menu > li.sub-open > .sub-menu {
	display: grid;
}

/* Sub-menu items */
.site-nav__menu > li > .sub-menu > li {
	position: relative;
}

.site-nav__menu > li > .sub-menu > li > a {
	display: block;
	padding: 0.375rem 0.875rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-text);
	border-radius: var(--border-radius);
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.site-nav__menu > li > .sub-menu > li > a:hover {
	background: var(--color-primary-light);
	color: var(--color-primary);
	text-decoration: none;
}

/* Third level: nested sub-sub-menu */
.site-nav__menu > li > .sub-menu > li > .sub-menu {
	position: absolute;
	left: 100%;
	top: 0;
	min-width: 180px;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	box-shadow: var(--shadow-md);
	padding: var(--space-xs) 0;
	z-index: 400;
	display: none;
}

.site-nav__menu > li > .sub-menu > li:hover > .sub-menu {
	display: block;
}

.site-nav__menu > li > .sub-menu > li > .sub-menu a {
	display: block;
	padding: 0.375rem 1rem;
	font-size: 0.8125rem;
	color: var(--color-text);
}

.site-nav__menu > li > .sub-menu > li > .sub-menu a:hover {
	background: var(--color-bg-subtle);
	color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   F. Blog grid — /artikler
   -------------------------------------------------------------------------- */

.post-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-xl);
	margin-bottom: var(--space-2xl);
}

.post-card {
	display: flex;
	flex-direction: column;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
	text-decoration: none;
}

.post-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-3px);
}

.post-card__image {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--color-bg-subtle);
}

.post-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-base);
}

.post-card:hover .post-card__image img {
	transform: scale(1.04);
}

/* Placeholder gradient when no thumbnail */
.post-card__image-placeholder {
	display: block;
	aspect-ratio: 16 / 9;
	background: linear-gradient(135deg, var(--color-primary-light) 0%, #d4eee0 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.post-card__image-placeholder svg {
	opacity: 0.3;
	width: 48px;
	height: 48px;
}

.post-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: var(--space-lg);
}

.post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	margin-bottom: var(--space-sm);
	flex-wrap: wrap;
}

.post-card__cat {
	display: inline-block;
	background: var(--color-primary-light);
	color: var(--color-primary);
	font-size: 0.75rem;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 999px;
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.post-card__cat:hover {
	background: var(--color-primary);
	color: #fff;
	text-decoration: none;
}

.post-card__date {
	font-size: 0.8125rem;
	color: var(--color-text-muted);
}

.post-card__title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.3;
	margin: 0 0 var(--space-sm);
}

.post-card__title a {
	color: var(--color-text);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.post-card__title a:hover {
	color: var(--color-primary);
}

.post-card__excerpt {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: 1.6;
	flex: 1;
	/* Clamp to 3 lines */
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.post-card__readmore {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin-top: var(--space-md);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-primary);
	text-decoration: none;
	transition: gap var(--transition-fast);
}

.post-card__readmore:hover {
	gap: 0.5rem;
	text-decoration: none;
}

/* Blog archive header */
.blog-archive-header {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-lg);
	border-bottom: 1px solid var(--color-border);
}

.blog-archive-header .page-title {
	margin-bottom: var(--space-xs);
}

.blog-archive-header .archive-description {
	color: var(--color-text-muted);
	font-size: var(--font-size-lg);
	margin: 0;
}

/* Single article styles */
article.single-post {
	max-width: none; /* grid layout handles width — no constraint needed */
}

.entry-header {
	margin-bottom: var(--space-xl);
}

.entry-title {
	font-family: var(--font-heading);
	font-size: 2.25rem;
	line-height: 1.2;
	margin-bottom: var(--space-sm);
}

.entry-meta {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	flex-wrap: wrap;
}

.entry-thumbnail {
	margin-bottom: var(--space-xl);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	aspect-ratio: 16 / 7;
}

.entry-thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.entry-content {
	font-size: 1.0625rem;
	line-height: 1.75;
}

.entry-content h2,
.entry-content h3 {
	margin-top: var(--space-2xl);
}

.entry-content img {
	border-radius: var(--border-radius);
	margin: var(--space-md) 0;
}

/* Posts navigation */
.posts-navigation {
	margin-top: var(--space-xl);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border);
	display: flex;
	justify-content: space-between;
	gap: var(--space-md);
}

.nav-links {
	display: flex;
	justify-content: space-between;
	width: 100%;
	gap: var(--space-md);
}

.nav-previous a,
.nav-next a {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   G. Single product — personality touches
   -------------------------------------------------------------------------- */

/* Product title in Fraunces for warmth */
.single-product .product_title {
	font-family: var(--font-heading);
	font-size: 2rem;
}

/* Sale price styling on product pages */
.single-product .price .woocommerce-Price-amount {
	color: var(--color-sale);
}

.single-product .price del .woocommerce-Price-amount {
	color: var(--color-text-muted);
}

/* Prisoversigt trust note personality */
.price-overview__trust-note {
	font-style: italic;
}

/* --------------------------------------------------------------------------
   H. Personality — section accents, micro-interactions
   -------------------------------------------------------------------------- */

/* Decorative underline on section headings */
.section-heading {
	font-family: var(--font-heading);
	position: relative;
	display: inline-block;
}

.section-heading::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 40%;
	height: 3px;
	background: var(--color-primary);
	border-radius: 2px;
}

/* Warm hover on product cards */
.product-card {
	border-color: transparent;
	box-shadow: var(--shadow-sm);
}

.product-card:hover {
	border-color: var(--color-primary-light);
	box-shadow: 0 6px 20px rgba(26, 122, 74, 0.12);
}

/* Category tiles charm (used on front-page) */
.cat-tile {
	transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.cat-tile:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0,0,0,0.16);
}

/* --------------------------------------------------------------------------
   I. Responsive updates
   -------------------------------------------------------------------------- */

@media (max-width: 1024px) {
	.post-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Mega menu: fewer columns on medium screens */
	.site-nav__menu > li > .sub-menu {
		grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	}
}

@media (max-width: 768px) {
	.post-grid {
		grid-template-columns: 1fr;
	}

	.entry-title {
		font-size: 1.75rem;
	}
}

/* --------------------------------------------------------------------------
   J. Breadcrumb container fix
   WooCommerce renders breadcrumb via woocommerce_before_main_content hook,
   outside our .container div. Apply container constraints to it directly.
   -------------------------------------------------------------------------- */

.woocommerce-breadcrumb {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
	padding-top: var(--space-md);
}

/* Remove the extra div wrapper WC adds above breadcrumb on archive pages */
.woocommerce-breadcrumb + .woocommerce-breadcrumb {
	display: none; /* prevent double breadcrumb */
}

/* ==========================================================================
   Fix patch — applied 2026-04-16
   Issues: search form layout, mega menu nested dropdown, blog grid cache bust
   ========================================================================== */

/* --------------------------------------------------------------------------
   Fix 1: Search form — inline flex layout
   WooCommerce product search form renders input + button.
   Force them into a flex row so the button sits beside the input.
   -------------------------------------------------------------------------- */

.site-header__search .woocommerce-product-search,
.site-header__search form {
	display: flex;
	align-items: center;
	gap: 0;
	width: 100%;
}

.site-header__search .search-field,
.site-header__search input[type="search"] {
	flex: 1;
	min-width: 0;
	border-radius: 999px 0 0 999px !important;
}

.site-header__search button[type="submit"],
.site-header__search [type="submit"] {
	flex-shrink: 0;
	padding: 0.5rem 1rem;
	background: var(--color-primary);
	color: #fff;
	border: 1px solid var(--color-primary);
	border-left: none;
	border-radius: 0 999px 999px 0;
	font-size: var(--font-size-sm);
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
	transition: background-color var(--transition-fast);
	line-height: 1.4;
}

.site-header__search button[type="submit"]:hover,
.site-header__search [type="submit"]:hover {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

/* --------------------------------------------------------------------------
   Fix 2: Mega menu — show level-3 items inline (no flyout)
   The Maerker and Kategorier menus have 3 levels:
     L1: Maerker / Kategorier
     L2: Column group headers (dashes or category group names)
     L3: Actual brands / sub-categories
   Previously level-3 was an absolute flyout that appeared off-screen.
   Now level-3 items are always visible inline beneath their L2 parent.
   -------------------------------------------------------------------------- */

/* Override: remove flyout from level 3 */
.site-nav__menu > li > .sub-menu > li > .sub-menu {
	position: static !important;
	display: block !important;
	left: auto !important;
	top: auto !important;
	min-width: 0 !important;
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	padding: 0.25rem 0 0 !important;
	z-index: auto !important;
}

/* Level 3 links */
.site-nav__menu > li > .sub-menu > li > .sub-menu a {
	display: block;
	padding: 0.25rem 0.875rem !important;
	font-size: 0.8rem !important;
	font-weight: 400 !important;
	color: var(--color-text) !important;
	border-radius: var(--border-radius);
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.site-nav__menu > li > .sub-menu > li > .sub-menu a:hover {
	background: var(--color-primary-light) !important;
	color: var(--color-primary) !important;
	text-decoration: none !important;
}

/* Level 2 group headers: style dash separators as subtle dividers */
.site-nav__menu > li > .sub-menu > li > a {
	display: block;
	font-size: 0.6875rem !important;
	font-weight: 800 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.07em !important;
	color: var(--color-text-muted) !important;
	padding: 0.25rem 0.875rem 0.375rem !important;
	border-bottom: 2px solid var(--color-border) !important;
	margin-bottom: 0.125rem !important;
	cursor: default;
	pointer-events: none;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
}

/* Hide the literal "-" text content — replace with a clean separator line */
.site-nav__menu > li > .sub-menu > li > a[href="#"] {
	font-size: 0 !important;    /* hide the dash text */
	padding: 0 0 0.25rem !important;
	border-bottom: 1px solid var(--color-border) !important;
	margin: 0 0.875rem 0.5rem !important;
}

/* --------------------------------------------------------------------------
   Fix 3: Mega menu grid — use flex-wrap columns so each L2 group
   forms its own column with L3 items expanding vertically beneath it.
   Replaces the auto-fill grid with a flex layout for more natural grouping.
   -------------------------------------------------------------------------- */

.site-nav__menu > li > .sub-menu {
	display: none;
	flex-wrap: wrap !important;
	gap: var(--space-md) var(--space-xl) !important;
	align-items: flex-start !important;
}

.site-nav__menu > li:hover > .sub-menu,
.site-nav__menu > li:focus-within > .sub-menu,
.site-nav__menu > li.sub-open > .sub-menu {
	display: flex !important;
}

.site-nav__menu > li > .sub-menu > li {
	min-width: 140px;
	flex: 0 0 auto;
}

/* --------------------------------------------------------------------------
   Fix 4: Logo image sizing
   When using the_custom_logo(), ensure the image is properly constrained.
   -------------------------------------------------------------------------- */

.site-header__logo .custom-logo-link img,
.site-header__logo .custom-logo {
	max-height: 100px;
	width: auto;
	display: block;
}

/* --------------------------------------------------------------------------
   Category/taxonomy bottom description (term-description)
   Now rendered inside .content-area via woocommerce_after_shop_loop hook.
   -------------------------------------------------------------------------- */

.term-description {
	padding-block: var(--space-2xl);
	border-top: 1px solid var(--color-border);
	font-size: 1rem;
	line-height: 1.75;
	color: var(--color-text);
}

.term-description h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	margin-bottom: var(--space-md);
	margin-top: var(--space-2xl);
}

.term-description ul {
	padding-left: 1.5rem;
}

.term-description ul li {
	margin-bottom: var(--space-sm);
}

/* --------------------------------------------------------------------------
   Fix 6: Automated brands (mærker) archive page template
   -------------------------------------------------------------------------- */

.brands-archive-header {
	margin-bottom: var(--space-2xl);
}

.brands-letter-nav {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
	margin-bottom: var(--space-2xl);
}

.brands-letter-nav__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-primary);
	text-decoration: none;
	transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.brands-letter-nav__link:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	text-decoration: none;
}

.brands-seo-text {
	margin-top: var(--space-3xl);
	padding-top: var(--space-2xl);
	border-top: 1px solid var(--color-border);
}

.brands-seo-text h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	margin-bottom: var(--space-lg);
}

.brands-seo-text ul {
	list-style: disc;
	padding-left: 1.5rem;
	color: var(--color-text-muted);
	line-height: 1.75;
}

.brands-seo-text ul li {
	margin-bottom: var(--space-sm);
}

.brands-letter-group {
	margin-bottom: var(--space-2xl);
}

.brands-letter-heading {
	font-family: var(--font-heading);
	font-size: 1.75rem;
	color: var(--color-primary);
	border-bottom: 2px solid var(--color-border);
	padding-bottom: var(--space-sm);
	margin-bottom: var(--space-lg);
}

.brands-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-lg);
}

@media (max-width: 900px) {
	.brands-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 600px) {
	.brands-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Category card — used in brands-grid items */
.brands-grid__item {
	list-style: none;
}

.category-card__link {
	display: flex;
	flex-direction: column;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
	height: 100%;
}

.category-card__link:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
	text-decoration: none;
}

.category-card__image {
	width: 100%;
	aspect-ratio: 1 / 1;
	background: var(--color-bg-subtle);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-md);
	overflow: hidden;
}

.category-card__img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: transform var(--transition-base);
}

.category-card__link:hover .category-card__img {
	transform: scale(1.05);
}

.category-card__body {
	padding: var(--space-sm) var(--space-md) var(--space-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.category-card__name {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--color-text);
	margin: 0;
	line-height: 1.3;
}

.category-card__count {
	font-size: 0.8rem;
	color: var(--color-text-muted);
	margin: 0;
}

/* --------------------------------------------------------------------------
   Related Products Sidebar (single blog posts)
   -------------------------------------------------------------------------- */

/* Remove max-width constraint — grid handles width in 2-col layout */
.single-has-sidebar .single-post {
	max-width: none;
	margin-inline: 0;
}

/* Make the blog post sidebar a bit wider */
.single-has-sidebar.main-content.has-sidebar > .container {
	grid-template-columns: 1fr 300px;
}

.related-sidebar__header {
	padding-bottom: var(--space-md);
	border-bottom: 2px solid var(--color-primary);
	margin-bottom: var(--space-lg);
}

.related-sidebar__title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
}

.related-sidebar__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.related-sidebar__item {
	border-bottom: 1px solid var(--color-border);
	padding-bottom: var(--space-xl);
}

.related-sidebar__item:last-child {
	border-bottom: none;
}

.related-sidebar__link {
	display: flex;
	gap: var(--space-sm);
	text-decoration: none;
	color: inherit;
	align-items: flex-start;
}

.related-sidebar__link:hover .related-sidebar__name {
	color: var(--color-primary);
}

.related-sidebar__img {
	flex-shrink: 0;
	width: 72px;
	height: 72px;
	border-radius: var(--border-radius);
	overflow: hidden;
	background: var(--color-bg-subtle);
}

.related-sidebar__img img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.related-sidebar__info {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.related-sidebar__name {
	font-size: var(--font-size-sm);
	font-weight: 600;
	line-height: 1.4;
	color: var(--color-text);
	transition: color var(--transition-fast);
}

.related-sidebar__price {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
}

.related-sidebar__price .woocommerce-Price-amount {
	font-weight: 700;
	color: var(--color-primary);
}

.related-sidebar__cta {
	margin-top: 4px;
	font-size: 0.75rem;
	padding: 0.3rem 0.75rem;
	align-self: flex-start;
}

/* Sticky sidebar on scroll */
.single-has-sidebar .sidebar--related-products {
	position: sticky;
	top: var(--space-xl);
}

@media (max-width: 768px) {
	.single-has-sidebar.main-content.has-sidebar > .container {
		grid-template-columns: 1fr;
	}
	.single-has-sidebar .sidebar--related-products {
		position: static;
		padding-top: var(--space-xl);
		border-top: 1px solid var(--color-border);
	}
}
/* ==========================================================================
   Sovedyret — Personality & Charm CSS
   Micro-interactions, delight details, warmth.
   ========================================================================== */

/* ── Scroll progress bar ─────────────────────────────────────────── */
#scroll-progress {
	position: fixed;
	top: 0;
	left: 0;
	height: 3px;
	width: 100%;
	transform: scaleX(0);
	transform-origin: left center;
	background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
	z-index: 9999;
	border-radius: 0 2px 2px 0;
	will-change: transform;
	pointer-events: none;
}

/* ── Hero greeting ───────────────────────────────────────────────── */
.hero__greeting {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(255,255,255,.75);
	margin-bottom: var(--space-sm);
	letter-spacing: .02em;
	animation: greetFadeIn .8s ease forwards;
}

@keyframes greetFadeIn {
	from { opacity: 0; transform: translateY(-8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ── Hero price cards — floating animation ──────────────────────── */
.hero__price-card--1 {
	animation: cardFloat1 4s ease-in-out infinite;
}
.hero__price-card--2 {
	animation: cardFloat2 4s ease-in-out 0.8s infinite;
}
.hero__price-card--3 {
	animation: cardFloat3 4s ease-in-out 1.6s infinite;
}

@keyframes cardFloat1 {
	0%, 100% { transform: translateY(0px); }
	50%       { transform: translateY(-8px); }
}
@keyframes cardFloat2 {
	0%, 100% { transform: translateY(0px); }
	50%       { transform: translateY(-6px); }
}
@keyframes cardFloat3 {
	0%, 100% { transform: translateY(0px); }
	50%       { transform: translateY(-5px); }
}

/* ── "Bedste pris" label — subtle sparkle ───────────────────────── */
.hero__price-card--1::after {
	content: '✦';
	position: absolute;
	top: -10px;
	right: -8px;
	font-size: 1rem;
	color: var(--color-accent);
	animation: sparkle 2s ease-in-out infinite;
}

@keyframes sparkle {
	0%, 100% { opacity: .4; transform: scale(.8) rotate(0deg); }
	50%       { opacity: 1;  transform: scale(1.2) rotate(20deg); }
}

/* ── Fade-up entrance animations ───────────────────────────────── */
.fade-up {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .5s ease, transform .5s ease;
}
.fade-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* ── Brand cards — enhanced hover ───────────────────────────────── */
.brand-card {
	transition: transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .2s ease !important;
	will-change: transform;
	cursor: pointer;
}
.brand-card:hover {
	transform: translateY(-6px) scale(1.03) !important;
	box-shadow: 0 12px 32px rgba(26,122,74,.18) !important;
	border-color: var(--color-primary) !important;
}
.brand-card:hover .brand-card__image img {
	transform: scale(1.08);
	transition: transform .3s ease;
}
.brand-card__image img {
	transition: transform .3s ease;
}

/* ── Product showcase cards — hover depth ───────────────────────── */
.showcase-card {
	transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s ease !important;
	will-change: transform;
}
.showcase-card:hover {
	box-shadow: 0 16px 48px rgba(0,0,0,.14) !important;
}

/* ── Category tiles — warm overlay ─────────────────────────────── */
.category-tile {
	transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease !important;
}
.category-tile:hover {
	transform: scale(1.04) translateY(-4px) !important;
	box-shadow: 0 20px 48px rgba(26,122,74,.25) !important;
}

/* ── "Se alle mærker" link — arrow bounce ───────────────────────── */
.section__link {
	position: relative;
	transition: color .2s ease;
}
.section__link::after {
	content: ' →';
	display: inline-block;
	transition: transform .2s ease;
}
.section__link:hover::after {
	transform: translateX(4px);
}

/* ── Trust bar savings ticker ────────────────────────────────────── */
.savings-ticker {
	color: var(--color-primary);
	display: inline-block;
	transition: opacity .2s ease, transform .2s ease;
}
.savings-ticker.ticker-flip {
	opacity: 0;
	transform: translateY(-6px);
}

/* ── Navigation links — fun underline ───────────────────────────── */
.site-nav__menu > li > a {
	position: relative;
}
.site-nav__menu > li > a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--color-primary);
	border-radius: 2px;
	transition: width .25s ease;
}
.site-nav__menu > li > a:hover::after,
.site-nav__menu > li.current-menu-item > a::after {
	width: 100%;
}

/* ── "Se pris" button — arrow slide ─────────────────────────────── */
.btn--primary {
	overflow: hidden;
	position: relative;
}
.btn--primary::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(255,255,255,.12);
	transform: translateX(-100%);
	transition: transform .3s ease;
}
.btn--primary:hover::before {
	transform: translateX(0);
}

/* ── How-steps — hover accent ────────────────────────────────────── */
.how-step {
	transition: transform .3s ease !important;
}
.how-step:hover {
	transform: translateY(-6px) !important;
}
.how-step__number {
	transition: background-color .3s ease, transform .3s ease;
}
.how-step:hover .how-step__number {
	background-color: var(--color-accent);
	transform: scale(1.15) rotate(-5deg);
}

/* ── Easter egg popup ─────────────────────────────────────────── */
.easter-egg {
	position: fixed;
	bottom: var(--space-xl);
	right: var(--space-xl);
	background: #fff;
	border: 2px solid var(--color-accent);
	border-radius: var(--border-radius-lg);
	padding: var(--space-md) var(--space-lg);
	box-shadow: 0 8px 32px rgba(0,0,0,.18);
	font-size: 0.9375rem;
	line-height: 1.5;
	z-index: 9999;
	opacity: 0;
	transform: translateY(16px) scale(.9);
	transition: opacity .3s ease, transform .3s ease;
	max-width: 280px;
}
.easter-egg--show {
	opacity: 1;
	transform: translateY(0) scale(1);
}
.easter-egg strong {
	display: block;
	margin-bottom: 4px;
	font-size: 1rem;
}

/* ── Footer personality ──────────────────────────────────────────── */
.site-footer {
	position: relative;
}
.site-footer::before {
	content: '🌙';
	position: absolute;
	top: var(--space-lg);
	right: var(--space-2xl);
	font-size: 1.5rem;
	opacity: .18;
	animation: moonFloat 6s ease-in-out infinite;
}

@keyframes moonFloat {
	0%, 100% { transform: translateY(0) rotate(0deg); }
	50%       { transform: translateY(-8px) rotate(8deg); }
}

/* ── Header logo — subtle hover ──────────────────────────────────── */
.site-header__logo a,
.custom-logo-link {
	display: inline-block;
	transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.site-header__logo a:hover,
.custom-logo-link:hover {
	transform: scale(1.06) rotate(-1deg);
}

/* ── Reduce motion ───────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
	.hero__price-card--1,
	.hero__price-card--2,
	.hero__price-card--3,
	.hero__price-card--1::after,
	.hero__greeting,
	.fade-up,
	.site-footer::before {
		animation: none !important;
		transition: none !important;
	}
	.fade-up { opacity: 1; transform: none; }
}

/* ==========================================================================
   SOV-29: Design Optimisations — Search page, Footer, Aesthetic
   ========================================================================== */

/* --------------------------------------------------------------------------
   Search Results Page
   -------------------------------------------------------------------------- */

.search-results-page {
	padding-top: var(--space-2xl);
}

.search-content-area {
	max-width: 100%;
}

/* Hero */
.search-hero {
	margin-bottom: var(--space-xl);
}

.search-hero__inner {
	max-width: 700px;
}

.search-hero__label {
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-bottom: var(--space-xs);
}

.search-hero__title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-family: var(--font-serif);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	line-height: 1.2;
}

.search-hero__query {
	color: var(--color-primary);
}

.search-hero__form {
	max-width: 540px;
}

/* Category nudge chips */
.search-cat-nudge {
	margin-bottom: var(--space-xl);
	padding: var(--space-md) var(--space-lg);
	background: var(--color-primary-light);
	border-radius: var(--border-radius-lg);
	border-left: 3px solid var(--color-primary);
}

.search-cat-nudge__label {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-sm);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.search-cat-nudge__chips {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs) var(--space-sm);
}

.search-cat-chip {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: 0.35rem 0.85rem;
	background: #fff;
	color: var(--color-primary-dark);
	border: 1.5px solid var(--color-primary);
	border-radius: 2rem;
	font-size: 0.85rem;
	font-weight: 600;
	text-decoration: none;
	transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

.search-cat-chip:hover {
	background: var(--color-primary);
	color: #fff;
	transform: translateY(-1px);
}

.search-cat-chip__count {
	background: var(--color-primary-light);
	color: var(--color-primary-dark);
	border-radius: 1rem;
	padding: 0.1rem 0.45rem;
	font-size: 0.72rem;
	font-weight: 700;
}

.search-cat-chip:hover .search-cat-chip__count {
	background: rgba(255,255,255,.25);
	color: #fff;
}

/* Search sections */
.search-section {
	margin-bottom: var(--space-3xl);
}

.search-section__title {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom: 2px solid var(--color-border);
}

.search-section__title svg {
	color: var(--color-primary);
	flex-shrink: 0;
}

.search-section__count {
	font-size: 0.8rem;
	font-weight: 500;
	color: var(--color-text-muted);
	margin-left: auto;
}

.search-section__more {
	margin-top: var(--space-lg);
	text-align: center;
}

.search-product-grid {
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

/* No results */
.search-no-results {
	text-align: center;
	padding: var(--space-3xl) 0;
}

.search-no-results__icon {
	font-size: 3rem;
	margin-bottom: var(--space-md);
	opacity: 0.5;
}

.search-no-results__title {
	font-family: var(--font-serif);
	font-size: 1.4rem;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
}

.search-no-results__text {
	color: var(--color-text-muted);
	margin-bottom: var(--space-xl);
}

.search-no-results__form {
	max-width: 480px;
	margin: 0 auto var(--space-xl);
}

.search-no-results__cats-label {
	font-size: 0.85rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-sm);
}

.search-cat-nudge--fallback {
	background: var(--color-bg-subtle);
	border-left-color: var(--color-border);
	max-width: 600px;
	margin: 0 auto;
}

.search-cat-nudge--fallback .search-cat-nudge__label {
	color: var(--color-text-muted);
}

.search-cat-nudge--fallback .search-cat-chip {
	border-color: var(--color-border);
	color: var(--color-text);
}

.search-cat-nudge--fallback .search-cat-chip:hover {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   Footer — Multi-column redesign
   -------------------------------------------------------------------------- */

.site-footer__main {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: var(--space-2xl);
	padding-bottom: var(--space-2xl);
	border-bottom: 1px solid rgba(255,255,255,.1);
	margin-bottom: var(--space-xl);
}

.site-footer__brand-name {
	display: block;
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 700;
	color: #fff;
	text-decoration: none;
	margin-bottom: var(--space-sm);
	letter-spacing: -0.02em;
}

.site-footer__tagline {
	font-size: 0.85rem;
	color: #aaa;
	line-height: 1.6;
	margin-bottom: var(--space-md);
}

.site-footer__trust-badges {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.site-footer__trust-badge {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: 0.78rem;
	color: #aaa;
}

.site-footer__trust-badge svg {
	color: var(--color-primary);
	flex-shrink: 0;
}

.site-footer__col-title {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #fff;
	margin-bottom: var(--space-md);
}

.site-footer__col-links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.site-footer__col-links li a,
.site-footer__col-links a {
	color: #aaa;
	font-size: 0.85rem;
	text-decoration: none;
	transition: color var(--transition-fast);
	display: inline-block;
}

.site-footer__col-links li a:hover,
.site-footer__col-links a:hover {
	color: #fff;
	text-decoration: none;
}

.site-footer__see-all {
	color: var(--color-primary) !important;
	margin-top: var(--space-xs);
}

.site-footer__see-all:hover {
	color: var(--color-primary-light) !important;
}

/* Override old bottom layout */
.site-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-sm);
	font-size: 0.8rem;
}

.site-footer__copy {
	color: #888;
}

.site-footer__disclaimer {
	color: #666;
	font-size: 0.75rem;
	margin: 0;
}

@media (max-width: 900px) {
	.site-footer__main {
		grid-template-columns: 1fr 1fr;
	}
	.site-footer__brand {
		grid-column: 1 / -1;
	}
}

@media (max-width: 540px) {
	.site-footer__main {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}
}

/* --------------------------------------------------------------------------
   Logo SVG — green wordmark (matches brand primary)
   -------------------------------------------------------------------------- */

.site-header__logo .site-logo-svg text {
	fill: var(--color-primary) !important;
}

/* --------------------------------------------------------------------------
   Homepage — aesthetic warmth for mothers
   Softer rounded corners on product cards, warmer hover tones
   -------------------------------------------------------------------------- */

/* Brand cards — slightly warmer border on hover */
.brand-card:hover {
	border-color: var(--color-primary);
	box-shadow: 0 4px 20px rgba(26,122,74,.12);
}

/* Category tiles — slightly warmer overlay */
.category-tile__overlay {
	background: linear-gradient(135deg, rgba(26,122,74,.55) 0%, rgba(26,122,74,.30) 100%);
}

/* Showcase card CTA — more prominent */
.showcase-card__cta.btn--primary {
	width: 100%;
	justify-content: center;
	margin-top: var(--space-sm);
}

/* Trust bar — warmer accent color on number */
.trust-bar__item strong,
.trust-bar .strong {
	color: var(--color-primary);
}

/* Blog post cards — subtle left accent on hover */
.post-card {
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.post-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-md);
}

/* --------------------------------------------------------------------------
   Blog archive — improved header
   -------------------------------------------------------------------------- */

.blog-archive-header {
	margin-bottom: var(--space-xl);
}

.blog-archive-header .page-title {
	font-size: clamp(1.5rem, 3vw, 2.2rem);
}

.archive-description {
	color: var(--color-text-muted);
	max-width: 600px;
	margin-top: var(--space-sm);
}

/* --------------------------------------------------------------------------
   Barnevogne menu — styled auto-linked headings
   -------------------------------------------------------------------------- */

.site-nav__menu > li > .sub-menu > li > a.auto-linked {
	color: var(--color-primary) !important;
	font-weight: 600 !important;
	pointer-events: auto !important;
	font-size: 0.8rem !important;
}

.site-nav__menu > li > .sub-menu > li > a.auto-linked:hover {
	color: var(--color-primary-dark) !important;
	text-decoration: underline;
}

/* --------------------------------------------------------------------------
   Reduce motion — extended
   -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
	.search-cat-chip,
	.post-card,
	.brand-card {
		transition: none !important;
		transform: none !important;
	}
}

/* Search page product grid — needs display:grid since homepage.css not loaded */
.search-product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
	gap: var(--space-lg);
}

/* Showcase card base styles for non-homepage contexts */
.search-product-grid .showcase-card {
	display: flex;
	flex-direction: column;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.search-product-grid .showcase-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.search-product-grid .showcase-card__image-link {
	position: relative;
	display: block;
	aspect-ratio: 1;
	background: var(--color-bg-subtle);
	overflow: hidden;
}

.search-product-grid .showcase-card__image-link img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: var(--space-md);
	transition: transform var(--transition-base);
}

.search-product-grid .showcase-card:hover .showcase-card__image-link img {
	transform: scale(1.05);
}

.search-product-grid .showcase-card__body {
	padding: var(--space-md);
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: var(--space-xs);
}

.search-product-grid .showcase-card__title {
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1.3;
	margin: 0;
}

.search-product-grid .showcase-card__title a {
	color: var(--color-text);
	text-decoration: none;
}

.search-product-grid .showcase-card__price-row {
	display: flex;
	align-items: baseline;
	gap: var(--space-xs);
	flex-wrap: wrap;
}

.search-product-grid .showcase-card__price {
	font-weight: 700;
	color: var(--color-primary);
}

.search-product-grid .showcase-card__from {
	font-size: 0.75rem;
	color: var(--color-text-muted);
}

.search-product-grid .showcase-card__was-price {
	font-size: 0.8rem;
	color: var(--color-text-muted);
}

.search-product-grid .showcase-card__cta {
	margin-top: auto;
	display: block;
	text-align: center;
}

.search-product-grid .showcase-card__no-image {
	width: 100%;
	aspect-ratio: 1;
	background: var(--color-bg-subtle);
}

@media (max-width: 600px) {
	.search-product-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* --------------------------------------------------------------------------
   Mega menu column headers: JS marks col headers as .nav-col-header
   and separators as .nav-sep-item. Override the [href="#"] hide rule.
   -------------------------------------------------------------------------- */

/* Column section headers — show with uppercase muted label style */
.site-nav__menu > li > .sub-menu > li.nav-col-header > a {
	font-size: 0.6875rem !important;
	font-weight: 800 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.07em !important;
	color: var(--color-text-muted) !important;
	padding: 0.25rem 0.875rem 0.375rem !important;
	border-bottom: 2px solid var(--color-border) !important;
	margin-bottom: 0.125rem !important;
	cursor: default !important;
	pointer-events: none !important;
}

/* Separator dashes — keep hidden */
.site-nav__menu > li > .sub-menu > li.nav-sep-item > a {
	font-size: 0 !important;
	padding: 0 0 0.25rem !important;
	border-bottom: 1px solid var(--color-border) !important;
	margin: 0 0.875rem 0.5rem !important;
}

/* ==========================================================================
   Contact Page
   ========================================================================== */

.contact-hero {
	background: linear-gradient(135deg, var(--color-primary-light) 0%, #f0f9f4 100%);
	padding: var(--space-3xl) 0 var(--space-2xl);
	text-align: center;
	border-bottom: 1px solid var(--color-border);
}

.contact-hero__eyebrow {
	font-size: var(--font-size-sm);
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin: 0 0 var(--space-sm);
}

.contact-hero__title {
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 auto var(--space-md);
	max-width: 600px;
	line-height: 1.2;
}

.contact-hero__sub {
	font-size: var(--font-size-lg);
	color: var(--color-text-muted);
	margin: 0 auto;
	max-width: 520px;
}

.contact-body {
	padding: var(--space-3xl) 0;
}

.contact-grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: var(--space-2xl);
	align-items: start;
}

@media (max-width: 900px) {
	.contact-grid {
		grid-template-columns: 1fr;
	}
	.contact-info {
		order: -1;
	}
}

.contact-form-wrap__heading {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-lg);
}

.contact-notice {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
	padding: var(--space-md) var(--space-lg);
	border-radius: var(--border-radius);
	margin-bottom: var(--space-lg);
	font-size: var(--font-size-sm);
	font-weight: 500;
	line-height: 1.5;
}

.contact-notice svg {
	flex-shrink: 0;
	margin-top: 1px;
}

.contact-notice--success {
	background: var(--color-primary-light);
	color: var(--color-primary-dark);
	border: 1px solid #b6dfc6;
}

.contact-notice--error {
	background: #fdf2f1;
	color: #9b1c15;
	border: 1px solid #f9c0bd;
}

.contact-form__row--two {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-md);
}

@media (max-width: 580px) {
	.contact-form__row--two {
		grid-template-columns: 1fr;
	}
}

.contact-form__field {
	margin-bottom: var(--space-md);
}

.contact-form__field label {
	display: block;
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: var(--space-xs);
}

.contact-form__field label span {
	color: var(--color-primary);
}

.contact-form__field input,
.contact-form__field textarea {
	width: 100%;
	padding: 0.65rem 0.875rem;
	font-size: 1rem;
	font-family: var(--font-sans);
	color: var(--color-text);
	background: var(--color-bg);
	border: 1.5px solid var(--color-border);
	border-radius: var(--border-radius);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	outline: none;
	-webkit-appearance: none;
	appearance: none;
}

.contact-form__field input:focus,
.contact-form__field textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(26,122,74,.12);
}

.contact-form__field textarea {
	resize: vertical;
	min-height: 140px;
	line-height: 1.6;
}

.contact-form__submit {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	margin-top: var(--space-sm);
}

.contact-info {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.contact-card {
	background: var(--color-bg-subtle);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--space-lg);
}

.contact-card--highlight {
	background: var(--color-primary);
	border-color: var(--color-primary-dark);
	color: #fff;
}

.contact-card__icon {
	width: 44px;
	height: 44px;
	background: var(--color-bg);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-sm);
	box-shadow: var(--shadow-sm);
}

.contact-card--highlight .contact-card__icon {
	background: rgba(255,255,255,.15);
	box-shadow: none;
}

.contact-card__title {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 var(--space-xs);
	color: inherit;
}

.contact-card__body {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin: 0;
	line-height: 1.7;
}

.contact-card--highlight .contact-card__body {
	color: rgba(255,255,255,.85);
}

.contact-card__body a {
	color: var(--color-primary);
	font-weight: 500;
}

.contact-card--highlight .contact-card__body a {
	color: #fff;
	text-decoration: underline;
}

/* --------------------------------------------------------------------------
   Shop archive — left sidebar layout & subcategory nav
   -------------------------------------------------------------------------- */

/* Override default right-sidebar grid: sidebar goes left on shop/category pages */
.shop-archive.main-content.has-sidebar > .container {
	grid-template-columns: 220px 1fr;
}

/* Subcategory navigation (cat-nav) */
.cat-nav {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	overflow: hidden;
}

.cat-nav__header {
	padding: var(--space-md) var(--space-lg);
	background: var(--color-primary);
}

.cat-nav__title {
	display: block;
	font-size: 0.9375rem;
	font-weight: 700;
	color: #fff;
	text-decoration: none;
	letter-spacing: 0.01em;
}

.cat-nav__title:hover {
	color: rgba(255,255,255,.85);
	text-decoration: none;
}

.cat-nav__list {
	list-style: none;
	margin: 0;
	padding: var(--space-xs) 0;
}

.cat-nav__item {
	border-bottom: 1px solid var(--color-border);
}

.cat-nav__item:last-child {
	border-bottom: none;
}

.cat-nav__item--active {
	background: var(--color-primary-light);
}

.cat-nav__link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-xs);
	padding: 0.55rem var(--space-lg);
	font-size: 0.875rem;
	color: var(--color-text);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.cat-nav__link:hover {
	background: var(--color-primary-light);
	color: var(--color-primary);
	text-decoration: none;
}

.cat-nav__link--active {
	color: var(--color-primary);
	font-weight: 600;
}

.cat-nav__count {
	flex-shrink: 0;
	font-size: 0.75rem;
	color: var(--color-text-muted);
	background: var(--color-bg-subtle);
	border-radius: 99px;
	padding: 0.1em 0.5em;
	min-width: 1.5em;
	text-align: center;
}

.cat-nav__item--active .cat-nav__count {
	background: rgba(26,122,74,.12);
	color: var(--color-primary);
}

/* Shop section divider — full-width banner between subcategory tiles and products */
.shop-section-divider {
	display: block;
	width: 100%;
	background: var(--color-primary-light);
	border-radius: var(--border-radius);
	padding: var(--space-sm) var(--space-lg);
	margin: var(--space-xl) 0 var(--space-md);
	border-left: 4px solid var(--color-primary);
}

.shop-section-divider__label {
	display: block;
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

/* Ordering bar below the Produkter divider */
.shop-ordering-bar {
	display: flex;
	justify-content: flex-end;
	margin-bottom: var(--space-md);
}
.shop-ordering-bar .woocommerce-ordering { margin-bottom: 0; }

/* Mobile: stack sidebar below content on small screens */
@media (max-width: 768px) {
	.shop-archive.main-content.has-sidebar > .container {
		grid-template-columns: 1fr;
	}
	.cat-nav-sidebar {
		order: 2;
	}
	.shop-archive .content-area {
		order: 1;
	}
}

/* =========================================================
   Affiliate trust bar — single product page
   ========================================================= */

.affiliate-trust-bar {
	margin: var(--space-md) 0 var(--space-lg);
	padding: var(--space-sm) var(--space-md);
	background: var(--color-bg-subtle);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	align-items: center;
	justify-content: space-between;
}

.affiliate-trust-bar__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.affiliate-trust-bar__item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 0.8125rem;
	color: var(--color-text-muted);
}

.affiliate-trust-bar__item svg {
	flex-shrink: 0;
	color: var(--color-primary);
}

.affiliate-trust-bar__scroll-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-primary);
	text-decoration: none;
	white-space: nowrap;
	transition: color var(--transition-fast);
}

.affiliate-trust-bar__scroll-link:hover {
	color: var(--color-primary-dark);
}

@media (max-width: 480px) {
	.affiliate-trust-bar {
		flex-direction: column;
		align-items: flex-start;
	}
}


/* ==========================================================================
   Fix patch — 2026-04-18
   Breadcrumb grid placement in single-product-layout + category tags
   ========================================================================== */

/* Breadcrumb must be row 1 spanning full width; shift media/summary/tabs down */
.single-product-layout > .breadcrumb {
	grid-column: 1 / -1;
	grid-row: 1;
}

.single-product-layout__media {
	grid-row: 2;
}

.single-product-layout__summary {
	grid-row: 2;
}

.single-product-layout__tabs {
	grid-row: 3;
}

/* Category tags */
.product-categories {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
	margin-top: var(--space-sm);
}

.product-category-tag {
	display: inline-block;
	padding: 0.25rem 0.625rem;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	font-size: 0.8125rem;
	color: var(--color-text-muted);
	text-decoration: none;
	transition: border-color var(--transition-fast), color var(--transition-fast);
}

.product-category-tag:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
	text-decoration: none;
}

@media (max-width: 768px) {
	.single-product-layout__media  { grid-row: 2; }
	.single-product-layout__summary { grid-row: 3; }
	.single-product-layout__tabs   { grid-row: 4; }
}
