/* === TABLE OF CONTENTS ===
 * 1. CSS Layers
 * 2. Reset
 * 3. CSS Custom Properties (:root)
 * 4. Globals (h1-h6, a, etc.)
 * 5. Utils (.sr-only, .wrapper-*, etc.)
 * 6. Components
 *    - Buttons
 *    - Logo
 *    - Eyebrow & Brand Dots
 *    - Logo Cloud
 *    - Splide Carousels
 *    - CTA Banner
 *    - Pagination
 *    - Modal (Portfolio)
 * 7. Template-Specific Styles
 *    - Header
 *    - Drawer
 *    - Content & Article
 *    - Footer
 *    - Search Form
 * 8. Project-Specific Styles
 *    - Homepage
 *    - Hero Video
 *    - Intro
 *    - Industries & Brands
 *    - Case Studies
 *    - Services
 *    - Portfolio
 *    - Relationships
 *    - News
 *    - Services Page
 */

/* === 1. CSS Layers === */
@layer reset, base, utilities, components;
@layer reset {
	*,
	*::before,
	*::after {
		box-sizing: inherit;
	}
	html {
		box-sizing: border-box;
		line-height: 1.5;
		-webkit-text-size-adjust: 100%;
		color: var(--black);
	}
	body {
		margin: 0;
		touch-action: manipulation;
		scroll-behavior: smooth;
	}
	img,
	iframe,
	embed,
	object,
	video {
		display: block;
		max-width: 100%;
		height: auto;
	}
	iframe {
		width: 100%;
		aspect-ratio: 16 / 9;
		border-radius: 1rem;
		overflow: hidden;
	}
	button,
	input,
	optgroup,
	select,
	textarea {
		font-family: inherit;
		font-size: 100%;
		line-height: 1.15;
		margin: 0;
	}
	b,
	strong {
		font-weight: bolder;
	}
	:where(.menu, .sub-menu) {
		margin: 0;
		padding: 0;
		list-style: none;
	}
	@media (prefers-reduced-motion: reduce) {
		html:focus-within {
			scroll-behavior: auto;
		}
		*,
		*::before,
		*::after {
			animation-duration: 0.01ms !important;
			animation-iteration-count: 1 !important;
			transition-duration: 0.01ms !important;
			scroll-behavior: auto !important;
		}
	}
}
@layer base {
	/* === 2. CSS Custom Properties === */
	:root {
		/* --- Colors --- */
		--primary-base: 28.61% 0.0637 238.26;
		--secondary-base: 75.24% 0.093 226.27;
		--white-base: 100% 0 0;
		--black-base: 60% 0 0;
		--strategy-base: 38.74% 0.0378 266.59;
		--creative-base: 60.78% 0.1221 237.06;
		--media-base: 79.55% 0.1572 81.27;
		--development-base: 65.26% 0.1235 15.3;
		--production-base: 75.24% 0.0482 189.39;

		--primary-hover-base: 66.82% 0.1082 225.63;

		--primary: oklch(var(--primary-base));
		--secondary: oklch(var(--secondary-base));
		--white: oklch(var(--white-base));
		--black: oklch(var(--black-base));
		--strategy: oklch(var(--strategy-base));
		--creative: oklch(var(--creative-base));
		--media: oklch(var(--media-base));
		--development: oklch(var(--development-base));
		--production: oklch(var(--production-base));

		--primary-hover: oklch(var(--primary-hover-base));

		--bg-light-base: 98.22% 0.0067 233.64;
		--bg-light: oklch(var(--bg-light-base));

		--border-light: oklch(var(--primary-base) / 0.1);

		--ff-heading: 'avenir-lt-pro', sans-serif;
		--ff-body: 'avenir-lt-pro', sans-serif;

		--fs-xs: clamp(0.6rem, 0.051vi + 0.587rem, 0.633rem);
		--fs-sm: clamp(0.75rem, 0.145vi + 0.714rem, 0.844rem);
		--fs-base: clamp(0.938rem, 0.288vi + 0.865rem, 1.125rem);
		--fs-md: clamp(1.172rem, 0.504vi + 1.046rem, 1.5rem);
		--fs-lg: clamp(1.465rem, 0.822vi + 1.259rem, 1.999rem);
		--fs-xl: clamp(1.831rem, 1.282vi + 1.51rem, 2.665rem);
		--fs-2xl: clamp(2.289rem, 1.943vi + 1.803rem, 3.552rem);
		--fs-3xl: clamp(2.861rem, 2.883vi + 2.14rem, 4.735rem);

		--gutter: 2rem;
		--max-w-max: 110rem;
		--max-w-content: 90rem;
		--max-w-article: 80rem;
		--max-w-feature: 52rem;
		--max-w-text: 48rem;

		--shadow-color: oklch(var(--primary-base) / 0.15);
		--shadow-color-dark: color-mix(in oklch, var(--primary) 80%, black 20%);
		--shadow-color-hover: oklch(var(--primary-base) / 0.35);
		--shadow-color-dark-hover: color-mix(in oklch, var(--primary) 60%, black 40%);

		--shadow: 0 3px 6px var(--shadow-color);
		--shadow-dark: 0 3px 6px var(--shadow-color-dark);
		--shadow-hover: 0 6px 12px var(--shadow-color-hover);
		--shadow-dark-hover: 0 6px 12px var(--shadow-color-dark-hover);
		--transition: all 200ms ease-out;

		@media (max-width: 480px) {
			--gutter: 1rem;
		}
	}
	/* === 4. Globals === */
	body {
		font-family: var(--ff-body);
		font-size: var(--fs-base);
	}
	body.dark-mode {
		background-color: oklch(var(--primary-base));
	}
	.site {
		display: flex;
		flex-direction: column;
		min-height: 100svh;
	}
	#main {
		flex: 1;
	}
	h1,
	h2,
	h3,
	h4,
	h5,
	h6 {
		--heading-color: var(--primary);
		color: var(--heading-color);
		font-family: var(--ff-heading);
		font-weight: 700;
		line-height: 1.2;
		letter-spacing: 0.01em;
		margin-block: 0 0.5em;
		text-transform: lowercase;
		text-wrap: balance;
	}
	h1 {
		font-size: var(--fs-2xl);
	}
	h2 {
		font-size: var(--fs-xl);
	}
	h3 {
		font-size: var(--fs-lg);
	}
	h4 {
		font-size: var(--fs-md);
	}
	h5 {
		font-size: var(--fs-base);
	}
	h6 {
		font-size: var(--fs-sm);
	}
	hr {
		width: 100%;
		height: 1px;
		border: none;
		margin-block: 3rem;
		background-color: oklch(var(--primary-base) / 0.1);
	}
	@media (max-width: 768px) {
		hr {
			margin-block: 3rem;
		}
	}
	a:not(.btn) {
		color: var(--primary);
		text-decoration: underline;
		text-decoration-thickness: 0.1em;
		text-underline-offset: 0.2em;
	}
	a:not(.btn):hover {
		color: color-mix(in oklch, var(--primary) 75%, black 25%);
		text-decoration-thickness: 0.15em;
		text-underline-offset: 0.25em;
	}
}
/* === 5. Utils === */
@layer utilities {
	.sr-only {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}
	.wrapper {
		padding-block: 3rem;
		padding-inline: var(--gutter);
	}
	.intro-wrapper {
		padding-block-end: 6rem;
	}
	.intro-wrapper > div {
		padding-inline: var(--gutter);
	}
	.inner-wrapper > div {
		padding-inline: var(--gutter);
	}
	@media (max-width: 768px) {
		.wrapper {
			padding-block: 3rem;
		}
	}
	.container {
		max-width: var(--max-w-content);
		margin-inline: auto;
	}
	.container--center {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	.inner-container {
		max-width: var(--max-w-content);
		margin-inline: auto;
	}
	.inner-feature {
		max-width: var(--max-w-feature);
		margin-inline: auto;
		margin-block: 6rem;
	}
	.bg-light {
		background-color: var(--bg-light);
	}
	.bg-dark {
		background-color: var(--primary);

		h2 {
			color: var(--white);
		}
	}
	.fs-sm {
		font-size: var(--fs-sm);
	}
	.fs-base {
		font-size: var(--fs-base);
	}
	.fs-md {
		font-size: var(--fs-md);
	}
	.fs-lg {
		font-size: var(--fs-lg);
	}
	.fs-xl {
		font-size: var(--fs-xl);
	}
	.fs-2xl {
		font-size: var(--fs-2xl);
	}
	.fs-3xl {
		font-size: var(--fs-3xl);
	}
}

/* === 6. Components === */
@layer components {
	/* --- Buttons --- */
	.btn,
	.btn-nav a {
		display: inline-block;
		background-color: var(--secondary);
		padding: 0.75rem 1.5rem;
		border-radius: 1rem;
		border: 2px solid var(--secondary);
		color: var(--white);
		font-size: var(--fs-base);
		font-weight: 400;
		text-decoration: none;
		text-transform: lowercase;
		text-align: center;
		cursor: pointer;
	}
	.btn:hover,
	.btn-nav a:hover {
		background-color: var(--primary-hover);
		border-color: var(--primary-hover);
	}
	.btn-outline {
		background-color: transparent;
		color: var(--secondary);
		border: 2px solid var(--secondary);
	}
	.btn-outline:hover {
		background-color: oklch(var(--primary-hover-base) / 0.1);
		color: var(--primary-hover);
		border-color: var(--primary-hover);
	}

	/* --- Logo --- */
	.site-logo {
		display: flex;
		padding-block: 1rem;
		transition: var(--transition);
	}
	.site-logo svg {
		--color-logo-primary: var(--white);
		--color-logo-secondary: var(--white);
		width: 200px;
		height: 42px;
		transition: var(--transition);
	}
	body:not(.home):not(.dark-mode) .site-header .site-logo svg,
	body:not(.dark-mode) .site-header-wrapper.is-locked .site-logo svg {
		--color-logo-primary: var(--primary);
		--color-logo-secondary: var(--secondary);
	}
	@media (width <= 1024px) {
		.site-logo svg {
			width: 180px;
			height: 38px;
		}
		.site-header.is-locked .site-logo svg {
			width: 130px;
			height: 27px;
		}
	}
	@media (width <= 768px) {
		.site-logo svg {
			width: 160px;
			height: 34px;
		}
		.site-header.is-locked .site-logo svg {
			width: 120px;
			height: 25px;
		}
	}
	@media (width <= 480px) {
		.site-logo svg {
			width: 140px;
			height: 29px;
		}
		.site-header.is-locked .site-logo svg {
			width: 100px;
			height: 21px;
		}
	}
	/* --- Eyebrow & Brand Dots --- */
	.eyebrow {
		color: var(--secondary);
		font-size: var(--fs-md);
		font-weight: 200;
		text-transform: lowercase;
		margin-block: 0 1rem;
	}
	.brand-dots {
		display: flex;
		gap: 3rem;
		justify-content: center;
		align-items: center;
		margin-block-end: 3rem;
	}
	.brand-dot,
	.services-dot {
		width: 0.5rem;
		height: 0.5rem;
		border-radius: 9999px;
		background-color: var(--team-color, var(--secondary));
		aspect-ratio: 1 / 1;
	}
	.services-dot {
		position: relative;
		top: 0.4em;
	}
	/* --- Logo Cloud --- */
	.logo-cloud {
		display: grid;
		grid-template-columns: repeat(var(--grid-columns, 12), 1fr);
		gap: 3rem;
		align-items: center;
		justify-items: center;
		margin-inline: auto;
		margin-block-start: 1.5rem;
	}
	.logo-cloud img {
		object-fit: contain;
		object-position: center;
		transition: var(--transition);
	}
	.logo-cloud-item {
		grid-area: var(--logo-area);
	}
	@media (width <= 1024px) {
		.logo-cloud {
			gap: 2rem;
		}
	}
	/* --- Logo Marquee --- */
	.logo-marquee {
		position: relative;
		overflow: hidden;
		mask-image: linear-gradient(to right, transparent 0, black 5%, black 95%, transparent 100%);
		-webkit-mask-image: linear-gradient(
			to right,
			transparent 0,
			black 5%,
			black 95%,
			transparent 100%
		);
	}
	.logo-marquee__track {
		--marquee-gap: clamp(2rem, 6vw, 6rem);
		--marquee-duration: 38s;
		display: flex;
		gap: var(--marquee-gap);
		align-items: center;
		width: max-content;
		animation: logo-marquee-scroll var(--marquee-duration, 26s) linear infinite;
		padding-block: 1rem;
		will-change: transform;
		backface-visibility: hidden;
		transform: translate3d(0, 0, 0);
	}
	.logo-marquee--reverse .logo-marquee__track {
		animation-direction: reverse;
	}
	.logo-marquee__track > * {
		flex: 0 0 auto;
	}
	.logo-marquee a {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		text-decoration: none;
	}
	/* Pause marquee on hover */
	.logo-marquee:hover .logo-marquee__track,
	.logo-marquee__track:hover {
		animation-play-state: paused;
	}
	.logo-marquee img {
		height: clamp(2.5rem, 100%, 3.5rem);
		width: auto;
		object-fit: contain;
		object-position: center;
		transition: filter var(--transition);
		pointer-events: none;
		backface-visibility: hidden;
		transform: translateZ(0);
	}
	/* Larger marquee variant for bigger logos */
	.logo-marquee--xl img {
		aspect-ratio: 16 / 9;
		max-width: 180px;
		filter: brightness(0) invert(0.85);
	}
	@keyframes logo-marquee-scroll {
		0% {
			transform: translate3d(0, 0, 0);
		}
		100% {
			transform: translate3d(calc(-1 * var(--marquee-distance, 50%)), 0, 0);
		}
	}

	@media (prefers-reduced-motion: reduce) {
		.logo-marquee__track {
			animation: none !important;
		}
	}

	/* --- Card --- */
	.card {
		background-color: var(--white);
		border: 1px solid oklch(var(--primary-base) / 0.1);
		border-radius: 1rem;
		padding: 2rem;
	}
	.card.card--link {
		box-shadow: var(--shadow);
		transition: var(--transition);
	}
	.card.card--link:hover {
		box-shadow: var(--shadow-hover);
		transform: translateY(-6px);
	}
	.card--icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 2.5rem;
		height: 2.5rem;
		background-color: var(--secondary);
		color: var(--white);
		border-radius: 0.75rem;
		margin-bottom: 1rem;
	}
	.card h3 {
		font-size: var(--fs-md);
		color: var(--primary);
		margin-bottom: 1rem;
	}
	.card p {
		font-size: var(--fs-base);
		line-height: 1.6;
		color: var(--text-secondary);
		margin-bottom: 0;
	}
	.card-cta {
		background-color: var(--primary);
		color: var(--white);
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		text-align: center;
		gap: 0.5rem;
	}
	.card-cta :is(h3, p) {
		color: var(--white);
		margin: 0;
	}
	.card-cta .btn {
		margin-top: 0.5rem;
		padding: 0.5rem 1rem;
	}
	@media (width <= 768px) {
		.card--icon {
			margin-bottom: 0.5rem;
		}
	}
	/* === Splide Carousels === */
	.splide {
		margin-block-start: 1rem;
		max-width: 100%;
	}
	.splide__arrows {
		display: flex;
		align-items: center;
		gap: 1rem;
	}
	.splide__arrow {
		background-color: var(--white);
		border-radius: 9999px;
		border: 1px solid currentColor;
		color: var(--secondary);
		width: 2.5rem;
		height: 2.5rem;
		display: flex;
		align-items: center;
		justify-content: center;
		cursor: pointer;
		transition: var(--transition);
	}
	.splide__arrow:hover {
		background-color: var(--bg-light);
	}
	.splide__arrow:disabled {
		color: color-mix(in oklch, var(--secondary) 50%, var(--white) 50%);
		cursor: not-allowed;
	}
	.splide__arrow:hover:disabled {
		background-color: transparent;
	}
	/* --- CTA Banner --- */
	.cta-banner {
		background-color: var(--primary);
		color: var(--white);
		padding: 6rem var(--gutter) 0;
		text-align: center;
	}
	.cta-banner-wrapper {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 3rem;
		max-width: var(--max-w-content);
		margin-inline: auto;
		border-block-end: 2px solid oklch(var(--white-base) / 50%);
		padding-block-end: 6rem;
	}
	.cta-banner-wrapper h2 {
		color: var(--white);
		margin: 0;
	}
	.cta-banner-wrapper:has(.details) {
		gap: 1rem;
	}
	.cta-banner-wrapper .details {
		max-width: 66ch;
		margin-inline: auto;
		text-align: center;
	}
	/* --- Pagination --- */
	.pagination {
		margin-block-start: 2rem;
		display: flex;
		justify-content: center;
	}
	.page-numbers {
		list-style: none;
		padding: 0;
		margin: 0;
		display: inline-flex;
		gap: 0.5rem;
	}
	.page-numbers a,
	.page-numbers span,
	.page-numbers button {
		display: inline-block;
		padding: 0.5rem 0.75rem;
		border: 1px solid oklch(var(--primary-base) / 0.2);
		border-radius: 0.5rem;
		text-decoration: none;
		color: var(--primary);
	}
	.page-numbers button[disabled] {
		opacity: 0.5;
		cursor: not-allowed;
		height: 100%;
	}
	.page-numbers .current {
		background-color: oklch(var(--primary-base) / 0.1);
		border-color: oklch(var(--primary-base) / 0.3);
		color: var(--primary);
	}
	.page-numbers a:hover {
		background-color: oklch(var(--primary-base) / 0.08);
	}
	/* --- Modal (Portfolio) --- */
	.modal-backdrop {
		position: fixed;
		inset: 0;
		background-color: color-mix(in oklch, var(--primary) 60%, transparent 40%);
		display: grid;
		place-items: center;
		padding: var(--gutter);
		z-index: 100000;
	}
	.modal-backdrop[hidden] {
		display: none !important;
	}
	.modal {
		background: var(--white);
		color: var(--black);
		width: min(90vw, var(--max-w-max));
		max-height: 92vh;
		border-radius: 1rem;
		box-shadow: var(--shadow-dark-hover);

		padding: 2rem 4rem;
		overflow: hidden auto;
		outline: none;
	}
	.modal-close {
		position: sticky;
		top: 0;
		margin-left: auto;
		margin-right: -2rem;
		background-color: var(--white);
		border-radius: 9999px;
		border: 1px solid currentColor;
		color: oklch(var(--black-base) / 0.4);
		width: 2.5rem;
		height: 2.5rem;
		display: flex;
		align-items: center;
		justify-content: center;
		cursor: pointer;
		transition: var(--transition);
		z-index: 1;
	}
	.modal-close:hover {
		background-color: oklch(var(--black-base) / 0.05);
	}
	.modal-content {
		display: grid;
		gap: 2rem;
	}
	.modal-header {
		display: grid;
		grid-template-columns: 3fr 2fr;
		gap: 2rem;
		align-items: start;
	}
	.modal-header h2 {
		margin: 0;
	}
	.services-title {
		margin-block: 0 0.5em;
		font-size: var(--fs-md);
		color: var(--primary);
		text-transform: lowercase;
	}
	.services-list {
		list-style: none;
		padding: 0;
		margin: 0;
		display: grid;
		gap: 0.5rem;
		text-transform: lowercase;
	}
	.services-list-row {
		display: flex;
		align-items: start;
		gap: 0.5rem;
		font-size: var(--fs-sm);
		color: var(--black);
	}
	.category-groups {
		display: grid;
		gap: 1rem;
		margin-top: 0.5rem;
	}
	.category-group-title {
		font-size: var(--fs-base);
		color: var(--secondary);
		margin: 0;
		text-transform: lowercase;
	}
	.category-pills {
		list-style: none;
		padding: 0;
		margin: 0.25rem 0 0 0;
		display: flex;
		flex-wrap: wrap;
		gap: 0.5rem;
	}
	.category-pill {
		padding: 0.25rem 0.5rem;
		border: 1px solid oklch(var(--primary-base) / 0.2);
		border-radius: 9999px;
		font-size: var(--fs-sm);
		color: var(--black);
		background: var(--bg-light);
	}
	/* Shared carousel styles for portfolio & case study */
	.splide-portfolio .splide__track,
	.splide-case-study .splide__track {
		overflow: visible !important;
	}
	.splide-portfolio .splide__slide,
	.splide-case-study .splide__slide {
		border-radius: 1rem;
		overflow: hidden;
		max-width: 100%;
	}
	.splide-portfolio .splide__arrows,
	.splide-case-study .splide__arrows {
		margin-block-start: 2rem;
		justify-content: center;
	}
	.splide-portfolio .splide__slide[data-splide-html-video],
	.splide-case-study .splide__slide[data-splide-html-video] {
		width: min(var(--video-slide-width, 320px), 100%);
	}
	.splide-portfolio .splide__video__wrapper video,
	.splide-case-study .splide__video__wrapper video {
		width: auto;
		max-width: 100%;
		height: 100%;
		object-fit: contain;
	}
	.splide-portfolio .splide__video__wrapper,
	.splide-case-study .splide__video__wrapper {
		display: block !important;
		background: transparent !important;
		position: relative;
	}
	.splide-portfolio .splide__slide[data-splide-html-video] .video-poster,
	.splide-case-study .splide__slide[data-splide-html-video] .video-poster {
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
		z-index: 0;
	}
	.splide-portfolio .splide__slide[data-splide-html-video] video,
	.splide-case-study .splide__slide[data-splide-html-video] video {
		position: relative;
		z-index: 1;
	}
	.modal-slide-image {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}
	@media (width <= 768px) {
		.modal {
			padding: 1rem 2rem 2rem;
		}
		.modal-close {
			margin-right: -1rem;
		}
		.splide-portfolio .splide__slide[data-splide-html-video],
		.splide-case-study .splide__slide[data-splide-html-video] {
			width: min(var(--video-slide-width, 280px), 100%);
		}
		/* ensure slide expands for vertical videos instead of forcing landscape feel */
		.splide-portfolio .splide__slide,
		.splide-case-study .splide__slide {
			max-width: 100%;
		}
		.modal-header {
			grid-template-columns: 1fr;
		}
	}
	/* --- Password Module --- */
	.post-password-required form {
		max-width: var(--max-w-text);
		margin-inline: auto;
		padding: 2rem;
		text-align: center;
		border: 1px solid oklch(var(--primary-base) / 0.1);
		border-radius: 2rem;
		box-shadow: var(--shadow);
	}
	.post-password-required:has(:focus-within) form {
		box-shadow: var(--shadow-hover);
	}
	.post-password-required label {
		font-size: 0;
	}
	.post-password-required label input {
		font-size: var(--fs-base);
	}
	.post-password-required p:has(label) {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 1rem;
	}
	.post-password-required :is(input, label) {
		width: 100%;
	}
	.post-password-required input[name="post_password"] {
		display: block !important;
		padding: 0.75rem 1.5rem !important;
		border-radius: 1rem !important;
		border: 1px solid oklch(var(--primary-base) / 0.2) !important;
		color: var(--black) !important;
		font-size: var(--fs-base) !important;
/* 		margin-inline-start: 1rem; */
	}
	.post-password-required input[name="post_password"]:focus-within {
		outline: 2px solid var(--secondary) !important;
		outline-offset: 3px !important;
	}
	.post-password-required input[type="submit"] {
		display: inline-block !important;
		background-color: var(--secondary) !important;
		padding: 0.75rem 1.5rem !important;
		border-radius: 1rem !important;
		border: 2px solid var(--secondary) !important;
		color: var(--white) !important;
		font-size: var(--fs-base) !important;
		font-weight: 400 !important;
		text-decoration: none !important;
		text-transform: lowercase !important;
		text-align: center !important;
		cursor: pointer !important;
	}
	.post-password-required input[type="submit"]:hover {
		background-color: var(--primary-hover) !important;
		border-color: var(--primary-hover) !important;
	}
}
/* === 7. Template-Specific Styles === */
/* --- Form --- */
.gform_fields {
	grid-row-gap: 1.25rem !important;
}
.gform_required_legend {
	text-align: right;
	font-size: var(--fs-sm);
	margin: 0;
}
.gfield .gform-field-label {
	font-size: calc(0.95 * var(--fs-base)) !important;
	color: var(--black) !important;
/* 	text-transform: lowercase !important; */
}
.gfield .gfield_required_asterisk {
	color: var(--secondary) !important;
}
.gfield :is(input, textarea) {
	border: 1px solid oklch(var(--primary-base) / 0.1) !important;
	box-shadow: none !important;
}
.gfield :is(input, textarea):focus {
	outline: 2px solid var(--secondary) !important;
	outline-offset: 3px !important;
}
.gfield label.gform-field-label--type-sub {
	font-size: var(--fs-sm) !important;
	margin-block: 0.25rem 0 !important;
}
.gform_button {
	display: inline-block !important;
	background-color: var(--secondary) !important;
	padding: 0.75rem 1.5rem !important;
	border-radius: 1rem !important;
	border: 2px solid var(--secondary) !important;
	color: var(--white) !important;
	font-size: var(--fs-base) !important;
	font-weight: 400 !important;
	text-decoration: none !important;
	text-transform: lowercase !important;
	text-align: center !important;
	cursor: pointer !important;
}
.gform_button:hover {
	background-color: var(--primary-hover) !important;
	border-color: var(--primary-hover) !important;
}
.gsection_title {
	margin-block: .5rem 0 !important;
	font-size: var(--fs-md) !important;
}
/* --- Header --- */
.site-header-wrapper {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: var(--white);
	transition: box-shadow var(--transition);
}
.site-header {
	padding-inline: var(--gutter);
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: var(--max-w-max);
	margin-inline: auto;
}
.home .site-header-wrapper {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background-color: transparent;
	z-index: 200;
}
.site-header-wrapper.is-locked {
	box-shadow: var(--shadow);
}
.home .site-header-wrapper.is-locked {
	background-color: var(--white);
}
.dark-mode .site-header-wrapper {
	background-color: var(--primary);
}
.main-navigation {
	justify-self: end;
}
.main-navigation .menu {
	display: flex;
	align-items: center;
	position: relative;
}
.main-navigation .menu > .menu-item:not(.btn-nav) > a {
	display: block;
	color: var(--white);
	text-decoration: none;
	padding: 1rem 2rem;
	text-transform: lowercase;
}
.main-navigation .menu > .menu-item.btn-nav {
	margin-inline-start: 1rem;
}
.main-navigation .menu > .menu-item.btn-nav > a {
	padding: 0.5rem 1rem;
}
.home .main-navigation .menu > .menu-item:not(.btn-nav) > a {
	color: var(--white);
}
body:not(.home):not(.dark-mode) .main-navigation .menu > .menu-item:not(.btn-nav) > a,
body:not(.dark-mode)
	.site-header-wrapper.is-locked
	.main-navigation
	.menu
	> .menu-item:not(.btn-nav)
	> a {
	color: var(--primary);
}
.main-navigation .menu > .menu-item:not(.btn-nav):hover > a,
.home .main-navigation .menu > .menu-item:not(.btn-nav):hover > a,
body.dark-mode .main-navigation .menu > .menu-item:not(.btn-nav):hover > a {
	color: var(--secondary) !important;
}
.main-navigation .menu-item:not(.btn-nav).current-menu-item > a,
.main-navigation .menu-item:not(.btn-nav).current-menu-ancestor > a {
	color: var(--secondary) !important;
}
.main-navigation .menu > .menu-item.has-submenu a {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.menu-caret {
	width: 1rem;
	height: 1rem;
	margin-inline-start: auto;
	flex-shrink: 0;
	fill: currentColor;
	transition: transform 0.2s ease;
}
.main-navigation .menu-item.has-submenu:hover .menu-caret {
	transform: rotate(180deg);
}
/* Current menu item icons and carets */
.main-navigation .menu-item:not(.btn-nav).current-menu-item .menu-icon,
.main-navigation .menu-item:not(.btn-nav).current-menu-ancestor .menu-icon,
.main-navigation .menu-item:not(.btn-nav).current-menu-item .menu-caret,
.main-navigation .menu-item:not(.btn-nav).current-menu-ancestor .menu-caret {
	fill: var(--secondary);
}
.sub-menu {
	display: grid;
	grid-template-columns: 1fr 1fr;
	position: absolute;
	width: calc(100% + 0.5rem);
	right: -0.5rem;
	padding: 1rem;
	margin-block-end: -0.5rem;
	border-radius: 1rem;
	gap: 1rem;
	background-color: var(--white);
	box-shadow: var(--shadow);
	border: 1px solid oklch(var(--primary-base) / 0.1);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform-origin: top left;
	transform: translateY(-6px) scale(0.98);
	will-change: transform, opacity;
	transition: transform 360ms cubic-bezier(0.22, 1, 0.36, 1),
		opacity 240ms cubic-bezier(0.22, 1, 0.36, 1), visibility 100ms linear;
}
.main-navigation .menu-item:has(.sub-menu):hover .sub-menu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0) scale(1);
}
.main-navigation .sub-menu a {
	display: flex;
	padding: 0.5rem 1rem;
	gap: 1rem;
	text-decoration: none;
	color: var(--primary);
	border-radius: 0.5rem;
	height: 100%;
}
.main-navigation .sub-menu .menu-item {
	position: relative;
}
.main-navigation .sub-menu .menu-item:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
.main-navigation .sub-menu a:hover {
	background-color: var(--bg-light);
}
.menu-icon {
	align-self: start;
	width: 1.25rem;
	height: 1.25rem;
	margin-block-start: 0.25rem;
	margin-inline-end: 0.25rem;
	fill: currentColor;
}
.main-navigation .menu-item.has-icon a {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}
.menu-content {
	display: flex;
	flex-direction: column;
	flex: 1;
	text-transform: lowercase;
}
.menu-description {
	display: block;
	font-size: var(--fs-sm);
	color: oklch(var(--black-base) / 0.8);
}
.menu-toggle {
	color: var(--white);
	background-color: transparent;
	border: none;
	padding: 0.5rem;
	border-radius: 0.25rem;
	cursor: pointer;
	transition: var(--transition);
	display: flex;
	align-items: center;
	justify-content: center;
}
.menu-toggle:hover {
	background-color: oklch(var(--white-base) / 0.1);
}
.menu-toggle svg {
	width: 24px;
	height: 24px;
	fill: currentColor;
}
/* Menu toggle color states */
body:not(.home):not(.dark-mode) .menu-toggle,
body:not(.dark-mode) .site-header-wrapper.is-locked .menu-toggle {
	color: var(--primary);
}
body:not(.home):not(.dark-mode) .menu-toggle:hover,
body:not(.dark-mode) .site-header-wrapper.is-locked .menu-toggle:hover {
	background-color: oklch(var(--primary-base) / 0.1);
}
@media (width <= 1024px) {
	.main-navigation {
		display: none;
	}
	.menu-toggle {
		display: flex;
	}
}
@media (width > 1024px) {
	.menu-toggle {
		display: none;
	}
}
/* --- Drawer --- */
.drawer {
	position: fixed;
	inset: 0;
	height: 100dvh;
	padding-block-start: 4.125rem;
	background-color: oklch(var(--primary-base));
	backdrop-filter: blur(4px);
	z-index: 90; /* behind header which is z-index: 100 */
	transform: translateY(-100%);
	transition: transform 300ms cubic-bezier(0.4, 0, 0.2, 1), visibility 300ms ease,
		opacity 300ms ease;
	overflow: hidden;
	visibility: hidden;
	opacity: 0;
}
.drawer.is-open {
	transform: translateY(0);
	visibility: visible;
	opacity: 1;
}
.drawer-wrapper {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 0 var(--gutter) 2rem;
}
.drawer-header {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-bottom: 2rem;
}
.drawer-navigation {
	flex: 1;
	overflow: hidden;
	position: relative;
}
.drawer-menu-container {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.drawer-menu {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 0;
	margin: 0;
	list-style: none;
	transition: transform 300ms cubic-bezier(0.4, 0, 0.2, 1);
}
.drawer .menu-item a {
	display: flex;
	align-items: center;
	font-size: var(--fs-lg);
	padding: 1.5rem 0;
	font-weight: 400;
	color: var(--white);
	text-decoration: none;
	text-transform: lowercase;
	border-bottom: 1px solid oklch(var(--white-base) / 0.1);
	transition: var(--transition);
}
.drawer .sub-menu {
	position: absolute;
	inset: 0;
	padding: 0;
	gap: 0;
	background-color: var(--primary);
	transform: translateX(100%);
	transition: transform 300ms cubic-bezier(0.4, 0, 0.2, 1);
	z-index: 10;
	display: flex;
	flex-direction: column;
	overflow-y: auto;
}
.drawer .sub-menu.is-open {
	transform: translateX(0);
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}
.drawer .sub-menu .menu-item a {
	font-size: var(--fs-md);
	padding: 1rem 0 1rem 1rem;
}
.drawer .sub-menu-back {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 1rem 0;
	color: var(--white);
	text-decoration: none;
	font-size: var(--fs-md);
	border-bottom: 1px solid oklch(var(--white-base) / 0.2);
	background-color: var(--primary);
	transition: var(--transition);
	position: sticky;
	top: 0;
}
.drawer .sub-menu-back::before {
	content: '←';
	font-size: var(--fs-md);
}
.drawer-footer {
	display: flex;
	flex-direction: column;
	padding-block-start: 2rem;
	border-top: 1px solid oklch(var(--white-base) / 0.1);
	gap: 1.5rem;
}
.drawer .search-form__field {
	background-color: oklch(var(--white-base) / 0.1);
	border: 2px solid var(--secondary);
	border-radius: 0.75rem;
	transition: var(--transition);
}
.drawer .search-form__field:focus-within {
	border-color: var(--secondary);
	box-shadow: 0 0 0 3px oklch(var(--secondary) / 0.1);
}
.drawer .search-form__input {
	color: var(--white);
	font-size: var(--fs-base);
}
.drawer .search-form__input::placeholder {
	color: var(--white);
	opacity: 0.7;
}
.drawer .search-form__submit {
	background-color: var(--secondary);
}
.drawer .search-form__submit:hover {
	background-color: var(--primary-hover);
}
.drawer .search-form__submit:focus {
	outline: 2px solid var(--white);
	outline-offset: -4px;
	border-radius: 0.5rem;
}
.drawer .menu-item.btn-nav {
	display: none;
}
/* === Content === */
.content .header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}
.content .header .title-container {
	grid-column: 1 / 2;
}
.content :is(h1, .eyebrow) {
	margin-block: 0 0.25rem;
}
.content .header .title-container .excerpt {
	margin-block: 1rem 0;
}
.content .header .description-container {
	margin-block-end: 0.625rem;
	grid-column: 2 / 3;
	place-self: end;
}
.content .article-wrapper {
	display: grid;
	grid-template-columns: 1fr 18rem;
	gap: 3rem;
	max-width: var(--max-w-article);
	margin-inline: auto;
}
.content .featured-image {
	margin-block-end: 3rem;
	aspect-ratio: 8 / 3;
	border-radius: 1rem;
	overflow: hidden;
}
.content .featured-image img {
	width: 100%;
	object-fit: cover;
	object-position: center;
}
.article-content {
	max-width: var(--max-w-text);
	margin-inline: auto;
}
.content .article-cta {
	margin-block-start: 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--gutter);
	background-color: var(--bg-light);
	padding: var(--gutter);
	border-radius: 1rem;
	margin-inline: -2rem;
}
.content .article-cta .article-cta-content {
	flex: 1 0 0%;
}
.content .article-cta .article-cta-content h2 {
	margin-block: 0 0.33em;
	font-size: var(--fs-md);
	color: var(--primary);
}
.content .article-cta .article-cta-content p {
	margin-block: 0;
	text-wrap: pretty;
}
.content .article-cta .btn {
	max-width: fit-content;
	flex: 1 0 auto;
	padding: 0.33rem 1rem;
	align-self: start;
}
.content .post-navigation-wrapper {
	margin-inline: auto;
	margin-block-start: 2rem;
	padding-block-start: 1.5rem;
	border-block-start: 1px solid oklch(var(--primary-base) / 0.1);
}
.content .post-navigation {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}
.content :is(.post-navigation-prev, .post-navigation-next) a {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--black);
	padding: 0.5rem 1rem;
	border-radius: 0.5rem;
	font-size: var(--fs-sm);
	text-decoration: none;
	text-transform: lowercase;
	width: fit-content;
}
.content :is(.post-navigation-prev, .post-navigation-next) a:hover {
	background-color: var(--bg-light);
	color: var(--primary);
}
.content .post-navigation-next {
	text-align: right;
}
/* === Article Sidebar === */
.content .article-sidebar {
	width: 18rem;
	position: sticky;
	top: 100px;
	height: fit-content;
	align-self: start;
	border-radius: 1rem;
}
/* Sidebar sections */
.content .article-sidebar .sidebar-section + .sidebar-section {
	margin-block-start: 1.5rem;
}
.content .article-sidebar .sidebar-section__title {
	font-size: var(--fs-base);
	margin-block: 0 1rem;
	color: var(--primary);
	text-transform: lowercase;
}
/* Sidebar lists */
.content .article-sidebar .sidebar-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.content .article-sidebar .sidebar-list--recent {
	display: grid;
	gap: 0.75rem;
}
.content .article-sidebar .sidebar-list--recent li {
	display: grid;
	gap: 0.125rem;
}
.content .article-sidebar .sidebar-list--recent a {
	text-decoration: none;
	color: var(--primary);
	text-transform: lowercase;
}
.content .article-sidebar .sidebar-recent__title {
	font-size: var(--fs-sm);
	line-height: 1.3;
	text-decoration: underline;
}
.content .article-sidebar .sidebar-recent__date {
	font-size: var(--fs-xs);
	color: oklch(var(--black-base) / 0.8);
	text-transform: lowercase;
}
/* Tag chips */
.content .article-sidebar .sidebar-list--tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.content .article-sidebar .tag-chip {
	display: inline-flex;
	align-items: center;
	padding: 0.25rem 0.75rem;
	border: 1px solid oklch(var(--primary-base) / 0.25);
	border-radius: 999px;
	background-color: var(--white);
	color: var(--primary);
	font-size: var(--fs-sm);
	line-height: 1.2;
	text-transform: lowercase;
}
/* Share section */
.content .article-sidebar .sidebar-share-list {
	display: flex;
	gap: 0.5rem;
	margin-block-start: 0.5rem;
	padding: 0;
	list-style: none;
}
.content .article-sidebar .share-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	padding: 0.5rem;
	border: 1px solid var(--secondary);
	border-radius: 9999px;
	color: var(--secondary);
	background-color: var(--white);
	text-decoration: none;
	transition: var(--transition);
}
.content .article-sidebar .share-link:hover {
	background-color: var(--bg-light);
}
/* === Post Content Styles === */
.content .article-content--post {
	margin-inline: auto;
}
.content .article-content--post .post-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-block-end: 2rem;
	padding-block-end: 1.5rem;
	border-bottom: 1px solid oklch(var(--primary-base) / 0.1);
}
.content .article-content--post :is(.post-date, .post-reading-time) {
	font-size: var(--fs-sm);
	color: oklch(var(--black-base) / 0.8);
	text-transform: lowercase;
}
.content .article-content--post :is(h2, h3, h4, h5, h6) {
	margin-block: 2rem 1rem;
	color: var(--primary);
}
.content .article-content--post h2 {
	font-size: var(--fs-lg);
}

.content .article-content--post h3 {
	font-size: var(--fs-md);
}
.content .article-content--post h4 {
	font-size: var(--fs-base);
}
.content .article-content--post p:last-child {
	margin-block-end: 0;
}
.content .article-content--post li {
	margin-block: 0.25rem;
}
.content .article-content--post blockquote {
	margin: 2rem 0;
	padding-inline-start: 1.5rem;
	border-left: 2px solid oklch(var(--primary-base) / 0.2);
	font-style: italic;
	color: oklch(var(--primary-base) / 0.8);
}
.content .article-content--post img {
	margin: 2rem 0;
	border-radius: 1rem;
}
/* === Responsive Design === */
@media (width <= 1024px) {
	.content .article-wrapper {
		gap: 2rem;
	}
	.content .article-sidebar {
		width: 16rem;
	}
}
@media (width <= 768px) {
	.content .featured-image {
		margin-block-end: 2rem;
	}
	.content .article-cta {
		flex-direction: column;
		align-items: start;
		gap: 1rem;
		margin-inline: 0;
	}
	.content .header {
		grid-template-columns: 1fr;
	}
	.content .header .title-container,
	.content .header .description-container {
		grid-column: 1;
	}
	.content .header .description-container {
		place-self: start;
	}
	.content .article-wrapper {
		grid-template-columns: 1fr;
	}
	.content .article-sidebar {
		width: 100%;
		background-color: var(--bg-light);
		padding: 2rem;
	}
}
/* --- Kadence Blocks --- */
.kt-accordion-wrap .kt-accordion-pane:first-of-type .kt-blocks-accordion-header {
	border-top: 0 !important;
	font-weight: 500;
}
.kt-accordion-wrap .kt-accordion-panel p {
	margin-block-start: 0;
	font-weight: 300;
}
/* --- Footer --- */
.site-footer {
	--color-logo-primary: var(--white);
	--color-logo-secondary: var(--white);
	background-color: var(--primary);
	color: var(--white);
	padding: 6rem var(--gutter) 3rem;
}
.site-footer .site-logo {
	display: flex;
	padding-block: 0;
}
.site-footer .site-logo svg {
	--color-logo-primary: var(--white);
	--color-logo-secondary: var(--white);
	width: 320px;
	height: 67px;
}
.site-footer p {
	margin: 0;
}
.site-footer a {
	color: var(--white);
	text-decoration: none;
}
.site-footer a:not(.btn):hover {
	color: var(--secondary);
}
.site-info {
	display: flex;
	flex-direction: column;
	gap: 3rem;
	max-width: var(--max-w-content);
	margin-inline: auto;
}
.footer-grid {
	display: grid;
	grid-template-columns: 2fr 2fr 3fr;
	gap: 2rem;
	align-items: start;
	padding-block-end: 3rem;
}
.footer-information {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.footer-socials {
	display: flex;
	align-items: center;
	gap: 1rem;
}
.footer-socials a {
	display: flex;
	align-items: center;
}
.footer-socials a svg {
	color: var(--white);
}
.footer-socials a:hover svg {
	color: var(--secondary);
}
.footer-navigation ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	text-transform: lowercase;
}
.footer-newsletter {
	display: flex;
	flex-direction: column;
	align-items: start;
	justify-content: center;
	gap: 1rem;
}
.footer-newsletter h3 {
	color: var(--white);
	font-size: var(--fs-md);
	margin: 0;
}
.footer-newsletter p {
	font-weight: 200;
	margin: 0;
}
.footer-newsletter .footer-buttons {
	display: flex;
	align-items: center;
	gap: 1rem;
}
.footer-newsletter .btn {
	padding: 0.5rem 1rem;
}
.footer-information p {
	margin: 0;
}
.footer-copyright {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: var(--max-w-content);
	margin-inline: auto;
	padding-block-start: 3rem;
	border-top: 2px solid oklch(var(--white-base) / 20%);
	text-transform: lowercase;
	font-weight: 200;
}
.footer-copyright p {
	margin: 0;
	font-weight: 200;
}
@media (width <= 1024px) {
	.footer-grid {
		grid-template-columns: 1fr 1fr;
		row-gap: 4rem;
	}
	.footer-newsletter {
		grid-column: 1 / -1;
	}
}
/* --- Search Form --- */
.search-form {
	position: relative;
	max-width: 100%;
}
.search-form__field {
	position: relative;
	display: flex;
	align-items: center;
	background-color: oklch(var(--white-base));
	border: 2px solid var(--black);
	border-radius: 0.5rem;
	overflow: hidden;
	transition: var(--transition);
}
.search-form__field:focus-within {
	border-color: var(--primary);
	box-shadow: 0 0 0 3px oklch(var(--primary) / 0.1);
}
.search-form__input {
	flex: 1;
	padding: 0.75rem 1rem;
	border: none;
	background: transparent;
	font-size: var(--fs-base);
	color: var(--black);
	outline: none;
}
.search-form__input::placeholder {
	color: var(--black);
	opacity: 0.7;
}
.search-form__submit {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem;
	border: none;
	background-color: var(--primary);
	color: oklch(var(--white-base));
	cursor: pointer;
	transition: var(--transition);
	min-width: 3rem;
}
.search-form__submit:hover {
	background-color: color-mix(in oklch, var(--primary) 85%, black 15%);
}
.search-form__submit:focus {
	outline: 2px solid oklch(var(--white-base));
	outline-offset: -2px;
}
.search-form__icon {
	width: 1.5rem;
	height: 1.5rem;
	fill: currentColor;
}
.search-form-wrapper {
	margin-bottom: 2rem;
	padding: 0 var(--gutter);
}
.search-results {
	display: grid;
	gap: 1.5rem;
	padding: 0 var(--gutter);
}
.search-results .main-article-content {
	padding: 1.5rem;
	background-color: oklch(var(--white-base));
	border: 1px solid var(--black);
	border-radius: 0.5rem;
	border: 1px solid oklch(var(--primary-base) / 0.1);
	box-shadow: var(--shadow);
	transition: var(--transition);
}
.search-results .main-article-content:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-2px);
}
.search-results .entry-summary {
	color: var(--black);
	line-height: 1.6;
}
.search-results .entry-summary p {
	margin: 0 0 1rem 0;
}
.search-results .entry-summary p:last-child {
	margin-bottom: 0;
}
/* --- 404 Error Page --- */
.error-page {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6rem var(--gutter) 4rem;
	text-align: center;
}
.error-content {
	max-width: var(--max-w-text);
	width: 100%;
}
.error-message {
	margin-bottom: 2rem;
}
.error-message__text {
	font-size: var(--fs-lg);
	color: var(--black);
	line-height: 1.6;
	margin: 0;
}
.error-actions {
	margin-bottom: 3rem;
}
.error-actions__list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	align-items: center;
	margin: 0;
	padding: 0;
	list-style: none;
}
.error-actions__item {
	width: 100%;
	max-width: 200px;
}
@media (width > 1024px) {
	.error-actions__list {
		flex-direction: row;
		justify-content: center;
	}
	.error-actions__item {
		width: auto;
	}
}
.error-search {
	margin-bottom: 2rem;
	padding: 2rem;
	background-color: var(--primary);
	border-radius: 1rem;
}
.error-search__title {
	font-size: var(--fs-md);
	color: var(--white);
	margin: 0 0 1rem 0;
	font-weight: 400;
}
.error-search .search-form {
	max-width: 25rem;
	margin-inline: auto;
}
.error-help__text {
	font-size: var(--fs-sm);
	color: var(--black);
	margin: 0;
	line-height: 1.5;
}
/* === 8. Project-Specific Styles === */
/* --- Homepage --- */
.home :is(h2), .home :is(h1) {
	text-align: center;
}
.home .modal h2 {
	text-align: left;
}
/* --- Hero Video Section --- */
.hero {
	position: relative;
	width: 100%;
	aspect-ratio: 2/1;
	/*border-radius: 0 0 1rem 1rem;*/
	overflow: hidden;
	z-index: 1;
	max-height: 85vb;
}
.hero__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
@media (width <= 768px) {
	.hero {
		aspect-ratio: 16/9;
		min-height: 25rem;
	}
}
@media (width <= 480px) {
	.hero {
		aspect-ratio: 4/3;
	}
}
@media (prefers-reduced-motion: reduce) {
	.hero__video {
		animation: none;
	}
}
/* --- Intro --- */
.intro-text {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	text-align: center;
}
.intro-text h2 {
	margin-block: 0;
	letter-spacing: 0.01em;
	line-height: 1.2;
	font-size: var(--fs-2xl);
}
.intro-text p {
	line-height: 1.7;
	max-width: 70ch;
}
.intro-buttons {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
}
@media (width <= 400px) {
	.intro-buttons {
		flex-direction: column;
	}
}
/* --- Industries and Brands --- */
.industries-brands.logo-cloud {
	--grid-columns: 20;
	grid-template-areas:
		'coloplast coloplast coloplast coloplast leidos leidos leidos leidos il-sec il-sec il-sec il-sec il-sec il-sec ppd ppd cat cat cat cat'
		'green green green green green kcuc kcuc kcuc kcuc kcuc hbt hbt hbt hbt hbt ilcc ilcc ilcc ilcc ilcc'
		'uiuc uiuc uiuc uiuc corteva corteva corteva corteva pia pia pia pia tlu tlu tlu tlu akkerman akkerman akkerman akkerman';
	row-gap: 3rem;
	column-gap: 1rem;
}
.industries-brands.logo-cloud img {
	max-height: 100px;
	max-width: 400px;
}
@media (768px < width <= 925px) {
	.industries-brands.logo-cloud img {
		max-width: 150px;
	}
}
@media (width <= 768px) {
	.industries-brands.logo-cloud {
		--grid-columns: 2;
		grid-template-areas:
			'coloplast leidos'
			'il-sec green'
			'ppd hbt'
			'ilcc uiuc'
			'pia corteva'
			'tlu akkerman'
			'cat kcuc';
	}
	.industries-brands.logo-cloud img {
		height: auto;
		max-width: 200px;
	}
}
@media (width <= 480px) {
	.industries-brands.logo-cloud img {
		max-width: 120px;
	}
}
/* === Case Studies === */
.splide-case-studies {
	position: relative;
}
.splide-case-studies .splide__arrows {
	justify-content: start;
	position: absolute;
	left: 50%;
	bottom: 5%;
	padding-inline-start: 2rem;
}
.splide-case-studies .splide__arrow:hover {
	background-color: var(--bg-light);
}
.splide-case-studies .carousel-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
}
.splide-case-studies .carousel-grid img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	border-radius: 1rem;
	aspect-ratio: 3 / 2;
}
.splide-case-studies .carousel-grid-content {
	position: relative;
	display: flex;
	align-items: start;
	flex-direction: column;
	top: 10%;
}
.splide-case-studies .carousel-grid-content h3 {
	font-size: var(--fs-xl);
}
@media (width <= 1024px) {
	.splide-case-studies .carousel-grid-content h3 {
		font-size: var(--fs-lg);
	}
}
@media (width <= 768px) {
	.splide-case-studies .carousel-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.splide-case-studies .carousel-grid-content {
		top: 0;
		padding-inline: 1rem;
	}
	.splide-case-studies .splide__arrows {
		position: relative;
		left: 0;
		bottom: 0;
		padding-inline-start: 1rem;
		padding-block-start: 2rem;
	}
}
/* === Services === */
.services {
	overflow: clip;
}
.splide-services .splide__track {
	overflow: visible;
}
.splide-services .carousel-item {
	padding: 2rem;
	background-color: var(--white);
	border-radius: 1rem;
	box-shadow: var(--shadow);
	border: 1px solid oklch(var(--primary-base) / 0.1);
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	transition: var(--transition);
}
.splide-services .carousel-item:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-6px);
}
.splide-services .carousel-item-content {
	flex: 1 1 auto;
}
.splide-services h3 {
	font-size: var(--fs-lg);
	margin-block: 0 0.33em;
}
.splide-services .description {
	font-size: var(--fs-md);
	font-weight: 200;
	margin-block: 0;
	color: var(--black);
	max-width: 80%;
	text-wrap: pretty;
}
.splide-services .learn-more {
	margin-block: 3rem 0;
	color: var(--secondary);
}
.splide-services .image-wrapper {
	--team-color: var(--primary);
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--team-color);
	height: 5rem;
	width: 5rem;
	border-radius: 9999px;
	padding: 1.25rem;
	position: absolute;
	bottom: 1.5rem;
	right: 1.5rem;
}
.splide-services .image-wrapper svg {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	color: var(--white);
}
.splide-services .splide__arrows {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	margin-block-start: 3rem;
}
.splide-services .splide__arrow {
	background-color: var(--bg-light);
}
.splide-services .splide__arrow:hover {
	background-color: color-mix(in oklch, var(--bg-light) 95%, var(--primary) 5%);
}
.splide-services .splide__arrow:hover:disabled {
	background-color: transparent;
}
/* === Our Work --- */
.portfolio-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 2rem;
	width: 100%;
	margin-block-end: 4rem;
	padding-block-start: 1rem;
}
.portfolio-card {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr;
	gap: 1rem;
	border-radius: 1rem;
	overflow: hidden;
	width: 100%;
	text-decoration: none;
	box-shadow: var(--shadow-dark);
	transition: var(--transition);
}
.portfolio-card:hover {
	box-shadow: var(--shadow-dark-hover);
	transform: translateY(-6px);
}
.portfolio-card > * {
	grid-column: 1 / -1;
	grid-row: 1 / -1;
	width: 100%;
}
.portfolio-card-content {
	place-self: end center;
	padding: 1rem 1rem 2rem;
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.portfolio-card-content h3 {
	margin: 0;
	color: var(--white);
	font-size: var(--fs-md);
}
.portfolio-card-content p {
	margin: 0;
	color: var(--white);
	font-size: var(--fs-sm);
	text-transform: lowercase;
}
@media (width <= 1024px) {
	.portfolio-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (width <= 768px) {
	.portfolio-grid {
		grid-template-columns: 1fr;
	}
}
/* === Relationships === */
.relationships h2 {
	max-width: 28ch;
	text-align: center;
}
.relationships .logo-cloud {
	--grid-columns: 20;
	grid-template-areas:
		'google google google google google meta meta meta meta meta tiktok tiktok tiktok tiktok tiktok linkedin linkedin linkedin linkedin linkedin'
		'spotify spotify spotify spotify instagram instagram instagram instagram reddit reddit reddit reddit snapchat snapchat snapchat snapchat pinterest pinterest pinterest pinterest';
}
.relationships .logo-cloud img {
	max-height: 75px;
	max-width: 120px;
	aspect-ratio: 16 / 9;
}
@media (width <= 768px) {
	.relationships .logo-cloud {
		--grid-columns: 2;
		grid-template-areas:
			'google meta'
			'tiktok linkedin'
			'spotify instagram'
			'snapchat reddit'
			'pinterest pinterest';
	}
}
/* === News === */
.content-news h2 {
	font-size: var(--fs-lg);
	margin-block-end: 1em;
}
.news-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 2rem;
	margin-block-start: 1rem;
}
.news-card {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	border-radius: 1rem;
	text-decoration: none;
	text-align: center;
	transition: var(--transition);
	background-color: var(--white);
	box-shadow: var(--shadow);
	border: 1px solid oklch(var(--primary-base) / 0.1);
}
.news-card:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-6px);
}
.news-card img {
	width: 100%;
	object-fit: cover;
	object-position: center;
	aspect-ratio: 16 / 9;
	border-radius: 1rem 1rem 0 0;
	transition: var(--transition);
}
.news-card-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1rem 1rem 2rem;
	height: 100%;
}
.news-card-date {
	margin: 0;
	padding-block: 0 1em;
	font-size: var(--fs-sm);
	color: oklch(var(--primary-base) / 0.5);
}
.news-card-content h3 {
	flex: 1 1 auto;
	font-size: var(--fs-md);
	line-height: 1.2;
	margin-block: 0;
	padding-block: 0 1em;
}
.news-card-excerpt {
	color: var(--black);
	font-size: var(--fs-base);
	margin-block: 0;
	padding-block: 0 1em;
}
.read-more {
	margin: 0;
	color: var(--secondary);
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.news-list {
	list-style: none;
	padding: 0;
	margin: 2rem 0 0 0;
	display: grid;
	gap: 0.5rem;
}
.news-list-row {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: 1rem;
	align-items: center;
	padding: 0.5rem 0.75rem;
	border-radius: 0.5rem;
	background-color: var(--white);
	box-shadow: var(--shadow);
	border: 1px solid oklch(var(--primary-base) / 0.1);
	transition: var(--transition);
}
.news-list-row:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-2px);
}
.news-list-date {
	font-size: var(--fs-sm);
	color: oklch(var(--primary-base) / 0.6);
}
.news-list-link {
	color: var(--black);
	text-decoration: none;
	font-size: var(--fs-md);
}
.news-list-link:hover {
	text-decoration: underline;
}
.news-feed {
	display: grid;
	gap: 1rem;
}
.news-feed-list {
	display: contents;
}
.news-feed-item {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 2rem;
	align-items: start;
	justify-content: center;
	text-decoration: none;
	background: var(--white);
	border-radius: 0.75rem;
	box-shadow: var(--shadow);
	border: 1px solid oklch(var(--primary-base) / 0.1);
	padding: 0.75rem 1rem;
	transition: var(--transition);
}
.news-feed-item:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-2px);
}
.news-feed-content {
	padding-block: 1rem;
}
.news-feed-thumb img {
	max-width: 16rem;
	aspect-ratio: 16/9;
	object-fit: cover;
	border-radius: 0.5rem;
}
.news-feed-excerpt {
	margin: 0;
	color: var(--black);
}
.news-feed-title {
	margin-block: 0 0.25em;
	font-size: var(--fs-md);
}
.news-feed-date {
	color: oklch(var(--primary-base) / 0.6);
	font-size: var(--fs-sm);
}
.news-feed-item .read-more {
	grid-column: 3;
	align-self: center;
	margin: 0;
}
@media (width > 1024px) {
	.news-card--latest {
		flex-direction: row;
		text-align: start;
	}
	.news-card--latest h3 {
		font-size: var(--fs-lg);
		padding-block: 0 0.5em;
	}
	.news-card--latest .news-card-content {
		align-items: start;
		align-self: center;
	}
	.news-card--latest img {
		max-width: 60%;
		border-radius: 1rem 0 0 1rem;
	}
}
@media (width <= 1024px) {
	.news-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
	.news-feed-item .read-more {
		display: none;
	}
}
@media (width <= 768px) {
	.news-grid {
		grid-template-columns: 1fr;
	}
	.news-feed-item {
		grid-template-columns: 1fr;
	}
	.news-feed-thumb {
		display: none;
	}

	.news-feed-item .read-more {
		grid-column: 1;
		grid-row: 2;
		margin-block-end: 0;
		color: var(--secondary);
		display: flex;
		align-items: center;
		justify-content: start;
		gap: 0.5rem;
	}
	.news-hero-grid {
		grid-template-columns: 1fr;
	}
	.news-card-grid {
		grid-template-columns: 1fr;
	}
}
/* === Services Page Styles === */
.service-section:not(:last-of-type) {
	margin-block-end: 5rem;
}
.service-section:not(:first-of-type) {
	margin-block-start: 5rem;
}
hr.service-divider {
	margin-block: 6rem;
}
.service-header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	align-items: start;
	margin-block-end: 2rem;
}
.service-title {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	margin-bottom: 1rem;
}
.service-icon {
	width: 5rem;
	height: 5rem;
	background-color: var(--team-color);
	border-radius: 50%;
	padding: 1.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--white);
}
.service-title h2 {
	margin: 0;
}
.service-description p {
	margin-block: 0;
}
.micro-services-list {
	list-style: none;
	padding: 0;
	margin-block: 1rem;
	column-count: 2;
	column-gap: 2rem;
}
.micro-services-list .service-item {
	position: relative;
	padding-inline-start: 1.5rem;
	color: var(--black);
	break-inside: avoid;
}
@media (width <= 1024px) {
	.micro-services-list {
		column-count: 1;
	}
}
.micro-services-list .service-item::before {
	content: '+';
	position: absolute;
	inset-inline-start: 0;
	color: var(--black);
	font-weight: bold;
}
.learn-more-link {
	color: var(--secondary);
	text-decoration: none;
	text-transform: lowercase;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	border-radius: 0.5rem;
	margin-inline-start: -1rem;
}
.learn-more-link svg {
	width: 1rem;
	height: 1rem;
	fill: currentColor;
}
.learn-more-link:hover {
	background-color: var(--bg-light);
}
.service-images {
	display: grid;
	grid-template-columns: 3fr 2fr;
	gap: 2rem;
	align-items: stretch;
}
.service-section:nth-of-type(2n) .service-images {
	grid-template-columns: 2fr 3fr;
}
.service-section:nth-of-type(2n) .service-image.large {
	order: 2;
}
.service-section:nth-of-type(2n) .service-image.small {
	order: 1;
}
.service-image {
	position: relative;
	overflow: hidden;
	border-radius: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
.service-image :is(img, video) {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (width <= 768px) {
	.service-header {
		grid-template-columns: 1fr;
	}
	.service-content {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.service-images {
		gap: 1rem;
	}
	.services-columns {
		grid-template-columns: 1fr;
	}
	.services-title h2 {
		font-size: 1.5rem;
	}
}
/* === Development Page === */
.service-single .intro-section {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 2rem;
	align-items: center;
	justify-content: center;
	margin-block-end: 4rem;
}
.service-single h2 {
	font-size: var(--fs-xl);
}
.service-single .intro-section-image {
	display: flex;
	align-items: center;
	justify-content: center;
}
.service-single .offerings {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: center;
	justify-content: center;
}
.service-single .offerings-image {
	border-radius: 1rem;
	overflow: hidden;
}
.service-single .offerings-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.service-single .process, .service-single .features {
	background-color: var(--bg-light);
}
.service-single .process :is(h2, .eyebrow) {
	text-align: center;
}
@media (width <= 768px) {
	.service-single .intro-section {
		grid-template-columns: 1fr;
	}
	.service-single .offerings {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.service-single .offerings-image {
		order: 2;
	}
}
/* Process Cards Styles */
.process-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	margin-top: 4rem;
}
.process-card-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--secondary);
	font-size: var(--fs-xl);
	font-weight: 600;
	margin-block-end: 0.5rem;
}
@media (width <= 768px) {
	.process-cards {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
}
/* Features Grid Styles */
.features :is(h2, .eyebrow) {
	text-align: center;
}
.features-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 3rem;
}
.features-grid :is(h2, .eyebrow) {
	text-align: center;
}

/* Responsive adjustments for features */
@media (max-width: 768px) {
	.features-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.card {
		padding: 1.5rem;
	}

	.card--icon {
		width: 2rem;
		height: 2rem;
		margin-bottom: 1rem;
	}
}

.mockups {
	background-color: var(--primary);
	overflow: clip;
}
.mockups :is(h2, .eyebrow) {
	text-align: center;
}
.mockups h2 {
	color: var(--white);
	margin-block-end: 4rem;
}
.mockup-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 2rem;
}
.mockup-tabs-nav {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
	grid-column: 2 / 6;
	padding-block: 2rem;
}
.mockup-tabs-nav input[type='radio'] {
	display: none;
}
.mockup-tab-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	background-color: transparent;
	border-radius: 1rem;
	cursor: pointer;
	transition: var(--transition);
	white-space: nowrap;
	aspect-ratio: 16 / 9;
}
.mockup-tabs-nav input[type='radio']:hover + .mockup-tab-label {
	background-color: color-mix(in oklch, var(--primary) 94%, black 6%);
}
.mockup-tabs-nav input[type='radio']:checked + .mockup-tab-label {
	background-color: color-mix(in oklch, var(--primary) 94%, black 6%);
}

.mockup-tab-logo {
	max-width: 120px;
	max-height: 75px;
	object-fit: contain;
	transition: var(--transition);
	filter: grayscale(100%) opacity(0.6);
}

.mockup-tab-label:hover .mockup-tab-logo {
	filter: grayscale(50%) opacity(1);
}

.mockup-tabs-nav input[type='radio']:checked + .mockup-tab-label .mockup-tab-logo {
	filter: grayscale(0%) opacity(1);
}

.mockup-tabs-content {
	position: relative;
	grid-column: 6 / -1;
}

.mockup-tab-panel {
	display: none;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.mockup-tab-panel.active {
	display: grid;
	opacity: 1;
	transform: translateY(0);
}
.mockup-tab-panel.active:hover {
	box-shadow: var(--shadow-dark-hover);
	transform: translateY(-6px);
}

.mockup-tab-image {
	width: 100%;
	min-width: 75rem;
	height: auto;
	border-radius: 1rem;
	box-shadow: var(--shadow-dark);
}
@media (width <= 1440px) {
	.mockup-tabs-nav {
		grid-column: 1 / 6;
	}
	.mockup-tab-label {
		aspect-ratio: 2 / 1;
		padding: 0;
	}
	.mockup-tab-image {
		min-width: 62.5rem;
	}
}
@media (width <= 1024px) {
	.mockups h2 {
		margin-block-end: 2rem;
	}
	.mockup-grid {
		grid-template-rows: 1fr auto;
	}
	.mockup-tabs-nav {
		display: flex;
		gap: 1rem;
		padding-block: 0;
		overflow-x: scroll;
		grid-column: 1 / -1;
		mask-image: linear-gradient(to right, transparent 0, var(--primary) 5%, var(--primary) 95%, transparent 100%);
		-webkit-mask-image: linear-gradient(
			to right,
			transparent 0,
			var(--primary) 5%,
			var(--primary) 95%,
			transparent 100%
		);
	}
	.mockup-tab-label {
		aspect-ratio: 1;
		padding: 0.5rem;
		min-width: 8rem;
	}
	.mockup-tabs-content {
		grid-column: 1 / -1;
		grid-row: 2 / -1;
	}
	.mockup-tab-image {
		min-width: unset;
	}
}
/* === Production: Video Showcase === */
.video-showcase {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: clamp(10rem, 12vw, 14rem) minmax(0, 1fr) clamp(10rem, 12vw, 14rem);
	align-items: stretch;
	gap: 1.5rem;
}
.video-frame {
	grid-column: 2 / 3;
	position: relative;
	border-radius: 1rem;
	padding: 0.75rem; /* bezel padding */
	background: linear-gradient(
			180deg,
			color-mix(in oklch, var(--black) 8%, transparent 92%),
			transparent
		),
		color-mix(in oklch, var(--primary) 92%, black 8%);
	box-shadow: 0 16px 40px var(--shadow-color-dark), 0 0 0 1px var(--shadow-color-dark),
		inset 0 0 0 1px var(--shadow-color-dark-hover);
}
.video-element {
	width: 100%;
	aspect-ratio: 16/9;
	display: block;
	border-radius: 0.75rem;
	background: black;
}
.video-bezel {
	pointer-events: none;
	position: absolute;
	inset: 0;
	border-radius: 1rem;
	box-shadow: inset 0 0 0 1px oklch(var(--black-base) / 0.25),
		inset 0 40px 80px oklch(var(--black-base) / 0.35);
}
/* Filmstrip playlist container with perforation effect */
/* Browse overlay controls */
.video-controls {
	display: flex;
	justify-content: end;
	gap: 0.5rem;
}

/* Video browser overlay (reuses modal base) */
[data-video-browser] .modal {
	padding: 2rem;
}

.video-browser-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1rem;
}
.video-browser-item {
	appearance: none;
	border: 1px solid oklch(var(--white-base) / 0.1);
	background: oklch(var(--white-base) / 0.02);
	border-radius: 0.75rem;
	padding: 0;
	text-align: left;
	cursor: pointer;
	transition: var(--transition);
}
.video-browser-item:hover {
	background: oklch(var(--white-base) / 0.04);
	box-shadow: 0 4px 16px oklch(var(--black-base) / 0.2);
}
.video-browser-item img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 0.75rem 0.75rem 0 0;
}
.video-browser-item .video-title {
	display: block;
	padding: 0.75rem 1rem 1rem;
	font-size: var(--fs-sm);
	color: var(--black);
}

/* Left/Right vertical rails */
.video-rail {
	grid-column: span 1;
	display: grid;
	align-content: start;
	gap: 0.75rem;
	height: 100%;
	overflow-y: auto;
}
.video-rail-item {
	appearance: none;
	display: block;
	border: 1px solid oklch(var(--white-base) / 0.08);
	background: oklch(var(--white-base) / 0.02);
	border-radius: 0.75rem;
	padding: 0;
	cursor: pointer;
	transition: var(--transition);
}
.video-rail-item:hover {
	background: oklch(var(--white-base) / 0.05);
	box-shadow: 0 2px 12px oklch(var(--black-base) / 0.18);
}
.video-rail-item.is-active {
	outline: 2px solid var(--secondary);
	outline-offset: -2px;
}
.video-rail-item img {
	display: block;
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	border-radius: 0.75rem;
}

/* Combined rail for mobile */
.video-rail-combined {
	display: none;
}

@media (width <= 1024px) {
	.video-showcase {
		grid-template-columns: 1fr;
	}
	.video-frame {
		grid-column: 1 / -1;
	}
	.video-rail {
		display: none;
	}
	.video-rail-combined {
		display: flex;
		gap: 0.75rem;
		overflow-x: auto;
		grid-column: 1 / -1;
		margin-block-end: 0.5rem;
		/* Edge fade mask to hint scroll */
		-webkit-mask-image: linear-gradient(
			to right,
			transparent 0,
			black 32px,
			black calc(100% - 32px),
			transparent 100%
		);
		mask-image: linear-gradient(
			to right,
			transparent 0,
			black 32px,
			black calc(100% - 32px),
			transparent 100%
		);
		-webkit-mask-size: 100% 100%;
		mask-size: 100% 100%;
	}
	.video-rail-item {
		min-width: 240px;
	}
}
/* === Creative Page === */
.service-creative .mockup-item {
	grid-column: span 4;
	border-radius: 1rem;
	overflow: hidden;
}
.service-creative .mockup-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (width <= 1024px) {
	.service-creative .mockup-item {
		grid-column: span 3;
	}
}
@media (width <= 768px) {
	.service-creative .mockup-item {
		grid-column: span 6;
	}
}
@media (width <= 480px) {
	.service-creative .mockup-item {
		grid-column: span 12;
	}
}
/* === About Page === */
.page-about :is(.intro-section, .story-section, .philosophy-section) {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	align-items: center;
	justify-content: center;
	margin-block-end: 6rem;
}
.page-about :is(.intro-section-image, .story-section-image, .philosophy-section-image) {
	display: flex;
	align-items: center;
	justify-content: center;
	/* aspect-ratio: 4 / 3; */
	overflow: hidden;
	border-radius: 1rem;
}
.page-about :is(.intro-section-image, .story-section-image, .philosophy-section-image) img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.values :is(h2, .eyebrow) {
	text-align: center;
}
.values-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
	gap: 2rem;
}
.values-grid h3 {
	font-size: var(--fs-md);
}
@media (width <= 768px) {
	.values-grid {
		grid-template-columns: 1fr;
	}
}
.pm-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	margin-block: 8rem 2rem;
}
.pm-card {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	background-color: var(--strategy);
	border-radius: 1rem;
	text-decoration: none;
	box-shadow: var(--shadow);
	transition: var(--transition);
}
.pm-card-image {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-block-start: -6rem;
	grid-area: 1 / 1 / 2 / 2;
	transition: var(--transition);
	overflow-block: clip;
}
.pm-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: drop-shadow(0 0 4px oklch(var(--strategy-base) / 0.6));
	transform: translateY(6px);
}
.pm-card-content {
	color: var(--white);
	padding: 1rem;
	grid-area: 1 / 1 / 2 / 2;
	place-self: end center;
	text-align: center;
	background: linear-gradient(to bottom, transparent 0%, var(--strategy) 70%);
	width: 100%;
	z-index: 10;
	overflow-block: clip;
	border-radius: 0 0 1rem 1rem;
}
.pm-card h3 {
	font-size: var(--fs-md);
	color: var(--white);
	margin: 0;
}
.pm-card p {
	margin: 0;
	font-size: var(--fs-sm);
	text-transform: lowercase;
}
.pm-card:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-6px);
}
.pm-card:hover .pm-card-image {
	transform: translateY(-6px);
}
.team {
	background-color: var(--bg-light);
}
.team :is(h2, .eyebrow) {
	text-align: center;
}
.team-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 2rem;
}
.team-grid .card:where(:nth-of-type(1), :nth-of-type(2)) {
	grid-column: span 3;
}
.team-grid .card:where(:nth-of-type(3), :nth-of-type(4), :nth-of-type(5)) {
	grid-column: span 2;
}
.team-list {
	list-style: none;
	padding: 2rem;
	margin: 0;
	text-align: center;
}
.team-list li {
	break-inside: avoid;
	margin: 0 0 0.25rem 0;
}
.team-list:has(li:nth-of-type(6)) {
	column-count: 2;
	column-gap: 1rem;
}
.team .card {
	padding: 0;
	position: relative;
	overflow: hidden;
}
.team .card h3 {
	--team-color: var(--secondary);
	background-color: var(--team-color);
	color: var(--white);
	padding: 0.5rem;
	text-align: center;
	border-radius: 0.5rem 0.5rem 0 0;
	margin: 0;
}
.team .card .team-icon {
	position: absolute;
	right: 0;
	bottom: 0;
	opacity: 0.04;
	pointer-events: none;
	z-index: 0;
	transform: translate(20%, 20%);
}
.team .card .team-icon svg {
	width: 100%;
	height: 100%;
}
.team .card :is(h3, .team-list) {
	position: relative;
	z-index: 1;
}
/* === Certs === */
.page-about .certs :is(h2, .eyebrow) {
	text-align: center;
}
.recognition-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 2rem;
}
.recognition-group {
	border: 1px solid oklch(var(--primary-base) / 0.1);
	border-radius: 1rem;
	padding: 2rem;
}
.recognition-group h3 {
	text-align: center;
	color: var(--black);
	margin-block: 0 2rem;
	font-weight: 300;
}
.recognition-group .logo-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 2rem;
	align-items: center;
	justify-items: center;
}
.recognition-group .logo-wrapper {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	width: 100%;
	height: 100%;
}
.recognition-group .logo-wrapper img {
	height: 100%;
	width: 100%;
	max-width: 14rem;
	aspect-ratio: 2/1;
	object-fit: contain;
}
.recognition-group:not(:has(.logo-wrapper:nth-of-type(4))) .logo-grid .logo-wrapper:last-of-type {
	grid-column: span 2;
}
@media (width <= 1024px) {
	.pm-grid {
		grid-template-columns: repeat(2, 1fr);
		row-gap: 8rem;
	}
	.team-grid > .card {
		grid-column: span 3;
	}
	.recognition-group .logo-grid {
		gap: 1rem;
	}
}
@media (width <= 768px) {
	.page-about :is(.intro-section, .story-section, .philosophy-section) {
		grid-template-columns: 1fr;
	}
	.page-about .story-section-image {
		order: 2;
	}
	.team-grid > .card {
		grid-column: span 6;
	}
	.recognition-grid {
		grid-template-columns: 1fr;
	}
	.recognition-group {
		padding: 1rem;
	}
	.recognition-group .logo-wrapper img {
		max-width: 8rem;
	}
}
@media (width <= 480px) {
	.pm-grid {
		row-gap: 2rem;
		margin-block-start: 0;
	}
	.pm-grid > .pm-card {
		grid-column: span 6;
	}
	.pm-grid .pm-card-image {
		margin-block-start: 0;
	}
	.team-grid .card .team-list {
		column-count: 1;
	}
}

/* === Case Study & Portfolio Pages === */
.splide-case-study,
.content-portfolio .splide-portfolio {
	margin-block: 6rem;
}
.case-studies.main-article-content {
	margin-block-start: 6rem;
}
.case-study .brand-dots {
	gap: 1rem;
	justify-content: start;
}
@media (width >= 768px) {
	.case-study .brand-dots {
		justify-content: center;
		flex-direction: column;
	}
}
/* === Recruitedge Page === */
.service-recruitedge .intro-section {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	align-items: center;
	justify-content: center;
	margin-block-end: 6rem;
	background-color: var(--bg-light);
	border-radius: 1rem;
	padding: 6rem 4rem;
	text-wrap: pretty;
}
.service-recruitedge .intro-section-cta {
	display: flex;
	align-items: center;
	justify-content: center;
}
.service-recruitedge .intro-section-cta .call-box {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 1rem;
	max-width: 32rem;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	border-radius: 1rem;
	border: 1px solid oklch(var(--primary-base) / 0.1);
	background-color: var(--white);
	box-shadow: var(--shadow);
	transition: var(--transition);
}
.service-recruitedge .intro-section-cta .call-wrapper:is(:hover, :focus-within) .call-box {
	box-shadow: var(--shadow-hover);
}
.service-recruitedge .intro-section-cta .call-wrapper .call-box p {
	margin: 0;
}
.service-recruitedge .intro-section-cta .call-wrapper .call-box p:first-of-type {
	color: var(--primary);
}
.service-recruitedge .intro-section-cta .call-wrapper .call-box input {
	width: 100%;
	height: 100%;
	border: 1px solid oklch(var(--primary-base) / 0.1);
	border-radius: 0.5rem;
	padding: 0.5rem;
}
.service-recruitedge .intro-section-cta .call-wrapper .call-box input:focus {
	outline: 2px solid var(--secondary);
	outline-offset: 3px;
}
.service-recruitedge .intro-section-cta .call-box button {
	width: 100%;
	height: 100%;
}
.service-recruitedge .offerings-content .eyebrow span {
	font-weight: 900;
}
.service-recruitedge .process-cards {
	grid-template-columns: repeat(3, 1fr);
}
.service-recruitedge .features-grid {
	grid-template-columns: repeat(3, 1fr);
}
@media (width <= 768px) {
	.service-recruitedge .intro-section {
		grid-template-columns: 1fr;
		padding: 2rem;
	}
	.service-recruitedge :is(.process-cards, .features-grid) {
		grid-template-columns: 1fr;
	}
}
/* === 9. Live Site Fixes === */
