/**
 * Posebyen Helse - Premium Design System
 * Agency-quality aesthetic with bold, distinctive choices
 * 
 * Crafted for maximum visual impact and memorability
 */

/* ============================================
   CSS Variables - Premium Design Tokens
   ============================================ */

:root {
	/* Primary Colors - Warm Olive/Earth Tone */
	--color-posebyen-green: #585C42;
	--color-accent: #976646;
	--color-canvas-base: #FAF8F5;
	
	/* Secondary Colors */
	--color-accent-light: #F2EDE6;
	--color-accent-warm: #E8D5C4;
	--color-soft-base: #FAF8F5;
	--color-green-medium: #686C50;
	--color-green-light: #EFEEE6;
	--color-green-dark: #3C3E2E;
	--color-cream: #FAF8F5;
	--color-sand: #F2EDE6;
	--color-rose: #976646;
	--color-rose-light: #b8916e;
	--color-rose-dark: #7a5338;
	
	/* Functional Colors */
	--color-text: #111111;
	--color-text-muted: #4B4B4B;
	--color-text-light: #7D8590;
	--color-vipps: #FF5B24;
	--color-border: #D9D9D9;
	--color-border-light: #E6E2DC;
	--color-border-hover: #BEBEBE;
	--color-white: #FFFFFF;
	--color-section-alt: #F2EDE6;
	--color-divider: #E6E2DC;
	
	/* Status Colors */
	--color-success: #0D7356;
	--color-warning: #C17F24;
	--color-error: #C93B3B;
	
	/* Typography - Merriweather (headings) & Open Sans (body) */
	--font-display: 'Merriweather', Georgia, serif;
	--font-heading: 'Merriweather', Georgia, serif;
	--font-body: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	
	/* 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;
	--space-4xl: 5rem;
	--space-5xl: 6rem;
	
	/* Border Radius - Consistent 12px */
	--radius-sm: 12px;
	--radius-md: 12px;
	--radius-lg: 12px;
	--radius-xl: 12px;
	--radius-2xl: 12px;
	--radius-input: 10px;
	--radius-full: 9999px;
	
	/* Shadows - Minimal */
	--shadow-xs: none;
	--shadow-sm: none;
	--shadow-md: none;
	--shadow-lg: none;
	--shadow-xl: none;
	--shadow-glow: none;
	--shadow-inner: none;
	--shadow-hover: 0 2px 8px rgba(0,0,0,0.06);
	
	/* Card tokens */
	--card-radius: 12px;
	--card-border: 1px solid var(--color-border);
	--card-padding: 28px;
	--card-padding-mobile: 20px;
	
	/* Transitions */
	--transition-fast: 200ms cubic-bezier(0.4, 0, 0.2, 1);
	--transition-base: 300ms cubic-bezier(0.4, 0, 0.2, 1);
	--transition-slow: 500ms cubic-bezier(0.4, 0, 0.2, 1);
	--transition-spring: 500ms cubic-bezier(0.34, 1.56, 0.64, 1);
	--transition-smooth: 600ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* ============================================
   Reset & Base Styles - Agency Quality
   ============================================ */

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

html {
	font-size: 16px;
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--color-text);
	background-color: var(--color-canvas-base);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	letter-spacing: 0;
	font-weight: 400;
	overflow-x: hidden;
	text-align: left;
}

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

a {
	color: inherit;
	text-decoration: none;
	transition: all var(--transition-base);
}

a:hover {
	color: var(--color-accent);
}

ul, ol {
	list-style: none;
}

button {
	font-family: inherit;
	cursor: pointer;
	border: none;
	background: none;
}

/* Premium selection styling */
::selection {
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
}

/* Smooth scrollbar */
::-webkit-scrollbar {
	width: 8px;
}

::-webkit-scrollbar-track {
	background: var(--color-soft-base);
}

::-webkit-scrollbar-thumb {
	background: var(--color-accent);
	border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
	background: var(--color-posebyen-green);
}

/* ============================================
   Typography - Bold Agency Style
   ============================================ */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 300;
	line-height: 1.2;
	color: var(--color-posebyen-green);
	letter-spacing: -0.01em;
	text-align: left;
}

/* All h1 elements – unified style across site */
h1,
.hero__title,
.section-header__title,
.course-title,
h1.hero__title,
h1.section-header__title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 5vw, 3rem);
	margin-bottom: 12px;
	font-weight: 300;
	line-height: 1.2;
	letter-spacing: -0.01em;
}

h2 {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	margin-bottom: 12px;
	font-weight: 300;
	line-height: 1.2;
}

h3 {
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	margin-bottom: var(--space-md);
	font-weight: 300;
}

h4 {
	font-size: clamp(1.125rem, 2vw, 1.25rem);
	margin-bottom: var(--space-md);
	font-weight: 300;
	font-family: var(--font-heading);
}

h5 {
	font-size: clamp(1rem, 1.5vw, 1.125rem);
	margin-bottom: var(--space-md);
	font-weight: 300;
}

h6 {
	font-size: clamp(0.875rem, 1.25vw, 1rem);
	margin-bottom: var(--space-sm);
	font-weight: 300;
}

/* Display text - Extra large headlines */
.display-text {
	font-family: var(--font-display);
	font-size: clamp(4rem, 12vw, 10rem);
	font-weight: 300;
	line-height: 0.9;
	letter-spacing: -0.04em;
}

.text-accent {
	color: var(--color-accent);
}

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

.text-light {
	color: var(--color-text-light);
}

.text-small {
	font-size: 0.875rem;
}

/* Premium label styling */
.text-label {
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.25em;
	color: var(--color-accent);
}

/* Overline - Agency style */
.overline {
	display: inline-flex;
	align-items: center;
	gap: var(--space-md);
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	color: var(--color-text-muted);
}

.overline::before {
	content: '';
	width: 40px;
	height: 1px;
	background-color: var(--color-accent);
}

/* Elegant divider */
.divider {
	width: 80px;
	height: 1px;
	background: var(--color-accent);
	margin: var(--space-xl) 0;
}

.divider--center {
	margin-left: auto;
	margin-right: auto;
}

/* Number styling - Agency detail */
.number-display {
	font-family: var(--font-display);
	font-size: 5rem;
	font-weight: 300;
	color: var(--color-accent);
	line-height: 1;
	letter-spacing: -0.05em;
}

/* ============================================
   Layout - Agency Premium Spacing
   ============================================ */

.site {
	display: flex;
	flex-direction: column;
}

.site-content {
	flex: 1;
}

.container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--space-xl);
	position: relative;
}

.container--wide {
	width: 100%;
	max-width: 1480px;
	margin: 0 auto;
	padding: 0 var(--space-xl);
	position: relative;
}

.container--narrow {
	max-width: 860px;
}

.container--readable {
	max-width: 720px;
}

.section {
	padding: var(--space-3xl) 0;
	position: relative;
}

.section--sm {
	padding: var(--space-2xl) 0;
}

.section--lg {
	padding: var(--space-4xl) 0;
}

/* Midtstill h2 i section--lg (unntatt der section-header--left er satt) */
.section.section--lg .section-header:not(.section-header--left) {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.section.section--lg .section-header:not(.section-header--left) .section-header__title {
	text-align: center;
}

.section.section--lg .section-header:not(.section-header--left) .section-header__label {
	justify-content: center;
}

.section.section--lg .section-header:not(.section-header--left) .section-header__label::before {
	display: none;
}

.section.section--lg .section-header:not(.section-header--left) .section-header__description {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.section--bg-white {
	background-color: var(--color-white);
}

.section--bg-soft {
	background-color: var(--color-soft-base);
}

.section--bg-cream {
	background-color: var(--color-cream);
}

.section--bg-sand {
	background-color: var(--color-sand);
}

.section--bg-green {
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	position: relative;
	overflow: hidden;
}

.section--bg-green h1,
.section--bg-green h2,
.section--bg-green h3 {
	color: var(--color-white);
}

/* Grid System - Premium spacing */
.grid {
	display: grid;
	gap: var(--space-xl);
}

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

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

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

@media (min-width: 640px) {
	.grid--2 {
		grid-template-columns: repeat(2, 1fr);
	}
	
	.grid--3 {
		grid-template-columns: repeat(2, 1fr);
	}
	
	.grid--4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.grid {
		gap: var(--space-2xl);
	}
	
	.grid--3 {
		grid-template-columns: repeat(3, 1fr);
	}
	
	.grid--4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ============================================
   Header - Elegant & Minimal
   ============================================ */

.site-header {
	background-color: #F0EDE7;
	padding: var(--space-md) 0;
	position: sticky;
	top: 0;
	z-index: 24000;
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	transition: all var(--transition-slow);
	border-bottom: 1px solid transparent;
}

.site-header.is-scrolled {
	padding: var(--space-sm) 0;
	background-color: #F0EDE7;
	border-bottom-color: var(--color-border-light);
	box-shadow: var(--shadow-sm);
}

.site-header.is-scrolled .site-logo img {
	height: 35px;
}

@media (min-width: 768px) {
	.site-header.is-scrolled .site-logo img {
		height: 45px;
	}
}

.header__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-lg);
}

.header__right {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	margin-left: auto;
}

/* Header cart icon (WooCommerce) */
.header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

@media (max-width: 767px) {
	.header__inner {
		gap: var(--space-sm);
	}

	.header__actions {
		gap: 0.25rem;
	}

	.header-cart {
		padding: 0.4rem 0.35rem;
	}

	.menu-toggle {
		padding: 0.4rem 0.35rem;
	}
}

.header-cart {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-sm) var(--space-md);
	color: var(--color-text-muted);
	transition: color var(--transition-base);
}

.header-cart:hover {
	color: var(--color-posebyen-green);
}

.header-cart__icon {
	display: block;
}

.header-cart__count {
	position: absolute;
	top: -2px;
	right: -2px;
	min-width: 1.125rem;
	height: 1.125rem;
	padding: 0 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-posebyen-green);
	color: var(--color-white);
	font-size: 0.6875rem;
	font-weight: 600;
	border-radius: var(--radius-full);
	line-height: 1;
}

.header__actions .header-cart__count {
	position: absolute;
	top: -2px;
	right: -2px;
}

.main-nav__link--cart,
.mobile-nav__link--cart {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
}

.mobile-nav__cart-count {
	position: static;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.125rem;
	height: 1.125rem;
	padding: 0 4px;
	margin-left: var(--space-xs);
	background: var(--color-posebyen-green);
	color: var(--color-white);
	font-size: 0.6875rem;
	font-weight: 600;
	border-radius: var(--radius-full);
	line-height: 1;
}

.site-logo {
	display: flex;
	align-items: center;
	transition: all var(--transition-base);
	z-index: 101;
}

.site-logo:hover {
	opacity: 0.85;
}

.site-logo img {
	height: 40px;
	width: auto;
	background: transparent !important;
	background-color: transparent !important;
	display: block;
	mix-blend-mode: normal;
	object-fit: contain;
	padding: 0;
	border: none;
	box-shadow: none;
	transition: all var(--transition-base);
}

@media (min-width: 768px) {
	.site-logo img {
		height: 50px;
	}
}

@media (min-width: 1024px) {
	.site-logo img {
		height: 60px;
	}
}

.site-logo__text {
	font-family: var(--font-heading);
	font-size: 1.375rem;
	font-weight: 500;
	color: var(--color-posebyen-green);
	letter-spacing: -0.02em;
}

.site-logo__text span {
	display: block;
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--color-text-light);
	margin-top: 4px;
}

/* Navigation - Clean & Minimal */
.main-nav {
	display: none;
}

@media (min-width: 768px) {
	.main-nav {
		display: block;
	}
}

.main-nav__list {
	display: flex;
	gap: var(--space-xs);
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 1024px) {
	.main-nav__list {
		gap: var(--space-sm);
	}
}

.main-nav__list > li {
	position: relative;
}

.main-nav__list > li.menu-item-has-children {
	position: relative;
}

.main-nav__link {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text-muted);
	padding: var(--space-xs) var(--space-sm);
	position: relative;
	display: inline-block;
	transition: all var(--transition-base);
	text-decoration: none;
	letter-spacing: 0.01em;
}

.main-nav__link::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: var(--space-sm);
	right: var(--space-sm);
	height: 1.5px;
	background-color: var(--color-accent);
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--transition-base);
}

.main-nav__link:hover {
	color: var(--color-posebyen-green);
}

.main-nav__link:hover::after {
	transform: scaleX(1);
	transform-origin: left;
}

.main-nav__link--active,
.main-nav__link.current-menu-item {
	color: var(--color-posebyen-green);
}

.main-nav__link--active::after,
.main-nav__link.current-menu-item::after {
	transform: scaleX(1);
}

/* Dropdown menu support */
.main-nav__list .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	background: #F0EDE7;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	padding: var(--space-xs) 0;
	min-width: 220px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: all var(--transition-base);
	margin-top: var(--space-xs);
	border: 1px solid var(--color-border);
	z-index: 1000;
}

.main-nav__list > li:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.main-nav__list .sub-menu li {
	margin: 0;
}

.main-nav__list .sub-menu .main-nav__link {
	padding: var(--space-xs) var(--space-md);
	display: block;
	width: 100%;
	font-size: 0.875rem;
}

.main-nav__list .sub-menu .main-nav__link::after {
	display: none;
}

.main-nav__list .sub-menu .main-nav__link:hover {
	background-color: var(--color-soft-base);
	color: var(--color-posebyen-green);
}

/* Mobile Menu Toggle */
.menu-toggle {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: var(--space-sm);
	background: transparent;
	border: none;
	cursor: pointer;
	z-index: 26000;
	transition: all var(--transition-base);
	border-radius: var(--radius-md);
}

.menu-toggle:hover {
	background-color: var(--color-soft-base);
}

.menu-toggle.is-active .menu-toggle__bar:nth-child(1) {
	transform: rotate(45deg) translate(6px, 6px);
}

.menu-toggle.is-active .menu-toggle__bar:nth-child(2) {
	opacity: 0;
}

.menu-toggle.is-active .menu-toggle__bar:nth-child(3) {
	transform: rotate(-45deg) translate(6px, -6px);
}

@media (min-width: 768px) {
	.menu-toggle {
		display: none;
	}
}

.menu-toggle__bar {
	width: 26px;
	height: 2.5px;
	background-color: var(--color-posebyen-green);
	transition: all var(--transition-base);
	border-radius: 2px;
}

/* Mobile Navigation */
.mobile-nav {
	display: block;
	position: fixed;
	inset: 0;
	width: 100vw;
	height: 100dvh;
	max-height: 100dvh;
	background:
		linear-gradient(180deg, #f7f4ef 0%, #f0ede7 52%, #ece8e0 100%);
	padding:
		calc(env(safe-area-inset-top, 0px) + 92px)
		clamp(1rem, 5vw, 2rem)
		calc(env(safe-area-inset-bottom, 0px) + 2rem);
	border: none;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(-10px) scale(0.98);
	transition: opacity 0.28s ease, transform 0.32s ease, visibility 0s linear 0.32s;
	z-index: 25000;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
}

.mobile-nav.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0) scale(1);
	transition: opacity 0.28s ease, transform 0.32s ease, visibility 0s linear;
}

.mobile-nav__close {
	position: fixed;
	top: calc(env(safe-area-inset-top, 0px) + 20px);
	right: clamp(1rem, 5vw, 2rem);
	width: 44px;
	height: 44px;
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-full);
	background: rgba(255, 255, 255, 0.92);
	color: var(--color-posebyen-green);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.75rem;
	line-height: 1;
	cursor: pointer;
	z-index: 25010;
}

.mobile-nav__close:hover,
.mobile-nav__close:focus {
	background: var(--color-white);
	border-color: var(--color-posebyen-green);
	outline: none;
}

.mobile-nav__list {
	display: flex;
	flex-direction: column;
	gap: 0;
	list-style: none;
	margin: 0 auto;
	padding: 0;
	max-width: 760px;
}

.mobile-nav__list > li {
	border-bottom: 1px solid var(--color-border);
}

.mobile-nav__list > li:last-child {
	border-bottom: none;
}

.mobile-nav__link {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text);
	padding: 1rem 0;
	display: block;
	transition: all var(--transition-base);
	text-decoration: none;
	position: relative;
	padding-left: var(--space-lg);
}

.mobile-nav__link::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 0;
	background-color: var(--color-accent);
	border-radius: 2px;
	transition: height var(--transition-base);
}

.mobile-nav__link:hover,
.mobile-nav__link.current-menu-item {
	color: var(--color-posebyen-green);
	padding-left: calc(var(--space-lg) + 4px);
}

.mobile-nav__link:hover::before,
.mobile-nav__link.current-menu-item::before {
	height: 60%;
}

/* Mobile sub-menu */
.mobile-nav__list .sub-menu {
	padding-left: var(--space-lg);
	margin-top: 0;
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease-out, opacity 0.3s ease-out;
	opacity: 0;
	list-style: none;
}

.mobile-nav__list .sub-menu.is-open {
	max-height: 1000px;
	opacity: 1;
	margin-top: var(--space-xs);
}

.mobile-nav__list .sub-menu .mobile-nav__link {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	padding: var(--space-sm) var(--space-md);
	padding-left: var(--space-sm);
}

.mobile-nav__list .sub-menu .mobile-nav__link:hover {
	color: var(--color-posebyen-green);
}

/* Mobile submenu toggle button */
.mobile-nav__toggle {
	position: absolute;
	right: 0;
	top: 0.5rem;
	transform: none;
	background: transparent;
	border: none;
	padding: var(--space-sm);
	cursor: pointer;
	color: var(--color-text-muted);
	transition: transform 0.3s ease, color 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	z-index: 1;
}

.mobile-nav__toggle:hover,
.mobile-nav__toggle:focus {
	color: var(--color-posebyen-green);
	outline: 2px solid var(--color-posebyen-green);
	outline-offset: 2px;
	border-radius: var(--radius-sm);
}

.mobile-nav__toggle[aria-expanded="true"] {
	transform: rotate(180deg);
	color: var(--color-posebyen-green);
}

.mobile-nav__toggle svg {
	width: 12px;
	height: 12px;
	transition: transform 0.3s ease;
}

/* Parent item with submenu */
.mobile-nav__list > li.menu-item-has-children {
	position: relative;
}

.mobile-nav__list > li.menu-item-has-children > .mobile-nav__link {
	padding-right: calc(var(--space-lg) + 44px);
}

.mobile-nav__list > li.has-open-submenu > .mobile-nav__link {
	color: var(--color-posebyen-green);
}

.mobile-nav__link--cart {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
}

.mobile-nav__link--cart::before {
	display: none;
}

.mobile-nav__link--cart svg {
	flex-shrink: 0;
}

body.mobile-menu-open {
	overflow: hidden;
}

@media (min-width: 768px) {
	.mobile-nav,
	.mobile-nav.is-open {
		display: none;
	}
}

/* ============================================
   Buttons - Premium Agency Style
   ============================================ */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: 14px 18px;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	text-align: center;
	letter-spacing: 0.01em;
	text-transform: none;
	border-radius: var(--radius-md);
	transition: all var(--transition-base);
	cursor: pointer;
	text-decoration: none;
	border: 1px solid transparent;
	position: relative;
	overflow: hidden;
	height: 48px;
}

@media (max-width: 768px) {
	.btn {
		height: 44px;
		padding: 12px 16px;
	}
}

/* Universal hover effect for all buttons */
.btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.btn:active {
	transform: translateY(0);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.btn--primary {
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	border-color: var(--color-posebyen-green);
}

.btn--primary:hover {
	background-color: var(--color-green-dark);
	border-color: var(--color-green-dark);
	color: var(--color-white);
	box-shadow: 0 4px 16px rgba(47, 82, 70, 0.35);
}

.btn--secondary {
	background-color: transparent;
	color: var(--color-posebyen-green);
	border-color: var(--color-posebyen-green);
}

.btn--secondary:hover {
	background-color: rgba(47, 82, 70, 0.06);
	color: var(--color-green-dark);
	border-color: var(--color-green-dark);
	box-shadow: 0 4px 12px rgba(47, 82, 70, 0.15);
}

.btn--accent {
	background-color: var(--color-accent);
	color: var(--color-white);
	border-color: var(--color-accent);
}

.btn--accent:hover {
	background-color: #B39474;
	border-color: #B39474;
	color: var(--color-white);
	box-shadow: 0 4px 16px rgba(196, 164, 132, 0.35);
}

.btn.btn--outline {
	background-color: transparent;
	color: var(--color-text);
	border: 1px solid var(--color-border);
}

.btn--outline:hover,
.btn.btn--ghost:hover {
	border-color: var(--color-posebyen-green);
	color: var(--color-posebyen-green);
	background-color: rgba(47, 82, 70, 0.03);
	box-shadow: 0 4px 12px rgba(47, 82, 70, 0.1);
}

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

.btn--vipps {
	background-color: var(--color-vipps);
	color: var(--color-white);
	border-color: var(--color-vipps);
}

.btn--vipps:hover {
	background-color: #E54E1C;
	border-color: #E54E1C;
	color: var(--color-white);
	box-shadow: 0 4px 16px rgba(255, 91, 36, 0.35);
}

.btn--sm {
	padding: 10px 16px;
	font-size: 0.8125rem;
	height: 40px;
}

.btn--lg {
	padding: 16px 24px;
	font-size: 0.9375rem;
	height: 52px;
}

.btn--full {
	width: 100%;
}

/* Rounded variant (pill) */
.btn--rounded {
	border-radius: var(--radius-full);
}

/* Suppress button hover when inside a hovered card */
.course-card:hover .btn,
.service-card:hover .btn,
.article-card:hover .btn,
.card-elegant:hover .btn,
.team-card:hover .btn,
.feature-card:hover .btn,
.room-card:hover .btn,
.value-card:hover .btn {
	transform: none !important;
	box-shadow: none !important;
}

/* Button with icon */
.btn svg {
	width: 1.125em;
	height: 1.125em;
	transition: transform var(--transition-base), opacity var(--transition-base);
}

.btn:hover svg {
	transform: translateY(-1px) scale(1.06);
	opacity: 0.9;
}

/* Icon-only button */
.btn--icon {
	width: 48px;
	height: 48px;
	padding: 0;
	border-radius: 50%;
}

.btn--icon svg {
	margin: 0;
}

.btn--icon:hover svg {
	transform: none;
}

/* ============================================
   Hero Section - Agency Premium
   ============================================ */

.hero {
	padding: 5rem 0;
	background-color: var(--color-cream);
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
}

/* Extra vertical spacing for front page hero */
.home .hero {
	padding: 5rem 0;
}

/* Decorative background elements */
.hero::before {
	content: '';
	position: absolute;
	top: -20%;
	right: -10%;
	width: 60%;
	height: 140%;
	background: radial-gradient(ellipse at center, var(--color-accent-warm) 0%, transparent 60%);
	opacity: 0.3;
	pointer-events: none;
}

.hero::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 200px;
	background: linear-gradient(to top, var(--color-canvas-base), transparent);
	pointer-events: none;
}

/* Decorative circle */
.hero .container::before,
.hero .container--wide::before {
	content: '';
	position: absolute;
	top: 10%;
	left: -5%;
	width: 120px;
	height: 120px;
	border: 1px solid var(--color-accent);
	border-radius: 50%;
	opacity: 0.3;
}

.hero__inner {
	display: block;
	position: relative;
	z-index: 1;
}

.hero__inner--split {
	display: grid;
	gap: var(--space-2xl);
	align-items: center;
}

@media (min-width: 1024px) {
	.hero__inner--split {
		grid-template-columns: 1.1fr 0.9fr;
		gap: var(--space-3xl);
	}
}

.hero__content {
	max-width: 620px;
}

.hero__content--center {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}


.hero__label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}

.hero__label::before {
	content: '';
	width: 48px;
	height: 1px;
	background-color: var(--color-rose);
}

.hero__title {
	text-align: left;
}

.hero__description {
	font-size: 1rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-2xl);
	line-height: 1.6;
	text-align: left;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-lg);
	align-items: center;
	margin-top: var(--space-2xl);
}

.hero__image {
	position: relative;
}

/* Image with organic shape mask */
.hero__image::before {
	content: '';
	position: absolute;
	top: -20px;
	right: -20px;
	width: 100%;
	height: 100%;
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-2xl);
	opacity: 0.4;
}

.hero__image-wrapper {
	position: relative;
	border-radius: var(--radius-2xl);
	overflow: hidden;
	box-shadow: var(--shadow-xl);
}

.hero__image img,
.hero__image > div {
	width: 100%;
	height: auto;
	object-fit: cover;
	transition: transform var(--transition-smooth);
	border-radius: var(--radius-2xl);
}

.hero__image:hover img,
.hero__image:hover > div {
	transform: scale(1.03);
}

.hero__image-overlay {
	position: absolute;
	bottom: var(--space-xl);
	left: var(--space-xl);
	background-color: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(12px);
	padding: var(--space-lg) var(--space-xl);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	z-index: 2;
}

/* Floating badge */
.hero__badge {
	position: absolute;
	top: var(--space-xl);
	right: var(--space-xl);
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	padding: var(--space-md) var(--space-lg);
	border-radius: var(--radius-lg);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	z-index: 2;
}

/* ============================================
   Course Cards - Premium Agency Design
   ============================================ */

.course-card {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
	border: 1px solid var(--color-border);
	position: relative;
}

/* Course card image */
.course-card__image {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	position: relative;
}

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

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

/* Accent line at top — move to below image if image present */
.course-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: var(--color-accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--transition-base);
	z-index: 1;
}

.course-card:hover {
	border-color: var(--color-border-hover);
}

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

.course-card__header {
	padding: var(--space-xl) var(--space-xl) var(--space-lg);
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-md);
}

.course-card__date {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-width: 60px;
	padding: var(--space-md);
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	text-align: center;
}

.course-card__date-day {
	font-family: var(--font-display);
	font-size: 1.75rem;
	font-weight: 400;
	line-height: 1;
}

.course-card__date-month {
	font-family: var(--font-body);
	font-size: 0.5625rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	margin-top: 2px;
	opacity: 0.8;
}

.course-card__category {
	font-family: var(--font-body);
	font-size: 0.5625rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--color-text-muted);
	padding: var(--space-xs) var(--space-md);
	border: 1px solid var(--color-border);
}

.course-card__body {
	padding: 0 var(--space-xl) var(--space-xl);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.course-card__title {
	font-family: var(--font-display);
	font-size: 1.5rem;
	margin-bottom: var(--space-sm);
	color: var(--color-posebyen-green);
	font-weight: 300;
	line-height: 1.2;
}

.course-card__title a {
	color: inherit;
	transition: color var(--transition-base);
}

.course-card__title a:hover {
	color: var(--color-accent);
}

.course-card__description {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-xl);
	flex: 1;
	line-height: 1.7;
}

.course-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	flex-wrap: wrap;
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border-light);
}

.course-card__price {
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-posebyen-green);
	letter-spacing: 0.01em;
}

.course-card__price del {
	font-size: 0.8125rem;
	font-weight: 400;
	color: var(--color-text-muted);
	text-decoration: line-through;
}

.course-card__price ins {
	text-decoration: none;
	font-weight: 700;
	color: var(--color-posebyen-green);
}

.course-card__price .woocommerce-Price-amount {
	color: inherit;
	font-weight: inherit;
}

.course-card__price .woocommerce-Price-currencySuffix,
.course-card__price .woocommerce-Price-currencySymbol {
	font-weight: inherit;
	color: inherit;
}

/* Availability badge */
.course-card__availability {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	font-family: var(--font-body);
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 0.3em 0.7em;
	border-radius: 999px;
}

.course-card__availability--available {
	background: var(--color-green-light);
	color: var(--color-posebyen-green);
}

.course-card__availability--few {
	background: #FFF3E0;
	color: #BF6C00;
}

.course-card__availability--full {
	background: #FDEAEA;
	color: #9E2E2E;
}

.course-card__availability-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: currentColor;
	flex-shrink: 0;
}

/* Course card - Aktuelt/Kommende style (screenshot design) */
.courses-section-header {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-lg);
	margin-bottom: var(--space-2xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
}

.courses-section-header__title {
	margin-bottom: 0.25em;
	font-weight: 300;
}

.courses-section-header__subtitle {
	font-size: 1rem;
	color: var(--color-text-muted);
	font-style: italic;
	margin: 0;
	line-height: 1.5;
}

.courses-section-header__link {
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-accent);
	text-decoration: none;
	white-space: nowrap;
	transition: color var(--transition-base);
}

.courses-section-header__link:hover {
	color: var(--color-posebyen-green);
}

.course-card--aktuelt .course-card__header {
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-lg) var(--space-xl);
}

.course-card--aktuelt .course-card__date,
.course-card--aktuelt .course-card__category {
	display: none;
}

.course-card__date-pill {
	display: inline-block;
	padding: 0.35em 0.75em;
	background-color: var(--color-accent);
	color: var(--color-white);
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--radius-full);
}

.course-card__capacity {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	font-family: var(--font-body);
	font-size: 0.75rem;
	color: var(--color-text-muted);
}

.course-card__capacity svg {
	flex-shrink: 0;
	opacity: 0.8;
}

.course-card--aktuelt .course-card__body {
	padding: 0 var(--space-xl) var(--space-xl);
}

.course-card--aktuelt .course-card__title {
	font-weight: 300;
}

.course-card--aktuelt .course-card__footer {
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border-light);
}

.course-card__add-to-cart {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	transition: background-color var(--transition-base), transform var(--transition-base);
}

.course-card__add-to-cart:hover {
	background-color: var(--color-green-dark);
	color: var(--color-white);
	transform: scale(1.05);
}

.course-card__add-to-cart svg {
	flex-shrink: 0;
}

.course-card--aktuelt::before {
	display: none;
}

.course-card--aktuelt {
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

/* Status Indicators */
.status {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: 0.75rem;
	font-weight: 500;
}

.status::before {
	content: '';
	width: 8px;
	height: 8px;
	border-radius: 50%;
}

.status--available {
	color: var(--color-success);
}

.status--available::before {
	background-color: var(--color-success);
}

.status--few {
	color: var(--color-warning);
}

.status--few::before {
	background-color: var(--color-warning);
}

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

.status--full::before {
	background-color: var(--color-error);
}

/* ============================================
   Service Cards - Premium Agency Design
   ============================================ */

.service-card {
	background-color: var(--color-white);
	padding: var(--space-2xl);
	transition: all var(--transition-base);
	border: 1px solid var(--color-border);
	position: relative;
}

/* Number indicator */
.service-card__number {
	font-family: var(--font-display);
	font-size: 4rem;
	font-weight: 300;
	color: var(--color-accent-light);
	line-height: 1;
	margin-bottom: var(--space-lg);
	transition: color var(--transition-base);
}

.service-card:hover .service-card__number {
	color: var(--color-accent);
}

.service-card:hover {
	border-color: var(--color-posebyen-green);
}

.service-card__icon {
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-sand);
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-xl);
	transition: all var(--transition-base);
}

.service-card:hover .service-card__icon {
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
}

.service-card__icon svg {
	width: 24px;
	height: 24px;
}

.service-card__title {
	font-family: var(--font-display);
	font-size: 1.5rem;
	margin-bottom: var(--space-md);
	font-weight: 300;
	line-height: 1.2;
}

.service-card__description {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
	line-height: 1.75;
}

.service-card__list {
	margin-bottom: var(--space-xl);
}

.service-card__list li {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	padding: var(--space-sm) 0;
	padding-left: var(--space-lg);
	position: relative;
	border-bottom: 1px solid var(--color-border-light);
}

.service-card__list li:last-child {
	border-bottom: none;
}

.service-card__list li::before {
	content: '—';
	position: absolute;
	left: 0;
	color: var(--color-accent);
	font-size: 0.75rem;
}

/* ============================================
   Section Headers - Agency Premium
   ============================================ */

.section-header {
	text-align: left;
	max-width: 720px;
	margin: 0 0 var(--space-2xl);
}

.section-header--left {
	text-align: left;
	margin-left: 0;
}

.section-header__label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}

.section-header__label::before {
	content: '';
	width: 24px;
	height: 1px;
	background-color: var(--color-accent);
}

.section-header__label::after {
	display: none;
}

.section-header--left .section-header__label::before {
	display: none;
}

@media (max-width: 768px) {
	.section-header__label,
	.section.section--lg .section-header:not(.section-header--left) .section-header__label,
	.fp-cta__header .section-header__label {
		justify-content: flex-start;
	}
	/* Forelder har text-align: center – overstyr på mobil så label venstrestilles */
	.section.section--lg .section-header:not(.section-header--left),
	.fp-cta__header,
	.section-header--center {
		text-align: left;
		margin-left: 0;
		margin-right: 0;
	}
	.section.section--lg .section-header:not(.section-header--left) .section-header__title,
	.fp-cta__header .fp-cta__title,
	.section-header--center .section-header__title,
	.section-header--center .section-header__description {
		text-align: left;
		margin-left: 0;
		margin-right: 0;
	}
}

.section-header__title {
	margin-bottom: 12px;
}

.section-header__description {
	font-size: 1rem;
	color: var(--color-text-muted);
	margin: 0;
	line-height: 1.6;
	max-width: 60ch;
}

.section-header--left .section-header__description {
	margin-left: 0;
}

/* Large section number */
.section-header__number {
	font-family: var(--font-display);
	font-size: 8rem;
	font-weight: 300;
	color: var(--color-accent-light);
	line-height: 0.8;
	margin-bottom: var(--space-lg);
	opacity: 0.5;
}

/* ============================================
   Front Page About Section
   ============================================ */

.fp-about-section {
	background-color: var(--color-soft-base);
}

.fp-about {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2xl);
	align-items: center;
}

@media (min-width: 768px) {
	.fp-about {
		grid-template-columns: 1.2fr 1fr;
		gap: var(--space-3xl);
	}
}

@media (min-width: 1200px) {
	.fp-about {
		gap: var(--space-4xl);
	}
}

.fp-about__image {
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.fp-about__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	min-height: 320px;
}

@media (min-width: 768px) {
	.fp-about__image img {
		min-height: 440px;
	}
}

.fp-about__content {
	max-width: 540px;
}

.fp-about__title {
	font-size: clamp(1.625rem, 4vw, 2rem);
	margin-bottom: var(--space-lg);
}

.fp-about__description {
	font-size: 1rem;
	color: var(--color-text-muted);
	line-height: 1.7;
	margin-bottom: var(--space-xl);
	max-width: 50ch;
}

.fp-about__list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-2xl);
}

.fp-about__list li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
	padding: var(--space-sm) 0;
	font-size: 0.9375rem;
	color: var(--color-text);
	line-height: 1.6;
}

.fp-about__list li svg {
	flex-shrink: 0;
	margin-top: 3px;
	color: var(--color-posebyen-green);
}

/* ============================================
   Front Page — Contact CTA
   ============================================ */

.fp-cta-section {
	background-color: var(--color-soft-base);
	position: relative;
	overflow: hidden;
}

.fp-cta-section::before,
.fp-cta-section::after {
	display: none;
}

.fp-cta {
	position: relative;
	z-index: 1;
}

.fp-cta__header {
	text-align: center;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: var(--space-3xl);
}

.fp-cta__header .section-header__label {
	justify-content: center;
	color: var(--color-posebyen-green);
}

.fp-cta__header .section-header__label::before {
	display: none;
}

.fp-cta__title {
	color: var(--color-posebyen-green);
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 300;
	margin: var(--space-md) 0 var(--space-lg);
	line-height: 1.2;
	letter-spacing: -0.02em;
	text-align: center;
}

.fp-cta__description {
	color: var(--color-text-muted);
	font-size: 1.0625rem;
	line-height: 1.7;
	margin: 0;
	text-align: center;
}

.fp-cta__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2xl);
	max-width: 800px;
	margin: 0 auto;
}

.fp-cta__info-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
}

.fp-cta__info-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-md);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: var(--space-xl) var(--space-lg);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.fp-cta__info-card:hover {
	border-color: rgba(88, 92, 66, 0.25);
	box-shadow: 0 4px 16px rgba(88, 92, 66, 0.06);
}

.fp-cta__info-icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: rgba(88, 92, 66, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-posebyen-green);
}

.fp-cta__info-card div:last-child {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.fp-cta__info-card strong {
	color: var(--color-posebyen-green);
	font-weight: 600;
	font-size: 0.9375rem;
	letter-spacing: 0.01em;
}

.fp-cta__info-card span,
.fp-cta__info-card a {
	color: var(--color-text-muted);
	font-size: 0.875rem;
	line-height: 1.5;
	text-decoration: none;
}

.fp-cta__info-card a:hover {
	color: var(--color-posebyen-green);
}

.fp-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	justify-content: center;
}

@media (max-width: 640px) {
	.fp-cta__info-cards {
		grid-template-columns: 1fr;
	}

	.fp-cta__info-card {
		flex-direction: row;
		text-align: left;
	}
}

/* ============================================
   Footer - Agency Premium
   ============================================ */

.site-footer {
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	padding: var(--space-3xl) 0 var(--space-xl);
	position: relative;
}

/* Decorative top border */
.site-footer::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-accent-warm), var(--color-accent));
}

.footer__inner {
	display: grid;
	gap: var(--space-2xl);
}

@media (min-width: 768px) {
	.footer__inner {
		grid-template-columns: 1.5fr 1fr 1fr;
	}
}

@media (min-width: 1024px) {
	.footer__inner {
		grid-template-columns: 2fr 1fr 1fr;
	}
}

.footer__brand {
	max-width: none;
}

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

.footer__logo img {
	height: 44px;
	width: auto;
	background: transparent;
	background-color: transparent;
	display: block;
	filter: brightness(0) invert(1);
	opacity: 1;
}

.footer__logo-text {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--color-white);
	letter-spacing: -0.01em;
}

.footer__tagline {
	font-family: var(--font-display);
	font-size: 1.75rem;
	font-weight: 300;
	font-style: italic;
	color: var(--color-accent);
	margin-bottom: var(--space-xl);
	line-height: 1.3;
}

.footer__description {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: var(--space-xl);
	line-height: 1.8;
}

.footer__contact p {
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: var(--space-sm);
}

.footer__contact a {
	color: var(--color-white);
	transition: all var(--transition-base);
	position: relative;
}

.footer__contact a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: var(--color-accent);
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--transition-base);
}

.footer__contact a:hover {
	color: var(--color-accent);
}

.footer__contact a:hover::after {
	transform: scaleX(1);
	transform-origin: left;
}

.footer__heading {
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgba(255, 255, 255, 0.7);
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.footer__links li {
	margin-bottom: var(--space-md);
}

.footer__links a {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.85);
	transition: all var(--transition-base);
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
}

.footer__links a::before {
	content: '';
	width: 0;
	height: 1px;
	background-color: var(--color-accent);
	transition: width var(--transition-base);
}

.footer__links a:hover {
	color: var(--color-white);
}

.footer__links a:hover::before {
	width: 16px;
}

.footer__bottom {
	margin-top: var(--space-2xl);
	padding-top: var(--space-lg);
	border-top: 1px solid rgba(255, 255, 255, 0.15);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-lg);
}

.footer__copyright {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.7);
	letter-spacing: 0.05em;
}

.footer__legal {
	display: flex;
	gap: var(--space-xl);
}

.footer__legal a {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.7);
	transition: color var(--transition-base);
	letter-spacing: 0.05em;
}

.footer__legal a:hover {
	color: var(--color-white);
}

/* Social links */
.footer__social {
	display: flex;
	gap: var(--space-md);
}

.footer__social a {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 255, 255, 0.3);
	color: rgba(255, 255, 255, 0.85);
	transition: all var(--transition-base);
}

.footer__social a:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}

/* ============================================
   Reviews Carousel (Kvinnehelse / Ingvild)
   ============================================ */

.reviews-section {
	background: var(--color-section-alt);
}

.reviews-section .section-header__label::before {
	display: none;
}

.reviews-carousel-wrapper {
	position: relative;
	overflow: hidden;
	margin: 0 calc(-1 * var(--space-xl));
	padding: 0 var(--space-xl);
}

.reviews-carousel {
	display: flex;
	gap: var(--space-xl);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	padding-bottom: var(--space-md);
	scrollbar-width: none;
	-ms-overflow-style: none;
}

.reviews-carousel::-webkit-scrollbar {
	display: none;
}

/* --- Arrow buttons --- */

.reviews-carousel-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: none;
	background: var(--color-white);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
	color: var(--color-posebyen-green);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all var(--transition-base);
}

.reviews-carousel-arrow:hover {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
}

.reviews-carousel-arrow--prev {
	left: 8px;
}

.reviews-carousel-arrow--next {
	right: 8px;
}

@media (max-width: 639px) {
	.reviews-carousel-arrow {
		width: 36px;
		height: 36px;
	}

	.reviews-carousel-arrow--prev {
		left: 4px;
	}

	.reviews-carousel-arrow--next {
		right: 4px;
	}
}

/* --- Review card --- */

.review-card {
	flex: 0 0 100%;
	min-width: 0;
	scroll-snap-align: start;
	background: var(--color-white);
	border-radius: 12px;
	padding: var(--space-xl) var(--space-2xl);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	border: none;
	display: flex;
	flex-direction: column;
}

@media (min-width: 640px) {
	.review-card {
		flex: 0 0 calc(50% - var(--space-xl) / 2);
	}
}

@media (min-width: 1024px) {
	.review-card {
		flex: 0 0 calc((100% - 2 * var(--space-xl)) / 3);
	}
}

/* --- Stars --- */

.review-card__stars {
	display: flex;
	gap: 2px;
	margin-bottom: var(--space-md);
}

.review-card__star {
	display: block;
	flex-shrink: 0;
}

/* --- Quote & text --- */

.review-card__quote {
	margin: 0 0 var(--space-lg);
	padding: 0;
	border: none;
	flex: 1;
}

.review-card__text {
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--color-text);
	margin: 0;
}

.review-card__text.is-truncated {
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.review-card__text.is-expanded {
	display: block;
	-webkit-line-clamp: unset;
	overflow: visible;
}

.review-card__read-more {
	background: none;
	border: none;
	padding: 0;
	margin-top: var(--space-xs);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
	cursor: pointer;
	display: none;
}

.review-card__read-more:hover {
	text-decoration: underline;
}

.review-card__read-more.is-visible {
	display: inline-block;
}

/* --- Footer --- */

.review-card__footer {
	margin-top: auto;
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border-light);
}

.review-card__author {
	font-style: normal;
	font-weight: 600;
	font-size: 0.875rem;
	color: var(--color-posebyen-green);
	display: block;
}

/* ============================================
   Forms - Elegant Inputs
   ============================================ */

.form-group {
	margin-bottom: var(--space-xl);
}

.form-label {
	display: block;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
	letter-spacing: 0.02em;
}

.form-input,
.form-textarea,
.form-select {
	width: 100%;
	padding: 1rem var(--space-lg);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	color: var(--color-text);
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-input);
	transition: all var(--transition-base);
}

.form-input::placeholder,
.form-textarea::placeholder {
	color: var(--color-text-light);
}

.form-input:hover,
.form-textarea:hover,
.form-select:hover {
	border-color: var(--color-text-light);
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: none;
}

.form-textarea {
	min-height: 160px;
	resize: vertical;
}

/* ============================================
   WooCommerce Overrides
   ============================================ */

.woocommerce-page .site-content {
	padding: var(--space-3xl) 0;
}


/* Product Grid – shop uses course-card--aktuelt layout */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: var(--space-2xl);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 640px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(2, 1fr);
	}
}

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

.woocommerce ul.products li.product {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
	margin: 0;
	padding: 0;
}

.woocommerce ul.products li.product:hover {
	box-shadow: var(--shadow-lg);
}

.woocommerce ul.products li.product a img {
	margin: 0;
	border-radius: 0;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	color: var(--color-posebyen-green);
	padding: var(--space-md) var(--space-lg) var(--space-sm);
}

.woocommerce ul.products li.product .price {
	color: var(--color-text);
	padding: 0 var(--space-lg);
	font-size: 1rem;
}

.woocommerce ul.products li.product .button {
	margin: var(--space-md) var(--space-lg) var(--space-lg);
	background-color: var(--color-accent);
	color: var(--color-white);
	border-radius: var(--radius-md);
	padding: 0.75rem var(--space-lg);
	font-size: 0.875rem;
	font-weight: 600;
}

.woocommerce ul.products li.product .button:hover {
	background-color: #A87872;
}

/* Buttons */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background-color: var(--color-accent);
	color: var(--color-white);
	border-radius: var(--radius-md);
	padding: 0.875rem var(--space-xl);
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	border: none;
	transition: all var(--transition-base);
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
	background-color: #A87872;
	color: var(--color-white);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	background-color: var(--color-posebyen-green);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
	background-color: var(--color-green-dark);
}

/* Notices wrapper - site width to match container */
.woocommerce-notices-wrapper {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--space-xl);
	padding-right: var(--space-xl);
}

/* Messages */
.woocommerce-message,
.woocommerce-info {
	border-top-color: var(--color-posebyen-green);
	background-color: var(--color-soft-base);
}

.woocommerce-message::before,
.woocommerce-info::before {
	color: var(--color-posebyen-green);
}

/* View cart button in success notice - professional style */
.woocommerce-message a.button,
.woocommerce-info a.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.625rem 1.25rem;
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: var(--color-posebyen-green);
	color: var(--color-white) !important;
	border: 1px solid var(--color-posebyen-green);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: all var(--transition-base);
}

.woocommerce-message a.button:hover,
.woocommerce-info a.button:hover {
	background: var(--color-green-dark);
	border-color: var(--color-green-dark);
	color: var(--color-white) !important;
	transform: translateY(-1px);
}

.woocommerce-error {
	border-top-color: var(--color-error);
}

/* ============================================
   WooCommerce Cart Page — Premium Card Layout
   ============================================ */

/* Page-level override: tighter top spacing */
.woocommerce-cart .site-content {
	padding-top: 0;
}

/* Hide default WC page title — we use section-header */
.woocommerce-cart .entry-title,
.woocommerce-cart .wp-block-post-title,
.woocommerce-cart .woocommerce > h1,
.woocommerce-cart .woocommerce > h2 {
	font-family: var(--font-body);
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: var(--color-posebyen-green);
	text-align: left;
	margin: 0 0 var(--space-xl);
}

/* ---- Layout: main + sidebar ---- */
.pb-cart {
	max-width: 1100px;
	margin: 0 auto;
	padding: var(--space-lg) var(--space-md) var(--space-3xl);
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
}

@media (min-width: 900px) {
	.pb-cart {
		grid-template-columns: 1fr 340px;
		align-items: start;
	}

	.pb-cart__form {
		grid-column: 1;
	}

	.pb-cart__sidebar {
		grid-column: 2;
		position: sticky;
		top: 100px; /* below sticky header */
	}

	.pb-cart-totals__checkout {
		margin-top: var(--space-lg);
	}
}

/* ---- Cart items list ---- */
.pb-cart__items-title {
	font-family: var(--font-body);
	font-size: 1.2rem !important;
	font-weight: 700;
	color: var(--color-posebyen-green);
	margin: 0.25rem 0 var(--space-sm);
}

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

/* ---- Cart item: Fjern øverst venstre | Rad 2: bilde + tittel/beskrivelse | Rad 3: pris + antall ---- */
.pb-cart-item {
	display: grid;
	grid-template-columns: 64px 1fr;
	grid-template-rows: auto auto auto;
	gap: var(--space-sm) var(--space-lg);
	padding: var(--space-lg);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-base);
	align-items: start;
}

.pb-cart-item:hover {
	border-color: var(--color-posebyen-green);
}

/* Fjern: helt oppe til venstre, alene */
.pb-cart-item__remove {
	grid-column: 1;
	grid-row: 1;
}

.pb-cart-item__remove a.remove {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.75rem;
	color: var(--color-text-muted) !important;
	text-decoration: none;
	transition: color var(--transition-fast);
	padding: 0.25rem 0;
}

.pb-cart-item__remove a.remove:hover {
	color: #c53030 !important;
}

.pb-cart-item__remove a.remove svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

.pb-cart-item__remove a.remove span {
	font-family: var(--font-body);
	font-weight: 500;
	letter-spacing: 0.01em;
}

/* Bilde – samme linje som tittel (vertikalt sentrert i rad 2) */
.pb-cart-item__image {
	grid-column: 1;
	grid-row: 2;
	align-self: center;
}

.pb-cart-item__image a {
	display: block;
}

.pb-cart-item__image img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: var(--radius-sm);
	background: var(--color-soft-base);
}

.pb-cart-item__image img.attachment-woocommerce_thumbnail.size-woocommerce_thumbnail {
	margin: 1rem;
}

/* Tittel og beskrivelse – samme linje som bilde */
.pb-cart-item__details {
	grid-column: 2;
	grid-row: 2;
	min-width: 0;
	align-self: center;
}

.pb-cart-item__name a {
	font-family: var(--font-body);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
	text-decoration: none;
	line-height: 1.4;
	display: block;
}

.pb-cart-item__name a:hover {
	color: var(--color-green-dark);
}

.pb-cart-item__description {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	line-height: 1.4;
	margin-top: 0.25rem;
}

/* Pris og antall på én linje under bilde og tittel – venstrestilt */
.pb-cart-item__actions {
	grid-column: 1 / -1;
	grid-row: 3;
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: flex-start;
	gap: var(--space-md);
}

.pb-cart-item__qty {
	order: 0;
	flex-shrink: 0;
	display: flex;
	align-items: center;
}

.pb-cart-item__subtotal {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--color-text);
	white-space: nowrap;
	order: 1;
	display: flex;
	align-items: center;
	min-height: 44px;
	height: 44px;
	line-height: 1;
	box-sizing: border-box;
}

.pb-cart-item__qty .quantity {
	display: flex;
	align-items: center;
}

/* Hide WooCommerce quantity label visually (keep for screen readers) */
.pb-cart-item__qty .quantity label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Antall-felt: samme høyde som pris (44px), på linje */
.pb-cart-item__qty .qty {
	width: 72px;
	height: 44px;
	min-height: 44px;
	text-align: center;
	padding: 0 0.5rem;
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 600;
	background: var(--color-white);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	box-sizing: border-box;
	line-height: 1;
}

.pb-cart-item__qty .qty:focus {
	outline: none;
	border-color: var(--color-posebyen-green);
	box-shadow: 0 0 0 3px rgba(47, 82, 70, 0.1);
}

/* ---- Bottom bar (coupon + update) ---- */
.pb-cart__bottom-bar {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	flex-wrap: wrap;
	padding-top: var(--space-sm);
}

.pb-cart__coupon {
	display: flex;
	gap: var(--space-sm);
	flex: 1;
	min-width: 200px;
}

.pb-cart__coupon #coupon_code {
	flex: 1;
	max-width: 220px;
	padding: 0.625rem 0.875rem;
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: 0.875rem;
	transition: border-color var(--transition-fast);
}

.pb-cart__coupon #coupon_code:focus {
	outline: none;
	border-color: var(--color-posebyen-green);
	box-shadow: 0 0 0 3px rgba(47, 82, 70, 0.1);
}

.pb-cart__update {
	margin-left: auto;
}

/* ---- Cart Totals / Sidebar ---- */
.pb-cart-totals {
	background: transparent;
}

/* Tittel over den hvite boksen (ikke på hvit bakgrunn) */
.pb-cart-totals__title {
	font-family: var(--font-body);
	font-size: 1.2rem !important;
	font-weight: 700;
	color: var(--color-posebyen-green);
	margin: 0.25rem 0 var(--space-sm);
	padding: 0;
	border: none;
}

/* Hvit boks med delsum, total, knapper */
.pb-cart-totals__card {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	padding: var(--space-xl);
}

.pb-cart-totals__rows {
	display: flex;
	flex-direction: column;
}

.pb-cart-totals__row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: var(--space-sm) 0;
}

.pb-cart-totals__label {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
}

.pb-cart-totals__value {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--color-text);
	text-align: right;
}

.pb-cart-totals__row--total {
	border-top: 2px solid var(--color-posebyen-green);
	margin-top: var(--space-sm);
	padding-top: var(--space-md);
}

.pb-cart-totals__row--total .pb-cart-totals__label {
	font-size: 1.0625rem;
	font-weight: 700;
	color: var(--color-text);
}

.pb-cart-totals__row--total .pb-cart-totals__value {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-posebyen-green);
}

.pb-cart-totals__row--discount .pb-cart-totals__value {
	color: #38a169;
}

/* Checkout button - ensure visible and prominent */
.pb-cart-totals__checkout {
	margin-top: var(--space-lg);
	display: block !important;
	width: 100%;
}

/* WooCommerce wraps the link in <p> – reset so button isn't skewed */
.pb-cart-totals__checkout p,
.pb-cart-totals .wc-proceed-to-checkout p {
	margin: 0;
	padding: 0;
	width: 100%;
}

.pb-cart-totals__checkout .checkout-button,
.pb-cart-totals .wc-proceed-to-checkout a.checkout-button {
	display: flex !important;
	width: 100% !important;
	max-width: 100%;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: var(--space-sm);
	min-height: 52px;
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.875rem;
	padding-bottom: 0.875rem;
	background: var(--color-posebyen-green);
	color: var(--color-white) !important;
	border: none;
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	transition: all var(--transition-base);
	cursor: pointer;
	appearance: none;
	box-sizing: border-box;
	margin: 0 !important;
}

/* Avoid <br> or inline spacing shifting content */
.pb-cart-totals__checkout a.checkout-button br {
	display: none;
}

.pb-cart-totals__checkout .checkout-button *,
.pb-cart-totals .wc-proceed-to-checkout a.checkout-button * {
	margin-left: 0;
	margin-right: 0;
}

.pb-cart-totals__checkout .checkout-button:hover,
.pb-cart-totals .wc-proceed-to-checkout a.checkout-button:hover {
	background: var(--color-green-dark);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(47, 82, 70, 0.2);
}

/* Continue shopping link */
.pb-cart-totals__continue {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	margin-top: var(--space-md);
	padding: var(--space-sm) 0;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.pb-cart-totals__continue:hover {
	color: var(--color-posebyen-green);
}

.pb-cart-totals__continue svg {
	transition: transform var(--transition-fast);
}

.pb-cart-totals__continue:hover svg {
	transform: translateX(-3px);
}

/* ---- Mobile responsive ---- */
@media (max-width: 640px) {
	.pb-cart {
		padding: var(--space-md) var(--space-sm) var(--space-2xl);
	}

	.pb-cart-item {
		grid-template-columns: 56px 1fr;
		grid-template-rows: auto auto auto;
		gap: var(--space-sm) var(--space-md);
		padding: var(--space-md);
	}

	.pb-cart-item__remove {
		grid-row: 1;
		grid-column: 1;
	}

	.pb-cart-item__image {
		grid-row: 2;
		grid-column: 1;
	}

	.pb-cart-item__image img {
		width: 56px;
		height: 56px;
	}

	.pb-cart-item__details {
		grid-column: 2;
		grid-row: 2;
	}

	.pb-cart-item__actions {
		grid-column: 1 / -1;
		grid-row: 3;
		padding-top: var(--space-sm);
		border-top: 1px solid var(--color-border-light);
	}

	.pb-cart__update {
		width: 100%;
	}

	/* Make update button full-width on mobile */
	.pb-cart__bottom-bar .pb-cart__update {
		margin-left: 0;
	}
}

/* ---- Empty cart ---- */
.woocommerce-cart .cart-empty {
	text-align: center;
	padding: var(--space-3xl) var(--space-xl);
	color: var(--color-text-muted);
	font-size: 1.125rem;
}

.woocommerce-cart .return-to-shop {
	text-align: center;
	margin-top: var(--space-lg);
}

.woocommerce-cart .return-to-shop .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: 0.875rem var(--space-2xl);
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border-radius: var(--radius-md);
	font-weight: 600;
	text-decoration: none;
}

.woocommerce-cart .return-to-shop .button:hover {
	background: var(--color-green-dark);
}

/* Block cart: hide (we use classic shortcode) */
.woocommerce-cart .wp-block-woocommerce-cart { display: none; }

/* ---- WC Block Product Grid (empty cart / new products) ---- */
.wc-block-grid__product {
	text-align: center;
}

.wc-block-grid__product-title {
	font-family: var(--font-heading);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
}

.wc-block-grid__product-price {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	font-weight: 600;
}

.wc-block-grid__product-image img {
	border-radius: var(--radius-sm);
}

.wc-block-grid__product .wp-block-button__link {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border-radius: var(--radius-md);
	font-size: 0.8125rem;
	font-weight: 600;
	padding: 0.5rem 1.25rem;
	text-decoration: none;
	transition: all var(--transition-base);
}

.wc-block-grid__product .wp-block-button__link:hover {
	background: var(--color-green-dark);
}

/* ---- Order summary heading in cart sidebar ---- */
.wc-block-cart .wp-block-woocommerce-cart-order-summary-heading-block {
	font-family: var(--font-heading);
	color: var(--color-posebyen-green);
	font-size: 1.25rem;
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border-light);
	margin-bottom: var(--space-md);
}

/* ============================================
   WooCommerce Checkout Page (Block-based)
   ============================================ */

/* Checkout page wrapper */
.woocommerce-checkout .wp-block-woocommerce-checkout {
	max-width: 1200px;
	margin: 0 auto;
	padding: var(--space-2xl) var(--space-xl);
}

/* Checkout form fields */
.wc-block-checkout .wc-block-components-text-input input,
.wc-block-checkout .wc-block-components-text-input textarea,
.wc-block-checkout .wc-block-components-combobox .wc-block-components-combobox-control input {
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-input);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	transition: border-color var(--transition-fast);
	background: var(--color-white);
}

.wc-block-checkout .wc-block-components-text-input input:focus,
.wc-block-checkout .wc-block-components-text-input textarea:focus {
	border-color: var(--color-posebyen-green);
	box-shadow: none;
}

/* Step titles */
.wc-block-components-checkout-step__title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	color: var(--color-posebyen-green);
}

/* Order summary sidebar */
.wc-block-checkout .wc-block-components-sidebar {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: var(--space-xl) var(--space-2xl);
}

/* ---- Checkout Order Summary Items ---- */

/* Hide per-unit price inside item description (duplicate of total price) */
.wc-block-components-order-summary-item__description > .wc-block-components-product-price {
	display: none;
}

/* Checkout item name: keep tight and consistent with cart */
.wc-block-components-order-summary-item__description > .wc-block-components-product-name {
	display: -webkit-box !important;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 36ch;
}

/* Product image in order summary */
.wc-block-components-order-summary-item__image img {
	border-radius: var(--radius-sm);
	object-fit: cover;
}

/* Description area: product name + metadata */
.wc-block-components-order-summary-item__description {
	font-family: var(--font-body);
}

/* Product name inside order summary */
.wc-block-components-order-summary-item__description > .wc-block-components-product-name {
	display: block !important;
	font-family: var(--font-heading);
	font-size: 0.9375rem !important;
	font-weight: 600;
	color: var(--color-posebyen-green);
	text-decoration: none;
	line-height: 1.4;
	margin-bottom: 2px;
}

/* Metadata (short description, variation info) */
.wc-block-components-order-summary-item__description .wc-block-components-product-metadata {
	font-size: 0.8125rem;
	color: var(--color-text-muted);
	line-height: 1.4;
}

.wc-block-components-order-summary-item__description .wc-block-components-product-metadata p {
	font-size: 0.8125rem;
	margin: 0;
}

/* Tame large headings in order summary */
.wc-block-components-order-summary-item__description h1,
.wc-block-components-order-summary-item__description h2,
.wc-block-components-order-summary-item__description h3,
.wc-block-components-order-summary-item__description h4 {
	font-size: 0.9375rem !important;
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-posebyen-green);
	margin: 0 0 2px;
}

/* Total price column */
.wc-block-components-order-summary-item__total-price {
	font-weight: 600;
	font-size: 0.9375rem;
	color: var(--color-text);
}

/* Place order button */
.wc-block-components-checkout-place-order-button {
	display: block;
	width: 100%;
	background: var(--color-posebyen-green) !important;
	color: var(--color-white) !important;
	padding: 1rem var(--space-xl);
	border-radius: var(--radius-md) !important;
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 600;
	border: none;
	cursor: pointer;
	transition: all var(--transition-base);
}

.wc-block-components-checkout-place-order-button:hover {
	background: var(--color-green-dark) !important;
	transform: translateY(-1px);
}

/* General WC block form overrides */
.wc-block-components-form .wc-block-components-text-input label {
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

/* WC block radio / payment method styling */
.wc-block-components-radio-control__option {
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	padding: var(--space-md) var(--space-lg);
	margin-bottom: var(--space-sm);
	transition: border-color var(--transition-fast);
}

.wc-block-components-radio-control__option:hover {
	border-color: var(--color-posebyen-green);
}

.wc-block-components-radio-control__option--checked {
	border-color: var(--color-posebyen-green);
	background: var(--color-cream);
}

/* Classic checkout (shortcode-based) */
.woocommerce-checkout form.checkout {
	display: grid;
	grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
	gap: var(--space-2xl);
	align-items: start;
}

.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
	width: 100%;
	float: none;
}

.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2,
.woocommerce-checkout #order_review {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
}

.woocommerce-checkout #order_review_heading {
	margin: 0 0 var(--space-sm);
	font-family: var(--font-heading);
	color: var(--color-posebyen-green);
}

.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout .shipping_address h3 {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-lg);
}

.woocommerce-checkout table.shop_table {
	border-collapse: collapse;
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.woocommerce-checkout table.shop_table th,
.woocommerce-checkout table.shop_table td {
	padding: 0.875rem 1rem;
	border-bottom: 1px solid var(--color-border-light);
}

.woocommerce-checkout #payment {
	background: var(--color-soft-base);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
}

.woocommerce-checkout #payment div.payment_box {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
}

.woocommerce-checkout #payment #place_order {
	width: 100%;
	padding: 0.9rem 1rem;
	font-size: 1rem;
	font-weight: 600;
}

@media (max-width: 980px) {
	.woocommerce-checkout form.checkout {
		grid-template-columns: 1fr;
	}
}

/* ============================================
   Course Calendar
   ============================================ */

/* Filter row: type pills left, date sort dropdown right */
.course-filters-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-lg);
	margin-bottom: var(--space-2xl);
}

.course-filter-pills {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	justify-content: flex-start;
}

.course-filter-pill {
	display: inline-flex;
	align-items: center;
	padding: 0.5em 1.25em;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-posebyen-green);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-full);
	text-decoration: none;
	transition: all var(--transition-base);
	letter-spacing: 0.01em;
}

.course-filter-pill:hover {
	background: var(--color-soft-base);
	border-color: var(--color-posebyen-green);
	color: var(--color-posebyen-green);
}

.course-filter-pill--active {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border-color: var(--color-posebyen-green);
}

.course-filter-pill--active:hover {
	background: var(--color-posebyen-green);
	color: var(--color-white);
}

.course-sort {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	flex-shrink: 0;
}

.course-sort__label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text-muted);
}

.course-sort__select {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-posebyen-green);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	padding: 0.5em 2em 0.5em 1em;
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%232f5246' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75em center;
}

.course-sort__select:hover,
.course-sort__select:focus {
	border-color: var(--color-posebyen-green);
	outline: none;
}

/* Calendar grid */
.calendar-grid {
	display: grid;
	gap: var(--space-2xl);
}

.calendar-day {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--space-xl) var(--space-2xl);
	box-shadow: var(--shadow-sm);
}

.calendar-day--past {
	opacity: 0.55;
}

.calendar-day__header {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border-light);
}

.calendar-day__date {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-width: 56px;
	padding: var(--space-sm) var(--space-md);
	background-color: var(--color-posebyen-green);
	color: var(--color-white);
	border-radius: var(--radius-md);
	text-align: center;
}

.calendar-day__day {
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	font-family: var(--font-heading);
}

.calendar-day__month {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.calendar-day__info {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

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

.calendar-day__weekday {
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
}

.calendar-day__events {
	display: grid;
	gap: 0;
}

.calendar-event {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-xl);
	padding: var(--space-lg) 0 var(--space-lg);
}

.calendar-event + .calendar-event {
	border-top: 1px solid var(--color-border-light);
}

.calendar-event__top-row {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.calendar-event__image {
	width: 240px;
	height: 170px;
	border-radius: var(--radius-md);
	overflow: hidden;
	flex-shrink: 0;
}

.calendar-event__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.calendar-event__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.calendar-event__type {
	display: inline-block;
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-posebyen-green);
	padding: var(--space-xs) var(--space-md);
	background-color: rgba(88, 92, 66, 0.08);
	border: 1px solid rgba(88, 92, 66, 0.2);
	border-radius: var(--radius-full);
	width: fit-content;
}

.calendar-event__title {
	font-size: 1.125rem;
	margin: 0;
}

.calendar-event__title a {
	color: var(--color-posebyen-green);
	transition: color var(--transition-base);
}

.calendar-event__title a:hover {
	color: var(--color-accent);
}

.calendar-event__meta {
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

.calendar-event__footer {
	display: flex;
	align-items: center;
	gap: var(--space-md) var(--space-xl);
	margin-top: auto;
	padding-top: var(--space-sm);
}

.calendar-event__footer .calendar-event__price {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
}

.calendar-event__footer .btn {
	margin-left: auto;
	flex-shrink: 0;
}

@media (max-width: 640px) {
	.calendar-event {
		grid-template-columns: 1fr;
	}

	.calendar-event__image {
		width: 100%;
		height: 200px;
	}

	.calendar-day {
		padding: var(--space-lg);
	}

	.course-filter-pills {
		justify-content: flex-start;
	}
}

/* ============================================
   Utility Classes
   ============================================ */

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

.text-center {
	text-align: left;
}

.text-left {
	text-align: left;
}

.text-right {
	text-align: right;
}

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--space-md); }
.mt-2 { margin-top: var(--space-xl); }
.mt-3 { margin-top: var(--space-3xl); }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--space-md); }
.mb-2 { margin-bottom: var(--space-xl); }
.mb-3 { margin-bottom: var(--space-3xl); }

.py-1 { padding-top: var(--space-md); padding-bottom: var(--space-md); }
.py-2 { padding-top: var(--space-xl); padding-bottom: var(--space-xl); }
.py-3 { padding-top: var(--space-3xl); padding-bottom: var(--space-3xl); }

/* ============================================
   Animations - Elegant Transitions
   ============================================ */

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(24px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(32px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeInScale {
	from {
		opacity: 0;
		transform: scale(0.95);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

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

@keyframes gentlePulse {
	0%, 100% {
		opacity: 1;
	}
	50% {
		opacity: 0.7;
	}
}

.animate-fade-in {
	animation: fadeIn 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.animate-fade-in-up {
	animation: fadeInUp 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.animate-fade-in-scale {
	animation: fadeInScale 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* Staggered animations */
.animate-stagger > *:nth-child(1) { animation-delay: 0ms; }
.animate-stagger > *:nth-child(2) { animation-delay: 100ms; }
.animate-stagger > *:nth-child(3) { animation-delay: 200ms; }
.animate-stagger > *:nth-child(4) { animation-delay: 300ms; }
.animate-stagger > *:nth-child(5) { animation-delay: 400ms; }
.animate-stagger > *:nth-child(6) { animation-delay: 500ms; }

/* Loading state */
.is-loading {
	animation: gentlePulse 1.5s ease-in-out infinite;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* ============================================
   Additional Elegant Touches
   ============================================ */

/* Elegant link underline effect */
.link-elegant {
	position: relative;
	display: inline-block;
}

.link-elegant::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: currentColor;
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--transition-base);
}

.link-elegant:hover::after {
	transform: scaleX(1);
	transform-origin: left;
}

/* Elegant image container */
.image-elegant {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-xl);
}

.image-elegant img {
	transition: transform var(--transition-slow);
}

.image-elegant:hover img {
	transform: scale(1.03);
}

/* Elegant card hover effect */
.card-elegant {
	transition: all var(--transition-base);
}

.card-elegant:hover {
	border-color: var(--color-border-hover);
}

/* Glass effect */
.glass {
	background: rgba(255, 255, 255, 0.8);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(255, 255, 255, 0.5);
}

/* Subtle badge */
.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: var(--space-xs) var(--space-md);
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	border-radius: var(--radius-full);
}

.badge--accent {
	background-color: var(--color-accent-light);
	color: var(--color-accent);
}

.badge--green {
	background-color: rgba(42, 74, 64, 0.1);
	color: var(--color-posebyen-green);
}

/* Quote styling */
blockquote {
	position: relative;
	padding-left: var(--space-xl);
	margin: var(--space-2xl) 0;
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-style: italic;
	color: var(--color-text-muted);
	line-height: 1.6;
	border-left: none;
}

blockquote::before {
	display: none;
}

/* Elegant horizontal rule */
hr {
	border: none;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-border), transparent);
	margin: var(--space-3xl) 0;
}

/* ============================================
   Rental Page Styles
   ============================================ */

/* Location Card */
.rental-location-card {
	background: var(--color-white);
	border-radius: 12px;
	padding: var(--card-padding);
	text-align: left;
	border: 1px solid var(--color-border);
	position: relative;
	overflow: hidden;
}

.rental-location-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-posebyen-green), var(--color-accent));
}

.rental-location-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 80px;
	height: 80px;
	margin: 0 auto var(--space-xl);
	background: var(--color-green-light);
	border-radius: var(--radius-full);
	color: var(--color-posebyen-green);
}

.rental-location-card h3 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
}

.rental-location-card p {
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

/* Eyebrows removed from design - hide if any remain */
.hero__label,
.rental-location-card__badge,
.section-label {
	display: none !important;
}

/* Feature Cards (4-column grid) - equal boxes */
.grid--4 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-auto-rows: 1fr;
	gap: var(--space-xl);
	align-items: stretch;
}

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

@media (max-width: 640px) {
	.grid--4 {
		grid-template-columns: 1fr;
		grid-auto-rows: auto;
	}
}

.feature-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 0;
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--space-2xl);
	text-align: center;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.feature-card:hover {
	border-color: var(--color-border-hover);
}

.feature-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	margin: 0 auto var(--space-lg);
	background: var(--color-green-light);
	border-radius: var(--radius-lg);
	color: var(--color-posebyen-green);
}

.feature-card__icon svg {
	width: 28px;
	height: 28px;
}

.feature-card__title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
	text-align: center;
}

.feature-card__description {
	flex: 1;
	font-size: 0.875rem;
	color: var(--color-text-muted);
	line-height: 1.6;
}

/* Room Cards */
.room-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-base);
}

.room-card:hover {
	border-color: var(--color-border-hover);
}

.room-card--featured {
	/* Border removed per design - room cards match without outline */
}

.room-card__visual {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-2xl);
	background: linear-gradient(135deg, var(--color-green-light) 0%, var(--color-soft-base) 100%);
}

.room-card--featured .room-card__visual {
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-soft-base) 100%);
}

.room-card__icon-large {
	color: var(--color-posebyen-green);
	opacity: 0.8;
}

.room-card--featured .room-card__icon-large {
	color: var(--color-accent);
}

.room-card__capacity {
	text-align: right;
}

.room-card__capacity-number {
	display: block;
	font-family: var(--font-heading);
	font-size: 3rem;
	font-weight: 700;
	color: var(--color-posebyen-green);
	line-height: 1;
}

.room-card--featured .room-card__capacity-number {
	color: var(--color-accent);
}

.room-card__capacity-label {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-muted);
}

.room-card__content {
	padding: var(--space-2xl);
}

.room-card__title {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-md);
}

.room-card__description {
	color: var(--color-text-muted);
	margin-bottom: var(--space-xl);
	line-height: 1.7;
}

.room-card__features {
	list-style: none;
	padding: 0;
	margin: 0;
}

.room-card__features li {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) 0;
	color: var(--color-text-muted);
	font-size: 0.9375rem;
}

.room-card__features li svg {
	color: var(--color-success);
	flex-shrink: 0;
}

/* Tech Features (Green section) */
.tech-feature {
	text-align: center;
	padding: var(--space-xl);
}

.tech-feature__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	margin: 0 auto var(--space-lg);
	background: rgba(255, 255, 255, 0.15);
	border-radius: var(--radius-lg);
	color: var(--color-white);
}

.tech-feature__icon svg {
	width: 32px;
	height: 32px;
}

.tech-feature__title {
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 300;
	color: var(--color-white);
	margin-bottom: var(--space-sm);
	text-align: center;
}

.tech-feature__description {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.6;
}

.utleie-tech-section {
	background: linear-gradient(180deg, var(--color-soft-base) 0%, var(--color-white) 100%);
}

.utleie-tech-section .section-header__label {
	color: var(--color-text-muted);
}

.utleie-tech-section .section-header__title {
	color: var(--color-posebyen-green);
}

.utleie-tech-section .section-header__description {
	color: var(--color-text-muted);
}

.utleie-tech-section .tech-feature {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
}

.utleie-tech-section .tech-feature__icon {
	background: var(--color-green-light);
	color: var(--color-posebyen-green);
}

.utleie-tech-section .tech-feature__title {
	color: var(--color-text);
}

.utleie-tech-section .tech-feature__description {
	color: var(--color-text-muted);
}

.utleie-tech-section .kitchen-highlight {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
}

.utleie-tech-section .kitchen-highlight__icon {
	background: var(--color-posebyen-green);
	color: var(--color-white);
}

.utleie-tech-section .kitchen-highlight__content h4 {
	color: var(--color-text);
}

.utleie-tech-section .kitchen-highlight__content p {
	color: var(--color-text-muted);
}

/* Kitchen Highlight */
.kitchen-highlight {
	display: flex;
	align-items: center;
	gap: var(--space-xl);
	margin-top: var(--space-3xl);
	padding: var(--space-xl) var(--space-2xl);
	background: rgba(255, 255, 255, 0.1);
	border-radius: var(--radius-lg);
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.kitchen-highlight__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	background: var(--color-accent);
	border-radius: var(--radius-md);
	color: var(--color-white);
	flex-shrink: 0;
}

.kitchen-highlight__content h4 {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 300;
	color: var(--color-white);
	margin-bottom: var(--space-xs);
}

.kitchen-highlight__content p {
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.7);
	margin: 0;
}

/* Service Checklist */
.service-checklist {
	list-style: none;
	padding: 0;
	margin: 0;
}

.service-checklist li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border-light);
}

.service-checklist li:last-child {
	border-bottom: none;
}

.service-checklist__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-success);
	flex-shrink: 0;
}

.service-checklist__icon svg {
	width: 16px;
	height: 16px;
	color: var(--color-success);
	flex-shrink: 0;
}

.service-checklist li span:last-child {
	color: var(--color-text);
	font-size: 1rem;
	line-height: 1.6;
	padding-top: 2px;
}

/* Flexibility Visual */
.flexibility-visual {
	display: flex;
	align-items: center;
	justify-content: center;
}

.flexibility-visual__card {
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-sand) 100%);
	border-radius: var(--radius-2xl);
	padding: var(--space-3xl);
	text-align: center;
	color: var(--color-text);
	box-shadow: var(--shadow-xl);
	max-width: 300px;
}

.flexibility-visual__stat {
	margin-bottom: var(--space-xl);
}

.flexibility-visual__number {
	display: block;
	font-family: var(--font-heading);
	font-size: 4rem;
	font-weight: 700;
	line-height: 1;
	color: var(--color-posebyen-green);
}

.flexibility-visual__label {
	display: block;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--color-text-muted);
	margin-top: var(--space-sm);
}

.flexibility-visual__card p {
	font-size: 1rem;
	color: var(--color-text-muted);
	line-height: 1.6;
	margin: 0;
}

/* Responsive adjustments for rental page */
@media (max-width: 768px) {
	.rental-location-card {
		padding: var(--space-2xl);
	}
	
	.room-card__visual {
		flex-direction: column;
		gap: var(--space-xl);
		text-align: center;
	}
	
	.room-card__capacity {
		text-align: center;
	}
	
	.kitchen-highlight {
		flex-direction: column;
		text-align: center;
	}
	
	.flexibility-visual__number {
		font-size: 3rem;
	}
}

/* ============================================
   Om Oss Page Styles
   ============================================ */

/* Hero About Variant */
.hero--about {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
	background: linear-gradient(180deg, var(--color-soft-base) 0%, var(--color-white) 100%);
}

/* Values Grid */
.values-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-2xl);
}

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

/* Value Cards */
.value-card {
	background: var(--color-white);
	border: var(--card-border);
	border-radius: var(--radius-lg);
	padding: var(--card-padding);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.value-card:hover {
	border-color: var(--color-border-hover);
	box-shadow: var(--shadow-hover);
}

/* Value card row layout (icon + text side by side, e.g. Om oss løfter) */
.value-card--row {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
}

.value-card--row .value-card__icon {
	width: 40px;
	height: 40px;
	min-width: 40px;
	margin-bottom: 0;
}

.value-card--row .value-card__title {
	font-size: 1rem;
	font-weight: 300;
	margin: 0;
}

.value-card--featured {
	grid-column: span 2;
	background: linear-gradient(135deg, var(--color-posebyen-green) 0%, var(--color-green-medium) 100%);
	color: var(--color-white);
}

@media (max-width: 768px) {
	.value-card--featured {
		grid-column: span 1;
	}
}

.value-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background: var(--color-green-light);
	border-radius: var(--radius-lg);
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-xl);
}

.value-card--featured .value-card__icon {
	background: rgba(255, 255, 255, 0.15);
	color: var(--color-white);
}

.value-card__icon svg {
	width: 28px;
	height: 28px;
}

.value-card__title {
	font-family: var(--font-heading);
	font-size: 1.375rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-md);
}

.value-card--featured .value-card__title {
	color: var(--color-white);
	font-size: 1.5rem;
}

.value-card__description {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	line-height: 1.7;
	margin: 0;
}

.value-card--featured .value-card__description {
	color: rgba(255, 255, 255, 0.8);
	font-size: 1rem;
}

/* Team Cards */
.team-card {
	background: var(--color-white);
	border: var(--card-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.team-card:hover {
	border-color: var(--color-border-hover);
	box-shadow: var(--shadow-hover);
}

.team-card--left .team-card__content {
	text-align: left;
}

.team-card__image {
	overflow: hidden;
	background: var(--color-green-light);
}

.team-card__image img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: middle;
	transition: transform var(--transition-slow);
}

.team-card:hover .team-card__image img {
	transform: scale(1.05);
}

.team-card__content {
	padding: var(--space-xl);
	text-align: center;
}

/* Team card "Les mer" – uten venstre padding, tydelig ikon */
.team-card__content .team-card__btn,
.team-card .team-card__content .btn.team-card__btn {
	padding-left: 0;
	padding-right: var(--space-md);
	min-height: 40px;
	height: auto;
	padding-top: 10px;
	padding-bottom: 10px;
	border: none;
	border-radius: 0;
	background: transparent;
	color: var(--color-posebyen-green);
	font-weight: 500;
	font-size: 0.875rem;
	gap: 6px;
	justify-content: flex-start;
}

.team-card__content .team-card__btn:hover,
.team-card .team-card__content .btn.team-card__btn:hover {
	background: transparent;
	color: var(--color-green-dark);
	box-shadow: none;
	border: none;
	transform: none;
}

.team-card__content .team-card__btn svg,
.team-card .team-card__content .btn.team-card__btn svg {
	flex-shrink: 0;
	width: 14px;
	height: 14px;
	position: relative;
	top: -0.5px;
}

.team-card__name {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-xs);
}

.team-card__title {
	font-size: 0.875rem;
	color: var(--color-accent);
	font-weight: 500;
	margin-bottom: var(--space-md);
}

.team-card__bio {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	line-height: 1.6;
	margin-bottom: var(--space-lg);
}

/* Section quote (blockquote) - used on Om oss and similar */
.section-quote {
	width: 100%;
	max-width: 920px;
	margin: 0 auto;
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: clamp(1.25rem, 2.5vw, 2.25rem);
}

.section-quote blockquote {
	font-family: var(--font-heading);
	font-size: clamp(1.125rem, 2.4vw, 1.5rem);
	font-weight: 400;
	font-style: italic;
	line-height: 1.55;
	color: var(--color-posebyen-green);
	border-left: none;
	padding-left: 0;
	margin: 0;
	text-wrap: balance;
}

.section-quote__attribution {
	margin-top: var(--space-lg);
	color: var(--color-text-muted);
	font-size: 0.9375rem;
	text-align: right;
}

@media (max-width: 768px) {
	.section-quote {
		max-width: none;
		padding: var(--space-lg);
	}

	.section-quote blockquote {
		font-size: 1.125rem;
	}
}

/* Content width constraints */
.container--narrow-max {
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}

.container--text-max {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

/* About rows – alternating image + text (Om oss) */
.about-row {
	display: grid;
	gap: var(--space-3xl);
	align-items: center;
	margin-bottom: var(--space-4xl);
}

.about-row:last-child {
	margin-bottom: 0;
}

@media (min-width: 768px) {
	.about-row {
		grid-template-columns: 1fr 1fr;
	}

	.about-row--reversed {
		direction: rtl;
	}

	.about-row--reversed > * {
		direction: ltr;
	}
}

.about-row__image {
	position: relative;
	border-radius: var(--radius-2xl);
	overflow: hidden;
}

.about-row__image img {
	width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: var(--radius-2xl);
	aspect-ratio: 4 / 3;
}

.about-row__placeholder {
	aspect-ratio: 4 / 3;
	background: var(--color-green-light);
	border-radius: var(--radius-2xl);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-posebyen-green);
}

.about-row__placeholder svg {
	width: 64px;
	height: 64px;
	opacity: 0.5;
}

.about-row__title {
	font-family: var(--font-heading);
	font-size: clamp(1.375rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-lg);
	line-height: 1.3;
}

.about-row__text {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--color-text-muted);
	max-width: 50ch;
}

/* ============================================
   Ansatt (single) page – align with design system
   ============================================ */

.ansatt-header {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-3xl);
	align-items: start;
	margin-bottom: var(--space-4xl);
}

.ansatt-image-wrapper img,
.ansatt-image-wrapper .ansatt-avatar {
	width: 200px;
	height: 200px;
	border-radius: var(--radius-full);
	object-fit: cover;
	border: 3px solid var(--color-accent);
	transition: all var(--transition-base);
}

.ansatt-image-wrapper .ansatt-avatar {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--color-posebyen-green), var(--color-green-medium));
	color: var(--color-white);
	font-size: 4rem;
	font-weight: 600;
	font-family: var(--font-heading);
}

.ansatt-info h1,
.ansatt-info .ansatt-name {
	margin-top: 0;
	margin-bottom: var(--space-md);
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 300;
	font-family: var(--font-heading);
	color: var(--color-posebyen-green);
}

.ansatt-info .ansatt-title {
	margin: 0 0 var(--space-lg) 0;
	font-size: 1.25rem;
	color: var(--color-text-muted);
	font-style: italic;
}

.ansatt-info .ansatt-specialization {
	margin: 0 0 var(--space-md) 0;
	font-size: 1rem;
}

.ansatt-contact {
	margin-top: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.ansatt-contact--buttons {
	flex-direction: row;
	flex-wrap: wrap;
	gap: var(--space-md);
}

.ansatt-contact--buttons .btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
}

.ansatt-contact p {
	margin: 0;
	font-size: 1rem;
}

.ansatt-contact a {
	color: var(--color-posebyen-green);
	text-decoration: none;
	transition: color var(--transition-base);
}

.ansatt-contact:not(.ansatt-contact--buttons) a:hover {
	color: var(--color-accent);
}

.ansatt-bio {
	margin-bottom: var(--space-4xl);
	max-width: 65ch;
}

.ansatt-bio .ansatt-bio__title {
	margin-bottom: var(--space-xl);
	font-size: 1.75rem;
	font-weight: 300;
	font-family: var(--font-heading);
	color: var(--color-posebyen-green);
}

.ansatt-bio__content {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--color-text-muted);
}

.ansatt-courses__title {
	margin-bottom: var(--space-2xl);
	font-size: 1.75rem;
	font-weight: 300;
	font-family: var(--font-heading);
	color: var(--color-posebyen-green);
}

.ansatt-courses-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-xl);
}

.ansatt-courses-grid .course-card {
	border: var(--card-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	transition: all var(--transition-base);
}

.ansatt-courses-grid .course-card:hover {
	border-color: var(--color-border-hover);
	box-shadow: var(--shadow-hover);
}

.ansatt-courses-grid .course-card__image {
	margin-bottom: var(--space-md);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.ansatt-courses-grid .course-card__image img {
	width: 100%;
	height: auto;
	display: block;
}

.ansatt-courses-grid .course-card__meta {
	margin: var(--space-sm) 0;
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

/* Responsive Om Oss */
@media (max-width: 768px) {
	.hero--about {
		padding-top: var(--space-4xl);
		padding-bottom: var(--space-3xl);
	}
	
	.value-card {
		padding: var(--space-xl);
	}
	
	.location-card {
		padding: var(--space-2xl);
	}
}

/* ============================================
   Articles / News Styles
   ============================================ */

/* Hero Articles Variant */
.hero--articles {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
	background: linear-gradient(180deg, var(--color-soft-base) 0%, var(--color-white) 100%);
}

.hero--single-post {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
}

/* Articles Grid */
.articles-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-2xl);
	margin-bottom: var(--space-4xl);
}

@media (max-width: 1024px) {
	.articles-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-xl);
	}
}

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

/* Article Card */
.article-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
}

.article-card:hover {
	border-color: var(--color-border-hover);
}

.article-card__image {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--color-green-light);
	display: block;
}

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

.article-card:hover .article-card__image img {
	transform: scale(1.1);
}

.article-card__overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(180deg, transparent 0%, rgba(29, 59, 50, 0.3) 100%);
	opacity: 0;
	transition: opacity var(--transition-base);
}

.article-card:hover .article-card__overlay {
	opacity: 1;
}

.article-card__content {
	padding: var(--space-xl);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.article-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-md);
	font-size: 0.875rem;
}

.article-card__category {
	background: var(--color-green-light);
	color: var(--color-posebyen-green);
	padding: var(--space-xs) var(--space-md);
	border-radius: var(--radius-full);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.75rem;
}

.article-card__date {
	color: var(--color-text-muted);
}

.article-card__title {
	font-family: var(--font-heading);
	font-size: 1.375rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-md);
	line-height: 1.4;
}

.article-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition-base);
}

.article-card__title a:hover {
	color: var(--color-posebyen-green);
}

.article-card__excerpt {
	color: var(--color-text-muted);
	line-height: 1.7;
	margin-bottom: var(--space-lg);
	flex: 1;
}

.article-card__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	color: var(--color-posebyen-green);
	font-weight: 500;
	text-decoration: none;
	font-size: 0.9375rem;
	transition: gap var(--transition-base);
	margin-top: auto;
}

.article-card__link:hover {
	gap: var(--space-md);
}

.article-card__link svg {
	transition: transform var(--transition-base);
}

.article-card__link:hover svg {
	transform: translateX(4px);
}

/* Single Article */
.article-single {
	margin-bottom: 0;
}

.article-excerpt {
	font-style: italic;
}

.entry-content {
	max-width: 100%;
}

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

.entry-content h2,
.entry-content h3,
.entry-content h4 {
	font-family: var(--font-heading);
	margin-top: var(--space-3xl);
	margin-bottom: var(--space-lg);
	color: var(--color-text);
}

.entry-content h2 {
	font-size: 2rem;
}

.entry-content h3 {
	font-size: 1.5rem;
}

.entry-content h4 {
	font-size: 1.25rem;
}

.entry-content ul,
.entry-content ol {
	margin-bottom: var(--space-xl);
	padding-left: var(--space-2xl);
}

.entry-content li {
	margin-bottom: var(--space-sm);
}

.entry-content blockquote {
	border-left: none;
	padding-left: var(--space-xl);
	margin: var(--space-2xl) 0;
	font-style: italic;
	color: var(--color-text-muted);
	font-size: 1.125rem;
}

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

.entry-content a {
	color: var(--color-posebyen-green);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color var(--transition-base);
}

.entry-content a:hover {
	color: var(--color-green-medium);
}

/* Article Footer */
.article-footer__section {
	margin-bottom: var(--space-xl);
}

.article-tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.article-tag {
	display: inline-block;
	padding: var(--space-xs) var(--space-md);
	background: var(--color-soft-base);
	color: var(--color-text);
	border-radius: var(--radius-md);
	text-decoration: none;
	font-size: 0.875rem;
	transition: all var(--transition-base);
}

.article-tag:hover {
	background: var(--color-posebyen-green);
	color: var(--color-white);
}

/* Post Navigation */
.post-navigation {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
}

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

.post-navigation__link {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-xl);
	background: var(--color-white);
	border-radius: var(--radius-lg);
	text-decoration: none;
	transition: all var(--transition-base);
	border: 1px solid var(--color-border);
}

.post-navigation__link:hover {
	border-color: var(--color-border-hover);
}

.post-navigation__link--prev {
	text-align: left;
}

.post-navigation__link--next {
	text-align: right;
	flex-direction: row-reverse;
}

.post-navigation__label {
	display: block;
	font-size: 0.875rem;
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--space-xs);
}

.post-navigation__title {
	display: block;
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 300;
	color: var(--color-text);
	line-height: 1.4;
}

.post-navigation__link svg {
	color: var(--color-posebyen-green);
	flex-shrink: 0;
}

/* Pagination */
.pagination-wrapper {
	margin-top: var(--space-4xl);
	text-align: center;
}

.pagination-wrapper .page-numbers {
	display: inline-flex;
	gap: var(--space-sm);
	list-style: none;
	padding: 0;
	margin: 0;
}

.pagination-wrapper .page-numbers li {
	display: inline-block;
}

.pagination-wrapper .page-numbers a,
.pagination-wrapper .page-numbers span {
	display: inline-block;
	padding: var(--space-sm) var(--space-md);
	border-radius: var(--radius-md);
	text-decoration: none;
	color: var(--color-text);
	background: var(--color-white);
	border: 1px solid var(--color-border);
	transition: all var(--transition-base);
}

.pagination-wrapper .page-numbers a:hover {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border-color: var(--color-posebyen-green);
}

.pagination-wrapper .page-numbers .current {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border-color: var(--color-posebyen-green);
}

/* Container Narrow */
.container--narrow {
	max-width: 860px;
	margin: 0 auto;
}

/* Responsive Articles */
@media (max-width: 768px) {
	.hero--articles,
	.hero--single-post {
		padding-top: var(--space-4xl);
		padding-bottom: var(--space-3xl);
	}
	
	.article-card__content {
		padding: var(--space-lg);
	}
	
	.article-card__title {
		font-size: 1.25rem;
	}
	
	.entry-content {
		font-size: 1rem;
	}
	
	.entry-content h2 {
		font-size: 1.75rem;
	}
	
	.entry-content h3 {
		font-size: 1.375rem;
	}
}

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

/* Hero Contact Variant */
.hero--contact {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
	background: linear-gradient(180deg, var(--color-soft-base) 0%, var(--color-white) 100%);
}

.hero--contact .hero__content {
	max-width: none;
	text-align: left;
}

/* Contact Info Card */
.contact-info-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	padding: var(--space-3xl);
	box-shadow: var(--shadow-sm);
	margin-bottom: var(--space-2xl);
}

.contact-info-card__title {
	font-family: var(--font-heading);
	font-size: 1.75rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-2xl);
}

.contact-info-item {
	display: flex;
	gap: var(--space-lg);
	margin-bottom: var(--space-2xl);
	align-items: flex-start;
}

.contact-info-item:last-child {
	margin-bottom: 0;
}

.contact-info-item__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: var(--color-green-light);
	border-radius: var(--radius-lg);
	color: var(--color-posebyen-green);
	flex-shrink: 0;
}

.contact-info-item__content h3 {
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-text-muted);
	margin-bottom: var(--space-xs);
	font-weight: 300;
}

.contact-info-item__content a {
	color: var(--color-posebyen-green);
	text-decoration: none;
	font-size: 1.125rem;
	font-weight: 500;
	transition: color var(--transition-base);
}

.contact-info-item__content a:hover {
	color: var(--color-green-medium);
	text-decoration: underline;
}

.contact-info-item__content p {
	color: var(--color-text);
	margin: 0;
	line-height: 1.6;
}

/* Opening Hours Card */
.contact-hours-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	padding: var(--space-3xl);
	box-shadow: var(--shadow-sm);
}

.contact-hours-card__title {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-xl);
}

.contact-hours-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.contact-hours-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border-light);
}

.contact-hours-item:last-child {
	border-bottom: none;
}

.contact-hours-item__day {
	color: var(--color-text);
	font-weight: 500;
}

.contact-hours-item__hours {
	color: var(--color-text-muted);
}

/* Contact Form Card */
.contact-form-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--space-2xl);
	box-shadow: var(--shadow-sm);
}

.contact-form-card__title {
	font-family: var(--font-heading);
	font-size: 1.375rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
}

.contact-form-card__description {
	color: var(--color-text-muted);
	font-size: 0.9375rem;
	margin-bottom: var(--space-xl);
	line-height: 1.6;
}

.contact-form-wrapper {
	margin-top: var(--space-lg);
}

/* Contact Form Messages */
.contact-form-message {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
	padding: var(--space-lg);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-xl);
}

.contact-form-message--success {
	background: var(--color-green-light);
	color: var(--color-success);
	border: 1px solid var(--color-success);
}

.contact-form-message--error {
	background: #FEE;
	color: var(--color-error);
	border: 1px solid var(--color-error);
}

.contact-form-message svg {
	flex-shrink: 0;
	margin-top: 2px;
}

.contact-form-message p {
	margin: 0;
	font-weight: 500;
}

/* Contact Form */
.contact-form {
	margin-top: var(--space-lg);
}

.contact-form-card .form-group {
	margin-bottom: var(--space-lg);
}

.form-group label {
	display: block;
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: var(--space-xs);
	font-size: 0.875rem;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
	width: 100%;
	padding: var(--space-sm) var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	color: var(--color-text);
	background: var(--color-white);
	transition: all var(--transition-base);
}

.form-group input[type="text"]:focus,
.form-group input[type="email"]:focus,
.form-group input[type="tel"]:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--color-posebyen-green);
	box-shadow: none;
}

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

.contact-form-card .btn--lg {
	padding: var(--space-sm) var(--space-lg);
	font-size: 0.9375rem;
}

/* Contact Map */
.contact-map-wrapper {
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-lg);
	margin-top: var(--space-2xl);
}

.contact-map-wrapper iframe {
	width: 100%;
	height: 450px;
	border: none;
	display: block;
}

.contact-map-link {
	display: block;
	text-decoration: none;
}

.contact-map-placeholder {
	background: var(--color-green-light);
	height: 450px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-lg);
	color: var(--color-posebyen-green);
	transition: all var(--transition-base);
}

.contact-map-placeholder:hover {
	background: var(--color-posebyen-green);
	color: var(--color-white);
}

.contact-map-placeholder p {
	font-size: 1.125rem;
	font-weight: 500;
	margin: 0;
}

/* Responsive Contact */
@media (max-width: 1024px) {
	.contact-info-card,
	.contact-hours-card,
	.contact-form-card {
		padding: var(--space-2xl);
	}
}

@media (max-width: 768px) {
	.hero--contact {
		padding-top: var(--space-4xl);
		padding-bottom: var(--space-3xl);
	}
	
	.contact-info-card,
	.contact-hours-card,
	.contact-form-card {
		padding: var(--space-xl);
	}
	
	.contact-info-item {
		flex-direction: column;
		gap: var(--space-md);
	}
	
	.contact-info-item__icon {
		width: 40px;
		height: 40px;
	}
	
	.contact-map-wrapper iframe,
	.contact-map-placeholder {
		height: 350px;
	}
}

/* ============================================
   Behandler Page Styles
   ============================================ */

/* Hero Behandler Variant */
.behandler-hero-section {
	background: var(--color-soft-base);
	padding: var(--space-4xl) 0;
}

.behandler-hero {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-areas:
		"image header"
		"image content";
	column-gap: var(--space-4xl);
	row-gap: var(--space-sm);
	align-items: start;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-xl);
}

.behandler-hero__header {
	grid-area: header;
	text-align: left;
}

.behandler-hero__header .section-header__label {
	justify-content: flex-start;
}

.behandler-hero__image {
	position: relative;
	grid-area: image;
}

.behandler-hero__content {
	grid-area: content;
	display: flex;
	flex-direction: column;
}

.behandler-hero__image img {
	width: 380px;
	height: auto;
	max-height: 480px;
	object-fit: cover;
	object-position: center top;
	border-radius: var(--radius-xl);
}

.behandler-hero__placeholder {
	width: 380px;
	height: 480px;
	border-radius: var(--radius-xl);
	background: linear-gradient(135deg, var(--color-posebyen-green), var(--color-green-medium));
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-white);
	font-size: 120px;
	font-weight: 600;
	font-family: var(--font-heading);
}

.behandler-hero__name {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 300;
	color: var(--color-posebyen-green);
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin: var(--space-md) 0 0;
	text-align: left;
}

.behandler-hero__role {
	font-family: var(--font-heading);
	font-style: italic;
	font-size: 1.25rem;
	color: var(--color-accent);
	margin: 0;
}

.behandler-hero__spec {
	font-size: 1rem;
	color: var(--color-text-muted);
	margin: var(--space-xs) 0 0;
	line-height: 1.6;
}

.behandler-hero__quote {
	font-size: 1.125rem;
	font-style: italic;
	color: var(--color-text-muted);
	border-left: 3px solid var(--color-accent);
	padding-left: var(--space-lg);
	margin: var(--space-xl) 0 0;
	font-family: var(--font-heading);
	line-height: 1.6;
}

.behandler-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	margin-top: var(--space-lg);
}

@media (max-width: 768px) {
	.behandler-hero {
		grid-template-columns: 1fr;
		grid-template-areas:
			"header"
			"image"
			"content";
		text-align: center;
	}

	.behandler-hero__image img {
		width: 100%;
		max-width: 320px;
		margin: 0 auto;
	}

	.behandler-hero__placeholder {
		width: 100%;
		max-width: 320px;
		height: 400px;
		margin: 0 auto;
	}

	.behandler-hero__actions {
		justify-content: center;
	}

	.behandler-hero__quote {
		text-align: left;
	}
}

/* About Section */
.behandler-about {
	margin-bottom: var(--space-4xl);
}

.behandler-about__content {
	max-width: 100%;
}

.behandler-bio {
	max-width: 100%;
}

.behandler-bio p {
	margin-bottom: var(--space-xl);
}

.behandler-bio p:first-child {
	margin-top: 0;
}

.behandler-bio p:last-child {
	margin-bottom: 0;
}

.behandler-bio h2,
.behandler-bio h3,
.behandler-bio h4 {
	font-family: var(--font-heading);
	margin-top: var(--space-2xl);
	margin-bottom: var(--space-lg);
}

/* Competencies */
.behandler-competencies {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
}

.competency-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-md) var(--space-xl);
	background: var(--color-white);
	border: 2px solid var(--color-posebyen-green);
	border-radius: var(--radius-full);
	color: var(--color-posebyen-green);
	font-weight: 500;
	transition: all var(--transition-base);
}

.competency-badge:hover {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.competency-badge svg {
	flex-shrink: 0;
}

/* Education */
.behandler-section-title {
	font-family: var(--font-heading);
	font-size: 1.75rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-2xl);
}

.behandler-education-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.behandler-education-item {
	padding: var(--space-xl) 0;
	border-bottom: 1px solid var(--color-border-light);
}

.behandler-education-item:last-child {
	border-bottom: none;
}

.behandler-education-item__content h4 {
	font-size: 1.125rem;
	font-weight: 300;
	color: var(--color-text);
	margin-bottom: var(--space-xs);
}

.behandler-education-item__institution {
	color: var(--color-text-muted);
	margin-bottom: var(--space-xs);
}

.behandler-education-item__year {
	display: inline-block;
	padding: var(--space-xs) var(--space-md);
	background: var(--color-green-light);
	color: var(--color-posebyen-green);
	border-radius: var(--radius-md);
	font-size: 0.875rem;
	font-weight: 500;
}

/* Certifications */
.behandler-certifications-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.behandler-certification-item {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border-light);
}

.behandler-certification-item:last-child {
	border-bottom: none;
}

.behandler-certification-item svg {
	color: var(--color-success);
	flex-shrink: 0;
}

.behandler-certification-item span {
	color: var(--color-text);
}

/* Responsive Behandler */
@media (max-width: 768px) {
	.behandler-competencies {
		justify-content: center;
	}
}

/* ============================================
   Services Page Styles
   ============================================ */

/* Hero Services Variant */
.hero--services {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
	background: linear-gradient(180deg, var(--color-soft-base) 0%, var(--color-white) 100%);
}

.hero--service {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
	min-height: 50vh;
	display: flex;
	align-items: center;
}

.hero--service .hero__content {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.hero--service .hero__description {
	font-size: 1.125rem;
	line-height: 1.7;
	color: var(--color-text-muted);
}

/* Service hero with image (split layout) */
.hero--service-with-image .hero__inner {
	min-height: 0;
}

.hero--service-with-image .hero__inner--split {
	display: grid;
	gap: var(--space-3xl);
	align-items: center;
	text-align: left;
}

@media (min-width: 1024px) {
	.hero--service-with-image .hero__inner--split {
		grid-template-columns: 1fr 1fr;
	}

	.hero--service-with-image .hero__content {
		text-align: left;
		margin: 0;
	}

	.hero--service-with-image .hero__description {
		margin: 0;
	}
}

.hero__label {
	display: block;
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-md);
}

.hero__image--service {
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

.hero__image--service img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

/* Services Grid */
.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--space-2xl);
}

.service-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
}

.service-card:hover {
	border-color: var(--color-border-hover);
}

.service-card__image {
	display: block;
	width: 100%;
	height: 200px;
	overflow: hidden;
}

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

.service-card:hover .service-card__image img {
	transform: scale(1.05);
}

.service-card__icon {
	padding: var(--space-2xl);
	text-align: center;
	background: var(--color-green-light);
	color: var(--color-posebyen-green);
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
}

.service-card__icon svg {
	width: 64px;
	height: 64px;
}

.service-card__body {
	padding: var(--space-2xl);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.service-card__title {
	font-size: 1.5rem;
	font-weight: 300;
	margin-bottom: var(--space-md);
	font-family: var(--font-heading);
}

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

.service-card__title a:hover {
	color: var(--color-posebyen-green);
}

.service-card__description {
	color: var(--color-text-muted);
	margin-bottom: var(--space-xl);
	line-height: 1.7;
	flex: 1;
}

.service-card .btn {
	margin-top: auto;
	align-self: flex-start;
}

/* Service Card - No Image Variant */
.service-card--no-image {
	border-top: 3px solid var(--color-posebyen-green);
}

.service-card--no-image .service-card__body {
	padding-top: var(--space-2xl);
	text-align: center;
	align-items: center;
}

.service-card--no-image .service-card__title {
	margin-top: 0;
	color: var(--color-posebyen-green);
	font-weight: 300;
}

.service-card--no-image .service-card__ingress {
	margin-bottom: var(--space-lg);
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--color-text-muted, var(--color-text));
	max-width: 28ch;
	margin-left: auto;
	margin-right: auto;
}

.service-card--no-image .btn {
	align-self: center;
	margin-top: var(--space-md);
}

/* Front page services buttons: text on one line */
.home .service-card--no-image .btn.btn--sm {
	padding: 0.85rem 1.75rem;
	font-size: 0.75rem;
	white-space: nowrap;
}

.service-card--no-image:hover {
	border-top-color: var(--color-rose);
}

.service-card--no-image:hover .service-card__title {
	color: var(--color-rose);
}

/* Front page services - cleaner layout, no odd line breaks */
.services-grid-front .service-card--no-image {
	display: flex;
	flex-direction: column;
}

.services-grid-front .service-card__body {
	display: flex;
	flex-direction: column;
	flex: 1;
}

.services-grid-front .service-card__ingress {
	hyphens: auto;
	overflow-wrap: break-word;
}

/* ============================================
   Services Showcase (Front Page)
   ============================================ */

.services-showcase {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
}

.service-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	background: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--color-border);
	transition: all var(--transition-base);
	text-decoration: none;
	color: inherit;
}

.service-row:hover {
	border-color: var(--color-border);
	box-shadow: 0 4px 24px rgba(0,0,0,0.06);
	color: inherit;
}

.service-row--reversed {
	direction: rtl;
}

.service-row--reversed > * {
	direction: ltr;
}

.service-row__image {
	position: relative;
	overflow: hidden;
	min-height: 320px;
}

.service-row__image img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.service-row:hover .service-row__image img {
	transform: scale(1.04);
}

.service-row__placeholder {
	width: 100%;
	height: 100%;
	min-height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--color-green-light) 0%, var(--color-sand) 100%);
	color: var(--color-posebyen-green);
	font-size: 5rem;
	font-family: var(--font-heading);
	font-weight: 300;
	opacity: 0.4;
}

.service-row__content {
	padding: var(--space-3xl) var(--space-3xl);
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.service-row__label {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-accent);
	margin-bottom: var(--space-sm);
}

.service-row__title {
	font-family: var(--font-heading);
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-lg);
	line-height: 1.2;
}

.service-row:hover .service-row__title {
	color: var(--color-green-dark);
}

.service-row__description {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--color-text-muted);
	margin-bottom: var(--space-xl);
	max-width: 48ch;
}

.service-row__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-posebyen-green);
	margin-top: auto;
	transition: all var(--transition-base);
}

.service-row:hover .service-row__link {
	color: var(--color-accent);
	gap: var(--space-md);
}

.service-row__link svg {
	transition: transform var(--transition-base);
}

.service-row:hover .service-row__link svg {
	transform: translateX(4px);
}

/* Tablet */
@media (max-width: 900px) {
	.service-row {
		grid-template-columns: 1fr;
	}

	.service-row--reversed {
		direction: ltr;
	}

	.service-row__image {
		min-height: 240px;
	}

	.service-row__placeholder {
		min-height: 240px;
	}

	.service-row__content {
		padding: var(--space-2xl);
	}
}

/* Mobile */
@media (max-width: 640px) {
	.service-row__image {
		min-height: 200px;
	}

	.service-row__placeholder {
		min-height: 200px;
	}

	.service-row__content {
		padding: var(--space-xl);
	}

	.service-row__title {
		font-size: 1.375rem;
	}
}

/* Service sections – consistent spacing */
.tjeneste-page .service-section .container--wide {
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
}

/* Service Content */
.service-content {
	font-size: 1.125rem;
	line-height: 1.9;
	color: var(--color-text);
}

.service-content--prose {
	max-width: 70ch;
	line-height: 1.8;
	font-size: 1.0625rem;
}

.tjeneste-page .service-section--intro .section-header,
.tjeneste-page .service-section--why .section-header {
	margin-bottom: var(--space-xl);
}

.tjeneste-page .service-section--intro .service-content--prose,
.tjeneste-page .service-section--why .service-content--prose {
	max-width: none;
}

.tjeneste-page .service-content--prose {
	font-size: 1.0625rem;
}

.service-content--prose p {
	margin-bottom: var(--space-xl);
}

.service-content--prose p:last-child {
	margin-bottom: 0;
}

.service-content p {
	margin-bottom: var(--space-xl);
}

.service-content h2,
.service-content h3,
.service-content h4 {
	font-family: var(--font-heading);
	margin-top: var(--space-2xl);
	margin-bottom: var(--space-lg);
	line-height: 1.3;
}

.service-content h2 { font-size: 1.5rem; }
.service-content h3 { font-size: 1.25rem; }
.service-content h4 { font-size: 1.125rem; }

.service-content ul,
.service-content ol {
	margin-bottom: var(--space-xl);
	padding-left: var(--space-2xl);
}

.service-content li {
	margin-bottom: var(--space-sm);
}

/* Intro-row – split layout with image (service-section--intro) */
.service-section--intro .intro-row {
	max-width: none;
}

.intro-row:not(.intro-row--has-image) {
	max-width: 720px;
}

.intro-row--has-image {
	display: grid;
	gap: var(--space-3xl);
	align-items: start;
	max-width: none;
}

@media (min-width: 768px) {
	.intro-row--has-image {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-4xl);
	}
}

@media (min-width: 900px) {
	.intro-row--has-image {
		grid-template-columns: 1.15fr 0.85fr;
		align-items: stretch;
		gap: var(--space-4xl);
	}
}

.intro-row__content {
	min-width: 0;
}

.intro-row__image {
	border-radius: var(--radius-xl);
	overflow: hidden;
	min-height: 260px;
	background: var(--color-soft-base);
	box-shadow: var(--shadow-sm);
}

.intro-row__image img {
	width: 100%;
	height: 100%;
	min-height: 260px;
	object-fit: cover;
	border-radius: var(--radius-xl);
	display: block;
}

@media (min-width: 900px) {
	.intro-row__image {
		min-height: 0;
		height: 100%;
	}
	.intro-row__image img {
		min-height: 100%;
		height: 100%;
	}
}

/* Why-row – split layout with image */
.service-section--why .why-row {
	max-width: none;
}

.why-row:not(.why-row--has-image) {
	max-width: 720px;
}

.why-row--has-image {
	display: grid;
	gap: var(--space-3xl);
	align-items: center;
	max-width: none;
}

@media (min-width: 768px) {
	.why-row--has-image {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-4xl);
	}
}

@media (min-width: 900px) {
	.tjeneste-page .why-row--has-image {
		grid-template-columns: 1.15fr 0.85fr;
		align-items: stretch;
		gap: var(--space-4xl);
	}
}

.why-row__content {
	min-width: 0;
}

.why-row__image {
	border-radius: var(--radius-xl);
	overflow: hidden;
	background: var(--color-soft-base);
	box-shadow: var(--shadow-sm);
}

.why-row__image img {
	width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: var(--radius-xl);
	aspect-ratio: 4 / 3;
}

.section-header--left {
	text-align: left;
}

.section-header--left .section-header__title {
	margin-bottom: var(--space-xl);
}

/* Feature Cards */
.feature-card {
	background: var(--color-white);
	padding: var(--space-2xl);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border-light);
	transition: all var(--transition-base);
}

.grid--features {
	gap: var(--space-xl);
}

.feature-card--service {
	padding: var(--space-xl) var(--space-2xl);
	text-align: left;
}

.feature-card:hover {
	border-color: var(--color-posebyen-green);
	box-shadow: var(--shadow-md);
}

.feature-card__title {
	font-size: 1.25rem;
	font-weight: 300;
	margin-bottom: var(--space-md);
	color: var(--color-posebyen-green);
	text-align: center;
}

.feature-card__description {
	color: var(--color-text-muted);
	line-height: 1.7;
}

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

.kvinnehelse-services-list__item {
	display: flex;
	gap: var(--space-md);
	padding: var(--space-lg);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
}

.kvinnehelse-services-list--no-icons .kvinnehelse-services-list__item {
	display: block;
}

.kvinnehelse-services-list__index {
	width: 2rem;
	height: 2rem;
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-full);
	background: rgba(47, 82, 70, 0.08);
	color: var(--color-posebyen-green);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.kvinnehelse-services-list__content h2,
.kvinnehelse-services-list__content h3,
.kvinnehelse-services-list__title {
	margin: 0 0 var(--space-md) 0;
	font-size: 1.125rem;
	color: var(--color-posebyen-green);
}

.kvinnehelse-services-list__description {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

/* Process Steps */
.process-steps {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
}

.process-steps--service {
	gap: var(--space-2xl);
	max-width: 65ch;
}

.process-step {
	display: flex;
	gap: var(--space-xl);
	align-items: flex-start;
}

.process-step__number {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--color-posebyen-green);
	color: var(--color-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	font-weight: 600;
	flex-shrink: 0;
}

.process-step__content {
	flex: 1;
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--color-text);
}

.process-step__content p {
	margin-bottom: var(--space-md);
}

.process-step__content p:last-child {
	margin-bottom: 0;
}

/* Process Steps — visual / card layout (Slik fungerer det) */
.section-header--center {
	text-align: center;
	margin-bottom: var(--space-3xl);
	margin-left: auto;
	margin-right: auto;
}

.section-header--center .section-header__title {
	margin-top: var(--space-sm);
}

.section-header--center .section-header__description {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.process-steps--visual {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	max-width: none;
}

@media (min-width: 640px) {
	.process-steps--visual {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 900px) {
	.process-steps--visual {
		grid-template-columns: repeat(4, 1fr);
		gap: var(--space-2xl);
	}
}

.process-step--card {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0;
	background: var(--color-white);
	border-radius: var(--radius-xl);
	border: 1px solid var(--color-border-light);
	padding: var(--space-2xl);
	box-shadow: var(--shadow-sm);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.process-step--card:hover {
	border-color: rgba(47, 82, 70, 0.25);
	box-shadow: var(--shadow-md);
}

.process-step__visual {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
}

.process-step__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: var(--radius-lg);
	background: rgba(47, 82, 70, 0.08);
	color: var(--color-posebyen-green);
	flex-shrink: 0;
}

.process-step--card .process-step__number {
	width: 32px;
	height: 32px;
	font-size: 1rem;
	font-weight: 600;
}

.process-step--card .process-step__content {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--color-text);
}

.process-step--card .process-step__content p:first-child {
	margin-top: 0;
}

.process-steps--minimal {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-lg);
}

.process-steps--minimal .process-step--card {
	padding: var(--space-xl);
}

.process-steps--minimal .process-step__visual {
	margin-bottom: var(--space-md);
}

/* FAQ */
.faq-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.faq-list--service {
	gap: var(--space-lg);
	max-width: 720px;
}

.faq-item {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	transition: all var(--transition-base);
}

.faq-item:hover {
	border-color: var(--color-posebyen-green);
	box-shadow: var(--shadow-sm);
}

.faq-item__question {
	font-size: 1.125rem;
	font-weight: 500;
	margin-bottom: var(--space-md);
	color: var(--color-text);
	font-family: var(--font-heading);
	line-height: 1.4;
}

.faq-item--accordion {
	padding: 0;
	overflow: hidden;
}

.faq-item--accordion .faq-item__question {
	margin: 0;
	padding: var(--space-lg) var(--space-xl);
	cursor: pointer;
	list-style: none;
	position: relative;
}

.faq-item--accordion .faq-item__question::-webkit-details-marker {
	display: none;
}

.faq-item--accordion .faq-item__question::after {
	content: '+';
	position: absolute;
	right: var(--space-xl);
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.25rem;
	line-height: 1;
	color: var(--color-posebyen-green);
}

.faq-item--accordion[open] .faq-item__question::after {
	content: '−';
}

.faq-item--accordion .faq-item__answer {
	padding: 0 var(--space-xl) var(--space-xl);
}

.tjeneste-page .faq-list--service {
	max-width: none;
}

.service-courses-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-xl);
}

.service-course-card {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.service-course-card__image {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.service-course-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.service-course-card__body {
	padding: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.service-course-card__title {
	font-size: 1.2rem;
	margin: 0;
}

.service-course-card__title a {
	color: var(--color-posebyen-green);
	text-decoration: none;
}

.service-course-card__excerpt {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.service-course-card__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
	margin-top: var(--space-xs);
	margin-bottom: var(--space-sm);
}

.service-course-card__price {
	font-weight: 700;
	color: var(--color-posebyen-green);
}

.faq-item__answer {
	color: var(--color-text-muted);
	line-height: 1.8;
	font-size: 1rem;
}

.faq-item__answer p {
	margin-bottom: var(--space-md);
}

.faq-item__answer p:last-child {
	margin-bottom: 0;
}

/* Service page CTA block */
.service-cta__inner {
	text-align: center;
	max-width: 560px;
	margin: 0 auto;
}

.service-cta__title {
	font-family: var(--font-heading);
	font-size: clamp(1.375rem, 3vw, 1.75rem);
	font-weight: 300;
	color: var(--color-white);
	margin-bottom: var(--space-lg);
}

.service-cta__description {
	font-size: 1.0625rem;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: var(--space-2xl);
}

/* CTA Section with Accent Background */
.section--bg-accent {
	background: var(--color-posebyen-green);
	color: var(--color-white);
}

.btn--white {
	background: var(--color-white);
	color: var(--color-posebyen-green);
	border-color: var(--color-white);
}

.btn--white:hover {
	background: transparent;
	color: var(--color-white);
	border-color: var(--color-white);
	box-shadow: 0 4px 16px rgba(255, 255, 255, 0.25);
}

/* Responsive Services */
@media (max-width: 1024px) {
	.services-grid {
		grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
		gap: var(--space-xl);
	}
}

@media (max-width: 768px) {
	.hero--services,
	.hero--service {
		padding-top: var(--space-4xl);
		padding-bottom: var(--space-3xl);
	}
	
	.services-grid {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}
	
	.service-card__icon {
		min-height: 150px;
		padding: var(--space-xl);
	}
	
	.service-card__icon svg {
		width: 48px;
		height: 48px;
	}
	
	.process-step {
		flex-direction: column;
		gap: var(--space-md);
	}
	
	.process-step__number {
		width: 40px;
		height: 40px;
		font-size: 1.125rem;
	}
	
	.service-content {
		font-size: 1rem;
	}
	
	.feature-card {
		padding: var(--space-xl);
	}

	.kvinnehelse-services-list {
		grid-template-columns: 1fr;
	}

	.process-steps--minimal {
		grid-template-columns: 1fr;
	}

	.service-courses-grid {
		grid-template-columns: 1fr;
	}
}

/* ============================================
   WooCommerce Single Product Page Styles
   ============================================ */

/* Hero Product Variant */
.hero--product {
	padding-top: var(--space-5xl);
	padding-bottom: var(--space-4xl);
	min-height: 50vh;
	display: flex;
	align-items: center;
}

.product-hero {
	max-width: 800px;
}

/* Product Details Layout */
.product-details {
	display: grid;
	grid-template-columns: 1fr 400px;
	gap: var(--space-4xl);
	align-items: start;
}

@media (max-width: 1024px) {
	.product-details {
		grid-template-columns: 1fr;
		gap: var(--space-3xl);
	}
}

/* Product Gallery */
.product-gallery {
	margin-bottom: var(--space-3xl);
}

.product-gallery__main {
	border-radius: var(--radius-xl);
	overflow: hidden;
	margin-bottom: var(--space-lg);
	box-shadow: var(--shadow-lg);
}

.product-gallery__image {
	width: 100%;
	height: auto;
	display: block;
}

.product-gallery__thumbs {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
}

.product-gallery__thumb {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: var(--radius-md);
	border: 2px solid var(--color-border-light);
	cursor: pointer;
	transition: all var(--transition-base);
}

.product-gallery__thumb:hover {
	border-color: var(--color-posebyen-green);
	transform: scale(1.05);
}

/* Product Description */
.product-description {
	margin-bottom: var(--space-3xl);
}

.product-description__content {
	font-size: 1.125rem;
	line-height: 1.9;
	color: var(--color-text);
}

.product-description__content p {
	margin-bottom: var(--space-xl);
}

.product-description__content h2,
.product-description__content h3,
.product-description__content h4 {
	font-family: var(--font-heading);
	margin-top: var(--space-2xl);
	margin-bottom: var(--space-lg);
}

.product-description__content ul,
.product-description__content ol {
	margin-bottom: var(--space-xl);
	padding-left: var(--space-2xl);
}

.product-description__content li {
	margin-bottom: var(--space-md);
}

/* Product Sidebar */
.product-sidebar {
	position: sticky;
	top: var(--space-xl);
}

.product-sidebar__card {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-xl);
	padding: var(--space-2xl);
	box-shadow: var(--shadow-md);
}

/* Product Price */
.product-price {
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
	margin-bottom: var(--space-xl);
}

.product-price__label {
	display: block;
	font-size: 0.875rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-xs);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.product-price__amount {
	font-size: 2rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
	font-family: var(--font-heading);
}

.product-price__amount del {
	font-size: 1.25rem;
	color: var(--color-text-muted);
	margin-right: var(--space-sm);
}

/* Product Details List */
.product-details-list {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
}

.product-detail-item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
}

.product-detail-item:last-child {
	margin-bottom: 0;
}

.product-detail-item svg {
	color: var(--color-posebyen-green);
	flex-shrink: 0;
	margin-top: 2px;
}

.product-detail-item__label {
	display: block;
	font-size: 0.875rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-xs);
}

.product-detail-item__value {
	display: block;
	font-size: 1rem;
	font-weight: 500;
	color: var(--color-text);
}

/* Add to Cart */
.product-add-to-cart {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
}

.product-add-to-cart .quantity {
	margin-bottom: var(--space-lg);
}

.product-add-to-cart .quantity input {
	width: 100px;
	padding: var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-align: center;
	font-size: 1rem;
}

.product-add-to-cart .single_add_to_cart_button {
	width: 100%;
	padding: var(--space-lg);
	font-size: 1.125rem;
	font-weight: 600;
}

/* Product Tags */
.product-tags {
	margin-top: var(--space-xl);
}

.product-tags__label {
	display: block;
	font-size: 0.875rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}

.product-tags__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.product-tag {
	display: inline-block;
	padding: var(--space-xs) var(--space-md);
	background: var(--color-green-light);
	color: var(--color-posebyen-green);
	border-radius: var(--radius-full);
	font-size: 0.875rem;
	font-weight: 500;
}

/* Behandler Info in Product */
.product-sidebar .product-behandler-info {
	margin-top: var(--space-xl) !important;
	padding: var(--space-xl) !important;
	background: var(--color-green-light) !important;
	border-left: 4px solid var(--color-posebyen-green) !important;
	border-radius: var(--radius-md) !important;
}

.product-sidebar .product-behandler-info h3 {
	margin-top: 0 !important;
	margin-bottom: var(--space-md) !important;
	font-size: 1.125rem !important;
	color: var(--color-text) !important;
	font-family: var(--font-heading) !important;
}

.product-sidebar .product-behandler-info > div {
	display: grid !important;
	grid-template-columns: auto 1fr !important;
	gap: var(--space-md) !important;
	align-items: start !important;
}

.product-sidebar .product-behandler-info img {
	width: 80px !important;
	height: 80px !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	border: 2px solid var(--color-white) !important;
}

.product-sidebar .product-behandler-info > div > div {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.product-sidebar .product-behandler-info h4 {
	margin: 0 !important;
	font-size: 1rem !important;
	font-weight: 300 !important;
	color: var(--color-text) !important;
}

.product-sidebar .product-behandler-info p {
	margin: 0 !important;
	font-size: 0.875rem !important;
	color: var(--color-text-muted) !important;
}

.product-sidebar .product-behandler-info a {
	color: var(--color-posebyen-green) !important;
	text-decoration: none !important;
	transition: color var(--transition-base) !important;
}

.product-sidebar .product-behandler-info a:hover {
	color: var(--color-green-medium) !important;
	text-decoration: underline !important;
}

/* Related Products */
.products.grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-2xl);
	list-style: none;
	padding: 0;
	margin: 0;
}

.products.grid .course-card {
	margin: 0;
}

/* WooCommerce Form Elements */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	padding: var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: 1rem;
	width: 100%;
	transition: all var(--transition-base);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--color-posebyen-green);
	box-shadow: none;
}

.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button {
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border: none;
	padding: var(--space-md) var(--space-xl);
	border-radius: var(--radius-md);
	font-weight: 600;
	transition: all var(--transition-base);
	cursor: pointer;
}

.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	background: var(--color-green-medium);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

/* Product Layout Without Images */
.product-details--no-image {
	display: grid;
	grid-template-columns: 450px 1fr;
	gap: var(--space-4xl);
	align-items: start;
}

@media (max-width: 1024px) {
	.product-details--no-image {
		grid-template-columns: 1fr;
		gap: var(--space-3xl);
	}
}

/* Product Booking Card */
.product-booking-card {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-xl);
	padding: var(--space-2xl);
	box-shadow: var(--shadow-md);
	position: sticky;
	top: var(--space-xl);
}

@media (max-width: 1024px) {
	.product-booking-card {
		position: static;
	}
}

.product-booking-card__header {
	margin-bottom: var(--space-xl);
}

/* Large Price Variant */
.product-price--large .product-price__amount {
	font-size: 2.5rem;
}

.product-price--large {
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
	margin-bottom: var(--space-xl);
}

/* Details List in Card */
.product-details-list--card {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
}

.product-details-list--card .product-detail-item {
	margin-bottom: var(--space-lg);
}

.product-details-list--card .product-detail-item:last-child {
	margin-bottom: 0;
}

/* Add to Cart in Card */
.product-add-to-cart--card {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-light);
}

.product-add-to-cart--card:last-child {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}

/* Full Width Description */
.product-description--full {
	margin-bottom: 0;
}

.product-description--full .product-description__content {
	max-width: none;
}

/* Tags at Bottom */
.product-tags--bottom {
	margin-top: var(--space-2xl);
	padding-top: var(--space-2xl);
	border-top: 1px solid var(--color-border-light);
}

/* Behandler Info in Booking Card */
.product-booking-card .product-behandler-info {
	margin-top: var(--space-xl) !important;
	padding: var(--space-xl) !important;
	background: var(--color-green-light) !important;
	border-left: 4px solid var(--color-posebyen-green) !important;
	border-radius: var(--radius-md) !important;
}

/* Responsive Product Page */
@media (max-width: 768px) {
	.hero--product {
		padding-top: var(--space-4xl);
		padding-bottom: var(--space-3xl);
		min-height: 40vh;
	}
	
	.product-details {
		gap: var(--space-2xl);
	}
	
	.product-details--no-image {
		gap: var(--space-2xl);
	}
	
	.product-sidebar {
		position: static;
	}
	
	.product-booking-card {
		padding: var(--space-xl);
	}
	
	.product-sidebar__card {
		padding: var(--space-xl);
	}
	
	.product-price__amount {
		font-size: 1.75rem;
	}
	
	.product-price--large .product-price__amount {
		font-size: 2rem;
	}
	
	.product-gallery__thumb {
		width: 60px;
		height: 60px;
	}
	
	.product-description__content {
		font-size: 1rem;
	}
	
	.products.grid {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}
}

/* ================================
   COURSE SINGLE PAGE - NEW LAYOUT
   ================================ */

.course-single {
	--card-radius: 16px;
	--card-shadow: none;
}

/* Product hero image (top of single product) */
.course-single-hero {
	padding-top: 0;
	margin-bottom: 0;
}
.course-single-hero__image {
	width: 100%;
	aspect-ratio: 21 / 9;
	overflow: hidden;
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	background: var(--color-soft-base);
}
.course-single-hero__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Course Product Image (in content area) */
.course-product-image {
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-green-light);
}

.course-product-image img {
	width: 100%;
	height: auto;
	display: block;
}

.course-section--image {
	padding-bottom: 0;
}

/* Course Header */
.course-header {
	padding: var(--space-3xl) 0;
	background: linear-gradient(135deg, var(--color-bg-cream) 0%, var(--color-bg-soft) 100%);
}

/* Main Booking Card */
.course-booking-card {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: var(--space-2xl);
	align-items: center;
	background: var(--color-white);
	border-radius: var(--card-radius);
	box-shadow: var(--card-shadow);
	padding: var(--space-2xl) var(--space-3xl);
}

/* Date Badge */
.course-date-badge {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 90px;
	height: 90px;
	background: var(--color-rose);
	color: white;
	border-radius: 12px;
	text-align: center;
}

.course-date-badge__day {
	font-size: 2.25rem;
	font-weight: 700;
	line-height: 1;
	font-family: var(--font-heading);
}

.course-date-badge__month {
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 500;
	margin-top: 4px;
}

/* Course Info */
.course-info {
	flex: 1;
}

.course-category {
	display: inline-block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-rose);
	font-weight: 600;
	margin-bottom: var(--space-sm);
}

.course-title {
	margin: 0 0 var(--space-lg) 0;
	font-family: var(--font-heading);
	font-size: 2rem;
	font-weight: 300;
	letter-spacing: -0.02em;
	color: var(--color-text);
	line-height: 1.2;
}

.course-title-availability {
	margin: calc(-1 * var(--space-sm)) 0 var(--space-lg);
}

/* Course Meta */
.course-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-lg) var(--space-2xl);
	margin-bottom: var(--space-lg);
}

.course-meta__item {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: 0.9375rem;
	color: var(--color-text-muted);
}

.course-meta__item svg {
	color: var(--color-rose);
	flex-shrink: 0;
}

.course-meta__item--capacity {
	flex-wrap: wrap;
	gap: var(--space-xs) var(--space-sm);
}

/* Course Instructor (in header) */
.course-instructor {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border-light);
}

.course-instructor__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	overflow: hidden;
	background: linear-gradient(135deg, var(--color-posebyen-green), var(--color-green-medium));
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 600;
	font-size: 1.125rem;
}

.course-instructor__avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.course-instructor__info {
	display: flex;
	flex-direction: column;
}

.course-instructor__label {
	font-size: 0.75rem;
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.course-instructor__name {
	font-weight: 600;
	color: var(--color-text);
}

/* Course Booking Section */
.course-booking {
	text-align: center;
	padding-left: var(--space-2xl);
	border-left: 1px solid var(--color-border-light);
	min-width: 200px;
}

.course-price {
	margin-bottom: var(--space-lg);
}

.course-price .woocommerce-Price-amount {
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-text);
	font-family: var(--font-heading);
}

.course-price .woocommerce-Price-currencySymbol {
	font-size: 1.25rem;
	font-weight: 500;
}

.course-price__contact {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
}

.course-booking__form .cart {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.course-booking__form .quantity {
	display: none;
}

.course-booking__form .single_add_to_cart_button {
	width: 100%;
	height: 48px;
	padding: 14px 18px;
	background: var(--color-posebyen-green);
	color: var(--color-white);
	border: 1px solid var(--color-posebyen-green);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-transform: none;
	cursor: pointer;
	transition: all var(--transition-base);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin-inline: auto;
}

.course-booking__form .single_add_to_cart_button:hover {
	background: var(--color-green-dark);
	border-color: var(--color-green-dark);
	color: var(--color-white);
	transform: translateY(-2px);
}

.course-booking__availability {
	display: flex;
	justify-content: center;
	margin: 0 0 var(--space-md);
}

.course-booking__note {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	font-size: 0.8125rem;
	color: var(--color-text-muted);
	margin-top: var(--space-md);
}

.course-booking__note svg {
	color: var(--color-rose);
}

/* Course Content Section */
.course-content {
	padding: 1rem 0 var(--space-4xl);
}

.course-content__grid {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: var(--space-4xl);
	align-items: start;
}

.course-content__main {
	max-width: 720px;
}

/* Course Section */
.course-section {
	margin-bottom: var(--space-4xl);
}

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

.course-section__title {
	font-size: 1.75rem;
	font-family: var(--font-heading);
	font-weight: 300;
	color: var(--color-text);
	margin: 0 0 var(--space-xl) 0;
	padding-bottom: var(--space-md);
	border-bottom: 2px solid var(--color-rose);
	display: inline-block;
}

.course-section__body {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--color-text);
}

.course-section__body p {
	margin-bottom: var(--space-lg);
}

.course-section__body p:last-child {
	margin-bottom: 0;
}

.course-section__body h1 {
	line-height: 1.2;
	margin: 0 0 var(--space-md) 0;
}

.course-section__body h2 {
	font-size: 1.125rem;
	line-height: 1.35;
	margin: 0 0 var(--space-md) 0;
}

.course-section__body h3 {
	font-size: 1.0625rem;
	line-height: 1.4;
	margin: 0 0 var(--space-sm) 0;
}

.course-section__body h4 {
	font-size: 1rem;
}

.course-section__body h5 {
	font-size: 0.9375rem;
}

.course-section__body h6 {
	font-size: 0.875rem;
}

/* Course Features Grid */
.course-features {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
}

.course-feature {
	display: flex;
	gap: var(--space-md);
	padding: var(--space-lg);
	background: var(--color-bg-soft);
	border-radius: 12px;
}

.course-feature__icon {
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-white);
	border-radius: 10px;
	color: var(--color-rose);
	flex-shrink: 0;
}

.course-feature__content {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.course-feature__content strong {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	font-weight: 500;
}

.course-feature__content span {
	font-weight: 600;
	color: var(--color-text);
}

/* Sidebar */
.course-content__sidebar {
	position: sticky;
	top: 5.5rem;
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

/* Instructor Card */
.instructor-card {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: var(--card-radius);
	padding: var(--space-xl);
}

.instructor-card__title {
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-muted);
	margin: 0 0 var(--space-lg) 0;
	font-weight: 600;
}

.instructor-card__profile {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
}

.instructor-card__avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	overflow: hidden;
	background: linear-gradient(135deg, var(--color-posebyen-green), var(--color-green-medium));
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 600;
	font-size: 1.5rem;
	flex-shrink: 0;
}

.instructor-card__avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.instructor-card__info {
	display: flex;
	flex-direction: column;
}

.instructor-card__info strong {
	font-size: 1.125rem;
	color: var(--color-text);
}

.instructor-card__info span {
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

.instructor-card__bio {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	line-height: 1.6;
	margin: 0 0 var(--space-lg) 0;
}

.instructor-card__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--color-rose);
	text-decoration: none;
	transition: gap var(--transition-base);
}

.instructor-card__link:hover {
	gap: var(--space-md);
	color: var(--color-rose-dark);
}

/* Quick Booking Card (Sticky) */
.quick-booking-card {
	background: var(--color-soft-base);
	border: 1px solid var(--color-border-light);
	color: var(--color-text);
	border-radius: var(--card-radius);
	padding: var(--space-xl);
	text-align: center;
}

.quick-booking-card__price {
	margin-bottom: var(--space-lg);
}

.quick-booking-card__price .woocommerce-Price-amount {
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-text);
	font-family: var(--font-heading);
}

.quick-booking-card__price .woocommerce-Price-currencySymbol {
	font-size: 1.25rem;
}

.quick-booking-card__form .cart {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-md);
}

.quick-booking-card__form .quantity {
	display: none;
}

.quick-booking-card__form .single_add_to_cart_button {
	width: 100%;
	height: 48px;
	padding: 14px 18px;
	background: var(--color-posebyen-green);
	color: white;
	border: none;
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 0.875rem;
	letter-spacing: 0.01em;
	text-transform: none;
	cursor: pointer;
	transition: all var(--transition-base);
	text-align: center;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-inline: auto;
}

/* Ensure add-to-cart button is centered in single product fallback layouts */
.single-product form.cart {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-md);
}

.single-product form.cart .single_add_to_cart_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin-inline: auto;
	float: none;
}

.quick-booking-card__form .single_add_to_cart_button:hover {
	background: var(--color-green-dark);
	color: white;
	transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 1200px) {
	.course-content__grid {
		grid-template-columns: 1fr 320px;
		gap: var(--space-3xl);
	}
}

@media (max-width: 1024px) {
	.course-booking-card {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
		text-align: center;
	}
	
	.course-date-badge {
		display: none;
	}
	
	.course-booking {
		padding-left: 0;
		border-left: none;
		padding-top: var(--space-xl);
		border-top: 1px solid var(--color-border-light);
		min-width: auto;
	}
	
	.course-meta {
		justify-content: center;
	}
	
	.course-instructor {
		justify-content: center;
	}
	
	.course-content__grid {
		grid-template-columns: 1fr;
		gap: var(--space-3xl);
	}
	
	.course-content__main {
		max-width: none;
	}
	
	.course-content__sidebar {
		position: static;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-xl);
	}
	
	.instructor-card {
		order: 1;
	}
	
	.quick-booking-card {
		order: 2;
	}
}

@media (max-width: 768px) {
	.course-header {
		padding: var(--space-2xl) 0;
	}
	
	.course-booking-card {
		padding: var(--space-xl);
	}
	
	.course-features {
		grid-template-columns: 1fr;
	}
	
	.course-content__sidebar {
		grid-template-columns: 1fr;
	}
	
	.course-content {
		padding: var(--space-2xl) 0;
	}
	
	.course-section__title {
		font-size: 1.5rem;
	}
}

@media (max-width: 480px) {
	.course-meta {
		flex-direction: column;
		gap: var(--space-md);
		align-items: flex-start;
	}
	
	.course-booking-card {
		text-align: left;
	}
	
	.course-instructor {
		justify-content: flex-start;
	}
	
	.course-booking {
		text-align: left;
	}
}

/* ============================================
   Behandler Cards (Service Page)
   ============================================ */

.behandler-card {
	display: block;
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: all var(--transition-base);
}

.behandler-card:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-2px);
	color: inherit;
}

.behandler-card__inner {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.behandler-card__image {
	width: 100%;
	aspect-ratio: 4 / 5;
	overflow: hidden;
	background: var(--color-green-light);
}

.behandler-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 20%;
	transition: transform var(--transition-slow);
}

.behandler-card:hover .behandler-card__image img {
	transform: scale(1.03);
}

.behandler-card__placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--color-posebyen-green), var(--color-green-medium));
	color: var(--color-white);
	font-size: 4rem;
	font-weight: 600;
	font-family: var(--font-heading);
}

.behandler-card__content {
	padding: var(--space-lg) var(--space-xl) var(--space-xl);
	display: flex;
	flex-direction: column;
	flex: 1;
}

.behandler-card__name {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 300;
	color: var(--color-posebyen-green);
	margin-bottom: var(--space-xs);
	line-height: 1.3;
}

.behandler-card__title {
	font-size: 0.9375rem;
	color: var(--color-accent);
	margin-bottom: var(--space-xs);
	font-weight: 500;
}

.behandler-card__specialization {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	margin-bottom: var(--space-sm);
}

.behandler-card__bio {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	line-height: 1.6;
	margin-bottom: var(--space-md);
}

.behandler-card__link {
	margin-top: auto;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-posebyen-green);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	transition: color var(--transition-base);
}

.behandler-card:hover .behandler-card__link {
	color: var(--color-accent);
}

@media (max-width: 768px) {
	.behandler-card__image {
		aspect-ratio: 3 / 4;
	}
}

/* Legacy classic cart table: hidden (replaced by pb-cart card layout) */
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart {
	display: none;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart th,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart td {
	vertical-align: middle;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-remove {
	width: 48px;
	text-align: center;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail {
	width: 152px;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail a {
	display: block;
	width: 120px;
	margin: 0 auto;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail img {
	width: 120px !important;
	height: 120px !important;
	object-fit: cover;
	border-radius: var(--radius-md);
	margin: 0;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-name a {
	display: inline-block;
	line-height: 1.35;
	text-wrap: balance;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-price,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-subtotal {
	width: 140px;
	white-space: nowrap;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-quantity {
	width: 130px;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-quantity .qty {
	width: 78px;
	min-width: 78px;
	margin: 0 auto;
	display: block;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .actions {
	padding-top: var(--space-lg);
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .actions .coupon {
	display: flex;
	gap: var(--space-sm);
	align-items: center;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .actions .coupon #coupon_code {
	min-width: 220px;
}

.woocommerce-cart .woocommerce .cart-collaterals .cart_totals table td {
	text-align: right;
}

.woocommerce-cart .woocommerce .cart-collaterals .cart_totals .wc-proceed-to-checkout .checkout-button {
	width: 100%;
}

/* Cart alignment + consistent cell background */
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart th,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart td {
	background-color: var(--color-white);
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-price,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-quantity,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-subtotal {
	text-align: center;
	vertical-align: middle;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart th.product-price,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart th.product-quantity,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart th.product-subtotal {
	text-align: center;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-name {
	vertical-align: middle;
}

/* Temporary cart simplification: hide single price column + coupon row */
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart th.product-price,
.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart td.product-price {
	display: none;
}

.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .actions .coupon {
	display: none !important;
}

@media (max-width: 900px) {
	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart {
		table-layout: auto;
	}

	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail {
		width: 120px;
	}

	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail a,
	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail img {
		width: 96px !important;
		height: 96px !important;
	}

	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-price,
	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-subtotal,
	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-quantity {
		width: auto;
	}

	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .actions .coupon {
		flex-wrap: wrap;
	}

	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .actions .coupon #coupon_code {
		width: 100%;
		min-width: 0;
	}
}

@media (max-width: 640px) {
	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail a,
	.woocommerce-cart .woocommerce form.woocommerce-cart-form table.shop_table.shop_table_responsive.cart .product-thumbnail img {
		width: 84px !important;
		height: 84px !important;
	}
}

/* Legacy cart totals table: hidden (replaced by pb-cart-totals) */
.woocommerce-cart .cart-collaterals .cart_totals table.shop_table { display: none; }
.woocommerce-cart .cart-collaterals .cart_totals > h2:not(.pb-cart-totals__title) { display: none; }
.woocommerce-cart .cart-collaterals .cart_totals > .wc-proceed-to-checkout:not(.pb-cart-totals__checkout) { display: none; }

@media (max-width: 768px) {
	.utleie-usecases__header {
		text-align: center;
		margin-left: auto;
		margin-right: auto;
	}

	.utleie-usecases__header .section-header__description {
		margin-left: auto;
		margin-right: auto;
	}
}

@media (max-width: 768px) {
	.section-header {
		text-align: center !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	.section-header .section-header__label {
		justify-content: center !important;
	}

	.section-header .section-header__title,
	.section-header .section-header__description {
		text-align: center !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	.behandler-hero__header .section-header__label {
		justify-content: flex-start !important;
	}

	.section.section--lg.fp-cta-section.global-cta-section .fp-cta__title {
		text-align: center !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}
}

@media (max-width: 768px) {
	.home .hero__inner--split .hero__image,
	.hero--service-with-image .hero__inner--split .hero__image,
	.hero--rental .hero__inner--split .hero__image {
		order: -1;
	}

	.home .hero__inner--split .hero__content,
	.hero--service-with-image .hero__inner--split .hero__content,
	.hero--rental .hero__inner--split .hero__content {
		order: 1;
	}
}
