/**
 * Design elements integration – palette and assets from design-elements folder
 *
 * Colors from uploaded assets: teal, gold, charcoal, sage.
 *
 * @package Ontario_Consulting
 */

:root {
	/* Design-elements palette (from backgrounds, circles, boxes) */
	--de-teal: #6B8C81;
	--de-teal-light: #80C8BF;
	--de-teal-mint: #98d9c2;
	--de-gold: #B4965A;
	--de-gold-muted: #C3B28B;
	--de-charcoal: #242424;
	--de-charcoal-soft: #2d2d2d;
	--de-sage: #7E9489;
	--de-sage-light: #91A99F;
	--de-white: #FFFFFF;
	/* Brand palette (Publications gradient) */
	--de-palette-gold: #C5B27D;
	--de-palette-teal: #75AC98;
	--de-palette-charcoal: #42393C;
}

/* Smooth scroll for anchor links (e.g. #service-content) */
html {
	scroll-behavior: smooth;
}

/* Check-list: use bullet points design element */
.orbia-about_one .check-list.gradient-check,
.check-list.gradient-check {
	list-style: none;
	padding-left: 0;
}
.check-list.gradient-check li {
	padding-left: 2rem;
	position: relative;
}
.check-list.gradient-check li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 1.25rem;
	height: 1.25rem;
	background: url("../images/design-elements/bullet points-01.png") no-repeat center;
	background-size: contain;
}
.check-list.gradient-check li i.fas {
	display: none;
}

/* Our Core Values – icons always visible (no hover-only), larger icon size */
.orbia-advance-sec .core-values-grid .orbia-iconic-box.style-one .icon-wrap .icon img {
	-webkit-filter: none;
	filter: none;
	opacity: 1;
	width: 80px;
	height: auto;
	object-fit: contain;
}
.orbia-advance-sec .core-values-grid .orbia-iconic-box.style-one:hover .icon-wrap .icon img {
	-webkit-filter: none;
	filter: none;
	opacity: 1;
}
.orbia-advance-sec .core-values-grid .orbia-iconic-box.style-one .content {
	padding-top: 0;
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
	min-height: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}
.orbia-advance-sec .core-values-grid .orbia-iconic-box.style-one .content h4.title {
	text-transform: uppercase;
	letter-spacing: 0.02em;
}
.orbia-advance-sec .core-values-grid .orbia-iconic-box.style-one .content p {
	-webkit-line-clamp: unset;
	line-clamp: unset;
	display: block;
}

/* Optional: section accents using design palette */
.orbia-about_one .section-title .sub-title,
.orbia-service_one .section-title .sub-title {
	color: var(--de-teal-light, var(--secondary-color));
}
.orbia-hero_one .hero-content .tag-line {
	color: var(--de-gold-muted, var(--primary-color));
}

/* Animated text: example client logos – same size as text, aligned */
.animated-text-slide .scroll-text-inner.scroll-text-logo {
	display: inline-flex;
	align-items: center;
	line-height: 1;
}
.animated-text-slide .scroll-text-inner.scroll-text-logo .text {
	display: inline-flex;
	align-items: center;
	line-height: 1;
	height: 1em;
}
.animated-text-slide .scroll-text-inner.scroll-text-logo .text img {
	height: 50px;
	width: auto;
	max-width: 180px;
	object-fit: contain;
	display: block;
	vertical-align: middle;
}
@media (max-width: 767.98px) {
	.animated-text-slide .scroll-text-inner.scroll-text-logo .text img {
		height: 30px;
		max-width: 120px;
	}
}

/* Partnerships section scroll: larger, clearer logos (partnership + success story logos) */
.animated-text-slide.ontario-partnerships-scroll .scroll-text-inner.scroll-text-logo .text img {
	height: 72px;
	max-width: 220px;
	object-fit: contain;
}
@media (max-width: 767.98px) {
	.animated-text-slide.ontario-partnerships-scroll .scroll-text-inner.scroll-text-logo .text img {
		height: 52px;
		max-width: 160px;
	}
}

/* ========== Publications section (home – based on ontarioconsulting.ca/publications) ========== */
.ontario-publications-section .section-title .sub-title {
	color: var(--de-teal);
}
.ontario-publications-section .section-title p {
	color: var(--text-color);
	font-size: 1rem;
}
.ontario-publication-card .post-thumbnail.ontario-publication-thumb {
	display: block;
	position: relative;
	overflow: hidden;
	border-radius: inherit;
}
.ontario-publication-card .post-thumbnail.ontario-publication-thumb img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.35s ease;
}
.ontario-publication-card .post-thumbnail.ontario-publication-thumb:hover img {
	transform: scale(1.04);
}
.ontario-publication-type {
	position: absolute;
	top: 12px;
	left: 12px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 6px 12px;
	border-radius: 20px;
	background: rgba(255, 255, 255, 0.95);
	color: var(--de-charcoal);
}
.ontario-publication-type--video {
	background: var(--de-teal);
	color: var(--de-white);
}
.ontario-publication-type--pdf {
	background: var(--de-gold);
	color: var(--de-white);
}
.ontario-publication-thumb--pdf {
	position: relative;
}
.ontario-publication-pdf-icon {
	position: absolute;
	bottom: 12px;
	right: 12px;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.95);
	border-radius: 50%;
	color: #c53030;
	font-size: 20px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
}
.ontario-publication-thumb--video {
	position: relative;
}
.ontario-publication-play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.2);
	transition: background 0.3s ease;
}
.ontario-publication-thumb--video:hover .ontario-publication-play {
	background: rgba(0, 0, 0, 0.35);
}
/* YouTube-style play button: red rounded rectangle + white triangle */
.ontario-publication-play::before {
	content: '';
	position: absolute;
	width: 72px;
	height: 50px;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background: #e62117;
	border-radius: 14px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	z-index: 0;
}
.ontario-publication-thumb--video:hover .ontario-publication-play::before {
	transform: translate(-50%, -50%) scale(1.05);
	box-shadow: 0 6px 28px rgba(0, 0, 0, 0.45);
}
.ontario-publication-play i {
	position: relative;
	z-index: 1;
	font-size: 22px;
	color: var(--de-white);
	margin-left: 4px;
	text-shadow: none;
}
.ontario-publication-card .post-content .ontario-publication-excerpt {
	font-size: 14px;
	line-height: 1.55;
	color: var(--text-color);
	margin-bottom: 18px;
}
.ontario-publications-cta {
	text-align: center;
}
.ontario-publications-cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	font-weight: 600;
}

/* ========== Publications page: equal-height creative cards (2 per row) ========== */
.ontario-publications-page .ontario-publications-grid {
	align-items: stretch;
}
.ontario-publications-page .ontario-publication-card-wrap {
	height: 100%;
	display: flex;
}
.ontario-publications-page .ontario-publication-card.ontario-publication-card--creative {
	display: flex;
	flex-direction: column;
	height: 100%;
	width: 100%;
	background: var(--de-white);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(66, 57, 60, 0.08);
	border: 1px solid rgba(117, 172, 152, 0.15);
	position: relative;
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
/* Whole card is one link to single publication */
.ontario-publications-page .ontario-publication-card--link {
	text-decoration: none;
	color: inherit;
}
.ontario-publications-page .ontario-publication-card--link .post-content .title {
	color: var(--de-charcoal);
	transition: color 0.25s ease;
}
.ontario-publications-page .ontario-publication-card--link:hover .post-content .title {
	color: var(--de-teal);
}
.ontario-publications-page .ontario-publication-card--link .post-thumbnail {
	display: block;
}
.ontario-publications-page .ontario-publication-card--link .post-content {
	display: flex;
}
.ontario-publications-page .ontario-publication-card.ontario-publication-card--creative:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 40px rgba(66, 57, 60, 0.12);
	border-color: rgba(117, 172, 152, 0.35);
}
/* Decorative accent (brand color strip) */
.ontario-publications-page .ontario-publication-card-accent {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	z-index: 2;
	pointer-events: none;
}
.ontario-publications-page .ontario-publication-card-accent--teal {
	background: linear-gradient(90deg, var(--de-teal) 0%, var(--de-palette-teal) 100%);
}
.ontario-publications-page .ontario-publication-card-accent--gold {
	background: linear-gradient(90deg, var(--de-gold) 0%, var(--de-palette-gold) 100%);
}
/* Same-size thumbnail area (16:9) */
.ontario-publications-page .ontario-publication-card--creative .post-thumbnail.ontario-publication-thumb {
	flex-shrink: 0;
	aspect-ratio: 16 / 9;
	display: block;
	border-radius: 20px 20px 0 0;
	overflow: hidden;
}
.ontario-publications-page .ontario-publication-card--creative .post-thumbnail.ontario-publication-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 0;
}
/* Card body: flex so CTA stays at bottom */
.ontario-publications-page .ontario-publication-card--creative .post-content {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 28px 24px 24px;
}
.ontario-publications-page .ontario-publication-card--creative .post-content .title {
	margin-bottom: 12px;
	line-height: 1.35;
	font-size: 20px;
}
.ontario-publications-page .ontario-publication-card--creative .post-content .title a {
	color: var(--de-charcoal);
	transition: color 0.25s ease;
}
.ontario-publications-page .ontario-publication-card--creative .post-content .title a:hover {
	color: var(--de-teal);
}
.ontario-publications-page .ontario-publication-card--creative .post-content .ontario-publication-excerpt {
	flex: 1;
	margin-bottom: 20px;
	font-size: 14px;
	line-height: 1.6;
	color: var(--text-color);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
/* CTA link as small button */
.ontario-publications-page .ontario-publication-cta-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	font-size: 14px;
	color: var(--de-teal);
	transition: color 0.25s ease, gap 0.25s ease;
}
.ontario-publications-page .ontario-publication-card--pdf .ontario-publication-cta-link {
	color: var(--de-gold);
}
.ontario-publications-page .ontario-publication-cta-link:hover {
	color: var(--de-charcoal);
	gap: 12px;
}
.ontario-publications-page .ontario-publication-card--creative .post-content .read-more.style-one {
	padding-top: 0;
}
/* Type badge with icon */
.ontario-publications-page .ontario-publication-type i {
	margin-right: 6px;
	opacity: 0.95;
}

/* ========== Publications page: 3 sections by type (Articles, Videos, PDFs) – compact & organized ========== */
.ontario-publications-compact.ontario-publications-by-type {
	padding-top: 4rem;
	padding-bottom: 3.5rem;
}
.ontario-publications-compact .ontario-publications-page-title {
	margin-bottom: 2.5rem;
}

.ontario-publications-by-type .ontario-publications-type-section {
	margin-bottom: 1.5rem;
	padding: 1.25rem 1.25rem 1rem;
	position: relative;
	border-radius: 16px;
	border: 1px solid rgba(117, 172, 152, 0.12);
	background: var(--de-white);
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.04);
	transition: box-shadow 0.25s ease, border-color 0.25s ease;
}
.ontario-publications-by-type .ontario-publications-type-section:hover {
	box-shadow: 0 4px 20px rgba(66, 57, 60, 0.06);
	border-color: rgba(117, 172, 152, 0.2);
}
.ontario-publications-by-type .ontario-publications-type-section:last-of-type {
	margin-bottom: 0;
}
/* Left accent bar (creative type indicator) */
.ontario-publications-type-section--articles {
	border-left: 4px solid var(--de-sage);
}
.ontario-publications-type-section--videos {
	border-left: 4px solid var(--de-teal);
}
.ontario-publications-type-section--pdfs {
	border-left: 4px solid var(--de-gold);
}

/* Compact header: icon + title inline, Explore all button top right */
.ontario-publications-type-header {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 1rem;
	text-align: left;
}
.ontario-publications-type-heading {
	flex: 1;
	min-width: 0;
}
/* Explore all button – top right, same style as home publications CTA */
.ontario-publications-type-header .ontario-publications-cta {
	display: flex;
	justify-content: flex-end;
	flex-shrink: 0;
	margin-left: auto;
	margin-bottom: 0;
}
.ontario-publications-type-header .ontario-publications-cta .theme-btn.gradient-btn.ontario-publications-cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	font-weight: 600;
	white-space: nowrap;
}
.ontario-publications-type-icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 12px;
	font-size: 20px;
	color: var(--de-white);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
.ontario-publications-type-icon--article {
	background: linear-gradient(135deg, var(--de-sage) 0%, var(--de-teal) 100%);
}
.ontario-publications-type-icon--video {
	background: linear-gradient(135deg, var(--de-teal) 0%, var(--de-palette-teal) 100%);
}
.ontario-publications-type-icon--pdf {
	background: linear-gradient(135deg, var(--de-gold) 0%, var(--de-palette-gold) 100%);
}
.ontario-publications-type-title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--de-charcoal);
	margin: 0 0 0.25rem;
	line-height: 1.3;
}
.ontario-publications-type-desc {
	font-size: 0.875rem;
	color: var(--text-color);
	margin: 0;
	line-height: 1.45;
	opacity: 0.9;
}
.ontario-publications-type-empty {
	text-align: center;
	color: var(--text-color);
	font-size: 0.9375rem;
	padding: 1.5rem 1rem;
	margin: 0;
	background: rgba(255, 255, 255, 0.7);
	border-radius: 12px;
	border: 1px dashed rgba(117, 172, 152, 0.25);
}
.ontario-publications-type-footer {
	text-align: right;
	margin-top: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px solid rgba(117, 172, 152, 0.1);
}
.ontario-explore-all-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-weight: 600;
	font-size: 14px;
	color: var(--de-teal);
	transition: color 0.25s ease, gap 0.25s ease;
}
.ontario-explore-all-link:hover {
	color: var(--de-charcoal);
	gap: 10px;
}
.ontario-publications-type-section--pdfs .ontario-explore-all-link {
	color: var(--de-gold);
}
.ontario-publications-type-section--pdfs .ontario-explore-all-link:hover {
	color: var(--de-charcoal);
}
.ontario-publications-by-type .ontario-publications-type-grid {
	align-items: stretch;
}
.ontario-publications-by-type .ontario-publications-type-grid .mb-40 {
	margin-bottom: 1.25rem !important;
}
.ontario-publications-by-type .ontario-publications-type-grid .mb-40:last-child {
	margin-bottom: 0 !important;
}
.ontario-publications-by-type .ontario-publication-card-wrap {
	height: 100%;
	display: flex;
}
.ontario-publications-by-type .ontario-publication-card-wrap .ontario-publication-card {
	height: 100%;
}

@media (max-width: 991.98px) {
	.ontario-publications-compact.ontario-publications-by-type {
		padding-top: 3rem;
		padding-bottom: 2.5rem;
	}
	.ontario-publications-compact .ontario-publications-page-title {
		margin-bottom: 2rem;
	}
	.ontario-publications-by-type .ontario-publications-type-section {
		margin-bottom: 1.25rem;
		padding: 1rem 1rem 0.75rem;
	}
	.ontario-publications-type-header {
		margin-bottom: 0.875rem;
	}
	.ontario-publications-type-header .ontario-publications-cta {
		margin-left: 0;
		width: 100%;
		justify-content: flex-end;
	}
	.ontario-publications-type-header .ontario-publications-cta .theme-btn.gradient-btn.ontario-publications-cta-btn {
		padding: 12px 22px;
		font-size: 0.9375rem;
	}
	.ontario-publications-type-icon {
		width: 40px;
		height: 40px;
		font-size: 18px;
		border-radius: 10px;
	}
	.ontario-publications-type-title {
		font-size: 1.2rem;
	}
	.ontario-publications-type-desc {
		font-size: 0.8125rem;
	}
}

@media (max-width: 575.98px) {
	.ontario-publications-compact.ontario-publications-by-type {
		padding-top: 2.5rem;
		padding-bottom: 2rem;
	}
	.ontario-publications-by-type .ontario-publications-type-section {
		margin-bottom: 1rem;
		padding: 0.875rem 0.75rem 0.75rem;
		border-radius: 12px;
	}
	.ontario-publications-type-section--articles,
	.ontario-publications-type-section--videos,
	.ontario-publications-type-section--pdfs {
		border-left-width: 3px;
	}
	.ontario-publications-type-header {
		margin-bottom: 0.75rem;
		gap: 0.75rem;
	}
	.ontario-publications-type-header .ontario-publications-cta {
		width: 100%;
		justify-content: center;
	}
	.ontario-publications-type-header .ontario-publications-cta .theme-btn.gradient-btn.ontario-publications-cta-btn {
		padding: 12px 20px;
		font-size: 0.875rem;
		white-space: normal;
		text-align: center;
	}
	.ontario-publications-type-icon {
		width: 36px;
		height: 36px;
		font-size: 16px;
	}
	.ontario-publications-type-title {
		font-size: 1.1rem;
	}
	.ontario-publications-by-type .ontario-publications-type-grid .col-lg-6 {
		margin-bottom: 1rem !important;
	}
	.ontario-publications-by-type .ontario-publications-type-grid .col-lg-6:last-child {
		margin-bottom: 0 !important;
	}
}

/* About section: character design in shape (replaces icon-01) */
.orbia-about_one .shape img {
	max-width: 200px;
	height: auto;
	object-fit: contain;
}

/* About page (orbia-about_four): shape-two vertical bars SVG */
.orbia-about_four .orbia-image-box .shape.shape-two img {
	height: auto;
	max-height: 100%;
	width: auto;
	display: block;
}

/* About page (orbia-about_four): main image large, character icon removed – crop to meeting scene only */
.orbia-about_four .orbia-about_four-image-box {
	min-height: 0;
}
.orbia-about_four .orbia-image-box .shape.shape-one {
	bottom: -76px;
}
.orbia-about_four .orbia-about_four-image-box .ontario-about-main-image {
	overflow: hidden;
	border-radius: 30px;
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12);
	aspect-ratio: 4 / 3;
	width: 100%;
}
.orbia-about_four .orbia-about_four-image-box .ontario-about-main-image img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: top center;
	border-radius: 30px;
}
@media (min-width: 992px) {
	.orbia-about_four .orbia-about_four-image-box .ontario-about-main-image {
		aspect-ratio: 3 / 3;
		min-height: 435px;
		max-height: 587px;
		height: auto;
	}
	.orbia-about_four .orbia-about_four-image-box .ontario-about-main-image img {
		min-height: 100%;
	}
}

/* About section: enhanced image design – image height fits right-side content */
.orbia-about_one .container .row {
	align-items: stretch;
}
.orbia-about_one .ontario-about-image-box {
	position: relative;
	height: 100%;
	min-height: 320px;
}
.orbia-about_one .ontario-about-image-box .ontario-about-image-deco {
	position: absolute;
	bottom: -20px;
	right: -20px;
	z-index: 2;
	width: 140px;
	height: auto;
	pointer-events: none;
	opacity: 0.85;
}
.orbia-about_one .ontario-about-image-box .ontario-about-image-deco img {
	width: 100%;
	height: auto;
	display: block;
}
.orbia-about_one .ontario-about-image-box .image_one {
	overflow: hidden;
	border-radius: 24px;
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12), 0 8px 20px rgba(0, 0, 0, 0.08);
	height: 100%;
}
.orbia-about_one .ontario-about-image-box .image_one img {
	border-radius: 24px;
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center center;
}
.orbia-about_one .ontario-about-image-box .image_two {
	overflow: hidden;
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}
.orbia-about_one .ontario-about-image-box .image_two img {
	border-radius: 16px;
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	max-width: 220px;
}
@media (max-width: 1199.98px) {
	.orbia-about_one .ontario-about-image-box {
		min-height: 380px;
	}
	.orbia-about_one .ontario-about-image-box .ontario-about-image-deco {
		width: 100px;
		bottom: -12px;
		right: -12px;
		opacity: 0.75;
	}
	.orbia-about_one .ontario-about-image-box .image_one img {
		object-position: center center;
	}
}
@media (max-width: 767.98px) {
	.orbia-about_one .ontario-about-image-box {
		height: auto;
		min-height: 0;
	}
	.orbia-about_one .ontario-about-image-box .image_one {
		height: auto;
		min-height: 280px;
	}
	.orbia-about_one .ontario-about-image-box .image_one img {
		height: auto;
		min-height: 280px;
		object-fit: cover;
	}
	.orbia-about_one .ontario-about-image-box .ontario-about-image-deco {
		width: 80px;
		bottom: -8px;
		right: 50%;
		transform: translateX(50%);
	}
	.orbia-about_one .ontario-about-image-box .image_two img {
		max-width: 100%;
	}
}

/* ========== About page: Welcome / Expertise / Vision / Mission ========== */
/* Variant A: Services-style section (same background as Services) – used by content-about-welcome-values.php */
.ontario-about-values-section.orbia-service_one {
	position: relative;
	background-color: var(--de-charcoal, #242424);
	background-size: cover;
	background-position: center;
}
.ontario-about-values-section.orbia-service_one.bg_cover::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background: linear-gradient(135deg, rgba(36, 36, 36, 0.92) 0%, rgba(66, 57, 60, 0.88) 50%, rgba(36, 36, 36, 0.92) 100%);
}
.ontario-about-values-section .container,
.ontario-about-values-section .ontario-about-values-wrapper {
	position: relative;
	z-index: 1;
}
.ontario-about-values-wrapper {
	padding-left: 15px;
	padding-right: 15px;
}
.ontario-about-values-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 32px;
	max-width: 1200px;
	margin: 0 auto;
}
.ontario-about-values-card {
	border-radius: 24px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	background: rgba(255, 255, 255, 0.06);
	transition: border-color 0.3s ease, background-color 0.3s ease, transform 0.25s ease;
	overflow: visible;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}
.ontario-about-values-card:hover {
	border-color: rgba(255, 255, 255, 0.45);
	background: rgba(255, 255, 255, 0.1);
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
}
.ontario-about-values-card-inner {
	padding: 40px 36px 44px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
/* Circle: proper round shape, clearer concentric rings */
.ontario-about-values-section .ontario-about-circle-label {
	width: 170px;
	height: 170px;
	flex-shrink: 0;
	margin-bottom: 28px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}
.ontario-about-values-section .ontario-about-circles {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06);
}
.ontario-about-values-section .ontario-about-ring {
	position: absolute;
	border-radius: 50%;
	border: 2.5px solid;
	box-sizing: border-box;
}
.ontario-about-values-section .ontario-about-ring--1 {
	inset: -8px;
	border-color: rgba(255, 255, 255, 0.55);
	opacity: 1;
}
.ontario-about-values-section .ontario-about-ring--2 {
	inset: 6px;
	border-color: var(--de-teal-light, #80C8BF);
	opacity: 1;
}
.ontario-about-values-section .ontario-about-ring--3 {
	inset: 20px;
	border-color: var(--de-gold-muted, #C3B28B);
	opacity: 1;
}
.ontario-about-values-section .ontario-about-ring--inner {
	inset: 18px;
	background: rgba(36, 36, 36, 0.85);
	border: 1px solid rgba(255, 255, 255, 0.12);
}
.ontario-about-values-section .ontario-about-circle-text {
	position: relative;
	z-index: 1;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
	color: rgba(255, 255, 255, 0.98);
	letter-spacing: 0.02em;
}
.ontario-about-values-section .ontario-about-circle-label--expertise .ontario-about-circle-text {
	color: var(--de-teal-light, #80C8BF);
}
.ontario-about-values-section .ontario-about-circle-label--vision .ontario-about-circle-text {
	color: var(--de-gold-muted, #C3B28B);
}
.ontario-about-values-section .ontario-about-circle-content {
	position: relative;
	width: 100%;
	max-width: 520px;
	padding-top: 0;
	text-align: left;
}
.ontario-about-values-section .ontario-about-circle-content p {
	margin: 0;
	font-size: 17px;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.9);
}
.ontario-about-values-section .ontario-about-highlight {
	color: var(--de-teal-light, #80C8BF);
	font-weight: 600;
}
@media (max-width: 991.98px) {
	.ontario-about-values-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.ontario-about-values-section .ontario-about-circle-label {
		width: 150px;
		height: 150px;
		margin-bottom: 24px;
	}
	.ontario-about-values-section .ontario-about-ring--1 { inset: -6px; }
	.ontario-about-values-section .ontario-about-ring--2 { inset: 8px; }
	.ontario-about-values-section .ontario-about-ring--3 { inset: 22px; }
	.ontario-about-values-section .ontario-about-ring--inner { inset: 36px; }
	.ontario-about-values-card-inner {
		padding: 32px 24px 36px;
	}
	.ontario-about-values-section .ontario-about-circle-content p {
		font-size: 16px;
	}
	.ontario-about-values-section .ontario-about-circle-content {
		text-align: center;
	}
}
@media (max-width: 575.98px) {
	.ontario-about-values-section .ontario-about-circle-label {
		width: 130px;
		height: 130px;
		margin-bottom: 20px;
	}
	.ontario-about-values-section .ontario-about-ring--inner { inset: 28px; }
	.ontario-about-values-section .ontario-about-circle-text {
		font-size: 1.1rem;
	}
	.ontario-about-values-section .ontario-about-circle-content p {
		font-size: 15px;
	}
	.ontario-about-values-card-inner {
		padding: 28px 20px 32px;
	}
}

/* ========== Services section – new design with icons from assets/images/icons ========== */
/* Clear, dark background so service list is always visible (no white on right) */
.ontario-services-new.orbia-service_one {
	background-color: var(--de-charcoal, #242424);
	background-size: cover;
	background-position: center;
}
.ontario-services-new.orbia-service_one.bg_cover::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background: linear-gradient(135deg, rgba(36, 36, 36, 0.92) 0%, rgba(66, 57, 60, 0.88) 50%, rgba(36, 36, 36, 0.92) 100%);
}
.ontario-services-new .container,
.ontario-services-new .container-fluid.services-six-wrapper {
	position: relative;
	z-index: 1;
}
.ontario-services-new .ontario-services-grid {
	gap: 28px;
}
.ontario-services-new .orbia-service-card.ontario-service-card {
	border-radius: 20px;
	padding: 32px 28px 36px;
	border: 1px solid rgba(255, 255, 255, 0.25);
	transition: border-color 0.3s ease, background-color 0.3s ease, transform 0.25s ease;
}
.ontario-services-new .orbia-service-card.ontario-service-card:hover,
.ontario-services-new .orbia-service-card.ontario-service-card.item-active {
	border-color: rgba(255, 255, 255, 0.4);
	background-color: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(40px);
	transform: translateY(-4px);
}
.ontario-services-new .ontario-service-icon {
	width: 122px;
	height: 122px;
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 50%;
	padding: 10px;
}
.ontario-services-new .ontario-service-icon img,
.orbia-service_one .services-grid-six .orbia-service-card .content .icon img {
	width: 90px;
	height: auto;
	object-fit: contain;
}
.ontario-services-new .orbia-service-card .content .title {
	font-size: 20px;
	line-height: 1.35;
	margin-bottom: 14px;
}
.ontario-services-new .orbia-service-card .content .title a:hover {
	color: var(--de-gold-muted);
}
.ontario-services-new .orbia-service-card .content p {
	font-size: 14px;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.82);
}
@media (max-width: 991px) {
	.ontario-services-new .ontario-service-icon {
		width: 88px;
		height: 88px;
		padding: 14px;
		margin-bottom: 18px;
	}
	.ontario-services-new .orbia-service-card .content .title {
		font-size: 18px;
	}
}

/* ========== Partnerships & Success Stories (Projects section intro) ========== */
/* Decorative shape: upper area only so it doesn't overlap the animation logos */
.ontario-partnerships-success-section.orbia-project_one .shape.ontario-partnerships-shape {
	top: 40px;
	bottom: auto;
	left: 0;
	max-height: 280px;
}
.ontario-partnerships-success-section.orbia-project_one .shape.ontario-partnerships-shape img {
	max-height: 100%;
	width: auto;
	object-fit: contain;
	opacity: 0.45;
}
@media (max-width: 1199.98px) {
	.ontario-partnerships-success-section.orbia-project_one .shape.ontario-partnerships-shape {
		display: none;
	}
}
/* Intro block: ensure text reads well above the decorative shape */
.ontario-partnerships-success-section.orbia-project_one .projects-section-intro.ontario-partnerships-intro {
	position: relative;
	z-index: 1;
}
.ontario-partnerships-success-section.orbia-project_one .projects-section-intro.ontario-partnerships-intro .sub-title {
	color: var(--de-teal);
	font-weight: 600;
	letter-spacing: 0.04em;
}
.ontario-partnerships-success-section.orbia-project_one .projects-section-intro.ontario-partnerships-intro h2 {
	color: var(--heading-color);
}
/* Intro paragraph: stronger contrast so it stays readable over the shape */
.ontario-partnerships-success-section.orbia-project_one .projects-section-intro.ontario-partnerships-intro p {
	color: #374151;
	font-size: 17px;
	line-height: 1.65;
	font-weight: 400;
}
@media (max-width: 767.98px) {
	.ontario-partnerships-success-section.orbia-project_one .projects-section-intro.ontario-partnerships-intro p {
		font-size: 16px;
	}
}
.ontario-intro-icons {
	display: flex;
	flex-wrap: wrap;
	gap: 20px 28px;
	margin-top: 28px;
	align-items: center;
}
.ontario-intro-icon-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	min-width: 64px;
	transition: transform 0.25s ease;
}
.ontario-intro-icon-item:hover {
	transform: translateY(-4px);
}
.ontario-intro-icon-item img {
	width: 48px;
	height: 48px;
	object-fit: contain;
	display: block;
}
/* Icon labels: darker so they stay readable (including over the shape) */
.ontario-intro-icon-item span {
	font-size: 13px;
	font-weight: 600;
	color: #1f2937;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	line-height: 1.2;
}
.ontario-partnerships-success-section .ontario-intro-icon-item span {
	color: #1f2937;
}
.ontario-partnerships-intro.text-xl-start .ontario-intro-icons {
	justify-content: flex-start;
}
.ontario-partnerships-intro.text-center .ontario-intro-icons {
	justify-content: center;
}
@media (max-width: 1199.98px) {
	.ontario-intro-icons { justify-content: center; margin-top: 24px; gap: 16px 24px; }
	.ontario-intro-icon-item img { width: 42px; height: 42px; }
	.ontario-intro-icon-item span { font-size: 12px; }
}

/* ========== Partnerships list (shared) ========== */
.ontario-partnerships-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	max-width: 900px;
	margin: 0 auto;
}
.ontario-partnerships-success-section .ontario-partnerships-inline {
	max-width: 100%;
	margin-top: 0;
}
.ontario-partnerships-success-section .ontario-partnership-item {
	background: var(--white-color);
	border: 1px solid var(--border-color);
	border-radius: 16px;
	margin-bottom: 20px;
	padding: 28px 24px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
}
.ontario-partnerships-success-section .ontario-partnership-item:last-child {
	margin-bottom: 0;
}
.ontario-partnerships-success-section .ontario-partnership-item:hover {
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

/* Combined Partnerships & Success Stories – full width one per line + animation */
.ontario-combined-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	max-width: 900px;
	margin: 0 auto;
}
.ontario-combined-cards-fullwidth {
	max-width: 100%;
	gap: 28px;
}
.ontario-combined-card {
	background: var(--white-color);
	border: 1px solid var(--border-color);
	border-radius: 20px;
	padding: 28px 32px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.35s ease;
	overflow: hidden;
}
.ontario-combined-card:hover {
	border-color: var(--de-gold, var(--primary-color));
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}
.ontario-combined-card-inner {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 20px;
}
@media (min-width: 768px) {
	.ontario-combined-card-inner {
		flex-direction: row;
		align-items: center;
		gap: 32px;
	}
}
.ontario-combined-card-logo {
	flex-shrink: 0;
	margin-bottom: 0;
}
.ontario-combined-card-inner .ontario-combined-card-logo {
	margin-bottom: 0;
}
.ontario-combined-card-logo img {
	max-height: 72px;
	width: auto;
	max-width: 220px;
	object-fit: contain;
	vertical-align: middle;
}
.ontario-combined-card-body {
	flex: 1;
	min-width: 0;
}
.ontario-combined-card-title {
	font-size: 22px;
	font-weight: 600;
	color: var(--heading-color);
	margin-bottom: 16px;
	line-height: 1.35;
	font-family: var(--heading-font);
}
.ontario-combined-card-excerpt {
	margin-bottom: 20px;
}
.ontario-combined-card-excerpt p {
	margin: 0;
	font-size: 15px;
	line-height: 1.65;
	color: var(--text-color);
}
.ontario-combined-card-link {
	font-size: 15px;
	font-weight: 600;
	color: var(--de-gold, var(--primary-color));
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: color 0.2s ease, gap 0.2s ease;
}
.ontario-combined-card-link:hover {
	color: var(--de-teal, var(--secondary-color));
	gap: 12px;
}
.ontario-combined-card-link i {
	font-size: 12px;
}
/* Staggered entrance: when AOS adds .aos-animate, card is fully visible */
.ontario-combined-cards-fullwidth .ontario-combined-card.aos-animate:hover {
	transform: translateY(-4px);
}
@media (max-width: 767.98px) {
	.ontario-combined-card-title { font-size: 18px; }
	.ontario-combined-cards,
	.ontario-combined-cards-fullwidth { gap: 20px; }
	.ontario-combined-card { padding: 24px 20px; }
}

/* ========== Success Stories page (dedicated): clear contrast, theme colors, no CTA link ========== */
.ontario-page-success-stories.ontario-partnerships-success-section {
	padding-bottom: 60px;
	background: var(--de-white);
}
.ontario-success-stories-intro {
	max-width: 820px;
	margin-bottom: 2.5rem;
}
.ontario-page-success-stories .ontario-ocil-first-label {
	color: var(--de-teal);
}
.ontario-page-success-stories .ontario-ocil-first-heading {
	color: var(--de-charcoal);
}
.ontario-success-stories-intro .ontario-success-stories-intro-head {
	margin-bottom: 1.25rem;
}
/* Intro paragraph: white background + dark text for clear readability, teal accent */
.ontario-success-stories-lede.ontario-solution-lede--accent {
	border-left-color: var(--de-teal);
	background: var(--de-white);
	border: 1px solid rgba(107, 140, 129, 0.2);
	border-left-width: 4px;
	border-left-color: var(--de-teal);
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.06);
}
.ontario-success-stories-lede p {
	color: var(--de-charcoal);
	font-size: 16px;
	line-height: 1.75;
}
@media (min-width: 768px) {
	.ontario-success-stories-lede p {
		font-size: 17px;
		line-height: 1.8;
	}
}
/* Icon row: white circles (teal border), larger icons, label below – theme colors */
.ontario-success-stories-icons {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.5rem 2rem;
	margin-top: 1.75rem;
}
.ontario-success-stories-icons .ontario-intro-icon-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 76px;
	position: relative;
	padding-top: 72px;
}
.ontario-success-stories-icons .ontario-intro-icon-item::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: var(--de-white);
	border: 2px solid var(--de-teal);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.ontario-success-stories-icons .ontario-intro-icon-item:hover::before {
	border-color: var(--de-gold-muted);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}
/* Icon slot: same position for uploaded images and Elementor library (svg/i) */
.ontario-success-stories-icons .ontario-intro-icon-item > img {
	position: absolute;
	top: 14px;
	left: 50%;
	transform: translateX(-50%);
	width: 44px;
	height: 44px;
	object-fit: contain;
	z-index: 1;
}
.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el {
	position: absolute;
	top: 14px;
	left: 50%;
	transform: translateX(-50%);
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
	box-sizing: border-box;
	pointer-events: none;
}
.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el img {
	position: static;
	transform: none;
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}
.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el svg {
	width: 100% !important;
	height: 100% !important;
	max-width: 100%;
	max-height: 100%;
	display: block;
	flex-shrink: 0;
}
/* Teal tint for icons that use currentColor (many Elementor / FA SVGs) */
.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el .elementor-icon,
.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el > svg {
	color: var(--de-teal);
}
.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el i {
	font-size: 1.75rem;
	line-height: 1;
	color: var(--de-teal);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.ontario-success-stories-icons .ontario-intro-icon-item span {
	font-size: 11px;
	font-weight: 600;
	color: var(--de-charcoal);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	text-align: center;
	line-height: 1.3;
}
/* Story blocks: Solutions-inspired (logo box + lede, decos, number badge) */
.ontario-success-stories-cards {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
	max-width: 100%;
	margin: 0 auto;
	position: relative;
}
.ontario-story-block {
	position: relative;
	padding: 0.2rem 0;
}
.ontario-story-block .row {
	position: relative;
	z-index: 1;
}
/* Logo column: vertical bar connects number and logo */
.ontario-story-block-logo-col {
	border-left: 4px solid var(--de-teal);
	padding-left: 1.25rem;
}
.ontario-story-block-logo-col--right {
	border-left: none;
	border-right: 4px solid var(--de-teal);
	padding-left: 0;
	padding-right: 1.25rem;
}
.ontario-story-block-num {
	display: block;
	width: 100%;
	font-size: 18px;
	font-weight: 800;
	color: var(--de-teal);
	line-height: 1;
	padding-bottom: 8px;
	border-bottom: 3px solid var(--de-gold);
	margin-bottom: 1.25rem;
	letter-spacing: 0.02em;
}
.ontario-story-block-num--right {
	text-align: right;
}
.ontario-story-block-logo-wrap {
	background: var(--de-white);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
	border: 2px solid rgba(107, 140, 129, 0.35);
	padding: 1.25rem 1.5rem;
	max-width: 280px;
}
.ontario-story-block-logo-wrap--right {
	margin-left: auto;
	margin-right: 0;
}
.ontario-story-block-logo-wrap img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: contain;
	max-height: 80px;
}
.ontario-story-block-lede {
	padding: 1.5rem 1.5rem 1.5rem 1.75rem;
	background: var(--de-white);
	border: 1px solid rgba(107, 140, 129, 0.18);
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	border-left: 4px solid var(--de-teal);
}
.ontario-story-block--2 .ontario-story-block-lede {
	border-left: none;
	border-right: 4px solid var(--de-teal);
	padding-left: 1.5rem;
	padding-right: 1.75rem;
}
.ontario-story-block-title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--de-charcoal);
	margin: 0 0 1rem;
	font-family: var(--heading-font);
	padding-bottom: 8px;
	border-bottom: 2px solid var(--de-gold);
	display: inline-block;
	margin-bottom: 1rem;
}
.ontario-story-block-excerpt p {
	margin: 0;
	font-size: 15px;
	line-height: 1.75;
	color: var(--de-charcoal);
}
/* Read more/less: animated open/close */
.ontario-story-block-excerpt-wrap {
	position: relative;
	overflow: hidden;
	transition: max-height 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}
.ontario-story-block-excerpt-wrap::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2.5em;
	background: linear-gradient(transparent, var(--de-white));
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.3s ease;
}
.ontario-story-block-excerpt-wrap.is-collapsed {
	max-height: 6.5em;
}
.ontario-story-block-excerpt-wrap.is-collapsed::after {
	opacity: 1;
}
.ontario-story-block-excerpt-wrap:not(.is-collapsed) {
	max-height: 120em;
}
.ontario-story-block-excerpt-wrap:not(.is-collapsed)::after {
	opacity: 0;
}
/* Read more / Read less button */
.ontario-story-block-toggle {
	display: inline-block;
	margin-top: 0.75rem;
	padding: 0.35em 0;
	font-size: 15px;
	font-weight: 600;
	color: var(--de-teal);
	background: none;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: color 0.2s ease;
}
.ontario-story-block-toggle:hover {
	color: var(--de-charcoal);
}
@media (min-width: 768px) {
	.ontario-story-block-lede {
		padding: 1.75rem 1.75rem 1.75rem 2rem;
	}
	.ontario-story-block--2 .ontario-story-block-lede {
		padding-right: 2rem;
		padding-left: 1.75rem;
	}
	.ontario-story-block-title {
		font-size: 1.375rem;
	}
	.ontario-story-block-excerpt p {
		font-size: 16px;
		line-height: 1.8;
	}
}
@media (max-width: 575.98px) {
	.ontario-success-stories-icons { gap: 1rem 1.5rem; }
	.ontario-success-stories-icons .ontario-intro-icon-item { width: 64px; padding-top: 60px; }
	.ontario-success-stories-icons .ontario-intro-icon-item::before { width: 60px; height: 60px; }
	.ontario-success-stories-icons .ontario-intro-icon-item > img { width: 36px; height: 36px; top: 12px; }
	.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el { width: 36px; height: 36px; top: 12px; }
	.ontario-success-stories-icons .ontario-intro-icon-item .ontario-intro-icon-el i { font-size: 1.35rem; }
	.ontario-success-stories-icons .ontario-intro-icon-item span { font-size: 10px; }
	.ontario-story-block { padding: 1.5rem 0; }
	.ontario-story-block-lede { padding: 1.25rem 1.25rem 1.25rem 1.5rem; }
	.ontario-story-block--2 .ontario-story-block-lede { padding-right: 1.5rem; padding-left: 1.25rem; }
	.ontario-story-block-title { font-size: 1.1rem; }
	.ontario-story-block-excerpt p { font-size: 14px; }
	.ontario-story-block-logo-wrap { max-width: 100%; }
}

.ontario-partnership-item {
	display: flex;
	align-items: flex-start;
	gap: 32px;
	padding: 28px 24px;
	border-bottom: 1px solid var(--border-color);
	transition: background 0.25s ease, box-shadow 0.25s ease;
}
.ontario-partnerships-section .ontario-partnership-item:last-of-type {
	border-bottom: none;
}
.ontario-partnerships-section .ontario-partnership-item:hover {
	background: rgba(255, 255, 255, 0.7);
}
.ontario-partnership-item .partnership-logo {
	flex-shrink: 0;
	width: 100px;
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--white-color);
	border-radius: 16px;
	padding: 16px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}
.ontario-partnership-item .partnership-logo img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}
.ontario-partnership-item .partnership-content {
	flex: 1;
	min-width: 0;
}
.ontario-partnership-item .partnership-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--de-gold);
	text-transform: uppercase;
	letter-spacing: 0.02em;
	margin-bottom: 10px;
	font-family: var(--heading-font);
}
.ontario-partnership-item .partnership-content p {
	font-size: 15px;
	line-height: 1.65;
	color: var(--text-color);
	margin: 0;
}
.ontario-success-stories-strip {
	text-align: center;
	padding: 48px 24px;
	background: var(--white-color);
	border-radius: 20px;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
	border: 1px solid var(--border-color);
}
.ontario-success-stories-strip .strip-heading {
	font-size: 16px;
	font-weight: 600;
	color: var(--de-gold);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 28px;
}
.ontario-success-stories-strip .strip-logos {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 48px 56px;
}
.ontario-success-stories-strip .strip-logo-item {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 56px;
	transition: opacity 0.25s ease;
}
.ontario-success-stories-strip .strip-logo-item:hover {
	opacity: 0.85;
}
.ontario-success-stories-strip .strip-logo-item img {
	max-height: 100%;
	width: auto;
	max-width: 140px;
	object-fit: contain;
}
.ontario-success-stories-strip .strip-logo-placeholder {
	width: 120px;
	background: var(--gray-color);
	border-radius: 8px;
	color: var(--text-color);
	font-size: 14px;
	font-weight: 500;
}
@media (max-width: 767px) {
	.ontario-partnership-item {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 20px;
		padding: 24px 16px;
	}
	.ontario-partnership-item .partnership-logo {
		width: 80px;
		height: 80px;
		padding: 12px;
	}
	.ontario-success-stories-strip .strip-logos {
		gap: 32px 24px;
	}
}

/* ========== Hero Icons Circle – multiple icons with animation ========== */
.ontario-hero-icons-wrap.hero-image {
	position: absolute;
	top: 50%;
	right: 12%;
	transform: translateY(-50%);
	width: 100%;
	max-width: 620px;
	aspect-ratio: 1;
}
.ontario-hero-icons-wrap .hero-icons-circle {
	position: relative;
	width: 100%;
	height: 100%;
	/* Inset so content sits centered with gap from circle edge */
	box-sizing: border-box;
	padding: 8%;
}
.ontario-hero-icons-wrap .hero-icon-item {
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	transform: translate(-50%, -50%);
}
.ontario-hero-icons-wrap .hero-icon-item img {
	width: 130px;
	height: 130px;
	object-fit: contain;
	display: block;
}

/* Hero character (center) – flying / floating animation */
.ontario-hero-icons-wrap .hero-character-wrap {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
	pointer-events: none;
}
.ontario-hero-icons-wrap .hero-character-wrap img {
	width: 250px;
	height: auto;
	object-fit: contain;
	display: block;
	filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.12));
}
@keyframes hero-character-fly {
	0%, 100% {
		transform: translate(-50%, -50%) translateY(0) rotate(-2deg);
	}
	25% {
		transform: translate(-50%, -50%) translateY(-12px) translateX(4px) rotate(1deg);
	}
	50% {
		transform: translate(-50%, -50%) translateY(-6px) translateX(-3px) rotate(2deg);
	}
	75% {
		transform: translate(-50%, -50%) translateY(-14px) translateX(2px) rotate(-1deg);
	}
}
.ontario-hero-icons-wrap .hero-character-wrap {
	animation: hero-character-fly 5s ease-in-out infinite;
}

/* Orbital positions: symmetric circle, more gap from center and between icons */
.ontario-hero-icons-wrap .hero-icon-pos-1 { left: 50%;   top: 6%; }   /* top */
.ontario-hero-icons-wrap .hero-icon-pos-2 { left: 80%;   top: 20%; }  /* top-right */
.ontario-hero-icons-wrap .hero-icon-pos-3 { left: 80%;   top: 80%; }  /* bottom-right */
.ontario-hero-icons-wrap .hero-icon-pos-4 { left: 50%;   top: 94%; }  /* bottom */
.ontario-hero-icons-wrap .hero-icon-pos-5 { left: 20%;   top: 80%; }  /* bottom-left */
.ontario-hero-icons-wrap .hero-icon-pos-6 { left: 20%;   top: 20%; }  /* top-left */

/* Staggered float + gentle scale animation */
@keyframes hero-icon-float {
	0%, 100% { transform: translate(-50%, -50%) translateY(0) scale(1); opacity: 0.92; }
	50%     { transform: translate(-50%, -50%) translateY(-10px) scale(1.08); opacity: 1; }
}
.ontario-hero-icons-wrap .hero-icon-item {
	animation: hero-icon-float 4s ease-in-out infinite;
}
.ontario-hero-icons-wrap .hero-icon-pos-1 { animation-delay: 0.4s; }
.ontario-hero-icons-wrap .hero-icon-pos-2 { animation-delay: 0.8s; }
.ontario-hero-icons-wrap .hero-icon-pos-3 { animation-delay: 1.2s; }
.ontario-hero-icons-wrap .hero-icon-pos-4 { animation-delay: 1.6s; }
.ontario-hero-icons-wrap .hero-icon-pos-5 { animation-delay: 2s; }
.ontario-hero-icons-wrap .hero-icon-pos-6 { animation-delay: 2.4s; }

@media (max-width: 1650px) {
	.ontario-hero-icons-wrap.hero-image { max-width: 560px; }
	.ontario-hero-icons-wrap .hero-icon-item img { width: 100px; height: 100px; }
	.ontario-hero-icons-wrap .hero-character-wrap img { width: 200px; }
}
@media screen and (max-width: 1199.98px) {
	.ontario-hero-icons-wrap.hero-image { display: none; }
}

/* ========== Choose Section – compact, same width/radius as Service section ========== */
.ontario-choose-compact.orbia-choose_one {
	margin: 0 30px;
}
.ontario-choose-compact .orbia-choose-wrapper {
	padding: 48px 24px;
	border-radius: 30px;
	overflow: hidden;
	background-color: var(--de-charcoal, var(--heading-color));
}
@media (max-width: 1650px) {
	.ontario-choose-compact.orbia-choose_one { margin: 0 15px; }
	.ontario-choose-compact .orbia-choose-wrapper { border-radius: 15px; }
}
@media screen and (max-width: 1199.98px) {
	.ontario-choose-compact.orbia-choose_one { margin: 0; }
	.ontario-choose-compact .orbia-choose-wrapper { border-radius: 0; }
}
.ontario-choose-compact .section-title .sub-title {
	color: var(--de-gold-muted);
	font-weight: 600;
	letter-spacing: 0.04em;
}
.ontario-choose-compact .section-title h2 {
	color: var(--de-white);
}
.ontario-choose-compact .section-title p {
	color: rgba(255, 255, 255, 0.88);
	font-size: 16px;
	line-height: 1.6;
}
.ontario-choose-features {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px 32px;
	margin-top: 36px;
}
.ontario-choose-feature {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	padding: 20px 24px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 16px;
	transition: background 0.25s ease, border-color 0.25s ease;
}
.ontario-choose-feature:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.2);
}
.ontario-choose-feature-icon {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 14px;
	padding: 12px;
}
.ontario-choose-feature-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.ontario-choose-feature-content h5 {
	font-size: 17px;
	font-weight: 600;
	color: var(--de-white);
	margin-bottom: 6px;
	font-family: var(--heading-font);
}
.ontario-choose-feature-content p {
	font-size: 14px;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
}
@media (max-width: 767.98px) {
	.ontario-choose-compact .orbia-choose-wrapper { padding: 36px 20px; }
	.ontario-choose-features { grid-template-columns: 1fr; gap: 16px; margin-top: 28px; }
	.ontario-choose-feature { padding: 16px 20px; gap: 16px; }
	.ontario-choose-feature-icon { width: 48px; height: 48px; padding: 10px; }
	.ontario-choose-feature-content h5 { font-size: 16px; }
}

/* ========== Process Section – same width/radius as Service section ========== */
.ontario-process-creative.orbia-process_one {
	position: relative;
	margin: 0 30px;
	border-radius: 30px;
	overflow: hidden;
	background-color: var(--de-charcoal);
}
@media (max-width: 1650px) {
	.ontario-process-creative.orbia-process_one { margin: 0 15px; border-radius: 15px; }
}
@media screen and (max-width: 1199.98px) {
	.ontario-process-creative.orbia-process_one { margin: 0; border-radius: 0; }
}
.ontario-process-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-size: cover;
	background-position: center;
}
.ontario-process-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	/* Dark overlay from design-elements – not too light; keeps text readable */
	background: linear-gradient(165deg, rgba(36, 36, 36, 0.88) 0%, rgba(45, 45, 45, 0.85) 50%, rgba(36, 36, 36, 0.88) 100%);
	z-index: 1;
}
/* Elementor Step Process widget uses its own overlay div – hide ::after to avoid double overlay */
.ontario-step-process-wrap .ontario-process-bg::after {
	display: none;
}
/* Decorative shapes (design-elements circles) */
.ontario-process-shape {
	position: absolute;
	z-index: 1;
	pointer-events: none;
	opacity: 0.2;
}
.ontario-process-shape img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.ontario-process-shape--left {
	top: 50%;
	left: -40px;
	width: 180px;
	height: 180px;
	transform: translateY(-50%);
}
.ontario-process-shape--right {
	top: 50%;
	right: -40px;
	width: 200px;
	height: 200px;
	transform: translateY(-50%);
}
@media (max-width: 1199.98px) {
	.ontario-process-shape { display: none; }
}
.ontario-process-creative .section-title .sub-title {
	color: var(--de-teal-light);
	font-weight: 600;
	letter-spacing: 0.04em;
}
.ontario-process-creative .section-title h2 {
	color: #ffffff;
	font-weight: 700;
}
.ontario-process-creative .section-title p {
	color: rgba(255, 255, 255, 0.88);
	font-size: 1.05rem;
	line-height: 1.6;
}
.ontario-process-steps {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-wrap: nowrap;
	gap: 0;
	max-width: 1200px;
	margin: 0 auto;
	padding-top: 20px;
}
.ontario-process-step {
	position: relative;
	flex: 1 1 0;
	min-width: 0;
	max-width: 280px;
	text-align: center;
	padding: 24px 16px;
}
.ontario-process-step-number {
	position: absolute;
	top: -68px;
	left: 50%;
	transform: translateX(-50%);
	font-size: clamp(6rem, 18vw, 11rem);
	font-weight: 800;
	line-height: 1;
	color: rgba(255, 255, 255, 0.2);
	pointer-events: none;
	z-index: 0;
	font-family: var(--heading-font);
}
.ontario-process-step-bubble {
	position: relative;
	z-index: 1;
	width: 130px;
	height: 130px;
	margin: 0 auto 22px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.5) 0%, rgba(255, 255, 255, 0.15) 100%);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.6);
	border: 1px solid rgba(255, 255, 255, 0.4);
	padding: 10px;
	animation: process-bubble-float 4s ease-in-out infinite;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.ontario-process-step:nth-child(1) .ontario-process-step-bubble { animation-delay: 0s; }
.ontario-process-step:nth-child(3) .ontario-process-step-bubble { animation-delay: 0.5s; }
.ontario-process-step:nth-child(5) .ontario-process-step-bubble { animation-delay: 1s; }
.ontario-process-step-bubble:hover {
	animation-play-state: paused;
	transform: translateY(0) scale(1.05);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
@keyframes process-bubble-float {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-8px); }
}
.ontario-process-step-bubble img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: transform 0.3s ease;
}
.ontario-process-step-bubble:hover img {
	transform: scale(1.08);
}
.ontario-process-step-title {
	font-size: 20px;
	font-weight: 700;
	color: #ffffff;
	margin: 0 0 8px;
	font-family: var(--heading-font);
	transition: color 0.25s ease;
}
.ontario-process-step:hover .ontario-process-step-title {
	color: var(--de-teal-light);
}
.ontario-process-step-desc {
	font-size: 14px;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
}
.ontario-process-connector {
	position: relative;
	flex: 0 0 90px;
	width: 90px;
	min-height: 160px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding-top: 70px;
}
.ontario-process-connector-line {
	display: block;
	width: 100%;
	height: 2px;
	min-width: 50px;
	background: repeating-linear-gradient(90deg, var(--de-teal-light) 0, var(--de-teal-light) 6px, transparent 6px, transparent 12px);
	opacity: 0.8;
	animation: process-connector-pulse 2s ease-in-out infinite;
}
@keyframes process-connector-pulse {
	0%, 100% { opacity: 0.6; }
	50% { opacity: 0.9; }
}
.ontario-process-connector-label {
	position: absolute;
	top: 8px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 15px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.9);
	text-align: center;
	white-space: nowrap;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	line-height: 1.3;
	max-width: 213px;
}
@media (min-width: 992px) and (max-width: 1400px) {
	.ontario-process-connector-label {
		font-size: 13px;
		max-width: 180px;
		white-space: normal;
	}
}
/* Tablet: keep horizontal but allow slight shrink */
@media (max-width: 1199.98px) {
	.ontario-process-steps { max-width: 100%; padding: 0 15px; }
	.ontario-process-step { max-width: 240px; padding: 20px 12px; }
	.ontario-process-connector { flex: 0 0 70px; width: 70px; }
	.ontario-process-step-bubble { width: 110px; height: 110px; margin-bottom: 18px; padding: 10px; }
	.ontario-process-step-number { top: -52px; font-size: clamp(4.5rem, 14vw, 7rem); }
}
/* Mobile: vertical stack – single column, clear flow */
@media (max-width: 991.98px) {
	.ontario-process-steps {
		flex-direction: column;
		align-items: center;
		flex-wrap: nowrap;
		gap: 0;
		max-width: 400px;
		margin-left: auto;
		margin-right: auto;
		padding: 0;
	}
	.ontario-process-step {
		width: 100%;
		max-width: 100%;
		min-width: 0;
		flex: none;
		padding: 20px 16px;
	}
	.ontario-process-connector {
		width: 100%;
		flex: none;
		min-height: 44px;
		padding-top: 0;
		display: flex;
		flex-direction: column-reverse;
		align-items: center;
		justify-content: center;
		gap: 6px;
	}
	.ontario-process-connector-line {
		width: 2px;
		height: 18px;
		min-width: 0;
		background: repeating-linear-gradient(180deg, var(--de-teal-light) 0, var(--de-teal-light) 6px, transparent 6px, transparent 12px);
	}
	.ontario-process-connector-label {
		position: static;
		transform: none;
		margin: 0;
		font-size: 12px;
		max-width: none;
	}
	.ontario-process-step-number {
		top: -44px;
		font-size: clamp(3.5rem, 20vw, 5.5rem);
	}
	.ontario-process-step-bubble {
		width: 100px;
		height: 100px;
		margin-bottom: 16px;
		padding: 10px;
	}
}
@media (max-width: 575.98px) {
	.ontario-process-step-bubble { width: 90px; height: 90px; padding: 10px; }
	.ontario-process-step-title { font-size: 18px; }
	.ontario-process-step-number { top: -38px; font-size: clamp(3rem, 24vw, 5rem); }
}

/* Process section – Partners / Trusted by strip */
.ontario-process-partners {
	margin-top: 10px;
	padding-top: 30px;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	text-align: center;
}
.ontario-process-partners-label {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.6);
	margin-bottom: 24px;
}
.ontario-process-partners-logos {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 32px 48px;
}
.ontario-process-partner-logo {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	opacity: 0.85;
	transition: opacity 0.25s ease;
}
.ontario-process-partner-logo:hover {
	opacity: 1;
}
.ontario-process-partner-logo img {
	max-height: 100%;
	width: auto;
	max-width: 120px;
	object-fit: contain;
	filter: brightness(0) invert(1);
}
.ontario-process-partner-logo--text span {
	font-size: 14px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.9);
	letter-spacing: 0.02em;
}
@media (max-width: 575.98px) {
	.ontario-process-partners { margin-top: 40px; padding-top: 32px; }
	.ontario-process-partners-logos { gap: 24px 32px; }
	.ontario-process-partner-logo { height: 32px; }
}

/* ========== Footer – compact, design elements (same width/radius as Service) ========== */
.main-footer.ontario-footer-modern {
	padding: 0;
	background: transparent;
}
.main-footer.ontario-footer-modern .ontario-footer-inner {
	margin: 0 30px 40px;
	border-radius: 30px;
	overflow: hidden;
	background: var(--de-charcoal);
}
@media (max-width: 1650px) {
	.main-footer.ontario-footer-modern .ontario-footer-inner { margin: 0 15px 32px; border-radius: 15px; }
}
@media screen and (max-width: 1199.98px) {
	.main-footer.ontario-footer-modern .ontario-footer-inner { margin: 0 0 24px; border-radius: 0; }
}
/* Newsletter strip – design-elements background + overlay */
.main-footer.ontario-footer-modern .ontario-footer-newsletter {
    position: relative;
    background-size: cover;
    background-position: bottom center;
}
.main-footer.ontario-footer-modern .ontario-footer-newsletter::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(36, 36, 36, 0.88) 0%, rgba(43, 43, 43, 0.9) 100%);
	z-index: 0;
}
.main-footer.ontario-footer-modern .ontario-footer-newsletter .container {
	position: relative;
	z-index: 1;
}
.main-footer.ontario-footer-modern .footer-newsletter-wrapper .section-title .sub-title {
	color: var(--de-gold-muted);
}
.main-footer.ontario-footer-modern .footer-newsletter-wrapper .orbia-avatar-box .avatar-list h6 {
	color: rgba(255, 255, 255, 0.9);
}
/* Footer bottom – charcoal, teal/gold accents */
.main-footer.ontario-footer-modern .footer-bottom-wrapper.ontario-footer-bottom {
	background: var(--de-charcoal);
	background-image: none;
	border-radius: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.main-footer.ontario-footer-modern .footer-widget .widget-title {
	color: var(--de-white);
	font-size: 17px;
	font-weight: 600;
	margin-bottom: 16px;
}
.main-footer.ontario-footer-modern .footer-widget .line-wrap span {
	background: var(--de-gold);
}
.main-footer.ontario-footer-modern .footer-widget .widget-content > p,
.main-footer.ontario-footer-modern .footer-widget .widget-content .info p,
.main-footer.ontario-footer-modern .footer-widget .widget-content .info a {
	color: rgba(255, 255, 255, 0.82);
}
.main-footer.ontario-footer-modern .footer-widget .widget-content .widget-nav li a {
	color: rgba(255, 255, 255, 0.82);
}
.main-footer.ontario-footer-modern .footer-widget .widget-content .widget-nav li a:hover {
	color: var(--de-gold-muted);
}
.main-footer.ontario-footer-modern .footer-widget .widget-content .social-box a {
	border-color: rgba(255, 255, 255, 0.2);
	color: rgba(255, 255, 255, 0.9);
}
.main-footer.ontario-footer-modern .footer-widget .widget-content .social-box a:hover {
	border-color: var(--de-gold);
	color: var(--de-gold);
}
.main-footer.ontario-footer-modern .footer-widget.footer-about-widget .footer-logo {
	margin-bottom: 20px;
}
.main-footer.ontario-footer-modern .footer-widget .widget-content .orbia-info-box.style-two .icon {
	color: var(--de-teal-light);
}
.main-footer.ontario-footer-modern .footer-contact-social .footer-contact-social-label {
	display: block;
	color: rgba(255, 255, 255, 0.82);
	font-size: 14px;
	margin-bottom: 10px;
}
.main-footer.ontario-footer-modern .footer-contact-social .social-box {
	margin-top: 0;
}
.main-footer.ontario-footer-modern .copyright-area {
	padding-top: 24px;
	padding-bottom: 24px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.main-footer.ontario-footer-modern .copyright-area .copyright-text p,
.main-footer.ontario-footer-modern .copyright-area .copyright-link a {
	color: rgba(255, 255, 255, 0.75);
	font-size: 14px;
}
.main-footer.ontario-footer-modern .copyright-area .copyright-link a:hover {
	color: var(--de-gold-muted);
}
.main-footer.ontario-footer-modern .footer-widget.mb-40 {
	margin-bottom: 28px;
}
@media (max-width: 767.98px) {
	.main-footer.ontario-footer-modern .ontario-footer-newsletter .footer-newsletter-wrapper { padding-top: 36px !important; padding-bottom: 36px !important; }
	.main-footer.ontario-footer-modern .footer-widget-area.ontario-footer-widget-area { padding-top: 40px !important; padding-bottom: 32px !important; }
	.main-footer.ontario-footer-modern .footer-widget.mb-40 { margin-bottom: 24px; }
}

/* Publications page: hero with gradient overlay (brand colors) */
.publications-hero {
	position: relative;
	background-size: cover;
	background-position: center;
}
/* Hero gradient overlay (used when Page Hero > Background overlay is enabled) */
.publications-hero-gradient, .page-hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(135deg, rgb(19 37 3 / 26%) 0%, rgb(12 26 21 / 43%) 45%, rgb(0 0 0 / 0%) 100%);
    pointer-events: none;
}
.publications-hero-inner,
.page-hero-inner {
	position: relative;
	z-index: 1;
}

/* Page hero parallax: fixed background for sections with .page-hero.ocil-hero.bg_cover or .page-hero.bg_cover */
.page-hero.bg_cover {
	background-attachment: fixed;
	background-position: center center;
	background-size: cover;
}
@media (max-width: 1023px) {
	.page-hero.bg_cover {
		background-attachment: scroll;
	}
}

/* ========== Publications page – YouTube playlist section ========== */
/* Same content width as home Service section */
.ontario-playlist-section {
	position: relative;
	overflow: hidden;
}
.ontario-playlist-width-wrap {
	position: relative;
	z-index: 3;
	max-width: 1320px;
	margin: 0 auto;
	padding-left: 100px;
	padding-right: 100px;
}
@media (max-width: 1199.98px) {
	.ontario-playlist-width-wrap {
		padding-left: 30px;
		padding-right: 30px;
	}
}
@media (max-width: 767.98px) {
	.ontario-playlist-width-wrap {
		padding-left: 15px;
		padding-right: 15px;
	}
}
/* Background: different color and pattern (no image) */
.ontario-playlist-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background: linear-gradient(160deg, #2a3f3a 0%, #1e2d29 35%, #253832 70%, #2a3f3a 100%);
	pointer-events: none;
}
.ontario-playlist-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(180deg, rgba(66, 57, 60, 0.25) 0%, transparent 40%, transparent 60%, rgba(42, 63, 58, 0.3) 100%);
	pointer-events: none;
}
/* Pattern: subtle arcs and diagonal lines */
.ontario-playlist-pattern {
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
	opacity: 0.06;
	background-image:
		radial-gradient(ellipse 120% 80% at 10% 20%, rgba(255, 255, 255, 0.15) 0%, transparent 50%),
		radial-gradient(ellipse 100% 60% at 90% 70%, rgba(255, 255, 255, 0.12) 0%, transparent 45%),
		radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.04) 0%, transparent 30%);
	background-size: 100% 100%, 100% 100%, 100% 100%;
}
.ontario-playlist-pattern::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		repeating-linear-gradient(105deg, transparent, transparent 60px, rgba(255, 255, 255, 0.02) 60px, rgba(255, 255, 255, 0.02) 61px),
		repeating-linear-gradient(15deg, transparent, transparent 80px, rgba(255, 255, 255, 0.015) 80px, rgba(255, 255, 255, 0.015) 81px);
	pointer-events: none;
}
/* Decorative arcs (CSS-only circles) */
.ontario-playlist-shape {
	position: absolute;
	z-index: 2;
	pointer-events: none;
	opacity: 0.07;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 0.2);
}
.ontario-playlist-shape--left {
	top: 25%;
	left: -80px;
	width: 220px;
	height: 220px;
}
.ontario-playlist-shape--right {
	bottom: 15%;
	right: -100px;
	width: 280px;
	height: 280px;
}
@media (max-width: 1199.98px) {
	.ontario-playlist-shape { display: none; }
}
.ontario-playlist-inner {
	position: relative;
	z-index: 1;
}
.ontario-playlist-section .section-title .sub-title {
	color: var(--de-teal-light);
	font-weight: 600;
}
.ontario-playlist-section .section-title h2 {
	color: var(--de-white);
}
/* Sidebar: playlist list */
.ontario-playlist-sidebar {
	background: rgba(255, 255, 255, 0.97);
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 8px 40px rgba(0, 0, 0, 0.25);
	border: 1px solid rgba(255, 255, 255, 0.15);
	height: 100%;
	min-height: 320px;
}
.ontario-playlist-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 20px;
	background: var(--de-charcoal);
	color: var(--de-white);
	font-size: 14px;
	font-weight: 600;
}
.ontario-playlist-count {
	color: rgba(255, 255, 255, 0.85);
	font-weight: 500;
}
.ontario-playlist-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.ontario-playlist-item {
	margin: 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.ontario-playlist-item:last-child {
	border-bottom: 0;
}
.ontario-playlist-item-link {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 12px 16px;
	text-decoration: none;
	color: var(--de-charcoal);
	transition: background 0.2s ease;
}
.ontario-playlist-item-link:hover {
	background: rgba(117, 172, 152, 0.08);
}
.ontario-playlist-item--active .ontario-playlist-item-link {
	background: rgba(117, 172, 152, 0.12);
}
.ontario-playlist-item-thumb {
	position: relative;
	flex-shrink: 0;
	width: 120px;
	aspect-ratio: 16 / 9;
	border-radius: 8px;
	overflow: hidden;
	background: #111;
}
.ontario-playlist-item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ontario-playlist-item-play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.35);
	color: var(--de-white);
	font-size: 14px;
	transition: background 0.2s ease;
}
/* YouTube-style play button on playlist thumbnails */
.ontario-playlist-item-play::before {
	content: '';
	position: absolute;
	width: 48px;
	height: 34px;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background: #e62117;
	border-radius: 10px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
	z-index: 0;
}
.ontario-playlist-item-play i {
	position: relative;
	z-index: 1;
	margin-left: 3px;
	font-size: 14px;
}
.ontario-playlist-item-link:hover .ontario-playlist-item-play {
	background: rgba(0, 0, 0, 0.45);
}
.ontario-playlist-item-link:hover .ontario-playlist-item-play::before {
	transform: translate(-50%, -50%) scale(1.08);
}
.ontario-playlist-item-info {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex: 1;
	min-width: 0;
}
.ontario-playlist-item-title {
	font-size: 14px;
	font-weight: 500;
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ontario-playlist-item-duration {
	font-size: 12px;
	color: var(--de-charcoal);
	opacity: 0.75;
	flex-shrink: 0;
}
/* Main video player */
.ontario-playlist-player-wrap {
	height: 100%;
	min-height: 320px;
}
.ontario-playlist-player {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	height: 0;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 12px 48px rgba(0, 0, 0, 0.35);
	border: 1px solid rgba(255, 255, 255, 0.1);
}
.ontario-playlist-player iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.ontario-playlist-player-caption {
	margin: 12px 0 0;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.85);
}
@media (max-width: 991.98px) {
	.ontario-playlist-row {
		align-items: flex-start;
	}
	.ontario-playlist-sidebar {
		min-height: 0;
	}
	.ontario-playlist-player-wrap {
		min-height: 0;
	}
}

/* ========== Single publication (details page) ========== */
.ontario-single-publication .ontario-publication-article {
	background: var(--de-white);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	padding: 0 0 40px;
}
.ontario-publication-featured-media {
	margin-bottom: 0;
	border-radius: 20px 20px 0 0;
	overflow: hidden;
}
.ontario-publication-featured-media .ontario-publication-featured-img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
}
.ontario-publication-featured-media--video .ontario-publication-embed-wrap {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	background: #111;
}
.ontario-publication-featured-media--video .ontario-publication-embed-wrap iframe,
.ontario-publication-featured-media--video .ontario-publication-embed-wrap .wp-block-embed iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.ontario-publication-featured-media--linkedin {
	margin-bottom: 1.5rem;
	border-radius: 16px;
	overflow: hidden;
	background: #f3f6f8;
}
.ontario-publication-linkedin-embed-wrap {
	position: relative;
	width: 100%;
	min-height: 400px;
}
.ontario-publication-linkedin-embed-wrap iframe {
	display: block;
	width: 100%;
	max-width: 100%;
	min-height: 400px;
	border: 0;
}
.ontario-publication-linkedin-after-content {
	margin-top: 2rem;
}
.ontario-publication-featured-media--pdf {
	padding: 32px 40px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.12) 0%, rgba(117, 172, 152, 0.1) 100%);
	border-radius: 20px 20px 0 0;
}
.ontario-publication-downloads-wrap {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 12px;
}
.ontario-publication-pdf-download {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 16px 28px;
	background: var(--de-charcoal);
	color: var(--de-white);
	border-radius: 12px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.25s ease, transform 0.2s ease;
}
.ontario-publication-pdf-download:hover {
	background: var(--de-teal);
	color: var(--de-white);
	transform: translateY(-2px);
}
.ontario-publication-pdf-download i {
	font-size: 24px;
}
.ontario-publication-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 20px;
	padding: 24px 40px 0;
	margin-bottom: 16px;
	font-size: 14px;
	color: var(--text-color);
}
.ontario-publication-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.ontario-publication-meta-item i {
	color: var(--de-teal);
}
.ontario-publication-meta-item + .ontario-publication-meta-item {
	border-left: 1px solid rgba(0, 0, 0, 0.18);
	padding-left: 16px;
	margin-left: 4px;
}
.ontario-publication-title {
	padding: 0 40px 24px;
	margin: 0 0 24px;
	font-size: 28px;
	line-height: 1.35;
	color: var(--de-charcoal);
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
.ontario-publication-content {
	padding: 0 40px;
	font-size: 16px;
	line-height: 1.7;
}
.ontario-publication-content p {
	margin-bottom: 1.25em;
}

.ontario-publication-content-link-wrap {
	padding: 8px 40px 0;
	margin-top: 8px;
}
.ontario-publication-content-link-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.ontario-publication-content-link-btn i {
	font-size: 14px;
	line-height: 1;
}

/* Single publication share footer */
.ontario-publication-footer {
	padding: 28px 40px 40px;
	margin-top: 32px;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}
.ontario-publication-share {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px 24px;
}
.ontario-publication-share-label {
	font-size: 15px;
	font-weight: 600;
	color: var(--de-charcoal);
}
.ontario-publication-share-list {
	display: flex;
	align-items: center;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.ontario-publication-share-list li {
	margin: 0;
}
.ontario-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: var(--de-white);
	color: var(--de-charcoal);
	text-decoration: none;
	transition: border-color 0.2s, background 0.2s, color 0.2s, transform 0.2s;
}
.ontario-share-btn:hover {
	border-color: currentColor;
	color: var(--de-white);
	transform: translateY(-2px);
}
.ontario-share-twitter:hover { background: #1da1f2; border-color: #1da1f2; color: #fff; }
.ontario-share-linkedin:hover { background: #0a66c2; border-color: #0a66c2; color: #fff; }
.ontario-share-facebook:hover { background: #1877f2; border-color: #1877f2; color: #fff; }
.ontario-share-copy {
	cursor: pointer;
	font-size: 16px;
}
.ontario-share-copy:hover { background: var(--de-teal); border-color: var(--de-teal); color: #fff; }
.ontario-share-copy.ontario-share-copied { background: var(--de-teal); border-color: var(--de-teal); color: #fff; }

/* Sidebar */
.ontario-single-publication .col-lg-4 {
	align-self: flex-start;
}
.ontario-publication-sidebar {
	background: #f5f5f5;
	border-radius: 20px;
	padding: 28px 24px;
}
.ontario-single-publication .ontario-publication-sidebar {
	position: sticky;
	top: 120px;
}
.ontario-sidebar-widget {
	margin-bottom: 28px;
}
.ontario-sidebar-widget:last-child {
	margin-bottom: 0;
}
.ontario-sidebar-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--de-charcoal);
	margin: 0 0 16px;
	padding: 0;
}
.ontario-sidebar-search {
	margin-bottom: 28px;
}
.ontario-search-form {
	display: flex;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	position: relative;
}
.ontario-search-input {
	flex: 1;
	border: 1px solid rgba(0, 0, 0, 0.08);
	padding: 14px 18px;
	font-size: 15px;
	border-radius: 12px 0 0 12px;
}
.ontario-search-btn {
	width: 52px;
	background: var(--de-charcoal);
	color: var(--de-white);
	border: none;
	border-radius: 0 12px 12px 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.25s ease;
}
.ontario-search-btn:hover {
	background: var(--de-teal);
	color: var(--de-white);
}
.ontario-sidebar-category-list,
.ontario-sidebar-recent-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.ontario-sidebar-category-list li,
.ontario-sidebar-recent-list li {
	margin: 0 0 10px;
	padding: 0;
}
.ontario-sidebar-card {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 18px;
	background: var(--de-white);
	border-radius: 12px;
	text-decoration: none;
	color: var(--de-charcoal);
	font-size: 15px;
	font-weight: 500;
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);
	transition: background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}
.ontario-sidebar-card:hover {
	background: var(--de-white);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
	color: var(--de-teal);
}
.ontario-sidebar-card i {
	flex-shrink: 0;
	font-size: 12px;
	opacity: 0.7;
}
.ontario-sidebar-card:hover i {
	opacity: 1;
}
.ontario-sidebar-card--empty {
	background: transparent;
	box-shadow: none;
	color: var(--text-color);
	font-weight: 400;
	cursor: default;
}
.ontario-sidebar-recent-card {
	align-items: center;
}
.ontario-recent-thumb {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	border-radius: 10px;
	overflow: hidden;
	background: #eee;
}
.ontario-recent-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ontario-recent-thumb--icon {
	display: flex;
	align-items: center;
	justify-content: center;
}
.ontario-recent-thumb--icon i {
	font-size: 22px;
	opacity: 0.9;
}
.ontario-recent-thumb--pdf {
	background: rgba(180, 150, 90, 0.15);
}
.ontario-recent-thumb--pdf i {
	color: var(--de-gold);
}
.ontario-recent-thumb--article {
	background: rgba(107, 140, 129, 0.12);
}
.ontario-recent-thumb--article i {
	color: var(--de-teal);
}
.ontario-recent-title {
	flex: 1;
	min-width: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	font-size: 14px;
}
@media (max-width: 991.98px) {
	.ontario-publication-meta,
	.ontario-publication-title,
	.ontario-publication-content,
	.ontario-publication-content-link-wrap {
		padding-left: 24px;
		padding-right: 24px;
	}
	.ontario-publication-sidebar {
		margin-top: 40px;
	}
}

/* Publications pagination: circular buttons (prev, 01, 02, …, next) */
.ontario-publications-pagination-wrap {
	display: flex;
	justify-content: center;
}
.ontario-publications-pagination {
	margin: 0;
}
.ontario-pagination-list {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
	flex-wrap: wrap;
}
.ontario-pagination-list li {
	margin: 0;
}
.ontario-pagination-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 1px solid rgba(36, 36, 36, 0.2);
	background: var(--de-white, #fff);
	color: var(--de-charcoal, #242424);
	text-decoration: none;
	font-weight: 500;
	font-size: 14px;
	transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.ontario-pagination-btn:hover {
	border-color: var(--de-charcoal, #242424);
	background: var(--de-charcoal-soft, #2d2d2d);
	color: var(--de-white, #fff);
}
.ontario-pagination-btn.ontario-pagination-active {
	border-color: var(--de-charcoal, #242424);
	background: var(--de-charcoal, #242424);
	color: var(--de-white, #fff);
}
.ontario-publications-loading .ontario-publications-grid {
	opacity: 0.6;
	pointer-events: none;
}

/* ========== OCIL Framework page ========== */
.ontario-ocil-intro-logo {
	line-height: 0;
}
.ontario-ocil-intro-logo img {
	max-width: 100%;
	height: auto;
	display: inline-block;
	vertical-align: top;
}
.ontario-ocil-tagline {
	font-size: 15px;
	color: var(--de-gold-muted);
	letter-spacing: 0.02em;
}

/* OCIL first section: label + heading + step cards (left) | image + lede (right) */
.ontario-ocil-first-intro {
	margin-bottom: 2rem;
}
.ontario-ocil-first-label {
	display: inline-block;
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--de-teal);
	margin-bottom: 12px;
}
.ontario-ocil-first-label::before {
	content: '• ';
	color: var(--de-gold-muted);
	margin-right: 4px;
}
.ontario-ocil-first-heading {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	line-height: 1.3;
	color: var(--de-charcoal);
	margin: 0 0 14px;
}
.ontario-ocil-first-heading .ontario-ocil-highlight {
	color: var(--de-gold-muted);
}
.ontario-ocil-first-sub {
	font-size: 15px;
	line-height: 1.65;
	color: var(--text-color);
	margin: 0;
}
.ontario-ocil-first-steps {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.ontario-ocil-step-card {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	padding: 24px 22px;
	background: var(--de-white);
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 20px;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
	transition: box-shadow 0.25s ease, border-color 0.25s ease;
}
.ontario-ocil-step-card:hover {
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.08);
	border-color: rgba(117, 172, 152, 0.2);
}
.ontario-ocil-step-card--icon-right {
	align-items: center;
}
.ontario-ocil-step-card--icon-right .ontario-ocil-step-body {
	order: 1;
}
.ontario-ocil-step-card--icon-right .ontario-ocil-step-icon {
	order: 2;
	flex-shrink: 0;
}
.ontario-ocil-step-num {
	flex-shrink: 0;
	font-size: 28px;
	font-weight: 700;
	line-height: 1;
	color: var(--de-charcoal);
	opacity: 0.9;
	font-variant-numeric: tabular-nums;
}
.ontario-ocil-step-icon {
	flex-shrink: 0;
	display: inline-block;
	line-height: 0;
}
/* Elementor icon library (font + inline SVG) — base + preset sizes when Style tab sliders are not used */
.ontario-ocil-step-icon--library {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	line-height: 1;
	box-sizing: border-box;
}
.ontario-ocil-step-icon--library.ontario-ocil-iconsz-100 {
	width: 100px;
	height: 100px;
	font-size: 100px;
}
.ontario-ocil-step-icon--library.ontario-ocil-iconsz-140 {
	width: 140px;
	height: 140px;
	font-size: 140px;
}
.ontario-ocil-step-icon--library.ontario-ocil-iconsz-full {
	width: auto;
	height: auto;
	min-width: 48px;
	min-height: 48px;
	font-size: 64px;
	max-width: 100%;
}
.ontario-ocil-step-icon img {
	width: 140px;
	height: 140px;
	object-fit: contain;
	display: block;
}
.ontario-ocil-step-icon--hover-swap {
	position: relative;
	width: 140px;
	height: 140px;
}
.ontario-ocil-step-icon--hover-swap .ontario-ocil-step-icon-hover {
	position: absolute;
	left: 0;
	top: 0;
	opacity: 0;
	transition: opacity 0.3s ease;
}
.ontario-ocil-step-icon--hover-swap .ontario-ocil-step-icon-default {
	transition: opacity 0.3s ease;
}
.ontario-ocil-step-card:hover .ontario-ocil-step-icon--hover-swap .ontario-ocil-step-icon-default {
	opacity: 0;
}
.ontario-ocil-step-card:hover .ontario-ocil-step-icon--hover-swap .ontario-ocil-step-icon-hover {
	opacity: 1;
}
.ontario-ocil-step-body {
	flex: 1;
	min-width: 0;
}
.ontario-ocil-step-title {
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--de-charcoal);
	margin: 0 0 10px;
}
.ontario-ocil-step-body p {
	font-size: 14px;
	line-height: 1.65;
	color: var(--text-color);
	margin: 0;
}
.ontario-ocil-step-body .ontario-ocil-highlight {
	color: var(--de-gold-muted);
	font-weight: 600;
}
.ontario-ocil-highlight {
	color: var(--de-gold-muted);
	font-weight: 600;
}
/* Right column: feature image + lede below */
.ontario-ocil-first .row.align-items-center {
	align-items: stretch;
}
.ontario-ocil-first-col-visual {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.ontario-ocil-first-col-visual .ontario-ocil-first-visual {
	width: 100%;
}
.ontario-ocil-first-visual {
	position: relative;
}
.ontario-ocil-first-img-wrap--feature {
	position: relative;
	border-radius: 24px;
	overflow: hidden;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
	max-width: 100%;
	width: 100%;
}
.ontario-ocil-first-img-wrap--feature img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
}
/* Second section: image left, content right (mirrored layout) */
.ontario-ocil-second .row.align-items-center {
	align-items: stretch;
}
.ontario-ocil-second-col-visual {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.ontario-ocil-second-col-visual .ontario-ocil-second-visual {
	width: 100%;
}
.ontario-ocil-second-visual {
	position: relative;
}

.ontario-ocil-first-lede {
	margin-top: 1.75rem;
	padding: 22px 24px;
	background: rgba(117, 172, 152, 0.08);
	border-radius: 16px;
	border-left: 4px solid var(--de-teal);
}
.ontario-ocil-first-lede p {
	font-size: 15px;
	line-height: 1.7;
	color: var(--de-charcoal);
	margin: 0;
}
@media (min-width: 992px) {
	.ontario-ocil-step-num {
		font-size: 32px;
	}
	.ontario-ocil-step-icon img {
		width: 140px;
		height: 140px;
	}
	.ontario-ocil-step-icon--hover-swap {
		width: 140px;
		height: 140px;
	}
	.ontario-ocil-step-card {
		padding: 28px 26px;
		gap: 1.5rem;
	}
	.ontario-ocil-first-img-wrap--feature {
		border-radius: 28px;
	}
	.ontario-ocil-first-lede {
		margin-top: 2rem;
		padding: 26px 28px;
	}
	.ontario-ocil-first-lede p {
		font-size: 16px;
	}
}
@media (max-width: 991.98px) {
	.ontario-ocil-first .row.align-items-start {
		align-items: stretch;
	}
	.ontario-ocil-first-visual {
		max-width: 480px;
		margin: 0 auto;
	}
}

.ontario-ocil-heading {
	font-size: 20px;
	font-weight: 700;
	color: var(--de-charcoal);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: 0 0 16px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--de-gold);
}
.ontario-ocil-section p {
	color: var(--text-color);
	line-height: 1.7;
}
.ontario-ocil-section.ontario-ocil-alt {
	background: rgba(117, 172, 152, 0.06);
}
.ontario-ocil-lede {
	font-size: 17px;
	color: var(--de-charcoal);
	line-height: 1.65;
}
.ontario-ocil-image-wrap {
	position: relative;
}
.ontario-ocil-image-wrap.ontario-ocil-image-circle {
	max-width: 380px;
	margin: 0 auto;
	border-radius: 50%;
	overflow: hidden;
	aspect-ratio: 1;
}
.ontario-ocil-image-circle img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
/* KEY BENEFITS (same width as Contact OCIL; lighter background + overlay for dark text) */
.ontario-ocil-benefits.orbia-contact_one.bg_cover::before {
	background: rgba(255, 255, 255, 0.78);
	border-radius: inherit;
}
.ontario-ocil-benefits .section-title .sub-title {
	color: var(--de-teal);
	font-weight: 600;
}
/* KEY BENEFITS: compact card height and spacing */
.ontario-ocil-benefits .orbia-iconic-box.style-one {
	padding: 22px 26px 20px;
	border-radius: 16px;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .box-border {
	border-radius: 16px;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .icon-wrap .number {
	font-size: 36px;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .icon-wrap .icon img {
	width: 36px;
	height: auto;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .content {
	padding-top: 10px;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .content h4.title {
	font-size: 18px;
	line-height: 1.3;
	margin-bottom: 8px;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .content p {
	font-size: 14px;
	line-height: 1.45;
	margin-bottom: 0;
}
/* OCIL Framework: Benefits section custom overlay */
.ontario-ocil-benefits {
	position: relative;
}
.ontario-ocil-benefits-overlay {
	position: absolute;
	top: 0; left: 0; width: 100%; height: 100%;
	background-image: linear-gradient(266deg, rgba(197, 178, 125, 0.9) -1.18%, rgba(66, 57, 60, 0.95) 96.14%);
	z-index: 1;
}
.ontario-ocil-benefits .section-title h2,
.ontario-ocil-benefits .section-title .sub-title {
	color: #fff;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	transition: all 0.3s ease;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: rgba(197, 178, 125, 0.5);
	transform: translateY(-5px);
}
.ontario-ocil-benefits .orbia-iconic-box.style-one:hover .icon img {
	filter: none !important; /* Ensure hover effects don't white-out colored icons */
	opacity: 1;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .title,
.ontario-ocil-benefits .orbia-iconic-box.style-one p {
	color: #fff;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .icon {
	background: #fff;
	width: 65px;
	height: 65px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .icon img {
	width: 36px;
	height: auto;
	object-fit: contain;
	filter: none; /* Reset any potential inherited filters */
	opacity: 1 !important;
}
/* No need for hover icon filter since the icons are naturally colored PNGs and should remain fully visible in the white circle */
.ontario-ocil-benefits .orbia-iconic-box.style-one .icon-wrap {
	display: flex;
	align-items: center;
	margin-bottom: 25px;
	position: relative;
	z-index: 2;
}
.ontario-ocil-benefits .orbia-iconic-box.style-one:hover .icon {
	background: #fff; /* Keep the circle white on hover */
}
.ontario-ocil-benefits .orbia-iconic-box.style-one:hover .icon img {
	filter: none !important; /* Stop the theme from turning the PNG white */
}
.ontario-ocil-benefits .orbia-iconic-box.style-one .number {
	color: #fff;
	font-weight: 800;
	font-size: 2.2rem;
	margin-right: 20px;
	opacity: 0.9;
	position: static;
	writing-mode: horizontal-tb; /* Reset in case inherited */
	transform: none; /* Reset in case inherited */
}

.ontario-ocil-benefits-grid {
	margin-left: -10px;
	margin-right: -10px;
	padding-left: 15px;
	padding-right: 15px;
	padding-bottom: 36px;
}
.ontario-ocil-benefits-grid > [class*="col-"] {
	padding-left: 10px;
	padding-right: 10px;
	margin-bottom: 14px;
}
.ontario-ocil-benefits-grid > [class*="col-"]:last-child {
	margin-bottom: 0;
}
.ontario-ocil-benefits .section-title.mb-55 {
	margin-bottom: 2rem;
}
@media (max-width: 991.98px) {
	.ontario-ocil-benefits .orbia-iconic-box.style-one .content {
		padding-top: 10px;
	}
	.ontario-ocil-benefits .orbia-iconic-box.style-one .content h4.title {
		font-size: 17px;
	}
	.ontario-ocil-benefits-grid > [class*="col-"] {
		margin-bottom: 12px;
	}
}
@media (max-width: 575.98px) {
	.ontario-ocil-benefits .orbia-iconic-box.style-one {
		padding: 18px 20px 16px;
	}
	.ontario-ocil-benefits .orbia-iconic-box.style-one .icon-wrap .number {
		font-size: 30px;
	}
	.ontario-ocil-benefits .orbia-iconic-box.style-one .content {
		padding-top: 10px;
	}
	.ontario-ocil-benefits .orbia-iconic-box.style-one .content h4.title {
		font-size: 16px;
		margin-bottom: 6px;
	}
	.ontario-ocil-benefits .orbia-iconic-box.style-one .content p {
		font-size: 13px;
	}
	.ontario-ocil-benefits-grid > [class*="col-"] {
		margin-bottom: 10px;
	}
}
.ontario-ocil-benefits-image {
	width: 100%;
	line-height: 0;
	margin-top: 0;
}
.ontario-ocil-benefits-image img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
	border-radius: 0 0 30px 30px;
}
@media (max-width: 991.98px) {
	.ontario-ocil-benefits-grid {
		padding-bottom: 36px;
		padding-left: 15px;
		padding-right: 15px;
	}
	.ontario-ocil-benefits-image img {
		border-radius: 0 0 20px 20px;
	}
}
@media (max-width: 575.98px) {
	.ontario-ocil-benefits-grid {
		padding-bottom: 28px;
	}
	.ontario-ocil-benefits-image img {
		border-radius: 0 0 16px 16px;
	}
}

.ontario-ocil-benefit-card {
	padding: 24px 20px;
	background: var(--de-white);
	border-radius: 16px;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.06);
	height: 100%;
}
.ontario-ocil-benefit-num {
	display: block;
	font-size: 32px;
	font-weight: 700;
	color: rgba(36, 36, 36, 0.12);
	line-height: 1;
	margin-bottom: 12px;
}
.ontario-ocil-benefit-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--de-charcoal);
	margin: 0 0 10px;
}
.ontario-ocil-benefit-card p {
	margin: 0;
	font-size: 15px;
}
/* TARGET AUDIENCE */
.ontario-ocil-audience .section-title .sub-title {
	color: var(--de-teal);
	font-weight: 600;
}
/* TARGET AUDIENCE: style-five with large OCIL icons */
.ontario-ocil-audience .orbia-iconic-box.style-five.ontario-ocil-audience-box {
	height: 100%;
	background: rgba(117, 172, 152, 0.06);
	padding: 30px 0;
	box-shadow: 0 2px 11px rgb(0 0 0 / 0%);
	border: 1px solid rgba(0, 0, 0, 0.05);
	margin-bottom: 0;
}
.ontario-ocil-audience .ontario-ocil-audience-box .shape {
	top: 0;
	left: 0;
}
.ontario-ocil-audience .ontario-ocil-audience-box .shape img {
	max-width: 120px;
	height: auto;
	opacity: 0.85;
}
.ontario-ocil-audience .ontario-ocil-audience-box .icon {
	width: 100px;
	height: 100px;
	border-radius: 20px;
	margin-bottom: 24px;
	background: rgba(117, 172, 152, 0.12);
}
.ontario-ocil-audience .ontario-ocil-audience-box .icon img {
	width: 56px;
	height: auto;
	max-height: 56px;
	object-fit: contain;
}
@media (min-width: 992px) {
	.ontario-ocil-audience .ontario-ocil-audience-box .icon img {
		width: 120px;
		max-height: 120px;
	}
}
.ontario-ocil-audience .ontario-ocil-audience-box .content h4 {
	font-size: 22px;
	font-weight: 600;
	color: var(--de-charcoal);
	margin-bottom: 12px;
}
.ontario-ocil-audience .ontario-ocil-audience-box .content p {
	margin: 0;
	font-size: 15px;
	line-height: 1.6;
	color: var(--text-color);
}
@media (min-width: 992px) {
	.ontario-ocil-audience .ontario-ocil-audience-box .icon {
		width: 110px;
		height: 110px;
		border-radius: 22px;
		margin-bottom: 26px;
	}
	.ontario-ocil-audience .ontario-ocil-audience-box .icon img {
		width: 64px;
		max-height: 64px;
	}
	.ontario-ocil-audience .ontario-ocil-audience-box .content h4 {
		font-size: 24px;
		margin-bottom: 15px;
	}
}
/* ISO 56002 */
/* ISO 56002 section – creative two-column: numbered list + diagram */
.ontario-ocil-iso .ontario-ocil-heading {
	text-align: center;
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 24px;
}
.ontario-ocil-iso-title {
	font-size: clamp(1.1rem, 2.2vw, 1.35rem);
	font-weight: 700;
	line-height: 1.35;
	color: var(--de-charcoal);
	text-transform: uppercase;
	letter-spacing: 0.03em;
	margin: 0 0 10px;
}
.ontario-ocil-iso-title-accent {
	color: var(--de-gold-muted);
}
.ontario-ocil-iso-title-line {
	display: block;
	width: 80px;
	height: 2px;
	background: var(--de-charcoal);
	opacity: 0.35;
}
.ontario-ocil-iso-content {
	align-items: stretch;
}
.ontario-ocil-iso-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.ontario-ocil-iso-list li {
	position: relative;
	padding-left: 28px;
	margin-bottom: 14px;
	line-height: 1.65;
	color: var(--text-color);
}
.ontario-ocil-iso-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--de-gold);
}
/* ISO alignment: orbia-iconic-box style-two – compact, content right-aligned, no number/icon */
.ontario-ocil-iso-boxes .orbia-iconic-box.style-two.ontario-ocil-iso-box {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 20px 24px 24px;
	border-radius: 20px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
	border: 1px solid rgba(0, 0, 0, 0.05);
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .shape {
	top: 0;
	right: 0;
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .shape img {
	max-width: 100px;
	height: auto;
	opacity: 0.85;
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .icon {
	display: none;
}
/* Large left number, content on the right, text left-aligned */
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .ontario-ocil-iso-num {
	flex-shrink: 0;
	font-size: 42px;
	font-weight: 700;
	line-height: 1;
	color: var(--de-teal);
	opacity: 0.4;
	font-variant-numeric: tabular-nums;
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .content {
	flex: 1;
	min-width: 0;
	text-align: left;
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .content .title {
	font-size: 17px;
	font-weight: 600;
	margin-bottom: 8px;
	color: var(--de-charcoal);
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .content .title a {
	color: inherit;
	text-decoration: none;
}
.ontario-ocil-iso-boxes .ontario-ocil-iso-box .content p {
	margin: 0;
	font-size: 13px;
	line-height: 1.6;
	color: var(--text-color);
}
@media (min-width: 992px) {
	.ontario-ocil-iso-boxes .orbia-iconic-box.style-two.ontario-ocil-iso-box {
		padding: 24px 28px 28px;
		gap: 20px;
	}
	.ontario-ocil-iso-boxes .ontario-ocil-iso-box .shape img {
		max-width: 110px;
	}
	.ontario-ocil-iso-boxes .ontario-ocil-iso-box .ontario-ocil-iso-num {
		font-size: 52px;
	}
	.ontario-ocil-iso-boxes .ontario-ocil-iso-box .content .title {
		font-size: 18px;
		margin-bottom: 10px;
	}
	.ontario-ocil-iso-boxes .ontario-ocil-iso-box .content p {
		font-size: 14px;
	}
}

/* Numbered list variant (large 01–04) – kept for any other use */
.ontario-ocil-iso-list-numbered {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.ontario-ocil-iso-list-numbered li {
	padding-left: 0;
	padding-top: 0;
	margin-bottom: 0;
	display: flex;
	align-items: flex-start;
	gap: 14px;
}
.ontario-ocil-iso-list-numbered li::before {
	display: none;
}
.ontario-ocil-iso-num {
	display: block;
	flex-shrink: 0;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	color: var(--de-teal);
	opacity: 0.45;
	font-variant-numeric: tabular-nums;
}
/* Diagram: two pillars + center badge, or single image */
.ontario-ocil-iso-diagram {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 0;
	align-items: stretch;
	min-height: 320px;
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 8px 40px rgba(0, 0, 0, 0.08);
}
.ontario-ocil-iso-diagram--image {
	display: block;
	min-height: 0;
	background: var(--de-white);
	box-shadow: 0 6px 32px rgba(0, 0, 0, 0.08);
	padding: 1rem 1.5rem;
	border-radius: 16px;
}
.ontario-ocil-iso-comparison-img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
	border-radius: 12px;
}
@media (min-width: 768px) {
	.ontario-ocil-iso-diagram--image {
		padding: 1.25rem 2rem;
	}
}
.ontario-ocil-iso-pillar {
	display: flex;
	flex-direction: column;
	padding: 0;
}
.ontario-ocil-iso-pillar-title {
	font-size: 0.95rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 16px 20px;
	text-align: center;
	color: var(--de-white);
}
.ontario-ocil-iso-pillar--ocil .ontario-ocil-iso-pillar-title {
	background: var(--de-teal);
}
.ontario-ocil-iso-pillar--iso .ontario-ocil-iso-pillar-title {
	background: var(--de-gold-muted);
	color: var(--de-charcoal);
}
.ontario-ocil-iso-pillar-cards {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 16px 14px;
	gap: 0;
	background: rgba(255, 255, 255, 0.6);
}
.ontario-ocil-iso-pillar--ocil .ontario-ocil-iso-pillar-cards {
	background: linear-gradient(180deg, rgba(107, 140, 129, 0.08) 0%, rgba(255, 255, 255, 0.95) 100%);
}
.ontario-ocil-iso-pillar--iso .ontario-ocil-iso-pillar-cards {
	background: linear-gradient(180deg, rgba(195, 178, 139, 0.12) 0%, rgba(255, 255, 255, 0.95) 100%);
}
.ontario-ocil-iso-card {
	border-radius: 12px;
	overflow: hidden;
	margin-bottom: 6px;
	border: 1px solid rgba(0, 0, 0, 0.06);
}
.ontario-ocil-iso-pillar--ocil .ontario-ocil-iso-card {
	background: rgba(107, 140, 129, 0.12);
}
.ontario-ocil-iso-card--gold,
.ontario-ocil-iso-pillar--iso .ontario-ocil-iso-card {
	background: rgba(195, 178, 139, 0.15);
}
.ontario-ocil-iso-card-head {
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	padding: 10px 14px;
	color: var(--de-white);
}
.ontario-ocil-iso-pillar--ocil .ontario-ocil-iso-card-head {
	background: var(--de-teal);
}
.ontario-ocil-iso-card--gold .ontario-ocil-iso-card-head,
.ontario-ocil-iso-pillar--iso .ontario-ocil-iso-card-head {
	background: var(--de-gold-muted);
	color: var(--de-charcoal);
}
.ontario-ocil-iso-card-body {
	font-size: 0.75rem;
	line-height: 1.5;
	padding: 10px 14px 12px;
	color: var(--de-charcoal);
}
.ontario-ocil-iso-connector {
	text-align: center;
	padding: 4px 0 8px;
}
.ontario-ocil-iso-connector-label {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--de-teal);
	background: rgba(107, 140, 129, 0.15);
	padding: 4px 10px;
	border-radius: 20px;
}
.ontario-ocil-iso-center {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	flex-shrink: 0;
	background: linear-gradient(180deg, var(--de-charcoal) 0%, var(--de-charcoal-soft) 100%);
}
.ontario-ocil-iso-badge {
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: var(--de-white);
}
@media (max-width: 991.98px) {
	.ontario-ocil-iso-diagram {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto auto;
		min-height: 0;
	}
	.ontario-ocil-iso-center {
		width: 100%;
		padding: 12px;
	}
	.ontario-ocil-iso-pillar-cards {
		padding: 12px 14px;
	}
}
/* OCIL contact section – image on right (no cover), form left, clean stacked fields */
.ontario-contact-ocil.orbia-contact_one.bg_cover {
	background-position: right center;
	background-size: cover;
	background-repeat: no-repeat;
	min-height: 560px;
}
.ontario-contact-ocil.orbia-contact_one.bg_cover::before {
	background: linear-gradient(to right, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0.75) 55%, transparent 70%);
	border-radius: inherit;
}
.ontario-contact-ocil.orbia-contact_one {
	position: relative;
}
.ontario-contact-ocil-deco {
	position: absolute;
	top: 50%;
	right: 5%;
	transform: translateY(-50%);
	z-index: 0;
	pointer-events: none;
	opacity: 0.90;
}
.ontario-contact-ocil-deco-circle {
	width: 180px;
	height: auto;
	display: block;
}
.ontario-contact-ocil-container {
	position: relative;
	z-index: 1;
}
.ontario-contact-ocil-form-wrapper {
	max-width: 100%;
	padding: 40px 40px 44px;
	border-radius: 16px;
	background-color: rgba(255, 255, 255, 0.97);
	box-shadow: 0 4px 24px rgba(36, 36, 36, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.08);
}
.ontario-contact-ocil-form-wrapper .ontario-contact-ocil-intro {
	color: var(--de-charcoal, #333);
	font-size: 1rem;
	line-height: 1.55;
	margin-bottom: 1.75rem;
	font-weight: 500;
}
.ontario-ocil-contact-fields .form-group {
	margin-bottom: 1.25rem;
}
.ontario-ocil-contact-fields .form-group--submit {
	margin-bottom: 0;
	margin-top: 0.5rem;
}
.ontario-ocil-contact-form .form-label {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--de-charcoal, #333);
	margin-bottom: 0.375rem;
}
.ontario-ocil-contact-form .form_control {
	display: block;
	width: 100%;
	padding: 12px 16px;
	border-radius: 8px;
	border: 1px solid rgba(0, 0, 0, 0.15);
	font-size: 0.9375rem;
	min-height: 46px;
	background: #fff;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.ontario-ocil-contact-form .form_control::placeholder {
	color: #888;
}
.ontario-ocil-contact-form .form_control:focus {
	outline: none;
	border-color: rgba(107, 140, 129, 0.6);
	box-shadow: 0 0 0 3px rgba(107, 140, 129, 0.12);
}
.ontario-ocil-contact-form textarea.form_control {
	min-height: 120px;
	resize: vertical;
	border-radius: 8px;
	padding: 12px 16px;
}
.ontario-ocil-contact-form .ontario-ocil-send-btn {
	padding: 14px 32px;
	font-size: 0.9375rem;
	font-weight: 600;
	background: linear-gradient(135deg, #4a7c59 0%, #6b8c81 100%);
	border: none;
	border-radius: 8px;
	box-shadow: 0 2px 12px rgba(74, 124, 89, 0.35);
}
.ontario-ocil-contact-form .ontario-ocil-send-btn:hover {
	background: linear-gradient(135deg, #3d6b4a 0%, #5a776d 100%);
	box-shadow: 0 4px 16px rgba(74, 124, 89, 0.4);
}
@media (max-width: 991.98px) {
	.ontario-contact-ocil.orbia-contact_one.bg_cover {
		background-size: cover;
		background-position: right bottom;
		min-height: 520px;
	}
	.ontario-contact-ocil.orbia-contact_one.bg_cover::before {
		background: linear-gradient(to right, rgba(255, 255, 255, 0.97) 0%, rgba(255, 255, 255, 0.82) 60%, transparent 75%);
	}
	.ontario-contact-ocil-form-wrapper {
		padding: 28px 24px 32px;
	}
	.ontario-contact-ocil-deco-circle {
		width: 120px;
	}
	.ontario-contact-ocil-deco {
		right: 2%;
	}
}
@media (max-width: 575.98px) {
	.ontario-contact-ocil.orbia-contact_one {
		margin-left: 0;
		margin-right: 0;
		min-height: 0;
	}
	.ontario-contact-ocil.orbia-contact_one.bg_cover {
		background-size: cover;
		background-position: right bottom;
		min-height: 420px;
	}
	.ontario-contact-ocil.orbia-contact_one.bg_cover::before {
		background: linear-gradient(to right, rgba(255, 255, 255, 0.98) 0%, transparent 55%);
	}
	.ontario-contact-ocil-form-wrapper {
		padding: 24px 20px 28px;
		border-radius: 12px;
	}
	.ontario-contact-ocil-deco {
		opacity: 0.90;
	}
	.ontario-contact-ocil-deco-circle {
		width: 90px;
	}
}

/* ========== Solutions page: intro, Planview IdeaPlace & ProjectPlace, closing ========== */
/* Intro section */
.ontario-solutions-intro-section {
	background: var(--de-white);
}
.ontario-solutions-intro-title {
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: var(--heading-color);
	margin: 0 0 1rem;
	font-family: var(--heading-font);
}
.ontario-solutions-intro-lede {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-color);
	margin: 0;
}
.ontario-solutions-intro-ai {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-color);
	margin: 0.75rem 0 1.25rem;
	font-weight: 500;
}
.ontario-solutions-outcomes {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem 1.5rem;
	margin: 0 0 1.25rem;
}
.ontario-solutions-outcome {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.9375rem;
	color: var(--heading-color);
	font-weight: 500;
}
.ontario-solutions-outcome img {
	width: 28px;
	height: 28px;
	object-fit: contain;
	flex-shrink: 0;
}
.ontario-solutions-intro-links {
	font-size: 0.9375rem;
	color: var(--text-color);
	margin: 0;
}
.ontario-solutions-intro-links a {
	color: var(--theme-color);
	font-weight: 500;
	text-decoration: none;
}
.ontario-solutions-intro-links a:hover {
	text-decoration: underline;
}

.ontario-solutions-section {
	background: var(--de-white);
	position: relative;
	overflow: hidden;
}
.ontario-solutions-second {
	margin-top: -0.5rem;
}
/* Decorative design-elements: circles and boxes (do not affect layout) */
/* Subtle moving animations for Solutions decorative elements */
@keyframes solutions-float-circle {
	0%, 100% { transform: translateY(-50%) translateY(0); }
	50% { transform: translateY(-50%) translateY(-14px); }
}
@keyframes solutions-float-circle-second {
	0%, 100% { transform: translateY(-50%) translateY(0); }
	50% { transform: translateY(-50%) translateY(12px); }
}
@keyframes solutions-drift-box-right {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(8px, -6px); }
}
@keyframes solutions-drift-box-left {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(-6px, 8px); }
}

.ontario-solutions-deco {
	position: absolute;
	pointer-events: none;
	z-index: 0;
}
.ontario-solutions-deco img {
	display: block;
	width: 100%;
	height: auto;
}
.ontario-solutions-deco--circle.ontario-solutions-deco--first {
	width: 240px;
	right: 8%;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0.60;
	animation: solutions-float-circle 5s ease-in-out infinite;
}
.ontario-solutions-deco--box.ontario-solutions-deco--box-1 {
	width: 100px;
	left: 2%;
	bottom: 15%;
	opacity: 0.9;
	animation: solutions-drift-box-left 4.5s ease-in-out infinite;
}
.ontario-solutions-deco--circle.ontario-solutions-deco--second {
	width: 180px;
	left: 5%;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0.92;
	animation: solutions-float-circle-second 5.5s ease-in-out infinite;
}
.ontario-solutions-deco--box.ontario-solutions-deco--box-2 {
	width: 100px;
	right: 3%;
	bottom: 12%;
	opacity: 0.9;
	animation: solutions-drift-box-right 4s ease-in-out infinite;
}
.ontario-solutions-section .container,
.ontario-solutions-section .row,
.ontario-solutions-section .ontario-solution-lede,
.ontario-solutions-section .ontario-solution-logo-wrap {
	position: relative;
	z-index: 1;
}
@media (prefers-reduced-motion: reduce) {
	.ontario-solutions-deco {
		animation: none;
	}
}
.ontario-solutions-section .ontario-solutions-intro {
	margin-bottom: 1rem;
}
.ontario-solutions-heading {
	padding-bottom: 8px;
	border-bottom: 2px solid var(--de-gold);
	margin-bottom: 0;
	display: inline-block;
}
.ontario-solution-lede {
	padding: 1.25rem 1.25rem 1.25rem 1.5rem;
	background: rgba(117, 172, 152, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 16px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}
.ontario-solution-lede--accent {
	border-left: 4px solid var(--de-gold);
	padding-left: 1.25rem;
}
.ontario-solutions-second .ontario-solution-lede--accent {
	border-left: none;
	border-right: 4px solid var(--de-teal);
	padding-right: 1.25rem;
	padding-left: 1.5rem;
}
.ontario-solution-lede p {
	font-size: 15px;
	line-height: 1.65;
	color: var(--text-color, var(--de-charcoal));
	margin: 0 0 0.75rem;
}
.ontario-solution-lede p:last-child {
	margin-bottom: 0;
}
.ontario-solution-lede .ontario-solution-cta {
	font-size: 14px;
	font-weight: 600;
	color: var(--de-teal);
	margin-top: 0.75rem;
}
.ontario-solution-lede .ontario-solution-strip {
	font-size: 13px;
	font-weight: 600;
	color: var(--de-teal);
	letter-spacing: 0.02em;
	margin: 0.5rem 0 0.75rem;
	opacity: 0.9;
}
.ontario-solutions-infographic-wrap {
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
	border: 1px solid rgba(0, 0, 0, 0.06);
	background: var(--de-white);
}
.ontario-solutions-infographic-wrap .ontario-solutions-infographic {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: middle;
}
.ontario-solution-logo-wrap {
	background: var(--de-white);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
	border: 1px solid rgba(0, 0, 0, 0.06);
	padding: 1.25rem;
	max-width: 360px;
	margin: 0 auto;
}
.ontario-solutions-first .ontario-solution-logo-wrap {
	margin-left: 0;
	margin-right: auto;
}
.ontario-solutions-second .ontario-solution-logo-wrap {
	margin-left: auto;
	margin-right: 0;
}

/* Planview: image always in right column; align card to outer (right) edge */
.ontario-solutions-planview__visual-col {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.ontario-solutions-first .ontario-solutions-planview__visual-col {
	justify-content: flex-start;
}
@media (max-width: 991.98px) {
	.ontario-solutions-planview__visual-col {
		justify-content: center !important;
	}
}

.ontario-solutions-planview--img-left .ontario-solutions-planview__visual-col {
	justify-content: flex-start;
}
.ontario-solutions-planview--img-left .ontario-solution-logo-wrap {
	margin-left: 0;
	margin-right: auto;
}

.ontario-solution-logo-wrap img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: contain;
}

/* Closing section: How we use these solutions – creative AI-service style (dark block) */
.ontario-solutions-close {
	position: relative;
	overflow: hidden;
}
/* Rounded, not full width – same treatment as home Services section (orbia-service_one) */
.ontario-solutions-close--rounded {
	margin-left: 30px;
	margin-right: 30px;
	border-radius: 30px;
	overflow: hidden;
}
@media (max-width: 1650px) {
	.ontario-solutions-close--rounded {
		margin-left: 15px;
		margin-right: 15px;
		border-radius: 20px;
	}
}
@media (max-width: 1199.98px) {
	.ontario-solutions-close--rounded {
		margin-left: 0;
		margin-right: 0;
		border-radius: 0;
	}
}
.ontario-solutions-close-bg {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, #1a1f1e 0%, #242424 40%, #2d2628 100%);
	opacity: 1;
}
.ontario-solutions-close-bg::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(117, 172, 152, 0.12) 0%, transparent 55%),
	            radial-gradient(ellipse 60% 40% at 100% 100%, rgba(197, 178, 125, 0.08) 0%, transparent 50%);
	pointer-events: none;
}
.ontario-solutions-close .container {
	z-index: 1;
}
.ontario-solutions-close-inner {
	text-align: center;
	padding: 3rem 2rem;
	border-radius: 24px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.01) 100%);
	backdrop-filter: blur(12px);
}
.ontario-solutions-close-label {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--primary-color);
	margin-bottom: 0.75rem;
}
.ontario-solutions-close-title {
	font-size: clamp(1.5rem, 2.8vw, 1.875rem);
	font-weight: 700;
	color: var(--white-color);
	margin: 0 0 1.25rem;
	font-family: var(--heading-font);
	line-height: 1.25;
}
.ontario-solutions-close-lede {
	font-size: 1rem;
	line-height: 1.8;
	color: rgba(255, 255, 255, 0.88);
	margin: 0 0 1.75rem;
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
}
.ontario-solutions-close-pills {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.75rem 1rem;
	margin-bottom: 1.75rem;
}
.ontario-solutions-close-pill {
	display: inline-block;
	font-size: 0.8125rem;
	font-weight: 600;
	padding: 0.5rem 1rem;
	border-radius: 999px;
	letter-spacing: 0.02em;
}
.ontario-solutions-close-pill--ideation {
	background: rgba(117, 172, 152, 0.25);
	color: rgba(255, 255, 255, 0.95);
	border: 1px solid rgba(117, 172, 152, 0.4);
}
.ontario-solutions-close-pill--delivery {
	background: rgba(197, 178, 125, 0.2);
	color: rgba(255, 255, 255, 0.95);
	border: 1px solid rgba(197, 178, 125, 0.35);
}
.ontario-solutions-close-cta .theme-btn {
	color: var(--white-color);
}
.ontario-solutions-close-cta .theme-btn:hover {
	color: var(--white-color);
}

.ontario-solutions-approach__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	text-decoration: none;
	transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.ontario-solutions-approach__btn .elementor-icon {
	display: inline-flex;
	line-height: 1;
}

@media (min-width: 768px) {
	.ontario-solutions-close-inner {
		padding: 4rem 3rem;
	}
}

/* Decorative bars from design-elements (teal/gold) – subtle section accent */
.ontario-solutions-first .container {
	position: relative;
}
.ontario-solutions-first .container::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 120px;
	background: linear-gradient(180deg, var(--de-teal) 0%, var(--de-charcoal) 100%);
	border-radius: 2px;
	opacity: 0.35;
}
@media (min-width: 992px) {
	.ontario-solution-lede {
		padding: 1.5rem 1.5rem 1.5rem 1.75rem;
	}
	.ontario-solution-lede--accent {
		padding-left: 1.5rem;
	}
	.ontario-solutions-second .ontario-solution-lede--accent {
		padding-right: 1.5rem;
		padding-left: 1.5rem;
	}
	.ontario-solution-lede p {
		font-size: 16px;
	}
}
@media (max-width: 991.98px) {
	.ontario-solutions-first .container::before {
		display: none;
	}
	.ontario-solutions-deco--circle.ontario-solutions-deco--first {
		width: 100px;
		right: 2%;
		opacity: 0.88;
	}
	.ontario-solutions-deco--box.ontario-solutions-deco--box-1 {
		width: 70px;
		left: 0;
		bottom: 10%;
		opacity: 0.85;
	}
	.ontario-solutions-deco--circle.ontario-solutions-deco--second {
		width: 90px;
		left: 2%;
		opacity: 0.88;
	}
	.ontario-solutions-deco--box.ontario-solutions-deco--box-2 {
		width: 70px;
		right: 0;
		bottom: 8%;
		opacity: 0.85;
	}
	.ontario-solutions-first .ontario-solution-logo-wrap,
	.ontario-solutions-second .ontario-solution-logo-wrap {
		margin-left: auto;
		margin-right: auto;
	}
	.ontario-solutions-second .ontario-solution-lede--accent {
		border-right: none;
		border-left: 4px solid var(--de-teal);
		padding-left: 1.25rem;
		padding-right: 1.25rem;
	}
}
@media (max-width: 575.98px) {
	.ontario-solutions-deco--circle,
	.ontario-solutions-deco--box {
		opacity: 0.8;
	}
	.ontario-solutions-deco--circle {
		width: 80px !important;
	}
	.ontario-solutions-deco--box {
		width: 50px !important;
	}
}

/* ========== Solutions Intro Section V2 – Modern Redesign ========== */
.ontario-solutions-intro-section-v2 {
	position: relative;
	background: linear-gradient(180deg, #ffffff 0%, #f8faf9 50%, #f0f5f3 100%);
	overflow: hidden;
}

.ontario-solutions-intro-deco {
	position: absolute;
	pointer-events: none;
}

.ontario-solutions-intro-deco--top {
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 200px;
	height: 4px;
	background: linear-gradient(90deg, transparent, var(--de-teal-light), var(--de-gold-muted), var(--de-teal-light), transparent);
	border-radius: 2px;
}

.ontario-solutions-intro-header {
	margin-bottom: 2rem;
}

.ontario-solutions-intro-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0.5rem 1rem;
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.12) 0%, rgba(197, 178, 125, 0.12) 100%);
	border: 1px solid rgba(117, 172, 152, 0.25);
	border-radius: 50px;
	color: var(--de-teal);
	margin-bottom: 1.25rem;
}

.ontario-solutions-intro-badge::before {
	content: "\2726";
	font-size: 0.625rem;
	color: var(--de-gold);
}

.ontario-solutions-intro-title-v2 {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	color: var(--de-charcoal);
	line-height: 1.25;
	margin: 0;
	background: linear-gradient(135deg, var(--de-charcoal) 0%, var(--de-sage) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.ontario-solutions-intro-content {
	max-width: 800px;
	margin: 0 auto 2.5rem;
	text-align: center;
}

.ontario-solutions-intro-lede-v2 {
	font-size: 1.0625rem;
	line-height: 1.85;
	color: var(--text-color);
	margin-bottom: 1rem;
	font-weight: 400;
}

.ontario-solutions-intro-ai-v2 {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--de-teal);
	font-weight: 500;
	padding: 1rem 1.5rem;
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.08) 0%, rgba(197, 178, 125, 0.06) 100%);
	border-radius: 12px;
	border-left: 3px solid var(--de-teal-light);
	margin: 0;
}

/* Outcomes Cards Grid */
.ontario-solutions-outcomes-v2 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.25rem;
	max-width: 900px;
	margin: 0 auto 2.5rem;
}

.ontario-solutions-outcome-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 1.75rem 1.25rem;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(66, 57, 60, 0.06), 0 1px 3px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(117, 172, 152, 0.15);
	transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
	position: relative;
	overflow: hidden;
}

.ontario-solutions-outcome-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	border-radius: 16px 16px 0 0;
}

.ontario-solutions-outcome-card--speed::before {
	background: linear-gradient(90deg, var(--de-teal) 0%, var(--de-teal-light) 100%);
}

.ontario-solutions-outcome-card--data::before {
	background: linear-gradient(90deg, var(--de-gold) 0%, var(--de-gold-muted) 100%);
}

.ontario-solutions-outcome-card--visibility::before {
	background: linear-gradient(90deg, var(--de-sage) 0%, var(--de-sage-light) 100%);
}

.ontario-solutions-outcome-card--launch::before {
	background: linear-gradient(90deg, var(--de-teal-light) 0%, var(--de-gold) 100%);
}

.ontario-solutions-outcome-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 40px rgba(66, 57, 60, 0.12), 0 4px 12px rgba(0, 0, 0, 0.06);
	border-color: rgba(117, 172, 152, 0.3);
}

.ontario-solutions-outcome-icon {
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.1) 0%, rgba(197, 178, 125, 0.1) 100%);
	border-radius: 14px;
	margin-bottom: 1rem;
	transition: transform 0.3s ease;
}

.ontario-solutions-outcome-card:hover .ontario-solutions-outcome-icon {
	transform: scale(1.08);
}

.ontario-solutions-outcome-icon img {
	width: 32px;
	height: 32px;
	object-fit: contain;
}

.ontario-solutions-outcome-label {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--de-charcoal);
	line-height: 1.4;
}

/* Footer Links */
.ontario-solutions-intro-footer {
	text-align: center;
}

.ontario-solutions-intro-links-v2 {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	justify-content: center;
	font-size: 0.9375rem;
	color: var(--text-color);
}

.ontario-solutions-links-label {
	color: var(--text-color);
	opacity: 0.8;
}

.ontario-solutions-links-separator {
	color: var(--de-gold);
	font-weight: 500;
	padding: 0 0.25rem;
}

.ontario-solutions-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--de-teal);
	font-weight: 600;
	text-decoration: none;
	padding: 0.5rem 1rem;
	background: rgba(117, 172, 152, 0.08);
	border-radius: 20px;
	border: 1px solid rgba(117, 172, 152, 0.2);
	transition: all 0.25s ease;
}

.ontario-solutions-link:hover {
	background: var(--de-teal);
	color: #ffffff;
	border-color: var(--de-teal);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(117, 172, 152, 0.25);
}

.ontario-solutions-link--framework {
	color: var(--de-gold);
	background: rgba(197, 178, 125, 0.08);
	border-color: rgba(197, 178, 125, 0.2);
}

.ontario-solutions-link--framework:hover {
	background: var(--de-gold);
	border-color: var(--de-gold);
	box-shadow: 0 4px 12px rgba(197, 178, 125, 0.25);
}

/* Registered Trademark Symbol for OCIL */
.ontario-solutions-tm {
	font-size: 1em;
	font-weight: 700;
	color: var(--de-gold);
	vertical-align: super;
	line-height: 1;
	margin-left: 0.2em;
}

.ontario-solutions-link--framework:hover .ontario-solutions-tm {
	color: #ffffff;
}

/* Responsive */
@media (max-width: 991.98px) {
	.ontario-solutions-outcomes-v2 {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}
}

@media (max-width: 575.98px) {
	.ontario-solutions-intro-section-v2 {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}
	
	.ontario-solutions-intro-header {
		margin-bottom: 1.5rem;
	}
	
	.ontario-solutions-intro-content {
		margin-bottom: 2rem;
	}
	
	.ontario-solutions-outcomes-v2 {
		grid-template-columns: 1fr;
		max-width: 300px;
	}
	
	.ontario-solutions-outcome-card {
		flex-direction: row;
		text-align: left;
		gap: 1rem;
		padding: 1.25rem;
	}
	
	.ontario-solutions-outcome-icon {
		margin-bottom: 0;
		flex-shrink: 0;
	}
	
	.ontario-solutions-intro-links-v2 {
		flex-direction: column;
		gap: 0.75rem;
	}
	
	.ontario-solutions-links-separator {
		display: none;
	}
}

/* ========== Solutions Outcomes V3 – Large Icon Modern Design ========== */
.ontario-solutions-outcomes-v3 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	width: 100%;
	max-width: 100%;
	margin: 0 auto 3rem;
	padding: 0;
}

.ontario-solutions-outcome-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 3rem 2rem 2.5rem;
	background: #ffffff;
	border-radius: 28px;
	box-shadow: 0 8px 32px rgba(66, 57, 60, 0.08), 0 2px 8px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(117, 172, 152, 0.12);
	transition: transform 0.4s ease, box-shadow 0.4s ease;
	position: relative;
	overflow: hidden;
	min-height: 380px;
}

.ontario-solutions-outcome-item::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 4px;
	transform: scaleX(0);
	transition: transform 0.4s ease;
}

.ontario-solutions-outcome-item:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 50px rgba(66, 57, 60, 0.14), 0 8px 20px rgba(0, 0, 0, 0.08);
}

.ontario-solutions-outcome-item:hover::after {
	transform: scaleX(1);
}

.ontario-solutions-outcome-item--speed::after {
	background: linear-gradient(90deg, var(--de-teal) 0%, var(--de-teal-light) 100%);
}

.ontario-solutions-outcome-item--data::after {
	background: linear-gradient(90deg, var(--de-gold) 0%, var(--de-gold-muted) 100%);
}

.ontario-solutions-outcome-item--visibility::after {
	background: linear-gradient(90deg, var(--de-sage) 0%, var(--de-sage-light) 100%);
}

.ontario-solutions-outcome-item--launch::after {
	background: linear-gradient(90deg, var(--de-teal-light) 0%, var(--de-gold) 100%);
}

/* Visual with Ring and Icon */
.ontario-solutions-outcome-visual {
	position: relative;
	width: 110px;
	height: 110px;
	margin-bottom: 1.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ontario-solutions-outcome-ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 3px dashed rgba(117, 172, 152, 0.25);
	animation: rotate-slow 20s linear infinite;
}

.ontario-solutions-outcome-item:hover .ontario-solutions-outcome-ring {
	animation-duration: 8s;
	border-color: rgba(117, 172, 152, 0.4);
}

.ontario-solutions-outcome-item--speed .ontario-solutions-outcome-ring {
	border-color: rgba(117, 172, 152, 0.3);
}

.ontario-solutions-outcome-item--data .ontario-solutions-outcome-ring {
	border-color: rgba(197, 178, 125, 0.3);
}

.ontario-solutions-outcome-item--visibility .ontario-solutions-outcome-ring {
	border-color: rgba(126, 148, 137, 0.3);
}

.ontario-solutions-outcome-item--launch .ontario-solutions-outcome-ring {
	border-color: rgba(128, 200, 191, 0.3);
}

@keyframes rotate-slow {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}

.ontario-solutions-outcome-icon-v3 {
	width: 84px;
	height: 84px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(145deg, #ffffff 0%, #f8faf9 100%);
	border-radius: 50%;
	box-shadow: 
		0 8px 24px rgba(66, 57, 60, 0.12),
		0 2px 6px rgba(0, 0, 0, 0.06),
		inset 0 1px 0 rgba(255, 255, 255, 0.8);
	position: relative;
	z-index: 1;
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.ontario-solutions-outcome-item:hover .ontario-solutions-outcome-icon-v3 {
	transform: scale(1.1);
	box-shadow: 
		0 12px 32px rgba(66, 57, 60, 0.18),
		0 4px 12px rgba(0, 0, 0, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.ontario-solutions-outcome-icon-v3 img {
	width: 44px;
	height: 44px;
	object-fit: contain;
}

/* Elementor library / SVG icons — match PNG slot size + per-card accent (teal / gold / sage) */
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
.ontario-solutions-outcome-icon-v3--el .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	line-height: 0;
}
.ontario-solutions-outcome-icon-v3--speed .ontario-solutions-outcome-icon-el-inner {
	color: var(--de-teal, #75ac98);
}
.ontario-solutions-outcome-icon-v3--data .ontario-solutions-outcome-icon-el-inner {
	color: var(--de-gold, #c5b27d);
}
.ontario-solutions-outcome-icon-v3--visibility .ontario-solutions-outcome-icon-el-inner {
	color: var(--de-sage, #6b8c81);
}
.ontario-solutions-outcome-icon-v3--launch .ontario-solutions-outcome-icon-el-inner {
	color: var(--de-teal-light, #8fbfa8);
}
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg {
	width: 44px !important;
	height: 44px !important;
	max-width: 44px;
	max-height: 44px;
	display: block;
	flex-shrink: 0;
}
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg path,
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg circle,
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg rect,
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg polygon,
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg polyline,
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg ellipse {
	fill: currentColor !important;
}
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg [fill="none"],
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg [fill="transparent"] {
	fill: none !important;
}
.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg [stroke]:not([stroke="none"]):not([stroke="0"]) {
	stroke: currentColor !important;
}

/* Content */
.ontario-solutions-outcome-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
}

.ontario-solutions-outcome-number {
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.15em;
	color: rgba(117, 172, 152, 0.5);
	text-transform: uppercase;
	margin-bottom: 0.25rem;
}

.ontario-solutions-outcome-item--speed .ontario-solutions-outcome-number {
	color: var(--de-teal);
	opacity: 0.6;
}

.ontario-solutions-outcome-item--data .ontario-solutions-outcome-number {
	color: var(--de-gold);
	opacity: 0.7;
}

.ontario-solutions-outcome-item--visibility .ontario-solutions-outcome-number {
	color: var(--de-sage);
	opacity: 0.7;
}

.ontario-solutions-outcome-item--launch .ontario-solutions-outcome-number {
	color: var(--de-teal-light);
	opacity: 0.8;
}

.ontario-solutions-outcome-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--de-charcoal);
	margin: 0;
	line-height: 1.4;
	max-width: 260px;
}

.ontario-solutions-outcome-desc {
	font-size: 0.9375rem;
	line-height: 1.65;
	color: var(--text-color);
	opacity: 0.85;
	margin: 0.5rem 0 0;
	max-width: 280px;
}

/* Responsive V3 */
@media (max-width: 1399.98px) {
	.ontario-solutions-outcomes-v3 {
		gap: 1.75rem;
	}
	
	.ontario-solutions-outcome-item {
		padding: 2.75rem 1.75rem 2.25rem;
		min-height: 360px;
	}
}

@media (max-width: 1199.98px) {
	.ontario-solutions-outcomes-v3 {
		gap: 1.5rem;
	}
	
	.ontario-solutions-outcome-item {
		padding: 2.5rem 1.5rem 2rem;
		min-height: 340px;
	}
	
	.ontario-solutions-outcome-visual {
		width: 100px;
		height: 100px;
	}
	
	.ontario-solutions-outcome-icon-v3 {
		width: 76px;
		height: 76px;
	}
	
	.ontario-solutions-outcome-icon-v3 img {
		width: 40px;
		height: 40px;
	}
	.ontario-solutions-outcome-icon-v3--el .ontario-solutions-outcome-icon-el-inner svg {
		width: 40px !important;
		height: 40px !important;
		max-width: 40px;
		max-height: 40px;
	}
}

@media (max-width: 991.98px) {
	.ontario-solutions-outcomes-v3 {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}
	
	.ontario-solutions-outcome-item {
		padding: 2.5rem 2rem 2rem;
		min-height: 320px;
	}
	
	.ontario-solutions-outcome-title {
		font-size: 1.1875rem;
	}
	
	.ontario-solutions-outcome-desc {
		font-size: 0.9375rem;
		max-width: 260px;
	}
}

@media (max-width: 767.98px) {
	.ontario-solutions-outcomes-v3 {
		gap: 1.25rem;
	}
	
	.ontario-solutions-outcome-item {
		padding: 2rem 1.5rem 1.75rem;
		min-height: 300px;
	}
	
	.ontario-solutions-outcome-visual {
		width: 90px;
		height: 90px;
		margin-bottom: 1.25rem;
	}
	
	.ontario-solutions-outcome-icon-v3 {
		width: 70px;
		height: 70px;
	}
	
	.ontario-solutions-outcome-icon-v3 img {
		width: 36px;
		height: 36px;
	}
	
	.ontario-solutions-outcome-title {
		font-size: 1.125rem;
	}
	
	.ontario-solutions-outcome-desc {
		font-size: 0.875rem;
		max-width: 240px;
	}
}

@media (max-width: 575.98px) {
	.ontario-solutions-outcomes-v3 {
		grid-template-columns: 1fr;
		max-width: 100%;
		gap: 1.25rem;
	}
	
	.ontario-solutions-outcome-item {
		padding: 2.25rem 2rem 2rem;
		min-height: auto;
	}
	
	.ontario-solutions-outcome-visual {
		width: 100px;
		height: 100px;
		margin-bottom: 1.5rem;
	}
	
	.ontario-solutions-outcome-icon-v3 {
		width: 76px;
		height: 76px;
	}
	
	.ontario-solutions-outcome-icon-v3 img {
		width: 40px;
		height: 40px;
	}
	
	.ontario-solutions-outcome-number {
		font-size: 0.8125rem;
	}
	
	.ontario-solutions-outcome-title {
		font-size: 1.25rem;
	}
	
	.ontario-solutions-outcome-desc {
		font-size: 0.9375rem;
		max-width: 280px;
	}
}

@media (max-width: 375px) {
	.ontario-solutions-outcome-item {
		padding: 2rem 1.5rem 1.75rem;
	}
	
	.ontario-solutions-outcome-visual {
		width: 90px;
		height: 90px;
	}
	
	.ontario-solutions-outcome-icon-v3 {
		width: 68px;
		height: 68px;
	}
	
	.ontario-solutions-outcome-icon-v3 img {
		width: 36px;
		height: 36px;
	}
	
	.ontario-solutions-outcome-title {
		font-size: 1.1875rem;
	}
	
	.ontario-solutions-outcome-desc {
		font-size: 0.875rem;
	}
}

/* ========== Industries page: Creative grid (theme-aligned, section-title + cards) ========== */
.ontario-industries-creative {
	position: relative;
	overflow: hidden;
}
.ontario-industries-creative-bg {
	position: absolute;
	inset: 0;
	background: linear-gradient(165deg, #f8faf9 0%, #eef4f2 40%, #f5f8f7 100%);
	opacity: 1;
	pointer-events: none;
}
.ontario-industries-creative-bg::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(197, 178, 125, 0.25), rgba(117, 172, 152, 0.25), transparent);
	opacity: 0.8;
}
.ontario-industries-creative .container {
	z-index: 1;
}

/* Header: use theme section-title (sub-title + h2 + p) */
.ontario-industries-creative .ontario-industries-header .section-title {
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}
.ontario-industries-creative .ontario-industries-header .section-title .sub-title {
	color: var(--primary-color);
}
.ontario-industries-creative .ontario-industries-header .section-title h2 {
	color: var(--heading-color);
}
.ontario-industries-creative .ontario-industries-header .section-title p {
	color: var(--text-color);
	font-size: 1rem;
	line-height: 1.7;
}

/* Grid of industry tiles (used when NOT zigzag) */
.ontario-industries-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 576px) {
	.ontario-industries-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.75rem;
	}
}
@media (min-width: 992px) {
	.ontario-industries-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 2rem;
	}
}

/* Shared: row inner (grid = column stack, zigzag = horizontal row) */
.ontario-industry-row-inner {
	display: flex;
	flex-direction: column;
	gap: 0;
}
.ontario-industry-row-content {
	flex: 1;
	min-width: 0;
}

/* Zigzag layout: alternating left/right rows */
.ontario-industries-creative--zigzag .ontario-industries-zigzag {
	display: block;
	gap: 0;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-tile {
	display: block;
	padding: 0;
	margin-bottom: 1.5rem;
	border-radius: 24px;
	overflow: visible;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-tile:last-child {
	margin-bottom: 0;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-inner {
	flex-direction: row;
	align-items: center;
	gap: 2rem;
	padding: 2rem 2.25rem;
	min-height: 0;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row--right .ontario-industry-row-inner {
	flex-direction: row-reverse;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-accent {
	top: 0;
	left: 0;
	right: auto;
	width: 4px;
	height: 100%;
	border-radius: 4px 0 0 4px;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row--right .ontario-industry-row-accent {
	left: auto;
	right: 0;
	border-radius: 0 4px 4px 0;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-icon {
	flex-shrink: 0;
	width: 120px;
	height: 120px;
	margin-bottom: 0;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-icon .ontario-industry-icon {
	width: 64px;
	height: 64px;
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-icon .ontario-industry-icon-inner--library svg {
	width: 64px !important;
	height: 64px !important;
	max-width: 64px;
	max-height: 64px;
}
@media (min-width: 992px) {
	.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-inner {
		padding: 2.5rem 3rem;
		gap: 2.5rem;
	}
	.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-icon {
		width: 140px;
		height: 140px;
	}
	.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-icon .ontario-industry-icon {
		width: 100px;
		height: 100px;
	}
	.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-icon .ontario-industry-icon-inner--library svg {
		width: 100px !important;
		height: 100px !important;
		max-width: 100px;
		max-height: 100px;
	}
}
.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-tile-content::before {
	margin: 0.5rem 0 0.75rem;
}

/* Tile card: theme gradient accent, larger icon, clear hierarchy */
.ontario-industry-tile {
	position: relative;
	background: var(--de-white);
	border-radius: 24px;
	box-shadow: 0 4px 24px rgba(66, 57, 60, 0.06), 0 1px 0 rgba(255, 255, 255, 0.85) inset;
	border: 1px solid rgba(197, 178, 125, 0.15);
	overflow: hidden;
	transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
	display: flex;
	flex-direction: column;
	padding: 2rem 1.5rem 1.75rem;
}
.ontario-industry-tile:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 48px rgba(66, 57, 60, 0.12), 0 1px 0 rgba(255, 255, 255, 0.9) inset;
	border-color: rgba(197, 178, 125, 0.35);
}
.ontario-industry-tile:hover .ontario-industry-tile-icon {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.18) 0%, rgba(117, 172, 152, 0.12) 100%);
	border-color: var(--primary-color);
}
.ontario-industry-tile:hover .ontario-industry-tile-accent {
	opacity: 1;
}

/* Gradient accent bar (theme gold–charcoal) */
.ontario-industry-tile-accent {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--gradient-brand);
	opacity: 0.85;
	transition: opacity 0.35s ease;
}

/* Icon – larger, theme-aligned */
.ontario-industry-tile-icon {
	flex-shrink: 0;
	width: 88px;
	height: 88px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.12) 0%, rgba(117, 172, 152, 0.08) 100%);
	border: 1px solid rgba(197, 178, 125, 0.25);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.35s ease, border-color 0.35s ease;
	margin-bottom: 1.25rem;
}
.ontario-industry-tile-icon .ontario-industry-icon {
	width: 52px;
	height: 52px;
	object-fit: contain;
	filter: none;
}
/* Elementor library icons (SVG/FA) in industries tiles */
.ontario-industry-tile-icon .ontario-industry-icon-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
.ontario-industry-tile-icon .ontario-industry-icon-inner--library .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	line-height: 1;
	color: var(--primary-color, #C5B27D);
}
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg {
	width: 52px !important;
	height: 52px !important;
	max-width: 52px;
	max-height: 52px;
	display: block;
}
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg path,
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg circle,
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg rect,
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg polygon,
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg polyline {
	fill: currentColor;
}
.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}
@media (min-width: 992px) {
	.ontario-industry-tile-icon {
		width: 100px;
		height: 100px;
		border-radius: 22px;
		margin-bottom: 1.5rem;
	}
	.ontario-industry-tile-icon .ontario-industry-icon {
		width: 100px;
		height: 100px;
	}
	.ontario-industry-tile-icon .ontario-industry-icon-inner--library svg {
		width: 100px !important;
		height: 100px !important;
		max-width: 100px;
		max-height: 100px;
	}
}

/* Title */
.ontario-industry-tile-title {
	font-size: 1.0625rem;
	font-weight: 700;
	color: var(--heading-color);
	line-height: 1.3;
	letter-spacing: 0.01em;
	margin: 0 0 0.875rem;
	font-family: var(--heading-font);
}
@media (min-width: 992px) {
	.ontario-industry-tile-title {
		font-size: 1.125rem;
		margin-bottom: 1rem;
	}
}

/* Content */
.ontario-industry-tile-content {
	padding: 0;
	border: none;
	flex: 1;
}
.ontario-industry-tile-content::before {
	content: "";
	display: block;
	width: 48px;
	height: 3px;
	background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
	border-radius: 2px;
	margin: 0 0 0.875rem;
}
.ontario-industry-tile-content p {
	font-size: 0.9375rem;
	line-height: 1.75;
	color: var(--text-color);
	margin: 0;
	font-family: var(--body-font);
}
@media (min-width: 992px) {
	.ontario-industry-tile-content p {
		font-size: 1rem;
		line-height: 1.8;
	}
}

/* Legacy Industries (non-creative) – keep for other templates if needed */
.ontario-industries-section:not(.ontario-industries-creative) {
	background: var(--de-white);
}
.ontario-industries-overview {
	margin-bottom: 2.5rem;
	max-width: 820px;
}
.ontario-industries-overview .ontario-industries-intro {
	margin-bottom: 1.25rem;
}
.ontario-industries-lede.ontario-solution-lede--accent {
	border-left-color: var(--de-teal);
}
.ontario-industries-lede p {
	font-size: 15px;
	line-height: 1.7;
}
@media (min-width: 768px) {
	.ontario-industries-lede p {
		font-size: 16px;
		line-height: 1.75;
	}
}
.ontario-industries-accordion {
	display: flex;
	flex-direction: column;
	gap: 0;
}
.ontario-industry-card {
	background: var(--de-white);
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 16px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
	margin-bottom: 12px;
	overflow: hidden;
	transition: box-shadow 0.25s ease, border-color 0.25s ease;
}
.ontario-industry-card:last-child {
	margin-bottom: 0;
}
.ontario-industry-card:hover {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	border-color: rgba(117, 172, 152, 0.2);
}
.ontario-industry-card:has(.collapse.show) {
	border-color: rgba(107, 140, 129, 0.35);
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.08);
}
.ontario-industry-card-header {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	padding: 1.125rem 1.25rem;
	cursor: pointer;
	transition: background 0.2s ease;
}
.ontario-industry-card-header:hover {
	background: rgba(117, 172, 152, 0.04);
}
.ontario-industry-card-header[aria-expanded="true"] {
	background: rgba(107, 140, 129, 0.06);
}
.ontario-industry-icon-wrap {
	flex-shrink: 0;
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: rgba(180, 150, 90, 0.12);
	border: 2px solid var(--de-gold-muted);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}
.ontario-industry-icon-wrap img,
.ontario-industry-icon-wrap .ontario-industry-icon {
	width: 52px;
	height: 52px;
	object-fit: contain;
	transition: filter 0.3s ease;
}
.ontario-industry-icon-wrap .ontario-industry-icon {
	filter: sepia(0.35) saturate(1.2) hue-rotate(5deg);
}
.ontario-industry-card-header:hover .ontario-industry-icon-wrap .ontario-industry-icon,
.ontario-industry-card-header[aria-expanded="true"] .ontario-industry-icon-wrap .ontario-industry-icon {
	filter: hue-rotate(81deg) brightness(92%) !important;
	transition-duration: 0.3s;
}
.ontario-industry-card-header:hover .ontario-industry-icon-wrap,
.ontario-industry-card-header[aria-expanded="true"] .ontario-industry-icon-wrap {
	background: rgba(107, 140, 129, 0.15);
	border-color: var(--de-teal);
}
.ontario-industry-title {
	flex: 1;
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--de-charcoal);
	margin: 0;
	min-width: 0;
}
.ontario-industry-toggle {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: var(--de-gold-muted);
	position: relative;
	transition: background 0.25s ease;
}
.ontario-industry-card-header:hover .ontario-industry-toggle,
.ontario-industry-card-header[aria-expanded="true"] .ontario-industry-toggle {
	background: var(--de-teal);
}
.ontario-industry-toggle::before,
.ontario-industry-toggle::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 12px;
	height: 2px;
	background: var(--de-white);
	transform: translate(-50%, -50%);
	transition: transform 0.25s ease;
}
.ontario-industry-toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}
.ontario-industry-card-header[aria-expanded="true"] .ontario-industry-toggle::after {
	transform: translate(-50%, -50%) rotate(0deg);
	opacity: 0;
}
.ontario-industry-content {
	padding: 1rem 1.25rem 1.25rem 1.25rem;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	background: rgba(107, 140, 129, 0.04);
	border-left: 4px solid var(--de-teal);
	margin-left: 1.25rem;
	margin-right: 1.25rem;
	margin-bottom: 1rem;
	border-radius: 0 0 12px 12px;
}
.ontario-industry-content p {
	font-size: 14px;
	line-height: 1.75;
	color: var(--text-color, var(--de-charcoal));
	margin: 0;
}
@media (min-width: 992px) {
	.ontario-industry-content {
		padding: 1.25rem 1.5rem 1.5rem 1.5rem;
		margin-left: 6rem;
		margin-right: 1.5rem;
		margin-bottom: 1.25rem;
		border-radius: 0 0 16px 0;
	}
	.ontario-industry-content p {
		font-size: 15px;
		line-height: 1.8;
	}
	.ontario-industry-icon-wrap {
		width: 80px;
		height: 80px;
	}
	.ontario-industry-icon-wrap img,
	.ontario-industry-icon-wrap .ontario-industry-icon {
		width: 58px;
		height: 58px;
	}
	.ontario-industry-card-header {
		padding: 1.25rem 1.5rem;
	}
	.ontario-industry-title {
		font-size: 17px;
	}
}
@media (max-width: 575.98px) {
	.ontario-industry-card-header {
		padding: 0.875rem 1rem;
		gap: 0.75rem;
	}
	.ontario-industry-icon-wrap {
		width: 60px;
		height: 60px;
	}
	.ontario-industry-icon-wrap img,
	.ontario-industry-icon-wrap .ontario-industry-icon {
		width: 42px;
		height: 42px;
	}
	.ontario-industry-content {
		padding: 0.875rem 1rem;
		margin-left: 1rem;
		margin-right: 1rem;
		margin-bottom: 0.875rem;
	}
	.ontario-industry-title {
		font-size: 14px;
	}
}

.mb-50 { margin-bottom: 3rem; }

/* ========== Team page – cards with bio (3 per row), creative AI/Tech design ========== */
.orbia-team-sec > .container > .row:last-of-type {
	margin-top: 60px;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio {
	background: #ffffff;
	border-radius: 24px;
	padding: 0 2rem 2.5rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(0, 0, 0, 0.04);
	position: relative;
	margin-top: 100px; /* Room for popping out image */
	margin-bottom: 20px;
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	height: calc(100% - 120px);
	display: flex;
	flex-direction: column;
	z-index: 1;
	/* Removed overflow: hidden so the image can pop out */
}

/* Tech glowing border effect on hover */
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio::after {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0; bottom: 0;
	border-radius: 24px;
	background-image: linear-gradient(266deg, #C5B27D -1.18%, #42393C 96.14%);
	z-index: -1;
	opacity: 0;
	transition: opacity 0.4s ease;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover {
	transform: translateY(-10px);
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1);
	border-color: transparent;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover::after {
	opacity: 1;
}

/* Larger, popping out profile image */
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .member-image {
	width: 180px;
	height: 180px;
	margin: -90px auto 1.5rem;
	border-radius: 50%;
	background: #fff;
	padding: 8px;
	box-shadow: 0 15px 35px rgba(0, 0, 0, 0.12);
	flex-shrink: 0;
	transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .member-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 50%;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover .member-image {
	transform: scale(1.08) translateY(-5px);
}

/* Info styling */
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .member-info {
	padding: 0;
	flex: 1;
	display: flex;
	flex-direction: column;
	text-align: center;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .member-info .title {
	font-size: 1.35rem;
	font-weight: 700;
	margin-bottom: 0.4rem;
	color: var(--heading-color);
	transition: color 0.3s ease;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover .member-info .title {
	color: #ffffff;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .member-info .position {
	font-size: 0.85rem;
	color: #C5B27D;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 1.25rem;
	display: inline-block;
	padding-bottom: 0;
	border-bottom: none;
	transition: color 0.3s ease;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover .member-info .position {
	color: #f8f8f8;
}

/* Full bio visible */
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .member-bio {
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--text-color, #555);
	margin: 0 0 1.5rem;
	display: block;
	text-align: center;
	opacity: 0.9;
	transition: all 0.3s ease;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover .member-bio {
	color: #f1f1f1;
	opacity: 1;
}

/* Social Box / LinkedIn Button */
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .social-box {
	margin-top: auto;
	display: flex;
	justify-content: center;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .social-box a.ontario-team-linkedin-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 24px;
	width: auto;
	height: auto;
	border-radius: 30px;
	background: #0077b5; /* Official LinkedIn Blue */
	color: #fff;
	font-weight: 600;
	font-size: 0.95rem;
	border: none;
	text-decoration: none;
	box-shadow: 0 4px 12px rgba(0, 119, 181, 0.25);
	transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio .social-box a.ontario-team-linkedin-btn i {
	font-size: 1.1rem;
}
.orbia-team-sec .orbia-team-item.ontario-team-item-with-bio:hover .social-box a.ontario-team-linkedin-btn {
	background: #ffffff !important;
	color: #0077b5 !important;
	transform: translateY(-3px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4);
}

/* Mobile slide-out menu: optional second logo when .menu-on (see Theme Options → Mobile menu open logo) */
.ontario-has-mobile-menu-open-logo .ontario-logo-mobile-sidebar--menu-on {
	display: none;
}
.theme-nav-menu.menu-on .ontario-has-mobile-menu-open-logo .ontario-logo-mobile-sidebar--default {
	display: none;
}
.theme-nav-menu.menu-on .ontario-has-mobile-menu-open-logo .ontario-logo-mobile-sidebar--menu-on {
	display: block;
}

/* Mobile only (<768px): header, home hero, page hero — body / .header-area for higher cascade priority */
@media (max-width: 767.98px) {
	body .header-area .header-navigation .site-branding {
		max-width: 130px;
	}
	body .header-area .header-navigation .theme-nav-menu.menu-on .site-branding {
		max-width: 200px;
	}
	body .header-area .header-navigation {
		padding: 5px 0;
	}
	body .header-area .header-navigation .theme-nav-menu .main-menu {
		margin-top: 5px;
	}
	body .orbia-hero_one .hero-wrapper .hero-content {
		padding-top: 110px;
		padding-bottom: 60px;
	}
	/* Page hero (icon, bg_cover padding, title) — mobile only, body prefix for priority */
	body .page-hero-icon-wrap {
		width: 90px;
		height: 90px;
		right: 14%;
		top: 47%;
	}
	body .page-hero.bg_cover {
		padding: 10px 0 10px;
	}
	body .page-hero .page-content h1 {
		font-size: 28px;
		margin-top: 70px;
	}
	.orbia-hero_one .hero-wrapper .hero-content .hero-button-wrap .orbia-avatar-box .avatar-list {
		display: flex;
		flex-direction: column;
	}
	.single-service-intro {
		margin-top: -50px;
		padding: 30px 0 70px;
	}
	.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row-inner {
		display: flex;
		flex-direction: column;
		padding: 1rem 1.25rem;
	}
	
	.ontario-industries-creative--zigzag .ontario-industries-zigzag .ontario-industry-row--right .ontario-industry-row-inner {
		display: flex;
		flex-direction: column;
	}
	.ontario-publication-downloads-wrap {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	body.page-template-page-innovation-landing .header-area .header-navigation .site-branding {
		max-width: 220px;
	}
}

/* ========== Laptop device (e.g. 1200 x 700) – responsive overrides ========== */
@media (min-width: 992px) and (max-width: 1299px) {
	.header-navigation .site-branding {
		max-width: 150px;
	}
	.header-navigation .main-menu ul > li {
		margin-left: 8px;
		margin-right: 8px;
	}
	.header-navigation .main-menu ul > li > a {
		font: 500 16px var(--heading-font);
		padding: 30px 0;
	}
	.nav-right-item .theme-btn {
		margin-left: 5px;
		padding: 15px 20px;
	}
	.page-hero {
		padding: 90px 0 20px;
	}
	.orbia-hero_one .hero-wrapper .hero-content h1 {
		font-size: 55px;
	}
	.orbia-hero_one .hero-wrapper .hero-image {
		max-width: 600px;
		right: 0;
	}
	.orbia-hero_one .hero-wrapper .hero-image img {
		width: 95%;
	}
}

/* ========== AI Practice Section – Premium Service Showcase ========== */
.ontario-ai-practice {
	position: relative;
	background: linear-gradient(135deg, #42393C 0%, #2a2426 100%);
	overflow: hidden;
}
.ontario-ai-practice-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: linear-gradient(266deg, rgba(197, 178, 125, 0.08) -1.18%, rgba(66, 57, 60, 0.15) 96.14%);
	z-index: 1;
}
.ontario-ai-practice-label {
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 600;
	color: #C5B27D;
	text-transform: uppercase;
	letter-spacing: 3px;
	margin-bottom: 1rem;
	padding: 0.5rem 1.5rem;
	border: 1px solid rgba(197, 178, 125, 0.4);
	border-radius: 30px;
}
.ontario-ai-practice-heading {
	font-size: 2.5rem;
	color: #fff;
	margin-bottom: 1.5rem;
	line-height: 1.3;
}
.ontario-ai-practice-heading .ontario-ocil-highlight {
	color: #C5B27D;
}
.ontario-ai-practice-lede {
	font-size: 1.125rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.8;
	max-width: 800px;
	margin: 0 auto;
}
.ontario-ai-practice-grid {
	margin-top: 3rem;
}
.ontario-ai-practice-card {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 20px;
	padding: 2.5rem 2rem;
	height: 100%;
	position: relative;
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	backdrop-filter: blur(10px);
}
.ontario-ai-practice-card:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(197, 178, 125, 0.4);
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}
.ontario-ai-practice-card--featured {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15) 0%, rgba(66, 57, 60, 0.3) 100%);
	border-color: rgba(197, 178, 125, 0.3);
}
.ontario-ai-practice-card--featured:hover {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.25) 0%, rgba(66, 57, 60, 0.4) 100%);
}
.ontario-ai-practice-card-icon {
	width: 70px;
	height: 70px;
	background: rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
	transition: all 0.3s ease;
}
.ontario-ai-practice-card:hover .ontario-ai-practice-card-icon {
	background: rgba(197, 178, 125, 0.25);
	transform: scale(1.1);
}
.ontario-ai-practice-card-icon img {
	width: 40px;
	height: 40px;
	object-fit: contain;
	opacity: 1 !important;
	filter: none !important;
}
.ontario-ai-practice-card-title {
	font-size: 1.25rem;
	color: #fff;
	margin-bottom: 1rem;
	font-weight: 600;
	line-height: 1.4;
}
.ontario-ai-practice-card-desc {
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.75);
	line-height: 1.7;
	margin-bottom: 0;
}
.ontario-ai-practice-card-badge {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	color: #42393C;
	background: #C5B27D;
	padding: 0.35rem 0.875rem;
	border-radius: 20px;
	margin-top: 1rem;
	text-transform: uppercase;
	letter-spacing: 1px;
}
.ontario-ai-practice-cta {
	padding: 1rem 2.5rem !important;
	font-size: 1.1rem !important;
}
@media (max-width: 991.98px) {
	.ontario-ai-practice-heading {
		font-size: 2rem;
	}
	.ontario-ai-practice-card {
		padding: 2rem 1.5rem;
	}
}
@media (max-width: 575.98px) {
	.ontario-ai-practice-heading {
		font-size: 1.75rem;
	}
	.ontario-ai-practice-card-icon {
		width: 60px;
		height: 60px;
	}
	.ontario-ai-practice-card-icon img {
		width: 32px;
		height: 32px;
	}
}

/* ========== Services Hub – Main Services Landing Page ========== */
.ontario-services-hub {
	background: linear-gradient(180deg, #ffffff 0%, #f8f8f8 100%);
	position: relative;
}
.ontario-services-hub-label {
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 600;
	color: #C5B27D;
	text-transform: uppercase;
	letter-spacing: 3px;
	margin-bottom: 1rem;
	padding: 0.5rem 1.5rem;
	border: 2px solid #C5B27D;
	border-radius: 30px;
}
.ontario-services-hub-heading {
	font-size: 2.75rem;
	color: var(--heading-color, #1a1a1a);
	margin-bottom: 1.5rem;
	line-height: 1.2;
	font-weight: 700;
}
.ontario-services-hub-heading .ontario-ocil-highlight {
	color: #C5B27D;
}
.ontario-services-hub-lede {
	font-size: 1.125rem;
	color: var(--text-color, #555);
	line-height: 1.8;
	max-width: 700px;
	margin: 0 auto;
}
.ontario-services-hub-grid {
	margin-top: 2rem;
}
.ontario-service-hub-card {
	background: #ffffff;
	border-radius: 24px;
	padding: 2.5rem 2rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
	height: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	overflow: hidden;
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.ontario-service-hub-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12);
	border-color: rgba(197, 178, 125, 0.3);
}
.ontario-service-hub-card--featured {
	background: linear-gradient(135deg, #42393C 0%, #2a2426 100%);
	color: #fff;
}
.ontario-service-hub-card--featured .ontario-service-hub-card-title {
	color: #fff;
}
.ontario-service-hub-card--featured .ontario-service-hub-card-desc {
	color: rgba(255, 255, 255, 0.85);
}
.ontario-service-hub-card--featured .ontario-service-hub-card-link {
	color: #C5B27D;
}
.ontario-service-hub-card--featured .ontario-service-hub-card-link:hover {
	color: #fff;
}
.ontario-service-hub-card-visual {
	width: 100px;
	height: 100px;
	background: rgba(197, 178, 125, 0.1);
	border-radius: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	margin-bottom: 1.5rem;
	transition: all 0.3s ease;
}
.ontario-service-hub-card:hover .ontario-service-hub-card-visual {
	background: rgba(197, 178, 125, 0.2);
	transform: scale(1.05);
}
.ontario-service-hub-card--featured .ontario-service-hub-card-visual {
	background: rgba(197, 178, 125, 0.15);
}
.ontario-service-hub-card-visual img {
	width: 80px;
	height: 80px;
	object-fit: contain;
	opacity: 1 !important;
	filter: none !important;
}
.ontario-service-hub-card-accent {
	position: absolute;
	top: -12px;
	right: -12px;
	width: 36px;
	height: 36px;
	background: #C5B27D;
	border-radius: 50%;
	opacity: 0.3;
	transition: all 0.3s ease;
}
.ontario-service-hub-card:hover .ontario-service-hub-card-accent {
	transform: scale(1.5);
	opacity: 0.2;
}
.ontario-service-hub-card-badge {
	position: absolute;
	top: 10px;
	right: 10px;
	font-size: 0.7rem;
	font-weight: 700;
	color: #42393C;
	background: #C5B27D;
	padding: 0.25rem 0.75rem;
	border-radius: 20px;
	text-transform: uppercase;
	letter-spacing: 1px;
}
.ontario-service-hub-card-content {
	flex: 1;
	display: flex;
	flex-direction: column;
}
.ontario-service-hub-card-title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--heading-color, #1a1a1a);
	margin-bottom: 1rem;
	line-height: 1.3;
}
.ontario-service-hub-card-desc {
	font-size: 0.9375rem;
	color: var(--text-color, #555);
	line-height: 1.7;
	margin-bottom: 1.5rem;
	flex: 1;
}
.ontario-service-hub-card-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: #C5B27D;
	text-decoration: none;
	transition: all 0.3s ease;
	margin-top: auto;
}
.ontario-service-hub-card-link i {
	transition: transform 0.3s ease;
}
.ontario-service-hub-card-link:hover {
	color: #a89968;
	gap: 0.75rem;
}
.ontario-service-hub-card-link:hover i {
	transform: translateX(4px);
}
.ontario-services-hub-cta {
	background: linear-gradient(135deg, #42393C 0%, #2a2426 100%);
	border-radius: 24px;
	padding: 3rem 2rem;
	margin-top: 2rem;
}

/* Services Hub AI Card (6th slot - AI focused) */
.ontario-service-hub-card--ai {
	background: linear-gradient(135deg, #42393C 0%, #2a2426 100%);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.ontario-service-hub-card--ai:hover {
	border-color: rgba(197, 178, 125, 0.5);
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3);
}
.ontario-service-hub-card-ai-glow {
	position: absolute;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(197, 178, 125, 0.15) 0%, transparent 70%);
	z-index: 0;
	pointer-events: none;
}
.ontario-service-hub-card--ai .ontario-service-hub-card-cta-content {
	padding: 1rem;
	position: relative;
	z-index: 1;
}
.ontario-service-hub-card-ai-icon {
	width: 90px;
	height: 90px;
	background: rgba(197, 178, 125, 0.15);
	border: 2px solid rgba(197, 178, 125, 0.3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
	transition: all 0.4s ease;
	animation: ai-pulse 3s ease-in-out infinite;
}
@keyframes ai-pulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(197, 178, 125, 0.4); }
	50% { box-shadow: 0 0 0 15px rgba(197, 178, 125, 0); }
}
.ontario-service-hub-card--ai:hover .ontario-service-hub-card-ai-icon {
	background: rgba(197, 178, 125, 0.3);
	border-color: #C5B27D;
	transform: scale(1.05);
}
.ontario-service-hub-card-ai-icon i {
	font-size: 2.75rem;
	color: #C5B27D;
	transition: all 0.3s ease;
}
.ontario-service-hub-card-ai-badge {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	color: #42393C;
	background: #C5B27D;
	padding: 0.35rem 1rem;
	border-radius: 20px;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: 1rem;
}
.ontario-service-hub-card--ai .ontario-service-hub-card-title {
	font-size: 1.25rem;
	color: #fff;
	margin-bottom: 0.75rem;
}
.ontario-service-hub-card--ai .ontario-service-hub-card-desc {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.8);
	margin-bottom: 1.5rem;
}
.ontario-service-hub-card-cta-btn {
	padding: 0.75rem 1.5rem !important;
	font-size: 0.9375rem !important;
}
.ontario-services-hub-cta-text {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: 1.5rem;
	font-weight: 500;
}
@media (max-width: 991.98px) {
	.ontario-services-hub-heading {
		font-size: 2.25rem;
	}
	.ontario-service-hub-card {
		padding: 2rem 1.5rem;
	}
}
@media (max-width: 575.98px) {
	.ontario-services-hub-heading {
		font-size: 1.875rem;
	}
	.ontario-services-hub-cta {
		padding: 2rem 1.5rem;
	}
	.ontario-service-hub-card-visual {
		width: 90px;
		height: 90px;
	}
	.ontario-service-hub-card-visual img {
		width: 70px;
		height: 70px;
	}
}

/* ========== Single Service Page ========== */
.service-hero {
	min-height: 500px;
	display: flex;
	align-items: center;
	position: relative;
	overflow: hidden;
}
.service-hero-content {
	position: relative;
	z-index: 2;
	padding: 3rem 0;
}
.service-hero-category {
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 600;
	color: #C5B27D;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: 1rem;
	padding: 0.5rem 1.25rem;
	background: rgba(197, 178, 125, 0.15);
	border: 1px solid rgba(197, 178, 125, 0.3);
	border-radius: 30px;
}
.service-hero-title {
	font-size: 3rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 1.5rem;
	line-height: 1.2;
}
.service-hero-desc {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.9);
	max-width: 700px;
	margin: 0 auto 2rem;
	line-height: 1.7;
}
.service-hero-icon {
	width: 120px;
	height: 120px;
	background: rgba(255, 255, 255, 0.1);
	border: 2px solid rgba(197, 178, 125, 0.3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	backdrop-filter: blur(10px);
}
.service-hero-icon img {
	width: 70px;
	height: 70px;
	object-fit: contain;
}
.service-hero-shape {
	position: absolute;
	bottom: -50px;
	right: -50px;
	width: 300px;
	height: 300px;
	opacity: 0.2;
	z-index: 1;
}
.service-hero-shape img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.service-content-section {
	background: #ffffff;
}
.service-elementor-content {
	padding: 2rem 0;
}
.service-default-content {
	max-width: 800px;
	margin: 0 auto;
}
.service-excerpt {
	font-size: 1.25rem;
	color: var(--text-color, #555);
	line-height: 1.8;
	margin-bottom: 2rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.service-body {
	font-size: 1rem;
	line-height: 1.8;
	color: var(--text-color, #555);
}
.service-body h2,
.service-body h3 {
	color: var(--heading-color, #1a1a1a);
	margin-top: 2rem;
	margin-bottom: 1rem;
}
.service-body ul,
.service-body ol {
	margin-bottom: 1.5rem;
	padding-left: 1.5rem;
}
.service-body li {
	margin-bottom: 0.5rem;
}
.service-cta-section {
	background: linear-gradient(135deg, #f8f8f8 0%, #ffffff 100%);
}
.service-cta-card {
	background: linear-gradient(135deg, #42393C 0%, #2a2426 100%);
	border-radius: 24px;
	padding: 3rem;
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
}
.service-cta-card h3 {
	font-size: 1.75rem;
	color: #fff;
	margin-bottom: 1rem;
}
.service-cta-card p {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 1.5rem;
}
.related-services-section {
	background: #ffffff;
	border-top: 1px solid rgba(0, 0, 0, 0.05);
}
.related-services-title {
	font-size: 2rem;
	color: var(--heading-color, #1a1a1a);
}
.related-service-card {
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 16px;
	padding: 1.5rem 2rem;
	transition: all 0.3s ease;
}
.related-service-card:hover {
	border-color: #C5B27D;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
	transform: translateY(-3px);
}
.related-service-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: var(--heading-color, #1a1a1a);
	text-decoration: none;
}
.related-service-link h4 {
	font-size: 1.1rem;
	font-weight: 600;
	margin: 0;
}
.related-service-arrow {
	width: 40px;
	height: 40px;
	background: rgba(197, 178, 125, 0.15);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #C5B27D;
	transition: all 0.3s ease;
}
.related-service-card:hover .related-service-arrow {
	background: #C5B27D;
	color: #fff;
}
@media (max-width: 991.98px) {
	.service-hero-title {
		font-size: 2.5rem;
	}
	.service-hero-icon {
		width: 100px;
		height: 100px;
	}
	.service-hero-icon img {
		width: 60px;
		height: 60px;
	}
}
@media (max-width: 575.98px) {
	.service-hero-title {
		font-size: 2rem;
	}
	.service-hero-desc {
		font-size: 1.1rem;
	}
	.service-cta-card {
		padding: 2rem 1.5rem;
	}
}

/* ========== Global Page Hero with Icon ========== */
.page-hero {
	position: relative;
	overflow: hidden;
}
/* Icon behind overlay: z-index 0 */
.page-hero-icon-wrap {
	position: absolute;
	right: 16%;
	top: 56%;
	transform: translateY(-50%);
    width: 280px;
    height: 280px;
	opacity: 1;
	pointer-events: none;
	z-index: 0;
}
.page-hero-icon-img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.page-hero .container,
.page-hero-inner {
	position: relative;
	z-index: 2;
}
/* ========== Single Service Page - Premium Creative Design ========== */

/* Service Intro Section - Floating Card */
.single-service-intro {
	position: relative;
	margin-top: -100px;
	padding: 40px 0 80px;
	z-index: 10;
}
.single-service-intro-card {
	position: relative;
	background: #ffffff;
	border-radius: 30px;
	padding: 50px 40px;
	box-shadow: 0 25px 80px rgba(0, 0, 0, 0.08), 0 10px 30px rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.15);
	overflow: hidden;
}
.single-service-intro-glow {
	position: absolute;
	top: -50%;
	right: -20%;
	width: 400px;
	height: 400px;
	background: radial-gradient(circle, rgba(197, 178, 125, 0.15) 0%, transparent 70%);
	pointer-events: none;
}
.single-service-intro-visual {
	display: flex;
	justify-content: center;
	align-items: center;
}
.single-service-intro-icon-wrap {
	position: relative;
	width: 180px;
	height: 180px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.single-service-intro-icon {
	width: 100px;
	height: 100px;
	object-fit: contain;
	position: relative;
	z-index: 3;
	transition: transform 0.4s ease;
}
.single-service-intro-icon-ring {
	position: absolute;
	width: 100%;
	height: 100%;
	border: 2px solid rgba(197, 178, 125, 0.3);
	border-radius: 50%;
	animation: pulse-ring 3s ease-out infinite;
}
.single-service-intro-icon-ring::before {
	content: '';
	position: absolute;
	top: 10px;
	left: 10px;
	right: 10px;
	bottom: 10px;
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 50%;
}
.single-service-intro-icon-accent {
	position: absolute;
	width: 140px;
	height: 140px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15) 0%, rgba(197, 178, 125, 0.05) 100%);
	border-radius: 50%;
	z-index: 1;
}
@keyframes pulse-ring {
	0% { transform: scale(1); opacity: 1; }
	50% { transform: scale(1.05); opacity: 0.6; }
	100% { transform: scale(1); opacity: 1; }
}
.single-service-intro-card:hover .single-service-intro-icon {
	transform: scale(1.1) rotate(5deg);
}
.single-service-intro-content {
	padding-left: 20px;
}
.single-service-intro-label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: linear-gradient(135deg, #C5B27D 0%, #a89968 100%);
	color: #ffffff;
	padding: 8px 18px;
	border-radius: 30px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 20px;
}
.single-service-intro-title {
	font-size: 2.2rem;
	font-weight: 700;
	color: #1a1a2e;
	margin-bottom: 20px;
	line-height: 1.3;
}
.single-service-intro-desc {
	font-size: 1.1rem;
	color: #555555;
	line-height: 1.7;
	margin-bottom: 15px;
}
.single-service-intro-benefits {
	font-size: 1.1rem;
	color: #1a1a2e;
	line-height: 1.7;
	font-weight: 600;
	margin-bottom: 25px;
	padding-top: 5px;
}
.single-service-intro-actions {
	display: flex;
	gap: 15px;
	flex-wrap: wrap;
}
.single-service-intro-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	background: linear-gradient(135deg, #C5B27D 0%, #a89968 100%);
	color: #ffffff;
	border-radius: 50px;
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	transition: all 0.3s ease;
	box-shadow: 0 8px 25px rgba(197, 178, 125, 0.3);
}
.single-service-intro-btn:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 35px rgba(197, 178, 125, 0.4);
	color: #ffffff;
}
.single-service-intro-btn i {
	transition: transform 0.3s ease;
}
.single-service-intro-btn:hover i {
	transform: translateX(3px) translateY(3px);
}
.single-service-intro-btn--outline {
	background: transparent;
	border: 2px solid #C5B27D;
	color: #C5B27D;
	box-shadow: none;
}
.single-service-intro-btn--outline:hover {
	background: #C5B27D;
	color: #ffffff;
}

@media (max-width: 991.98px) {
	.single-service-intro-card {
		padding: 35px 25px;
	}
	.single-service-intro-icon-wrap {
		width: 140px;
		height: 140px;
		margin-bottom: 25px;
	}
	.single-service-intro-icon {
		width: 70px;
		height: 70px;
	}
	.single-service-intro-content {
		padding-left: 0;
		text-align: center;
	}
	.single-service-intro-title {
		font-size: 1.8rem;
	}
	.single-service-intro-actions {
		justify-content: center;
	}
}

/* Service Content Sections */
#service-content,
.single-service-content {
	position: relative;
	/* Gap for sticky header when scrolling to this section */
	scroll-margin-top: 100px;
}
.single-service-excerpt {
	margin-bottom: 40px;
}
.single-service-excerpt-box {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.08) 0%, rgba(197, 178, 125, 0.03) 100%);
	border-left: 4px solid #C5B27D;
	padding: 30px 35px;
	border-radius: 0 16px 16px 0;
	position: relative;
}
.single-service-excerpt-box i {
	position: absolute;
	top: 20px;
	left: 20px;
	font-size: 2rem;
	color: rgba(197, 178, 125, 0.3);
}
.single-service-excerpt-box p {
	font-size: 1.15rem;
	color: #444444;
	line-height: 1.8;
	margin: 0;
	padding-left: 30px;
	font-style: italic;
}
.single-service-body {
	font-size: 1.05rem;
	line-height: 1.9;
	color: #333333;
}
.single-service-body h2,
.single-service-body h3 {
	color: #1a1a2e;
	margin-top: 40px;
	margin-bottom: 20px;
}
.single-service-body p {
	margin-bottom: 20px;
}
.single-service-body ul,
.single-service-body ol {
	margin-bottom: 25px;
	padding-left: 25px;
}
.single-service-body li {
	margin-bottom: 10px;
}

/* Key Learning Objectives (Service meta) */
.single-service-learning-objectives {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.single-service-learning-objectives-section .single-service-learning-objectives {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}

.single-service-learning-objectives-title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--heading-color, #1a1a2e);
	margin: 0 0 24px 0;
}

.single-service-learning-objectives-list {
	list-style: decimal;
	padding-left: 1.5em;
	margin: 0 0 0 0;
	counter-reset: none;
}

.single-service-learning-objectives-item {
	margin-bottom: 20px;
	font-size: 1rem;
	line-height: 1.6;
	color: var(--heading-color, #333);
}

.single-service-learning-objectives-item-title {
	display: inline;
	font-weight: 700;
	color: var(--heading-color, #1a1a2e);
}

.single-service-learning-objectives-points {
	list-style: disc;
	padding-left: 1.5em;
	margin: 8px 0 0 0;
}

.single-service-learning-objectives-points li {
	margin-bottom: 6px;
	font-weight: 400;
}

/* Target Audience (Service meta – list style) */
.single-service-target-audience {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.single-service-target-audience-section .single-service-target-audience {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}

.single-service-target-audience-title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--heading-color, #1a1a2e);
	margin: 0 0 20px 0;
}

.single-service-target-audience-list {
	list-style: disc;
	padding-left: 1.5em;
	margin: 0;
}

.single-service-target-audience-list li {
	margin-bottom: 10px;
	font-size: 1rem;
	line-height: 1.6;
	color: var(--heading-color, #333);
}

/* Stats Strip */
.single-service-stats {
	background: linear-gradient(135deg, #1a1a2e 0%, #2d2d44 50%, #1a1a2e 100%);
	padding: 60px 0;
	position: relative;
	overflow: hidden;
}
.single-service-stats::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C5B27D' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.single-service-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 30px;
	position: relative;
	z-index: 1;
}
.single-service-stat {
	display: flex;
	align-items: center;
	gap: 15px;
	padding: 20px;
}
.single-service-stat-icon {
	width: 60px;
	height: 60px;
	background: rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	color: #C5B27D;
	flex-shrink: 0;
}
.single-service-stat-number {
	display: block;
	font-size: 2rem;
	font-weight: 700;
	color: #C5B27D;
	line-height: 1;
}
.single-service-stat-label {
	display: block;
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.7);
	margin-top: 5px;
}
@media (max-width: 991.98px) {
	.single-service-stats-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 575.98px) {
	.single-service-stats-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.single-service-stat {
		justify-content: center;
		text-align: center;
		flex-direction: column;
	}
}

/* CTA Section - Glassmorphism */
.single-service-cta {
	position: relative;
	padding: 100px 0;
	overflow: hidden;
}
.single-service-cta-bg {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, #f8f6f3 0%, #ffffff 50%, #f8f6f3 100%);
}
.single-service-cta-card {
	position: relative;
	background: rgba(255, 255, 255, 0.9);
	backdrop-filter: blur(20px);
	border-radius: 30px;
	padding: 60px 50px;
	text-align: center;
	border: 1px solid rgba(197, 178, 125, 0.2);
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.1), 0 0 0 1px rgba(197, 178, 125, 0.1);
	overflow: hidden;
}
.single-service-cta-glow {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(197, 178, 125, 0.15) 0%, transparent 60%);
	pointer-events: none;
}
.single-service-cta-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15) 0%, rgba(197, 178, 125, 0.05) 100%);
	border: 1px solid rgba(197, 178, 125, 0.3);
	color: #C5B27D;
	padding: 10px 22px;
	border-radius: 30px;
	font-size: 0.85rem;
	font-weight: 600;
	margin-bottom: 25px;
}
.single-service-cta-content h3 {
	font-size: 2rem;
	font-weight: 700;
	color: #1a1a2e;
	margin-bottom: 20px;
}
.single-service-cta-content p {
	font-size: 1.1rem;
	color: #555555;
	max-width: 500px;
	margin: 0 auto 30px;
}
.single-service-cta-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
}
.single-service-cta-btn {
	padding: 16px 40px !important;
	font-size: 1rem !important;
}
.single-service-cta-link {
	color: #666666;
	text-decoration: none;
	font-size: 0.95rem;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: color 0.3s ease;
}
.single-service-cta-link i {
	color: #C5B27D;
}
.single-service-cta-link:hover {
	color: #C5B27D;
}
.single-service-cta-shapes {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	pointer-events: none;
	overflow: hidden;
}
.single-service-cta-shape {
	position: absolute;
	border-radius: 50%;
	background: rgba(197, 178, 125, 0.08);
}
.single-service-cta-shape--1 {
	width: 100px;
	height: 100px;
	top: 20%;
	left: 10%;
	animation: float-shape 6s ease-in-out infinite;
}
.single-service-cta-shape--2 {
	width: 60px;
	height: 60px;
	top: 60%;
	right: 15%;
	animation: float-shape 8s ease-in-out infinite reverse;
}
.single-service-cta-shape--3 {
	width: 80px;
	height: 80px;
	bottom: 20%;
	left: 20%;
	animation: float-shape 7s ease-in-out infinite;
}
@keyframes float-shape {
	0%, 100% { transform: translateY(0) rotate(0deg); }
	50% { transform: translateY(-20px) rotate(10deg); }
}
@media (max-width: 767.98px) {
	.single-service-cta-card {
		padding: 40px 25px;
	}
	.single-service-cta-content h3 {
		font-size: 1.5rem;
	}
}

/* Related Services */
.single-service-related {
	background: linear-gradient(180deg, #ffffff 0%, #f8f6f3 100%);
}
.single-service-related-label {
	display: inline-block;
	background: rgba(197, 178, 125, 0.1);
	color: #C5B27D;
	padding: 8px 20px;
	border-radius: 20px;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	margin-bottom: 15px;
}
.single-service-related-title {
	font-size: 2.2rem;
	font-weight: 700;
	color: #1a1a2e;
}
.single-service-related-grid {
	perspective: 1000px;
}
.single-service-related-card {
	display: block;
	position: relative;
	background: #ffffff;
	border-radius: 20px;
	padding: 35px 30px;
	text-align: center;
	text-decoration: none;
	border: 1px solid rgba(197, 178, 125, 0.15);
	transition: all 0.4s ease;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.05);
	overflow: hidden;
}
.single-service-related-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, #C5B27D 0%, #a89968 100%);
	transform: scaleX(0);
	transition: transform 0.4s ease;
}
.single-service-related-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1);
}
.single-service-related-card:hover::before {
	transform: scaleX(1);
}
.single-service-related-card-bg {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.03) 0%, transparent 50%);
	opacity: 0;
	transition: opacity 0.4s ease;
}
.single-service-related-card:hover .single-service-related-card-bg {
	opacity: 1;
}
.single-service-related-card-icon {
	width: 70px;
	height: 70px;
	margin: 0 auto 20px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1) 0%, rgba(197, 178, 125, 0.05) 100%);
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.4s ease;
}
.single-service-related-card:hover .single-service-related-card-icon {
	background: linear-gradient(135deg, #C5B27D 0%, #a89968 100%);
	transform: scale(1.1);
}
.single-service-related-card-icon img {
	width: 40px;
	height: 40px;
	object-fit: contain;
	transition: all 0.4s ease;
	filter: none !important;
	opacity: 1 !important;
}
.single-service-related-card:hover .single-service-related-card-icon img {
	filter: brightness(0) invert(1) !important;
}
.single-service-related-card h4 {
	font-size: 1.2rem;
	font-weight: 700;
	color: #1a1a2e;
	margin-bottom: 15px;
	transition: color 0.3s ease;
}
.single-service-related-card:hover h4 {
	color: #C5B27D;
}
.single-service-related-card-arrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #999999;
	font-size: 0.9rem;
	font-weight: 500;
	transition: all 0.3s ease;
}
.single-service-related-card:hover .single-service-related-card-arrow {
	color: #C5B27D;
	gap: 12px;
}

/* ========== Contact Page – Creative Design ========== */
.ontario-contact-section {
	position: relative;
	background-size: cover;
	background-position: center;
	margin: 0 30px;
	border-radius: 30px;
	overflow: hidden;
}
.ontario-contact-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(36, 36, 36, 0.92) 0%, rgba(66, 57, 60, 0.88) 50%, rgba(36, 36, 36, 0.92) 100%);
	z-index: 1;
}

.ontario-contact-form-wrapper {
	position: relative;
	z-index: 2;
	background: rgba(255, 255, 255, 0.03);
	backdrop-filter: blur(20px);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 24px;
	padding: 50px 45px;
}

.ontario-contact-form-header {
	margin-bottom: 35px;
}

.ontario-contact-subtitle {
	display: inline-block;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--de-teal-light);
	margin-bottom: 12px;
}

.ontario-contact-title {
	font-size: clamp(1.8rem, 4vw, 2.5rem);
	font-weight: 700;
	color: #ffffff;
	margin-bottom: 12px;
	line-height: 1.2;
}

.ontario-contact-lead {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.6;
}

.ontario-form-group {
	position: relative;
}

.ontario-form-label {
	display: block;
	font-size: 14px;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: 10px;
}

.ontario-form-control {
	width: 100%;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 12px;
	padding: 14px 18px;
	font-size: 15px;
	color: #ffffff;
	transition: all 0.3s ease;
}

.ontario-form-control::placeholder {
	color: rgba(255, 255, 255, 0.4);
}

.ontario-form-control:focus {
	background: rgba(255, 255, 255, 0.08);
	border-color: var(--de-teal-light);
	outline: none;
	box-shadow: 0 0 0 3px rgba(117, 172, 152, 0.15);
}

.ontario-form-select {
	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'%3E%3Cpath fill='%23ffffff' fill-opacity='0.5' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 15px center;
	padding-right: 40px;
	cursor: pointer;
}

.ontario-form-select option {
	background: #242424;
	color: #ffffff;
}

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

.ontario-form-submit-wrapper {
	margin-top: 10px;
}

.ontario-contact-submit {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 16px 32px;
	font-size: 15px;
	font-weight: 600;
	border-radius: 50px;
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
}

.ontario-contact-submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.ontario-contact-submit i {
	font-size: 14px;
	transition: transform 0.3s ease;
}

.ontario-contact-submit:hover i {
	transform: translateX(4px);
}

/* Contact Info Card */
.ontario-contact-info-wrapper {
	position: relative;
	z-index: 2;
	height: 100%;
}

.ontario-contact-info-card {
	background: linear-gradient(145deg, rgba(197, 178, 125, 0.15) 0%, rgba(117, 172, 152, 0.1) 100%);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 24px;
	padding: 45px 40px;
	height: 100%;
	position: relative;
	overflow: hidden;
}

.ontario-contact-info-card::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 100%;
	height: 100%;
	background: radial-gradient(circle, rgba(197, 178, 125, 0.1) 0%, transparent 70%);
	pointer-events: none;
}

.ontario-contact-info-header {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-bottom: 25px;
}

.ontario-contact-icon {
	width: 60px;
	height: 60px;
	background: linear-gradient(135deg, var(--de-gold-muted) 0%, var(--de-teal-light) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-contact-icon i {
	font-size: 24px;
	color: #ffffff;
}

.ontario-contact-icon svg {
	width: 24px;
	height: 24px;
	fill: #ffffff;
}

.ontario-contact-info-title {
	font-size: 1.4rem;
	font-weight: 600;
	color: #ffffff;
	line-height: 1.3;
}

.ontario-contact-info-text {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.75);
	line-height: 1.6;
	margin-bottom: 30px;
}

.ontario-contact-details {
	display: flex;
	flex-direction: column;
	gap: 22px;
	margin-bottom: 35px;
}

.ontario-contact-detail-item {
	display: flex;
	align-items: flex-start;
	gap: 16px;
}

.ontario-contact-detail-icon {
	width: 44px;
	height: 44px;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-contact-detail-icon i {
	font-size: 18px;
	color: var(--de-teal-light);
}

.ontario-contact-detail-icon svg {
	width: 18px;
	height: 18px;
	fill: var(--de-teal-light);
}

.ontario-contact-detail-content h5 {
	font-size: 14px;
	font-weight: 600;
	color: var(--de-gold-muted);
	margin-bottom: 6px;
	letter-spacing: 0.02em;
}

.ontario-contact-detail-content p,
.ontario-contact-detail-content a {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.6;
	margin: 0;
}

.ontario-contact-detail-content a:hover {
	color: var(--de-teal-light);
	text-decoration: none;
}

.ontario-contact-social {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding-top: 25px;
}

.ontario-contact-social h5 {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.6);
	margin-bottom: 15px;
}

.ontario-contact-social-links {
	display: flex;
	gap: 12px;
}

.ontario-contact-social-links a {
	width: 44px;
	height: 44px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	font-size: 16px;
	transition: all 0.3s ease;
}

.ontario-contact-social-links a:hover {
	background: var(--de-gold-muted);
	border-color: var(--de-gold-muted);
	color: #ffffff;
	transform: translateY(-3px);
}

.ontario-contact-social-links a svg {
	width: 16px;
	height: 16px;
	fill: #ffffff;
}

.ontario-contact-social-links a:hover svg {
	fill: #ffffff;
}

/* Contact Map inside Info Card */
.ontario-contact-map {
	margin-top: 25px;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.1);
	height: 320px;
	position: relative;
}

.ontario-contact-map-link {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none;
}

.ontario-contact-map iframe {
	display: block;
	width: 100%;
	height: 100%;
	filter: grayscale(40%) contrast(1.05);
	border-radius: 12px;
}

.ontario-contact-map-overlay {
	position: absolute;
	inset: 0;
	background: rgba(36, 36, 36, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.3s ease;
	border-radius: 12px;
}

.ontario-contact-map-link:hover .ontario-contact-map-overlay {
	opacity: 1;
	background: rgba(36, 36, 36, 0.6);
}

.ontario-contact-view-map {
	background: var(--de-gold-muted);
	color: #ffffff;
	padding: 10px 18px;
	border-radius: 25px;
	font-size: 13px;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transform: translateY(10px);
	transition: transform 0.3s ease;
}

.ontario-contact-map-link:hover .ontario-contact-view-map {
	transform: translateY(0);
}

/* Map Section */
.ontario-map-section {
	position: relative;
	margin: 0 30px 40px;
	border-radius: 20px;
	overflow: hidden;
}

.ontario-map-wrapper {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
}

.ontario-map-wrapper iframe {
	display: block;
	filter: grayscale(30%) contrast(1.1);
}

/* Responsive */
@media (max-width: 1399px) {
	.ontario-contact-form-wrapper { padding: 40px 35px; }
	.ontario-contact-info-card { padding: 40px 35px; }
}

@media (max-width: 1199px) {
	.ontario-contact-section { margin: 0 15px; border-radius: 20px; }
	.ontario-map-section { margin: 0 15px 30px; }
}

@media (max-width: 991px) {
	.ontario-contact-section { margin: 0; border-radius: 0; }
	.ontario-contact-form-wrapper { 
		padding: 35px 25px; 
		margin-bottom: 30px;
	}
	.ontario-contact-info-card { padding: 35px 25px; }
	.ontario-map-section { margin: 0; border-radius: 0; }
}

@media (max-width: 767px) {
	.ontario-contact-form-wrapper { padding: 30px 20px; }
	.ontario-contact-info-card { padding: 30px 20px; }
	.ontario-contact-info-header { flex-direction: column; text-align: center; }
	.ontario-contact-icon { margin: 0 auto; }
}

@media (max-width: 575px) {
	.ontario-contact-title { font-size: 1.6rem; }
	.ontario-form-control { padding: 12px 15px; }
}

/* Contact Form Alerts */
.ontario-contact-alerts {
	margin-bottom: 20px;
}

.ontario-contact-alert {
	padding: 16px 20px;
	border-radius: 12px;
	margin-bottom: 15px;
	font-size: 14px;
	font-weight: 500;
	animation: ontarioAlertSlide 0.4s ease-out;
	display: flex;
	align-items: center;
	gap: 12px;
	position: relative;
}

.ontario-contact-alert i {
	font-size: 18px;
	flex-shrink: 0;
}

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

.ontario-alert-success {
	background: rgba(117, 172, 152, 0.15);
	border: 1px solid rgba(117, 172, 152, 0.3);
	color: #75ac98;
}

.ontario-alert-success i {
	color: #75ac98;
}

.ontario-alert-error {
	background: rgba(220, 53, 69, 0.15);
	border: 1px solid rgba(220, 53, 69, 0.3);
	color: #ff6b7a;
}

.ontario-alert-error i {
	color: #ff6b7a;
}

.ontario-alert-close {
	background: none;
	border: none;
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
	margin-left: auto;
	padding: 0;
	color: inherit;
	opacity: 0.6;
	transition: opacity 0.2s;
}

.ontario-alert-close:hover {
	opacity: 1;
}

/* Form Loading State */
.ontario-contact-submit.ontario-loading {
	opacity: 0.7;
	cursor: not-allowed;
}

.ontario-contact-submit.ontario-loading:hover {
	transform: none;
}

/* Input Error State */
.ontario-form-control.ontario-input-error {
	border-color: #dc3232;
	box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.ontario-form-control.ontario-input-error:focus {
	border-color: #dc3232;
	box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.15);
}

/* ==========================================================================
   Academy (LearnPress courses)
   ========================================================================== */
.academy-hero.page-hero .page-hero-overlay,
.single-course-hero.page-hero .page-hero-overlay {
	background: linear-gradient(135deg, rgba(66, 57, 60, 0.75) 0%, rgba(66, 57, 60, 0.5) 50%, rgba(0, 128, 128, 0.4) 100%);
}

.ontario-academy-section .ontario-academy-intro {
	font-size: 1.0625rem;
	line-height: 1.6;
	color: var(--de-charcoal, #42393c);
}

.ontario-academy-empty {
	text-align: center;
	color: var(--de-charcoal, #42393c);
	margin: 2rem 0;
}

.ontario-academy-empty-wrap {
	text-align: center;
	padding: 3rem 1rem;
}

/* Academy toolbar: view toggle + count */
.ontario-academy-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 16px 24px;
	margin-bottom: 32px;
	padding-bottom: 20px;
	border-bottom: 1px solid rgba(66, 57, 60, 0.1);
}

.ontario-academy-view-toggle {
	display: inline-flex;
	background: #f5f5f5;
	border-radius: 10px;
	padding: 4px;
	box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.06);
}

.ontario-academy-view-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 500;
	color: var(--de-charcoal, #42393c);
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.ontario-academy-view-btn:hover {
	background: rgba(255, 255, 255, 0.8);
	color: var(--de-teal, #6B8C81);
}

.ontario-academy-view-btn.is-active {
	background: #fff;
	color: var(--de-teal, #6B8C81);
	box-shadow: 0 2px 8px rgba(66, 57, 60, 0.12);
}

.ontario-academy-view-btn i {
	font-size: 1em;
	opacity: 0.9;
}

.ontario-academy-count {
	margin: 0;
	font-size: 14px;
	color: #6b6366;
}

.ontario-academy-count .ontario-academy-count-total,
.ontario-academy-count .ontario-academy-count-from,
.ontario-academy-count .ontario-academy-count-to {
	font-weight: 600;
	color: var(--de-charcoal, #42393c);
}

/* Academy list view */
.ontario-academy-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 4px 24px rgba(66, 57, 60, 0.08);
	overflow: hidden;
	border: 1px solid rgba(66, 57, 60, 0.06);
}

.ontario-course-list-item {
	margin: 0;
	padding: 0;
	border: none;
	border-bottom: 1px solid rgba(66, 57, 60, 0.08);
}

.ontario-course-list-item:first-child .ontario-course-list-item-link {
	border-top-left-radius: 12px;
	border-top-right-radius: 12px;
}

.ontario-course-list-item:last-child .ontario-course-list-item-link {
	border-bottom-left-radius: 12px;
	border-bottom-right-radius: 12px;
}

.ontario-course-list-item-link {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 0;
	text-decoration: none;
	color: inherit;
	background: #fff;
	transition: background 0.25s ease, box-shadow 0.25s ease;
	min-height: 180px;
	overflow: hidden;
}

.ontario-course-list-item-link:hover {
	background: #fafafa;
	box-shadow: 0 4px 24px rgba(66, 57, 60, 0.08);
}

.ontario-course-list-item-thumb {
	flex: 0 0 280px;
	min-width: 200px;
	max-width: 100%;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: #eee;
	flex-shrink: 0;
}

.ontario-course-list-item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease;
}

.ontario-course-list-item-link:hover .ontario-course-list-item-thumb img {
	transform: scale(1.03);
}

.ontario-course-list-item-body {
	flex: 1 1 280px;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 24px 28px;
	text-align: left;
}

.ontario-course-list-item-meta-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 16px;
	margin-bottom: 8px;
	font-size: 13px;
	color: #6b6366;
}

.ontario-course-list-item-cat {
	display: inline-block;
	padding: 4px 10px;
	background: rgba(107, 140, 129, 0.12);
	color: var(--de-teal, #6B8C81);
	border-radius: 6px;
	font-weight: 500;
}

.ontario-course-list-item-title {
	font-size: 1.25rem;
	line-height: 1.35;
	margin: 0 0 10px;
	color: var(--de-charcoal, #242424);
	transition: color 0.2s ease;
}

.ontario-course-list-item-link:hover .ontario-course-list-item-title {
	color: var(--de-teal, #6B8C81);
}

.ontario-course-list-item-excerpt {
	font-size: 0.9375rem;
	line-height: 1.55;
	color: #6b6366;
	margin: 0 0 10px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ontario-course-list-item-instructor,
.ontario-course-list-item-date {
	font-size: 13px;
	color: #6b6366;
	margin: 0;
}

.ontario-course-list-item-aside {
	flex: 0 0 160px;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	justify-content: center;
	gap: 12px;
	padding: 24px 28px;
	border-left: 1px solid rgba(66, 57, 60, 0.06);
	text-align: right;
}

.ontario-course-list-item-price {
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--de-teal, #6B8C81);
}

.ontario-course-list-item-price .course-price-free {
	color: var(--de-charcoal, #242424);
}

.ontario-course-list-item-price del {
	color: #6b6366;
	font-weight: 400;
	margin-right: 4px;
}

.ontario-course-list-item-cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 500;
	color: var(--de-teal, #6B8C81);
	transition: gap 0.2s ease, color 0.2s ease;
}

.ontario-course-list-item-link:hover .ontario-course-list-item-cta {
	gap: 10px;
	color: var(--de-charcoal, #242424);
}

@media (max-width: 991px) {
	.ontario-course-list-item-thumb {
		flex: 0 0 100%;
		aspect-ratio: 16 / 9;
		min-width: 100%;
	}
	.ontario-course-list-item-body {
		padding: 20px 20px 12px;
	}
	.ontario-course-list-item-aside {
		flex: 1 1 100%;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		border-left: none;
		border-top: 1px solid rgba(66, 57, 60, 0.06);
		padding: 16px 20px 20px;
		text-align: left;
	}
	.ontario-course-list-item-cta {
		order: 1;
	}
	.ontario-course-list-item-price {
		order: 2;
	}
}

@media (max-width: 575px) {
	.ontario-academy-toolbar {
		flex-direction: column;
		align-items: flex-start;
	}
	.ontario-course-list-item-excerpt {
		-webkit-line-clamp: 3;
		line-clamp: 3;
	}
}

/* Academy course grid cards */
.ontario-course-grid {
	margin-left: -15px;
	margin-right: -15px;
}

.ontario-course-card-wrap {
	height: 100%;
	margin-bottom: 40px;
}

.ontario-course-card.orbia-blog-post-item {
	display: flex;
	flex-direction: column;
	height: 100%;
	background: #fff;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(66, 57, 60, 0.08);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ontario-course-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 40px rgba(66, 57, 60, 0.12);
}

.ontario-course-card-link {
	display: flex;
	flex-direction: column;
	flex: 1;
	text-decoration: none;
	color: inherit;
}

.ontario-course-card-thumb {
	display: block;
	position: relative;
	flex-shrink: 0;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.ontario-course-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease;
}

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

.ontario-course-card-content {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 24px 20px;
}

.ontario-course-card-title {
	font-size: 1.125rem;
	line-height: 1.35;
	margin-bottom: 8px;
	color: var(--de-charcoal, #42393c);
	transition: color 0.25s ease;
}

.ontario-course-card-link:hover .ontario-course-card-title {
	color: var(--de-teal, #008080);
}

.ontario-course-card-meta {
	font-size: 13px;
	color: #6b6366;
	margin-bottom: 4px;
}

.ontario-course-card-details {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	margin: 12px 0;
	font-size: 12px;
	color: #6b6366;
}

.ontario-course-card-detail:not(:last-child)::after {
	content: "·";
	margin-left: 12px;
	color: #aaa;
}

.ontario-course-card-date {
	font-size: 13px;
	color: var(--de-charcoal, #42393c);
	margin-bottom: 8px;
}

.ontario-course-card-date--soon {
	font-style: italic;
	color: #6b6366;
}

.ontario-course-card-price {
	margin-bottom: 12px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--de-teal, #008080);
}

.ontario-course-card-price del {
	color: #6b6366;
	font-weight: 400;
	margin-right: 6px;
}

.ontario-course-card-cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: auto;
	padding-top: 12px;
	font-size: 14px;
	font-weight: 500;
	color: var(--de-teal, #008080);
	transition: gap 0.2s ease;
}

.ontario-course-card-link:hover .ontario-course-card-cta {
	gap: 10px;
}

/* Academy pagination */
.ontario-academy-pagination {
	text-align: center;
}

.ontario-academy-pagination .nav-links {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}

.ontario-academy-pagination .nav-links a,
.ontario-academy-pagination .nav-links span {
	display: inline-block;
	padding: 8px 14px;
	min-width: 44px;
	text-align: center;
	background: #fff;
	border: 1px solid rgba(66, 57, 60, 0.15);
	border-radius: 8px;
	color: var(--de-charcoal, #42393c);
	text-decoration: none;
	transition: border-color 0.2s, color 0.2s, background 0.2s;
}

.ontario-academy-pagination .nav-links a:hover {
	border-color: var(--de-teal, #008080);
	color: var(--de-teal, #008080);
	background: rgba(0, 128, 128, 0.04);
}

.ontario-academy-pagination .nav-links .current {
	border-color: var(--de-teal, #008080);
	background: var(--de-teal, #008080);
	color: #fff;
}

/* Single course hero (override) */
.single-course-hero.page-hero .page-content h1 {
	margin-bottom: 0.5rem;
}

/* LearnPress single course: match theme spacing and typography */
.lp-content-area .course-summary {
	max-width: 100%;
}

.ontario-single-course-wrap .lp-content-area {
	padding-top: 0;
}

/* ==========================================================================
   Single Course Sidebar - Modern Design
   ========================================================================== */

/* Main Sidebar Container - Sticky */
.course-summary-sidebar {
	position: sticky;
	top: 100px;
}

.course-summary-sidebar__inner {
	position: relative;
}

/* Sidebar Preview Card */
.ontario-course-sidebar-preview {
	background: #fff;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 8px 32px rgba(66, 57, 60, 0.12);
	border: 1px solid rgba(66, 57, 60, 0.06);
}

/* Course Thumbnail */
.ontario-course-sidebar-thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: linear-gradient(135deg, var(--de-charcoal, #42393c) 0%, #5a5054 100%);
}

.ontario-course-sidebar-thumb::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 60%, rgba(66, 57, 60, 0.3) 100%);
	pointer-events: none;
}

.ontario-course-sidebar-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease;
}

.ontario-course-sidebar-thumb:hover .ontario-course-sidebar-img {
	transform: scale(1.05);
}

/* Featured Badge */
.ontario-course-sidebar-thumb .course-featured {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 2;
	background: var(--de-gold, #d4a017);
	color: #fff;
	padding: 6px 12px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

/* Course Info Card */
.ontario-course-sidebar-info {
	padding: 0;
}

.ontario-course-info-header {
	background: linear-gradient(135deg, var(--de-teal, #008080) 0%, #006666 100%);
	padding: 18px 20px;
}

.ontario-course-info-title {
	color: #fff;
	font-size: 16px;
	font-weight: 600;
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ontario-course-info-body {
	padding: 8px 0;
}

/* Info Row - Modern Design */
.ontario-course-info-row {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 20px;
	border-bottom: 1px solid rgba(66, 57, 60, 0.08);
	transition: background 0.2s ease;
}

.ontario-course-info-row:last-child {
	border-bottom: none;
}

.ontario-course-info-row:hover {
	background: rgba(0, 128, 128, 0.03);
}

/* Info Icon Wrap */
.ontario-course-info-icon-wrap {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	background: rgba(0, 128, 128, 0.1);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ontario-course-info-icon-wrap i {
	font-size: 14px;
	color: var(--de-teal, #008080);
}

/* Info Content */
.ontario-course-info-content {
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 2px;
}

.ontario-course-info-label {
	font-size: 12px;
	color: #8a8285;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	font-weight: 500;
}

.ontario-course-info-value {
	font-size: 14px;
	color: var(--de-charcoal, #42393c);
	font-weight: 600;
}

/* Price Styling */
.ontario-course-info-row:first-child .ontario-course-info-icon-wrap {
	background: rgba(212, 160, 23, 0.15);
}

.ontario-course-info-row:first-child .ontario-course-info-icon-wrap i {
	color: var(--de-gold, #d4a017);
}

.ontario-course-info-value .course-price {
	font-size: 16px;
	color: var(--de-teal, #008080);
}

.ontario-course-info-value .course-price-free {
	color: var(--de-charcoal, #42393c);
}

.ontario-course-info-value .course-price del,
.ontario-course-info-value .course-price .origin-price {
	color: #999;
	font-weight: 400;
	font-size: 13px;
	margin-right: 8px;
}

.ontario-course-info-value .course-price .price-suffix,
.ontario-course-info-value .course-price-suffix {
	display: block;
	font-size: 11px;
	font-weight: 400;
	color: #888;
	margin-top: 2px;
}

/* Instructor Section */
.ontario-course-sidebar-instructor {
	margin-top: 20px;
	padding: 20px;
	background: #f9f9f9;
	border-radius: 12px;
	border: 1px solid rgba(66, 57, 60, 0.06);
}

.ontario-course-instructor-title {
	font-size: 14px;
	font-weight: 600;
	color: var(--de-charcoal, #42393c);
	margin: 0 0 12px 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ontario-course-instructor-content {
	font-size: 14px;
}

.ontario-course-instructor-content .course-instructor {
	display: flex;
	align-items: center;
	gap: 10px;
}

.ontario-course-instructor-content .course-instructor a {
	color: var(--de-teal, #008080);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s ease;
}

.ontario-course-instructor-content .course-instructor a:hover {
	color: var(--de-charcoal, #42393c);
}

/* Action Buttons */
.ontario-course-sidebar-actions {
	margin-top: 20px;
	padding: 0 20px 20px;
}

.ontario-course-sidebar-actions .course-buttons {
	margin: 0;
}

.ontario-course-sidebar-actions .lp-button,
.ontario-course-sidebar-actions button[type="submit"],
.ontario-course-sidebar-actions .button {
	width: 100%;
	padding: 14px 20px;
	font-size: 15px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: 10px;
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
}

.ontario-course-sidebar-actions .button-purchase,
.ontario-course-sidebar-actions .lp-button.purchase,
.ontario-course-sidebar-actions .button.enroll {
	background: linear-gradient(135deg, var(--de-teal, #008080) 0%, #006666 100%);
	color: #fff;
}

.ontario-course-sidebar-actions .button-purchase:hover,
.ontario-course-sidebar-actions .lp-button.purchase:hover,
.ontario-course-sidebar-actions .button.enroll:hover {
	background: linear-gradient(135deg, #006666 0%, var(--de-teal, #008080) 100%);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 128, 128, 0.3);
}

/* Status Section (Progress, Graduation) */
.ontario-course-sidebar-status {
	margin-top: 20px;
	padding: 20px;
	background: #f9f9f9;
	border-radius: 12px;
	border: 1px solid rgba(66, 57, 60, 0.06);
}

.ontario-course-sidebar-status .course-graduation,
.ontario-course-sidebar-status .lp-user-progress,
.ontario-course-sidebar-status .lp-user-time {
	margin: 0;
	padding: 0;
	border: none;
}

.ontario-course-sidebar-status .lp-user-progress {
	margin-top: 16px;
}

/* Responsive Adjustments */
@media (max-width: 991px) {
	.course-summary-sidebar {
		position: relative;
		top: auto;
		margin-top: 40px;
	}
}

/* Academy single course (ontario_course) main content */
.ontario-course-main .ontario-course-heading {
	font-size: 1.35em;
	margin-top: 1.5em;
	margin-bottom: 0.75em;
	color: var(--de-charcoal, #42393c);
}
.ontario-course-main .ontario-course-heading:first-child { margin-top: 0; }
.ontario-course-modules-list,
.ontario-course-objectives-list {
	list-style: none;
	padding-left: 0;
	margin: 0 0 1em;
}
.ontario-course-modules-list li,
.ontario-course-objectives-list li {
	margin-bottom: 0.75em;
	padding-left: 1.25em;
	position: relative;
}
.ontario-course-modules-list li::before {
	content: '\f02d';
	font-family: 'Font Awesome 5 Pro';
	font-weight: 900;
	position: absolute;
	left: 0;
	color: var(--de-teal, #008080);
}
.ontario-course-objectives-list li::before {
	content: '\f00c';
	font-family: "Font Awesome 5 Pro" !important;
	font-weight: 900 !important;
	position: absolute;
	left: 0;
	color: var(--primary-color);
}
.ontario-course-module-desc {
	margin-top: 0.35em;
	font-size: 0.95em;
	opacity: 0.9;
}
.ontario-course-map-embed {
	margin-top: 1em;
	border-radius: 8px;
	overflow: hidden;
	max-width: 100%;
}
.ontario-course-map-embed iframe {
	display: block;
	width: 100%;
	border: 0;
}
.ontario-course-sidebar-instructor .ontario-course-instructor-content {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}
.ontario-course-instructor-avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
}
.ontario-course-enquiry-btn {
	width: 100%;
	display: inline-block;
	text-align: center;
	padding: 14px 24px;
	background: linear-gradient(135deg, var(--de-teal, #008080) 0%, #006666 100%);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-weight: 600;
	text-decoration: none;
	transition: opacity 0.2s;
}
.ontario-course-enquiry-btn:hover {
	color: #fff;
	opacity: 0.95;
}
.ontario-course-start-date { margin-top: 0; border-top: none; }

/* Instructor profile single */
.ontario-instructor-role { font-size: 1.1em; opacity: 0.9; margin-bottom: 0.5em; }
.ontario-instructor-thumb { margin-bottom: 1.5em; }
.ontario-instructor-img { border-radius: 8px; max-width: 100%; height: auto; }
.ontario-instructor-contact h3,
.ontario-instructor-courses h3 { margin-top: 1.5em; margin-bottom: 0.5em; }
.ontario-instructor-links { list-style: none; padding-left: 0; margin: 0; }
.ontario-instructor-links li { margin-bottom: 0.5em; }
.ontario-instructor-links a { display: inline-flex; align-items: center; gap: 8px; }
.ontario-instructor-courses-list { list-style: none; padding-left: 0; margin: 0; }
.ontario-instructor-courses-list li { margin-bottom: 0.5em; }

/* ==========================================================================
   Single Course Main Layout Enhancement
   ========================================================================== */

/* Course Summary Container */
#learn-press-course.course-summary {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
}

/* Main Content Area */
.course-summary-content {
	flex: 1;
	min-width: 0;
}

/* Sidebar Area */
.course-summary-sidebar {
	width: 360px;
	flex-shrink: 0;
}

@media (max-width: 991px) {
	#learn-press-course.course-summary {
		flex-direction: column;
	}

	.course-summary-sidebar {
		width: 100%;
	}
}

/* Course Tabs Styling */
.course-summary-content .learn-press-nav-tabs {
	background: #fff;
	border-radius: 12px;
	padding: 0;
	margin-bottom: 24px;
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.06);
	border: 1px solid rgba(66, 57, 60, 0.08);
}

.course-summary-content .learn-press-nav-tabs .nav-tab {
	padding: 16px 24px;
	font-size: 14px;
	font-weight: 500;
	color: #6b6366;
	border: none;
	border-bottom: 2px solid transparent;
	transition: all 0.3s ease;
}

.course-summary-content .learn-press-nav-tabs .nav-tab:hover {
	color: var(--de-teal, #008080);
	background: rgba(0, 128, 128, 0.03);
}

.course-summary-content .learn-press-nav-tabs .nav-tab.active {
	color: var(--de-teal, #008080);
	border-bottom-color: var(--de-teal, #008080);
	font-weight: 600;
}

/* Course Tabs Content */
.course-summary-content .course-tab-panel {
	background: #fff;
	border-radius: 12px;
	padding: 32px;
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.06);
	border: 1px solid rgba(66, 57, 60, 0.08);
}

.course-summary-content .course-tab-panel h2,
.course-summary-content .course-tab-panel h3 {
	color: var(--de-charcoal, #42393c);
	margin-bottom: 20px;
	font-weight: 600;
}

.course-summary-content .course-tab-panel p {
	color: #6b6366;
	line-height: 1.7;
	margin-bottom: 16px;
}

/* Curriculum Section */
.course-summary-content .lp-course-curriculum {
	background: #fff;
	border-radius: 12px;
	padding: 24px;
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.06);
	border: 1px solid rgba(66, 57, 60, 0.08);
}

.course-summary-content .curriculum-sections .section-header {
	padding: 16px 20px;
	background: #f9f9f9;
	border-radius: 10px;
	margin-bottom: 12px;
}

.course-summary-content .curriculum-sections .section-title {
	font-size: 15px;
	font-weight: 600;
	color: var(--de-charcoal, #42393c);
}

/* Instructor Section */
.course-summary-content .course-instructor-section {
	background: #fff;
	border-radius: 12px;
	padding: 32px;
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.06);
	border: 1px solid rgba(66, 57, 60, 0.08);
}

.course-summary-content .instructor-avatar img {
	border-radius: 50%;
	border: 3px solid var(--de-teal, #008080);
}

/* Course Description */
.course-summary-content .course-description {
	background: #fff;
	border-radius: 12px;
	padding: 32px;
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.06);
	border: 1px solid rgba(66, 57, 60, 0.08);
	margin-bottom: 24px;
}

.course-summary-content .course-description h2 {
	font-size: 22px;
	color: var(--de-charcoal, #42393c);
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--de-teal, #008080);
	display: inline-block;
}

/* FAQ Section */
.course-summary-content .course-faq {
	background: #fff;
	border-radius: 12px;
	padding: 32px;
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.06);
	border: 1px solid rgba(66, 57, 60, 0.08);
}

.course-summary-content .faq-item {
	border-bottom: 1px solid rgba(66, 57, 60, 0.08);
	padding: 20px 0;
}

.course-summary-content .faq-item:last-child {
	border-bottom: none;
}

.course-summary-content .faq-question {
	font-weight: 600;
	color: var(--de-charcoal, #42393c);
	margin-bottom: 8px;
}

.course-summary-content .faq-answer {
	color: #6b6366;
	line-height: 1.7;
}

/* ==========================================================================
   MODERN ACADEMY PAGE DESIGN
   ========================================================================== */

/* Hero Section */
.ontario-academy-hero {
	min-height: 500px;
	display: flex;
	align-items: center;
}

.ontario-academy-hero-content {
	padding: 60px 0;
}

.ontario-academy-hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(10px);
	padding: 10px 20px;
	border-radius: 50px;
	font-size: 14px;
	font-weight: 500;
	color: #fff;
	margin-bottom: 24px;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.ontario-academy-hero-badge i {
	color: var(--primary-color);
}

.ontario-academy-hero-content h1 {
	font-size: 3.5rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 20px;
	line-height: 1.2;
}

.ontario-academy-hero-subtitle {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.85);
	max-width: 600px;
	margin: 0 auto 40px;
	line-height: 1.6;
}

.ontario-academy-hero-stats {
	display: flex;
	justify-content: center;
	gap: 60px;
	margin-bottom: 40px;
}

.ontario-academy-stat {
	text-align: center;
}

.ontario-academy-stat .stat-number {
	display: block;
	font-size: 2.5rem;
	font-weight: 700;
	color: #fff;
	line-height: 1;
}

.ontario-academy-stat .stat-label {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.7);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-top: 8px;
}

.ontario-academy-breadcrumb {
	display: flex;
	justify-content: center;
	list-style: none;
	padding: 0;
	margin: 0;
	gap: 12px;
	font-size: 14px;
}

.ontario-academy-breadcrumb a {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
	transition: color 0.3s;
}

.ontario-academy-breadcrumb a:hover {
	color: #fff;
}

.ontario-academy-breadcrumb li:not(:last-child)::after {
	content: '/';
	margin-left: 12px;
	color: rgba(255, 255, 255, 0.4);
}

.ontario-academy-breadcrumb li:last-child {
	color: #fff;
}

@media (max-width: 991px) {
	.ontario-academy-hero-content h1 {
		font-size: 2.5rem;
	}
	.ontario-academy-hero-stats {
		gap: 30px;
	}
	.ontario-academy-stat .stat-number {
		font-size: 2rem;
	}
}

@media (max-width: 575px) {
	.ontario-academy-hero-content h1 {
		font-size: 2rem;
	}
	.ontario-academy-hero-stats {
		flex-direction: column;
		gap: 20px;
	}
}

/* Featured Courses Section */
.ontario-academy-featured {
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.03) 0%, var(--de-white) 100%);
}

.ontario-section-header {
	margin-bottom: 50px;
}

.ontario-section-badge {
	display: inline-block;
	background: var(--primary-color);
	color: var(--de-white);
	padding: 8px 20px;
	border-radius: 50px;
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 20px;
}

.ontario-section-title {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	margin-bottom: 16px;
}

.ontario-section-subtitle {
	font-size: 1.125rem;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	max-width: 600px;
	margin: 0 auto;
}

/* Featured Course Card */
.ontario-course-featured-card {
	background: var(--de-white);
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, 0.08);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s;
	height: 100%;
}

.ontario-course-featured-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
	border-color: rgba(0, 0, 0, 0.12);
}

.ontario-featured-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
	height: 100%;
}

.ontario-featured-card-image {
	position: relative;
	height: 240px;
	background: rgba(0, 0, 0, 0.04);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.ontario-featured-card-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	transition: transform 0.4s ease;
}

.ontario-course-featured-card:hover .ontario-featured-card-image img {
	transform: scale(1.03);
}

.ontario-featured-card-badge {
	position: absolute;
	top: 16px;
	left: 16px;
	background: var(--primary-color);
	color: var(--de-white);
	padding: 6px 14px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ontario-featured-card-content {
	padding: 28px;
}

.ontario-featured-card-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	margin-bottom: 12px;
	line-height: 1.4;
	transition: color 0.3s;
}

.ontario-featured-card-link:hover .ontario-featured-card-title {
	color: var(--primary-color);
}

.ontario-featured-card-excerpt {
	font-size: 15px;
	color: var(--heading-color, #242424);
	opacity: 0.75;
	line-height: 1.6;
	margin-bottom: 20px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ontario-featured-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.ontario-featured-card-meta span {
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	display: flex;
	align-items: center;
	gap: 6px;
}

.ontario-featured-card-meta i {
	color: var(--primary-color);
}

.ontario-featured-card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ontario-featured-card-price {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
}

.ontario-featured-card-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 24px;
	background: rgba(59, 130, 246, 0.15);
	color: var(--primary-color);
	border-radius: 50px;
	font-size: 14px;
	font-weight: 600;
	transition: all 0.3s ease;
}

.ontario-featured-card-link:hover .ontario-featured-card-cta {
	background: var(--primary-color);
	color: var(--de-white);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Main Academy Section & Filters Sidebar */
.ontario-academy-main {
	background: var(--de-white);
}

.ontario-academy-filters {
	position: sticky;
	top: 100px;
}

.ontario-filter-block {
	background: var(--de-white);
	border-radius: 12px;
	padding: 24px;
	margin-bottom: 20px;
	border: 1px solid rgba(66, 57, 60, 0.08);
	box-shadow: 0 2px 12px rgba(66, 57, 60, 0.04);
}

.ontario-filter-title {
	font-size: 15px;
	font-weight: 700;
	color: var(--de-charcoal);
	margin-bottom: 20px;
	display: flex;
	align-items: center;
	gap: 10px;
}

.ontario-filter-title i {
	color: var(--primary-color);
	font-size: 14px;
}

.ontario-search-input-wrap {
	position: relative;
}

.ontario-search-input {
	width: 100%;
	padding: 14px 44px 14px 16px;
	border: 2px solid rgba(66, 57, 60, 0.1);
	border-radius: 12px;
	font-size: 14px;
	transition: border-color 0.3s, box-shadow 0.3s;
	background: #fff;
}

.ontario-search-input:focus {
	outline: none;
	border-color: var(--primary-color);
	box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.06);
}

.ontario-search-btn {
	position: absolute;
	right: 6px;
	top: 50%;
	transform: translateY(-50%);
	background: var(--primary-color);
	color: var(--de-white);
	border: none;
	width: 36px;
	height: 36px;
	border-radius: 10px;
	cursor: pointer;
	transition: background 0.3s, opacity 0.3s;
}

.ontario-search-btn:hover {
	opacity: 0.9;
}

.ontario-filter-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.ontario-filter-list li {
	margin-bottom: 8px;
}

.ontario-filter-link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 16px;
	border-radius: 10px;
	font-size: 14px;
	color: var(--de-palette-charcoal);
	opacity: 0.9;
	text-decoration: none;
	transition: all 0.3s;
	border: 1px solid transparent;
}

.ontario-filter-link:hover {
	background: rgba(0, 0, 0, 0.04);
	color: var(--primary-color);
	opacity: 1;
}

.ontario-filter-link.is-active {
	background: var(--primary-color);
	color: var(--de-white);
	border-color: var(--primary-color);
	opacity: 1;
}

.ontario-filter-count {
	font-size: 12px;
	padding: 4px 10px;
	background: rgba(66, 57, 60, 0.08);
	border-radius: 20px;
	transition: background 0.3s;
}

.ontario-filter-link.is-active .ontario-filter-count {
	background: rgba(255, 255, 255, 0.2);
}

.ontario-filter-link i {
	margin-right: 8px;
	width: 16px;
}

.ontario-filter-reset {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px;
	background: rgba(220, 53, 69, 0.08);
	color: #dc3545;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	transition: background 0.3s;
}

.ontario-filter-reset:hover {
	background: rgba(220, 53, 69, 0.15);
}

/* Academy header: title + toolbar */
.ontario-academy-header {
	margin-bottom: 28px;
}

.ontario-academy-title {
	margin: 0 0 6px 0;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	letter-spacing: -0.02em;
	line-height: 1.25;
}

/* Toolbar & Active Filters - light design */
.ontario-academy-toolbar {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 16px 24px;
	padding: 20px 24px;
	background: rgba(0, 0, 0, 0.02);
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	margin-bottom: 0;
}

.ontario-academy-toolbar-left {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-academy-results-text {
	margin: 0;
	font-size: 14px;
	font-weight: 500;
	color: var(--heading-color, #242424);
	opacity: 0.85;
}

.ontario-academy-results-text .results-search {
	color: var(--primary-color);
	font-weight: 500;
}

.ontario-academy-toolbar-right {
	display: flex;
	align-items: center;
	gap: 16px;
	flex: 1;
	min-width: 0;
	justify-content: flex-end;
}

.ontario-academy-toolbar-right .ontario-orderby-select {
	flex-shrink: 0;
	width: auto;
	min-width: 180px;
}

.ontario-academy-search-form {
	flex: 1;
	min-width: 0;
	max-width: 480px;
}

.ontario-toolbar-search-wrap {
	display: flex;
	align-items: center;
	gap: 0;
	background: var(--de-white);
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 10px;
	overflow: hidden;
	transition: border-color 0.25s, box-shadow 0.25s;
}

.ontario-toolbar-search-wrap:focus-within {
	border-color: var(--primary-color);
	box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.04);
}

.ontario-toolbar-search-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	flex-shrink: 0;
	color: var(--heading-color, #242424);
	opacity: 0.45;
}

.ontario-toolbar-search-icon i {
	font-size: 14px;
}

.ontario-toolbar-search-input {
	flex: 1;
	min-width: 0;
	padding: 12px 12px 12px 0;
	font-size: 14px;
	border: none;
	background: transparent;
	color: var(--heading-color, #242424);
}

.ontario-toolbar-search-input::placeholder {
	color: var(--heading-color, #242424);
	opacity: 0.5;
}

.ontario-toolbar-search-input:focus {
	outline: none;
}

.ontario-toolbar-search-btn {
	padding: 10px 18px;
	margin: 5px;
	background: var(--primary-color);
	color: var(--de-white);
	border: none;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: opacity 0.25s, transform 0.2s;
	flex-shrink: 0;
}

.ontario-toolbar-search-btn:hover {
	opacity: 0.92;
}

.ontario-orderby-select {
	padding: 10px 32px 10px 12px;
	font-size: 14px;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 10px;
	background: var(--de-white);
	color: var(--heading-color, #242424);
	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'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 10px center;
	transition: border-color 0.25s;
}

.ontario-orderby-select:hover,
.ontario-orderby-select:focus {
	outline: none;
	border-color: rgba(0, 0, 0, 0.12);
}

.ontario-academy-results {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 15px;
	color: var(--de-palette-charcoal);
	opacity: 0.9;
}

.ontario-academy-results .results-count {
	font-weight: 700;
	color: var(--de-charcoal);
}

.ontario-academy-results .results-search {
	color: var(--primary-color);
	font-weight: 500;
}

.ontario-academy-view-toggle {
	display: flex;
	gap: 4px;
	background: rgba(0, 0, 0, 0.04);
	padding: 4px;
	border-radius: 10px;
}

.view-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 8px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	text-decoration: none;
	transition: all 0.25s;
}

.view-btn:hover {
	background: var(--de-white);
	color: var(--primary-color);
	opacity: 1;
}

.view-btn.is-active {
	background: var(--de-white);
	color: var(--primary-color);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
	opacity: 1;
}

.ontario-active-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 30px;
}

.active-filters-label {
	font-size: 14px;
	color: var(--de-palette-charcoal);
	opacity: 0.9;
}

.active-filter-tag {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	background: rgba(0, 0, 0, 0.06);
	color: var(--primary-color);
	border-radius: 20px;
	font-size: 13px;
	font-weight: 500;
}

.active-filter-tag a {
	color: var(--primary-color);
	text-decoration: none;
	display: flex;
	align-items: center;
	transition: color 0.3s;
}

.active-filter-tag a:hover {
	color: var(--de-charcoal);
}

/* Modern Course Grid Card */
.ontario-courses-grid {
	margin: 0 -15px;
}

.ontario-course-modern-card {
	background: var(--de-white);
	border-radius: 20px;
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, 0.08);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s;
	height: 100%;
}

.ontario-course-modern-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 48px rgba(0, 0, 0, 0.1);
	border-color: rgba(0, 0, 0, 0.12);
}

.ontario-modern-card-link {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	height: 100%;
}

.ontario-modern-card-image {
	position: relative;
	height: 200px;
	background: rgba(0, 0, 0, 0.03);
	display: flex;
	align-items: center;
	justify-content: center;
}

.ontario-modern-card-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	transition: transform 0.4s ease;
}

.ontario-course-modern-card:hover .ontario-modern-card-image img {
	transform: scale(1.03);
}

.ontario-modern-card-category {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--primary-color);
	color: var(--de-white);
	padding: 6px 14px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 2;
}

.ontario-modern-card-delivery {
	position: absolute;
	top: 12px;
	right: 12px;
	background: var(--de-white);
	color: var(--heading-color, #242424);
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
	z-index: 2;
}

/* Instructor avatar - positioned at bottom right of image */
.ontario-modern-card-instructor-avatar {
	position: absolute;
	bottom: -24px;
	right: 16px;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	border: 3px solid var(--de-white);
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	z-index: 3;
	background: var(--de-white);
}

.ontario-modern-card-instructor-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.ontario-modern-card-content {
	padding: 24px;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.ontario-modern-card-title {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	margin-bottom: 8px;
	line-height: 1.3;
	transition: color 0.3s;
}

.ontario-modern-card-link:hover .ontario-modern-card-title {
	color: var(--primary-color);
}

.ontario-modern-card-excerpt {
	font-size: 14px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	line-height: 1.5;
	margin-bottom: 12px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Instructor section */
.ontario-modern-card-instructor {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 5px;
}

.ontario-instructor-initial {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--primary-color);
	color: var(--de-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
}

.ontario-instructor-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--heading-color, #242424);
}

/* Card details: duration, level, location */
/* Course date on its own line (with icon) */
.ontario-modern-card-date-row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 5px 0;
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.9;
}

.ontario-modern-card-date-row i {
	font-size: 14px;
	color: var(--primary-color);
	flex-shrink: 0;
}

.ontario-modern-card-date-row span {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ontario-modern-list-date-row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 8px 0;
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.9;
}

.ontario-modern-list-date-row i {
	font-size: 14px;
	color: var(--primary-color);
	flex-shrink: 0;
}

.ontario-modern-list-date-row span {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ontario-modern-card-details {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 20px;
	margin-bottom: 16px;
	align-items: center;
}

.ontario-modern-card-detail {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.85;
}

.ontario-modern-card-detail i {
	font-size: 14px;
	color: var(--primary-color);
	flex-shrink: 0;
}

.ontario-modern-card-detail span {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 180px;
}

/* Footer with price and Read More button */
.ontario-modern-card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: auto;
	padding-top: 16px;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.ontario-modern-card-footer--no-price {
	justify-content: center;
}

.ontario-modern-card-price {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
}

.ontario-modern-card-price .course-price {
	display: block;
}

.ontario-modern-card-price .course-price-main {
	display: block;
	font-size: 1.125rem;
}

.ontario-modern-card-price .price-suffix {
	display: block;
	font-size: 0.8125rem;
	font-weight: 400;
	opacity: 0.85;
	margin-top: 2px;
}

.ontario-modern-card-price .course-price-free {
	color: var(--primary-color);
	font-size: 1.125rem;
}

.ontario-modern-card-price .price-prefix {
	font-size: 0.8125rem;
	font-weight: 600;
	opacity: 0.9;
}

.ontario-modern-card-price del,
.ontario-modern-card-price .origin-price {
	font-size: 0.8125rem;
	color: var(--heading-color, #242424);
	opacity: 0.6;
	font-weight: 400;
	margin-right: 6px;
}

.ontario-modern-card-price .price-current {
	font-size: 1.125rem;
	font-weight: 700;
}

/* Read More button - pill style */
.ontario-modern-card-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 24px;
	background: rgba(59, 130, 246, 0.15);
	color: var(--primary-color);
	border-radius: 50px;
	font-size: 14px;
	font-weight: 600;
	transition: all 0.3s ease;
}

.ontario-modern-card-link:hover .ontario-modern-card-btn {
	background: var(--primary-color);
	color: var(--de-white);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Modern List View */
.ontario-courses-list {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.ontario-course-modern-list-item {
	background: var(--de-white);
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, 0.08);
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.05);
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s;
}

.ontario-course-modern-list-item:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
	border-color: rgba(0, 0, 0, 0.1);
}

.ontario-modern-list-link {
	display: flex;
	text-decoration: none;
	color: inherit;
}

.ontario-modern-list-image {
	flex: 0 0 280px;
	height: 226px;
	background: rgba(0, 0, 0, 0.04);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.ontario-modern-list-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	transition: transform 0.4s ease;
}

.ontario-course-modern-list-item:hover .ontario-modern-list-image img {
	transform: scale(1.03);
}

.ontario-modern-list-content {
	flex: 1;
	min-width: 0;
	padding: 24px 28px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0;
}

.ontario-modern-list-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}

.ontario-modern-list-category {
	display: inline-block;
	background: rgba(0, 0, 0, 0.06);
	color: var(--primary-color);
	padding: 6px 14px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ontario-modern-list-delivery {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
}

.ontario-modern-list-delivery i {
	font-size: 8px;
	color: var(--primary-color);
}

.ontario-modern-list-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	margin: 0 0 8px 0;
	transition: color 0.3s;
	line-height: 1.3;
}

.ontario-modern-list-link:hover .ontario-modern-list-title {
	color: var(--primary-color);
}

.ontario-modern-list-excerpt {
	font-size: 15px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	line-height: 1.6;
	margin-bottom: 16px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ontario-modern-list-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.ontario-modern-list-meta span {
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	display: flex;
	align-items: center;
	gap: 6px;
}

.ontario-modern-list-meta i {
	color: var(--primary-color);
}

.ontario-modern-list-aside {
	flex: 0 0 180px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-end;
	padding: 28px;
	gap: 14px;
}

.ontario-modern-list-aside--no-price {
	align-items: center;
	border-left: 1px solid rgba(66, 57, 60, 0.06);
	gap: 16px;
}

.ontario-modern-list-price {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	text-align: right;
}

.ontario-modern-list-price .course-price {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ontario-modern-list-price .course-price-main {
	display: block;
	font-size: 1.125rem;
	font-weight: 700;
}

.ontario-modern-list-price .price-prefix {
	display: block;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--heading-color, #242424);
	opacity: 0.9;
	margin-bottom: 2px;
}

.ontario-modern-list-price .price-amount {
	display: block;
	font-size: 1rem;
	font-weight: 600;
}

.ontario-modern-list-price .origin-price {
	font-size: 0.8125rem;
	font-weight: 500;
	opacity: 0.65;
	margin-right: 6px;
}

.ontario-modern-list-price .price-current {
	font-size: 1.25rem;
	font-weight: 700;
}

.ontario-modern-list-price .course-price .price-suffix {
	display: block;
	font-size: 0.75rem;
	font-weight: 400;
	opacity: 0.8;
	margin-top: 2px;
}

.ontario-modern-list-price .course-price-free {
	color: var(--primary-color);
}

/* List view instructor section */
.ontario-modern-list-instructor {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 6px 0;
}

.ontario-list-instructor-avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--de-white);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.ontario-list-instructor-initial {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--primary-color);
	color: var(--de-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
}

.ontario-list-instructor-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--heading-color, #242424);
}

/* List view details: duration, level, location */
.ontario-modern-list-details {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 20px;
	margin: 0;
	align-items: center;
}

.ontario-modern-list-detail {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--heading-color, #242424);
	opacity: 0.85;
}

.ontario-modern-list-detail i {
	font-size: 14px;
	color: var(--primary-color);
	flex-shrink: 0;
}

.ontario-modern-list-detail span {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 200px;
}

.ontario-modern-list-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 24px;
	background: rgba(59, 130, 246, 0.15);
	color: var(--primary-color);
	border-radius: 50px;
	font-size: 14px;
	font-weight: 600;
	transition: all 0.3s ease;
}

.ontario-modern-list-link:hover .ontario-modern-list-action {
	background: var(--primary-color);
	color: var(--de-white);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

@media (max-width: 991px) {
	.ontario-modern-list-link {
		flex-direction: column;
	}
	.ontario-modern-list-image {
		flex: 0 0 auto;
		width: 100%;
	}
	.ontario-modern-list-content {
		padding: 20px 24px;
	}
	.ontario-modern-list-aside {
		flex: 0 0 auto;
		width: 100%;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
		border-left: none;
		border-top: 1px solid rgba(0, 0, 0, 0.08);
		padding: 20px 24px;
	}
	.ontario-modern-list-aside--no-price {
		justify-content: center;
	}
}

/* No Results */
.ontario-academy-no-results {
	text-align: center;
	padding: 80px 20px;
	background: rgba(0, 0, 0, 0.03);
	border-radius: 16px;
	border: 1px solid rgba(0, 0, 0, 0.06);
}

.no-results-icon {
	width: 80px;
	height: 80px;
	background: rgba(0, 0, 0, 0.06);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 24px;
}

.no-results-icon i {
	font-size: 32px;
	color: var(--primary-color);
}

.ontario-academy-no-results h3 {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--heading-color, #242424);
	margin-bottom: 12px;
}

.ontario-academy-no-results p {
	font-size: 15px;
	color: var(--heading-color, #242424);
	opacity: 0.7;
	margin-bottom: 24px;
}

/* Academy pagination – circular buttons, centered */
.ontario-academy-pagination {
	margin-top: 48px;
	margin-bottom: 24px;
	text-align: center;
	width: 100%;
	display: flex;
	justify-content: center;
}

.ontario-academy-pagination-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 12px;
	width: 100%;
}

.ontario-academy-pagination .ontario-pagination-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	min-width: 48px;
	padding: 0;
	border-radius: 50%;
	background: var(--de-white);
	border: 1px solid rgba(0, 0, 0, 0.15);
	color: var(--heading-color, #242424);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: border-color 0.25s, background 0.25s, color 0.25s;
}

.ontario-academy-pagination a.ontario-pagination-btn:hover {
	border-color: var(--primary-color);
	color: var(--primary-color);
	background: rgba(255, 255, 255, 0.95);
}

.ontario-academy-pagination .ontario-pagination-current {
	border-color: var(--primary-color);
	background: var(--primary-color);
	color: var(--de-white);
	cursor: default;
}

.ontario-academy-pagination .ontario-pagination-disabled {
	opacity: 0.5;
	cursor: not-allowed;
	pointer-events: none;
}

.ontario-academy-pagination .ontario-pagination-btn i {
	font-size: 12px;
}

/* CTA Section */
.ontario-academy-cta {
	background: linear-gradient(180deg, var(--de-white) 0%, rgba(126, 148, 137, 0.05) 100%);
	padding: 80px 0 100px;
}

.ontario-cta-box {
	background: linear-gradient(135deg, var(--de-charcoal) 0%, var(--de-charcoal-soft) 100%);
	border-radius: 20px;
	padding: 50px 60px;
	color: var(--de-white);
	box-shadow: 0 16px 48px rgba(36, 36, 36, 0.2);
}

.ontario-cta-title {
	font-size: 1.75rem;
	font-weight: 700;
	margin-bottom: 12px;
	color: var(--de-white);
}

.ontario-cta-text {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.9);
	margin: 0;
}

.ontario-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 32px;
	border-radius: 12px;
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	transition: transform 0.3s, box-shadow 0.3s;
}

.ontario-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

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

.ontario-btn-white:hover {
	color: var(--primary-color);
	background: var(--de-white);
}

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

.ontario-btn-primary:hover {
	opacity: 0.9;
	color: var(--de-white);
}

@media (max-width: 991px) {
	.ontario-cta-box {
		padding: 40px;
		text-align: center;
	}
	.ontario-cta-box .text-lg-end {
		text-align: center !important;
		margin-top: 24px;
	}
}

@media (max-width: 767px) {
	.ontario-academy-toolbar {
		flex-direction: column;
		align-items: stretch;
		gap: 16px;
	}
	.ontario-academy-toolbar-right {
		flex-direction: column;
		align-items: stretch;
		max-width: none;
	}
	.ontario-academy-search-form {
		max-width: none;
	}
	.ontario-toolbar-search-wrap {
		width: 100%;
	}
	.ontario-toolbar-search-input {
		min-width: 0;
		flex: 1;
	}
	.ontario-section-title {
		font-size: 2rem;
	}
}

/* ===== Intelligence Hub Section (Homepage) - Theme Colors ===== */
/* Using theme primary (#C5B27D) and secondary (#75AC98) colors */

/* Wide layout with border radius - similar to Process Section */
.ontario-intelligence-hub-section {
	position: relative;
	margin: 0 30px;
	border-radius: 30px;
	overflow: hidden;
	background-color: var(--heading-color, #42393C);
}

/* Background image */
.ontario-intelligence-hub-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-size: cover;
	background-position: center;
}

/* Dark overlay on background image */
.ontario-intelligence-hub-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(165deg, rgba(66, 57, 60, 0.95) 0%, rgba(45, 38, 40, 0.92) 50%, rgba(66, 57, 60, 0.95) 100%);
}

/* Additional overlay div for decorative accents */
.ontario-intelligence-hub-overlay {
	position: absolute;
	inset: 0;
	z-index: 0;
	background:
		radial-gradient(ellipse 80% 60% at 50% 20%, rgba(197, 178, 125, 0.08) 0%, transparent 70%),
		radial-gradient(ellipse 40% 40% at 80% 80%, rgba(117, 172, 152, 0.06) 0%, transparent 60%);
	pointer-events: none;
}

/* Header */
.ontario-hub-header {
	position: relative;
	z-index: 1;
}

.ontario-hub-label {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	display: block;
	margin-bottom: 16px;
}

.ontario-hub-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 800;
	color: var(--white-color, #ffffff);
	margin-bottom: 16px;
	line-height: 1.2;
}

.ontario-hub-subtitle {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.85);
	max-width: 600px;
	margin: 0 auto;
	font-weight: 300;
}
.ontario-hub-subtitle p:last-child {
	margin-bottom: 0;
}

/* Section Label */
.ontario-hub-section-label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(197, 178, 125, 0.2);
	position: relative;
	z-index: 1;
}

.ontario-hub-section-label span {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.6);
}

.ontario-hub-see-all {
	font-size: 13px;
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
}

.ontario-hub-see-all:hover {
	color: var(--secondary-color, #75AC98);
	gap: 10px;
}
.ontario-hub-see-all .elementor-icon,
.ontario-hub-see-all svg {
	display: inline-block;
	vertical-align: middle;
}

/* Hub Cards */
.ontario-hub-card {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 28px;
	position: relative;
	overflow: hidden;
	transition: all 0.3s ease;
	margin-bottom: 30px;
	z-index: 1;
}

.ontario-hub-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--primary-color, #C5B27D), transparent);
}

.ontario-hub-card:hover {
	border-color: rgba(197, 178, 125, 0.4);
	transform: translateY(-4px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.2);
	background: rgba(255, 255, 255, 0.06);
}

.ontario-hub-card--featured::before {
	background: linear-gradient(90deg, var(--primary-color, #C5B27D), var(--secondary-color, #75AC98));
}

.ontario-hub-card--featured {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.08) 0%, rgba(255,255,255,0.03) 100%);
}

/* Featured Badge */
.ontario-hub-badge {
	position: absolute;
	top: 16px;
	right: 16px;
	font-size: 10px;
	padding: 4px 12px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.15);
	border: 1px solid rgba(197, 178, 125, 0.3);
	color: var(--primary-color, #C5B27D);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-weight: 600;
}

/* Card Icon */
.ontario-hub-card-icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: var(--primary-color, #C5B27D);
	margin-bottom: 20px;
}
/* SVG icons from Elementor: inherit theme color + fixed 24px (matches design) */
.ontario-hub-card-icon .elementor-icon,
.ontario-hub-card-icon svg {
	color: inherit;
	width: 24px !important;
	height: 24px !important;
	max-width: 24px;
	max-height: 24px;
	display: block;
	flex-shrink: 0;
}
.ontario-hub-card-icon i {
	font-size: 24px;
	line-height: 1;
}
.ontario-hub-card-icon svg path,
.ontario-hub-card-icon svg circle,
.ontario-hub-card-icon svg rect,
.ontario-hub-card-icon svg line,
.ontario-hub-card-icon svg polyline,
.ontario-hub-card-icon svg polygon {
	fill: currentColor;
}
.ontario-hub-card-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.ontario-hub-card-icon--video {
	background: rgba(117, 172, 152, 0.12);
	border-color: rgba(117, 172, 152, 0.25);
	color: var(--secondary-color, #75AC98);
}

.ontario-hub-card-icon--pdf {
	background: rgba(197, 178, 125, 0.12);
	border-color: rgba(197, 178, 125, 0.25);
	color: var(--primary-color, #C5B27D);
}

/* Card Title */
.ontario-hub-card-title {
	font-family: 'Syne', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--white-color, #ffffff);
	margin-bottom: 12px;
	line-height: 1.4;
}

/* Card Description */
.ontario-hub-card-desc {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.7;
	margin-bottom: 20px;
}
.ontario-hub-card-desc p:last-child {
	margin-bottom: 0;
}

/* Card Meta */
.ontario-hub-card-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 16px;
}

.ontario-hub-tag {
	font-size: 11px;
	padding: 4px 10px;
	border-radius: 6px;
	background: rgba(197, 178, 125, 0.1);
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ontario-hub-tag--video {
	background: rgba(117, 172, 152, 0.12);
	color: var(--secondary-color, #75AC98);
}

.ontario-hub-tag--pdf {
	background: rgba(197, 178, 125, 0.12);
	color: var(--primary-color, #C5B27D);
}

.ontario-hub-card-for {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.6);
}

/* Card CTA - Styled as theme button */
.ontario-hub-card-cta {
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
	cursor: pointer;
	padding: 10px 18px;
	border-radius: 6px;
}

.ontario-hub-card-cta:hover {
	gap: 10px;
}

/* Tools Banner Section */
.ontario-hub-tools-section {
	position: relative;
	z-index: 1;
}

.ontario-hub-tools-banner {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.06) 0%, rgba(117, 172, 152, 0.08) 100%);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 16px;
	padding: 32px 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px;
}

.ontario-hub-tools-content h4 {
	font-family: 'Syne', sans-serif;
	font-size: 20px;
	font-weight: 700;
	color: var(--white-color, #ffffff);
	margin-bottom: 8px;
}

.ontario-hub-tools-content p {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.8);
	max-width: 420px;
	margin-bottom: 16px;
}

/* Tools Banner Button - Uses theme-btn gradient-btn */
.ontario-hub-tools-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 20px;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
	transition: all 0.3s ease;
}

.ontario-hub-tools-btn:hover {
	transform: translateX(4px);
}

.ontario-hub-tools-preview {
	width: 100px;
	height: 100px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15), rgba(117, 172, 152, 0.1));
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 40px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
}
/* Tools preview icon: 40×40 inside the preview box */
.ontario-hub-tools-preview .elementor-icon,
.ontario-hub-tools-preview svg {
	color: inherit;
	width: 40px !important;
	height: 40px !important;
	max-width: 40px;
	max-height: 40px;
	display: block;
	flex-shrink: 0;
}
.ontario-hub-tools-preview i {
	font-size: 40px;
	line-height: 1;
}
.ontario-hub-tools-preview svg path,
.ontario-hub-tools-preview svg circle,
.ontario-hub-tools-preview svg rect,
.ontario-hub-tools-preview svg line,
.ontario-hub-tools-preview svg polyline,
.ontario-hub-tools-preview svg polygon {
	fill: currentColor;
}
.ontario-hub-tools-preview svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

/* Main CTA Button - Uses theme-btn gradient-btn class in HTML */
.ontario-hub-cta {
	position: relative;
	z-index: 1;
}

.ontario-hub-cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.3s ease;
}

.ontario-hub-cta-btn:hover {
	gap: 14px;
}

/* Mini Tags for Card Types */
.ontario-hub-card-types {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 16px;
}

.ontario-hub-mini-tag {
	font-size: 10px;
	padding: 3px 8px;
	border-radius: 4px;
	background: rgba(197, 178, 125, 0.08);
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.ontario-hub-mini-tag--live {
	background: rgba(39, 174, 96, 0.15);
	color: #27ae60;
}

.ontario-hub-mini-tag--live i {
	font-size: 6px;
	animation: pulse 2s infinite;
}

.ontario-hub-mini-tag--agent {
	background: rgba(197, 178, 125, 0.12);
	color: var(--primary-color, #C5B27D);
}
/* Mini tag icons: same visual size as label text (10px caps) */
.ontario-hub-mini-tag .elementor-icon,
.ontario-hub-mini-tag svg {
	color: inherit;
	width: 1em !important;
	height: 1em !important;
	max-width: 1em;
	max-height: 1em;
	display: block;
	flex-shrink: 0;
	vertical-align: middle;
}
.ontario-hub-mini-tag i {
	font-size: 1em;
	line-height: 1;
}
/* Live dot: tiny pulse, same proportion as original 6px vs 10px text */
.ontario-hub-mini-tag--live .elementor-icon,
.ontario-hub-mini-tag--live svg {
	width: 0.55em !important;
	height: 0.55em !important;
	max-width: 0.55em;
	max-height: 0.55em;
}
.ontario-hub-mini-tag svg path,
.ontario-hub-mini-tag svg circle,
.ontario-hub-mini-tag svg rect,
.ontario-hub-mini-tag svg line,
.ontario-hub-mini-tag svg polyline,
.ontario-hub-mini-tag svg polygon {
	fill: currentColor;
}
.ontario-hub-mini-tag svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

/* Progress Bar for Learning Path */
.ontario-hub-card-progress {
	margin-bottom: 16px;
}

.ontario-hub-progress-bar {
	width: 100%;
	height: 4px;
	background: rgba(197, 178, 125, 0.1);
	border-radius: 2px;
	overflow: hidden;
	margin-bottom: 8px;
}

.ontario-hub-progress-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--primary-color, #C5B27D), var(--secondary-color, #75AC98));
	border-radius: 2px;
	transition: width 0.5s ease;
}

.ontario-hub-progress-text {
	font-size: 11px;
	color: rgba(255, 255, 255, 0.6);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Additional Card Icon Styles */
.ontario-hub-card-icon--gradient {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15) 0%, rgba(117, 172, 152, 0.1) 100%);
	border-color: rgba(197, 178, 125, 0.3);
}

.ontario-hub-card-icon--gold {
	background: rgba(197, 178, 125, 0.12);
	border-color: rgba(197, 125, 0.25);
	color: var(--primary-color, #C5B27D);
}

.ontario-hub-card-icon--agents {
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.15) 0%, rgba(197, 178, 125, 0.1) 100%);
	border-color: rgba(117, 172, 152, 0.3);
	color: var(--secondary-color, #75AC98);
}

/* Agent Card Specific */
.ontario-hub-card--agents::before {
	background: linear-gradient(90deg, var(--secondary-color, #75AC98), var(--primary-color, #C5B27D));
}

/* 4-Column Layout Responsive */
@media (max-width: 1200px) {
	.ontario-hub-card {
		margin-bottom: 20px;
	}
}

/* Responsive Adjustments */
@media screen and (max-width: 1199.98px) {
	.ontario-intelligence-hub-section {
		margin: 0 15px;
		border-radius: 15px;
	}
}

@media (max-width: 768px) {
	.ontario-intelligence-hub-section {
		margin: 0;
		border-radius: 0;
	}

	.ontario-hub-title {
		font-size: 28px;
	}

	.ontario-hub-card {
		padding: 24px;
	}

	.ontario-hub-tools-banner {
		flex-direction: column;
		text-align: center;
		padding: 24px;
	}

	.ontario-hub-tools-content p {
		max-width: 100%;
	}

	.ontario-hub-tools-preview {
		width: 80px;
		height: 80px;
		font-size: 32px;
	}
}

/* ===== Learning Path Page ===== */
.ontario-learning-section {
	background: var(--gray-color, #F8F8F8);
	position: relative;
}

/* Learning Path Header */
.ontario-learning-header {
	position: relative;
	z-index: 1;
}

.ontario-learning-label {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	display: block;
	margin-bottom: 16px;
}

.ontario-learning-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 800;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
	line-height: 1.2;
}

.ontario-learning-subtitle {
	font-size: 1.1rem;
	color: var(--text-color, #5c5356);
	max-width: 700px;
	margin: 0 auto;
	font-weight: 300;
}

/* Learning Path Hero Banner */
.ontario-learning-hero-banner {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.12) 0%, rgba(117, 172, 152, 0.08) 100%);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 16px;
	padding: 32px 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px;
	margin-bottom: 48px;
}

.ontario-learning-hero-content h4 {
	font-family: 'Syne', sans-serif;
	font-size: 20px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-learning-hero-content p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	max-width: 420px;
	margin: 0;
}

/* Progress Pill */
.ontario-learning-progress-pill {
	display: flex;
	align-items: center;
	gap: 12px;
	background: var(--white-color, #ffffff);
	border-radius: 100px;
	padding: 12px 20px;
	flex-shrink: 0;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.ontario-learning-progress-circle {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: conic-gradient(var(--primary-color, #C5B27D) 25%, rgba(197, 178, 125, 0.15) 0);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 700;
	color: var(--primary-color, #C5B27D);
	position: relative;
}

.ontario-learning-progress-circle::before {
	content: '';
	position: absolute;
	inset: 4px;
	border-radius: 50%;
	background: var(--white-color, #ffffff);
}

.ontario-learning-progress-circle span {
	position: relative;
	z-index: 1;
}

.ontario-learning-progress-info .ontario-progress-label {
	font-size: 11px;
	color: var(--text-color, #5c5356);
	display: block;
}

.ontario-learning-progress-info strong {
	display: block;
	color: var(--heading-color, #42393C);
	font-size: 14px;
	font-weight: 600;
}

/* Learning Path Track */
.ontario-learning-track {
	max-width: 900px;
	margin: 0 auto 48px;
}

.ontario-learning-level {
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: 0;
	position: relative;
	margin-bottom: 8px;
}

/* Level Spine (Left side with nodes) */
.ontario-level-spine {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-top: 20px;
}

.ontario-level-node {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: 2px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
	color: var(--text-color, #5c5356);
	background: var(--white-color, #ffffff);
	flex-shrink: 0;
	position: relative;
	z-index: 1;
	transition: all 0.3s ease;
}

.ontario-level-node.done {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

.ontario-level-node.active {
	background: rgba(197, 178, 125, 0.15);
	border-color: var(--primary-color, #C5B27D);
	color: var(--primary-color, #C5B27D);
	box-shadow: 0 0 0 4px rgba(197, 178, 125, 0.1);
}

.ontario-level-line {
	flex: 1;
	width: 2px;
	background: rgba(197, 178, 125, 0.2);
	margin-top: 8px;
	min-height: 60px;
}

.ontario-level-line.done {
	background: var(--primary-color, #C5B27D);
}

.ontario-level-line.final {
	background: linear-gradient(to bottom, rgba(197, 178, 125, 0.2), transparent);
}

/* Level Content */
.ontario-level-content {
	padding: 14px 0 24px 24px;
}

.ontario-level-label {
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--text-color, #5c5356);
	margin-bottom: 14px;
	font-weight: 600;
}

.ontario-level-label.active {
	color: var(--primary-color, #C5B27D);
}

/* Level Cards Grid */
.ontario-level-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}

.ontario-level-card {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 12px;
	padding: 18px;
	transition: all 0.3s ease;
	cursor: pointer;
}

.ontario-level-card:hover {
	border-color: rgba(197, 178, 125, 0.3);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.ontario-level-card.done {
	border-color: rgba(197, 178, 125, 0.25);
	background: rgba(197, 178, 125, 0.03);
}

.ontario-level-card.active {
	border-color: rgba(197, 178, 125, 0.4);
	background: rgba(197, 178, 125, 0.06);
	box-shadow: 0 4px 16px rgba(197, 178, 125, 0.1);
}

.ontario-level-card.locked {
	opacity: 0.6;
	cursor: not-allowed;
}

.ontario-level-card.locked:hover {
	transform: none;
	border-color: rgba(197, 178, 125, 0.15);
	box-shadow: none;
}

.ontario-card-type {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--text-color, #5c5356);
	margin-bottom: 8px;
	font-weight: 600;
	display: block;
}

.ontario-level-card.done .ontario-card-type {
	color: var(--primary-color, #C5B27D);
}

.ontario-level-card h5 {
	font-family: 'Syne', sans-serif;
	font-size: 14px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	line-height: 1.4;
	margin-bottom: 6px;
}

.ontario-level-card p {
	font-size: 12px;
	color: var(--text-color, #5c5356);
	line-height: 1.5;
	margin-bottom: 0;
}

.ontario-card-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid rgba(197, 178, 125, 0.1);
}

.ontario-duration {
	font-size: 11px;
	color: var(--text-color, #5c5356);
	display: flex;
	align-items: center;
	gap: 4px;
}

.ontario-duration i {
	font-size: 10px;
}

.ontario-status-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(197, 178, 125, 0.3);
}

.ontario-status-dot.done {
	background: var(--primary-color, #C5B27D);
}

.ontario-status-dot.active {
	background: var(--secondary-color, #75AC98);
}

.ontario-lock-icon {
	font-size: 12px;
	color: var(--text-color, #5c5356);
	opacity: 0.5;
}

/* Learning Features */
.ontario-learning-features {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 40px;
	margin-bottom: 40px;
}

.ontario-learning-feature {
	text-align: center;
	padding: 20px;
}

.ontario-learning-feature i {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 16px;
}

.ontario-learning-feature h5 {
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-learning-feature p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin: 0;
}

/* Learning CTA */
.ontario-learning-cta {
	position: relative;
	z-index: 1;
}

.ontario-learning-cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 32px;
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.3s ease;
}

.ontario-learning-cta-btn:hover {
	gap: 14px;
}

/* Responsive Adjustments */
@media (max-width: 991px) {
	.ontario-learning-hero-banner {
		flex-direction: column;
		text-align: center;
		padding: 24px;
	}

	.ontario-learning-hero-content p {
		max-width: 100%;
	}

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

@media (max-width: 768px) {
	.ontario-learning-title {
		font-size: 28px;
	}

	.ontario-learning-level {
		grid-template-columns: 50px 1fr;
	}

	.ontario-level-cards {
		grid-template-columns: 1fr;
	}

	.ontario-learning-features {
		padding: 24px;
	}

	.ontario-learning-feature {
		margin-bottom: 24px;
	}

	.ontario-level-content {
		padding-left: 16px;
	}
}

/* ===== AI Tools & Demos Page ===== */
.ontario-tools-section {
	background: var(--gray-color, #F8F8F8);
	position: relative;
}

/* Tools Section Header */
.ontario-tools-header {
	position: relative;
	z-index: 1;
}

.ontario-tools-label {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	display: block;
	margin-bottom: 16px;
}

.ontario-tools-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 800;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
	line-height: 1.2;
}

.ontario-tools-subtitle {
	font-size: 1.1rem;
	color: var(--text-color, #5c5356);
	max-width: 700px;
	margin: 0 auto;
	font-weight: 300;
}

/* Tools Hero Banner */
.ontario-tools-hero-banner {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15) 0%, rgba(117, 172, 152, 0.1) 100%);
	border: 1px solid rgba(197, 178, 125, 0.25);
	border-radius: 16px;
	padding: 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	margin-bottom: 48px;
}

.ontario-tools-hero-content {
	flex: 1;
}

.ontario-tools-hero-content h4 {
	font-family: 'Syne', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
}

.ontario-tools-hero-content p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	max-width: 480px;
	margin-bottom: 20px;
}

.ontario-tools-hero-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	font-size: 14px;
	font-weight: 600;
}

.ontario-demo-preview {
	width: 200px;
	height: 120px;
	border-radius: 12px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.2), rgba(117, 172, 152, 0.15));
	border: 2px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 48px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
	position: relative;
	overflow: hidden;
}

.ontario-play-icon {
	position: absolute;
	bottom: 10px;
	right: 10px;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	box-shadow: 0 4px 12px rgba(197, 178, 125, 0.4);
}

/* Tools Tabs */
.ontario-tools-tabs {
	display: flex;
	gap: 12px;
	margin-bottom: 32px;
	flex-wrap: wrap;
}

.ontario-tab-btn {
	font-size: 13px;
	font-weight: 600;
	padding: 10px 20px;
	border-radius: 8px;
	border: 1px solid rgba(197, 178, 125, 0.3);
	background: var(--white-color, #ffffff);
	color: var(--text-color, #5c5356);
	cursor: pointer;
	transition: all 0.3s ease;
}

.ontario-tab-btn:hover {
	border-color: var(--primary-color, #C5B27D);
	color: var(--primary-color, #C5B27D);
}

.ontario-tab-btn.active {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

/* Tools Grid */
.ontario-tools-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-bottom: 48px;
}

.ontario-tool-card {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 14px;
	overflow: hidden;
	transition: all 0.3s ease;
}

.ontario-tool-card:hover {
	border-color: rgba(197, 178, 125, 0.35);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

/* Tool Preview */
.ontario-tool-preview {
	height: 140px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1), rgba(117, 172, 152, 0.08));
	border-bottom: 1px solid rgba(197, 178, 125, 0.15);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 40px;
	color: var(--primary-color, #C5B27D);
	position: relative;
	overflow: hidden;
}

.ontario-tool-preview.video-preview {
	padding: 0;
}

.ontario-tool-preview.video-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ontario-play-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.3);
}

.ontario-play-overlay i {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

.ontario-tool-type-badge {
	position: absolute;
	top: 12px;
	right: 12px;
	font-size: 9px;
	padding: 4px 10px;
	border-radius: 100px;
	background: rgba(0, 0, 0, 0.6);
	color: var(--white-color, #ffffff);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.ontario-tool-type-badge.video {
	background: rgba(117, 172, 152, 0.9);
}

/* Animated Preview Elements */
.ontario-preview-animated {
	display: flex;
	align-items: center;
	gap: 8px;
}

.ontario-flow-node {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--primary-color, #C5B27D);
	opacity: 0.5;
}

.ontario-flow-node.active {
	opacity: 1;
	box-shadow: 0 0 8px var(--primary-color, #C5B27D);
}

.ontario-flow-line {
	width: 30px;
	height: 2px;
	background: linear-gradient(90deg, var(--primary-color, #C5B27D), var(--secondary-color, #75AC98));
}

.ontario-preview-bars {
	display: flex;
	gap: 4px;
	align-items: flex-end;
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
}

.ontario-bar {
	width: 8px;
	border-radius: 4px;
	background: var(--primary-color, #C5B27D);
	opacity: 0.6;
}

/* Code Preview Window */
.ontario-code-window {
	width: 80%;
	background: var(--heading-color, #42393C);
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.ontario-code-header {
	display: flex;
	gap: 6px;
	padding: 10px;
	background: rgba(255, 255, 255, 0.05);
}

.ontario-code-header span {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.3);
}

.ontario-code-header span:nth-child(1) { background: #ff5f56; }
.ontario-code-header span:nth-child(2) { background: #ffbd2e; }
.ontario-code-header span:nth-child(3) { background: #27c93f; }

.ontario-code-body {
	padding: 12px;
}

.ontario-code-body code {
	font-size: 11px;
	color: rgba(255, 255, 255, 0.8);
	font-family: 'Monaco', 'Consolas', monospace;
}

/* Tool Info */
.ontario-tool-info {
	padding: 20px;
}

.ontario-tool-info h4 {
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-tool-info p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 16px;
}

/* Tool Footer */
.ontario-tool-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.ontario-tool-tag {
	font-size: 11px;
	padding: 4px 10px;
	border-radius: 6px;
	background: rgba(197, 178, 125, 0.1);
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ontario-tool-tag.video {
	background: rgba(117, 172, 152, 0.12);
	color: var(--secondary-color, #75AC98);
}

.ontario-tool-link {
	font-size: 12px;
	color: var(--primary-color, #C5B27D);
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: all 0.3s ease;
}

.ontario-tool-link:hover {
	color: var(--secondary-color, #75AC98);
	gap: 8px;
}

/* Custom Demo Section */
.ontario-custom-demo-section {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 16px;
	padding: 48px;
	text-align: center;
	margin-bottom: 48px;
}

.ontario-custom-demo-content h3 {
	font-family: 'Syne', sans-serif;
	font-size: 24px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
}

.ontario-custom-demo-content p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	max-width: 600px;
	margin: 0 auto 24px;
}

.ontario-custom-demo-buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

.theme-btn.outline-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: transparent;
	color: var(--primary-color, #C5B27D);
	border: 2px solid var(--primary-color, #C5B27D);
	border-radius: 6px;
	padding: 12px 24px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.3s ease;
}

.theme-btn.outline-btn:hover {
	background: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

/* Tools Features */
.ontario-tools-features {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 40px;
}

.ontario-tools-feature {
	text-align: center;
	padding: 20px;
}

.ontario-tools-feature i {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 16px;
}

.ontario-tools-feature h5 {
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-tools-feature p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin: 0;
}

/* Responsive Adjustments */
@media (max-width: 991px) {
	.ontario-tools-hero-banner {
		flex-direction: column;
		text-align: center;
		padding: 32px;
	}

	.ontario-tools-hero-content p {
		max-width: 100%;
	}

	.ontario-demo-preview {
		width: 160px;
		height: 100px;
	}

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

	.ontario-custom-demo-section {
		padding: 32px;
	}
}

@media (max-width: 768px) {
	.ontario-tools-title {
		font-size: 28px;
	}

	.ontario-tools-tabs {
		gap: 8px;
	}

	.ontario-tab-btn {
		padding: 8px 14px;
		font-size: 12px;
	}

	.ontario-tools-grid {
		grid-template-columns: 1fr;
	}

	.ontario-demo-preview {
		width: 140px;
		height: 80px;
		font-size: 36px;
	}

	.ontario-custom-demo-buttons {
		flex-direction: column;
	}

	.ontario-tools-features {
		padding: 24px;
	}

	.ontario-tools-feature {
		margin-bottom: 24px;
	}
}

/* ===== AI Agents Directory Page ===== */
.ontario-agents-section {
	background: var(--gray-color, #F8F8F8);
	position: relative;
}

/* Agents Header */
.ontario-agents-header {
	position: relative;
	z-index: 1;
}

.ontario-agents-label {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	display: block;
	margin-bottom: 16px;
}

.ontario-agents-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 800;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
	line-height: 1.2;
}

.ontario-agents-subtitle {
	font-size: 1.1rem;
	color: var(--text-color, #5c5356);
	max-width: 700px;
	margin: 0 auto;
	font-weight: 300;
}

/* Category Tabs */
.ontario-agents-tabs {
	display: flex;
	gap: 12px;
	margin-bottom: 24px;
	flex-wrap: wrap;
	border-bottom: 1px solid rgba(197, 178, 125, 0.2);
	padding-bottom: 16px;
}

.ontario-agents-tabs .ontario-tab-btn {
	font-size: 14px;
	font-weight: 600;
	padding: 10px 20px;
	border-radius: 8px;
	border: 1px solid transparent;
	background: transparent;
	color: var(--text-color, #5c5356);
	cursor: pointer;
	transition: all 0.3s ease;
}

.ontario-agents-tabs .ontario-tab-btn:hover {
	background: rgba(197, 178, 125, 0.1);
	color: var(--primary-color, #C5B27D);
}

.ontario-agents-tabs .ontario-tab-btn.active {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

/* Filter Row */
.ontario-filter-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	margin-bottom: 40px;
	flex-wrap: wrap;
}

.ontario-filter-chips {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.ontario-chip {
	font-size: 12px;
	padding: 6px 14px;
	border-radius: 100px;
	border: 1px solid rgba(197, 178, 125, 0.3);
	background: var(--white-color, #ffffff);
	color: var(--text-color, #5c5356);
	cursor: pointer;
	transition: all 0.3s ease;
	font-weight: 500;
}

.ontario-chip:hover {
	border-color: var(--primary-color, #C5B27D);
	color: var(--primary-color, #C5B27D);
}

.ontario-chip.active {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

.ontario-search-box {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.3);
	border-radius: 8px;
	padding: 10px 16px;
	min-width: 240px;
}

.ontario-search-box i {
	color: var(--text-color, #5c5356);
	font-size: 14px;
}

.ontario-search-box input {
	border: none;
	background: transparent;
	font-size: 14px;
	color: var(--heading-color, #42393C);
	outline: none;
	width: 100%;
}

.ontario-search-box input::placeholder {
	color: var(--text-color, #5c5356);
}

/* Section Label */
.ontario-section-label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(197, 178, 125, 0.2);
}

.ontario-section-label.ontario-agents-intro {
	border-bottom: none;
	justify-content: center;
	gap: 12px;
	margin-bottom: 32px;
}

.ontario-section-label.ontario-agents-intro span {
	font-size: 14px;
	letter-spacing: 0.05em;
}

.ontario-section-label.ontario-agents-intro strong {
	color: var(--primary-color, #C5B27D);
}

.ontario-agents-intro-text {
	color: var(--text-color, #5c5356);
	font-weight: 400;
}

/* Agents Filter Chips */
.ontario-agents-filter-chips {
	display: flex;
	gap: 10px;
	margin-bottom: 32px;
	flex-wrap: wrap;
	justify-content: center;
}

.ontario-filter-chip {
	font-size: 13px;
	padding: 8px 18px;
	border-radius: 100px;
	border: 1px solid rgba(197, 178, 125, 0.3);
	background: var(--white-color, #ffffff);
	color: var(--text-color, #5c5356);
	cursor: pointer;
	transition: all 0.3s ease;
	font-weight: 500;
}

.ontario-filter-chip:hover {
	border-color: var(--primary-color, #C5B27D);
	color: var(--primary-color, #C5B27D);
	transform: translateY(-1px);
}

.ontario-filter-chip.active {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
	box-shadow: 0 4px 12px rgba(197, 178, 125, 0.3);
}

.ontario-section-label span {
	font-family: 'Syne', sans-serif;
	font-size: 13px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-color, #5c5356);
	font-weight: 600;
}

.ontario-see-all {
	font-size: 13px;
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
}

.ontario-see-all:hover {
	color: var(--secondary-color, #75AC98);
	gap: 10px;
}

/* Featured Agent */
.ontario-featured-agent {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.12) 0%, rgba(117, 172, 152, 0.08) 100%);
	border: 1px solid rgba(197, 178, 125, 0.25);
	border-radius: 16px;
	padding: 32px;
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 24px;
	align-items: center;
	margin-bottom: 48px;
}

.ontario-featured-agent-icon {
	width: 72px;
	height: 72px;
	border-radius: 16px;
	background: rgba(197, 178, 125, 0.15);
	border: 1px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 32px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
}

.ontario-featured-agent-content h4 {
	font-family: 'Syne', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
}

.ontario-featured-agent-content p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 16px;
}

.ontario-featured-agent-tags {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.ontario-agent-tag {
	font-size: 11px;
	padding: 4px 12px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.12);
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
}

.ontario-tag-enterprise {
	background: rgba(245, 200, 66, 0.15);
	color: #b8860b;
}

.ontario-featured-agent-actions {
	display: flex;
	gap: 12px;
	flex-shrink: 0;
}

.ontario-btn-sm {
	padding: 10px 18px;
	font-size: 13px;
}

/* Agents Grid */
.ontario-agents-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-bottom: 40px;
}

/* Agent Card */
.ontario-agent-card {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 24px;
	position: relative;
	transition: all 0.3s ease;
	overflow: hidden;
}

.ontario-agent-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--primary-color, #C5B27D), transparent);
}

.ontario-agent-card:hover {
	border-color: rgba(197, 178, 125, 0.35);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

/* Featured Card */
.ontario-agent-card--featured::before {
	background: linear-gradient(90deg, var(--secondary-color, #75AC98), var(--primary-color, #C5B27D));
}

.ontario-agent-card--featured {
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.05) 0%, rgba(255, 255, 255, 1) 100%);
}

/* New Badge */
.ontario-new-badge {
	position: absolute;
	top: 16px;
	right: 16px;
	font-size: 10px;
	padding: 4px 10px;
	border-radius: 100px;
	background: var(--secondary-color, #75AC98);
	color: var(--white-color, #ffffff);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 600;
}

/* Coming Soon Card */
.ontario-agent-card--soon {
	opacity: 0.7;
	border-style: dashed;
	background: rgba(255, 255, 255, 0.5);
}

.ontario-agent-card--soon::before {
	background: rgba(197, 178, 125, 0.3);
}

.ontario-agent-card--soon:hover {
	transform: none;
	box-shadow: none;
}

.ontario-soon-badge {
	position: absolute;
	top: 16px;
	right: 16px;
	font-size: 9px;
	padding: 4px 10px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.2);
	border: 1px solid rgba(197, 178, 125, 0.3);
	color: var(--text-color, #5c5356);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 600;
}

/* Agent Icon */
.ontario-agent-icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	color: var(--primary-color, #C5B27D);
	margin-bottom: 16px;
}

.ontario-agent-card--soon .ontario-agent-icon {
	opacity: 0.6;
}

/* Agent Card Content */
.ontario-agent-card h4 {
	font-family: 'Syne', sans-serif;
	font-size: 17px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
}

.ontario-agent-card--soon h4 {
	color: var(--text-color, #5c5356);
}

.ontario-agent-card p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 16px;
}

/* Agent Meta */
.ontario-agent-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 16px;
	padding-bottom: 16px;
	border-bottom: 1px solid rgba(197, 178, 125, 0.1);
}

.ontario-agent-for {
	font-size: 11px;
	color: var(--text-color, #5c5356);
}

/* Agent CTA */
.ontario-agent-cta {
	font-size: 13px;
	color: var(--primary-color, #C5B27D);
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
}

.ontario-agent-cta:hover {
	color: var(--secondary-color, #75AC98);
	gap: 10px;
}

/* Notify Button for Coming Soon */
.ontario-notify-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	padding: 8px 16px;
	border-radius: 6px;
	border: 1px solid rgba(197, 178, 125, 0.3);
	background: transparent;
	color: var(--text-color, #5c5356);
	cursor: pointer;
	transition: all 0.3s ease;
}

.ontario-notify-btn:hover {
	border-color: var(--primary-color, #C5B27D);
	color: var(--primary-color, #C5B27D);
	background: rgba(197, 178, 125, 0.05);
}

/* Agents Footer */
.ontario-agents-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 0;
	border-top: 1px solid rgba(197, 178, 125, 0.2);
	border-bottom: 1px solid rgba(197, 178, 125, 0.2);
	margin-bottom: 48px;
}

.ontario-agents-stats {
	font-size: 14px;
	color: var(--text-color, #5c5356);
}

.ontario-agents-stats strong {
	color: var(--heading-color, #42393C);
	font-weight: 700;
}

.ontario-agents-footer-links {
	display: flex;
	gap: 24px;
}

.ontario-agents-footer-links a {
	font-size: 14px;
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
}

.ontario-agents-footer-links a:hover {
	color: var(--secondary-color, #75AC98);
	gap: 10px;
}

/* Why Agents Section */
.ontario-why-agents {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 48px;
	margin-bottom: 40px;
}

.ontario-why-agents h3 {
	font-family: 'Syne', sans-serif;
	font-size: 24px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	text-align: center;
	margin-bottom: 40px;
}

.ontario-why-card {
	text-align: center;
	padding: 24px;
}

.ontario-why-card i {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 16px;
}

.ontario-why-card h5 {
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
}

.ontario-why-card p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin: 0;
}

/* Agents CTA */
.ontario-agents-cta {
	text-align: center;
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

.ontario-agents-cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 32px;
	font-size: 15px;
	font-weight: 600;
}

.ontario-agents-cta-btn.ml-3 {
	margin-left: 12px;
}

/* Request Section Variant */
.ontario-agents-request-section {
	margin-top: 24px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.08) 0%, rgba(117, 172, 152, 0.05) 100%);
}

/* Responsive Adjustments */
@media (max-width: 991px) {
	.ontario-featured-agent {
		grid-template-columns: 1fr;
		text-align: center;
		padding: 24px;
	}

	.ontario-featured-agent-icon {
		margin: 0 auto;
	}

	.ontario-featured-agent-actions {
		justify-content: center;
	}

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

	.ontario-filter-row {
		flex-direction: column;
		align-items: stretch;
	}

	.ontario-search-box {
		width: 100%;
	}

	.ontario-agents-footer {
		flex-direction: column;
		gap: 16px;
		text-align: center;
	}

	.ontario-why-agents {
		padding: 32px;
	}
}

@media (max-width: 768px) {
	.ontario-agents-title {
		font-size: 28px;
	}

	.ontario-agents-tabs {
		gap: 8px;
	}

	.ontario-agents-tabs .ontario-tab-btn {
		padding: 8px 14px;
		font-size: 12px;
	}

	.ontario-agents-grid {
		grid-template-columns: 1fr;
	}

	.ontario-featured-agent-tags {
		justify-content: center;
	}

	.ontario-why-agents {
		padding: 24px;
	}

	.ontario-why-card {
		margin-bottom: 24px;
	}

	.ontario-agents-filter-chips {
		gap: 8px;
	}

	.ontario-filter-chip {
		padding: 6px 14px;
		font-size: 12px;
	}
}

/* ===== Innovation Landing Page ===== */

/* Network Badge Section */
.ontario-network-badge-section {
	background: var(--gray-color, #F8F8F8);
}

.ontario-network-badge {
	display: inline-block;
	background: transparent;
	border: 1px solid rgba(197, 178, 125, 0.4);
	border-radius: 50px;
	padding: 12px 28px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
}

/* Intro Section */
.ontario-landing-intro-section {
	background: var(--gray-color, #F8F8F8);
}

.ontario-landing-intro-content {
	text-align: center;
}

.ontario-intro-text {
	font-size: 18px;
	color: var(--text-color, #5c5356);
	line-height: 1.8;
	margin-bottom: 28px;
}

.ontario-intro-highlight {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1), rgba(117, 172, 152, 0.08));
	border-left: 4px solid var(--primary-color, #C5B27D);
	border-radius: 0 12px 12px 0;
	padding: 24px 32px;
	margin: 28px 0;
	text-align: left;
}

.ontario-intro-highlight p {
	font-size: 17px;
	color: var(--heading-color, #42393C);
	font-weight: 600;
	font-style: italic;
	line-height: 1.7;
	margin: 0;
}

.ontario-intro-guide {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	font-style: italic;
}

/* Challenges Section V2 - Modern Horizontal Cards */
.ontario-challenges-v2 {
	background: #ffffff;
	padding: 100px 0 80px;
	position: relative;
}

.ontario-challenges-v2::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(197, 178, 125, 0.2), transparent);
}

.ontario-challenges-header {
	text-align: center;
	margin-bottom: 60px;
}

.ontario-challenges-label {
	display: inline-block;
	padding: 8px 18px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 50px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	margin-bottom: 20px;
}

.ontario-challenges-title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 36px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
	line-height: 1.3;
}

.ontario-challenges-subtitle {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	margin: 0;
}

/* Grid Layout - 5 Cards in One Row */
.ontario-challenges-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 20px;
	align-items: stretch;
}

/* Challenge Card */
.ontario-challenge-card {
	position: relative;
	background: #ffffff;
	border-radius: 16px;
	padding: 20px 18px;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	border: 1px solid rgba(0, 0, 0, 0.06);
	overflow: hidden;
}

.ontario-challenge-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	transition: height 0.3s ease;
}

.ontario-challenge-card.card-purple::before { background: #442e66; }
.ontario-challenge-card.card-sage::before { background: #668f7b; }
.ontario-challenge-card.card-coral::before { background: #dc3545; }
.ontario-challenge-card.card-navy::before { background: #1E3A5F; }
.ontario-challenge-card.card-gold::before { background: var(--primary-color, #C5B27D); }

.ontario-challenge-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
}

.ontario-challenge-card:hover::before {
	height: 6px;
}

.ontario-challenge-card__number {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 32px;
	font-weight: 700;
	color: rgba(0, 0, 0, 0.1);
	line-height: 1;
	margin-bottom: 12px;
}

.ontario-challenge-card.card-purple .ontario-challenge-card__number { color: rgba(68, 46, 102, 0.15); }
.ontario-challenge-card.card-sage .ontario-challenge-card__number { color: rgba(102, 143, 123, 0.2); }
.ontario-challenge-card.card-coral .ontario-challenge-card__number { color: rgba(220, 53, 69, 0.15); }
.ontario-challenge-card.card-navy .ontario-challenge-card__number { color: rgba(30, 58, 95, 0.15); }
.ontario-challenge-card.card-gold .ontario-challenge-card__number { color: rgba(197, 178, 125, 0.3); }

.ontario-challenge-card__content {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.ontario-challenge-card__title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 15px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
	line-height: 1.4;
}

.ontario-challenge-card__desc {
	font-size: 12px;
	color: var(--text-color, #5c5356);
	line-height: 1.5;
	margin-bottom: 12px;
	flex: 1;
}

.ontario-challenge-card__tag {
	display: inline-block;
	font-size: 9px;
	font-weight: 600;
	padding: 4px 10px;
	border-radius: 20px;
	background: rgba(0, 0, 0, 0.04);
	color: var(--text-color, #5c5356);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ontario-challenge-card.card-purple .ontario-challenge-card__tag { background: rgba(68, 46, 102, 0.08); color: #442e66; }
.ontario-challenge-card.card-sage .ontario-challenge-card__tag { background: rgba(102, 143, 123, 0.12); color: #668f7b; }
.ontario-challenge-card.card-coral .ontario-challenge-card__tag { background: rgba(220, 53, 69, 0.08); color: #dc3545; }
.ontario-challenge-card.card-navy .ontario-challenge-card__tag { background: rgba(30, 58, 95, 0.08); color: #1E3A5F; }
.ontario-challenge-card.card-gold .ontario-challenge-card__tag { background: rgba(197, 178, 125, 0.15); color: #a08f5a; }

.ontario-challenge-card__icon {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.03);
	transition: all 0.3s ease;
}

.ontario-challenge-card__icon i {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	transition: all 0.3s ease;
}

.ontario-challenge-card.card-purple .ontario-challenge-card__icon { background: rgba(68, 46, 102, 0.08); }
.ontario-challenge-card.card-purple .ontario-challenge-card__icon i { color: #442e66; }

.ontario-challenge-card.card-sage .ontario-challenge-card__icon { background: rgba(102, 143, 123, 0.12); }
.ontario-challenge-card.card-sage .ontario-challenge-card__icon i { color: #668f7b; }

.ontario-challenge-card.card-coral .ontario-challenge-card__icon { background: rgba(220, 53, 69, 0.08); }
.ontario-challenge-card.card-coral .ontario-challenge-card__icon i { color: #dc3545; }

.ontario-challenge-card.card-navy .ontario-challenge-card__icon { background: rgba(30, 58, 95, 0.08); }
.ontario-challenge-card.card-navy .ontario-challenge-card__icon i { color: #1E3A5F; }

.ontario-challenge-card.card-gold .ontario-challenge-card__icon { background: rgba(197, 178, 125, 0.15); }
.ontario-challenge-card.card-gold .ontario-challenge-card__icon i { color: #a08f5a; }

.ontario-challenge-card__icon--el {
	line-height: 0;
}
.ontario-challenge-card__icon--el .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
}
.ontario-challenge-card__icon--el svg {
	width: 14px;
	height: 14px;
	max-width: 14px;
	max-height: 14px;
	display: block;
}
.ontario-challenge-card__icon--el svg path,
.ontario-challenge-card__icon--el svg circle {
	fill: currentColor;
}
.ontario-challenge-card__icon--el svg [fill="none"] {
	fill: none !important;
}
.ontario-challenge-card__icon--el svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

/* Hover - Down Arrow Indicator */
.ontario-challenge-card__arrow {
	position: absolute;
	bottom: -30px;
	left: 50%;
	transform: translateX(-50%);
	width: 36px;
	height: 36px;
	background: rgba(255, 255, 255, 0.95);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	opacity: 0;
	transition: all 0.3s ease;
	z-index: 10;
}

.ontario-challenge-card__arrow i {
	font-size: 14px;
	color: var(--heading-color, #42393C);
	animation: bounceDown 1s ease infinite;
}

.ontario-challenge-card:hover .ontario-challenge-card__arrow {
	opacity: 1;
	bottom: 16px;
}

@keyframes bounceDown {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(3px); }
}

/* Challenges V2 Responsive - Tablet: 3 columns + 2 columns */
@media (max-width: 1399px) {
	.ontario-challenges-grid {
		grid-template-columns: repeat(5, 1fr);
		gap: 14px;
	}

	.ontario-challenge-card {
		padding: 18px 16px;
	}

	.ontario-challenge-card__number {
		font-size: 28px;
		margin-bottom: 10px;
	}

	.ontario-challenge-card__title {
		font-size: 14px;
	}

	.ontario-challenge-card__desc {
		font-size: 11px;
	}

	.ontario-challenge-card__tag {
		font-size: 8px;
		padding: 3px 8px;
	}
}

/* Tablet: 3 + 2 split */
@media (max-width: 1199px) {
	.ontario-challenges-grid {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 16px;
	}

	.ontario-challenge-card {
		flex: 0 0 calc(33.333% - 11px);
		min-width: 240px;
		padding: 18px 16px;
	}
}

/* Small tablet: 2 columns */
@media (max-width: 991px) {
	.ontario-challenges-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 16px;
	}

	.ontario-challenge-card {
		padding: 18px 16px;
	}

	.ontario-challenges-title {
		font-size: 28px;
	}

	.ontario-challenges-header {
		margin-bottom: 40px;
	}
}

/* Intro Section V2 - Modern Redesign */
.ontario-landing-intro-v2 {
	background: linear-gradient(180deg, #fafafa 0%, #f5f5f5 100%);
	padding: 80px 0 60px;
	position: relative;
}

.ontario-landing-intro-v2::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(197, 178, 125, 0.3), transparent);
}

.ontario-intro-wrapper {
	text-align: center;
}

/* Badge */
.ontario-intro-badge {
	display: inline-flex;
	align-items: center;
	padding: 10px 24px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 50px;
	margin-bottom: 40px;
}

.ontario-badge-text {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
}

/* Content */
.ontario-intro-content {
	max-width: 800px;
	margin: 0 auto;
}

.ontario-intro-heading {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 36px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 24px;
	line-height: 1.3;
}

.ontario-intro-lead {
	font-size: 18px;
	color: var(--text-color, #5c5356);
	line-height: 1.8;
	margin-bottom: 40px;
}

/* Problem Card */
.ontario-problem-card {
	position: relative;
	background: #ffffff;
	border-radius: 16px;
	padding: 32px 40px;
	margin: 40px 0;
	text-align: left;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
	display: flex;
	align-items: flex-start;
	gap: 24px;
}

.ontario-problem-card__icon {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.15), rgba(117, 172, 152, 0.08));
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ontario-problem-card__icon i {
	font-size: 24px;
	color: var(--secondary-color, #75AC98);
}

/* Landing intro widget: Elementor / SVG icon matches FA size & theme color */
.ontario-problem-card__icon--el {
	line-height: 0;
}
.ontario-problem-card__icon--el .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	color: inherit;
}
.ontario-problem-card__icon--el svg {
	width: 24px;
	height: 24px;
	max-width: 24px;
	max-height: 24px;
	display: block;
}
.ontario-problem-card__icon--el svg path,
.ontario-problem-card__icon--el svg circle,
.ontario-problem-card__icon--el svg rect,
.ontario-problem-card__icon--el svg polygon,
.ontario-problem-card__icon--el svg polyline,
.ontario-problem-card__icon--el svg ellipse {
	fill: currentColor;
}
.ontario-problem-card__icon--el svg [fill="none"],
.ontario-problem-card__icon--el svg [fill="transparent"] {
	fill: none !important;
}
.ontario-problem-card__icon--el svg [stroke]:not([stroke="none"]):not([stroke="0"]) {
	stroke: currentColor;
}

.ontario-problem-card__content {
	flex: 1;
}

.ontario-problem-card__content p {
	font-size: 16px;
	color: var(--heading-color, #42393C);
	font-weight: 500;
	line-height: 1.7;
	margin: 0;
	font-style: italic;
}

.ontario-problem-card__accent {
	position: absolute;
	left: 0;
	top: 20%;
	bottom: 20%;
	width: 4px;
	background: linear-gradient(180deg, var(--secondary-color, #75AC98), var(--primary-color, #C5B27D));
	border-radius: 0 3px 3px 0;
}

/* Solution Statement */
.ontario-solution-statement {
	margin-top: 48px;
	padding: 24px 0;
}

.ontario-solution-statement p {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin: 20px 0;
	padding: 0 20px;
}

.ontario-solution-line {
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(197, 178, 125, 0.4), transparent);
	margin: 0 auto;
	max-width: 200px;
}

/* Responsive */
@media (max-width: 768px) {
	.ontario-landing-intro-v2 {
		padding: 60px 0 40px;
	}

	.ontario-intro-badge {
		padding: 8px 18px;
		margin-bottom: 28px;
	}

	.ontario-badge-text {
		font-size: 11px;
		letter-spacing: 1.5px;
	}

	.ontario-intro-heading {
		font-size: 28px;
		margin-bottom: 20px;
	}

	.ontario-intro-lead {
		font-size: 16px;
		margin-bottom: 28px;
	}

	.ontario-problem-card {
		padding: 24px 28px;
		margin: 28px 0;
		gap: 16px;
	}

	.ontario-problem-card__icon {
		width: 44px;
		height: 44px;
		border-radius: 12px;
	}

	.ontario-problem-card__icon i {
		font-size: 20px;
	}

	.ontario-problem-card__icon--el svg {
		width: 20px;
		height: 20px;
		max-width: 20px;
		max-height: 20px;
	}

	.ontario-problem-card__content p {
		font-size: 15px;
	}

	.ontario-solution-statement {
		margin-top: 32px;
		padding: 16px 0;
	}

	.ontario-solution-statement p {
		font-size: 15px;
		padding: 0 10px;
	}
}

/* Challenge Tiles Section */
.ontario-challenge-tiles-section {
	background: var(--white-color, #ffffff);
}

.ontario-tiles-section-title {
	font-family: 'Syne', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	text-align: center;
	margin-bottom: 48px;
}

.ontario-challenge-tiles-row {
	justify-content: center;
}

.ontario-challenge-tile {
	display: block;
	background: var(--gray-color, #F8F8F8);
	border: 1px solid rgba(197, 178, 125, 0.1);
	border-radius: 16px;
	padding: 32px 28px;
	text-decoration: none;
	position: relative;
	overflow: hidden;
	transition: all 0.35s ease;
	margin-bottom: 24px;
	height: calc(100% - 24px);
}

.ontario-challenge-tile::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	transition: height 0.3s ease;
}

.ontario-challenge-tile.tile-purple::before { background: #442e66; }
.ontario-challenge-tile.tile-sage::before { background: #668f7b; }
.ontario-challenge-tile.tile-coral::before { background: #dc3545; }
.ontario-challenge-tile.tile-navy::before { background: #1E3A5F; }
.ontario-challenge-tile.tile-gold::before { background: var(--primary-color, #C5B27D); }

.ontario-challenge-tile:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
}

.ontario-challenge-tile:hover::before {
	height: 6px;
}

.ontario-tile-number {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--white-color, #ffffff);
	margin-bottom: 18px;
}

.tile-purple .ontario-tile-number { background: #442e66; }
.tile-sage .ontario-tile-number { background: #668f7b; }
.tile-coral .ontario-tile-number { background: #dc3545; }
.tile-navy .ontario-tile-number { background: #1E3A5F; }
.tile-gold .ontario-tile-number { background: var(--primary-color, #C5B27D); }

.ontario-challenge-tile .ontario-tile-title {
	font-family: 'Syne', sans-serif;
	font-size: 17px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
	line-height: 1.4;
}

.ontario-challenge-tile .ontario-tile-summary {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 16px;
}

.ontario-challenge-tile .ontario-tile-core {
	font-size: 12px;
	font-weight: 600;
	padding-top: 14px;
	border-top: 1px solid rgba(197, 178, 125, 0.15);
	display: block;
}

.tile-purple .ontario-tile-core { color: #442e66; }
.tile-sage .ontario-tile-core { color: #668f7b; }
.tile-coral .ontario-tile-core { color: #dc3545; }
.tile-navy .ontario-tile-core { color: #1E3A5F; }
.tile-gold .ontario-tile-core { color: var(--primary-color, #C5B27D); }

.ontario-tile-arrow {
	position: absolute;
	bottom: 20px;
	right: 20px;
	font-size: 18px;
	opacity: 0;
	transition: all 0.3s ease;
}

.tile-purple .ontario-tile-arrow { color: #442e66; }
.tile-sage .ontario-tile-arrow { color: #668f7b; }
.tile-coral .ontario-tile-arrow { color: #dc3545; }
.tile-navy .ontario-tile-arrow { color: #1E3A5F; }
.tile-gold .ontario-tile-arrow { color: var(--primary-color, #C5B27D); }

.ontario-challenge-tile:hover .ontario-tile-arrow {
	opacity: 1;
	transform: translateY(3px);
}

/* Challenge Detail Section V2 */
.ontario-challenge-detail-v2 {
	background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 100%);
	padding: 80px 0;
}

.ontario-challenge-wrapper {
	position: relative;
}

/* Back Navigation */
.ontario-challenge-back {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--text-color, #5c5356);
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	margin-bottom: 32px;
	transition: all 0.3s ease;
	padding: 8px 16px;
	border-radius: 8px;
	background: rgba(0, 0, 0, 0.02);
}

.ontario-challenge-back:hover {
	background: rgba(197, 178, 125, 0.1);
	color: var(--primary-color, #C5B27D);
}

.ontario-challenge-back i {
	font-size: 12px;
	transition: transform 0.3s ease;
}

.ontario-challenge-back:hover i {
	transform: translateX(-3px);
}

/* Header Card */
.ontario-challenge-header-card {
	background: #ffffff;
	border-radius: 20px;
	padding: 40px 48px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
	margin-bottom: 32px;
	display: flex;
	align-items: center;
	gap: 24px;
	position: relative;
	overflow: hidden;
}

.ontario-challenge-header-card::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
}

.challenge-purple .ontario-challenge-header-card::before { background: #442e66; }
.challenge-sage .ontario-challenge-header-card::before { background: #668f7b; }
.challenge-coral .ontario-challenge-header-card::before { background: #dc3545; }
.challenge-navy .ontario-challenge-header-card::before { background: #1E3A5F; }
.challenge-gold .ontario-challenge-header-card::before { background: var(--primary-color, #C5B27D); }

.ontario-challenge-header__number {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 48px;
	font-weight: 700;
	color: rgba(0, 0, 0, 0.08);
	line-height: 1;
}

.challenge-purple .ontario-challenge-header__number { color: rgba(68, 46, 102, 0.12); }
.challenge-sage .ontario-challenge-header__number { color: rgba(102, 143, 123, 0.18); }
.challenge-coral .ontario-challenge-header__number { color: rgba(220, 53, 69, 0.12); }
.challenge-navy .ontario-challenge-header__number { color: rgba(30, 58, 95, 0.12); }
.challenge-gold .ontario-challenge-header__number { color: rgba(197, 178, 125, 0.25); }

.ontario-challenge-header__content {
	flex: 1;
}

.ontario-challenge-header__title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 32px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
	line-height: 1.3;
}

.ontario-challenge-header__tag {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	padding: 6px 14px;
	border-radius: 20px;
	background: rgba(0, 0, 0, 0.04);
}

.challenge-purple .ontario-challenge-header__tag { background: rgba(68, 46, 102, 0.08); color: #442e66; }
.challenge-sage .ontario-challenge-header__tag { background: rgba(102, 143, 123, 0.12); color: #668f7b; }
.challenge-coral .ontario-challenge-header__tag { background: rgba(220, 53, 69, 0.08); color: #dc3545; }
.challenge-navy .ontario-challenge-header__tag { background: rgba(30, 58, 95, 0.08); color: #1E3A5F; }
.challenge-gold .ontario-challenge-header__tag { background: rgba(197, 178, 125, 0.18); color: #a08f5a; }

.ontario-challenge-header__icon {
	width: 60px;
	height: 60px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.03);
}

.challenge-purple .ontario-challenge-header__icon { background: rgba(68, 46, 102, 0.1); }
.challenge-purple .ontario-challenge-header__icon i { color: #442e66; font-size: 24px; }

.challenge-sage .ontario-challenge-header__icon { background: rgba(102, 143, 123, 0.12); }
.challenge-sage .ontario-challenge-header__icon i { color: #668f7b; font-size: 24px; }

.challenge-coral .ontario-challenge-header__icon { background: rgba(220, 53, 69, 0.1); }
.challenge-coral .ontario-challenge-header__icon i { color: #dc3545; font-size: 24px; }

.challenge-navy .ontario-challenge-header__icon { background: rgba(30, 58, 95, 0.1); }
.challenge-navy .ontario-challenge-header__icon i { color: #1E3A5F; font-size: 24px; }

.challenge-gold .ontario-challenge-header__icon { background: rgba(197, 178, 125, 0.15); }
.challenge-gold .ontario-challenge-header__icon i { color: #a08f5a; font-size: 24px; }

/* Elementor icons — match FA sizes & theme colors */
.ontario-challenge-header__icon--el,
.ontario-challenge-header__icon--el .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	margin: 0;
}
.ontario-challenge-header__icon--el svg {
	width: 24px;
	height: 24px;
	display: block;
}
.ontario-challenge-header__icon--el svg path,
.ontario-challenge-header__icon--el svg circle { fill: currentColor; }
.ontario-challenge-header__icon--el svg [fill="none"] { fill: none !important; }
.ontario-challenge-header__icon--el svg [stroke]:not([stroke="none"]) { stroke: currentColor; }

.challenge-purple .ontario-challenge-header__icon--el,
.challenge-purple .ontario-challenge-header__icon--el .elementor-icon { color: #442e66; }
.challenge-sage .ontario-challenge-header__icon--el,
.challenge-sage .ontario-challenge-header__icon--el .elementor-icon { color: #668f7b; }
.challenge-coral .ontario-challenge-header__icon--el,
.challenge-coral .ontario-challenge-header__icon--el .elementor-icon { color: #dc3545; }
.challenge-navy .ontario-challenge-header__icon--el,
.challenge-navy .ontario-challenge-header__icon--el .elementor-icon { color: #1E3A5F; }
.challenge-gold .ontario-challenge-header__icon--el,
.challenge-gold .ontario-challenge-header__icon--el .elementor-icon { color: #a08f5a; }

.ontario-challenge-detail-v2__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	flex-shrink: 0;
}
.ontario-challenge-detail-v2__icon .elementor-icon { margin: 0; line-height: 0; }
.ontario-challenge-detail-v2__icon--18 svg,
.ontario-challenge-detail-v2__icon--18 i { width: 18px; height: 18px; font-size: 18px; }
.ontario-challenge-detail-v2__icon--18 svg { display: block; }
.ontario-challenge-detail-v2__icon--14 svg,
.ontario-challenge-detail-v2__icon--14 i { width: 14px; height: 14px; font-size: 14px; }
.ontario-challenge-detail-v2__icon--14 svg { display: block; }
.ontario-challenge-detail-v2__icon--20 svg,
.ontario-challenge-detail-v2__icon--20 i { width: 20px; height: 20px; font-size: 20px; }
.ontario-challenge-detail-v2__icon--20 svg { display: block; }
.ontario-challenge-detail-v2__icon svg path,
.ontario-challenge-detail-v2__icon svg circle { fill: currentColor; }
.ontario-challenge-detail-v2__icon svg [fill="none"] { fill: none !important; }
.ontario-challenge-detail-v2__icon svg [stroke]:not([stroke="none"]) { stroke: currentColor; }

.challenge-purple .ontario-challenge-problem .ontario-challenge-detail-v2__icon { color: #442e66; }
.challenge-sage .ontario-challenge-problem .ontario-challenge-detail-v2__icon { color: #668f7b; }
.challenge-coral .ontario-challenge-problem .ontario-challenge-detail-v2__icon { color: #dc3545; }
.challenge-navy .ontario-challenge-problem .ontario-challenge-detail-v2__icon { color: #1E3A5F; }
.challenge-gold .ontario-challenge-problem .ontario-challenge-detail-v2__icon { color: #a08f5a; }

.challenge-purple .ontario-challenge-insight .ontario-challenge-detail-v2__icon { color: #442e66; }
.challenge-sage .ontario-challenge-insight .ontario-challenge-detail-v2__icon { color: #668f7b; }
.challenge-coral .ontario-challenge-insight .ontario-challenge-detail-v2__icon { color: #dc3545; }
.challenge-navy .ontario-challenge-insight .ontario-challenge-detail-v2__icon { color: #1E3A5F; }
.challenge-gold .ontario-challenge-insight .ontario-challenge-detail-v2__icon { color: #a08f5a; }

.challenge-purple .ontario-challenge-enables .ontario-challenge-detail-v2__icon { color: #442e66; }
.challenge-sage .ontario-challenge-enables .ontario-challenge-detail-v2__icon { color: #668f7b; }
.challenge-coral .ontario-challenge-enables .ontario-challenge-detail-v2__icon { color: #dc3545; }
.challenge-navy .ontario-challenge-enables .ontario-challenge-detail-v2__icon { color: #1E3A5F; }
.challenge-gold .ontario-challenge-enables .ontario-challenge-detail-v2__icon { color: #a08f5a; }

.challenge-purple .ontario-intervention-table-header .ontario-challenge-detail-v2__icon { color: #442e66; }
.challenge-sage .ontario-intervention-table-header .ontario-challenge-detail-v2__icon { color: #668f7b; }
.challenge-coral .ontario-intervention-table-header .ontario-challenge-detail-v2__icon { color: #dc3545; }
.challenge-navy .ontario-intervention-table-header .ontario-challenge-detail-v2__icon { color: #1E3A5F; }
.challenge-gold .ontario-intervention-table-header .ontario-challenge-detail-v2__icon { color: #a08f5a; }

.challenge-purple .ontario-challenge-interventions__header i { color: #442e66; }
.challenge-sage .ontario-challenge-interventions__header i { color: #668f7b; }
.challenge-coral .ontario-challenge-interventions__header i { color: #dc3545; }
.challenge-navy .ontario-challenge-interventions__header i { color: #1E3A5F; }
.challenge-gold .ontario-challenge-interventions__header i { color: #a08f5a; }

.challenge-purple .ontario-challenge-interventions__header .ontario-challenge-detail-v2__icon { color: #442e66; }
.challenge-sage .ontario-challenge-interventions__header .ontario-challenge-detail-v2__icon { color: #668f7b; }
.challenge-coral .ontario-challenge-interventions__header .ontario-challenge-detail-v2__icon { color: #dc3545; }
.challenge-navy .ontario-challenge-interventions__header .ontario-challenge-detail-v2__icon { color: #1E3A5F; }
.challenge-gold .ontario-challenge-interventions__header .ontario-challenge-detail-v2__icon { color: #a08f5a; }

.ontario-challenge-interventions--no-numbers .ontario-challenge-interventions__list li {
	gap: 0;
}

/* Content Grid */
.ontario-challenge-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

/* Cards */
.ontario-challenge-card-v2 {
	background: #ffffff;
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(0, 0, 0, 0.04);
}

.ontario-challenge-card-v2__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.ontario-challenge-card-v2__header i {
	font-size: 18px;
}

.ontario-challenge-card-v2__header h3 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin: 0;
}

.ontario-challenge-card-v2 p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin: 0;
}

/* Problem Card — icon follows challenge theme on detail pages */
.ontario-challenge-problem .ontario-challenge-card-v2__header i {
	color: #dc3545;
}
.challenge-purple .ontario-challenge-problem .ontario-challenge-card-v2__header i { color: #442e66; }
.challenge-sage .ontario-challenge-problem .ontario-challenge-card-v2__header i { color: #668f7b; }
.challenge-coral .ontario-challenge-problem .ontario-challenge-card-v2__header i { color: #dc3545; }
.challenge-navy .ontario-challenge-problem .ontario-challenge-card-v2__header i { color: #1E3A5F; }
.challenge-gold .ontario-challenge-problem .ontario-challenge-card-v2__header i { color: #a08f5a; }

.ontario-challenge-problem {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.ontario-challenge-problem p {
	flex: 1;
	margin: 0;
}

/* Core Challenge Card */
.ontario-challenge-core {
	text-align: center;
	padding: 40px 32px;
}

.ontario-challenge-core__label {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--text-color, #5c5356);
	margin-bottom: 12px;
}

.ontario-challenge-core__value {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 22px;
	font-weight: 700;
}

.challenge-purple .ontario-challenge-core__value { color: #442e66; }
.challenge-sage .ontario-challenge-core__value { color: #668f7b; }
.challenge-coral .ontario-challenge-core__value { color: #dc3545; }
.challenge-navy .ontario-challenge-core__value { color: #1E3A5F; }
.challenge-gold .ontario-challenge-core__value { color: #a08f5a; }

/* Insight Card */
.ontario-challenge-insight {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.08), rgba(117, 172, 152, 0.06));
}

.ontario-challenge-insight__badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	background: #ffffff;
	border-radius: 20px;
	margin-bottom: 16px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
	width: fit-content; /* Only as wide as content, not full-width */
	max-width: 100%; /* Prevent overflow on very small screens */
}

.ontario-challenge-insight__badge i {
	font-size: 14px;
	color: var(--primary-color, #C5B27D);
}

.ontario-challenge-insight__badge span {
	font-size: 12px;
	font-weight: 600;
	color: var(--heading-color, #42393C);
	text-transform: uppercase;
	letter-spacing: 1px;
}

.ontario-challenge-insight p {
	font-style: italic;
}

/* Enables Card */
.ontario-challenge-enables {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.ontario-challenge-enables .ontario-challenge-enables__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.ontario-challenge-enables .ontario-challenge-enables__header i {
	font-size: 18px;
	color: var(--secondary-color, #75AC98);
}

.ontario-challenge-enables .ontario-challenge-enables__header h3 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin: 0;
}

.ontario-challenge-enables p {
	flex: 1;
	margin: 0;
}

/* Full Width Card */
.ontario-challenge-fullwidth {
	grid-column: 1 / -1;
}

/* Interventions Card */
.ontario-challenge-interventions {
	grid-column: 1 / -1;
}

.ontario-challenge-interventions__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 24px;
}

.ontario-challenge-interventions__header i {
	font-size: 18px;
	color: var(--primary-color, #C5B27D);
}

.ontario-challenge-interventions__header h3 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin: 0;
}

.ontario-challenge-interventions__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

.ontario-challenge-interventions__list li {
	display: flex;
	gap: 16px;
	padding: 20px;
	background: rgba(0, 0, 0, 0.02);
	border-radius: 12px;
	transition: all 0.3s ease;
}

.ontario-challenge-interventions__list li:hover {
	background: rgba(197, 178, 125, 0.08);
}

.ontario-intervention-number {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 700;
	color: #ffffff;
}

.challenge-purple .ontario-intervention-number { background: #442e66; }
.challenge-sage .ontario-intervention-number { background: #668f7b; }
.challenge-coral .ontario-intervention-number { background: #dc3545; }
.challenge-navy .ontario-intervention-number { background: #1E3A5F; }
.challenge-gold .ontario-intervention-number { background: var(--primary-color, #C5B27D); }

.ontario-intervention-content {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.ontario-intervention-content strong {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 15px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
}

.ontario-intervention-content span {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.5;
}

/* Examples of Suitable Interventions - Clean List Design */
.ontario-challenge-examples {
	grid-column: 1 / -1;
}

.ontario-examples-title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--text-color, #5c5356);
	margin: 0 0 20px 0;
}

.ontario-examples-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.ontario-example-item {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 12px 0;
}

.ontario-examples-list--dividers .ontario-example-item + .ontario-example-item {
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.ontario-examples-list--cards .ontario-example-item {
	background: #ffffff;
	border-radius: 8px;
	padding: 16px 20px;
	border: 1px solid rgba(0, 0, 0, 0.06);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.ontario-examples-list--cards .ontario-example-item + .ontario-example-item {
	margin-top: 12px;
}

.ontario-example-number {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
	color: #ffffff;
	background: var(--primary-color, #C5B27D);
	position: relative;
}

.ontario-example-content {
	flex: 1;
	line-height: 1.6;
}

.ontario-example-link {
	display: inline;
	text-decoration: none;
	color: inherit;
	transition: opacity 0.2s ease;
}

.ontario-example-link:hover {
	opacity: 0.8;
}

.ontario-example-link::after {
	content: '';
	display: inline-block;
	width: 12px;
	height: 12px;
	margin-left: 6px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235c5356' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'%3E%3C/path%3E%3Cpolyline points='15 3 21 3 21 9'%3E%3C/polyline%3E%3Cline x1='10' y1='14' x2='21' y2='3'%3E%3C/line%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	vertical-align: middle;
	opacity: 0.5;
}

.ontario-example-item__title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-weight: 700;
	color: var(--heading-color, #42393C);
}

.ontario-example-item__desc {
	color: var(--text-color, #5c5356);
}

/* Equal height cards in grid rows */
.ontario-challenge-grid {
	align-items: stretch; /* Makes all cards in a row equal height */
}

.ontario-challenge-card-v2 {
	display: flex;
	flex-direction: column;
	height: 100%; /* Ensure cards fill the grid row height */
}

/* Core Challenge Card - centers content vertically within equal height */
.ontario-challenge-core {
	text-align: center;
	padding: 40px 32px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100%;
}

/* Insight Card - ensures content fills height properly */
.ontario-challenge-insight {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.08), rgba(117, 172, 152, 0.06));
	display: flex;
	flex-direction: column;
	height: 100%;
}

.ontario-challenge-insight p {
	font-style: italic;
	flex: 1; /* Allows paragraph to fill available space */
	margin: 0;
}

/* Intervention Table - Challenge 1 Only */
.ontario-intervention-table-wrapper {
	grid-column: 1 / -1;
	background: #ffffff;
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(0, 0, 0, 0.04);
	margin-top: 8px;
}

.ontario-intervention-table-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 24px;
	padding-bottom: 16px;
	border-bottom: 2px solid rgba(68, 46, 102, 0.15);
}

.ontario-intervention-table-header i {
	font-size: 20px;
	color: #442e66;
}

.ontario-intervention-table-header h3 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 18px;
	font-weight: 700;
	color: #442e66;
	margin: 0;
}

/* Intervention table + icons: match challenge color theme */
.challenge-sage .ontario-intervention-table-header {
	border-bottom-color: rgba(102, 143, 123, 0.25);
}
.challenge-sage .ontario-intervention-table-header i,
.challenge-sage .ontario-intervention-table-header h3 { color: #668f7b; }

.challenge-coral .ontario-intervention-table-header {
	border-bottom-color: rgba(220, 53, 69, 0.2);
}
.challenge-coral .ontario-intervention-table-header i,
.challenge-coral .ontario-intervention-table-header h3 { color: #dc3545; }

.challenge-navy .ontario-intervention-table-header {
	border-bottom-color: rgba(30, 58, 95, 0.2);
}
.challenge-navy .ontario-intervention-table-header i,
.challenge-navy .ontario-intervention-table-header h3 { color: #1E3A5F; }

.challenge-gold .ontario-intervention-table-header {
	border-bottom-color: rgba(160, 143, 90, 0.25);
}
.challenge-gold .ontario-intervention-table-header i,
.challenge-gold .ontario-intervention-table-header h3 { color: #a08f5a; }

.ontario-intervention-table-container {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ontario-intervention-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 14px;
}

.ontario-intervention-table thead {
	background: linear-gradient(135deg, #442e66 0%, #5a3d7a 100%);
}

.challenge-sage .ontario-intervention-table thead {
	background: linear-gradient(135deg, #668f7b 0%, #7a9f8d 100%);
}
.challenge-coral .ontario-intervention-table thead {
	background: linear-gradient(135deg, #dc3545 0%, #e4606d 100%);
}
.challenge-navy .ontario-intervention-table thead {
	background: linear-gradient(135deg, #1E3A5F 0%, #2d5280 100%);
}
.challenge-gold .ontario-intervention-table thead {
	background: linear-gradient(135deg, #a08f5a 0%, #C5B27D 100%);
}

.ontario-intervention-table thead th {
	padding: 16px 20px;
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: #ffffff;
	text-align: left;
	border: none;
}

.ontario-intervention-table thead th:first-child {
	border-radius: 10px 0 0 0;
}

.ontario-intervention-table thead th:last-child {
	border-radius: 0 10px 0 0;
}

.ontario-intervention-table tbody tr {
	background: #ffffff;
	transition: background 0.3s ease;
}

.ontario-intervention-table tbody tr:nth-child(even) {
	background: #fafafa;
}

.ontario-intervention-table tbody tr:hover {
	background: rgba(68, 46, 102, 0.04);
}

.challenge-sage .ontario-intervention-table tbody tr:hover { background: rgba(102, 143, 123, 0.06); }
.challenge-coral .ontario-intervention-table tbody tr:hover { background: rgba(220, 53, 69, 0.05); }
.challenge-navy .ontario-intervention-table tbody tr:hover { background: rgba(30, 58, 95, 0.05); }
.challenge-gold .ontario-intervention-table tbody tr:hover { background: rgba(197, 178, 125, 0.1); }

.ontario-intervention-table tbody td {
	padding: 20px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	border-bottom: 1px solid rgba(0, 0, 0, 0.04);
	vertical-align: top;
}

.ontario-intervention-table tbody tr:last-child td:first-child {
	border-radius: 0 0 0 10px;
}

.ontario-intervention-table tbody tr:last-child td:last-child {
	border-radius: 0 0 10px 0;
}

.ontario-intervention-table tbody td strong {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-weight: 600;
	color: #442e66;
}

.challenge-sage .ontario-intervention-table tbody td strong { color: #668f7b; }
.challenge-coral .ontario-intervention-table tbody td strong { color: #b02a37; }
.challenge-navy .ontario-intervention-table tbody td strong { color: #1E3A5F; }
.challenge-gold .ontario-intervention-table tbody td strong { color: #8a7a4a; }

.ontario-audience-tag {
	display: inline-block;
	padding: 6px 12px;
	background: rgba(68, 46, 102, 0.08);
	color: #442e66;
	font-size: 12px;
	font-weight: 500;
	border-radius: 20px;
	white-space: nowrap;
}

.challenge-sage .ontario-audience-tag { background: rgba(102, 143, 123, 0.12); color: #668f7b; }
.challenge-coral .ontario-audience-tag { background: rgba(220, 53, 69, 0.08); color: #c82333; }
.challenge-navy .ontario-audience-tag { background: rgba(30, 58, 95, 0.1); color: #1E3A5F; }
.challenge-gold .ontario-audience-tag { background: rgba(197, 178, 125, 0.2); color: #8a7a4a; }

/* Responsive Table */
@media (max-width: 991px) {
	.ontario-intervention-table-wrapper {
		padding: 24px;
	}
	
	.ontario-intervention-table-header h3 {
		font-size: 16px;
	}
	
	.ontario-intervention-table thead {
		display: none;
	}
	
	.ontario-intervention-table tbody,
	.ontario-intervention-table tbody tr,
	.ontario-intervention-table tbody td {
		display: block;
		width: 100%;
	}
	
	.ontario-intervention-table tbody tr {
		margin-bottom: 16px;
		background: #ffffff;
		border-radius: 12px;
		box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
		border: 1px solid rgba(0, 0, 0, 0.06);
		overflow: hidden;
	}
	
	.ontario-intervention-table tbody tr:nth-child(even) {
		background: #ffffff;
	}
	
	.ontario-intervention-table tbody tr:hover {
		background: #ffffff;
	}
	
	.ontario-intervention-table tbody td {
		padding: 16px;
		border-bottom: 1px solid rgba(0, 0, 0, 0.04);
		position: relative;
		padding-left: 40%;
	}
	
	.ontario-intervention-table tbody td:last-child {
		border-bottom: none;
	}
	
	.ontario-intervention-table tbody td::before {
		content: attr(data-label);
		position: absolute;
		left: 16px;
		width: 35%;
		font-family: var(--heading-font, 'Ubuntu', sans-serif);
		font-weight: 600;
		font-size: 11px;
		letter-spacing: 0.5px;
		text-transform: uppercase;
		color: #442e66;
	}
	
	.ontario-intervention-table tbody td strong {
		font-size: 15px;
	}
	
	.ontario-audience-tag {
		font-size: 11px;
		padding: 4px 10px;
	}
}

@media (max-width: 576px) {
	.ontario-intervention-table-wrapper {
		padding: 20px;
	}
	
	.ontario-intervention-table tbody td {
		padding-left: 16px;
		padding-top: 40px;
	}
	
	.ontario-intervention-table tbody td::before {
		top: 16px;
		left: 16px;
		width: auto;
	}
}

/* Responsive */
@media (max-width: 991px) {
	.ontario-challenge-grid {
		grid-template-columns: 1fr;
		gap: 20px; /* Slightly smaller gap on mobile */
	}
	
	/* On mobile, cards don't need to stretch to equal height since they're stacked */
	.ontario-challenge-card-v2 {
		height: auto;
	}
	
	/* Core card padding adjustment for mobile */
	.ontario-challenge-core {
		padding: 32px 24px;
	}
	
	.ontario-challenge-fullwidth {
		grid-column: 1 / -1;
	}
	
	.ontario-challenge-interventions__list {
		grid-template-columns: 1fr;
	}
	
	.ontario-challenge-header-card {
		padding: 32px 28px;
		flex-wrap: wrap;
	}
	
	.ontario-challenge-header__title {
		font-size: 26px;
	}
	
	.ontario-challenge-header__number {
		font-size: 36px;
	}
}

@media (max-width: 768px) {
	.ontario-challenge-detail-v2 {
		padding: 60px 0;
	}
	
	.ontario-challenge-header-card {
		padding: 28px 24px;
	}
	
	.ontario-challenge-header__title {
		font-size: 22px;
	}
	
	.ontario-challenge-card-v2 {
		padding: 24px;
	}
}

/* Password Gate Section */
.ontario-password-gate-section {
	background: var(--gray-color, #F8F8F8);
}

.ontario-password-box {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 20px;
	padding: 56px 48px;
	text-align: center;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
}

.ontario-password-icon {
	width: 80px;
	height: 80px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15), rgba(117, 172, 152, 0.1));
	border: 2px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 32px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 28px;
}

.ontario-password-box h2 {
	font-family: 'Syne', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 14px;
}

.ontario-password-subtitle {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin-bottom: 32px;
}

.ontario-password-error {
	background: rgba(220, 53, 69, 0.08);
	border: 1px solid rgba(220, 53, 69, 0.2);
	border-radius: 10px;
	padding: 14px 20px;
	color: #dc3545;
	font-size: 14px;
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.ontario-password-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 32px;
}

.ontario-password-input-wrap {
	position: relative;
	display: flex;
	align-items: center;
}

.ontario-password-input-wrap i {
	position: absolute;
	left: 18px;
	color: var(--primary-color, #C5B27D);
	font-size: 16px;
}

.ontario-password-input-wrap input {
	width: 100%;
	padding: 16px 16px 16px 48px;
	border: 2px solid rgba(197, 178, 125, 0.25);
	border-radius: 12px;
	font-size: 15px;
	color: var(--heading-color, #42393C);
	background: var(--white-color, #ffffff);
	transition: all 0.3s ease;
}

.ontario-password-input-wrap input:focus {
	outline: none;
	border-color: var(--primary-color, #C5B27D);
	box-shadow: 0 0 0 4px rgba(197, 178, 125, 0.1);
}

.ontario-password-input-wrap input::placeholder {
	color: var(--text-color, #5c5356);
}

.ontario-password-submit {
	width: 100%;
	justify-content: center;
	padding: 16px 24px;
	font-size: 15px;
}

.ontario-password-help {
	padding-top: 28px;
	border-top: 1px solid rgba(197, 178, 125, 0.15);
}

.ontario-password-help p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin-bottom: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

/* Request Access Page */
.ontario-request-access-section {
	background: var(--gray-color, #F8F8F8);
}

.ontario-request-box {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 20px;
	padding: 56px 48px;
	text-align: center;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
}

.ontario-request-form-page {
	text-align: left;
	margin-top: 32px;
}

.ontario-request-form-page .ontario-form-group {
	margin-bottom: 20px;
}

.ontario-request-form-page label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 600;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-request-form-page label i {
	color: var(--primary-color, #C5B27D);
	font-size: 14px;
}

.ontario-request-form-page .required {
	color: #dc3545;
	font-size: 12px;
}

.ontario-request-form-page .ontario-form-control {
	width: 100%;
	padding: 14px 18px;
	border: 1px solid rgba(197, 178, 125, 0.25);
	border-radius: 12px;
	font-size: 15px;
	color: var(--heading-color, #42393C);
	background: var(--gray-color, #F8F8F8);
	transition: all 0.3s ease;
}

.ontario-request-form-page .ontario-form-control:focus {
	outline: none;
	border-color: var(--primary-color, #C5B27D);
	background: var(--white-color, #ffffff);
	box-shadow: 0 0 0 3px rgba(197, 178, 125, 0.1);
}

.ontario-request-form-page .ontario-form-control::placeholder {
	color: rgba(92, 83, 86, 0.5);
}

.ontario-request-form-page textarea.ontario-form-control {
	resize: vertical;
	min-height: 100px;
}

.ontario-submit-request-page {
	width: 100%;
	justify-content: center;
	padding: 16px 28px;
	font-size: 15px;
	margin-top: 8px;
}

.ontario-request-back-link {
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid rgba(197, 178, 125, 0.15);
}

.ontario-request-back-link a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	color: var(--text-color, #5c5356);
	text-decoration: none;
	transition: color 0.3s ease;
}

.ontario-request-back-link a:hover {
	color: var(--primary-color, #C5B27D);
}

.ontario-request-success {
	text-align: center;
	padding: 20px 0;
}

.ontario-request-success-icon {
	width: 80px;
	height: 80px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(117, 172, 152, 0.15), rgba(117, 172, 152, 0.1));
	border: 2px solid rgba(117, 172, 152, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 32px;
	color: var(--secondary-color, #75AC98);
	margin: 0 auto 24px;
}

.ontario-request-success h2 {
	font-family: 'Syne', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
}

.ontario-request-success-text {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin-bottom: 32px;
}

/* Request Success V2 - Clean Professional Design */
.ontario-request-success-v2 {
	background: #ffffff;
	border-radius: 20px;
	padding: 0;
	text-align: center;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	border: 1px solid #f0f0f0;
	overflow: hidden;
}

.ontario-success-header {
	background: linear-gradient(135deg, #75AC98 0%, #5a9a82 100%);
	padding: 48px 24px 64px;
	position: relative;
}

.ontario-success-badge {
	width: 88px;
	height: 88px;
	background: #ffffff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
	animation: badgePop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
	position: relative;
	z-index: 2;
}

.ontario-success-badge i {
	font-size: 40px;
	color: #75AC98;
	animation: checkBounce 0.5s ease 0.3s both;
}

@keyframes badgePop {
	0% { transform: scale(0); opacity: 0; }
	100% { transform: scale(1); opacity: 1; }
}

@keyframes checkBounce {
	0% { transform: scale(0); }
	50% { transform: scale(1.2); }
	100% { transform: scale(1); }
}

.ontario-success-confetti {
	position: absolute;
	inset: 0;
	pointer-events: none;
	overflow: hidden;
}

.ontario-success-confetti span {
	position: absolute;
	width: 8px;
	height: 8px;
	background: rgba(255, 255, 255, 0.4);
	border-radius: 50%;
	animation: confettiFall 3s ease-out infinite;
}

.ontario-success-confetti span:nth-child(1) { left: 10%; animation-delay: 0s; }
.ontario-success-confetti span:nth-child(2) { left: 20%; animation-delay: 0.2s; }
.ontario-success-confetti span:nth-child(3) { left: 30%; animation-delay: 0.4s; }
.ontario-success-confetti span:nth-child(4) { left: 50%; animation-delay: 0.1s; }
.ontario-success-confetti span:nth-child(5) { left: 60%; animation-delay: 0.3s; }
.ontario-success-confetti span:nth-child(6) { left: 70%; animation-delay: 0.5s; }
.ontario-success-confetti span:nth-child(7) { left: 80%; animation-delay: 0.2s; }
.ontario-success-confetti span:nth-child(8) { left: 90%; animation-delay: 0.4s; }

@keyframes confettiFall {
	0% { transform: translateY(-20px) scale(0); opacity: 0; }
	10% { opacity: 1; transform: translateY(0) scale(1); }
	90% { opacity: 1; }
	100% { transform: translateY(100px) scale(0); opacity: 0; }
}

.ontario-success-body {
	padding: 48px 32px 32px;
	margin-top: -32px;
	background: #ffffff;
	border-radius: 24px 24px 0 0;
	position: relative;
}

.ontario-success-body h2 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 28px;
	font-weight: 700;
	color: #2d2628;
	margin-bottom: 12px;
	letter-spacing: -0.5px;
}

.ontario-success-message {
	font-size: 15px;
	color: #6b5d60;
	line-height: 1.7;
	margin-bottom: 28px;
	max-width: 360px;
	margin-left: auto;
	margin-right: auto;
}

.ontario-success-status {
	display: inline-flex;
	flex-direction: column;
	gap: 8px;
	padding: 16px 24px;
	background: #f8faf9;
	border-radius: 12px;
	border: 1px solid #e8eeea;
}

.ontario-status-row {
	display: flex;
	align-items: center;
	gap: 8px;
	justify-content: center;
}

.ontario-status-dot {
	width: 8px;
	height: 8px;
	background: #f59e0b;
	border-radius: 50%;
	animation: statusPulse 2s ease-in-out infinite;
}

@keyframes statusPulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

.ontario-status-text {
	font-size: 14px;
	font-weight: 600;
	color: #2d2628;
}

.ontario-status-note {
	font-size: 13px;
	color: #75AC98;
	display: flex;
	align-items: center;
	gap: 6px;
	justify-content: center;
}

.ontario-status-note i {
	font-size: 13px;
}

.ontario-success-footer {
	padding: 0 32px 32px;
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}

.ontario-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.2s ease;
	cursor: pointer;
	border: none;
}

.ontario-btn-primary {
	background: #2d2628;
	color: #ffffff;
}

.ontario-btn-primary:hover {
	background: #42393C;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(45, 38, 40, 0.2);
}

.ontario-btn-secondary {
	background: transparent;
	color: #6b5d60;
	border: 1px solid #e0e0e0;
}

.ontario-btn-secondary:hover {
	background: #f8f8f8;
	border-color: #d0d0d0;
	color: #2d2628;
}

.ontario-btn i {
	font-size: 13px;
}

/* Request Access Modal */
.ontario-modal {
	display: none;
	position: fixed;
	z-index: 9999;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
}

.ontario-modal.active {
	display: flex;
}

.ontario-modal-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(4px);
}

.ontario-modal-container {
	position: relative;
	background: var(--white-color, #ffffff);
	border-radius: 24px;
	width: 90%;
	max-width: 520px;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 25px 80px rgba(0, 0, 0, 0.3);
	animation: modalSlideIn 0.3s ease-out;
}

@keyframes modalSlideIn {
	from {
		opacity: 0;
		transform: translateY(-30px) scale(0.95);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.ontario-modal-close {
	position: absolute;
	top: 20px;
	right: 20px;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid rgba(197, 178, 125, 0.2);
	background: var(--gray-color, #F8F8F8);
	color: var(--text-color, #5c5356);
	font-size: 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
	z-index: 10;
}

.ontario-modal-close:hover {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

.ontario-modal-content {
	padding: 48px 40px;
}

.ontario-modal-header {
	text-align: center;
	margin-bottom: 32px;
}

.ontario-modal-icon {
	width: 72px;
	height: 72px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15), rgba(117, 172, 152, 0.1));
	border: 2px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 20px;
}

.ontario-modal-header h3 {
	font-family: 'Syne', sans-serif;
	font-size: 26px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
}

.ontario-modal-subtitle {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin: 0;
}

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

.ontario-request-form label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 600;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-request-form label i {
	color: var(--primary-color, #C5B27D);
	font-size: 14px;
}

.ontario-request-form .required {
	color: #dc3545;
	font-size: 12px;
}

.ontario-form-control {
	width: 100%;
	padding: 14px 18px;
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 12px;
	font-size: 15px;
	color: var(--heading-color, #42393C);
	background: var(--gray-color, #F8F8F8);
	transition: all 0.3s ease;
}

.ontario-form-control:focus {
	outline: none;
	border-color: var(--primary-color, #C5B27D);
	background: var(--white-color, #ffffff);
	box-shadow: 0 0 0 3px rgba(197, 178, 125, 0.1);
}

.ontario-form-control::placeholder {
	color: rgba(92, 83, 86, 0.5);
}

textarea.ontario-form-control {
	resize: vertical;
	min-height: 100px;
}

.ontario-submit-request {
	width: 100%;
	padding: 16px 28px;
	font-size: 15px;
	margin-top: 8px;
}

.ontario-submit-request:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

.ontario-request-success {
	text-align: center;
	padding: 20px 0;
}

.ontario-request-success i {
	font-size: 56px;
	color: var(--secondary-color, #75AC98);
	margin-bottom: 20px;
}

.ontario-request-success h4 {
	font-family: 'Syne', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
}

.ontario-request-success p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin: 0;
}

/* Request Access Modal – mobile: from top, constrained height, compact layout */
@media (max-width: 767px) {
	.ontario-modal.active {
		align-items: center;
		justify-content: center;
		padding: 20px;
		overflow-y: auto;
	}
	.ontario-modal-container {
		width: 100%;
		max-width: 520px;
		max-height: calc(100vh - 40px);
		flex-shrink: 0;
		margin: auto;
		border-radius: 20px;
	}
	.ontario-modal-content {
		padding: 44px 20px 28px;
	}
	.ontario-modal-close {
		top: 12px;
		right: 12px;
		width: 36px;
		height: 36px;
		font-size: 14px;
	}
	.ontario-modal-header {
		margin-bottom: 24px;
	}
	.ontario-modal-icon {
		width: 56px;
		height: 56px;
		font-size: 22px;
		margin-bottom: 14px;
	}
	.ontario-modal-header h3 {
		font-size: 22px;
		margin-bottom: 8px;
	}
	.ontario-modal-subtitle {
		font-size: 13px;
	}
	.ontario-request-form .ontario-form-group {
		margin-bottom: 14px;
	}
	.ontario-request-form label {
		font-size: 13px;
		margin-bottom: 6px;
	}
	.ontario-form-control {
		padding: 12px 14px;
		font-size: 16px;
	}
	textarea.ontario-form-control {
		min-height: 88px;
	}
	.ontario-submit-request {
		padding: 14px 24px;
		font-size: 14px;
		margin-top: 4px;
	}
}

/* Challenge Detail Sections */
.ontario-challenge-detail-section {
	position: relative;
}

.ontario-challenge-detail-section.challenge-purple {
	background: linear-gradient(135deg, rgba(68, 46, 102, 0.04) 0%, rgba(68, 46, 102, 0.02) 100%);
}

.ontario-challenge-detail-section.challenge-sage {
	background: linear-gradient(135deg, rgba(102, 143, 123, 0.06) 0%, rgba(102, 143, 123, 0.03) 100%);
}

.ontario-challenge-detail-section.challenge-coral {
	background: linear-gradient(135deg, rgba(220, 53, 69, 0.04) 0%, rgba(220, 53, 69, 0.02) 100%);
}

.ontario-challenge-detail-section.challenge-navy {
	background: linear-gradient(135deg, rgba(30, 58, 95, 0.04) 0%, rgba(30, 58, 95, 0.02) 100%);
}

.ontario-challenge-detail-section.challenge-gold {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1) 0%, rgba(197, 178, 125, 0.05) 100%);
}

.ontario-challenge-detail-section .ontario-challenge-header {
	margin-bottom: 40px;
}

.ontario-challenge-detail-section .ontario-challenge-number {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Syne', sans-serif;
	font-size: 20px;
	font-weight: 700;
	color: var(--white-color, #ffffff);
	margin-bottom: 20px;
}

.challenge-purple .ontario-challenge-number { background: #442e66; }
.challenge-sage .ontario-challenge-number { background: #668f7b; }
.challenge-coral .ontario-challenge-number { background: #dc3545; }
.challenge-navy .ontario-challenge-number { background: #1E3A5F; }
.challenge-gold .ontario-challenge-number { background: var(--primary-color, #C5B27D); }

.ontario-challenge-detail-section .ontario-challenge-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(26px, 4vw, 34px);
	font-weight: 700;
	color: var(--heading-color, #42393C);
	line-height: 1.25;
}

.ontario-challenge-detail-section .ontario-challenge-intro {
	font-size: 17px;
	color: var(--heading-color, #42393C);
	line-height: 1.8;
	margin-bottom: 24px;
}

.ontario-core-challenge-box {
	background: var(--white-color, #ffffff);
	border-left: 4px solid var(--primary-color, #C5B27D);
	border-radius: 0 10px 10px 0;
	padding: 18px 24px;
	margin-bottom: 28px;
	font-size: 17px;
	color: var(--text-color, #5c5356);
}

.ontario-core-challenge-box strong {
	color: var(--heading-color, #42393C);
}

.ontario-challenge-detail-section .ontario-insight-box {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	background: var(--white-color, #ffffff);
	padding: 24px 28px;
	border-radius: 12px;
	margin-bottom: 28px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}

.ontario-challenge-detail-section .ontario-insight-box i {
	font-size: 22px;
	color: var(--primary-color, #C5B27D);
	margin-top: 2px;
	flex-shrink: 0;
}

.ontario-challenge-detail-section .ontario-insight-box p {
	font-size: 16px;
	font-style: italic;
	color: var(--heading-color, #42393C);
	line-height: 1.6;
	margin: 0;
}

.ontario-challenge-detail-section .ontario-enables-box {
	margin-bottom: 32px;
}

.ontario-challenge-detail-section .ontario-enables-box h4 {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--primary-color, #C5B27D);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.ontario-challenge-detail-section .ontario-enables-box h4 i {
	font-size: 16px;
}

.ontario-challenge-detail-section .ontario-enables-box p {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
}

.ontario-challenge-detail-section .ontario-interventions-title {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--heading-color, #42393C);
	margin-bottom: 18px;
}

.ontario-challenge-detail-section .ontario-interventions-list {
	list-style: none;
	padding: 0;
	margin: 0 0 40px;
}

.ontario-challenge-detail-section .ontario-interventions-list li {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	padding: 14px 0 14px 28px;
	border-bottom: 1px solid rgba(197, 178, 125, 0.15);
	line-height: 1.6;
	position: relative;
}

.ontario-challenge-detail-section .ontario-interventions-list li::before {
	content: '→';
	position: absolute;
	left: 0;
	color: var(--primary-color, #C5B27D);
	font-weight: 700;
}

.ontario-challenge-detail-section .ontario-interventions-list li:last-child {
	border-bottom: none;
}

.ontario-challenge-detail-section .ontario-interventions-list li strong {
	color: var(--heading-color, #42393C);
}

.ontario-challenge-detail-section .ontario-back-to-top {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 600;
	color: var(--text-color, #5c5356);
	text-decoration: none;
	padding: 10px 18px;
	border: 1px solid rgba(197, 178, 125, 0.25);
	border-radius: 8px;
	transition: all 0.3s ease;
	background: var(--white-color, #ffffff);
}

.ontario-challenge-detail-section .ontario-back-to-top:hover {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

/* Final CTA Section */
.ontario-landing-final-cta {
	background: var(--gray-color, #F8F8F8);
}

.ontario-landing-cta-box {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 20px;
	padding: 56px 48px;
	text-align: center;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
}

.ontario-landing-cta-box h2 {
	font-family: 'Syne', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
}

.ontario-landing-cta-box > p {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 32px;
}

.ontario-landing-cta-buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

/* Responsive Adjustments */
@media (max-width: 991px) {
	.ontario-landing-hero-subtitle {
		font-size: 18px;
	}

	.ontario-password-box {
		padding: 40px 32px;
	}

	.ontario-landing-cta-box {
		padding: 40px 32px;
	}

	.ontario-landing-cta-box h2 {
		font-size: 24px;
	}
}

@media (max-width: 768px) {
	.ontario-landing-badge {
		font-size: 11px;
		padding: 6px 14px;
	}

	.ontario-landing-hero-subtitle {
		font-size: 16px;
	}

	.ontario-intro-highlight {
		padding: 18px 22px;
	}

	.ontario-intro-highlight p {
		font-size: 15px;
	}

	.ontario-tiles-section-title {
		font-size: 22px;
	}

	.ontario-password-box {
		padding: 32px 24px;
	}

	.ontario-password-box h2 {
		font-size: 22px;
	}

	.ontario-challenge-detail-section .ontario-challenge-title {
		font-size: 24px;
	}

	.ontario-landing-cta-box {
		padding: 32px 24px;
	}

	.ontario-landing-cta-box h2 {
		font-size: 22px;
	}
}

/* ===== Intelligence Hub Main Page ===== */

/* Main Hub Overview */
.ontario-intelligence-hub-main {
	background: var(--gray-color, #F8F8F8);
}

.ontario-hub-main-header {
	margin-bottom: 70px;
}

.ontario-hub-main-label {
	font-family: 'Syne', sans-serif;
	font-size: 13px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	display: block;
	margin-bottom: 16px;
}

.ontario-hub-main-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(36px, 5vw, 56px);
	font-weight: 800;
	color: var(--heading-color, #42393C);
	margin-bottom: 20px;
	line-height: 1.15;
}

.ontario-hub-main-subtitle {
	font-size: 1.15rem;
	color: var(--text-color, #5c5356);
	max-width: 800px;
	margin: 0 auto;
	line-height: 1.7;
}

/* Hub Navigation Cards */
.ontario-hub-nav-row {
	margin-top: 60px;
}

.ontario-hub-nav-card {
	display: block;
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 32px 24px;
	text-align: center;
	text-decoration: none;
	transition: all 0.35s ease;
	height: 100%;
}

.ontario-hub-nav-card:hover {
	border-color: rgba(197, 178, 125, 0.4);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.1);
	transform: translateY(-6px);
}

.ontario-hub-nav-icon {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 20px;
	transition: all 0.35s ease;
}

.ontario-hub-nav-card:hover .ontario-hub-nav-icon {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

.ontario-hub-nav-icon.ontario-icon-learning {
	background: rgba(117, 172, 152, 0.1);
	border-color: rgba(117, 172, 152, 0.2);
	color: var(--secondary-color, #75AC98);
}

.ontario-hub-nav-card:hover .ontario-hub-nav-icon.ontario-icon-learning {
	background: var(--secondary-color, #75AC98);
	border-color: var(--secondary-color, #75AC98);
	color: var(--white-color, #ffffff);
}

.ontario-hub-nav-icon.ontario-icon-tools {
	background: rgba(245, 200, 66, 0.1);
	border-color: rgba(245, 200, 66, 0.2);
	color: #b8860b;
}

.ontario-hub-nav-card:hover .ontario-hub-nav-icon.ontario-icon-tools {
	background: #b8860b;
	border-color: #b8860b;
	color: var(--white-color, #ffffff);
}

.ontario-hub-nav-icon.ontario-icon-agents {
	background: rgba(155, 89, 182, 0.1);
	border-color: rgba(155, 89, 182, 0.2);
	color: #9b59b6;
}

.ontario-hub-nav-card:hover .ontario-hub-nav-icon.ontario-icon-agents {
	background: #9b59b6;
	border-color: #9b59b6;
	color: var(--white-color, #ffffff);
}

.ontario-hub-nav-card h4 {
	font-family: 'Syne', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-hub-nav-card p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin: 0;
}

/* Elementor SVG icons — match Font Awesome i size & color (IH Overview nav) */
.ontario-hub-nav-icon .elementor-icon,
.ontario-hub-nav-icon svg {
	color: inherit;
	width: 28px !important;
	height: 28px !important;
	max-width: 28px;
	max-height: 28px;
	display: block;
	flex-shrink: 0;
}
.ontario-hub-nav-icon i {
	font-size: 28px;
	line-height: 1;
}
.ontario-hub-nav-icon svg path,
.ontario-hub-nav-icon svg circle,
.ontario-hub-nav-icon svg rect,
.ontario-hub-nav-icon svg line,
.ontario-hub-nav-icon svg polyline,
.ontario-hub-nav-icon svg polygon {
	fill: currentColor;
}
.ontario-hub-nav-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

/* Hub Section Header (shared) */
.ontario-hub-section-header {
	text-align: center;
	margin-bottom: 50px;
}

.ontario-hub-section-label {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	margin-bottom: 14px;
}

.ontario-hub-section-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(28px, 4vw, 42px);
	font-weight: 800;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
}

.ontario-hub-section-desc {
	font-size: 1.05rem;
	color: var(--text-color, #5c5356);
	max-width: 700px;
	margin: 0 auto;
	line-height: 1.6;
}

/* Resources Section */
.ontario-hub-resources-section {
	background: var(--white-color, #ffffff);
}

.ontario-resources-types {
	margin-bottom: 50px;
}

.ontario-resource-type-card {
	background: var(--gray-color, #F8F8F8);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 32px;
	height: 100%;
	transition: all 0.3s ease;
}

.ontario-resource-type-card:hover {
	border-color: rgba(197, 178, 125, 0.3);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

.ontario-resource-type-header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 20px;
}

.ontario-resource-type-icon {
	width: 52px;
	height: 52px;
	border-radius: 12px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
}

.ontario-resource-type-icon.video {
	background: rgba(117, 172, 152, 0.12);
	border-color: rgba(117, 172, 152, 0.25);
	color: var(--secondary-color, #75AC98);
}

.ontario-resource-type-icon.pdf {
	background: rgba(245, 200, 66, 0.12);
	border-color: rgba(245, 200, 66, 0.25);
	color: #b8860b;
}
.ontario-resource-type-icon .elementor-icon,
.ontario-resource-type-icon svg {
	color: inherit;
	width: 22px !important;
	height: 22px !important;
	max-width: 22px;
	max-height: 22px;
	display: block;
}
.ontario-resource-type-icon i {
	font-size: 22px;
	line-height: 1;
}
.ontario-resource-type-icon svg path,
.ontario-resource-type-icon svg circle,
.ontario-resource-type-icon svg rect,
.ontario-resource-type-icon svg polyline,
.ontario-resource-type-icon svg polygon {
	fill: currentColor;
}
.ontario-resource-type-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.ontario-resource-type-header h4 {
	font-family: 'Syne', sans-serif;
	font-size: 20px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin: 0;
}

.ontario-resource-type-card > p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 24px;
}

.ontario-resource-list {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
}

.ontario-resource-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin-bottom: 10px;
}

.ontario-resource-list li i {
	color: var(--primary-color, #C5B27D);
	font-size: 12px;
}
.ontario-resource-list li .elementor-icon,
.ontario-resource-list li svg {
	color: var(--primary-color, #C5B27D);
	width: 14px !important;
	height: 14px !important;
	max-width: 14px;
	max-height: 14px;
	flex-shrink: 0;
	display: block;
}
.ontario-resource-list li svg path,
.ontario-resource-list li svg circle {
	fill: currentColor;
}
.ontario-resource-list li svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

/* Featured Resources */
.ontario-featured-resources {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.06) 0%, rgba(117, 172, 152, 0.04) 100%);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 32px;
}

.ontario-featured-resources h3 {
	font-family: 'Syne', sans-serif;
	font-size: 20px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 24px;
	text-align: center;
}

.ontario-featured-resource-item {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.1);
	border-radius: 12px;
	padding: 24px;
}

.ontario-resource-badge {
	font-size: 10px;
	padding: 4px 10px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.15);
	color: var(--primary-color, #C5B27D);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	display: inline-block;
	margin-bottom: 12px;
}

.ontario-resource-badge.video {
	background: rgba(117, 172, 152, 0.15);
	color: var(--secondary-color, #75AC98);
}

.ontario-resource-badge.pdf {
	background: rgba(245, 200, 66, 0.15);
	color: #b8860b;
}

.ontario-featured-resource-item h5 {
	font-family: 'Syne', sans-serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-featured-resource-item p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin: 0;
}

/* Resources Main CTA */
.ontario-resources-main-cta {
	text-align: center;
	margin-top: 50px;
}

.ontario-resources-main-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 36px;
	font-size: 15px;
	font-weight: 600;
}

/* Learning Section */
.ontario-hub-learning-section {
	background: var(--gray-color, #F8F8F8);
}

.ontario-learning-overview {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 32px 48px;
	margin-bottom: 40px;
}

.ontario-learning-stats {
	display: flex;
	justify-content: space-around;
	gap: 24px;
	flex-wrap: wrap;
}

.ontario-learning-stat {
	text-align: center;
}

.ontario-learning-stat strong {
	display: block;
	font-family: 'Syne', sans-serif;
	font-size: 36px;
	font-weight: 800;
	color: var(--primary-color, #C5B27D);
	line-height: 1;
	margin-bottom: 6px;
}

.ontario-learning-stat span {
	font-size: 13px;
	color: var(--text-color, #5c5356);
}

/* Learning Levels */
.ontario-learning-levels {
	margin-bottom: 40px;
}

.ontario-learning-level-item {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.1);
	border-radius: 12px;
	padding: 24px 28px;
	margin-bottom: 16px;
	transition: all 0.3s ease;
}

.ontario-learning-level-item:hover {
	border-color: rgba(197, 178, 125, 0.25);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}

.ontario-level-number {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 2px solid rgba(197, 178, 125, 0.25);
	background: var(--white-color, #ffffff);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--text-color, #5c5356);
	flex-shrink: 0;
}

.ontario-level-number.active {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

.ontario-level-content h4 {
	font-family: 'Syne', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-level-content p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 10px;
}

.ontario-level-meta {
	font-size: 12px;
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
}

.ontario-learning-cta {
	text-align: center;
}

/* Tools Section */
.ontario-hub-tools-section {
	background: var(--white-color, #ffffff);
}

.ontario-featured-tool-banner {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.12) 0%, rgba(117, 172, 152, 0.08) 100%);
	border: 1px solid rgba(197, 178, 125, 0.25);
	border-radius: 20px;
	padding: 48px;
	display: flex;
	align-items: center;
	gap: 48px;
	margin-bottom: 40px;
}

.ontario-featured-tool-content {
	flex: 1;
}

.ontario-featured-badge {
	font-size: 11px;
	padding: 6px 14px;
	border-radius: 100px;
	background: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	display: inline-block;
	margin-bottom: 16px;
}

.ontario-featured-tool-content h3 {
	font-family: 'Syne', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 12px;
}

.ontario-featured-tool-content > p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 20px;
}

.ontario-featured-tool-meta {
	display: flex;
	gap: 20px;
	margin-bottom: 24px;
}

.ontario-featured-tool-meta span {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	display: flex;
	align-items: center;
	gap: 6px;
}

.ontario-featured-tool-meta i {
	color: var(--primary-color, #C5B27D);
}
.ontario-featured-tool-meta span .elementor-icon,
.ontario-featured-tool-meta span svg {
	color: var(--primary-color, #C5B27D);
	width: 16px !important;
	height: 16px !important;
	max-width: 16px;
	max-height: 16px;
	flex-shrink: 0;
	display: block;
}
.ontario-featured-tool-meta span svg path,
.ontario-featured-tool-meta span svg circle {
	fill: currentColor;
}
.ontario-featured-tool-meta span svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.ontario-featured-tool-preview {
	width: 220px;
	height: 140px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.2), rgba(117, 172, 152, 0.15));
	border: 2px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 56px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
}
.ontario-featured-tool-preview .elementor-icon,
.ontario-featured-tool-preview svg {
	color: inherit;
	width: 52px !important;
	height: 52px !important;
	max-width: 52px;
	max-height: 52px;
	display: block;
}
.ontario-featured-tool-preview i {
	font-size: 56px;
	line-height: 1;
}
.ontario-featured-tool-preview svg path,
.ontario-featured-tool-preview svg circle,
.ontario-featured-tool-preview svg polyline,
.ontario-featured-tool-preview svg polygon {
	fill: currentColor;
}
.ontario-featured-tool-preview svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.ontario-tools-showcase {
	margin-bottom: 40px;
}

.ontario-tool-showcase-card {
	background: var(--gray-color, #F8F8F8);
	border: 1px solid rgba(197, 178, 125, 0.1);
	border-radius: 16px;
	padding: 28px;
	text-align: center;
	transition: all 0.3s ease;
	height: 100%;
}

.ontario-tool-showcase-card:hover {
	border-color: rgba(197, 178, 125, 0.3);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
	transform: translateY(-4px);
}

.ontario-tool-showcase-icon {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: rgba(197, 178, 125, 0.1);
	border: 1px solid rgba(197, 178, 125, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 16px;
}
.ontario-tool-showcase-icon .elementor-icon,
.ontario-tool-showcase-icon svg {
	color: inherit;
	width: 24px !important;
	height: 24px !important;
	max-width: 24px;
	max-height: 24px;
	display: block;
}
.ontario-tool-showcase-icon i {
	font-size: 24px;
	line-height: 1;
}
.ontario-tool-showcase-icon svg path,
.ontario-tool-showcase-icon svg circle,
.ontario-tool-showcase-icon svg polyline,
.ontario-tool-showcase-icon svg polygon {
	fill: currentColor;
}
.ontario-tool-showcase-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.ontario-tool-showcase-card h4 {
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
}

.ontario-tool-showcase-card p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin-bottom: 16px;
}

.ontario-tool-tag {
	font-size: 11px;
	padding: 4px 12px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.1);
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.ontario-tool-tag.interactive {
	background: rgba(117, 172, 152, 0.12);
	color: var(--secondary-color, #75AC98);
}

.ontario-tool-tag.prototype {
	background: rgba(245, 200, 66, 0.12);
	color: #b8860b;
}

.ontario-tools-cta {
	text-align: center;
}

/* Agents Section */
.ontario-hub-agents-section {
	background: var(--gray-color, #F8F8F8);
}

.ontario-directory-featured-agent {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1) 0%, rgba(117, 172, 152, 0.06) 100%);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 20px;
	padding: 40px;
	display: flex;
	gap: 32px;
	align-items: center;
	margin-bottom: 40px;
}

.ontario-directory-agent-icon {
	width: 80px;
	height: 80px;
	border-radius: 20px;
	background: rgba(197, 178, 125, 0.15);
	border: 1px solid rgba(197, 178, 125, 0.25);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 36px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
}
.ontario-directory-agent-icon .elementor-icon,
.ontario-directory-agent-icon svg {
	color: inherit;
	width: 36px !important;
	height: 36px !important;
	max-width: 36px;
	max-height: 36px;
	display: block;
}
.ontario-directory-agent-icon i {
	font-size: 36px;
	line-height: 1;
}
.ontario-directory-agent-icon svg path,
.ontario-directory-agent-icon svg circle,
.ontario-directory-agent-icon svg polyline,
.ontario-directory-agent-icon svg polygon {
	fill: currentColor;
}
.ontario-directory-agent-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.ontario-directory-agent-content {
	flex: 1;
}

.ontario-directory-badge {
	font-size: 10px;
	padding: 4px 12px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.2);
	border: 1px solid rgba(197, 178, 125, 0.3);
	color: var(--primary-color, #C5B27D);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	display: inline-block;
	margin-bottom: 12px;
}

.ontario-directory-agent-content h3 {
	font-family: 'Syne', sans-serif;
	font-size: 24px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
}

.ontario-directory-agent-content > p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 16px;
}

.ontario-directory-agent-tags {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.ontario-directory-agent-tags span {
	font-size: 11px;
	padding: 4px 12px;
	border-radius: 100px;
	background: rgba(197, 178, 125, 0.12);
	color: var(--primary-color, #C5B27D);
	font-weight: 500;
}

.ontario-directory-agent-tags .enterprise {
	background: rgba(245, 200, 66, 0.15);
	color: #b8860b;
}

.ontario-directory-agent-actions {
	display: flex;
	gap: 12px;
	flex-shrink: 0;
}

/* Agent Categories */
.ontario-agent-categories {
	margin-bottom: 40px;
}

.ontario-agent-category-card {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.1);
	border-radius: 16px;
	padding: 28px;
	text-align: center;
	height: 100%;
	transition: all 0.3s ease;
}

.ontario-agent-category-card:hover {
	border-color: rgba(197, 178, 125, 0.3);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

/* Pale gold box + compact gold icon (matches IH Agents Directory wireframe) */
.ontario-agent-category-icon-wrap {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: linear-gradient(145deg, rgba(251, 248, 242, 1) 0%, rgba(245, 238, 225, 0.95) 100%);
	border: 1px solid rgba(197, 178, 125, 0.28);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 18px;
	color: var(--primary-color, #C5B27D);
	flex-shrink: 0;
	box-sizing: border-box;
	overflow: hidden;
}
.ontario-agent-category-icon-wrap i {
	font-size: 26px;
	color: inherit;
	line-height: 1;
	margin: 0;
	background: none;
	border: none;
	width: auto;
	height: auto;
	display: block;
}
.ontario-agent-category-icon-wrap .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto !important;
	height: auto !important;
	min-width: 0;
	min-height: 0;
	margin: 0 !important;
	padding: 0 !important;
	background: none !important;
	border: none !important;
	font-size: inherit;
	color: inherit !important;
	box-shadow: none;
}
/* SVG from Elementor: force size + theme gold (library SVGs often ship black / huge) */
.ontario-agent-category-icon-wrap svg {
	width: 30px !important;
	height: 30px !important;
	max-width: 30px !important;
	max-height: 30px !important;
	min-width: 0;
	min-height: 0;
	display: block;
	flex-shrink: 0;
	color: var(--primary-color, #C5B27D) !important;
	overflow: visible;
}
.ontario-agent-category-icon-wrap svg path,
.ontario-agent-category-icon-wrap svg circle,
.ontario-agent-category-icon-wrap svg rect,
.ontario-agent-category-icon-wrap svg polygon,
.ontario-agent-category-icon-wrap svg polyline,
.ontario-agent-category-icon-wrap svg ellipse {
	fill: currentColor !important;
}
.ontario-agent-category-icon-wrap svg [fill="none"],
.ontario-agent-category-icon-wrap svg [fill="transparent"] {
	fill: none !important;
}
.ontario-agent-category-icon-wrap svg [stroke]:not([stroke="none"]):not([stroke="0"]) {
	stroke: currentColor !important;
}

.ontario-agent-category-card h4 {
	font-family: 'Syne', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-agent-category-card p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin-bottom: 12px;
}

.ontario-agent-count {
	font-size: 12px;
	color: var(--primary-color, #C5B27D);
	font-weight: 600;
}

.ontario-agents-directory-cta {
	text-align: center;
}

/* Final CTA */
.ontario-hub-final-cta {
	background: var(--white-color, #ffffff);
}

.ontario-hub-cta-box {
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1) 0%, rgba(117, 172, 152, 0.08) 100%);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 20px;
	padding: 64px 48px;
	text-align: center;
}

.ontario-hub-cta-box h2 {
	font-family: 'Syne', sans-serif;
	font-size: 32px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 0;
}

/* Subtitle / body: centered, readable width, spacing from title & buttons */
.ontario-hub-cta-box > p,
.ontario-hub-cta-box .ontario-hub-final-cta-desc {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	max-width: 600px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 20px;
	margin-bottom: 40px;
	padding-left: 16px;
	padding-right: 16px;
	box-sizing: border-box;
	text-align: center;
	line-height: 1.65;
}
.ontario-hub-cta-box .ontario-hub-final-cta-desc p {
	margin-bottom: 0.75em;
	text-align: center;
}
.ontario-hub-cta-box .ontario-hub-final-cta-desc p:last-child {
	margin-bottom: 0;
}

.ontario-hub-final-buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

/* IH page CTAs: inline arrow icons (Elementor SVG) */
.ontario-intelligence-hub-main .theme-btn .elementor-icon,
.ontario-hub-resources-section .theme-btn .elementor-icon,
.ontario-hub-learning-section .theme-btn .elementor-icon,
.ontario-hub-tools-section .theme-btn .elementor-icon,
.ontario-hub-agents-section .theme-btn .elementor-icon,
.ontario-hub-final-cta .theme-btn .elementor-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	vertical-align: middle;
	margin-left: 6px;
	color: inherit;
}
.ontario-intelligence-hub-main .theme-btn .elementor-icon svg,
.ontario-hub-resources-section .theme-btn .elementor-icon svg,
.ontario-hub-learning-section .theme-btn .elementor-icon svg,
.ontario-hub-tools-section .theme-btn .elementor-icon svg,
.ontario-hub-agents-section .theme-btn .elementor-icon svg,
.ontario-hub-final-cta .theme-btn .elementor-icon svg {
	width: 14px !important;
	height: 14px !important;
	max-width: 14px;
	max-height: 14px;
	display: block;
}
.ontario-intelligence-hub-main .theme-btn .elementor-icon svg path,
.ontario-hub-resources-section .theme-btn .elementor-icon svg path,
.ontario-hub-learning-section .theme-btn .elementor-icon svg path,
.ontario-hub-tools-section .theme-btn .elementor-icon svg path,
.ontario-hub-agents-section .theme-btn .elementor-icon svg path,
.ontario-hub-final-cta .theme-btn .elementor-icon svg path,
.ontario-intelligence-hub-main .theme-btn .elementor-icon svg circle,
.ontario-hub-resources-section .theme-btn .elementor-icon svg circle,
.ontario-hub-learning-section .theme-btn .elementor-icon svg circle,
.ontario-hub-tools-section .theme-btn .elementor-icon svg circle,
.ontario-hub-agents-section .theme-btn .elementor-icon svg circle,
.ontario-hub-final-cta .theme-btn .elementor-icon svg circle {
	fill: currentColor;
}
.ontario-intelligence-hub-main .theme-btn .elementor-icon svg [stroke]:not([stroke="none"]),
.ontario-hub-resources-section .theme-btn .elementor-icon svg [stroke]:not([stroke="none"]),
.ontario-hub-learning-section .theme-btn .elementor-icon svg [stroke]:not([stroke="none"]),
.ontario-hub-tools-section .theme-btn .elementor-icon svg [stroke]:not([stroke="none"]),
.ontario-hub-agents-section .theme-btn .elementor-icon svg [stroke]:not([stroke="none"]),
.ontario-hub-final-cta .theme-btn .elementor-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

/* Responsive Adjustments */
@media (max-width: 991px) {
	.ontario-hub-main-header {
		margin-bottom: 50px;
	}

	.ontario-hub-nav-card {
		padding: 24px 20px;
		margin-bottom: 20px;
	}

	.ontario-featured-tool-banner {
		flex-direction: column;
		text-align: center;
		padding: 32px;
	}

	.ontario-featured-tool-preview {
		width: 180px;
		height: 120px;
	}

	.ontario-directory-featured-agent {
		flex-direction: column;
		text-align: center;
		padding: 32px;
	}

	.ontario-directory-agent-icon {
		margin: 0 auto;
	}

	.ontario-directory-agent-tags {
		justify-content: center;
	}

	.ontario-directory-agent-actions {
		justify-content: center;
		width: 100%;
	}

	.ontario-hub-cta-box {
		padding: 48px 32px;
	}

	.ontario-learning-level-item {
		padding: 20px;
	}

	.ontario-learning-overview {
		padding: 24px 32px;
	}
}

@media (max-width: 768px) {
	.ontario-hub-main-title {
		font-size: 30px;
	}

	.ontario-hub-section-title {
		font-size: 26px;
	}

	.ontario-featured-resources {
		padding: 24px;
	}

	.ontario-featured-resource-item {
		margin-bottom: 16px;
	}

	.ontario-learning-stats {
		gap: 16px;
	}

	.ontario-learning-stat strong {
		font-size: 28px;
	}

	.ontario-level-number {
		width: 36px;
		height: 36px;
		font-size: 14px;
	}

	.ontario-agent-category-card {
		margin-bottom: 20px;
	}

	.ontario-hub-cta-box {
		padding: 32px 24px;
	}

	.ontario-hub-cta-box h2 {
		font-size: 24px;
	}
}

/* ===== Innovation Landing Page (Password Protected) ===== */

/* Password Gate Section */
.ontario-password-gate {
	background: linear-gradient(135deg, var(--gray-color, #F8F8F8) 0%, rgba(197, 178, 125, 0.1) 100%);
	min-height: 80vh;
	display: flex;
	align-items: center;
}

.ontario-password-box {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 20px;
	padding: 56px 48px;
	text-align: center;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
}

.ontario-password-icon {
	width: 80px;
	height: 80px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.15), rgba(117, 172, 152, 0.1));
	border: 2px solid rgba(197, 178, 125, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 32px;
	color: var(--primary-color, #C5B27D);
	margin: 0 auto 28px;
}

.ontario-password-box h2 {
	font-family: 'Syne', sans-serif;
	font-size: 32px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
}

.ontario-password-subtitle {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin-bottom: 32px;
}

.ontario-password-error {
	background: rgba(220, 53, 69, 0.08);
	border: 1px solid rgba(220, 53, 69, 0.2);
	border-radius: 10px;
	padding: 14px 20px;
	color: #dc3545;
	font-size: 14px;
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.ontario-password-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 28px;
}

.ontario-password-input-wrap {
	position: relative;
	display: flex;
	align-items: center;
}

.ontario-password-input-wrap i {
	position: absolute;
	left: 18px;
	color: var(--primary-color, #C5B27D);
	font-size: 16px;
}

.ontario-password-input-wrap input {
	width: 100%;
	padding: 16px 16px 16px 48px;
	border: 2px solid rgba(197, 178, 125, 0.25);
	border-radius: 12px;
	font-size: 15px;
	color: var(--heading-color, #42393C);
	background: var(--white-color, #ffffff);
	transition: all 0.3s ease;
}

.ontario-password-input-wrap input:focus {
	outline: none;
	border-color: var(--primary-color, #C5B27D);
	box-shadow: 0 0 0 4px rgba(197, 178, 125, 0.1);
}

.ontario-password-input-wrap input::placeholder {
	color: var(--text-color, #5c5356);
}

.ontario-password-submit {
	width: 100%;
	justify-content: center;
	padding: 16px 24px;
	font-size: 15px;
}

.ontario-password-help {
	padding-top: 24px;
	border-top: 1px solid rgba(197, 178, 125, 0.15);
}

.ontario-password-help p {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	margin-bottom: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.ontario-contact-link {
	font-size: 14px;
	color: var(--primary-color, #C5B27D);
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
}

.ontario-contact-link:hover {
	color: var(--secondary-color, #75AC98);
	gap: 10px;
}

/* Landing Page Hero */
.ontario-innovation-landing {
	background: var(--white-color, #ffffff);
}

.ontario-landing-hero {
	background: linear-gradient(135deg, var(--gray-color, #F8F8F8) 0%, var(--white-color, #ffffff) 100%);
	position: relative;
}

.ontario-landing-hero::before {
	content: '';
	position: absolute;
	top: -100px;
	right: -100px;
	width: 400px;
	height: 400px;
	background: radial-gradient(circle, rgba(197, 178, 125, 0.1) 0%, transparent 70%);
	pointer-events: none;
}

.ontario-landing-hero-content {
	text-align: center;
	margin-bottom: 60px;
}

.ontario-landing-badge {
	font-family: 'Syne', sans-serif;
	font-size: 12px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--primary-color, #C5B27D);
	display: inline-block;
	padding: 8px 20px;
	background: rgba(197, 178, 125, 0.1);
	border-radius: 100px;
	margin-bottom: 24px;
}

.ontario-landing-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(36px, 5vw, 56px);
	font-weight: 800;
	color: var(--heading-color, #42393C);
	line-height: 1.15;
	margin-bottom: 16px;
}

.ontario-landing-subtitle {
	font-size: 22px;
	color: var(--secondary-color, #75AC98);
	font-weight: 500;
	margin-bottom: 40px;
}

.ontario-landing-intro {
	max-width: 800px;
	margin: 0 auto;
}

.ontario-landing-intro p {
	font-size: 17px;
	color: var(--text-color, #5c5356);
	line-height: 1.8;
	margin-bottom: 20px;
}

.ontario-landing-highlight {
	font-size: 18px;
	color: var(--heading-color, #42393C);
	font-weight: 600;
	padding: 24px 32px;
	background: linear-gradient(135deg, rgba(197, 178, 125, 0.1), rgba(117, 172, 152, 0.08));
	border-left: 4px solid var(--primary-color, #C5B27D);
	border-radius: 0 12px 12px 0;
	margin: 28px 0;
}

.ontario-landing-guide {
	font-size: 16px;
	font-style: italic;
	color: var(--text-color, #5c5356);
}

/* Challenge Tiles */
.ontario-tiles-header {
	font-family: 'Syne', sans-serif;
	font-size: 24px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	text-align: center;
	margin-bottom: 32px;
}

.ontario-challenge-tiles {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 20px;
}

.ontario-challenge-tile {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 16px;
	padding: 28px 24px;
	text-decoration: none;
	position: relative;
	overflow: hidden;
	transition: all 0.35s ease;
	display: flex;
	flex-direction: column;
}

.ontario-challenge-tile::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	transition: height 0.3s ease;
}

.ontario-challenge-tile.challenge-tile-1::before { background: #442e66; }
.ontario-challenge-tile.challenge-tile-2::before { background: #668f7b; }
.ontario-challenge-tile.challenge-tile-3::before { background: #dc3545; }
.ontario-challenge-tile.challenge-tile-4::before { background: #1E3A5F; }
.ontario-challenge-tile.challenge-tile-5::before { background: var(--primary-color, #C5B27D); }

.ontario-challenge-tile:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
}

.ontario-challenge-tile:hover::before {
	height: 6px;
}

.ontario-tile-number {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	font-weight: 700;
	color: var(--white-color, #ffffff);
	margin-bottom: 16px;
}

.ontario-challenge-tile.challenge-tile-1 .ontario-tile-number { background: #442e66; }
.ontario-challenge-tile.challenge-tile-2 .ontario-tile-number { background: #668f7b; }
.ontario-challenge-tile.challenge-tile-3 .ontario-tile-number { background: #dc3545; }
.ontario-challenge-tile.challenge-tile-4 .ontario-tile-number { background: #1E3A5F; }
.ontario-challenge-tile.challenge-tile-5 .ontario-tile-number { background: var(--primary-color, #C5B27D); }

.ontario-tile-title {
	font-family: 'Syne', sans-serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 10px;
	line-height: 1.3;
}

.ontario-tile-summary {
	font-size: 13px;
	color: var(--text-color, #5c5356);
	line-height: 1.5;
	margin-bottom: 12px;
	flex-grow: 1;
}

.ontario-tile-core {
	font-size: 12px;
	font-weight: 600;
	padding-top: 12px;
	border-top: 1px solid var(--gray-200, #e9ecef);
}

.ontario-challenge-tile.challenge-tile-1 .ontario-tile-core { color: #442e66; }
.ontario-challenge-tile.challenge-tile-2 .ontario-tile-core { color: #668f7b; }
.ontario-challenge-tile.challenge-tile-3 .ontario-tile-core { color: #dc3545; }
.ontario-challenge-tile.challenge-tile-4 .ontario-tile-core { color: #1E3A5F; }
.ontario-challenge-tile.challenge-tile-5 .ontario-tile-core { color: var(--primary-color, #C5B27D); }

.ontario-tile-arrow {
	position: absolute;
	bottom: 20px;
	right: 20px;
	font-size: 18px;
	opacity: 0;
	transition: all 0.3s ease;
}

.ontario-challenge-tile.challenge-tile-1 .ontario-tile-arrow { color: #442e66; }
.ontario-challenge-tile.challenge-tile-2 .ontario-tile-arrow { color: #668f7b; }
.ontario-challenge-tile.challenge-tile-3 .ontario-tile-arrow { color: #dc3545; }
.ontario-challenge-tile.challenge-tile-4 .ontario-tile-arrow { color: #1E3A5F; }
.ontario-challenge-tile.challenge-tile-5 .ontario-tile-arrow { color: var(--primary-color, #C5B27D); }

.ontario-challenge-tile:hover .ontario-tile-arrow {
	opacity: 1;
	transform: translateY(3px);
}

/* Challenge Sections */
.ontario-challenge-section {
	position: relative;
}

.ontario-challenge-1 { background: rgba(68, 46, 102, 0.04); }
.ontario-challenge-2 { background: rgba(102, 143, 123, 0.06); }
.ontario-challenge-3 { background: rgba(220, 53, 69, 0.04); }
.ontario-challenge-4 { background: rgba(30, 58, 95, 0.04); }
.ontario-challenge-5 { background: rgba(197, 178, 125, 0.08); }

.ontario-challenge-header {
	margin-bottom: 40px;
}

.ontario-challenge-number {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Syne', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--white-color, #ffffff);
	margin-bottom: 20px;
}

.ontario-challenge-1 .ontario-challenge-number { background: #442e66; }
.ontario-challenge-2 .ontario-challenge-number { background: #668f7b; }
.ontario-challenge-3 .ontario-challenge-number { background: #dc3545; }
.ontario-challenge-4 .ontario-challenge-number { background: #1E3A5F; }
.ontario-challenge-5 .ontario-challenge-number { background: var(--primary-color, #C5B27D); }

.ontario-challenge-title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(26px, 4vw, 36px);
	font-weight: 700;
	color: var(--heading-color, #42393C);
	line-height: 1.2;
}

.ontario-challenge-content {
	max-width: 800px;
}

.ontario-section-intro {
	font-size: 17px;
	color: var(--heading-color, #42393C);
	line-height: 1.8;
	margin-bottom: 20px;
}

.ontario-core-challenge {
	font-size: 18px;
	color: var(--text-color, #5c5356);
	margin-bottom: 28px;
	padding: 16px 20px;
	background: var(--white-color, #ffffff);
	border-radius: 10px;
	border-left: 4px solid var(--primary-color, #C5B27D);
}

.ontario-insight-box {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	background: var(--white-color, #ffffff);
	padding: 24px 28px;
	border-radius: 12px;
	margin-bottom: 28px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}

.ontario-insight-box i {
	font-size: 22px;
	color: var(--primary-color, #C5B27D);
	margin-top: 2px;
}

.ontario-insight-box p {
	font-size: 16px;
	font-style: italic;
	color: var(--heading-color, #42393C);
	line-height: 1.6;
	margin: 0;
}

.ontario-enables-box {
	margin-bottom: 32px;
}

.ontario-enables-box h4 {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--primary-color, #C5B27D);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.ontario-enables-box h4 i {
	font-size: 16px;
}

.ontario-enables-box p {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
}

.ontario-interventions-title {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
}

.ontario-interventions-list {
	list-style: none;
	padding: 0;
	margin: 0 0 40px;
}

.ontario-interventions-list li {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	padding: 14px 0;
	border-bottom: 1px solid rgba(197, 178, 125, 0.15);
	line-height: 1.6;
	position: relative;
	padding-left: 24px;
}

.ontario-interventions-list li::before {
	content: '→';
	position: absolute;
	left: 0;
	color: var(--primary-color, #C5B27D);
	font-weight: 700;
}

.ontario-interventions-list li:last-child {
	border-bottom: none;
}

.ontario-back-to-top {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 600;
	color: var(--text-color, #5c5356);
	text-decoration: none;
	padding: 10px 18px;
	border: 1px solid rgba(197, 178, 125, 0.25);
	border-radius: 8px;
	transition: all 0.3s ease;
}

.ontario-back-to-top:hover {
	background: var(--primary-color, #C5B27D);
	border-color: var(--primary-color, #C5B27D);
	color: var(--white-color, #ffffff);
}

/* Landing CTA Section */
.ontario-landing-cta {
	background: var(--gray-color, #F8F8F8);
}

.ontario-landing-cta-box {
	background: var(--white-color, #ffffff);
	border: 1px solid rgba(197, 178, 125, 0.15);
	border-radius: 20px;
	padding: 56px 48px;
	text-align: center;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.ontario-landing-cta-box h2 {
	font-family: 'Syne', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 16px;
}

.ontario-landing-cta-box > p {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin-bottom: 32px;
}

.ontario-landing-cta-buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

/* Responsive Adjustments */
@media (max-width: 1199px) {
	.ontario-challenge-tiles {
		grid-template-columns: repeat(3, 1fr);
	}

	.ontario-password-box {
		padding: 40px 32px;
	}
}

@media (max-width: 991px) {
	.ontario-challenge-tiles {
		grid-template-columns: repeat(2, 1fr);
	}

	.ontario-landing-title {
		font-size: 32px;
	}

	.ontario-landing-cta-box {
		padding: 40px 32px;
	}

	.ontario-landing-cta-buttons {
		flex-direction: column;
		align-items: center;
	}
}

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

	.ontario-password-box {
		padding: 32px 24px;
		margin: 0 16px;
	}

	.ontario-password-box h2 {
		font-size: 24px;
	}

	.ontario-landing-title {
		font-size: 28px;
	}

	.ontario-landing-highlight {
		padding: 18px 20px;
		font-size: 16px;
	}

	.ontario-challenge-title {
		font-size: 24px;
	}

	.ontario-landing-cta-box {
		padding: 32px 24px;
	}

	.ontario-landing-cta-box h2 {
		font-size: 22px;
	}

	.ontario-network-badge {
		padding: 10px 20px;
		font-size: 10px;
		letter-spacing: 1.5px;
	}

	/* Challenges V2 - Mobile */
	.ontario-challenges-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.ontario-challenges-header {
		margin-bottom: 40px;
	}

	.ontario-challenges-label {
		font-size: 11px;
		padding: 6px 14px;
	}

	.ontario-challenges-title {
		font-size: 26px;
	}

	.ontario-challenges-subtitle {
		font-size: 14px;
	}

	.ontario-challenge-card {
		padding: 18px 16px;
	}

	.ontario-challenge-card__number {
		font-size: 26px;
		margin-bottom: 10px;
	}

	.ontario-challenge-card__icon {
		width: 28px;
		height: 28px;
		top: 14px;
		right: 14px;
	}

	.ontario-challenge-card__icon i {
		font-size: 12px;
	}

	.ontario-challenge-card__title {
		font-size: 16px;
		margin-bottom: 8px;
	}

	.ontario-challenge-card__desc {
		font-size: 13px;
		margin-bottom: 10px;
	}

	.ontario-challenge-card__tag {
		font-size: 9px;
		padding: 4px 8px;
	}

	.ontario-challenge-card__arrow {
		width: 32px;
		height: 32px;
	}

	.ontario-challenge-card__arrow i {
		font-size: 12px;
	}

	.ontario-modal.active {
		padding: 16px;
	}

	.ontario-modal-container {
		width: 100%;
		max-width: 100%;
		max-height: calc(100vh - 32px);
		border-radius: 16px;
	}

	.ontario-modal-content {
		padding: 36px 20px 24px;
	}

	.ontario-modal-icon {
		width: 56px;
		height: 56px;
		font-size: 20px;
		border-radius: 16px;
	}

	.ontario-modal-header h3 {
		font-size: 20px;
	}

	.ontario-modal-subtitle {
		font-size: 13px;
	}

	.ontario-modal-close {
		top: 10px;
		right: 10px;
		width: 32px;
		height: 32px;
		font-size: 13px;
	}

	/* Request Access Page Responsive */
	.ontario-request-box {
		padding: 40px 24px;
	}

	.ontario-request-success-icon {
		width: 64px;
		height: 64px;
		font-size: 26px;
		border-radius: 16px;
	}

	.ontario-request-success h2 {
		font-size: 24px;
	}

	/* Request Success V2 - Mobile */
	.ontario-request-success-v2 {
		border-radius: 16px;
		margin: 0 8px;
	}

	.ontario-success-header {
		padding: 36px 20px 48px;
	}

	.ontario-success-badge {
		width: 72px;
		height: 72px;
	}

	.ontario-success-badge i {
		font-size: 32px;
	}

	.ontario-success-body {
		padding: 36px 24px 24px;
		margin-top: -24px;
	}

	.ontario-success-body h2 {
		font-size: 24px;
	}

	.ontario-success-message {
		font-size: 14px;
		margin-bottom: 24px;
	}

	.ontario-success-status {
		padding: 14px 20px;
	}

	.ontario-status-text {
		font-size: 13px;
	}

	.ontario-status-note {
		font-size: 12px;
	}

	.ontario-success-footer {
		padding: 0 20px 24px;
		flex-direction: column;
	}

	.ontario-btn {
		width: 100%;
		justify-content: center;
		padding: 14px 20px;
	}

	.ontario-request-form-page .ontario-form-control {
		padding: 12px 14px;
		font-size: 16px;
	}
}

/* Why We Collaborate Section V2 */
.ontario-collaborate-v2 {
	background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 50%, #f8f9fa 100%);
	padding: 100px 0;
	position: relative;
	overflow: hidden;
}

.ontario-collaborate-v2::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(197, 178, 125, 0.3), transparent);
}

/* Header */
.ontario-collaborate-header {
	text-align: center;
	max-width: 800px;
	margin: 0 auto 60px;
}

.ontario-collaborate-label {
	display: inline-block;
	padding: 8px 18px;
	background: rgba(102, 143, 123, 0.1);
	border: 1px solid rgba(102, 143, 123, 0.2);
	border-radius: 50px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #668f7b;
	margin-bottom: 20px;
}

.ontario-collaborate-title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 36px;
	font-weight: 700;
	color: #442e66;
	margin-bottom: 20px;
	line-height: 1.3;
}

.ontario-collaborate-intro {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.8;
	margin: 0;
}

/* Grid Layout */
.ontario-collaborate-grid {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 40px;
	align-items: stretch;
	margin-bottom: 60px;
}

/* Cards */
.ontario-collaborate-card {
	background: #ffffff;
	border-radius: 20px;
	padding: 40px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.ontario-collaborate-card__accent {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
	background: linear-gradient(180deg, #442e66, #5a3d7a);
}

.ontario-collaborate-card__accent--secondary {
	background: linear-gradient(180deg, #dc3545, #e85d6a);
}

.ontario-collaborate-card__header {
	margin-bottom: 24px;
}

.ontario-collaborate-card__icon {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(68, 46, 102, 0.1), rgba(68, 46, 102, 0.05));
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
}

.ontario-collaborate-card__icon i {
	font-size: 28px;
	color: #442e66;
}

.ontario-collaborate-card__icon img,
.ontario-collaborate-card__icon svg {
	max-width: 36px;
	max-height: 36px;
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}

.ontario-collaborate-card--secondary .ontario-collaborate-card__icon {
	background: linear-gradient(135deg, rgba(220, 53, 69, 0.1), rgba(220, 53, 69, 0.05));
}

.ontario-collaborate-card--secondary .ontario-collaborate-card__icon i {
	color: #dc3545;
}

.ontario-collaborate-card__header h3 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 24px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-collaborate-card__tag {
	display: inline-block;
	padding: 6px 14px;
	background: rgba(68, 46, 102, 0.08);
	color: #442e66;
	font-size: 12px;
	font-weight: 600;
	border-radius: 20px;
	letter-spacing: 0.5px;
}

.ontario-collaborate-card--secondary .ontario-collaborate-card__tag {
	background: rgba(220, 53, 69, 0.08);
	color: #dc3545;
}

.ontario-collaborate-card__body {
	flex: 1;
}

.ontario-collaborate-card__body p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin-bottom: 24px;
}

.ontario-collaborate-features {
	list-style: none;
	padding: 0;
	margin: 0;
}

.ontario-collaborate-features li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--heading-color, #42393C);
	font-weight: 500;
	margin-bottom: 12px;
}

.ontario-collaborate-features li:last-child {
	margin-bottom: 0;
}

.ontario-collaborate-features li i {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: rgba(102, 143, 123, 0.15);
	color: #668f7b;
	font-size: 11px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-collaborate-features li .ontario-collaborate-features__img img {
	width: 24px;
	height: 24px;
	object-fit: contain;
	flex-shrink: 0;
	display: block;
}

.ontario-collaborate-features li .ontario-collaborate-features__ic {
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-collaborate-features li .ontario-collaborate-features__ic i {
	width: auto;
	height: auto;
	border-radius: 0;
	background: transparent;
	font-size: 14px;
}

.ontario-collaborate-features li .ontario-collaborate-features__ic svg {
	width: 18px;
	height: 18px;
}

/* Bridge */
.ontario-collaborate-bridge {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	padding: 20px;
}

.ontario-collaborate-bridge__icon {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--primary-color, #C5B27D), #b8a46e);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 24px rgba(197, 178, 125, 0.3);
}

.ontario-collaborate-bridge__icon i {
	font-size: 32px;
	color: #ffffff;
}

.ontario-collaborate-bridge__icon img,
.ontario-collaborate-bridge__icon svg {
	max-width: 40px;
	max-height: 40px;
	object-fit: contain;
	display: block;
}

.ontario-collaborate-bridge__line {
	width: 2px;
	height: 60px;
	background: linear-gradient(180deg, var(--primary-color, #C5B27D), transparent);
}

.ontario-collaborate-bridge p {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 14px;
	font-weight: 600;
	color: var(--text-color, #5c5356);
	text-align: center;
	margin: 0;
}

.ontario-collaborate-bridge p span {
	color: var(--primary-color, #C5B27D);
	font-weight: 700;
	margin: 0 4px;
}

/* Result Box */
.ontario-collaborate-result {
	text-align: center;
}

.ontario-collaborate-result__box {
	display: inline-flex;
	align-items: center;
	gap: 16px;
	padding: 24px 40px;
	background: linear-gradient(135deg, rgba(68, 46, 102, 0.05), rgba(102, 143, 123, 0.05));
	border-radius: 16px;
	border: 1px solid rgba(68, 46, 102, 0.1);
}

.ontario-collaborate-result__box i {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: linear-gradient(135deg, #442e66, #5a3d7a);
	color: #ffffff;
	font-size: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-collaborate-result__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-collaborate-result__icon > i {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: linear-gradient(135deg, #442e66, #5a3d7a);
	color: #ffffff;
	font-size: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ontario-collaborate-result__icon img {
	width: 48px;
	height: 48px;
	object-fit: contain;
	border-radius: 12px;
}

.ontario-collaborate-result__icon svg {
	width: 40px;
	height: 40px;
}

.ontario-collaborate-result__box p {
	font-size: 15px;
	color: var(--heading-color, #42393C);
	font-weight: 500;
	line-height: 1.6;
	margin: 0;
	max-width: 500px;
	text-align: left;
}

/* Responsive */
@media (max-width: 1199px) {
	.ontario-collaborate-grid {
		gap: 24px;
	}
	
	.ontario-collaborate-card {
		padding: 32px;
	}
}

@media (max-width: 991px) {
	.ontario-collaborate-v2 {
		padding: 80px 0;
	}
	
	.ontario-collaborate-grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	
	.ontario-collaborate-bridge {
		flex-direction: row;
		padding: 20px 0;
	}
	
	.ontario-collaborate-bridge__line {
		width: 60px;
		height: 2px;
		background: linear-gradient(90deg, var(--primary-color, #C5B27D), transparent);
	}
	
	.ontario-collaborate-bridge__line::after {
		content: '';
		width: 60px;
		height: 2px;
		background: linear-gradient(270deg, var(--primary-color, #C5B27D), transparent);
	}
	
	.ontario-collaborate-title {
		font-size: 28px;
	}
	
	.ontario-collaborate-card__header h3 {
		font-size: 20px;
	}
}

@media (max-width: 768px) {
	.ontario-collaborate-v2 {
		padding: 60px 0;
	}
	
	.ontario-collaborate-header {
		margin-bottom: 40px;
	}
	
	.ontario-collaborate-title {
		font-size: 24px;
	}
	
	.ontario-collaborate-intro {
		font-size: 15px;
	}
	
	.ontario-collaborate-card {
		padding: 28px 24px;
	}
	
	.ontario-collaborate-card__icon {
		width: 56px;
		height: 56px;
	}
	
	.ontario-collaborate-card__icon i {
		font-size: 24px;
	}
	
	.ontario-collaborate-bridge__icon {
		width: 60px;
		height: 60px;
	}
	
	.ontario-collaborate-bridge__icon i {
		font-size: 26px;
	}
	
	.ontario-collaborate-result__box {
		flex-direction: column;
		text-align: center;
		padding: 24px;
	}
	
	.ontario-collaborate-result__box p {
		text-align: center;
	}
}

/* How Organizations Progress Section V2 */
.ontario-progress-v2 {
	background: linear-gradient(180deg, #ffffff 0%, #f8f9fa 50%, #f5f7f9 100%);
	padding: 100px 0;
	position: relative;
}

.ontario-progress-v2::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(197, 178, 125, 0.3), transparent);
}

/* Header */
.ontario-progress-header {
	text-align: center;
	max-width: 700px;
	margin: 0 auto 60px;
}

.ontario-progress-label {
	display: inline-block;
	padding: 8px 18px;
	background: rgba(197, 178, 125, 0.12);
	border: 1px solid rgba(197, 178, 125, 0.2);
	border-radius: 50px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #a08f5a;
	margin-bottom: 20px;
}

.ontario-progress-title {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 36px;
	font-weight: 700;
	color: #442e66;
	margin-bottom: 16px;
	line-height: 1.3;
}

.ontario-progress-intro {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	line-height: 1.7;
	margin: 0;
}

/* Progress Steps */
.ontario-progress-steps {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	gap: 0;
	margin-bottom: 60px;
	position: relative;
}

.ontario-progress-step {
	flex: 1;
	max-width: 300px;
	text-align: center;
	position: relative;
	padding: 0 20px;
}

.ontario-progress-step__number {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 14px;
	font-weight: 700;
	color: #ffffff;
	background: linear-gradient(135deg, #442e66, #5a3d7a);
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	position: relative;
	z-index: 2;
	box-shadow: 0 4px 12px rgba(68, 46, 102, 0.2);
}

.ontario-progress-step:nth-child(2) .ontario-progress-step__number {
	background: linear-gradient(135deg, #668f7b, #7da391);
	box-shadow: 0 4px 12px rgba(102, 143, 123, 0.2);
}

.ontario-progress-step:nth-child(3) .ontario-progress-step__number {
	background: linear-gradient(135deg, #dc3545, #e85d6a);
	box-shadow: 0 4px 12px rgba(220, 53, 69, 0.2);
}

.ontario-progress-step__connector {
	position: absolute;
	top: 18px;
	left: 60%;
	width: 80%;
	height: 2px;
	background: linear-gradient(90deg, rgba(68, 46, 102, 0.2), rgba(197, 178, 125, 0.3));
	z-index: 1;
}

.ontario-progress-step:last-child .ontario-progress-step__connector {
	display: none;
}

.ontario-progress-step__content {
	background: #ffffff;
	border-radius: 16px;
	padding: 32px 24px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
	position: relative;
	z-index: 2;
}

.ontario-progress-step__icon {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(68, 46, 102, 0.1), rgba(68, 46, 102, 0.05));
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
}

.ontario-progress-step__icon i {
	font-size: 24px;
	color: #442e66;
}

.ontario-progress-step:nth-child(2) .ontario-progress-step__icon {
	background: linear-gradient(135deg, rgba(102, 143, 123, 0.12), rgba(102, 143, 123, 0.06));
}

.ontario-progress-step:nth-child(2) .ontario-progress-step__icon i {
	color: #668f7b;
}

.ontario-progress-step:nth-child(3) .ontario-progress-step__icon {
	background: linear-gradient(135deg, rgba(220, 53, 69, 0.1), rgba(220, 53, 69, 0.05));
}

.ontario-progress-step:nth-child(3) .ontario-progress-step__icon i {
	color: #dc3545;
}

/* Landing journey Elementor: alternating themes for any number of steps */
.ontario-progress-step--t1 .ontario-progress-step__number {
	background: linear-gradient(135deg, #442e66, #5a3d7a);
	box-shadow: 0 4px 12px rgba(68, 46, 102, 0.2);
}

.ontario-progress-step--t2 .ontario-progress-step__number {
	background: linear-gradient(135deg, #668f7b, #7da391);
	box-shadow: 0 4px 12px rgba(102, 143, 123, 0.2);
}

.ontario-progress-step--t3 .ontario-progress-step__number {
	background: linear-gradient(135deg, #dc3545, #e85d6a);
	box-shadow: 0 4px 12px rgba(220, 53, 69, 0.2);
}

.ontario-progress-step--t1 .ontario-progress-step__icon {
	background: linear-gradient(135deg, rgba(68, 46, 102, 0.1), rgba(68, 46, 102, 0.05));
}

.ontario-progress-step--t1 .ontario-progress-step__icon i {
	color: #442e66;
}

.ontario-progress-step--t2 .ontario-progress-step__icon {
	background: linear-gradient(135deg, rgba(102, 143, 123, 0.12), rgba(102, 143, 123, 0.06));
}

.ontario-progress-step--t2 .ontario-progress-step__icon i {
	color: #668f7b;
}

.ontario-progress-step--t3 .ontario-progress-step__icon {
	background: linear-gradient(135deg, rgba(220, 53, 69, 0.1), rgba(220, 53, 69, 0.05));
}

.ontario-progress-step--t3 .ontario-progress-step__icon i {
	color: #dc3545;
}

.ontario-progress-step__icon img,
.ontario-progress-step__icon svg {
	max-width: 28px;
	max-height: 28px;
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}

.ontario-progress-quote__icon img,
.ontario-progress-quote__icon svg {
	max-width: 28px;
	max-height: 28px;
	object-fit: contain;
	display: block;
}

.ontario-progress-step__content h4 {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 18px;
	font-weight: 700;
	color: var(--heading-color, #42393C);
	margin-bottom: 8px;
}

.ontario-progress-step__content p {
	font-size: 14px;
	color: var(--text-color, #5c5356);
	line-height: 1.6;
	margin: 0;
}

/* Context Text */
.ontario-progress-context {
	text-align: center;
	max-width: 700px;
	margin: 0 auto 40px;
	padding: 20px 0;
	position: relative;
}

.ontario-progress-context::before,
.ontario-progress-context::after {
	content: '';
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(68, 46, 102, 0.2), transparent);
}

.ontario-progress-context::before {
	top: 0;
}

.ontario-progress-context::after {
	bottom: 0;
}

.ontario-progress-context p {
	font-size: 15px;
	color: var(--text-color, #5c5356);
	font-style: italic;
	line-height: 1.7;
	margin: 0;
}

/* Quote Box */
.ontario-progress-quote {
	text-align: center;
}

.ontario-progress-quote__box {
	display: inline-flex;
	align-items: center;
	gap: 24px;
	background: #ffffff;
	border-radius: 16px;
	padding: 32px 48px;
	box-shadow: 0 8px 32px rgba(68, 46, 102, 0.1);
	border: 1px solid rgba(68, 46, 102, 0.08);
	position: relative;
	overflow: hidden;
}

.ontario-progress-quote__accent {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
	background: linear-gradient(180deg, #442e66, #dc3545);
}

.ontario-progress-quote__icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: linear-gradient(135deg, rgba(220, 53, 69, 0.1), rgba(220, 53, 69, 0.05));
	color: #dc3545;
	font-size: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ontario-progress-quote__content {
	text-align: left;
}

.ontario-progress-quote__lead {
	font-size: 16px;
	color: var(--text-color, #5c5356);
	margin: 0 0 4px 0;
	line-height: 1.4;
}

.ontario-progress-quote__highlight {
	font-family: var(--heading-font, 'Ubuntu', sans-serif);
	font-size: 20px;
	font-weight: 700;
	color: #442e66;
	margin: 0;
	line-height: 1.3;
}

/* Responsive */
@media (max-width: 991px) {
	.ontario-progress-v2 {
		padding: 80px 0;
	}
	
	.ontario-progress-title {
		font-size: 28px;
	}
	
	.ontario-progress-steps {
		flex-direction: column;
		align-items: center;
		gap: 24px;
	}
	
	.ontario-progress-step {
		max-width: 400px;
		width: 100%;
		padding: 0;
	}
	
	.ontario-progress-step__connector {
		display: none;
	}
	
	.ontario-progress-step__number {
		margin-bottom: 12px;
	}
	
	.ontario-progress-quote__box {
		flex-direction: column;
		text-align: center;
		padding: 28px 32px;
		margin: 0 20px;
	}
	
	.ontario-progress-quote__content {
		text-align: center;
	}
	
	.ontario-progress-quote__highlight {
		font-size: 18px;
	}
}

@media (max-width: 768px) {
	.ontario-progress-v2 {
		padding: 60px 0;
	}
	
	.ontario-progress-header {
		margin-bottom: 40px;
	}
	
	.ontario-progress-title {
		font-size: 24px;
	}
	
	.ontario-progress-intro {
		font-size: 15px;
	}
	
	.ontario-progress-step__content {
		padding: 24px 20px;
	}
	
	.ontario-progress-step__icon {
		width: 48px;
		height: 48px;
	}
	
	.ontario-progress-step__icon i {
		font-size: 20px;
	}
	
	.ontario-progress-step__content h4 {
		font-size: 16px;
	}
	
	.ontario-progress-quote__box {
		padding: 24px;
	}
	
	.ontario-progress-quote__icon {
		width: 40px;
		height: 40px;
		font-size: 18px;
	}
	
	.ontario-progress-quote__lead {
		font-size: 14px;
	}
	
	.ontario-progress-quote__highlight {
		font-size: 16px;
	}
}

/* ========== Page Content Area - Gutenberg/WordPress Editor Styles ========== */
.page-content-area {
	background: var(--de-white);
	position: relative;
}

.page-content-area::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(74, 124, 89, 0.02) 0%, transparent 15%, transparent 85%, rgba(74, 124, 89, 0.02) 100%);
	pointer-events: none;
}

/* Entry Content - Main Typography */
.entry-content {
	font-size: 1rem;
	line-height: 1.85;
	color: var(--text-color);
}

.entry-content > * {
	margin-bottom: 1.5rem;
}

.entry-content > *:last-child {
	margin-bottom: 0;
}

/* Headings */
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
	font-family: var(--heading-font);
	font-weight: 700;
	line-height: 1.3;
	color: var(--heading-color);
	margin-bottom: 1.25rem;
	margin-top: 2.5rem;
}

.entry-content h1:first-child,
.entry-content h2:first-child,
.entry-content h3:first-child,
.entry-content h4:first-child,
.entry-content h5:first-child,
.entry-content h6:first-child {
	margin-top: 0;
}

.entry-content h1 { font-size: clamp(1.75rem, 3vw, 2.25rem); }
.entry-content h2 { font-size: clamp(1.5rem, 2.5vw, 1.875rem); }
.entry-content h3 { font-size: clamp(1.25rem, 2vw, 1.5rem); }
.entry-content h4 { font-size: clamp(1.125rem, 1.5vw, 1.25rem); }
.entry-content h5 { font-size: 1.0625rem; }
.entry-content h6 { font-size: 1rem; }

/* Paragraphs */
.entry-content p {
	margin-bottom: 1rem;
	line-height: 1.85;
}

.entry-content p.has-background {
	padding: 1.5rem 2rem;
	border-radius: 12px;
	margin-bottom: 1.5rem;
}

/* Links */
.entry-content a {
	color: var(--de-primary);
	text-decoration: none;
	font-weight: 500;
	transition: all 0.25s ease;
	border-bottom: 1px solid transparent;
}

.entry-content a:hover {
	color: var(--de-primary-dark, #3d6b4a);
	border-bottom-color: var(--de-primary);
}

/* Lists */
.entry-content ul,
.entry-content ol {
	margin-bottom: 1.5rem;
	padding-left: 1.5rem;
}

.entry-content ul {
	list-style: none;
}

.entry-content ul li {
	position: relative;
	padding-left: 1.5rem;
	margin-bottom: 0.75rem;
}

.entry-content ul li::before {
	content: '\f058';
	font-family: 'Font Awesome 5 Pro';
	font-weight: 400;
	position: absolute;
	left: 0;
	color: var(--de-primary);
	font-size: 0.875rem;
}

.entry-content ul li ul li::before {
	content: '\f111';
	font-size: 0.375rem;
	top: 0.5rem;
}

.entry-content ol {
	list-style: none;
	counter-reset: list-counter;
}

.entry-content ol li {
	position: relative;
	padding-left: 2rem;
	margin-bottom: 0.75rem;
	counter-increment: list-counter;
}

.entry-content ol li::before {
	content: counter(list-counter) '.';
	position: absolute;
	left: 0;
	color: var(--de-primary);
	font-weight: 700;
	font-size: 0.9375rem;
}

.entry-content li > ul,
.entry-content li > ol {
	margin-top: 0.75rem;
	margin-bottom: 0.75rem;
}

/* Blockquotes */
.entry-content blockquote,
.entry-content .wp-block-quote {
	background: linear-gradient(135deg, rgba(74, 124, 89, 0.05) 0%, rgba(107, 140, 129, 0.05) 100%);
	border-left: 4px solid var(--de-primary);
	padding: 1.5rem 2rem;
	margin: 2rem 0;
	border-radius: 0 12px 12px 0;
	position: relative;
}

.entry-content blockquote::before,
.entry-content .wp-block-quote::before {
	content: '\f10d';
	font-family: 'Font Awesome 5 Pro';
	font-weight: 900;
	position: absolute;
	top: 1rem;
	right: 1.5rem;
	color: var(--de-primary);
	opacity: 0.15;
	font-size: 2rem;
}

.entry-content blockquote p,
.entry-content .wp-block-quote p {
	font-size: 1.125rem;
	font-style: italic;
	color: var(--heading-color);
	margin-bottom: 1rem;
	line-height: 1.7;
}

.entry-content blockquote p:last-child,
.entry-content .wp-block-quote p:last-child {
	margin-bottom: 0;
}

.entry-content blockquote cite,
.entry-content .wp-block-quote cite {
	font-size: 0.875rem;
	font-style: normal;
	font-weight: 600;
	color: var(--de-primary);
}

/* Tables */
.entry-content table,
.entry-content .wp-block-table table {
	width: 100%;
	border-collapse: collapse;
	margin: 2rem 0;
	font-size: 0.9375rem;
	background: var(--de-white);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.entry-content th,
.entry-content td,
.entry-content .wp-block-table th,
.entry-content .wp-block-table td {
	padding: 1rem 1.25rem;
	text-align: left;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.entry-content th,
.entry-content .wp-block-table th {
	background: var(--de-primary);
	color: var(--de-white);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.entry-content tr:last-child td,
.entry-content .wp-block-table tr:last-child td {
	border-bottom: none;
}

.entry-content tr:nth-child(even),
.entry-content .wp-block-table tr:nth-child(even) {
	background: rgba(74, 124, 89, 0.02);
}

.entry-content tr:hover,
.entry-content .wp-block-table tr:hover {
	background: rgba(74, 124, 89, 0.04);
}

/* Code */
.entry-content code,
.entry-content pre {
	font-family: 'SF Mono', Monaco, Inconsolata, 'Fira Code', monospace;
	font-size: 0.875rem;
	background: #f5f7f6;
	border-radius: 6px;
}

.entry-content code {
	padding: 0.25rem 0.5rem;
	color: #e83e8c;
}

.entry-content pre {
	padding: 1.5rem;
	overflow-x: auto;
	margin: 2rem 0;
	border: 1px solid rgba(0, 0, 0, 0.06);
}

.entry-content pre code {
	background: none;
	padding: 0;
	color: inherit;
}

/* Images & Figures */
.entry-content img,
.entry-content .wp-block-image img {
	max-width: 100%;
	height: auto;
	border-radius: 12px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.entry-content figure,
.entry-content .wp-block-image {
	margin: 2rem 0;
}

.entry-content figcaption,
.entry-content .wp-block-image figcaption {
	text-align: center;
	font-size: 0.875rem;
	color: var(--text-color);
	margin-top: 0.75rem;
	font-style: italic;
}

/* Alignments */
.entry-content .alignleft {
	float: left;
	margin-right: 2rem;
	margin-bottom: 1rem;
}

.entry-content .alignright {
	float: right;
	margin-left: 2rem;
	margin-bottom: 1rem;
}

.entry-content .aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.entry-content .alignwide {
	max-width: 120%;
	margin-left: -10%;
}

.entry-content .alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

/* Separator */
.entry-content hr,
.entry-content .wp-block-separator {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--de-primary) 50%, transparent 100%);
	margin: 3rem auto;
	max-width: 200px;
	opacity: 0.3;
}

/* Buttons */
.entry-content .wp-block-button {
	margin: 1.5rem 0;
}

.entry-content .wp-block-button__link {
	background: linear-gradient(135deg, var(--de-primary) 0%, var(--de-secondary, #6b8c81) 100%);
	color: var(--de-white);
	padding: 14px 32px;
	border-radius: 8px;
	font-weight: 600;
	font-size: 0.9375rem;
	transition: all 0.3s ease;
	border: none;
	text-decoration: none;
	display: inline-block;
}

.entry-content .wp-block-button__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(74, 124, 89, 0.35);
	color: var(--de-white);
}

/* Gallery */
.entry-content .gallery,
.entry-content .wp-block-gallery {
	margin: 2rem 0;
}

.entry-content .gallery-item,
.entry-content .wp-block-gallery .wp-block-image {
	border-radius: 12px;
	overflow: hidden;
}

/* Cover Block */
.entry-content .wp-block-cover {
	border-radius: 12px;
	margin: 2rem 0;
}

/* Media & Text */
.entry-content .wp-block-media-text {
	border-radius: 12px;
	overflow: hidden;
	margin: 2rem 0;
}

/* Group Block */
.entry-content .wp-block-group {
	padding: 2rem;
}

.entry-content .wp-block-group.has-background {
	border-radius: 12px;
}

/* Columns */
.entry-content .wp-block-columns {
	gap: 2rem;
	margin: 2rem 0;
}

/* Pull Quote */
.entry-content .wp-block-pullquote {
	border-top: 4px solid var(--de-primary);
	border-bottom: 4px solid var(--de-primary);
	padding: 2rem;
	margin: 2.5rem 0;
}

.entry-content .wp-block-pullquote blockquote {
	background: none;
	border-left: none;
	border-radius: 0;
}

.entry-content .wp-block-pullquote blockquote::before {
	display: none;
}

/* Responsive */
@media (max-width: 991.98px) {
	.entry-content {
		font-size: 0.9375rem;
	}

	.entry-content h1 { font-size: 1.75rem; }
	.entry-content h2 { font-size: 1.5rem; }
	.entry-content h3 { font-size: 1.25rem; }
	.entry-content h4 { font-size: 1.125rem; }

	.entry-content blockquote,
	.entry-content .wp-block-quote {
		padding: 1.25rem 1.5rem;
	}

	.entry-content .alignleft,
	.entry-content .alignright {
		float: none;
		margin: 1.5rem auto;
		display: block;
	}

	.entry-content table,
	.entry-content .wp-block-table {
		font-size: 0.875rem;
	}

	.entry-content th,
	.entry-content td,
	.entry-content .wp-block-table th,
	.entry-content .wp-block-table td {
		padding: 0.75rem 1rem;
	}
}

@media (max-width: 575.98px) {
	.entry-content h1 { font-size: 1.5rem; }
	.entry-content h2 { font-size: 1.25rem; }
	.entry-content h3 { font-size: 1.125rem; }

	.entry-content blockquote,
	.entry-content .wp-block-quote {
		padding: 1rem 1.25rem;
	}

	.entry-content blockquote p,
	.entry-content .wp-block-quote p {
		font-size: 1rem;
	}

	.entry-content table,
	.entry-content .wp-block-table {
		display: block;
		overflow-x: auto;
		white-space: nowrap;
	}

	.entry-content .wp-block-columns {
		flex-direction: column;
	}
}
