:root {
	--lasikangas-header-height: clamp(320px, 70vh, 640px);
	--lasikangas-nav-bar-offset: 4rem;
	--lasikangas-content-overlap: 0px;
}

body {
	margin: 0;
}

/* Fixed header image layer */
.lasikangas-random-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: var(--lasikangas-header-height);
	z-index: 0;
	overflow: hidden;
}

.lasikangas-random-header--empty {
	background: linear-gradient(
		160deg,
		var(--wp--preset--color--metsa, #2f4f3e) 0%,
		var(--wp--preset--color--joki, #3d6b7a) 100%
	);
}

.lasikangas-random-header__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.lasikangas-random-header__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(30, 42, 36, 0.15) 0%,
		rgba(30, 42, 36, 0.45) 100%
	);
	pointer-events: none;
}

/* Spacer pushes content below header area */
.lasikangas-header-spacer {
	height: calc(var(--lasikangas-header-height) - var(--lasikangas-nav-bar-offset));
	pointer-events: none;
}

/* Navigation overlay on top of header image — full width, not constrained */
.lasikangas-nav-overlay {
	position: relative;
	z-index: 20;
	width: 100%;
	max-width: none;
	margin-top: calc(var(--lasikangas-nav-bar-offset) - var(--lasikangas-header-height));
	padding-top: max(0.25rem, env(safe-area-inset-top, 0px));
	padding-bottom: 0;
	min-height: calc(var(--lasikangas-header-height) - var(--lasikangas-nav-bar-offset));
	pointer-events: none;
	overflow: visible;
}

.lasikangas-nav-overlay > * {
	pointer-events: auto;
	max-width: none;
	width: 100%;
	margin-top: 0;
	margin-bottom: 0;
}

.site-header-bar {
	position: relative;
	z-index: 21;
	width: 100%;
	box-sizing: border-box;
	padding: 0.6rem var(--wp--preset--spacing--40, 1.5rem);
	align-items: center;
	background: rgba(30, 42, 36, 0.72);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	overflow: visible;
}

/* Blur taustalla — ei riko fixed/absolute-lapsia */
.site-header-bar::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: rgba(30, 42, 36, 0.35);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	pointer-events: none;
}

.site-header-bar .wp-block-navigation {
	position: relative;
	flex: 0 0 auto;
	margin-left: auto;
	overflow: visible;
}

.site-header-bar .wp-block-site-title {
	margin: 0;
	line-height: 1.2;
	flex: 0 1 auto;
	min-width: 0;
}

.site-header-bar .wp-block-navigation .wp-block-navigation__responsive-container,
.site-header-bar .wp-block-navigation .wp-block-navigation__responsive-container-content,
.site-header-bar .wp-block-navigation .wp-block-navigation__container {
	overflow: visible;
}

.site-header-bar .wp-block-site-title a {
	color: #fff;
	text-decoration: none;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
	font-family: var(--wp--preset--font-family--cormorant-garamond, Georgia, serif);
	font-size: clamp(1.35rem, 4.8vw, 1.55rem);
	font-weight: 600;
	line-height: 1.1;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	max-width: 100%;
}

.site-header-bar .wp-block-site-title a::before {
	content: "";
	display: inline-block;
	width: 1.35em;
	height: 1.35em;
	flex-shrink: 0;
	background: center / contain no-repeat url("../images/ornaments/site-title-leaf.svg");
	opacity: 0.9;
	filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
	margin-right: 0.2em;
}

/* Desktop: horizontal menu on header image */
.site-header-bar .wp-block-navigation {
	color: #fff;
}

.site-header-bar .wp-block-navigation .wp-block-navigation-item__content {
	color: #fff;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

.site-header-bar .wp-block-navigation a:hover,
.site-header-bar .wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--hiekka, #c4a882);
}

/* Mobile: hamburger button (like old theme "MENU") */
.site-header-bar .wp-block-navigation__responsive-container-open,
.site-header-bar .wp-block-navigation__responsive-container-close {
	color: #fff;
	background: rgba(30, 42, 36, 0.55);
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: 4px;
	padding: 0.4rem 0.75rem;
}

.site-header-bar .wp-block-navigation__responsive-container-open svg,
.site-header-bar .wp-block-navigation__responsive-container-close svg {
	fill: #fff;
}

.site-header-bar .wp-block-navigation__responsive-container-open::after {
	content: "MENU";
	margin-left: 0.35rem;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	vertical-align: middle;
}

/* Mobile overlay panel — desktop overrides in min-width query below */

@media screen and (min-width: 801px) {
	/* Desktop: single-row horizontal menu */
	.site-header-bar .wp-block-site-title {
		flex: 1 1 auto;
		min-width: 0;
		max-width: 58%;
	}

	.site-header-bar .wp-block-site-title a {
		font-size: clamp(1.55rem, 2.8vw, 2.15rem);
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.site-header-bar .wp-block-navigation__responsive-container-open {
		display: none !important;
	}

	.site-header-bar .wp-block-navigation__responsive-container:not(.is-menu-open) {
		display: block !important;
		position: static !important;
		width: auto !important;
		height: auto !important;
		background: transparent !important;
		padding: 0 !important;
		overflow: visible !important;
	}

	.site-header-bar .wp-block-navigation__responsive-container-close {
		display: none !important;
	}

	.site-header-bar .wp-block-navigation__responsive-container-content {
		display: block !important;
		padding: 0 !important;
	}

	.site-header-bar .wp-block-navigation__container {
		flex-wrap: nowrap !important;
		gap: 1.25rem;
	}

	.site-header-bar .wp-block-navigation-item {
		white-space: nowrap;
	}

	/* Keep submenu open while hovering parent, bridge, or submenu itself */
	.site-header-bar .wp-block-navigation-submenu:hover > .wp-block-navigation__submenu-container,
	.site-header-bar .wp-block-navigation-submenu:focus-within > .wp-block-navigation__submenu-container,
	.site-header-bar .wp-block-navigation-item.has-child:hover > .wp-block-navigation__submenu-container,
	.site-header-bar .wp-block-navigation-item.has-child:focus-within > .wp-block-navigation__submenu-container,
	.site-header-bar .wp-block-navigation__submenu-container:hover {
		visibility: visible !important;
		opacity: 1 !important;
		display: block !important;
		height: auto !important;
		overflow: visible !important;
		pointer-events: auto !important;
	}

	.site-header-bar .wp-block-navigation-submenu .wp-block-navigation-submenu__toggle {
		display: none;
	}

	/* Desktop dropdown submenu */
	.site-header-bar .wp-block-navigation .wp-block-navigation-item.has-child,
	.site-header-bar .wp-block-navigation .wp-block-navigation-submenu {
		position: relative;
		overflow: visible;
	}

	.site-header-bar .wp-block-navigation .wp-block-navigation-item.has-child::after,
	.site-header-bar .wp-block-navigation .wp-block-navigation-submenu::after {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		height: 14px;
		z-index: 499;
	}

	.site-header-bar .wp-block-navigation .wp-block-navigation__submenu-container {
		position: absolute;
		top: calc(100% + 8px);
		left: 0;
		right: auto;
		z-index: 500;
		background: rgba(30, 42, 36, 0.92);
		backdrop-filter: blur(8px);
		-webkit-backdrop-filter: blur(8px);
		border: 1px solid rgba(255, 255, 255, 0.12);
		border-radius: 4px;
		box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
		padding: 0.5rem 0;
		min-width: 13rem;
		margin: 0;
		transform: none;
		clip: auto;
		clip-path: none;
	}

	.site-header-bar .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item {
		width: 100%;
	}

	.site-header-bar .wp-block-navigation .wp-block-navigation__submenu-container a {
		color: #fff;
		padding: 0.45rem 1rem;
		display: block;
		text-shadow: none;
	}

	.site-header-bar .wp-block-navigation .wp-block-navigation__submenu-container a:hover {
		background-color: rgba(255, 255, 255, 0.1);
		color: var(--wp--preset--color--hiekka, #c4a882);
	}

	/* Desktop-valikon linkkien alleviivaus */
	.site-header-bar .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content,
	.site-header-bar .wp-block-navigation__container > .wp-block-navigation-submenu > .wp-block-navigation-item__content {
		background-image: linear-gradient(currentColor, currentColor);
		background-position: 0 calc(100% - 2px);
		background-repeat: no-repeat;
		background-size: 0 1px;
		transition: color 0.2s ease, background-size 0.25s ease;
	}

	.site-header-bar .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:hover,
	.site-header-bar .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:focus-visible,
	.site-header-bar .wp-block-navigation__container > .wp-block-navigation-submenu > .wp-block-navigation-item__content:hover,
	.site-header-bar .wp-block-navigation__container > .wp-block-navigation-submenu > .wp-block-navigation-item__content:focus-visible {
		background-size: 100% 1px;
	}
}

@media screen and (max-width: 800px) {
	/* backdrop-filter voi rikkoa position:fixed-lapset — pois mobiilissa */
	.site-header-bar::before {
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
	}

	.site-header-bar {
		display: flex;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: space-between;
		gap: 0.75rem;
		padding-left: max(1rem, 5vw);
		padding-right: max(1rem, 5vw);
	}

	.site-header-bar .wp-block-site-title {
		flex: 1 1 auto;
		min-width: 0;
		margin: 0;
	}

	.site-header-bar .wp-block-site-title a {
		font-size: clamp(1.2rem, 5.2vw, 1.5rem);
		line-height: 1.1;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.site-header-bar .wp-block-navigation {
		flex: 0 0 auto;
		margin-left: auto;
	}

	.site-header-bar .wp-block-navigation__responsive-container-open {
		display: flex !important;
		align-items: center;
		margin: 0;
		min-height: 2.5rem;
	}

	.site-header-bar .wp-block-navigation__responsive-container:not(.is-menu-open) {
		display: none !important;
	}

	body.lasikangas-menu-open .site-header-bar .wp-block-navigation__responsive-container-open {
		display: none !important;
	}

	body.lasikangas-menu-open .site-header-bar {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 0.75rem;
	}

	body.lasikangas-menu-open .site-header-bar .wp-block-navigation {
		position: absolute;
		width: 0;
		height: 0;
		overflow: visible;
		opacity: 0;
		pointer-events: none;
	}

	.site-header-bar .wp-block-navigation .wp-block-navigation-item.has-child::after,
	.site-header-bar .wp-block-navigation .wp-block-navigation-submenu::after {
		display: none;
	}

	/* Pudotusvalikko headerin alle; tumma tausta näyttää sivun sisällön läpi */
	.site-header-bar .wp-block-navigation__responsive-container.is-menu-open,
	body > .wp-block-navigation__responsive-container.is-menu-open {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		justify-content: flex-start !important;
		position: fixed !important;
		top: var(--lasikangas-menu-top, 3.5rem) !important;
		right: 0 !important;
		bottom: 0 !important;
		left: 0 !important;
		z-index: 100000 !important;
		width: 100% !important;
		max-width: none !important;
		height: auto !important;
		min-height: calc(100dvh - var(--lasikangas-menu-top, 3.5rem)) !important;
		max-height: none !important;
		margin: 0 !important;
		padding: 0 !important;
		overflow-x: hidden !important;
		overflow-y: auto !important;
		-webkit-overflow-scrolling: touch;
		transform: none !important;
		background: rgba(30, 42, 36, 0.4) !important;
		-webkit-backdrop-filter: blur(3px);
		backdrop-filter: blur(3px);
	}

	.site-header-bar .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close,
	body > .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
		display: block !important;
		flex: 0 0 auto !important;
		width: 100% !important;
		height: auto !important;
		min-height: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		position: static !important;
		inset: auto !important;
		transform: none !important;
		overflow: visible !important;
	}

	.site-header-bar .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog,
	body > .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
		display: flex !important;
		flex-direction: column !important;
		flex: 0 0 auto !important;
		width: 100% !important;
		max-width: none !important;
		height: auto !important;
		max-height: min(88dvh, calc(100dvh - var(--lasikangas-menu-top, 3.5rem) - 0.5rem)) !important;
		min-height: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		position: relative !important;
		inset: auto !important;
		left: 0 !important;
		right: 0 !important;
		transform: none !important;
		overflow: hidden !important;
		background: linear-gradient(
			180deg,
			rgba(30, 42, 36, 0.88) 0%,
			rgba(47, 79, 62, 0.84) 100%
		) !important;
		-webkit-backdrop-filter: blur(10px);
		backdrop-filter: blur(10px);
		box-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
	}

	.site-header-bar .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content,
	body > .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
		flex: 1 1 auto !important;
		width: 100% !important;
		max-width: none !important;
		height: auto !important;
		min-height: 0 !important;
		max-height: inherit !important;
		margin: 0 !important;
		padding: 0.85rem max(1.5rem, 5vw) 0.85rem !important;
		padding-bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px)) !important;
		overflow-x: hidden !important;
		overflow-y: auto !important;
		-webkit-overflow-scrolling: touch;
		position: static !important;
		inset: auto !important;
		left: 0 !important;
		right: 0 !important;
		transform: none !important;
		box-sizing: border-box !important;
	}

	body.lasikangas-menu-open .site-header-bar {
		position: relative;
		z-index: 100001;
	}

	.site-header-bar .wp-block-navigation__responsive-container-close {
		position: absolute !important;
		top: 0.5rem !important;
		right: max(1rem, 5vw) !important;
		left: auto !important;
		bottom: auto !important;
		z-index: 3;
		display: flex !important;
		align-items: center;
		margin: 0;
		min-height: 2.5rem;
		padding: 0.4rem 0.75rem;
		background: rgba(255, 255, 255, 0.08);
		border: 1px solid rgba(255, 255, 255, 0.35);
		border-radius: 4px;
	}

	/* SULJE header-rivillä otsikon vieressä (siirretty JS:llä) */
	body.lasikangas-menu-open .site-header-bar > .wp-block-navigation__responsive-container-close {
		position: static !important;
		top: auto !important;
		right: auto !important;
		margin: 0;
		z-index: 100002;
	}

	.site-header-bar .wp-block-navigation__responsive-container-close svg {
		display: none;
	}

	.site-header-bar .wp-block-navigation__responsive-container-close::after {
		content: "SULJE";
		font-size: 0.8rem;
		font-weight: 600;
		letter-spacing: 0.06em;
		color: #fff;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		flex-wrap: nowrap !important;
		gap: 0 !important;
		width: 100% !important;
		padding: 0 !important;
		margin: 0 !important;
		list-style: none;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item,
	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu {
		width: 100% !important;
		position: static !important;
		margin: 0 !important;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu {
		border-bottom: none;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
		display: flex !important;
		align-items: center !important;
		width: 100% !important;
		box-sizing: border-box;
		color: #fff;
		font-family: var(--wp--preset--font-family--source-sans-3, system-ui, sans-serif);
		font-size: 1.1rem;
		font-weight: 600;
		line-height: 1.3;
		min-height: 2.75rem;
		padding: 0 !important;
		text-shadow: none;
		text-decoration: none;
		border-bottom: none !important;
		transition: color 0.15s ease;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover,
	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:focus-visible {
		color: var(--wp--preset--color--hiekka, #c4a882);
		background: transparent;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu__toggle {
		display: none !important;
	}

	/* Alavalikon otsikko pois — vain yhtenäinen linkkilista */
	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu > .wp-block-navigation-item__content {
		display: none !important;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu {
		width: 100% !important;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
		position: static !important;
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		height: auto !important;
		overflow: visible !important;
		pointer-events: auto !important;
		background: transparent !important;
		border: none !important;
		box-shadow: none !important;
		padding: 0 !important;
		margin: 0 !important;
		min-width: 0 !important;
		width: 100% !important;
		transform: none !important;
	}

	.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
		min-height: 2.75rem;
		font-size: 1.1rem;
		font-weight: 600;
		line-height: 1.3;
		color: #fff;
		border-bottom: none !important;
		border-left: none !important;
		margin: 0 !important;
		width: 100% !important;
	}

	/* Nykyinen sivu — vain yksi täsmällinen osuma */
	.wp-block-navigation__responsive-container.is-menu-open .lasikangas-nav-is-current > .wp-block-navigation-item__content {
		color: #fff;
		background: rgba(196, 168, 130, 0.2);
		border-radius: 6px;
		padding-left: 0.85rem !important;
		padding-right: 0.85rem !important;
		box-shadow: inset 3px 0 0 var(--wp--preset--color--hiekka, #c4a882);
		min-height: 2.75rem;
	}

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

.lasikangas-page {
	overflow: visible;
}

.lasikangas-page > .lasikangas-content-layer {
	margin-block-start: 0;
}

.lasikangas-content-layer {
	position: relative;
	z-index: 1;
	margin-top: calc(-1 * var(--lasikangas-content-overlap));
	background-color: var(--wp--preset--color--usva, #f4f1eb);
	border-radius: 12px 12px 0 0;
	box-shadow: 0 -4px 24px rgba(30, 42, 36, 0.08);
	min-height: 50vh;
	animation: lasikangas-content-enter 0.75s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes lasikangas-content-enter {
	from {
		opacity: 0;
		transform: translateY(12px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.lasikangas-content-inner {
	position: relative;
	padding-top: var(--wp--preset--spacing--50, 2rem);
	padding-bottom: var(--wp--preset--spacing--60, 3rem);
	padding-left: max(1.5rem, env(safe-area-inset-left, 0px));
	padding-right: max(1.5rem, env(safe-area-inset-right, 0px));
	--lasikangas-ornament-color: rgba(47, 79, 62, 0.72);
	--lasikangas-ornament-fade: rgba(47, 79, 62, 0);
	--lasikangas-orn-divider: url("../images/ornaments/divider-leaf-vine.svg");
	--lasikangas-orn-flourish: url("../images/ornaments/divider-leaf-vine.svg");
	--lasikangas-orn-laurel: url("../images/ornaments/divider-leaf-vine.svg");
	--lasikangas-orn-title: url("../images/ornaments/divider-leaf-vine-compact.svg");
	--lasikangas-orn-sub: url("../images/ornaments/divider-leaf-vine-compact.svg");
	--lasikangas-orn-corner: url("../images/ornaments/corner-flourish.svg");
}

.lasikangas-content-inner > .wp-block-post-title,
.lasikangas-content-inner > .wp-block-post-content,
.lasikangas-content-inner > .entry-content {
	max-width: 100%;
}

.lasikangas-content-inner > .wp-block-post-title {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-weight: 600;
	font-size: clamp(2.35rem, 4.8vw, 3.5rem);
	line-height: 1.15;
	letter-spacing: -0.01em;
}

.lasikangas-content-inner :is(.wp-block-post-content, .entry-content) > :is(h1, h1.wp-block-heading):first-child {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-weight: 600;
	font-size: clamp(2.35rem, 4.8vw, 3.5rem);
	line-height: 1.15;
	letter-spacing: -0.01em;
}

.lasikangas-content-inner :is(.wp-block-post-content, .entry-content) > :is(h1, h1.wp-block-heading):first-child :is(.lasikangas-script, .special_font) {
	font-family: "Great Vibes", "Cormorant Garamond", Georgia, serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.45em;
	letter-spacing: 0.01em;
}

/* Classic editor paragraphs and headings */
.lasikangas-content-inner .wp-block-post-content > * {
	max-width: 100%;
}

/* Classic editor content compatibility */
.entry-content iframe,
.wp-block-post-content iframe {
	max-width: 100%;
}

.special_font {
	font-family: var(--wp--preset--font-family--cormorant-garamond, Georgia, serif);
	font-style: italic;
}

/* Pidemmät tekstikappaleet tasataan molemmin puolin */
.lasikangas-content-inner :is(.wp-block-post-content, .entry-content) :is(p, .wp-block-paragraph):not(.special_font) {
	text-align: left;
	text-wrap: pretty;
	hyphens: auto;
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	hyphenate-limit-chars: 6 3 3;
	hyphenate-limit-lines: 2;
	hyphenate-limit-zone: 8%;
}

@media screen and (min-width: 801px) {
	.lasikangas-content-inner :is(.wp-block-post-content, .entry-content) :is(p, .wp-block-paragraph):not(.special_font) {
		text-align: justify;
		text-justify: inter-word;
	}
}

/* Hienovaraiset modernit yksityiskohdat */
html {
	scroll-behavior: smooth;
	color-scheme: light;
}

::selection {
	background: rgba(47, 79, 62, 0.22);
	color: var(--wp--preset--color--kuori, #1e2a24);
}

.lasikangas-content-inner a:not(.wp-block-button__link):not(.lasikangas-footer-link) {
	color: var(--wp--preset--color--joki, #3d6b7a);
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-position: 0 calc(100% - 1px);
	background-repeat: no-repeat;
	background-size: 0 1px;
	transition: color 0.2s ease, background-size 0.25s ease;
}

.lasikangas-content-inner a:not(.wp-block-button__link):not(.lasikangas-footer-link):hover,
.lasikangas-content-inner a:not(.wp-block-button__link):not(.lasikangas-footer-link):focus-visible {
	color: var(--wp--preset--color--metsa, #2f4f3e);
	background-size: 100% 1px;
}

.lasikangas-content-inner :is(h1, h2, h3, .wp-block-heading) {
	letter-spacing: -0.015em;
}

.lasikangas-random-header::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.035;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Sisällön kuvat ja lainaukset */
.lasikangas-content-inner :is(.wp-block-image img, img) {
	border-radius: 6px;
	box-shadow: 0 6px 20px rgba(30, 42, 36, 0.1);
}

.lasikangas-content-inner :is(blockquote, .wp-block-quote) {
	margin: 1.5rem 0;
	padding: 0.85rem 0 0.85rem 1.25rem;
	border-left: 3px solid var(--wp--preset--color--hiekka, #c4a882);
	color: var(--wp--preset--color--kuori, #1e2a24);
	font-family: var(--wp--preset--font-family--cormorant-garamond, Georgia, serif);
	font-style: italic;
	position: relative;
}

.lasikangas-content-inner :is(blockquote, .wp-block-quote)::before {
	content: "“";
	position: absolute;
	top: -0.35rem;
	left: -0.15rem;
	font-family: var(--wp--preset--font-family--cormorant-garamond, Georgia, serif);
	font-size: 2.75rem;
	line-height: 1;
	color: var(--wp--preset--color--hiekka, #c4a882);
	opacity: 0.72;
	pointer-events: none;
}

.lasikangas-content-inner :is(ul, ol) li::marker {
	color: var(--wp--preset--color--sammal, #5a7d5e);
}

/* Jakajat ja koristeelliset vanhan ajan koristeet */
.lasikangas-ornament-divider {
	display: block;
	width: min(100%, 36rem);
	height: 60px;
	margin: 0 auto;
	background: center / contain no-repeat var(--lasikangas-orn-divider);
	opacity: 0.95;
}

/* Jakaja sivun pääotsikon alle */
.lasikangas-content-inner > .wp-block-post-title::after {
	content: "";
	display: block;
	width: min(100%, 36rem);
	height: 60px;
	margin: 0.85rem auto 1.75rem;
	background: center / contain no-repeat var(--lasikangas-orn-flourish);
	opacity: 0.95;
}

/* Etusivu: ei erillistä sivun otsikkoa */
.lasikangas-content-inner:not(:has(> .wp-block-post-title)) :is(.wp-block-post-content, .entry-content) > :is(h1, h1.wp-block-heading):first-child::after {
	content: "";
	display: block;
	width: min(100%, 36rem);
	height: 60px;
	margin: 0.85rem auto 1.75rem;
	background: center / contain no-repeat var(--lasikangas-orn-flourish);
	opacity: 0.95;
}

.lasikangas-content-inner hr,
.lasikangas-content-inner .wp-block-separator:not(.is-style-wide):not(.is-style-dots):not(.is-style-lasikangas-ornament):not(.is-style-lasikangas-leaf) {
	border: none;
	border-top: 1px solid rgba(47, 79, 62, 0.22);
	height: auto;
	margin: 2rem auto;
	width: min(100%, 36rem);
	max-width: none;
	background: none;
	opacity: 1;
}

.lasikangas-content-inner .wp-block-separator.is-style-lasikangas-ornament {
	border: none;
	height: 64px;
	width: min(100%, 42rem);
	max-width: none;
	margin: 2.6rem auto;
	background: center / contain no-repeat var(--lasikangas-orn-flourish);
	opacity: 0.96;
}

.lasikangas-content-inner .wp-block-separator.is-style-lasikangas-leaf {
	border: none;
	height: 60px;
	width: min(100%, 38rem);
	max-width: none;
	margin: 2.6rem auto;
	background: center / contain no-repeat var(--lasikangas-orn-laurel);
	opacity: 0.96;
}

.lasikangas-content-inner .wp-block-separator.is-style-dots {
	border: none;
	height: auto;
	max-width: none;
	background: none;
	opacity: 1;
}

.lasikangas-content-inner .wp-block-group.is-style-lasikangas-framed {
	position: relative;
	margin: 2.25rem 0;
	padding: 1.75rem 1.5rem;
	border: 1px solid rgba(47, 79, 62, 0.28);
	border-radius: 2px;
	background: rgba(255, 255, 255, 0.28);
	box-shadow: inset 0 0 0 1px rgba(196, 168, 130, 0.22);
}

.lasikangas-content-inner .wp-block-group.is-style-lasikangas-framed::before,
.lasikangas-content-inner .wp-block-group.is-style-lasikangas-framed::after {
	content: "";
	position: absolute;
	width: 2.25rem;
	height: 2.25rem;
	pointer-events: none;
	background: center / contain no-repeat var(--lasikangas-orn-corner);
	opacity: 0.78;
}

.lasikangas-content-inner .wp-block-group.is-style-lasikangas-framed::before {
	top: 0.35rem;
	left: 0.35rem;
}

.lasikangas-content-inner .wp-block-group.is-style-lasikangas-framed::after {
	right: 0.35rem;
	bottom: 0.35rem;
	transform: rotate(180deg);
}

@media screen and (min-width: 960px) {
	.lasikangas-content-inner > .wp-block-post-title::after,
	.lasikangas-content-inner:not(:has(> .wp-block-post-title)) :is(.wp-block-post-content, .entry-content) > :is(h1, h1.wp-block-heading):first-child::after {
		width: min(100%, 42rem);
		height: 64px;
	}

	.lasikangas-content-inner .wp-block-separator.is-style-lasikangas-ornament {
		height: 48px;
		width: min(100%, 46rem);
	}

	.lasikangas-content-inner .wp-block-separator.is-style-lasikangas-leaf {
		height: 44px;
		width: min(100%, 42rem);
	}
}

/* Näppäimistöfokus */
:focus {
	outline: none;
}

:focus-visible {
	outline: 2px solid var(--wp--preset--color--hiekka, #c4a882);
	outline-offset: 3px;
}

.site-header-bar .wp-block-navigation :focus-visible {
	outline-color: #fff;
	outline-offset: 4px;
}

@media screen and (min-width: 801px) {
	:root {
		/* Nostaa sisältökerrosta hero-kuvan alle jäävän tyhjän välin umpeen */
		--lasikangas-content-overlap: 2.75rem;
	}
}

@media screen and (max-width: 800px) {
	:root {
		/* ~25 % matalampi kuin aiempi mobiilihero */
		--lasikangas-header-height: clamp(285px, 54dvh, 540px);
		--lasikangas-nav-bar-offset: 3.5rem;
	}

	/*
	 * Hero näkyy vain nav-palkin ja sisältökerroksen välissä.
	 * min-height pitää sisällön alhaalla — ilman sitä kerros alkaa heti palkin jälkeen.
	 */
	.lasikangas-nav-overlay {
		min-height: calc(var(--lasikangas-header-height) - var(--lasikangas-nav-bar-offset)) !important;
		overflow: visible;
	}

	.lasikangas-random-header__image {
		width: 170%;
		max-width: none;
		height: 100%;
		object-fit: cover;
		position: relative;
		left: 0;
		animation: lasikangas-slidein 15s ease-in-out infinite alternate;
	}

	@keyframes lasikangas-slidein {
		from {
			left: 0;
		}
		to {
			left: -40%;
		}
	}

	/* Like old theme: content inset from edges (~88% width feel) */
	.lasikangas-content-inner {
		padding-left: max(1.25rem, 6vw);
		padding-right: max(1.25rem, 6vw);
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	.lasikangas-content-layer {
		animation: none;
	}

	.lasikangas-random-header__image {
		animation: none !important;
	}
}

/* Footer */
.site-footer-bar {
	position: relative;
	background-color: var(--wp--preset--color--metsa, #2f4f3e);
	color: var(--wp--preset--color--usva, #f4f1eb);
	padding: var(--wp--preset--spacing--50, 2rem) var(--wp--preset--spacing--40, 1.5rem);
	margin-top: var(--wp--preset--spacing--60, 3rem);
}

.site-footer-bar::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: min(10rem, 42%);
	height: 3px;
	border-radius: 0 0 4px 4px;
	background: linear-gradient(
		90deg,
		var(--wp--preset--color--hiekka, #c4a882) 0%,
		var(--wp--preset--color--joki, #3d6b7a) 50%,
		var(--wp--preset--color--metsa, #2f4f3e) 100%
	);
	opacity: 0.55;
	pointer-events: none;
}

.site-footer-bar a {
	color: var(--wp--preset--color--hiekka, #c4a882);
}

.site-footer-bar a:hover {
	color: #fff;
}

.site-footer-bar .lasikangas-footer-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
}

.site-footer-bar .lasikangas-footer-link::before {
	content: "";
	display: inline-block;
	width: 1.05em;
	height: 1.05em;
	flex-shrink: 0;
	background-color: currentColor;
	opacity: 0.92;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.site-footer-bar .lasikangas-footer-link--email::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='4' width='20' height='16' rx='2'/%3E%3Cpath d='m22 6-10 7L2 6'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='4' width='20' height='16' rx='2'/%3E%3Cpath d='m22 6-10 7L2 6'/%3E%3C/svg%3E") center / contain no-repeat;
}

.site-footer-bar .lasikangas-footer-link--facebook::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M24 12.073c0-6.627-5.373-12-12-12S0 5.446 0 12.073c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M24 12.073c0-6.627-5.373-12-12-12S0 5.446 0 12.073c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.site-footer-bar .lasikangas-footer-link:hover::before {
	transform: scale(1.08);
	opacity: 1;
}

/* Logged-in admin bar pushes content down */
.admin-bar .lasikangas-nav-overlay {
	padding-top: calc(0.25rem + 32px);
}

@media screen and (max-width: 782px) {
	.admin-bar .lasikangas-nav-overlay {
		padding-top: calc(0.25rem + 46px);
	}
}
