/*
Theme Name: Onnenmaali
Theme URI: https://onnenmaali.fi
Author: Onnenmaali
Author URI: https://onnenmaali.fi
Description: Onnenmaalin WordPress-lohkoteema.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: onnenmaali-theme
Tags: full-site-editing, block-patterns, block-styles, wide-blocks, custom-colors, custom-logo, custom-menu, editor-style, translation-ready
*/


/* ==========================================================================
   1. BASE & TYPOGRAPHY
   ========================================================================== */

html {
	scroll-behavior: smooth;
}

/* -- Page transition: fade in -- */
@keyframes om-page-enter {
	from { opacity: 0; }
	to { opacity: 1; }
}

main,
.wp-site-blocks {
	animation: om-page-enter 0.6s ease;
}

/* -- Scroll reveal: smooth fade + subtle lift -- */
.om-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.8s cubic-bezier(0.25, 0.1, 0.25, 1),
	            transform 0.8s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.om-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

a {
	text-decoration: none;
}

a:hover {
	text-decoration: none;
}

/* Fix button hover styles in editor */
.editor-styles-wrapper .wp-block-button .wp-block-button__link,
.editor-styles-wrapper .wp-element-button {
	background-color: var(--wp--preset--color--accent) !important;
	color: var(--wp--preset--color--white) !important;
}

.wp-site-blocks {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}


/* ==========================================================================
   2. PATTERN COMPONENTS
   Reusable classes used across block patterns.
   ========================================================================== */

/* -- Section Label (uppercase accent text above headings) -- */
.om-section-label {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent);
	margin-bottom: 12px;
}

/* -- Stat Number (large serif accent numbers) -- */
.om-stat-number {
	font-size: clamp(2.5rem, 4vw, 4rem);
	line-height: 1;
	letter-spacing: -0.03em;
	font-weight: 400;
	color: var(--wp--preset--color--accent);
}

/* -- Accent Badge (yellow pill, dark text) -- */
.om-emergency-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--primary, #111) !important;
	padding: 6px 16px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-decoration: none !important;
	transition: background-color 0.2s ease;
}

.om-emergency-badge:hover {
	background: var(--wp--preset--color--accent-dark);
	color: var(--wp--preset--color--primary, #111) !important;
}

/* -- Separator (short accent line) -- */
.om-separator {
	width: 48px;
	height: 2px;
	background: var(--wp--preset--color--accent);
	border: none;
	margin: 16px 0;
}


/* ==========================================================================
   3. CARD STYLES
   Soft rounded corners + gentle shadows + playful hover lift.
   ========================================================================== */

/* -- Service Card (rounded with playful hover lift) -- */
.om-service-card {
	padding: 32px;
	background: var(--wp--preset--color--white);
	border-radius: 24px;
	border: 1px solid var(--wp--preset--color--border);
	box-shadow: 0 2px 8px rgba(17, 17, 17, 0.04);
	transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.3s ease,
	            border-color 0.3s ease;
}

.om-service-card:hover {
	transform: translateY(-4px);
	border-color: var(--wp--preset--color--accent);
	box-shadow: 0 12px 32px rgba(17, 17, 17, 0.08);
}

/* -- Testimonial Card (rounded with quote mark) -- */
.om-testimonial {
	position: relative;
	padding: 40px 32px 32px;
	background: var(--wp--preset--color--surface);
	border-radius: 24px;
	transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.3s ease;
}

.om-testimonial:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(17, 17, 17, 0.07);
}

.om-testimonial::before {
	content: "\201C";
	position: absolute;
	top: 4px;
	left: 24px;
	font-size: 80px;
	color: var(--wp--preset--color--accent);
	line-height: 1;
	opacity: 0.8;
}

/* -- Blog Grid gap -- */
:root .wp-block-post-template.columns-3 {
	gap: 2rem !important;
}

:root .wp-block-post-template.columns-3 > li {
	flex: 1 1 0;
	width: auto !important;
	min-width: 0;
}

@media (max-width: 600px) {
	:root .wp-block-post-template.columns-3 {
		flex-direction: column;
	}
	:root .wp-block-post-template.columns-3 > li {
		flex: 1 1 100%;
		width: 100% !important;
	}
}

/* -- Blog Card (image zoom on hover, soft rounded) -- */
.om-blog-card {
	overflow: hidden;
	border-radius: 24px;
	background: var(--wp--preset--color--white);
	box-shadow: 0 2px 8px rgba(17, 17, 17, 0.04);
	transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.3s ease;
}

.om-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px rgba(17, 17, 17, 0.08);
}

.om-blog-card .wp-block-post-featured-image {
	width: 100%;
	max-width: 100%;
}

.om-blog-card .wp-block-post-featured-image img {
	width: 100%;
	height: 280px;
	object-fit: cover;
}


/* -- Role Selector Card (rounded with playful tilt) -- */
.om-role-card {
	border-radius: 28px;
	background: var(--wp--preset--color--white, #fff);
	box-shadow: 0 2px 8px rgba(17, 17, 17, 0.05);
	transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.3s ease;
}

.om-role-card:hover {
	box-shadow: 0 16px 36px rgba(17, 17, 17, 0.1);
	transform: translateY(-6px) rotate(-0.5deg);
}

/* -- Product Card (rounded with image zoom) -- */
.om-product-card {
	border-radius: 24px;
	overflow: hidden;
	background: var(--wp--preset--color--white);
	box-shadow: 0 2px 8px rgba(17, 17, 17, 0.04);
	transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.3s ease;
}

.om-product-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px rgba(17, 17, 17, 0.08);
}

.om-product-card img {
	aspect-ratio: 16/10;
	object-fit: cover;
	width: 100%;
	transition: transform 0.5s ease;
}

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

/* -- Team Card (rounded portrait, soft hover) -- */
.om-team-card {
	text-align: left;
}

.om-team-card img {
	border-radius: 24px;
	aspect-ratio: 3 / 4;
	object-fit: cover;
	width: 100%;
	transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.om-team-card:hover img {
	transform: translateY(-4px) rotate(-1deg);
}

/* -- Feature Item (rounded pad-card on hover) -- */
.om-feature-item {
	padding: 28px;
	border-radius: 20px;
	background: transparent;
	transition: background-color 0.25s ease, transform 0.25s ease;
}

.om-feature-item:hover {
	background-color: var(--wp--preset--color--accent-light);
	transform: translateY(-2px);
}

/* -- News Card -- */
.om-news-card {
	padding: 28px;
	border-radius: 20px;
	background: var(--wp--preset--color--white);
	border: 1px solid var(--wp--preset--color--border);
	transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.om-news-card:hover {
	transform: translateY(-3px);
	border-color: var(--wp--preset--color--accent);
	box-shadow: 0 10px 24px rgba(17, 17, 17, 0.06);
}

.om-service-list-item {
	border-bottom: 1px solid var(--wp--preset--color--border);
	padding: 24px 0;
	transition: padding-left 0.2s ease, border-color 0.2s ease;
}

.om-service-list-item:hover {
	padding-left: 12px;
	border-color: var(--wp--preset--color--accent);
}

.om-download-item {
	border-radius: 16px;
	border: 1px solid var(--wp--preset--color--border);
	padding: 20px 24px;
	transition: border-color 0.2s ease, transform 0.2s ease;
}

.om-download-item:hover {
	border-color: var(--wp--preset--color--accent);
	transform: translateY(-2px);
}

.om-form-card {
	border-radius: 24px;
	border: 1px solid var(--wp--preset--color--border);
	background: var(--wp--preset--color--white);
	padding: 32px;
	box-shadow: 0 2px 8px rgba(17, 17, 17, 0.04);
}

.om-icon-feature {
	padding: 28px;
	border-radius: 20px;
	transition: background-color 0.25s ease;
}

.om-icon-feature:hover {
	background-color: var(--wp--preset--color--surface);
}

.om-feature-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 20px;
	background-color: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--primary);
	line-height: 1;
	margin-bottom: var(--wp--preset--spacing--30) !important;
	transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.om-service-card:hover .om-feature-icon,
.om-icon-feature:hover .om-feature-icon,
.om-feature-item:hover .om-feature-icon {
	transform: rotate(-6deg) scale(1.05);
}


/* ==========================================================================
   4. TIMELINE
   ========================================================================== */

.om-timeline-item {
	padding: 32px 0 32px 32px;
	border-left: 2px solid var(--wp--preset--color--border);
	position: relative;
}

.om-timeline-item .om-stat-number {
	font-size: 3rem;
	white-space: nowrap;
}

.om-timeline-item::before {
	content: '';
	position: absolute;
	left: -5px;
	top: 40px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--wp--preset--color--accent);
}


/* ==========================================================================
   5. TABLE
   ========================================================================== */

.om-comparison-table .wp-block-table { margin: 0; }

.om-comparison-table table {
	border-collapse: collapse;
	width: 100%;
	border: 1px solid var(--wp--preset--color--border);
}

.om-comparison-table th {
	text-align: left;
	padding: 12px 16px;
	font-weight: 600;
	border-bottom: 2px solid var(--wp--preset--color--primary);
}

.om-comparison-table td {
	padding: 12px 16px;
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.om-comparison-table tr:last-child td { border-bottom: none; }


/* ==========================================================================
   6. CORE BLOCK OVERRIDES
   ========================================================================== */

/* Buttons */
.wp-block-button__link {
	transition: background-color 0.2s ease, transform 0.15s ease;
}

.wp-block-button__link:hover {
	transform: translateY(-1px);
}

/* FAQ / Details — rounded card style */
.wp-block-details {
	background: var(--wp--preset--color--white);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 20px;
	padding: 20px 28px;
	margin-bottom: 12px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.wp-block-details:hover {
	border-color: var(--wp--preset--color--accent);
	box-shadow: 0 4px 16px rgba(17, 17, 17, 0.05);
}

.wp-block-details[open] {
	border-color: var(--wp--preset--color--accent);
	background-color: var(--wp--preset--color--accent-light);
}

.wp-block-details summary {
	cursor: pointer;
	font-weight: 700;
	padding: 0.25em 0;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.wp-block-details summary::-webkit-details-marker { display: none; }

.wp-block-details summary::after {
	content: "+";
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--accent);
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
	flex-shrink: 0;
	margin-left: 1rem;
	line-height: 1;
}

.wp-block-details[open] summary::after {
	content: "\2212";
	transform: rotate(180deg);
}

/* Blockquote */
.wp-block-quote {
	border-left: 4px solid var(--wp--preset--color--accent);
	border-radius: 4px;
}

/* Cover inner container */
.alignfull > .wp-block-cover__inner-container {
	padding-left: 0;
	padding-right: 0;
}

/* ==========================================================================
   6.5  GLOBAL IMAGE & COVER ROUNDING
   Soft rounded corners on all media for the friendly Onnenmaali look.
   Override per-block by setting borderRadius:0 in the block settings.
   ========================================================================== */

/* Default rounded images — except logos, icons, and small inline images */
.wp-block-image:not(.is-style-no-radius):not(.is-style-circle) > img,
.wp-block-image:not(.is-style-no-radius):not(.is-style-circle) > figure > img,
.wp-block-image:not(.is-style-no-radius):not(.is-style-circle) > a > img {
	border-radius: 24px;
}

/* Featured image on posts */
.wp-block-post-featured-image img {
	border-radius: 24px;
}

/* Cover blocks — rounded by default unless full-bleed section */
.wp-block-cover:not(.alignfull):not(.is-style-no-radius) {
	border-radius: 28px;
	overflow: hidden;
}

/* Avoid double-rounding inside cards */
.om-blog-card .wp-block-image > img,
.om-blog-card .wp-block-post-featured-image img,
.om-product-card .wp-block-image > img,
.om-team-card .wp-block-image > img {
	border-radius: 0;
}

/* Inside service-card images get rounded inner */
.om-service-card .wp-block-image > img,
.om-service-card figure.wp-block-image img {
	border-radius: 16px;
}

/* Circle style for image block */
.wp-block-image.is-style-circle > img,
.wp-block-image.is-style-circle > figure > img {
	border-radius: 50% !important;
	aspect-ratio: 1;
	object-fit: cover;
}

/* No radius style for image block (e.g. logos, icons) */
.wp-block-image.is-style-no-radius > img,
.wp-block-image.is-style-no-radius > figure > img {
	border-radius: 0 !important;
}

/* Galleries */
.wp-block-gallery .wp-block-image > img,
.wp-block-gallery .wp-block-image figure > img {
	border-radius: 20px;
}

/* Embeds — YouTube etc. */
.wp-block-embed:not(.is-style-no-radius) iframe,
.wp-block-embed:not(.is-style-no-radius) .wp-block-embed__wrapper {
	border-radius: 24px;
	overflow: hidden;
}


/* ==========================================================================
   6.7  FULL-WIDTH SECTION ROUNDING
   Floating "card" feel — every full-width background section gets soft
   rounded corners and a small breathing margin. Body shows a soft surface
   color between sections so the rounding is visible.
   ========================================================================== */

/* Soft canvas behind floating sections */
body.has-rounded-sections,
.wp-site-blocks {
	background-color: var(--wp--preset--color--surface);
}

/* Single-post main — constrain to content-size and center, so the
   alignfull hero behaves identically to pattern-based heroes on pages. */
body.single main.wp-block-group {
	max-width: var(--wp--style--global--content-size);
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Single-post content typography — generous breathing room above headings */
body.single .wp-block-post-content h2 {
	margin-top: var(--wp--preset--spacing--70);
	margin-bottom: var(--wp--preset--spacing--30);
}

body.single .wp-block-post-content h3 {
	margin-top: var(--wp--preset--spacing--60);
	margin-bottom: var(--wp--preset--spacing--20);
}

body.single .wp-block-post-content h4,
body.single .wp-block-post-content h5,
body.single .wp-block-post-content h6 {
	margin-top: var(--wp--preset--spacing--50);
	margin-bottom: var(--wp--preset--spacing--20);
}

body.single .wp-block-post-content p,
body.single .wp-block-post-content ul,
body.single .wp-block-post-content ol {
	margin-bottom: var(--wp--preset--spacing--30);
}

/* First heading shouldn't push down — it's right after the hero */
body.single .wp-block-post-content > h2:first-child,
body.single .wp-block-post-content > h3:first-child,
body.single .wp-block-post-content > h4:first-child {
	margin-top: 0;
}

/* Each full-bleed background section becomes a rounded "card".
   No !important so editor block settings (Dimensions, Border Radius) can override. */
main .wp-block-group.alignfull.has-background,
main .wp-block-cover.alignfull,
main > .wp-block-cover.alignfull,
main > .wp-block-post-content .wp-block-group.alignfull.has-background,
main > .wp-block-post-content .wp-block-cover.alignfull,
main.is-layout-constrained > .wp-block-cover.alignfull,
main.is-layout-flow > .wp-block-cover.alignfull {
	border-radius: 36px;
	overflow: hidden;
	max-width: calc(100vw - 32px);
	margin-left: 16px;
	margin-right: 16px;
	margin-top: 16px;
	margin-bottom: 16px;
	box-sizing: border-box;
}

/* Adjacent sections — keep vertical breathing gap consistent */
main .wp-block-group.alignfull.has-background + .wp-block-group.alignfull.has-background,
main .wp-block-cover.alignfull + .wp-block-cover.alignfull,
main .wp-block-group.alignfull.has-background + .wp-block-cover.alignfull,
main .wp-block-cover.alignfull + .wp-block-group.alignfull.has-background {
	margin-top: 0;
}

/* First section (hero) — extra breathing room under sticky header */
main > .wp-block-post-content > .wp-block-group.alignfull.has-background:first-child,
main > .wp-block-post-content > .wp-block-cover.alignfull:first-child,
main > .wp-block-group.alignfull.has-background:first-child,
main > .wp-block-cover.alignfull:first-child {
	margin-top: 50px;
}

/* Nested alignfull inside another alignfull — no double-margin */
main .wp-block-group.alignfull.has-background .wp-block-group.alignfull,
main .wp-block-group.alignfull.has-background .wp-block-cover.alignfull,
main .wp-block-cover.alignfull .wp-block-group.alignfull,
main .wp-block-cover.alignfull .wp-block-cover.alignfull {
	border-radius: 0;
	max-width: 100%;
	margin-left: 0;
	margin-right: 0;
}

/* Mobile — tighter radius and margin */
@media (max-width: 781px) {
	main .wp-block-group.alignfull.has-background,
	main .wp-block-cover.alignfull,
	main > .wp-block-post-content .wp-block-group.alignfull.has-background,
	main > .wp-block-post-content .wp-block-cover.alignfull {
		border-radius: 24px;
		max-width: calc(100vw - 16px);
		margin-left: 8px;
		margin-right: 8px;
		margin-top: 8px;
		margin-bottom: 8px;
	}
}

/* Opt-out: pattern can add .is-style-no-radius for edge-to-edge feel */
main .wp-block-group.alignfull.has-background.is-style-no-radius,
main .wp-block-cover.alignfull.is-style-no-radius {
	border-radius: 0;
	max-width: 100%;
	margin-left: 0;
	margin-right: 0;
}


/* ==========================================================================
   6.6  ORGANIC BACKGROUND DECORATIONS
   Soft yellow blobs that can be dropped behind a section for personality.
   Use as: <div class="om-blob-bg"> wrapping a relative section.
   ========================================================================== */

.om-blob-section {
	position: relative;
	overflow: hidden;
}

.om-blob-section::before,
.om-blob-section::after {
	content: '';
	position: absolute;
	width: 420px;
	height: 420px;
	border-radius: 50%;
	background: var(--wp--preset--color--accent-light);
	z-index: 0;
	pointer-events: none;
	opacity: 0.7;
	filter: blur(8px);
}

.om-blob-section::before {
	top: -120px;
	left: -120px;
}

.om-blob-section::after {
	bottom: -120px;
	right: -160px;
	background: var(--wp--preset--color--accent);
	opacity: 0.18;
}

.om-blob-section > * {
	position: relative;
	z-index: 1;
}

/* Single accent dot — small playful corner decoration */
.om-accent-dot {
	position: relative;
}

.om-accent-dot::after {
	content: '';
	position: absolute;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--wp--preset--color--accent);
	top: 0;
	right: -16px;
}

/* Sticker-style yellow tag — for "Yli 95 %" -style highlight */
.om-sticker {
	display: inline-block;
	background: var(--wp--preset--color--accent-light);
	color: var(--wp--preset--color--primary);
	padding: 8px 20px;
	border-radius: 999px;
	font-weight: 700;
	letter-spacing: -0.01em;
	transform: rotate(-3deg);
	box-shadow: 0 4px 12px rgba(254, 231, 0, 0.4);
}

/* Soft yellow background section with rounded top */
.om-rounded-section-top {
	border-top-left-radius: 48px;
	border-top-right-radius: 48px;
}

.om-rounded-section-bottom {
	border-bottom-left-radius: 48px;
	border-bottom-right-radius: 48px;
}

/* Logo cloud */
.om-logo-item {
	opacity: 0.4;
	transition: opacity 0.3s ease;
}

.om-logo-item:hover { opacity: 1; }

/* Stats column dividers */
.om-stats-section .wp-block-column + .wp-block-column {
	border-left: 1px solid rgba(255, 255, 255, 0.1);
	padding-left: var(--wp--preset--spacing--40);
}

/* Yoast Breadcrumbs */
.wp-block-yoast-seo-breadcrumbs,
.yoast-breadcrumbs {
	font-size: 0.8125rem !important;
}

/* Focus */
*:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: 2px;
	border-radius: 2px;
}


/* ==========================================================================
   7. ADAPTIVE COLORS
   Text color adapts automatically based on parent background color.
   ========================================================================== */

/* -- Dark backgrounds → light text -- */
.has-dark-bg-background-color,
.has-primary-background-color,
.has-dark-bg-lighter-background-color {
	color: var(--wp--preset--color--surface);
}

.has-dark-bg-background-color h1, .has-dark-bg-background-color h2,
.has-dark-bg-background-color h3, .has-dark-bg-background-color h4,
.has-dark-bg-background-color h5, .has-dark-bg-background-color h6,
.has-primary-background-color h1, .has-primary-background-color h2,
.has-primary-background-color h3, .has-primary-background-color h4,
.has-primary-background-color h5, .has-primary-background-color h6,
.has-dark-bg-lighter-background-color h1, .has-dark-bg-lighter-background-color h2,
.has-dark-bg-lighter-background-color h3, .has-dark-bg-lighter-background-color h4,
.has-dark-bg-lighter-background-color h5, .has-dark-bg-lighter-background-color h6 {
	color: var(--wp--preset--color--white);
}

.has-dark-bg-background-color p, .has-dark-bg-background-color li, .has-dark-bg-background-color span,
.has-primary-background-color p, .has-primary-background-color li, .has-primary-background-color span,
.has-dark-bg-lighter-background-color p, .has-dark-bg-lighter-background-color li, .has-dark-bg-lighter-background-color span {
	color: rgba(249, 248, 247, 0.75);
}


.has-dark-bg-background-color a:not(.wp-block-button__link),
.has-primary-background-color a:not(.wp-block-button__link),
.has-dark-bg-lighter-background-color a:not(.wp-block-button__link) {
	color: var(--wp--preset--color--accent);
}

/* Buttons on accent/emergency backgrounds → dark pill (yellow CTA would be invisible on yellow bg) */
.has-accent-background-color .wp-block-button .wp-block-button__link,
.has-accent-dark-background-color .wp-block-button .wp-block-button__link,
.has-accent-light-background-color .wp-block-button .wp-block-button__link,
.has-emergency-background-color .wp-block-button .wp-block-button__link,
.has-accent-background-color .wp-block-button__link.wp-element-button,
.has-accent-dark-background-color .wp-block-button__link.wp-element-button,
.has-accent-light-background-color .wp-block-button__link.wp-element-button,
.has-emergency-background-color .wp-block-button__link.wp-element-button {
	background-color: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--white) !important;
}

.has-accent-background-color .wp-block-button .wp-block-button__link:hover,
.has-accent-dark-background-color .wp-block-button .wp-block-button__link:hover,
.has-accent-light-background-color .wp-block-button .wp-block-button__link:hover,
.has-emergency-background-color .wp-block-button .wp-block-button__link:hover,
.has-accent-background-color .wp-block-button__link.wp-element-button:hover,
.has-accent-dark-background-color .wp-block-button__link.wp-element-button:hover,
.has-accent-light-background-color .wp-block-button__link.wp-element-button:hover,
.has-emergency-background-color .wp-block-button__link.wp-element-button:hover {
	background-color: var(--wp--preset--color--secondary) !important;
	color: var(--wp--preset--color--white) !important;
}

.has-dark-bg-background-color .om-section-label,
.has-primary-background-color .om-section-label,
.has-dark-bg-lighter-background-color .om-section-label {
	color: var(--wp--preset--color--accent);
}

.has-dark-bg-background-color .wp-block-details summary,
.has-primary-background-color .wp-block-details summary,
.has-dark-bg-lighter-background-color .wp-block-details summary {
	color: var(--wp--preset--color--white);
}

.has-dark-bg-background-color .wp-block-separator,
.has-primary-background-color .wp-block-separator,
.has-dark-bg-lighter-background-color .wp-block-separator {
	border-color: rgba(255, 255, 255, 0.12);
}

/* -- Yellow backgrounds → dark text (white would be unreadable) -- */
.has-accent-background-color, .has-accent-dark-background-color {
	color: var(--wp--preset--color--primary);
}

.has-accent-background-color h1, .has-accent-background-color h2,
.has-accent-background-color h3, .has-accent-background-color h4,
.has-accent-background-color p, .has-accent-background-color li,
.has-accent-dark-background-color h1, .has-accent-dark-background-color h2,
.has-accent-dark-background-color h3, .has-accent-dark-background-color h4,
.has-accent-dark-background-color p, .has-accent-dark-background-color li {
	color: var(--wp--preset--color--primary);
}

/* -- Emergency (red) background → white text -- */
.has-emergency-background-color {
	color: var(--wp--preset--color--white);
}

.has-emergency-background-color h1, .has-emergency-background-color h2,
.has-emergency-background-color h3, .has-emergency-background-color h4,
.has-emergency-background-color p, .has-emergency-background-color li {
	color: var(--wp--preset--color--white);
}

/* -- Light backgrounds → dark text -- */
.has-surface-background-color, .has-surface-alt-background-color,
.has-white-background-color, .has-card-background-color {
	color: var(--wp--preset--color--secondary);
}

.has-surface-background-color h1, .has-surface-background-color h2,
.has-surface-background-color h3, .has-surface-background-color h4,
.has-surface-alt-background-color h1, .has-surface-alt-background-color h2,
.has-surface-alt-background-color h3, .has-surface-alt-background-color h4,
.has-white-background-color h1, .has-white-background-color h2,
.has-white-background-color h3, .has-white-background-color h4,
.has-card-background-color h1, .has-card-background-color h2,
.has-card-background-color h3, .has-card-background-color h4 {
	color: var(--wp--preset--color--primary);
}

/* -- Accent-light background → dark text -- */
.has-accent-light-background-color {
	color: var(--wp--preset--color--primary);
}

.has-accent-light-background-color h1, .has-accent-light-background-color h2,
.has-accent-light-background-color h3, .has-accent-light-background-color h4,
.has-accent-light-background-color p, .has-accent-light-background-color li {
	color: var(--wp--preset--color--primary);
}

/* -- Section labels on yellow backgrounds → dark text (accent yellow is invisible on yellow) -- */
.has-accent-background-color .om-section-label,
.has-accent-light-background-color .om-section-label,
.has-accent-dark-background-color .om-section-label {
	color: var(--wp--preset--color--primary);
}

/* -- Section padding helpers — generous breathing room between blocks -- */
.om-section {
	padding-top: var(--wp--preset--spacing--80);
	padding-bottom: var(--wp--preset--spacing--80);
}

.om-section-lg {
	padding-top: var(--wp--preset--spacing--90);
	padding-bottom: var(--wp--preset--spacing--90);
}

@media (max-width: 781px) {
	.om-section {
		padding-top: var(--wp--preset--spacing--60);
		padding-bottom: var(--wp--preset--spacing--60);
	}
	.om-section-lg {
		padding-top: var(--wp--preset--spacing--70);
		padding-bottom: var(--wp--preset--spacing--70);
	}
}


/* ==========================================================================
   8. HEADER — FLOATING / STICKY
   Desktop: centered floating bar with rounded corners.
   Mobile: full-width, no rounded corners.
   ========================================================================== */

header.wp-block-template-part {
	position: sticky;
	top: 8px;
	z-index: 999;
	background: transparent;
	margin-bottom: calc(-1 * var(--om-header-height, 110px));
	padding-top: 8px;
}

.admin-bar header.wp-block-template-part { top: 40px; }

@media screen and (max-width: 782px) {
	.admin-bar header.wp-block-template-part { top: 54px; }
}

.om-header {
	z-index: 999;
	gap: 0 !important;
	background: transparent !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.om-header > * {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

/* -- Main header bar (logo + nav) -- */
/* Force dark text on white header nav */
.om-header-main .wp-block-navigation,
.om-header-main .wp-block-navigation .wp-block-navigation-item__content,
.om-header-main .wp-block-navigation .wp-block-navigation-submenu__toggle,
.om-header-main .wp-block-navigation a,
.om-header-main .wp-block-navigation .has-white-color,
.om-header-main .wp-block-navigation__responsive-container:not(.is-menu-open) {
	font-size: 1.25rem !important;
	color: var(--wp--preset--color--dark-bg) !important;
	font-family: "Carter One", system-ui !important;
}


.om-header-main .wp-block-navigation a:hover,
.om-header-main .wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--primary) !important;
}

/* Top-level nav hover — yellow underline sweeps in from left, out to right */
.om-header-main .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content {
	position: relative;
}

/* Invisible hover-bridge below the Palvelut link so the cursor stays in the
   link's :hover area across the header-main padding gap into the submenu */
.om-header-main .wp-block-navigation__container > .wp-block-navigation-item.has-child > .wp-block-navigation-item__content::before {
	content: "";
	position: absolute;
	top: 100%;
	left: -24px;
	right: -24px;
	height: 64px;
	background: transparent;
}

.om-header-main .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content::after {
	content: "";
	position: absolute;
	bottom: -6px;
	left: 0;
	right: 0;
	height: 3px;
	background: var(--wp--preset--color--accent);
	border-radius: 2px;
	transform: scaleX(0);
	transform-origin: right center;
	transition: transform 0.4s cubic-bezier(0.65, 0.05, 0.36, 1);
}

.om-header-main .wp-block-navigation__container > .wp-block-navigation-item:hover > .wp-block-navigation-item__content::after,
.om-header-main .wp-block-navigation__container > .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content::after,
.om-header-main .wp-block-navigation__container > .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content::after {
	transform: scaleX(1);
	transform-origin: left center;
}

.om-header-main .wp-block-navigation__submenu-icon svg {
	stroke: var(--wp--preset--color--dark-bg) !important;
}


.om-header-main .wp-block-navigation__container {
	gap: 2.5rem !important;
}

/* -- Navigation submenu — mega-style, full header width, CLICK ONLY -- */

/* Force all intermediate elements static so submenu positions relative to om-header-main */
.om-header-main .wp-block-navigation,
.om-header-main .wp-block-navigation__responsive-container:not(.is-menu-open),
.om-header-main .wp-block-navigation__responsive-close,
.om-header-main .wp-block-navigation__responsive-dialog,
.om-header-main .wp-block-navigation__responsive-container-content,
.om-header-main .wp-block-navigation__container,
.om-header-main .wp-block-navigation-item.has-child,
.om-header-main .wp-block-navigation-submenu {
	position: static !important;
}


.om-header-main .wp-block-navigation__submenu-container {
	position: absolute !important;
	top: calc(100% + 12px) !important;
	left: 0 !important;
	right: 0 !important;
	width: 100% !important;
	min-width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;

	/* Always rendered as flex — visibility controls show/hide so we can use a delay */
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	justify-content: center !important;
	align-items: center !important;
	gap: 0.25rem 0.75rem !important;

	padding: 2.25rem 1.5rem !important;
	background: rgba(255, 255, 255, 0.97) !important;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-radius: 24px !important;
	border: 1px solid rgba(17, 17, 17, 0.06) !important;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);

	/* Hidden by default with 300ms close delay so the cursor can travel to it */
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease, visibility 0s 0.3s;
}

.om-header-main .wp-block-navigation .has-child:hover > .wp-block-navigation__submenu-container,
.om-header-main .wp-block-navigation .has-child:focus-within > .wp-block-navigation__submenu-container {
	visibility: visible;
	opacity: 1;
	pointer-events: auto;
	transition: opacity 0.2s ease, visibility 0s 0s;
}

.om-header-main .wp-block-navigation__submenu-container > .wp-block-navigation-item {
	flex: 0 1 auto;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	margin: 0 !important;
}

.om-header-main .wp-block-navigation__submenu-container a,
.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	padding: 0.4rem 0.5rem !important;
	font-size: 1.25rem !important;
	white-space: nowrap;
	color: var(--wp--preset--color--primary) !important;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
}

.om-header-main .wp-block-navigation__submenu-container a:hover,
.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover,
.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item:hover > .wp-block-navigation-item__content {
	background: transparent !important;
	color: var(--wp--preset--color--primary) !important;
}

/* Submenu hover — yellow underline sweep, anchored to text width */
.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item__label {
	position: relative;
	display: inline-block;
}

.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item__label::after {
	content: "";
	position: absolute;
	bottom: -4px;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--wp--preset--color--accent);
	border-radius: 2px;
	transform: scaleX(0);
	transform-origin: right center;
	transition: transform 0.4s cubic-bezier(0.65, 0.05, 0.36, 1);
}

.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item:hover .wp-block-navigation-item__label::after,
.om-header-main .wp-block-navigation__submenu-container .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__label::after {
	transform: scaleX(1);
	transform-origin: left center;
}

/* Active page in nav — stay black (current page indicated by hover state or underline elsewhere) */
.om-header .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content,
.om-header .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content {
	color: var(--wp--preset--color--primary) !important;
}

.om-header .wp-block-navigation__submenu-container .current-menu-item > .wp-block-navigation-item__content {
	color: var(--wp--preset--color--primary) !important;
	background: transparent !important;
}

/* Overview link in submenu */
.om-header .nav-overview-link > .wp-block-navigation-item__content {
	font-weight: 400 !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
	padding-bottom: 0.8rem !important;
	margin-bottom: 0.25rem;
}

.om-header-main {
	background: rgba(255, 255, 255, 0.97);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	max-width: 1200px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	border-radius: 24px;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
	transition: max-width 0.4s ease, margin-top 0.3s ease, box-shadow 0.4s ease;
	position: relative;
}

/* -- Scrolled down: header shrinks slightly -- */
.om-header.is-scrolling-down .om-header-main {
	max-width: 1000px !important;
	margin-top: 10px;
}

/* -- Scrolling up: header expands back to top-state width -- */
.om-header.is-scrolling-up .om-header-main {
	max-width: 1200px !important;
	margin-top: 0;
}


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

/* Footer on keltainen — linkit mustia, hover saa underline-korostuksen */
.om-footer a {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	transition: text-decoration 0.2s ease;
}

.om-footer a:hover {
	color: var(--wp--preset--color--primary) !important;
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 2px;
}

/* Navigation links inside footer — keep them black on yellow */
.om-footer .wp-block-navigation,
.om-footer .wp-block-navigation__container,
.om-footer .wp-block-navigation-item,
.om-footer .wp-block-navigation-item__content,
.om-footer .wp-block-navigation a,
.om-footer .wp-block-navigation .wp-block-navigation-item__label,
.om-footer .wp-block-navigation a span {
	color: var(--wp--preset--color--primary) !important;
}

.om-footer .wp-block-navigation a:hover,
.om-footer .wp-block-navigation a:hover .wp-block-navigation-item__label,
.om-footer .wp-block-navigation a:hover span,
.om-footer .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--primary) !important;
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 2px;
}


/* ==========================================================================
   10. MOBILE MENU — FULL SCREEN OVERLAY
   Menu is moved to <body> via JS to escape sticky header.
   ========================================================================== */

/* Navigation font size — ensure page list inherits nav size */
.wp-block-navigation .wp-block-page-list,
.wp-block-navigation .wp-block-navigation-item__content {
	font-size: inherit;
}

/* Hamburger icon color */
.wp-block-navigation__responsive-container-open {
	color: var(--wp--preset--color--accent) !important;
}

/* Flash prevention: hide content while menu is still inside header NAV */
.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100vw !important;
	height: 100vh !important;
	max-width: none !important;
	margin: 0 !important;
	z-index: 999999 !important;
	background-color: #ffffff !important;
	border-radius: 0 !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
	visibility: hidden;
}

body > .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
	visibility: visible;
}

/* Overlay behind menu — prevents any flash of page content */
body.om-menu-open::after {
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: #ffffff;
	z-index: 999998;
	pointer-events: none;
}

/* Body scroll lock */
body.om-menu-open {
	overflow: hidden !important;
}

/* Full screen menu container (when moved to body) */
.wp-block-navigation__responsive-container.is-menu-open {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100vw !important;
	height: 100vh !important;
	height: 100dvh !important;
	min-height: 100vh !important;
	max-height: none !important;
	max-width: none !important;
	margin: 0 !important;
	z-index: 999999 !important;
	background-color: #ffffff !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	overflow-y: auto !important;
	border-radius: 0 !important;
}

/* Admin bar offset */
.admin-bar .wp-block-navigation__responsive-container.is-menu-open {
	top: 32px !important;
	height: calc(100vh - 32px) !important;
	height: calc(100dvh - 32px) !important;
}

@media screen and (max-width: 782px) {
	.admin-bar .wp-block-navigation__responsive-container.is-menu-open {
		top: 46px !important;
		height: calc(100vh - 46px) !important;
		height: calc(100dvh - 46px) !important;
	}
}

/* Inner wrappers — full size, no padding */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
	width: 100% !important;
	max-width: 100% !important;
	height: 100% !important;
	min-height: 100vh !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	background: transparent !important;
	position: relative !important;
}

/* Close button — same padding as header-main */
.wp-block-navigation__responsive-container-close {
	color: var(--wp--preset--color--dark-bg) !important;
	background: none !important;
	border: none !important;
	padding-top: var(--wp--preset--spacing--30) !important;
	padding-right: var(--wp--preset--spacing--x-large) !important;
	padding-bottom: var(--wp--preset--spacing--30) !important;
	padding-left: 0 !important;
}

/* Menu content area — same padding as header-main */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	flex-direction: column !important;
	align-items: flex-start !important;
	justify-content: flex-start !important;
	gap: 0 !important;
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--x-large) 80px !important;
	width: 100% !important;
	text-align: left !important;
	box-sizing: border-box !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
	align-items: flex-start !important;
	text-align: left !important;
}

/* Navigation lists inside menu */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__container,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-page-list {
	flex-direction: column !important;
	align-items: flex-start !important;
	gap: 0 !important;
	width: 100% !important;
}

/* Menu items — top level */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	width: 100% !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu__toggle,
.wp-block-navigation__responsive-container.is-menu-open button.wp-block-navigation-item__content {
	font-size: 1.1rem !important;
	color: var(--wp--preset--color--dark-bg) !important;
	display: block !important;
	text-align: left !important;
	text-decoration: none !important;
	padding: 20px 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open > .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content > .wp-block-navigation-item > .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open > .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content > .wp-block-navigation-item > .wp-block-navigation-submenu__toggle {
	padding: 20px 0 !important;
	font-weight: 600 !important;
}

/* Submenu items in mobile */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item {
	border-bottom: none !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	padding: 14px 0 14px 1.25rem !important;
	font-size: 1.1rem !important;
	font-weight: 400 !important;
	color: rgba(0, 0, 0, 0.55) !important;
	display: block !important;
	text-align: left !important;
	text-decoration: none !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .nav-overview-link .wp-block-navigation-item__content {
	font-weight: 400 !important;
	color: rgba(0, 0, 0, 0.55) !important;
}

.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-submenu__toggle:hover {
	color: var(--wp--preset--color--accent) !important;
}

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

/* Cloned elements inside menu */
.om-logo-clone {
	flex-shrink: 0;
	margin-bottom: 24px;
}

.om-logo-clone img {
	max-width: 130px !important;
	height: auto !important;
}

/* -- Menu open animations -- */
.wp-block-navigation__responsive-container.is-menu-open .om-logo-clone {
	animation: fadeIn 0.3s ease forwards;
	opacity: 0;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
	animation: fadeIn 0.3s ease forwards;
	opacity: 0;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	animation: menuItemSlideIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
	opacity: 0;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1) { animation-delay: 0.10s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2) { animation-delay: 0.15s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3) { animation-delay: 0.20s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4) { animation-delay: 0.25s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5) { animation-delay: 0.30s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(6) { animation-delay: 0.35s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(7) { animation-delay: 0.40s; }
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(8) { animation-delay: 0.45s; }

@keyframes fadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes menuItemSlideIn {
	from { opacity: 0; transform: translateX(-12px); }
	to   { opacity: 1; transform: translateX(0); }
}


/* ==========================================================================
   11. ACCESSIBILITY
   ========================================================================== */

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

	html { scroll-behavior: auto; }
}


/* ==========================================================================
   12. RESPONSIVE (max-width: 781px)
   ========================================================================== */

@media (max-width: 781px) {

	/* General */
	.wp-block-columns { gap: var(--wp--preset--spacing--30) !important; }
	.om-stat-number   { font-size: 2.25rem; }
	.om-service-card  { padding: 20px 20px 20px 24px; }

	.om-testimonial::before { font-size: 60px; }

	.om-stats-section .wp-block-column + .wp-block-column {
		border-left: none;
		border-top: 1px solid rgba(255, 255, 255, 0.1);
		padding-top: var(--wp--preset--spacing--30);
	}

	/* Header — slim floating bar with rounded corners */
	.om-header-main {
		max-width: calc(100% - 16px) !important;
		margin-left: 8px !important;
		margin-right: 8px !important;
		border-radius: 16px;
		box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
	}

	.om-header-main .wp-block-navigation a,
	.om-header-main .wp-block-navigation .wp-block-navigation-item__content {
		font-size: 1rem !important;
	}

	.om-header.is-scrolled .om-header-main {
		max-width: 100% !important;
		border-radius: 0 !important;
		margin-top: 0 !important;
	}

	/* Logo */
	.om-header-main .wp-block-site-logo img {
		max-width: 130px !important;
		height: auto;
	}

	/* Emergency badge */
	.om-emergency-badge {
		padding: 3px 8px !important;
		font-size: 0.625rem !important;
	}
}


/* ==========================================================================
   Logo-scroller (kumppanikaruselli)
   Käytä patternin kanssa: onnenmaali-theme/logo-scroller
   ========================================================================== */

.om-logo-scroller {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding: 1rem 0;
	mask-image: linear-gradient(
		to right,
		transparent 0,
		#000 80px,
		#000 calc(100% - 80px),
		transparent 100%
	);
	-webkit-mask-image: linear-gradient(
		to right,
		transparent 0,
		#000 80px,
		#000 calc(100% - 80px),
		transparent 100%
	);
}

.om-logo-scroller__track {
	display: flex !important;
	align-items: center !important;
	gap: 3.5rem !important;
	width: max-content !important;
	max-width: none !important;
	flex-wrap: nowrap !important;
}

/* Animaatio toimii vasta kun frontend on kloonannut logot (data-om-cloned="1") */
.om-logo-scroller__track[data-om-cloned="1"] {
	animation: om-logo-scroll 50s linear infinite;
}

/* Hover-hidastus hoidetaan JS:llä (playbackRate-asteittainen muutos) — ks. functions.php */

/* Kuvalohko track-divin lapsena = yksi logo-slotti */
.om-logo-scroller__track > .wp-block-image,
.om-logo-scroller__item {
	flex: 0 0 auto !important;
	width: 150px;
	height: 80px;
	margin: 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
}

.om-logo-scroller__track > .wp-block-image a,
.om-logo-scroller__item a {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.om-logo-scroller__track > .wp-block-image img,
.om-logo-scroller__item img {
	max-width: 100%;
	max-height: 100%;
	width: auto !important;
	height: auto !important;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.7;
	transition: filter 0.25s ease, opacity 0.25s ease;
}

.om-logo-scroller__track > .wp-block-image:hover img,
.om-logo-scroller__track > .wp-block-image:focus-within img,
.om-logo-scroller__item:hover img,
.om-logo-scroller__item:focus img {
	filter: grayscale(0%);
	opacity: 1;
}

@keyframes om-logo-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(calc(-50% - 1.75rem)); }
}

/* Saavutettavuus: jos käyttäjä on pyytänyt vähemmän liikettä, näytä logot grid-muodossa */
@media (prefers-reduced-motion: reduce) {
	.om-logo-scroller {
		mask-image: none;
		-webkit-mask-image: none;
	}
	.om-logo-scroller__track {
		animation: none !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
		width: 100% !important;
	}
}

/* Pienillä näytöillä logot tiiviimmin */
@media (max-width: 600px) {
	.om-logo-scroller__track { gap: 2rem !important; }
	.om-logo-scroller__track > .wp-block-image,
	.om-logo-scroller__item { width: 110px; height: 60px; }
}



/* ==========================================================================
   Step number — watermark-tyylinen iso numero prosessiosioiden taustalle.
   Suuri, hyvin haalea numero joka toimii taustaeleenä otsikon ylä-/alapuolella.
   ========================================================================== */
.om-step-number {
	font-size: clamp(7rem, 14vw, 11rem) !important;
	font-weight: 800 !important;
	line-height: 0.85 !important;
	letter-spacing: -0.06em !important;
	color: rgba(254, 231, 0, 0.5) !important;  /* haalea keltainen watermark vaalealle taustalle */
	margin-top: 0 !important;
	margin-bottom: -2.5rem !important;
}

/* Keltaisilla/tummilla taustoilla: mustempi watermark */
.has-accent-background-color .om-step-number,
.has-accent-light-background-color .om-step-number,
.has-accent-dark-background-color .om-step-number {
	color: rgba(17, 17, 17, 0.12) !important;
}

.has-dark-bg-background-color .om-step-number,
.has-primary-background-color .om-step-number,
.has-emergency-background-color .om-step-number {
	color: rgba(254, 231, 0, 0.22) !important;
}

/* Heading hieman tiukemmin numeron alle (overlap-vaikutelma) */
.om-step-number + h3,
.om-step-number + .wp-block-heading {
	position: relative;
	z-index: 2;
}

/* Accent-viiva askelten otsikoiden alle */
.om-step-number + h3::after,
.om-step-number + .wp-block-heading::after {
	content: "";
	display: block;
	width: 36px;
	height: 3px;
	background: var(--wp--preset--color--accent);
	margin-top: 14px;
	border-radius: 2px;
}

/* Keltaisella taustalla: musta viiva */
.has-accent-background-color .om-step-number + h3::after,
.has-accent-background-color .om-step-number + .wp-block-heading::after,
.has-accent-light-background-color .om-step-number + h3::after,
.has-accent-light-background-color .om-step-number + .wp-block-heading::after,
.has-accent-dark-background-color .om-step-number + h3::after,
.has-accent-dark-background-color .om-step-number + .wp-block-heading::after {
	background: var(--wp--preset--color--primary);
}

/* Tummalla taustalla: keltainen viiva */
.has-dark-bg-background-color .om-step-number + h3::after,
.has-dark-bg-background-color .om-step-number + .wp-block-heading::after,
.has-primary-background-color .om-step-number + h3::after,
.has-primary-background-color .om-step-number + .wp-block-heading::after,
.has-emergency-background-color .om-step-number + h3::after,
.has-emergency-background-color .om-step-number + .wp-block-heading::after {
	background: var(--wp--preset--color--accent);
}

/* ==========================================================================
   REFERENSSIKARTTA (Leaflet)
   ========================================================================== */

.om-referenssikartta-wrap {
	position: relative;
	margin: 0 auto;
}

.om-referenssikartta {
	height: 520px;
	width: 100%;
	border-radius: 28px;
	overflow: hidden;
	box-shadow: 0 24px 60px -28px rgba(0, 0, 0, 0.35);
	background: var(--wp--preset--color--accent-light, #FFF7A0);
	z-index: 0;
}

.om-referenssikartta__empty {
	margin-top: var(--wp--preset--spacing--20, 16px);
	color: var(--wp--preset--color--muted, #6B6B6B);
	text-align: center;
}

/* Keltainen brändi-pin (divIcon) */
.om-map-pin-wrap {
	background: transparent;
	border: 0;
}

.om-map-pin {
	display: block;
	width: 24px;
	height: 24px;
	background: var(--wp--preset--color--accent, #FEE700);
	border: 2px solid var(--wp--preset--color--primary, #111111);
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	box-shadow: 0 5px 12px -3px rgba(0, 0, 0, 0.5);
	transition: transform 0.15s ease;
}

.om-map-pin::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 7px;
	height: 7px;
	background: var(--wp--preset--color--primary, #111111);
	border-radius: 50%;
	transform: translate(-50%, -50%);
}

.om-map-pin-wrap:hover .om-map-pin {
	transform: rotate(-45deg) scale(1.12);
}

/* -- Pin-variantit kohteen tyypin mukaan -- */

/* Maalaus (oletus): keltainen täppä, musta reuna + piste */
.om-map-pin--maalaus {
	background: var(--wp--preset--color--accent, #FEE700);
	border-color: var(--wp--preset--color--primary, #111111);
}
.om-map-pin--maalaus::after {
	background: var(--wp--preset--color--primary, #111111);
}

/* Kattohuolto: musta täppä, keltainen reuna + piste */
.om-map-pin--katto {
	background: var(--wp--preset--color--primary, #111111);
	border-color: var(--wp--preset--color--accent, #FEE700);
}
.om-map-pin--katto::after {
	background: var(--wp--preset--color--accent, #FEE700);
}

/* Taloyhtiö: valkoinen täppä, musta reuna + piste */
.om-map-pin--taloyhtio {
	background: #ffffff;
	border-color: var(--wp--preset--color--primary, #111111);
}
.om-map-pin--taloyhtio::after {
	background: var(--wp--preset--color--primary, #111111);
}

/* -- Kartan selite (legend) -- */
.om-map-legend {
	background: rgba(255, 255, 255, 0.95);
	padding: 10px 14px;
	border-radius: 12px;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
	font-size: 0.8125rem;
	line-height: 1.6;
}
.om-map-legend__row {
	display: flex;
	align-items: center;
	gap: 8px;
}
.om-map-legend__dot {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 2px solid var(--wp--preset--color--primary, #111111);
	flex-shrink: 0;
}
.om-map-legend__dot--maalaus { background: var(--wp--preset--color--accent, #FEE700); }
.om-map-legend__dot--katto { background: var(--wp--preset--color--primary, #111111); border-color: var(--wp--preset--color--accent, #FEE700); }
.om-map-legend__dot--taloyhtio { background: #ffffff; }

/* Popup-sisältö */
.om-map-popup {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 160px;
	font-family: "Inter", sans-serif;
}

.om-map-popup__type {
	font-size: 15px;
	font-weight: 700;
	color: var(--wp--preset--color--primary, #111111);
	line-height: 1.3;
}

.om-map-popup__addr {
	font-size: 13px;
	color: var(--wp--preset--color--secondary, #3B3B3B);
}

.om-map-popup__link {
	margin-top: 6px;
	font-size: 13px;
	font-weight: 600;
	color: var(--wp--preset--color--primary, #111111);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.om-map-popup__link:hover {
	color: var(--wp--preset--color--accent-dark, #E5D000);
}

/* Leaflet popup -laatikon brändäys */
.leaflet-popup-content-wrapper {
	border-radius: 14px;
}

.leaflet-popup-content {
	margin: 14px 16px;
}

@media (max-width: 781px) {
	.om-referenssikartta {
		height: 380px;
		border-radius: 20px;
	}
}
