/* ==========================================================================
   NUVIOR - Clean Responsive Stylesheet
   Architecture:
   - Mobile-first approach
   - Fluid typography via clamp()
   - CSS custom properties for spacing, sizing, and colors
   - Standard breakpoints: 640 / 768 / 1024 / 1280
   - rem base = 10px (1rem = 10px) for easier math
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Design Tokens (CSS Variables)
   -------------------------------------------------------------------------- */

:root {
	/* Colors */
	--c-bg: #ffffff;
	--c-bg-dark: #151717;
	--c-bg-soft: #f0f0f0;
	--c-text: #141919;
	--c-text-inverse: #ffffff;
	--c-text-muted: rgba(20, 25, 25, 0.5);
	--c-text-muted-dark: rgba(255, 255, 255, 0.5);
	--c-border: rgba(20, 25, 25, 0.15);
	--c-border-dark: rgba(255, 255, 255, 0.15);
	--c-accent: #0587b4;
	/* Fluid Typography — scales smoothly between mobile and desktop */
	--fs-xs: clamp(1.1rem, 1rem + 0.25vw, 1.3rem);
	/* 11 → 13 */
	--fs-sm: clamp(1.3rem, 1.2rem + 0.25vw, 1.45rem);
	/* 13 → 14.5 */
	--fs-base: clamp(1.35rem, 1.25rem + 0.35vw, 1.6rem);
	/* 13.5 → 16 */
	--fs-md: clamp(1.45rem, 1.3rem + 0.5vw, 1.8rem);
	/* 14.5 → 18 */
	--fs-lg: clamp(1.6rem, 1.35rem + 1vw, 2.1rem);
	/* 16 → 21 */
	--fs-xl: clamp(1.8rem, 1.5rem + 1.3vw, 2.5rem);
	/* 18 → 25 */
	--fs-2xl: clamp(2.1rem, 1.7rem + 2.2vw, 3.2rem);
	/* 21 → 32 */
	--fs-3xl: clamp(2.5rem, 2rem + 2.7vw, 3.9rem);
	/* 25 → 39 */
	--fs-4xl: clamp(3rem, 2.2rem + 4vw, 5rem);
	/* 30 → 50 */
	--fs-5xl: clamp(3.5rem, 2.5rem + 5.3vw, 6.4rem);
	/* 35 → 64 */
	--fs-6xl: clamp(4.4rem, 2.7rem + 8.8vw, 8.8rem);
	/* 44 → 88 */
	/* Line heights */
	--lh-tight: 1.1;
	--lh-snug: 1.25;
	--lh-normal: 1.5;
	--lh-relaxed: 1.65;
	/* Spacing scale */
	--sp-1: 0.5rem;
	--sp-2: 1rem;
	--sp-3: 1.5rem;
	--sp-4: 2rem;
	--sp-5: 3rem;
	--sp-6: 4rem;
	--sp-7: 6rem;
	--sp-8: 8rem;
	--sp-9: 10rem;
	--sp-10: 15rem;
	/* Section padding — fluid */
	--section-py: clamp(6rem, 4rem + 5vw, 15rem);
	--section-py-sm: clamp(4rem, 3rem + 3vw, 10rem);
	/* Container */
	--container-max: 142rem;
	--container-px: clamp(2rem, 1rem + 2vw, 4rem);
	/* Radius */
	--radius-pill: 300px;
	/* Transitions */
	--ease-out: cubic-bezier(0.16, 1, 0.3, 1);
	--ease-back: cubic-bezier(0.35, 3.55, 0.65, 1);
}
/* --------------------------------------------------------------------------
   2. Reset & Base
   -------------------------------------------------------------------------- */

*,
*::before,
*::after {
	box-sizing: border-box;
}
@font-face {
	font-family: 'Ex';
	font-style: normal;
	font-weight: 400 700;
	font-stretch: 100%;
	font-display: swap;
	src: url('fonts/Ex.woff2') format('woff2');
}
@font-face {
	font-family: 'Instrument Sans';
	font-style: normal;
	font-weight: 400 700;
	font-stretch: 100%;
	font-display: swap;
	src: url('fonts/Instrument-Sans.woff2') format('woff2');
}
html {
	font-size: 62.5%;
	/* 1rem = 10px — clean math */
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}
body {
	margin: 0;
	padding: 0;
	font-family: 'Instrument Sans', system-ui, -apple-system, sans-serif;
	font-weight: 500;
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	color: var(--c-text);
	background: var(--c-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img,
video {
	max-width: 100%;
	height: auto;
	display: block;
}
a {
	color: inherit;
	text-decoration: none;
}
ul,
ol {
	margin: 0;
	padding: 0;
	list-style: none;
}
button {
	font-family: inherit;
	cursor: pointer;
}
address,
blockquote,
em,
h1,
h2,
h3,
h4,
h5,
h6,
p {
	margin: 0;
	padding: 0;
	font-weight: inherit;
	font-style: inherit;
	font-size: inherit;
	line-height: inherit;
	letter-spacing: inherit;
}
/* --------------------------------------------------------------------------
   3. Lenis Smooth Scroll
   -------------------------------------------------------------------------- */

html.lenis,
html.lenis body {
	height: auto;
}
.lenis.lenis-smooth {
	scroll-behavior: auto !important;
}
.lenis.lenis-smooth [data-lenis-prevent] {
	overscroll-behavior: contain;
}
.lenis.lenis-stopped {
	overflow: hidden;
}
.lenis.lenis-smooth iframe {
	pointer-events: none;
}
@media (max-width: 767px) {
	html,
	body {
		overscroll-behavior-y: none;
	}
}
/* --------------------------------------------------------------------------
   4. Layout Helpers
   -------------------------------------------------------------------------- */

.container {
	max-width: 1420px;
}
/* --------------------------------------------------------------------------
   5. Typography Utilities (Gradient Em)
   -------------------------------------------------------------------------- */

.zo-em {
	-webkit-text-fill-color: transparent;
	background: linear-gradient( to right, rgb(180, 180, 180) var(--zo-progress, 0%), rgb(205, 205, 205) var(--zo-progress, 0%));
	-webkit-background-clip: text;
	background-clip: text;
}
/* Common section title patterns */

.zo-title-section .zo-title {
	font-weight: 500;
	font-size: var(--fs-5xl);
	line-height: var(--lh-tight);
	letter-spacing: -0.03em;
}
.zo-title-section .zo-text {
	font-weight: 500;
	font-size: var(--fs-lg);
	line-height: var(--lh-normal);
}
.zo-title-section .zo-more {
	margin-top: var(--sp-5);
}
.zo-headline-section {
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	line-height: var(--lh-snug);
}
.zo-heading-section {
	display: grid;
	margin-bottom: var(--sp-7);
	gap: var(--sp-4);
}
.zo-heading-section .zo-caption {
	font-family: 'Ex';
	font-size: var(--fs-md);
	line-height: var(--lh-normal);
}
.zo-heading-section .zo-heading {
	font-weight: 500;
	font-size: var(--fs-4xl);
	line-height: var(--lh-tight);
	letter-spacing: -0.03em;
}
@media (min-width: 1024px) {
	.zo-heading-section {
		grid-template-columns: auto 97.6rem;
		margin-bottom: var(--sp-9);
	}
}
/* --------------------------------------------------------------------------
   6. Button Component
   -------------------------------------------------------------------------- */

.zo-button a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 1.4rem 2.8rem;
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: 1.4;
	text-align: center;
	position: relative;
	overflow: hidden;
	background: var(--c-bg);
	color: var(--c-text);
	border: 1px solid rgba(20, 25, 25, 0.25);
	border-radius: var(--radius-pill);
	transition: transform 0.6s var(--ease-out);
}
@media (min-width: 768px) {
	.zo-button a {
		padding: 1.55rem 3.25rem;
		font-size: var(--fs-base);
	}
}
.zo-button a img {
	width: 1.8rem;
	height: 1.8rem;
}
.zo-button.zo-white a {
	border-color: var(--c-bg);
}
.zo-button.zo-black a {
	background: var(--c-bg-dark);
	color: var(--c-text-inverse);
}
.zo-button.zo-outline a {
	background: transparent;
	color: var(--c-text-inverse);
	border: 1px solid rgba(255, 255, 255, 0.5);
}
.zo-button a span {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	transition: transform 0.6s var(--ease-out), opacity 0.4s;
}
.zo-button a::before {
	content: attr(zo-content);
	width: 100%;
	position: absolute;
	top: 50%;
	left: -1.5rem;
	opacity: 0;
	transform: translate(0, -250%);
	transition: all 0.25s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
	.zo-button a:hover::before {
		opacity: 1;
		transform: translate(0, -50%);
	}
	.zo-button a:hover span {
		opacity: 0;
		transform: translate(0, 300%);
	}
	.zo-button a:hover {
		transform: scaleX(1.02);
		transition: transform 0.5s var(--ease-back);
	}
}
/* --------------------------------------------------------------------------
   7. Header
   -------------------------------------------------------------------------- */

.zo-header-section {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 50;
	background-color: transparent;
	transition: background-color 0.3s, transform 0.3s ease-in-out;
}
.zo-header-section .zo-header {
	min-height: 7.5rem;
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	color: var(--c-bg-dark);
	position: relative;
	z-index: 50;
	gap: var(--sp-3);
}
@media (min-width: 1024px) {
	.zo-header-section .zo-header {
		min-height: 8.4rem;
		grid-template-columns: 25rem 1fr 25rem;
	}
}
@media (max-width: 1024px) {
	.zo-header-section .zo-header .zo-button {
		display: none
	}
}
.zo-header-section .zo-logo {
	display: flex;
	align-items: center;
}
.zo-header-section .zo-nav {
	display: none;
	margin: auto;
	gap: clamp(2rem, 1rem + 2vw, 4rem);
}
@media (min-width: 1024px) {
	.zo-header-section .zo-nav {
		display: flex;
	}
}
.zo-header-section .zo-nav .zo-link {
	display: flex;
	align-items: center;
	gap: 1rem;
	font-weight: 500;
	font-size: var(--fs-base);
	line-height: 1.4;
	overflow: hidden;
	cursor: pointer;
}
.zo-header-section .zo-nav .zo-link a {
	color: var(--c-text);
}
.zo-header-section .zo-nav .zo-link span {
	display: block;
	position: relative;
	transition: transform 0.7s var(--ease-out);
}
.zo-header-section .zo-nav .zo-link span::after {
	content: attr(data-text);
	display: block;
	position: absolute;
	top: 105%;
	left: 0;
	right: 0;
}
@media (hover: hover) and (pointer: fine) {
	.zo-header-section .zo-nav .zo-link span:hover {
		transform: translateY(-105%);
	}
}
.zo-header-section .zo-action {
	display: none;
}
@media (min-width: 1024px) {
	.zo-header-section .zo-action {
		display: flex;
		align-items: center;
		justify-content: flex-end;
	}
}
/* --------------------------------------------------------------------------
   8. Hero Section
   -------------------------------------------------------------------------- */

.zo-hero-section {
	height: 200vh;
	position: relative;
}
@media (min-width: 1024px) {
	.zo-hero-section {
		height: 250vh;
	}
}
.zo-hero-section:first-child {
	margin-top: -7.5rem;
}
@media (min-width: 1024px) {
	.zo-hero-section:first-child {
		margin-top: -8.4rem;
	}
}
.zo-hero-section .zo-hero {
	height: 100vh;
	position: sticky;
	top: 0;
	z-index: 10;
}
.zo-hero-section .zo-hero .zo-background {
	overflow: hidden;
	pointer-events: none;
}
.zo-hero-section .zo-hero .zo-back,
.zo-hero-section .zo-hero .zo-background {
	position: absolute;
	inset: 0;
}
.zo-hero-section .zo-hero .zo-back img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}
.zo-hero-section .zo-hero .zo-composite {
	position: absolute;
	inset: 0;
	z-index: 1;
	opacity: 1;
}
.zo-hero-section .zo-hero .zo-house {
	height: clamp(30rem, 50vw, 170rem);
	position: absolute;
	top: 60vh;
	left: 0;
	right: 0;
	z-index: 1;
	transform-origin: bottom center;
}
.zo-hero-section .zo-hero .zo-house img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.zo-hero-section .zo-hero .zo-clouds {
	position: absolute;
	inset: 0;
	z-index: 2;
}
.zo-hero-section .zo-hero .zo-cloud {
	position: absolute;
	z-index: 2;
}
.zo-hero-section .zo-hero .zo-cloud:first-child {
	width: clamp(60rem, 80vw, 112rem);
	height: clamp(25rem, 35vw, 48rem);
	top: clamp(25rem, 30vw, 30%);
	left: clamp(-50rem, -30vw, -34rem);
}
.zo-hero-section .zo-hero .zo-cloud:last-child {
	width: clamp(50rem, 65vw, 94rem);
	height: clamp(22rem, 28vw, 40rem);
	top: clamp(28rem, 30vw, 20%);
	right: clamp(-40rem, -25vw, -34rem);
}
.zo-hero-section .zo-hero .zo-cloud img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.zo-hero-section .zo-logo {
	width: clamp(20rem, 50vw, 97.7rem);
	aspect-ratio: 977 / 423;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	opacity: 0;
}
.zo-hero-section .zo-logo .zo-stroke-group path {
	fill: none;
}
.zo-overlap {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 100vh;
	pointer-events: none;
}
.zo-smoke {
	height: clamp(35rem, 50vh, 62rem);
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
}
.zo-hero .zo-smoke {
	transform: translateY(30%);
}
.zo-smoke img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
}
.zo-overlay {
	height: clamp(8rem, 15vh, 30.9rem);
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0), #fff);
}
.zo-hero-section .zo-hero .zo-content {
	height: 100%;
	display: grid;
	align-items: center;
	padding-bottom: clamp(10rem, 20vh, 22.8rem);
	position: relative;
}
.zo-hero-section .zo-hero .zo-content .zo-title h1 {
	font-family: 'Ex';
	font-size: var(--fs-6xl);
	line-height: var(--lh-tight);
	letter-spacing: -0.25rem;
	text-align: center
}
.zo-hero-section .zo-hero .zo-content .zo-text {
	margin-top: var(--sp-3);
	font-weight: 500;
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	text-align: center;
	text-wrap: balance;
	margin-inline: auto;
}
@media (min-width: 1024px) {
	.zo-hero-section .zo-hero .zo-content .zo-text {
		margin-top: var(--sp-4);
		font-size: var(--fs-xl)
	}
}
@media (max-width: 1024px) {
	.zo-hero-section .zo-hero .zo-content .zo-title h1 {
		font-size: var(--fs-2xl)
	}
}
.zo-hero-section .zo-hero .zo-content .zo-text .zo-em {
	color: var(--c-text-muted);
}
.zo-hero-section .zo-hero .zo-content .zo-action {
	display: flex;
	justify-content: center;
	margin-top: var(--sp-5);
	opacity: 1
}
/* --------------------------------------------------------------------------
   9. Mission Section
   -------------------------------------------------------------------------- */

.zo-mission-section {
	padding-block: var(--section-py);
	background: var(--c-bg);
	position: relative;
}
.zo-mission-section .zo-title {
	font-family: 'Ex';
	font-size: var(--fs-md);
	line-height: var(--lh-normal);
	margin: 0 0 var(--sp-3);
}
.zo-mission-section .zo-title img {
    width: 300px
}
@media (min-width: 1024px) {
	.zo-mission-section .zo-title {
		margin: 0;
	}
}
.zo-mission-section .zo-text {
	font-size: clamp(2rem, 1.4rem + 2.5vw, 5rem);
	line-height: var(--lh-snug);
}
.zo-mission-section .zo-video {
	margin-top: var(--sp-5);
	aspect-ratio: 16 / 9;
	overflow: hidden;
}
@media (min-width: 1024px) {
	.zo-mission-section .zo-video {
		margin-top: var(--sp-7);
		max-height: 100rem;
		aspect-ratio: auto;
		height: 100rem;
	}
}
.zo-mission-section .zo-video img,
.zo-mission-section .zo-video video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/* --------------------------------------------------------------------------
   10. Healthcare Section
   -------------------------------------------------------------------------- */

.zo-healthcare-section {
	width: 100%;
	display: block;
	padding-block: var(--section-py);
}
.zo-healthcare-section strong {
	display: block;
	margin: 0 0 var(--sp-5);
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	line-height: var(--lh-tight);
}
.zo-healthcare-section span {
	display: block;
	margin-bottom: var(--sp-3);
	font-size: var(--fs-md);
	font-weight: 500;
}
.zo-healthcare-section .zo-actions ul li {
	display: block;
}
.zo-healthcare-section .zo-tab-content {
	width: 100%;
	max-width: 42.5rem;
	aspect-ratio: 425 / 550;
	position: relative;
	overflow: hidden;
	margin-bottom: var(--sp-5);
}
@media (min-width: 1024px) {
	.zo-healthcare-section .zo-tab-content {
		margin-bottom: 0;
	}
}
.zo-healthcare-section .zo-tab-pane {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	will-change: transform, opacity, clip-path;
}
.zo-healthcare-section .zo-tab-pane.is-active {
	opacity: 1;
	visibility: visible;
}
.zo-healthcare-section .zo-tab-pane img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn {
	width: 100%;
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	margin: 0;
	padding: 2rem 1.5rem;
	font-weight: 500;
	font-size: var(--fs-md);
	text-align: left;
	background: transparent;
	color: var(--c-text);
	border: 0;
	border-top: 1px solid var(--c-border);
	position: relative;
	overflow: hidden;
	cursor: pointer;
	transition: color 0.4s ease, padding-left 0.5s var(--ease-out);
}
@media (min-width: 768px) {
	.zo-healthcare-section .zo-actions ul li .zo-tab-btn {
		padding: 2.5rem 1.5rem;
		font-size: var(--fs-lg);
	}
}
.zo-healthcare-section .zo-actions ul li:first-child .zo-tab-btn {
	border-top: 0;
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	background: var(--c-bg-dark);
	transform: translateY(-101%);
	transition: transform 0.6s var(--ease-out);
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn:hover::before,
.zo-healthcare-section .zo-actions ul li .zo-tab-btn.is-active::before {
	transform: translateY(0);
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn>* {
	position: relative;
	z-index: 1;
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn:hover,
.zo-healthcare-section .zo-actions ul li .zo-tab-btn.is-active {
	padding-left: 2.5rem;
	color: var(--c-text-inverse);
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn small {
	flex-shrink: 0;
	padding-right: 0.5rem;
	font-size: var(--fs-sm);
	color: var(--c-accent);
	transition: color 0.4s ease;
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn:hover small,
.zo-healthcare-section .zo-actions ul li .zo-tab-btn.is-active small {
	color: var(--c-text-inverse);
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn p {
	margin: 0;
	line-height: var(--lh-normal);
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn::after {
	content: '';
	width: 3px;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 2;
	background: var(--c-accent);
	transform: scaleY(0);
	transform-origin: top;
	transition: transform 0.5s var(--ease-out) 0.15s;
}
.zo-healthcare-section .zo-actions ul li .zo-tab-btn.is-active::after {
	transform: scaleY(1);
}
/* --------------------------------------------------------------------------
   11. Vision Section
   -------------------------------------------------------------------------- */

.zo-vision-section {
	padding-block: var(--section-py);
}
.zo-vision-section .zo-title {
	display: flex;
	justify-content: center;
	margin: 0 0 var(--sp-6);
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	line-height: var(--lh-tight);
	text-align: center;
}
@media (min-width: 1024px) {
	.zo-vision-section .zo-title {
		margin: 0 0 var(--sp-8);
		font-size: var(--fs-5xl);
	}
}
.zo-vision-section .zo-pictures {
	display: flex;
	justify-content: center;
	margin: auto;
	position: relative
}
.zo-vision-section .zo-pictures .zo-picture {
	flex-shrink: 0;
	width: clamp(9rem, 17.5vw, 35rem);
	margin: 0 0 0 -30px;
	-webkit-mask: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 346 440"><path fill="%23000" d="M183.98 440 346 220 183.98 0H0l162.02 220L0 440h183.98Z"/></svg>');
	mask: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 346 440"><path fill="%23000" d="M183.98 440 346 220 183.98 0H0l162.02 220L0 440h183.98Z"/></svg>');
	-webkit-mask-size: contain;
	mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat
}
.zo-vision-section .zo-pictures .zo-picture img {
	width: 100%;
	height: 100%;
	object-fit: cover
}
.zo-vision-section .zo-text {
	margin-top: var(--sp-6);
	font-weight: 500;
	font-size: var(--fs-lg);
	line-height: var(--lh-snug);
	max-width: 85rem;
	margin-inline: auto;
	text-wrap: balance;
}
@media (min-width: 1024px) {
	.zo-vision-section .zo-pictures {
		margin: 0 -90px 0 0
	}
	.zo-vision-section .zo-pictures .zo-picture {
		margin: 0 0 0 -90px
	}
	.zo-vision-section .zo-text {
		font-size: var(--fs-2xl);
		line-height: 1.5
	}
}
/* --------------------------------------------------------------------------
   12. About Section
   -------------------------------------------------------------------------- */

.zo-about-section {
	padding-block: var(--section-py);
}
.zo-about-section .zo-row {
	display: flex;
	flex-direction: column;
	gap: var(--sp-6);
}
@media (min-width: 1024px) {
	.zo-about-section .zo-row {
		flex-direction: row;
	}
}
.zo-about-section .zo-row .zo-col:first-child {
	flex: 1 1;
}
.zo-about-section .zo-row .zo-col:nth-child(2) {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sp-6);
}
@media (min-width: 1024px) {
	.zo-about-section .zo-row .zo-col:nth-child(2) {
		flex-basis: 97.6rem;
		gap: var(--sp-8);
	}
}
.zo-about-section .zo-caption {
	font-family: 'Ex';
	font-size: var(--fs-md);
	line-height: var(--lh-normal);
}
.zo-about-section .zo-first {
	width: 100%;
	max-width: 35rem;
	margin-top: clamp(2rem, 10vw, 25rem);
	position: relative;
	aspect-ratio: 365 / 430;
	overflow: hidden;
}
.zo-about-section .zo-first img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.zo-about-section .zo-second {
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
}
.zo-about-section .zo-second .zo-text {
	font-size: var(--fs-lg);
	font-weight: 500;
	line-height: var(--lh-snug);
}
@media (min-width: 1024px) {
	.zo-about-section .zo-second .zo-text {
		font-size: var(--fs-2xl);
		line-height: 1.3;
		letter-spacing: -0.01em;
	}
}
.zo-about-section .zo-thumb {
	max-width: 100%;
	position: relative;
	overflow: hidden;
}
.zo-about-section .zo-thumb img {
	width: 100%;
	height: auto;
}
.zo-about-section .zo-more {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: var(--sp-5);
}
@media (min-width: 768px) {
	.zo-about-section .zo-more {
		flex-direction: row;
		gap: 1.2rem;
	}
}
/* --------------------------------------------------------------------------
   13. Testimonial Section
   -------------------------------------------------------------------------- */

.zo-testimonial-section {
	padding-block: var(--section-py);
	background: var(--c-bg-soft);
}
.zo-testimonial-section .zo-title {
	margin: 0 0 var(--sp-6);
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	line-height: var(--lh-tight);
	letter-spacing: -0.25rem
}
@media (min-width: 1024px) {
	.zo-testimonial-section .zo-title {
		margin: 0 0 var(--sp-9);
		font-size: var(--fs-5xl);
	}
	.zo-testimonial-section .zo-testimonial {
		display: grid;
		grid-template-columns: auto 65.2rem;
		gap: var(--sp-8);
	}
}
.zo-testimonial-section .zo-col:last-child {
	margin-top: var(--sp-6);
}
@media (min-width: 1024px) {
	.zo-testimonial-section .zo-col:last-child {
		margin-top: 0;
		order: -1;
	}
}
.zo-testimonial-section .zo-divider {
	border-top: 1px solid;
}
.zo-testimonial-section .zo-cover {
	overflow: hidden;
}
.zo-testimonial-section .zo-cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.zo-testimonial-section .zo-swiper {
	margin-top: var(--sp-5);
	counter-reset: item-count;
	position: relative;
}
.zo-testimonial-section .zo-swiper .swiper-pagination {
	display: flex;
	gap: 0.5rem;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 4;
}
.zo-testimonial-section .zo-swiper .swiper-pagination::after {
	content: '';
	width: clamp(3.7rem, 4vw, 4.9rem);
	height: clamp(3.7rem, 4vw, 4.9rem);
	display: block;
	position: absolute;
	right: 0;
	background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 49 49"><path fill="%23151717" d="M10.72 20.9.16 10.34 10.72 0l10.34 10.34L1.48 48.4.16 47.08 10.72 20.9Zm27.94 0L28.1 10.34 38.66 0 49 10.34 29.42 48.4l-1.32-1.32L38.66 20.9Z"/></svg>');
	background-size: cover;
}
.zo-testimonial-section .zo-swiper .swiper-pagination-bullet {
	min-width: clamp(3.6rem, 3.5vw, 4.6rem);
	height: clamp(3.6rem, 3.5vw, 4.6rem);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: 1.4;
	text-align: center;
	background: transparent;
	color: rgb(180, 180, 180);
	border: 1px solid rgb(180, 180, 180);
	border-radius: 50%;
	opacity: 1;
	cursor: pointer;
	transition: color 0.3s, transform 0.3s;
}
@media (hover: hover) and (pointer: fine) {
	.zo-testimonial-section .zo-swiper .swiper-pagination-bullet:hover {
		transform: scale(0.95);
	}
}
.zo-testimonial-section .zo-swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
	color: var(--c-text);
	border-color: var(--c-text);
	pointer-events: none;
}
.zo-testimonial-section .zo-swiper .swiper-wrapper {
	padding-top: var(--sp-9);
}
.zo-testimonial-section .zo-quote {
	font-family: 'Lora', serif;
	font-weight: 400;
	font-size: var(--fs-base);
	line-height: var(--lh-relaxed);
	letter-spacing: -0.01em;
}
@media (min-width: 1024px) {
	.zo-testimonial-section .zo-quote {
		font-size: var(--fs-lg);
		letter-spacing: -0.02em;
	}
}
.zo-testimonial-section .zo-info {
	margin-top: var(--sp-5);
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-3);
}
.zo-testimonial-section .zo-author {
	display: inline-block;
	vertical-align: middle;
	font-family: 'Lora', serif;
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: 1.2;
	text-transform: uppercase;
}
@media (min-width: 1024px) {
	.zo-testimonial-section .zo-author {
		font-size: var(--fs-base);
	}
}
.zo-testimonial-section .zo-separator {
	display: inline-block;
	vertical-align: middle;
	font-family: 'Lora', serif;
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: 1.2;
	text-transform: uppercase;
	color: var(--c-text-muted);
}
@media (min-width: 1024px) {
	.zo-testimonial-section .zo-separator {
		font-size: var(--fs-base);
	}
}
.zo-testimonial-section .zo-rating {
	width: 8rem;
	height: 1.6rem;
	display: inline-block;
	background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path fill="%23151717" d="M7.52 1.46a.5.5 0 0 1 .96 0l1.2 3.72c.07.2.26.35.48.35h3.91a.5.5 0 0 1 .3.9l-3.17 2.3a.5.5 0 0 0-.18.56l1.2 3.72a.5.5 0 0 1-.76.56l-3.17-2.3a.5.5 0 0 0-.58 0l-3.17 2.3a.5.5 0 0 1-.77-.56l1.21-3.72a.5.5 0 0 0-.18-.56l-3.16-2.3a.5.5 0 0 1 .29-.9h3.91a.5.5 0 0 0 .48-.35l1.2-3.72Z"/></svg>');
	background-size: 1.6rem 1.6rem;
}
@media (min-width: 1024px) {
	.zo-testimonial-section .zo-rating {
		width: 10rem;
		height: 2rem;
		background-size: 2rem 2rem;
	}
}
/* --------------------------------------------------------------------------
   14. Services Section
   -------------------------------------------------------------------------- */

.zo-services-section {
	padding-block: var(--section-py);
	background: var(--c-bg-dark);
	color: var(--c-text-inverse);
}
.zo-services-section .zo-service {
	width: 100%;
	min-height: clamp(25rem, 35vw, 40rem);
	display: block;
	background: none;
	color: inherit;
	border: none;
	border-top: 1px solid rgb(55, 60, 60);
	position: relative;
	overflow: hidden;
	padding: 0;
}
.zo-services-section .zo-service>.zo-container {
	height: 100%;
	min-height: inherit;
	padding-block: var(--sp-5);
	position: relative;
}
@media (min-width: 1024px) {
	.zo-services-section .zo-service>.zo-container {
		padding-top: var(--sp-7);
		padding-bottom: 5.2rem;
	}
}
.zo-services-section .zo-service>.zo-container>.row {
	position: relative;
	z-index: 1;
	--bs-gutter-x: var(--sp-5);
	row-gap: var(--sp-4);
}
@media (min-width: 1024px) {
	.zo-services-section .zo-service>.zo-container>.row {
		--bs-gutter-x: var(--sp-7);
	}
}
.zo-services-section .zo-cover {
	position: absolute;
	inset: 0;
	background: rgb(25, 30, 30);
	opacity: 0.3;
}
.zo-services-section .zo-cover img {
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
	color: transparent;
	object-fit: cover;
}
@media (hover: hover) and (pointer: fine) {
	.zo-services-section .zo-cover {
		opacity: 0;
		clip-path: inset(100% 0 0 0);
		transform: scale(1.05);
		transition: opacity 0.4s, transform 4s cubic-bezier(0.5, 1, 0.89, 1), clip-path 1s var(--ease-out);
	}
	.zo-services-section .zo-service:hover .zo-cover {
		opacity: 0.4;
		clip-path: inset(0 0 0 0);
		transform: scale(1);
	}
}
.zo-services-section .zo-service .zo-number {
	width: clamp(3.6rem, 3vw, 4.6rem);
	height: clamp(3.6rem, 3vw, 4.6rem);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: auto;
	position: relative;
	font-size: var(--fs-sm);
	font-weight: 500;
	line-height: 1.5;
	border: 1px solid;
	border-radius: 50%
}
.zo-services-section .zo-service .zo-text {
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
	text-align: left;
	position: relative;
}
@media (min-width: 768px) {
	.zo-services-section .zo-service .zo-text {
		max-width: 45rem;
		font-size: var(--fs-lg);
		letter-spacing: -0.02em;
		text-wrap: balance;
	}
}
.zo-services-section .zo-service .zo-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	align-self: end;
	font-family: 'Ex';
	font-size: clamp(3.5rem, 7.5vw, 10rem);
	line-height: 1.15;
	letter-spacing: -0.25rem;
	white-space: nowrap;
	position: relative;
}
@media (min-width: 1024px) {
	.zo-services-section .zo-service .zo-title {
		align-self: start;
	}
}
.zo-services-section .zo-service .zo-title span {
	display: inline-block;
	position: relative;
}
@media (hover: hover) and (pointer: fine) {
	.zo-services-section .zo-service .zo-title span::after {
		content: '';
		display: block;
		position: absolute;
		left: 0.085em;
		right: 0;
		bottom: 0;
		border-top: 0.0333em solid;
		transform: scaleX(0);
		transform-origin: left center;
		transition: transform 1s var(--ease-out);
	}
	.zo-services-section .zo-service:hover .zo-title span::after {
		transform: scaleX(1);
	}
}
.zo-services-section .zo-service .zo-arrow {
	position: relative;
	right: 4.5em;
	opacity: 0
}
@media (hover: hover) and (pointer: fine) {
	.zo-services-section .zo-service .zo-arrow {
		opacity: 0;
		transform: translateX(-10%);
		transition: opacity 0.5s, transform 0.75s;
	}
	.zo-services-section .zo-service:hover .zo-arrow {
		opacity: 1;
		transform: translateX(0);
	}
}
.zo-services-section .zo-content {
	margin-top: var(--sp-6);
	font-weight: 500;
	font-size: var(--fs-lg);
	line-height: var(--lh-snug);
}
@media (min-width: 1024px) {
	.zo-services-section .zo-content {
		max-width: 77.6rem;
		font-size: var(--fs-3xl);
		line-height: var(--lh-snug);
		letter-spacing: -0.02em;
	}
}
.zo-services-section .zo-content .em {
	color: rgba(255, 255, 255, 0.5);
}
.zo-services-section .zo-more {
	margin-top: var(--sp-6);
}
@media (max-width: 1024px) {
	.zo-services-section .zo-service {
		padding: 0 15px
	}
	.zo-services-section .zo-service .row {
		flex-direction: column-reverse
	}
	.zo-services-section .zo-service .row .zo-title {
		margin: 0 0 1.5rem
	}
	.zo-services-section .zo-service .row .zo-number,
	.zo-services-section .zo-service .row .zo-arrow {
		display: none
	}
}
/* --------------------------------------------------------------------------
   15. Brands Section
   -------------------------------------------------------------------------- */

.zo-brands-section {
	padding-block: var(--section-py);
	background: var(--c-bg-dark);
	color: var(--c-text-inverse);
}
.zo-brands-section .zo-title-section {
	margin-bottom: var(--sp-7);
}
.zo-brands-section .zo-title-section .zo-title {
	margin: 0 0 var(--sp-4);
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	font-weight: 500;
	line-height: var(--lh-tight);
	letter-spacing: -0.25rem
}
@media (min-width: 1024px) {
	.zo-brands-section .zo-title-section .zo-title {
		font-size: var(--fs-5xl);
		margin-bottom: 0;
	}
}
.zo-brands-section .zo-title-section .zo-text {
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	margin-bottom: var(--sp-4);
}
@media (min-width: 1024px) {
	.zo-brands-section .zo-title-section .zo-text {
		font-size: var(--fs-lg);
	}
}
.zo-brands-section .zo-brands {
	display: grid;
	grid-auto-flow: column;
	gap: var(--sp-2);
	margin-top: var(--sp-5);
	padding-inline: var(--sp-4);
	overflow-x: auto;
	overflow-y: hidden;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.zo-brands-section .zo-brands::-webkit-scrollbar {
	display: none;
}
@media (min-width: 1024px) {
	.zo-brands-section .zo-brands {
		grid-template-columns: 1fr 1fr 1fr;
		grid-auto-flow: row;
		gap: var(--sp-5);
		padding-inline: 0;
		overflow: visible;
	}
	.zo-brands-section .zo-brands:first-of-type {
		grid-template-columns: 1fr 1fr;
	}
}
@media (min-width: 1024px) and (hover: hover) {
	.zo-brands-section .zo-brands {
		transition: grid-template-columns 1s var(--ease-out);
	}
	.zo-brands-section .zo-brands:first-of-type:has(.zo-brand:first-child:hover) {
		grid-template-columns: 1.2fr 0.8fr;
	}
	.zo-brands-section .zo-brands:first-of-type:has(.zo-brand:nth-child(2):hover) {
		grid-template-columns: 0.8fr 1.2fr;
	}
	.zo-brands-section .zo-brands:not(:first-of-type):has(.zo-brand:first-child:hover) {
		grid-template-columns: 1.2fr 0.9fr 0.9fr;
	}
	.zo-brands-section .zo-brands:not(:first-of-type):has(.zo-brand:nth-child(2):hover) {
		grid-template-columns: 0.9fr 1.2fr 0.9fr;
	}
	.zo-brands-section .zo-brands:not(:first-of-type):has(.zo-brand:nth-child(3):hover) {
		grid-template-columns: 0.9fr 0.9fr 1.2fr;
	}
}
.zo-brands-section .zo-brands .zo-brand {
	width: 28rem;
	height: 38rem;
	display: grid;
	gap: var(--sp-3);
	padding: var(--sp-5);
	position: relative;
	overflow: hidden;
}
@media (min-width: 768px) {
	.zo-brands-section .zo-brands .zo-brand {
		width: 33rem;
		height: 42rem;
	}
}
@media (min-width: 1024px) {
	.zo-brands-section .zo-brands .zo-brand {
		width: auto;
		height: 47rem;
		padding: var(--sp-6);
	}
}
.zo-brands-section .zo-brands .zo-brand .zo-thumbnail {
	position: absolute;
	inset: 0;
}
.zo-brands-section .zo-brands .zo-brand .zo-thumbnail img {
	width: 100%;
	height: 100%;
	transform: scale(1.01);
	object-fit: cover;
}
.zo-brands-section .zo-brands .zo-brand .zo-title {
	max-width: 80%;
	font-weight: 500;
	font-size: var(--fs-2xl);
	line-height: var(--lh-tight);
	letter-spacing: -0.02em;
	color: var(--c-text-inverse);
	position: relative;
	text-wrap: balance;
}
@media (min-width: 1024px) {
	.zo-brands-section .zo-brands .zo-brand .zo-title {
		max-width: 34.5rem;
		font-size: var(--fs-3xl);
	}
}
.zo-brands-section .zo-brands .zo-brand .zo-text {
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
	position: relative;
}
@media (min-width: 1024px) {
	.zo-brands-section .zo-brands .zo-brand .zo-text {
		max-width: 34.5rem;
		font-size: var(--fs-md);
	}
}
@media (min-width: 1024px) and (hover: hover) {
	.zo-brands-section .zo-brands .zo-brand .zo-text {
		opacity: 0;
		transition: opacity 0.4s;
	}
	.zo-brands-section .zo-brands .zo-brand:hover .zo-text {
		opacity: 1;
	}
}
.zo-brands-section .zo-brands .zo-brand .zo-more {
	align-self: end;
	position: relative;
}
/* --------------------------------------------------------------------------
   16. News Section
   -------------------------------------------------------------------------- */

.zo-news-section {
	width: 100%;
	display: block;
	padding-block: var(--section-py);
	background: var(--c-bg-soft);
	border-bottom: 1px solid var(--c-border);
}
.zo-news-section .zo-title-section .zo-title {
	margin: 0 0 var(--sp-4);
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	font-weight: 500;
	line-height: var(--lh-tight);
	letter-spacing: -0.25rem
}
@media (min-width: 1024px) {
	.zo-news-section .zo-title-section .zo-title {
		font-size: var(--fs-5xl);
		margin-bottom: 0;
	}
}
.zo-news-section .zo-title-section .zo-text {
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	margin-bottom: var(--sp-4);
}
@media (min-width: 1024px) {
	.zo-news-section .zo-title-section .zo-text {
		font-size: var(--fs-lg);
	}
}
.zo-news-section .zo-space {
	margin-top: var(--sp-6);
}
@media (min-width: 1024px) {
	.zo-news-section .zo-space {
		margin-top: var(--sp-9);
	}
}
.zo-news-section .zo-news {
	padding-block: var(--sp-5);
	border-top: 1px solid var(--c-border);
}
.zo-news-section .zo-news .zo-thumbnail {
	display: block;
	position: relative;
	aspect-ratio: 365 / 250;
	overflow: hidden;
	margin-bottom: var(--sp-3);
}
@media (min-width: 1024px) {
	.zo-news-section .zo-news .zo-thumbnail {
		aspect-ratio: 976 / 450;
		margin-bottom: 0;
	}
}
.zo-news-section .zo-news .zo-thumbnail figure {
	width: 100%;
	height: 100%;
	display: flex;
	position: relative;
	background: transparent;
	overflow: hidden;
	margin: 0;
}
.zo-news-section .zo-news figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.zo-news-section .zo-news .zo-content {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.zo-news-section .zo-news .zo-content h2 {
	display: block;
	font-size: var(--fs-3xl);
	font-weight: 500;
	line-height: var(--lh-tight);
	letter-spacing: -0.02em;
}
.zo-news-section .zo-news .zo-content .zo-text {
	margin-top: var(--sp-3);
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
}
@media (min-width: 1024px) {
	.zo-news-section .zo-news .zo-content .zo-text {
		margin-top: var(--sp-4);
		font-size: var(--fs-base);
	}
}
.zo-news-section .zo-news .zo-content .zo-text p {
	margin: 0;
}
.zo-news-section .zo-news .zo-content .zo-more {
	margin-top: var(--sp-5);
}
.zo-news-section .zo-news .zo-content .zo-more a {
	border: 0;
}
/* Stack image above content on mobile for visual hierarchy */

@media (max-width: 1024px) {
	.zo-news-section .zo-news .row {
		flex-direction: column-reverse;
	}
	.zo-news-section .zo-news .row .zo-thumbnail {
		aspect-ratio: auto
	}
	.zo-news-section .zo-news .row .zo-thumbnail figure,
	.zo-news-section .zo-news .row .zo-thumbnail figure img {
		height: auto
	}
}
/* --------------------------------------------------------------------------
   17. Videos Section
   -------------------------------------------------------------------------- */

.zo-videos-section {
	width: 100%;
	display: block;
	padding-block: var(--section-py-sm);
}
.zo-videos-section .zo-title {
	display: block;
	margin: 0 0 var(--sp-5);
	font-family: 'Ex';
	font-size: var(--fs-4xl);
	font-weight: 600;
	line-height: var(--lh-tight);
	letter-spacing: -0.25rem;
	text-align: center;
}
.zo-videos-section .zo-more {
	margin-top: calc(var(--sp-3) * -1);
	margin-bottom: var(--sp-5);
	text-align: center;
}
.zo-videos-section img {
	width: 100%;
	border-radius: 5px
}
.zo-videos-section .swiper {
	overflow: hidden;
	padding-inline: var(--sp-3);
}
.zo-videos-section .swiper-slide {
	transition: all 0.25s ease-in-out;
	transform: scale(0.9);
}
.zo-videos-section .swiper-slide.swiper-slide-active {
	transform: scale(1);
}
/* --------------------------------------------------------------------------
   18. Canada Section (Sticky Image)
   -------------------------------------------------------------------------- */

.zo-canada-section {
	position: sticky;
	top: 0;
	width: 100%;
	height: 70vh;
	overflow: hidden;
	z-index: 1;
}
@media (min-width: 768px) {
	.zo-canada-section {
		height: 100vh;
	}
}
.zo-canada-section .zo-canada-inner {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.zo-canada-section .zo-canada-inner img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center center;
}
.zo-canada-section .zo-canada-overlay {
	display: none;
}
/* --------------------------------------------------------------------------
   19. Footer
   -------------------------------------------------------------------------- */

.zo-footer-wrapper {
	position: relative;
	z-index: 2;
	background: var(--c-bg-dark);
}
.zo-footer-section {
	color: var(--c-text-inverse);
	background-color: var(--c-bg-dark);
	position: relative;
	z-index: 1;
}
.zo-footer-section a:hover {
	color: var(--c-text-inverse);
}
.zo-footer-section .zo-grid {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-areas: 'newsletter' 'links' 'logo' 'copyright';
	gap: var(--sp-6);
	padding-block: var(--sp-7) var(--sp-5);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-grid {
		grid-template-columns: 78.1rem 48.3rem;
		grid-template-rows: repeat(3, auto);
		grid-template-areas: 'newsletter links' 'logo logo' 'copyright copyright';
		justify-content: space-between;
		padding-block: var(--sp-10) var(--sp-5);
	}
}
.zo-footer-section .zo-newsletter {
	display: flex;
	flex-direction: column;
	gap: var(--sp-7);
	grid-area: newsletter;
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-newsletter {
		width: 86.2rem;
		max-width: 100%;
	}
}
.zo-footer-section .zo-newsletter .zo-title {
	font-weight: 500;
	font-size: var(--fs-md);
	line-height: var(--lh-normal);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-newsletter .zo-title {
		font-size: var(--fs-2xl);
		line-height: var(--lh-tight);
		letter-spacing: -0.01em;
	}
}
.zo-footer-section .zo-newsletter .zo-form {
	margin-top: var(--sp-4);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-newsletter .zo-form {
		margin-top: var(--sp-5);
	}
}
.zo-footer-section .zo-newsletter .zo-form input::placeholder {
	color: var(--c-text-muted-dark);
}
.zo-footer-section .zo-newsletter .zo-form input:focus {
	border-color: var(--c-text-inverse);
}
.zo-footer-section .zo-contacts {
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-contacts {
		flex-direction: row;
		margin: var(--sp-9) 0 0;
	}
}
.zo-footer-section .zo-contacts .zo-address span {
	display: block;
	line-height: 1.75
}
.zo-footer-section .zo-contacts .zo-contact hr {
	margin: 30px 0
}
.zo-footer-section .zo-contacts .zo-contact .zo-label {
	display: none
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-contacts .zo-contact .zo-label {
		display: block;
		margin: 0 0 var(--sp-3);
		font-size: var(--fs-sm);
		font-weight: 500;
		line-height: var(--lh-normal);
		color: var(--c-text-muted-dark)
	}
}
.zo-footer-section .zo-contacts .zo-contact .zo-value {
	font-weight: 500;
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-contacts .zo-contact .zo-value {
		font-size: var(--fs-md);
	}
}
.zo-footer-section .zo-links {
	display: flex;
	justify-content: space-between;
	gap: var(--sp-4);
	grid-area: links;
}
.zo-footer-section .zo-links>* {
	flex: 1 1;
}
.zo-footer-section .zo-links .zo-link {
	font-weight: 500;
	font-size: var(--fs-xl);
	line-height: var(--lh-snug);
	letter-spacing: -0.015em;
	overflow: hidden;
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-links .zo-link {
		font-size: var(--fs-2xl);
	}
}
.zo-footer-section .zo-links .zo-link span {
	display: block;
	position: relative;
	transition: transform 0.7s var(--ease-out);
}
.zo-footer-section .zo-links .zo-link span::after {
	content: attr(data-text);
	display: block;
	position: absolute;
	top: 105%;
	right: 0;
	left: 0;
}
@media (hover: hover) and (pointer: fine) {
	.zo-footer-section .zo-links .zo-link span:hover {
		transform: translateY(-105%);
	}
}
.zo-footer-section .zo-links .zo-nav,
.zo-footer-section .zo-links .zo-socials {
	max-width: max-content;
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
.zo-footer-section .zo-links .zo-socials .zo-social {
	font-weight: 500;
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-links .zo-socials .zo-social {
		font-size: var(--fs-md);
	}
}
.zo-footer-section .zo-logo {
	grid-area: logo;
}
.zo-footer-section .zo-logo svg {
	width: 100%;
	max-width: 75rem;
	height: auto;
	overflow: visible;
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-logo {
		margin-top: var(--sp-7);
	}
}
.zo-footer-section .zo-copyright {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: var(--sp-3);
	margin-top: var(--sp-4);
	font-size: var(--fs-sm);
	font-weight: 500;
	line-height: var(--lh-normal);
	color: var(--c-text-muted-dark);
	grid-area: copyright;
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-copyright {
		flex-direction: row;
		gap: var(--sp-5);
	}
}
.zo-footer-section .zo-copyright .zo-sublinks {
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-copyright .zo-sublinks {
		flex-direction: row;
		gap: var(--sp-5);
	}
}
.zo-footer-section .zo-form {
	position: relative;
}
.zo-footer-section .zo-form .zo-send {
    position: absolute;
	top: 0;
	right: 0
}
.zo-footer-section .zo-form .zo-send input {
    padding: 5px 30px;
	background: rgb(255, 255, 255);
    color: rgb(0, 0, 0);
    font-weight: 500;
	border: 0;
	border-radius: 300px;
	cursor: pointer
}
.zo-footer-section .zo-form .zo-field {
	width: 100%;
	position: relative;
	overflow: hidden
}
.zo-footer-section .zo-form .zo-field.zo-dark {
	border-bottom-color: var(--c-text-muted-dark);
}
.zo-footer-section .zo-form .zo-field.zo-dark:focus-within {
	border-color: var(--c-text-inverse);
}
@media (min-width: 768px) {
	.zo-footer-section .zo-form .zo-field {
		padding: 0 0 1.75rem;
	}
}
.zo-footer-section .zo-form .zo-input {
    width: 100%;
    height: 45px;
	padding: 0;
	font-weight: 500;
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	background: transparent;
	color: inherit;
	border: 0;
	border-bottom: 1px solid rgb(190, 190, 190, .5);
	outline: none
}
.zo-footer-section .zo-form .zo-input:focus::placeholder {
	opacity: 0.5;
}
.zo-footer-section .zo-form .zo-input::placeholder {
	color: inherit;
}
.zo-footer-section .zo-form .zo-input:disabled {
	opacity: 0.5;
}
@media (min-width: 1024px) {
	.zo-footer-section .zo-form .zo-input {
		font-size: var(--fs-base);
	}
}
.zo-footer-section .zo-form .wpcf7-spinner {
    display: none
}
.wpcf7 form .wpcf7-response-output {
    margin: 2.5px 0 0;
    padding: 0;
    border: 0
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    color: rgb(255 185 0)    
}
.zo-hero-section .zo-hero .zo-cover-img {
	position: absolute;
	top: 80%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: clamp(25rem, 50vw, 70rem);
	z-index: 1;
}
.zo-hero-section .zo-hero .zo-cover-img img {
	width: 100%;
	height: auto;
	object-fit: contain;
}
.zo-hero-section .zo-logo .zo-stroke-group path {
	stroke: #141919;
}
.zo-hero-section .zo-logo .zo-stroke-group path {
	stroke-width: 12px;
}
/* ==========================================================================
   Mobile Menu
   ========================================================================== */

.zo-hamburger {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 4.4rem;
	height: 4.4rem;
	padding: 1rem;
	background: transparent;
	border: none;
	cursor: pointer;
	z-index: 100;
	position: absolute;
	top: 15px;
	right: 5px;
}
@media (min-width: 1024px) {
	.zo-hamburger {
		display: none;
	}
}
.zo-hamburger span {
	display: block;
	width: 100%;
	height: 2.5px;
	background: var(--c-text);
	transform-origin: center;
	transition: transform 0.4s var(--ease-out), opacity 0.3s ease, width 0.4s var(--ease-out);
}
.zo-hamburger.is-open span:nth-child(1) {
	transform: translateY(6.5px) rotate(45deg);
}
.zo-hamburger.is-open span:nth-child(2) {
	opacity: 0;
	transform: scaleX(0);
}
.zo-hamburger.is-open span:nth-child(3) {
	width: 100%;
	transform: translateY(-6.5px) rotate(-45deg);
}
.zo-mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 49;
	background: var(--c-bg);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 10rem var(--container-px) 5rem;
	clip-path: inset(0 0 100% 0);
	transition: clip-path 0.7s var(--ease-out);
	pointer-events: none;
	overflow-y: auto;
}
.zo-mobile-menu.is-open {
	clip-path: inset(0 0 0% 0);
	pointer-events: all;
}
@media (min-width: 1024px) {
	.zo-mobile-menu {
		display: none;
	}
}
.zo-mobile-nav {
	display: flex;
	flex-direction: column;
}
.zo-mobile-link {
	font-weight: 500;
	font-size: var(--fs-3xl);
	line-height: var(--lh-tight);
	letter-spacing: -0.03em;
	color: var(--c-text);
	padding: 1.6rem 0;
	border-bottom: 1px solid var(--c-border);
	display: block;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease, transform 0.5s var(--ease-out), color 0.3s;
}
.zo-mobile-link:first-child {
	border-top: 1px solid var(--c-border);
}
.zo-mobile-menu.is-open .zo-mobile-link {
	opacity: 1;
	transform: translateY(0);
}
.zo-mobile-menu.is-open .zo-mobile-link:nth-child(1) {
	transition-delay: 0.15s;
}
.zo-mobile-menu.is-open .zo-mobile-link:nth-child(2) {
	transition-delay: 0.20s;
}
.zo-mobile-menu.is-open .zo-mobile-link:nth-child(3) {
	transition-delay: 0.25s;
}
.zo-mobile-menu.is-open .zo-mobile-link:nth-child(4) {
	transition-delay: 0.30s;
}
.zo-mobile-menu.is-open .zo-mobile-link:nth-child(5) {
	transition-delay: 0.35s;
}
.zo-mobile-menu.is-open .zo-mobile-link:nth-child(6) {
	transition-delay: 0.40s;
}
@media (hover: hover) and (pointer: fine) {
	.zo-mobile-link:hover {
		color: var(--c-text-muted);
	}
}
.zo-mobile-footer {
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
	margin-top: var(--sp-5);
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease 0.45s, transform 0.5s var(--ease-out) 0.45s;
}
.zo-mobile-menu.is-open .zo-mobile-footer {
	opacity: 1;
	transform: translateY(0);
}
.zo-mobile-contacts {
	display: flex;
	flex-direction: column;
	gap: var(--sp-1);
}
.zo-mobile-contacts a {
	font-size: var(--fs-sm);
	color: var(--c-text-muted);
}
body.menu-open {
	overflow: hidden;
}
/* --------------------------------------------------------------------------
   20. About Modal
   -------------------------------------------------------------------------- */

.zo-modal {
	position: fixed;
	inset: 0;
	z-index: 1090;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	visibility: hidden;
}
.zo-modal.is-open {
	pointer-events: auto;
	visibility: visible;
	background: radial-gradient(ellipse 60% 80% at 20% 30%, rgba(5, 135, 180, 0.18) 0%, transparent 60%), radial-gradient(ellipse 70% 60% at 80% 70%, rgba(180, 200, 220, 0.15) 0%, transparent 60%), radial-gradient(ellipse 50% 70% at 60% 20%, rgba(255, 255, 255, 0.1) 0%, transparent 50%), linear-gradient(135deg, rgba(20, 25, 25, 0.6) 0%, rgba(5, 135, 180, 0.2) 50%, rgba(20, 25, 25, 0.7) 100%);
	backdrop-filter: blur(18px) saturate(160%) contrast(105%);
	-webkit-backdrop-filter: blur(18px) saturate(160%) contrast(105%);
}
.zo-modal .zo-container {
	width: 100%;
	max-height: 90vh;
	padding: 0 15px;
	position: relative;
	z-index: 15;
	opacity: 0;
	transform: scale(0.90) translateY(30px);
	filter: blur(20px);
	transition: opacity 0.7s var(--ease-out) 0.2s, transform 0.9s var(--ease-out) 0.2s, filter 0.6s var(--ease-out) 0.2s;
}
.zo-modal.is-open .zo-container {
	opacity: 1;
	transform: scale(1) translateY(0);
	filter: blur(0);
}
.zo-modal .zo-container .zo-close {
	width: 4.5rem;
	height: 4.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	top: -15px;
	right: 0;
	background: rgb(255, 255, 255);
	border: 1px solid var(--c-border);
	border-radius: 50%;
	cursor: pointer;
	transition: transform 0.25s var(--ease-out), background 0.25s;
	z-index: 15
}
.zo-modal .zo-container .zo-close span {
	position: absolute;
	width: 1.6rem;
	height: 1.5px;
	background: var(--c-text);
	transition: transform 0.4s var(--ease-out);
}
.zo-modal .zo-container .zo-close span:first-child {
	transform: rotate(45deg);
}
.zo-modal .zo-container .zo-close span:last-child {
	transform: rotate(-45deg);
}
@media (hover: hover) {
	.zo-modal .zo-container .zo-close:hover {
		background: var(--c-bg-soft);
		transform: scale(1.08) rotate(90deg);
	}
}
.zo-modal .zo-container .zo-layout {
	max-height: 85vh;
	display: flex;
	flex-direction: column-reverse
}
.zo-modal .zo-container .zo-layout .zo-text {
	max-height: 85vh;
	padding: 30px;
	flex: 1 1 auto;
	background: rgb(255, 255, 255);
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch
}
.zo-modal .zo-container .zo-layout .zo-text h3 {
	display: block;
	margin: 15px 0 5px;
	font-size: 2.5rem;
	font-weight: 700
}
.zo-modal .zo-container .zo-layout .zo-text h4 {
	display: block;
	margin: 15px 0 5px;
	font-size: 1.75rem;
	font-weight: 700
}
.zo-modal .zo-container .zo-layout .zo-text ul {
	margin: 15px 0
}
.zo-modal .zo-container .zo-layout .zo-text ul li {
	width: 100%;
	display: inline-block
}
.zo-modal .zo-container .zo-layout .zo-text::-webkit-scrollbar {
	width: 6px;
}
.zo-modal .zo-container .zo-layout .zo-text::-webkit-scrollbar-track {
	background: transparent;
}
.zo-modal .zo-container .zo-layout .zo-text::-webkit-scrollbar-thumb {
	background: var(--c-border);
	border-radius: 3px;
}
.zo-modal .zo-container .zo-layout .zo-text::-webkit-scrollbar-thumb:hover {
	background: var(--c-text-muted);
}
.zo-modal .zo-container .zo-layout .zo-thumbnail {
	flex: 0 0 auto;
	position: relative;
	overflow: hidden;
}
.zo-modal .zo-container .zo-layout .zo-thumbnail img {
	width: 100%;
	height: 300px;
	object-fit: cover;
	display: block;
}
@media (min-width: 1024px) {
	.zo-modal .zo-container .zo-layout {
		height: 85vh;
		max-height: 85vh;
		flex-direction: row
	}
	.zo-modal .zo-container .zo-layout .zo-thumbnail {
		flex: 0 0 45%;
		height: 85vh;
		position: sticky;
		top: 0;
	}
	.zo-modal .zo-container .zo-layout .zo-thumbnail img {
		width: 100%;
		height: 100%;
		object-fit: cover
	}
}
.zo-modal .zo-form {
	width: 55%
}
@media (min-width: 1024px) {
	.zo-modal .zo-form .zo-layout {
		height: auto;
		max-height: auto;
		flex-direction: column-reverse
	}
	.zo-modal .zo-form .zo-layout .zo-thumbnail {
		flex: 0 0 25%;
		height: 85vh;
		position: sticky;
		top: 0;
	}
}
.zo-marquee {
	overflow: hidden;
	width: 100%;
	position: relative;
	/* Optional fade edges for a polished look */
	-webkit-mask-image: linear-gradient( to right, transparent 0, #000 80px, #000 calc(100% - 80px), transparent 100%);
	mask-image: linear-gradient( to right, transparent 0, #000 80px, #000 calc(100% - 80px), transparent 100%);
}
.zo-marquee ul {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 15px;
	width: max-content;
	/* let it grow as wide as its contents */
	animation: zo-scroll 10s linear infinite;
	will-change: transform;
}
.zo-marquee ul li {
	flex: 0 0 auto;
}
.zo-marquee ul li img {
	height: 350px;
	display: block;
	width: auto;
	user-select: none;
	-webkit-user-drag: none;
}
/* Pause on hover */

.zo-marquee:hover ul {
	animation-play-state: paused;
}
/* The magic: scroll exactly half the width (since we duplicate the list) */

@keyframes zo-scroll {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-50%);
	}
}
/* Respect users who prefer no motion */

@media (prefers-reduced-motion: reduce) {
	.zo-marquee ul {
		animation: none;
	}
}
/* --------------------------------------------------------------------------
   21. Service Request Modal (Portal Choice + CF7)
   -------------------------------------------------------------------------- */

.zo-modal-service .zo-step {
	display: none;
}
.zo-modal-service .zo-step.is-active {
	display: block;
}
/* --- Step 1: Portal Choice -------------------------------------------- */

.zo-modal-service .zo-service-title {
	margin: 0 0 var(--sp-2);
}
.zo-modal-service .zo-service-subtext {
	margin: 0 0 var(--sp-5);
	font-size: var(--fs-base);
	color: var(--c-text-muted);
}
.zo-modal-service .zo-portal-choices {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-3);
	margin-top: var(--sp-4);
}
@media (min-width: 768px) {
	.zo-modal-service .zo-portal-choices {
		grid-template-columns: 1fr 1fr;
		gap: var(--sp-4);
	}
}
.zo-modal-service .zo-portal-btn {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	gap: var(--sp-2);
	padding: var(--sp-3) var(--sp-3);
	text-align: center;
	background: var(--c-bg);
	color: var(--c-text);
	border: 1px solid var(--c-border);
	border-radius: 16px;
	cursor: pointer;
	font-family: inherit;
	transition: transform 0.4s var(--ease-out), background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}
.zo-modal-service .zo-portal-btn .zo-portal-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 1.2rem 2.4rem;
	font-weight: 600;
	font-size: var(--fs-sm);
	line-height: 1.4;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	border-radius: var(--radius-pill);
	transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}
.zo-modal-service .zo-portal-btn .zo-portal-desc {
	font-size: var(--fs-xs);
	line-height: var(--lh-normal);
	font-weight: 500;
	font-style: italic;
	color: var(--c-text);
	max-width: 32rem;
}
/* Manufacturer (filled black) */

.zo-modal-service .zo-portal-manufacturer .zo-portal-label {
	min-width: 30rem;
	background: var(--c-bg-dark);
	color: var(--c-text-inverse);
	border: 1px solid var(--c-bg-dark)
}
/* Medical Professional (outline) */

.zo-modal-service .zo-portal-medical .zo-portal-label {
	min-width: 30rem;
	background: transparent;
	color: var(--c-text);
	border: 1px solid var(--c-border)
}
@media (hover: hover) and (pointer: fine) {
	.zo-modal-service .zo-portal-btn:hover {
		transform: translateY(-2px);
	}
	.zo-modal-service .zo-portal-manufacturer:hover .zo-portal-label {
		opacity: 0.9;
	}
	.zo-modal-service .zo-portal-medical:hover .zo-portal-label {
		background: var(--c-bg-dark);
		color: var(--c-text-inverse);
		border-color: var(--c-bg-dark);
	}
}
/* --- Step 2: Form ---------------------------------------------------- */

.zo-modal-service .zo-back-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	margin-bottom: var(--sp-3);
	padding: 0.6rem 1.2rem 0.6rem 0;
	font-family: inherit;
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-text-muted);
	background: transparent;
	border: none;
	cursor: pointer;
	transition: color 0.25s ease, transform 0.3s var(--ease-out);
}
.zo-modal-service .zo-back-btn:hover {
	color: var(--c-text);
	transform: translateX(-3px);
}
.zo-modal-service .zo-service-form {
	margin-top: var(--sp-4);
}
.zo-modal-service .zo-service-form .wpcf7 {
	margin: 0;
	padding: 0;
}
.wpcf7-form-control-wrap .wpcf7-form-control.wpcf7-checkbox {
	display: flex;
	flex-direction: column;
	margin: 10px 0 0
}
.wpcf7-form-control-wrap .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item {
	margin: 0 0 2.5px
}
.wpcf7-form-control-wrap .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item input {
	position: relative;
	top: 1.5px
}
.zo-modal-service .zo-service-form .zo-title {
	font-size: var(--fs-md)
}
.zo-modal-service .zo-service-form p {
	margin: 0 0 var(--sp-3);
}
.zo-modal-service .zo-service-form label {
	display: block;
	margin-bottom: 0.6rem;
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-text);
}
.zo-modal-service .zo-service-form input[type="text"],
.zo-modal-service .zo-service-form input[type="email"],
.zo-modal-service .zo-service-form input[type="tel"],
.zo-modal-service .zo-service-form input[type="url"],
.zo-modal-service .zo-service-form input[type="number"],
.zo-modal-service .zo-service-form select,
.zo-modal-service .zo-service-form textarea {
	width: 100%;
	padding: .75rem 0;
	font-family: inherit;
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
	color: var(--c-text);
	background: var(--c-bg);
	border: 0;
	border-bottom: 1px solid rgb(0, 0, 0);
	outline: none;
	transition: border-color 0.25s ease;
}
.zo-modal-service .zo-service-form input:focus,
.zo-modal-service .zo-service-form select:focus,
.zo-modal-service .zo-service-form textarea:focus {
	border-color: var(--c-accent);
}
.zo-modal-service .zo-service-form textarea {
	height: 10rem;
	resize: none
}
.zo-modal-service .zo-service-form input[type="submit"],
.zo-modal-service .zo-service-form .wpcf7-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 1.25rem 4.5rem;
	font-family: inherit;
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: 1.4;
	background: var(--c-bg-dark);
	color: var(--c-text-inverse);
	border: 1px solid var(--c-bg-dark);
	border-radius: var(--radius-pill);
	cursor: pointer;
	transition: opacity 0.25s ease, transform 0.4s var(--ease-out);
}
.zo-modal-service .zo-service-form input[type="submit"]:hover,
.zo-modal-service .zo-service-form .wpcf7-submit:hover {
	opacity: 0.88;
	transform: scale(1.02);
}
.zo-modal-service .zo-service-form .wpcf7-not-valid-tip {
	margin-top: 0.5rem;
	font-size: var(--fs-xs);
	color: #d33;
}
.zo-modal-service .zo-service-form .wpcf7-response-output {
	margin-top: var(--sp-3);
	padding: 1rem 1.4rem;
	font-size: var(--fs-sm);
	border-radius: 4px;
}
.zo-modal-service .zo-service-form .wpcf7-spinner {
	margin-left: 1rem;
}