/**
 * Czas na Zieleń – Frontend Theme CSS
 * Design tokens: theme.json
 * @package czasnazielen
 */

@font-face {
	font-family: "Manrope";
	font-style: normal;
	font-weight: 200 800;
	font-display: swap;
	src: url("../fonts/manrope/Manrope-LatinExt.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
	font-family: "Manrope";
	font-style: normal;
	font-weight: 200 800;
	font-display: swap;
	src: url("../fonts/manrope/Manrope-Latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ==========================================================================
   1. CSS Custom Properties (additional, beyond theme.json)
   ========================================================================== */

:root {
	--czn-transition: 0.2s ease;
	--czn-shadow-sm:  0 2px  8px rgba(0,0,0,.08);
	--czn-shadow-md:  0 4px 20px rgba(0,0,0,.10);
	--czn-shadow-lg:  0 8px 40px rgba(0,0,0,.14);
	--czn-radius-sm:  8px;
	--czn-radius-md:  16px;
	--czn-radius-lg:  24px;
	--czn-radius-pill: 40px;
}

/* ==========================================================================
   2. Base / Reset
   ========================================================================== */

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img,
video {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	transition: color var(--czn-transition), opacity var(--czn-transition);
}

/* ==========================================================================
   3. Site Header
   ========================================================================== */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: none;
	transition: box-shadow var(--czn-transition), background-color var(--czn-transition);
}

.site-header.is-scrolled {
	box-shadow: var(--czn-shadow-sm);
}

/* Navigation links */
.site-header .wp-block-navigation a {
	color: var(--wp--preset--color--black);
	font-weight: 600;
	text-decoration: none;
	padding: 4px 0;
	position: relative;
	transition: color var(--czn-transition);
}

.site-header .wp-block-navigation a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--wp--preset--color--green-primary);
	transition: width var(--czn-transition);
}

.site-header .wp-block-navigation a:hover::after,
.site-header .wp-block-navigation .current-menu-item > a::after {
	width: 100%;
}

.site-header .wp-block-navigation a:hover {
	color: var(--wp--preset--color--green-primary);
}

.site-header .wp-block-navigation a[href="/oferta"],
.site-header .wp-block-navigation a[href="/oferta/"] {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
}

.site-header .wp-block-navigation a[href="/oferta"]::before,
.site-header .wp-block-navigation a[href="/oferta/"]::before {
	content: '';
	order: 2;
	display: inline-block;
	width: 16px;
	height: 16px;
	margin-top: 1px;
	background-color: currentColor;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E") center / 16px 16px no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E") center / 16px 16px no-repeat;
	transform: translateY(0);
	transition: transform var(--czn-transition), opacity var(--czn-transition);
	opacity: 0.92;
	flex-shrink: 0;
}

.site-header .wp-block-navigation a[href="/oferta"]:hover::before,
.site-header .wp-block-navigation a[href="/oferta/"]:hover::before {
	transform: translateY(1px);
}

/* CTA button in header */
.site-header .wp-block-button__link {
	white-space: nowrap;
	font-weight: 800;
	font-size: 0.875rem;
	letter-spacing: 0.01em;
	transition: background-color var(--czn-transition), transform var(--czn-transition), box-shadow var(--czn-transition);
}

.site-header .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--green-dark) !important;
	transform: translateY(-1px);
	box-shadow: var(--czn-shadow-sm);
}

/* Mobile hamburger */
.site-header .wp-block-navigation__responsive-container-open,
.site-header .wp-block-navigation__responsive-container-close {
	color: var(--wp--preset--color--black);
}

.site-header .mobile-menu-brand,
.site-header .mobile-menu-extras {
	display: none;
}

@media (max-width: 781px) {
	.site-header {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}

	.site-header .wp-block-buttons {
		display: none;
	}

	.site-header .wp-block-navigation__responsive-container-open {
		padding: 0;
		width: 2.25rem;
		height: 2.25rem;
	}

	.site-header .wp-block-navigation__responsive-container {
		background: rgba(32, 36, 31, 0.08) !important;
		padding: 0.75rem !important;
	}

	.site-header .wp-block-navigation__responsive-container.is-menu-open {
		display: flex;
		justify-content: stretch;
		align-items: stretch;
	}

	.site-header .wp-block-navigation__responsive-container-content {
		position: relative;
		width: 100%;
		max-width: none;
		min-height: calc(100vh - 1.5rem);
		padding: 1.25rem 1rem 1rem;
		border-radius: 0;
		background: #fff;
		overflow-y: auto;
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-start;
		gap: 1.5rem;
	}

	.site-header .wp-block-navigation__responsive-container-content::before {
		content: '';
		display: block;
		width: 11rem;
		height: 2.25rem;
		background: url('/wp-content/themes/czasnazielen/assets/images/logo-horizontal.png') center left / contain no-repeat;
		margin-right: auto;
		margin-bottom: 0.5rem;
		flex: 0 0 auto;
	}

	.site-header .wp-block-navigation__responsive-container-close {
		position: absolute;
		right: 0.875rem;
		top: 0.875rem;
		padding: 0;
		width: 1.75rem;
		height: 1.75rem;
	}

	.site-header .mobile-menu-brand {
		padding-right: 2.25rem;
	}

	.site-header .mobile-menu-brand .wp-block-image img {
		width: 8.8125rem !important;
	}

	.site-header .wp-block-navigation__responsive-container .wp-block-navigation__container {
		width: 100%;
		align-items: stretch;
		gap: 1.25rem;
	}

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

	.site-header .wp-block-navigation__responsive-container .wp-block-navigation-item a {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 0;
		width: 100%;
		text-align: left;
		font-size: 1.125rem;
		font-weight: 600;
		line-height: 1.2;
	}

	.site-header .wp-block-navigation__responsive-container .wp-block-navigation-item a::after {
		display: none;
	}

	.site-header .wp-block-navigation__responsive-container .has-offer-shortcut > a::before {
		content: "+";
		order: 2;
		font-size: 1.625rem;
		font-weight: 400;
		line-height: 1;
		color: #20241f;
		margin-left: auto;
	}

	.site-header .mobile-menu-extras {
		margin-top: auto;
		display: flex;
		flex-direction: column;
		gap: 0.75rem;
		align-items: flex-start;
		width: 100%;
	}

	.site-header .mobile-menu-divider {
		height: 1px;
		background: rgba(32, 36, 31, 0.08);
	}

	.site-header .mobile-menu-extras .mobile-menu-divider:first-child {
		display: none;
	}

	.site-header .mobile-menu-extras .mobile-menu-divider:last-of-type {
		width: 100%;
		display: block;
		margin-bottom: 0.25rem;
	}

	.site-header .mobile-menu-extras .mobile-menu-contact-list + .mobile-menu-divider {
		display: block;
	}

	.site-header .mobile-menu-contact-list {
		display: grid;
		gap: 0.5rem;
		width: 100%;
	}

	.site-header .mobile-menu-contact-item {
		display: flex;
		align-items: center;
		gap: 0.75rem;
		width: 100%;
		min-height: 3.375rem;
		padding: 0.375rem 0.75rem 0.375rem 0.375rem;
		border-radius: 1rem;
		background: #84CF281A;
		color: #20241f;
		font-size: 1rem;
		font-weight: 700;
		line-height: 1.4;
		text-decoration: none;
	}

	.site-header .mobile-menu-contact-icon {
		width: 2.5rem;
		height: 2.5rem;
		border-radius: 0.875rem;
		background: #84cf28;
		flex: 0 0 auto;
		background-position: center;
		background-repeat: no-repeat;
		background-size: 1.125rem 1.125rem;
	}

	.site-header .mobile-menu-contact-icon--phone {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M21 16.42v3a2 2 0 0 1-2.18 2A19.8 19.8 0 0 1 3.58 5.18 2 2 0 0 1 5.57 3h3a2 2 0 0 1 2 1.72c.12.9.33 1.78.61 2.63a2 2 0 0 1-.45 2.11L9.46 10.73a16 16 0 0 0 3.81 3.81l1.27-1.27a2 2 0 0 1 2.11-.45c.85.28 1.73.49 2.63.61A2 2 0 0 1 21 16.42Z' stroke='%2320241F' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	}

	.site-header .mobile-menu-contact-icon--mail {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Crect x='3' y='5' width='18' height='14' rx='3' stroke='%2320241F' stroke-width='1.8'/%3E%3Cpath d='m6 8 5.1 4.08a1.5 1.5 0 0 0 1.88 0L18 8' stroke='%2320241F' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	}

	.site-header .mobile-menu-cta {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		box-sizing: border-box;
		min-height: 3.5rem;
		border-radius: 999px;
		background: #84cf28;
		color: #20241f;
		font-size: 0.875rem;
		font-weight: 800;
		line-height: 1.5;
		text-transform: uppercase;
		text-decoration: none;
	}
}

/* ==========================================================================
   4. Buttons – global
   ========================================================================== */

.wp-element-button,
.wp-block-button__link {
	transition: background-color var(--czn-transition), transform var(--czn-transition), box-shadow var(--czn-transition);
	cursor: pointer;
}

.wp-element-button:hover,
.wp-block-button__link:hover {
	transform: translateY(-2px);
	box-shadow: var(--czn-shadow-sm);
}

/* Button outline variant */
.wp-block-button.is-style-outline .wp-block-button__link {
	border: 2px solid var(--wp--preset--color--white);
	background: transparent !important;
	color: var(--wp--preset--color--white) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: rgba(255,255,255,.1) !important;
}

/* ==========================================================================
   5. Hero Section
   ========================================================================== */

.hero-section {
	position: relative;
	overflow: hidden;
}

.hero-section .wp-block-cover {
	min-height: 600px;
}

.hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--wp--preset--color--dark);
	color: var(--wp--preset--color--green-primary);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 8px 16px;
	border-radius: 20px;
}

.homepage-hero {
	position: relative;
	overflow: hidden;
	min-height: 700px;
	color: #fff;
	background:
		linear-gradient(180deg, rgba(22, 22, 22, 0.15) 0%, rgba(22, 22, 22, 0.52) 44%, rgba(22, 22, 22, 0.88) 78%, #161616 100%),
		var(--homepage-hero-bg-image) center center / cover no-repeat;
}

.homepage-hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 220px;
	background: linear-gradient(180deg, rgba(22, 22, 22, 0) 0%, #161616 100%);
	pointer-events: none;
}

.homepage-hero__inner {
	position: relative;
	z-index: 1;
	min-height: 700px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding-top: clamp(6rem, 9vw, 8rem);
	padding-bottom: clamp(8rem, 12vw, 11rem);
}

.homepage-hero__content {
	width: min(100%, 62rem);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	text-align: center;
}

.homepage-hero__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	min-height: 2.125rem;
	padding: 0.375rem 0.95rem;
	border: 1px solid rgba(132, 207, 40, 0.95);
	border-radius: 999px;
	background: rgba(29, 29, 29, 0.72);
	box-shadow: inset 0 0 0 1px rgba(132, 207, 40, 0.12);
	backdrop-filter: blur(6px);
}

.homepage-hero__badge-dot {
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 999px;
	background: #84cf28;
	box-shadow: 0 0 0 4px rgba(132, 207, 40, 0.14);
	flex: 0 0 auto;
}

.homepage-hero__badge p,
.homepage-hero__lead,
.homepage-hero__content h1 {
	margin: 0;
}

.homepage-hero__badge p {
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	line-height: 1;
}

.homepage-hero__content h1 {
	max-width: 15ch;
	color: #fff;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(3rem, 5.25vw, 4.6rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: balance;
}

.homepage-hero__lead {
	max-width: 55rem;
	color: rgba(255, 255, 255, 0.92);
	font-size: clamp(1rem, 1.3vw, 1.35rem);
	line-height: 1.55;
	text-wrap: balance;
}

.homepage-hero__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin-top: 0.5rem;
}

.homepage-hero__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.875rem;
	padding: 1rem 1.75rem;
	border-radius: 999px;
	border: 1.5px solid transparent;
	font-size: 0.95rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform var(--czn-transition), background-color var(--czn-transition), border-color var(--czn-transition), color var(--czn-transition), box-shadow var(--czn-transition);
}

.homepage-hero__button--primary {
	background: #84cf28;
	color: #20241f;
	box-shadow: 0 20px 36px rgba(132, 207, 40, 0.16);
}

.homepage-hero__button--primary:hover {
	background: #94dd3a;
	color: #20241f;
}

.homepage-hero__button--secondary {
	border-color: rgba(255, 255, 255, 0.45);
	background: rgba(29, 29, 29, 0.34);
	color: #fff;
	backdrop-filter: blur(6px);
}

.homepage-hero__button--secondary:hover {
	border-color: #fff;
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
}

.homepage-hero__scroll {
	position: absolute;
	left: 50%;
	bottom: 4rem;
	width: 1.75rem;
	height: 1.75rem;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	transform: translateX(-50%);
	background: rgba(22, 22, 22, 0.2);
	backdrop-filter: blur(6px);
}

.homepage-hero__scroll span {
	position: absolute;
	left: 50%;
	top: 0.5rem;
	width: 2px;
	height: 0.5rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.55);
	transform: translateX(-50%);
}

.scroll-top-button {
	position: fixed;
	right: clamp(1rem, 2vw, 1.75rem);
	bottom: clamp(1rem, 2vw, 1.75rem);
	z-index: 40;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3.25rem;
	height: 3.25rem;
	padding: 0;
	border: 1px solid rgba(229, 228, 228, 0.95);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.84);
	box-shadow: 0 12px 28px rgba(22, 22, 22, 0.12), 0 3px 10px rgba(22, 22, 22, 0.06);
	color: #2f342e;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(1rem) scale(0.92);
	transition: opacity 0.24s ease, transform 0.24s ease, visibility 0.24s ease, box-shadow 0.24s ease;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.scroll-top-button:hover,
.scroll-top-button:focus-visible {
	transform: translateY(0) scale(1);
	box-shadow: 0 16px 32px rgba(22, 22, 22, 0.14), 0 4px 12px rgba(22, 22, 22, 0.08);
	outline: none;
}

.scroll-top-button.is-visible {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0) scale(1);
}

.scroll-top-button__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.scroll-top-button__icon svg {
	width: 1.25rem;
	height: 1.25rem;
	flex-shrink: 0;
}

.home-page {
	display: block;
}

.home-page > * {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

.services-showcase {
	background: #ffffff;
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4.5rem, 7vw, 6rem);
}

.services-showcase__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 3.6vw, 2.8rem);
}

.services-showcase__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}

.services-showcase__badge,
.services-showcase__intro h2,
.services-showcase__intro p,
.services-showcase__eyebrow,
.services-showcase__content h3,
.services-showcase__copy {
	margin: 0;
}

.services-showcase__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #eaf5d3;
}

.services-showcase__badge span {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #84cf28;
	flex: 0 0 auto;
}

.services-showcase__badge p {
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
}

.services-showcase__intro h2 {
	max-width: 13ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.5rem, 4vw, 3.5rem);
	font-weight: 800;
	line-height: 0.95;
	letter-spacing: -0.05em;
	text-wrap: balance;
}

.services-showcase__intro > p {
	max-width: 36rem;
	color: #3d3d3d;
	font-size: 1.05rem;
	line-height: 1.6;
	text-wrap: balance;
}

.services-showcase__tabs {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 0.85rem;
	align-items: stretch;
}

.services-showcase__tab {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.85rem;
	min-height: 6.15rem;
	padding: 1.1rem 1rem 1rem;
	border: 1px solid #e5e4e4;
	border-radius: 0.95rem;
	background: #ffffff;
	color: #20241f;
	cursor: pointer;
	box-shadow: none;
	transition: border-color var(--czn-transition), color var(--czn-transition), transform var(--czn-transition), box-shadow var(--czn-transition);
}

.services-showcase__tab:hover {
	transform: translateY(-1px);
	border-color: rgba(132, 207, 40, 0.55);
	box-shadow: none;
}

.services-showcase__tab.is-active {
	border-color: #84cf28;
	color: #84cf28;
	box-shadow: inset 0 0 0 1px rgba(132, 207, 40, 0.18);
}

.services-showcase__tab.is-active::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -0.48rem;
	width: 0.95rem;
	height: 0.95rem;
	border-right: 1px solid #84cf28;
	border-bottom: 1px solid #84cf28;
	background: #ffffff;
	transform: translateX(-50%) rotate(45deg);
}

.services-showcase__tab-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
}

.services-showcase__tab-icon svg {
	width: 1.5rem;
	height: 1.5rem;
	stroke: currentColor;
	stroke-width: 1.7;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.services-showcase__tab-label {
	color: inherit;
	font-size: 1.02rem;
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
	text-align: center;
}

.services-showcase__panels {
	position: relative;
	min-height: 25rem;
}

.services-showcase__panel {
	display: none;
	grid-template-columns: minmax(0, 1.08fr) minmax(22rem, 0.92fr);
	gap: clamp(2rem, 4vw, 3.2rem);
	align-items: center;
}

.services-showcase__panel.is-active {
	display: grid;
}

.services-showcase__media {
	position: relative;
	min-height: 16rem;
	border-radius: 1rem;
	overflow: hidden;
	background: #f4f4f4;
}

.services-showcase__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(32, 36, 31, 0.12) 100%);
	pointer-events: none;
}

.services-showcase__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.services-showcase__media--projektowanie-ogrodow img {
	object-position: 42% 50%;
}

.services-showcase__media--urzadzanie-ogrodow img {
	object-position: center center;
}

.services-showcase__media--zakladanie-trawnikow img {
	object-position: 58% 64%;
}

.services-showcase__media--uslugi-ogrodnicze img {
	object-position: 55% 40%;
}

.services-showcase__media--nawadnianie-ogrodow img {
	object-position: 68% 46%;
}

.services-showcase__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
	padding-top: 0.55rem;
}

.services-showcase__eyebrow {
	color: #84cf28;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.2;
}

.services-showcase__content h3 {
	max-width: 12ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2rem, 3vw, 3rem);
	font-weight: 800;
	line-height: 1.04;
	letter-spacing: -0.04em;
	text-wrap: balance;
}

.services-showcase__copy {
	max-width: 32rem;
	color: #3d3d3d;
	font-size: 1.04rem;
	line-height: 1.6;
}

.services-showcase__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.45rem;
	margin-top: 0.45rem;
	padding: 0.85rem 1.55rem;
	border: 1.5px solid #84cf28;
	border-radius: 999px;
	background: transparent;
	color: #20241f;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
	box-shadow: none;
}

.services-showcase__cta:hover {
	background: rgba(132, 207, 40, 0.08);
	color: #20241f;
	box-shadow: none;
}

/* ==========================================================================
   6. Section Labels / Badges
   ========================================================================== */

.section-label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(131, 207, 39, 0.12);
	color: var(--wp--preset--color--green-primary);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 6px 14px;
	border-radius: 20px;
	margin-bottom: 1rem;
}

.section-label::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--wp--preset--color--green-primary);
}

/* ==========================================================================
   7. Cards (service cards, blog cards, realization cards)
   ========================================================================== */

.service-card,
.blog-card,
.realization-card {
	border-radius: var(--czn-radius-md);
	overflow: hidden;
	transition: transform var(--czn-transition), box-shadow var(--czn-transition);
	background: var(--wp--preset--color--white);
}

.service-card:hover,
.blog-card:hover,
.realization-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--czn-shadow-md);
}

/* Service icon boxes */
.service-icon-box {
	background: var(--wp--preset--color--white);
	border-radius: var(--czn-radius-md);
	padding: 1.5rem;
	text-align: center;
	box-shadow: var(--czn-shadow-sm);
	transition: transform var(--czn-transition), box-shadow var(--czn-transition);
}

.service-icon-box:hover {
	transform: translateY(-4px);
	box-shadow: var(--czn-shadow-md);
}

/* ==========================================================================
   8. Blog Cards
   ========================================================================== */

.blog-card {
	box-shadow: var(--czn-shadow-sm);
}

.blog-card .wp-block-post-title a {
	color: var(--wp--preset--color--black);
	text-decoration: none;
}

.blog-card .wp-block-post-title a:hover {
	color: var(--wp--preset--color--green-primary);
}

.blog-archive-section {
	padding-top: clamp(4rem, 6vw, 5.5rem);
	padding-bottom: clamp(4rem, 6vw, 5.5rem);
	background: #ffffff;
}

.blog-archive-section__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 2.75rem);
}

.blog-archive-section__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.25rem;
	text-align: center;
}

.blog-archive-section__badge,
.blog-archive-section__intro h1,
.blog-archive-section__intro p,
.blog-archive-card__tag,
.blog-archive-card__date,
.blog-archive-card h2,
.blog-archive-card__excerpt,
.blog-archive-card__cta,
.blog-archive-section__empty {
	margin: 0;
}

.blog-archive-section__badge p {
	line-height: 1;
}

.blog-archive-section__intro h1 {
	max-width: 13ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.6rem, 4.5vw, 4rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: balance;
}

.blog-archive-section__intro p {
	max-width: 54rem;
	color: #3d3d3d;
	font-size: 1.04rem;
	line-height: 1.6;
	text-wrap: balance;
}

.blog-archive-section__filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
}

.blog-archive-section__filter {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.875rem;
	padding: 0.75rem 1.1rem;
	border: 1px solid #d9d9d9;
	border-radius: 999px;
	background: #ffffff;
	color: #363636;
	font-size: 0.95rem;
	font-weight: 500;
	line-height: 1;
	text-decoration: none;
	box-shadow: none;
	transition: border-color var(--czn-transition), color var(--czn-transition), background-color var(--czn-transition), transform var(--czn-transition);
}

.blog-archive-section__filter:hover {
	transform: translateY(-1px);
	border-color: rgba(132, 207, 40, 0.55);
	color: #20241f;
}

.blog-archive-section__filter.is-active {
	border-width: 2px;
	border-color: #84cf28;
	padding: calc(0.75rem - 1px) calc(1.1rem - 1px);
	color: #20241f;
	box-shadow: inset 0 0 0 1px rgba(132, 207, 40, 0.08);
}

.blog-archive-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.blog-archive-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	border: 1px solid #e5e4e4;
	border-radius: 1rem;
	overflow: hidden;
	background: #ffffff;
	box-shadow: none;
	transition: transform var(--czn-transition), box-shadow var(--czn-transition), border-color var(--czn-transition);
}

.blog-archive-card:hover {
	transform: translateY(-3px);
	border-color: rgba(132, 207, 40, 0.28);
	box-shadow: 0 16px 34px rgba(32, 36, 31, 0.07);
}

.blog-archive-card[hidden] {
	display: none !important;
}

.blog-archive-card__media {
	position: relative;
	display: block;
	aspect-ratio: 356 / 244;
	overflow: hidden;
	background: #eef0e6;
	text-decoration: none;
}

.blog-archive-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.35s ease;
}

.blog-archive-card:hover .blog-archive-card__media img {
	transform: scale(1.03);
}

.blog-archive-card__tag {
	position: absolute;
	left: 1rem;
	bottom: 1rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #ffffff;
	color: #20241f;
	font-size: 0.9rem;
	font-weight: 700;
	line-height: 1;
	box-shadow: 0 8px 20px rgba(32, 36, 31, 0.08);
	z-index: 1;
}

.blog-archive-card__body {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	align-items: flex-start;
	padding: 1rem 1rem 1.125rem;
	gap: 0.75rem;
}

.blog-archive-card__date {
	color: #9f9f9f;
	font-size: 0.95rem;
	line-height: 1.2;
}

.blog-archive-card h2 {
	color: #20241f;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.01em;
	text-wrap: balance;
}

.blog-archive-card h2 a {
	color: inherit;
	text-decoration: none;
}

.blog-archive-card__excerpt {
	color: #4f4f4f;
	font-size: 0.95rem;
	font-weight: 500;
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.blog-archive-card__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	margin-top: auto;
	padding-top: 0.25rem;
	color: #20241f;
	font-size: 0.95rem;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
}

.blog-archive-card__cta svg {
	width: 1rem;
	height: 1rem;
	stroke: #84cf28;
	stroke-width: 1.8;
	stroke-linecap: round;
	stroke-linejoin: round;
	flex-shrink: 0;
}

.blog-archive-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.625rem;
	flex-wrap: wrap;
	margin-top: 0.75rem;
}

.blog-archive-pagination__item {
	display: inline-flex;
}

.blog-archive-pagination__item .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 3rem;
	min-height: 3rem;
	padding: 0.625rem 0.875rem;
	border: 1px solid #e5e4e4;
	border-radius: 0.5rem;
	background: #ffffff;
	color: #20241f;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	box-shadow: none;
	transition: border-color var(--czn-transition), color var(--czn-transition), transform var(--czn-transition);
}

.blog-archive-pagination__item .page-numbers:hover {
	transform: translateY(-1px);
	border-color: rgba(132, 207, 40, 0.5);
}

.blog-archive-pagination__item.is-current .page-numbers {
	border-width: 2px;
	border-color: #84cf28;
	padding: calc(0.625rem - 1px) calc(0.875rem - 1px);
}

.blog-archive-pagination__item.is-dots .page-numbers {
	pointer-events: none;
}

.blog-archive-pagination__item.is-disabled .page-numbers {
	opacity: 0.45;
	pointer-events: none;
}

.blog-archive-pagination__item.is-arrow .page-numbers {
	min-width: 3.125rem;
	padding-inline: 0.75rem;
}

.blog-archive-pagination__item svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	stroke-width: 1.9;
	stroke-linecap: round;
	stroke-linejoin: round;
	fill: none;
}

.blog-archive-section__empty {
	color: #6a6a6a;
	font-size: 1rem;
	text-align: center;
}

.blog-cta-section {
	padding-top: 0;
	padding-bottom: clamp(4rem, 6vw, 5.5rem);
	background: #ffffff;
}

.blog-cta-section__inner {
	border-radius: 24px;
	padding: 56px 299px;
	background: linear-gradient(87.6deg, #84cf28 0%, #c0e83d 100%);
}

.blog-cta-section__content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 0.875rem;
}

.blog-cta-section__content h2,
.blog-cta-section__content p,
.blog-cta-section__button {
	margin: 0;
}

.blog-cta-section__content h2 {
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0;
	text-wrap: balance;
}

.blog-cta-section__content p {
	max-width: 35rem;
	color: #20241f;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.4;
	text-wrap: balance;
}

.blog-cta-section__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 232px;
	min-height: 48px;
	margin-top: 1rem;
	padding: 0.95rem 2rem;
	border-radius: 40px;
	background: #ffffff;
	color: #20241f;
	font-size: 0.9rem;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
	box-shadow: 0 8px 22px rgba(32, 36, 31, 0.08);
	transition: transform var(--czn-transition), box-shadow var(--czn-transition);
}

.blog-cta-section__button:hover,
.blog-cta-section__button:focus-visible {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(32, 36, 31, 0.12);
	outline: none;
}

/* ==========================================================================
   9. Testimonials
   ========================================================================== */

.testimonials-section {
	--testimonial-card-width: 15.75rem;
	--testimonial-card-gap: 0.875rem;
	position: relative;
	background: #161616;
	margin-top: -1px;
	padding-top: clamp(1.5rem, 2.8vw, 2.5rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
	overflow: hidden;
}

.testimonials-section__inner {
	position: relative;
	display: grid;
	grid-template-columns: minmax(14.5rem, 15.75rem) minmax(0, 1fr);
	gap: clamp(2.25rem, 3.4vw, 3rem);
	align-items: start;
	margin-top: 0;
	z-index: 2;
}

.testimonials-section__intro {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.75rem;
	padding-bottom: 1.5rem;
	color: #fff;
}

.testimonials-section__intro h2,
.testimonials-section__stars,
.testimonials-section__rating,
.testimonials-section__note,
.testimonials-section__google-link,
.testimonial-card__name,
.testimonial-card__time,
.testimonial-card__stars,
.testimonial-card__copy {
	margin: 0;
}

.testimonials-section__intro h2 {
	max-width: 12ch;
	color: #fff;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.1rem, 3.35vw, 3rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.04em;
	text-wrap: balance;
}

.testimonials-section__stars,
.testimonial-card__stars {
	color: #fabb05;
	letter-spacing: 0.22em;
	white-space: nowrap;
}

.testimonials-section__stars {
	font-size: 1.25rem;
	line-height: 1;
}

.testimonials-section__rating {
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.25;
}

.testimonials-section__note {
	color: #a4a4a4;
	font-size: 0.75rem;
	line-height: 1.35;
}

.testimonials-section__google-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	min-height: 3.5rem;
	margin-top: 1rem;
	padding: 0.875rem 1.25rem;
	border: 1px solid #3d3d3d;
	border-radius: 999px;
	background: transparent;
	color: #fff;
	font-size: 0.8rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform var(--czn-transition), border-color var(--czn-transition), background-color var(--czn-transition), box-shadow var(--czn-transition);
}

.testimonials-section__google-link:hover {
	border-color: rgba(255, 255, 255, 0.35);
	background: rgba(255, 255, 255, 0.05);
	color: #fff;
	box-shadow: none;
}

.testimonials-section__reviews-wrap {
	min-width: 0;
	overflow: hidden;
	padding-top: 0.9rem;
}

.testimonials-section__reviews {
	display: flex;
	align-items: stretch;
	gap: var(--testimonial-card-gap);
	overflow-x: auto;
	padding-bottom: 1rem;
	scroll-behavior: smooth;
	scroll-snap-type: x proximity;
	overscroll-behavior-x: contain;
	scrollbar-width: none;
}

.testimonials-section__reviews::-webkit-scrollbar {
	display: none;
}

.testimonial-card {
	flex: 0 0 var(--testimonial-card-width);
	min-height: 11.15rem;
	display: flex;
	flex-direction: column;
	gap: 0.82rem;
	padding: 0.95rem 1rem 1rem;
	border-radius: 0.8rem;
	background: #f4f4f4;
	box-shadow: none;
	scroll-snap-align: start;
}

.testimonial-card__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0.75rem;
}

.testimonial-card__author {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	min-width: 0;
}

.testimonial-card__avatar {
	width: 1.95rem;
	height: 1.95rem;
	border-radius: 999px;
	background: #d9d9d9;
	flex: 0 0 auto;
}

.testimonial-card__name {
	color: #20241f;
	font-size: 0.76rem;
	font-weight: 800;
	line-height: 1.2;
}

.testimonial-card__time {
	margin-top: 0.2rem;
	color: #a4a4a4;
	font-size: 0.66rem;
	line-height: 1.2;
}

.testimonial-card__stars {
	font-size: 0.78rem;
	line-height: 1;
	letter-spacing: 0.12em;
}

.testimonial-card__copy {
	color: #363636;
	font-size: 0.83rem;
	line-height: 1.38;
	letter-spacing: -0.01em;
}

.testimonials-section__pagination {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	margin-top: 0.375rem;
	padding-left: 0.125rem;
}

.testimonials-section__pagination button {
	width: 0.375rem;
	height: 0.375rem;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.24);
	box-shadow: none;
}

.testimonials-section__pagination .is-active {
	width: 0.5rem;
	height: 0.5rem;
	background: #84cf28;
}

.testimonials-section__pagination button:hover {
	transform: none;
	box-shadow: none;
	background: rgba(255, 255, 255, 0.44);
}

/* ==========================================================================
   10. Video Showcase
   ========================================================================== */

.video-showcase {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(1.5rem, 3vw, 2.5rem);
	background: #ffffff;
}

.video-showcase__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 2.8rem);
}

.video-showcase__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}

.video-showcase__badge,
.video-showcase__intro h2,
.video-showcase__intro p {
	margin: 0;
}

.video-showcase__badge,
.process-card__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #ecf8d8;
}

.video-showcase__badge span,
.process-card__badge span {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #84cf28;
	flex: 0 0 auto;
}

.video-showcase__badge p,
.process-card__badge p {
	margin: 0;
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
}

.video-showcase__intro h2 {
	max-width: 16ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.3rem, 3.6vw, 3.5rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: pretty;
}

.video-showcase__intro p {
	max-width: 48rem;
	color: #3d3d3d;
	font-size: 1.04rem;
	line-height: 1.6;
	text-wrap: balance;
}

.video-showcase__frame {
	position: relative;
	aspect-ratio: 16 / 9;
	width: 100%;
	border-radius: 1.25rem;
	background: #1d1d1d;
	overflow: hidden;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.video-showcase__frame iframe {
	width: 100%;
	height: 100%;
	border: 0;
}

.video-showcase__play {
	position: absolute;
	left: 50%;
	top: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: clamp(4rem, 7vw, 5.25rem);
	height: clamp(4rem, 7vw, 5.25rem);
	border-radius: 50%;
	background: #ffffff;
	transform: translate(-50%, -50%);
	box-shadow: 0 18px 30px rgba(0, 0, 0, 0.18);
}

.video-showcase__play svg {
	width: 1.55rem;
	height: 1.55rem;
	margin-left: 0.18rem;
	fill: #161616;
	stroke: #161616;
	stroke-width: 1.4;
	stroke-linejoin: round;
}

/* ==========================================================================
   11. Process Steps
   ========================================================================== */

.process-section {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #f4f4f4;
}

.process-card {
	max-width: 1280px;
	padding: clamp(2.75rem, 5vw, 4rem) clamp(1.5rem, 4.5vw, 3rem) clamp(3rem, 5vw, 4rem);
	border-radius: 2rem;
	background: #ffffff;
	box-shadow: 0 36px 70px rgba(32, 36, 31, 0.12);
}

.process-card__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}

.process-card__badge,
.process-card__intro h2,
.process-workflow__label,
.process-workflow__step h3 {
	margin: 0;
}

.process-card__intro h2 {
	max-width: 18ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.3rem, 4vw, 3.5rem);
	font-weight: 800;
	line-height: 1.02;
	letter-spacing: -0.05em;
	text-wrap: balance;
}

.process-workflow {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr);
	align-items: start;
	gap: clamp(0.65rem, 1.2vw, 1rem);
	margin-top: clamp(2.3rem, 4.5vw, 3.5rem);
}

.process-workflow--4col {
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr);
}

.process-workflow__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.85rem;
	min-width: 0;
}

.process-workflow__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.35rem;
	height: 1.35rem;
	border: 1.5px solid #84cf28;
	border-radius: 50%;
	color: #84cf28;
	background: #ffffff;
}

.process-workflow__icon svg {
	width: 0.85rem;
	height: 0.85rem;
	stroke: currentColor;
	stroke-width: 2.1;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.process-workflow__label {
	color: #a4a4a4;
	font-size: 0.92rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}

.process-workflow__step h3 {
	max-width: 12ch;
	color: #20241f;
	font-size: clamp(1.2rem, 1.6vw, 1.6rem);
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: -0.03em;
	text-wrap: balance;
}

.process-workflow__connector {
	align-self: center;
	width: 0.36rem;
	height: 0.36rem;
	margin-top: 0.2rem;
	border-radius: 50%;
	background: #84cf28;
}

.process-card__actions {
	display: flex;
	justify-content: center;
	margin-top: clamp(2.2rem, 4vw, 3.25rem);
}

.process-card__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.65rem;
	padding: 0.95rem 1.75rem;
	border-radius: 999px;
	background: #84cf28;
	color: #20241f;
	font-size: 0.88rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
	box-shadow: 0 18px 34px rgba(132, 207, 40, 0.18);
}

.process-card__cta:hover {
	background: #94dd3a;
	color: #20241f;
	box-shadow: 0 18px 34px rgba(132, 207, 40, 0.22);
}

/* ==========================================================================
   12. Projects Showcase
   ========================================================================== */

.projects-showcase {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.projects-showcase__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 2.9rem);
}

.projects-showcase__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}

.projects-showcase__badge,
.projects-showcase__intro h2,
.projects-showcase__intro p,
.project-card__badge,
.project-card__content h3,
.projects-showcase__empty {
	margin: 0;
}

.projects-showcase__badge p {
	line-height: 1;
}

.projects-showcase__intro h2 {
	max-width: 12ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.5rem, 4vw, 3.8rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: balance;
}

.projects-showcase__intro p {
	max-width: 42rem;
	color: #3d3d3d;
	font-size: 1.04rem;
	line-height: 1.6;
	text-wrap: balance;
}

.projects-showcase__filters {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem 1.5rem;
	flex-wrap: wrap;
}

.projects-showcase--categories-only .projects-showcase__filters {
	justify-content: center;
}

.projects-showcase__filter-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.projects-showcase__filter-group--media {
	justify-content: flex-end;
	margin-left: auto;
}

.projects-showcase__filter {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	min-height: 3rem;
	padding: 0.75rem 1.1rem;
	border: 1px solid #d9d9d9;
	border-radius: 999px;
	background: #ffffff;
	color: #363636;
	font-size: 0.92rem;
	font-weight: 500;
	line-height: 1;
	box-shadow: none;
	transition: border-color var(--czn-transition), color var(--czn-transition), background-color var(--czn-transition), transform var(--czn-transition);
}

.projects-showcase__filter:hover {
	transform: translateY(-1px);
	border-color: rgba(132, 207, 40, 0.55);
	box-shadow: none;
}

.projects-showcase__filter.is-active {
	border-color: #84cf28;
	color: #20241f;
	box-shadow: inset 0 0 0 1px rgba(132, 207, 40, 0.16);
}

.projects-showcase__filter--media {
	padding-inline: 1rem 1.15rem;
}

.projects-showcase__filter-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1rem;
	height: 1rem;
	flex: 0 0 auto;
}

.projects-showcase__filter-icon svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	stroke-width: 1.8;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.projects-showcase__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	gap: 1.125rem;
	align-items: stretch;
}

.project-card {
	position: relative;
	min-height: 15rem;
	border-radius: 1.5rem;
	overflow: hidden;
	background: #1d1d1d;
}

.project-card[hidden] {
	display: none !important;
}

.project-card--featured {
	grid-row: span 2;
	min-height: 30.25rem;
}

.project-card--stacked {
	min-height: 14.55rem;
}

.project-card__link {
	position: relative;
	display: block;
	height: 100%;
	color: inherit;
	text-decoration: none;
}

.project-card__link img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.project-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(22, 22, 22, 0.04) 18%, rgba(22, 22, 22, 0.18) 52%, rgba(22, 22, 22, 0.72) 100%);
}

.project-card__content {
	position: absolute;
	left: 1.45rem;
	right: 6rem;
	bottom: 1.4rem;
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.project-card__badge {
	width: fit-content;
	padding: 0.45rem 0.8rem;
	border-radius: 999px;
	background: rgba(132, 207, 40, 0.22);
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
	backdrop-filter: blur(6px);
}

.project-card__content h3 {
	color: #ffffff;
	font-size: clamp(1.5rem, 2.2vw, 2.1rem);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.03em;
	text-wrap: balance;
}

.project-card__arrow {
	position: absolute;
	right: 1.45rem;
	bottom: 1.45rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 4rem;
	height: 4rem;
	border-radius: 1.15rem;
	background: #84cf28;
	color: #20241f;
	z-index: 2;
	box-shadow: 0 18px 34px rgba(132, 207, 40, 0.2);
}

.project-card__arrow svg {
	width: 1.4rem;
	height: 1.4rem;
	stroke: currentColor;
	stroke-width: 2.2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.projects-showcase__empty {
	color: #3d3d3d;
	font-size: 1rem;
	text-align: center;
}

/* ==========================================================================
   13. Gradient CTA Section
   ========================================================================== */

.cta-gradient-section {
	padding-top: 0;
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.cta-gradient-section__inner {
	display: grid;
	grid-template-columns: minmax(34rem, 1fr) max-content;
	gap: 2.5rem;
	align-items: center;
	padding: clamp(2rem, 4vw, 2.8rem) clamp(1.5rem, 4vw, 2.6rem);
	border-radius: 1.5rem;
	background: linear-gradient(87.6deg, #84CF28 0%, #C0E83D 100%);
	box-shadow: none;
}

.cta-gradient-section__content,
.cta-gradient-section__actions {
	display: flex;
}

.cta-gradient-section__content {
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
}

.cta-gradient-section__content h2,
.cta-gradient-section__content p {
	margin: 0;
	color: #20241f;
}

.cta-gradient-section__content h2 {
	max-width: 27rem;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2rem, 2.75vw, 2.85rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: pretty;
}

.cta-gradient-section__content p {
	max-width: 33rem;
	font-size: 1.02rem;
	line-height: 1.5;
}

.cta-gradient-section__actions {
	justify-content: flex-end;
	align-items: center;
	gap: 0.9rem;
	flex-wrap: nowrap;
	flex-shrink: 0;
}

.cta-gradient-section__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.5rem;
	padding: 0.95rem 1.7rem;
	border-radius: 999px;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 0.86rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	white-space: nowrap;
	transition: transform var(--czn-transition), background-color var(--czn-transition), color var(--czn-transition), border-color var(--czn-transition), box-shadow var(--czn-transition);
}

.cta-gradient-section__button:hover {
	transform: translateY(-1px);
}

.cta-gradient-section__button--solid {
	background: #ffffff;
	border: 1px solid #ffffff;
	color: #20241f;
	box-shadow: 0 14px 24px rgba(255, 255, 255, 0.18);
}

.cta-gradient-section__button--solid:hover {
	background: #f7f7f7;
	color: #20241f;
}

.cta-gradient-section__button--outline {
	background: transparent;
	border: 2px solid #20241f;
	color: #20241f;
}

.cta-gradient-section__button--outline:hover {
	background: rgba(255, 255, 255, 0.14);
	color: #20241f;
}

/* ==========================================================================
   14. Experience Showcase
   ========================================================================== */

.experience-showcase {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.experience-showcase__inner {
	display: grid;
	grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
	gap: clamp(2rem, 4vw, 3.25rem);
	align-items: start;
}

.experience-showcase__media {
	position: relative;
	border-radius: 1.75rem;
	overflow: hidden;
	background: #f4f4f4;
	min-height: 32rem;
	box-shadow: none;
}

.experience-showcase__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.experience-showcase__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1.4rem;
	padding-top: 0.3rem;
}

.experience-showcase__badge,
.experience-showcase__content h2,
.experience-showcase__lead,
.experience-showcase__card h3,
.experience-showcase__card p {
	margin: 0;
}

.experience-showcase__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #ecf8d8;
}

.experience-showcase__badge span {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #84cf28;
	flex: 0 0 auto;
}

.experience-showcase__badge p {
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
}

.experience-showcase__content h2 {
	max-width: 12ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.6rem, 4.2vw, 4rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.055em;
	text-wrap: pretty;
}

.experience-showcase__lead {
	max-width: 38rem;
	color: #3d3d3d;
	font-size: 1.03rem;
	line-height: 1.52;
}

.experience-showcase__lead strong {
	color: #20241f;
	font-weight: 700;
}

.experience-showcase__cards {
	display: flex;
	flex-direction: column;
	gap: 0.95rem;
	width: 100%;
	margin-top: 0.1rem;
}

.experience-showcase__card {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.95rem;
	align-items: start;
	padding: 1.35rem 1.5rem;
	border-radius: 1.1rem;
	box-shadow: none;
}

.experience-showcase__card--vision {
	background: #F2FFD7;
	margin-right: 6rem;
}

.experience-showcase__card--work {
	background: #EDFFE6;
	margin-left: 6rem;
}

.experience-showcase__card-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.3rem;
	height: 1.3rem;
	border: 1.5px solid #84cf28;
	border-radius: 50%;
	color: #84cf28;
	background: transparent;
	margin-top: 0.1rem;
}

.experience-showcase__card-icon svg {
	width: 0.8rem;
	height: 0.8rem;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.experience-showcase__card h3 {
	color: #20241f;
	font-size: 1.55rem;
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: -0.03em;
}

.experience-showcase__card p {
	margin-top: 0.55rem;
	color: #3d3d3d;
	font-size: 0.98rem;
	line-height: 1.5;
}

/* ==========================================================================
   15. Latest Posts
   ========================================================================== */

.latest-posts-section {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.latest-posts-section__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 2.8rem);
}

.latest-posts-section__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}

.latest-posts-section__badge,
.latest-posts-section__intro h2,
.latest-posts-section__empty,
.blog-entry-card__tag,
.blog-entry-card__date,
.blog-entry-card h3,
.blog-entry-card__excerpt,
.blog-entry-card__cta {
	margin: 0;
}

.latest-posts-section__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #ecf8d8;
}

.latest-posts-section__badge span {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #84cf28;
	flex: 0 0 auto;
}

.latest-posts-section__badge p {
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
}

.latest-posts-section__intro h2 {
	max-width: 13ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.3rem, 3.7vw, 3.5rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: pretty;
}

.blog-list {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.1rem;
}

.blog-entry-card {
	display: flex;
	flex-direction: column;
	border: 1px solid #e5e4e4;
	border-radius: 1rem;
	overflow: hidden;
	background: #ffffff;
	box-shadow: none;
}

.blog-entry-card__media {
	position: relative;
	display: block;
	aspect-ratio: 1.05 / 0.72;
	overflow: hidden;
	color: inherit;
	text-decoration: none;
	background: #f4f4f4;
}

.blog-entry-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.blog-entry-card__tag {
	position: absolute;
	left: 0.9rem;
	bottom: 0.9rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2rem;
	padding: 0.42rem 0.9rem;
	border-radius: 999px;
	background: #ffffff;
	color: #20241f;
	font-size: 0.82rem;
	font-weight: 500;
	line-height: 1;
}

.blog-entry-card__body {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.9rem;
	padding: 1rem 0.95rem 1.2rem;
	flex: 1 1 auto;
}

.blog-entry-card__date {
	color: #a4a4a4;
	font-size: 0.82rem;
	line-height: 1.3;
}

.blog-entry-card h3 {
	color: #20241f;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.03em;
}

.blog-entry-card h3 a {
	color: inherit;
	text-decoration: none;
}

.blog-entry-card__excerpt {
	color: #3d3d3d;
	font-size: 0.95rem;
	line-height: 1.55;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}

.blog-entry-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	margin-top: auto;
	color: #20241f;
	font-size: 0.88rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
}

.blog-entry-card__cta svg {
	width: 1rem;
	height: 1rem;
	stroke: #84cf28;
	stroke-width: 2.1;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.latest-posts-section__empty {
	color: #3d3d3d;
	font-size: 1rem;
	text-align: center;
}

/* ==========================================================================
   16. Local Company Showcase
   ========================================================================== */

.local-company-showcase {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.local-company-showcase__inner {
	display: grid;
	grid-template-columns: minmax(0, 0.93fr) minmax(19rem, 20rem) minmax(0, 0.87fr);
	gap: 1.1rem;
	align-items: stretch;
}

.local-company-showcase__intro {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1.2rem;
	padding: 0.35rem 1rem 0 0;
}

.local-company-showcase__badge,
.local-company-showcase__intro h2,
.local-company-showcase__intro p,
.local-company-showcase__card h3,
.local-company-showcase__card p {
	margin: 0;
}

.local-company-showcase__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #ecf8d8;
}

.local-company-showcase__badge span {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #84cf28;
	flex: 0 0 auto;
}

.local-company-showcase__badge p {
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
}

.local-company-showcase__intro h2 {
	max-width: 8.5ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.8rem, 4.4vw, 4.3rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.055em;
	text-wrap: pretty;
}

.local-company-showcase__intro p {
	max-width: 25rem;
	color: #3d3d3d;
	font-size: 1.02rem;
	line-height: 1.48;
}

.local-company-showcase__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.4rem;
	margin-top: 0.15rem;
	padding: 0.9rem 1.45rem;
	border: 2px solid #84cf28;
	border-radius: 999px;
	background: transparent;
	color: #20241f;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
}

.local-company-showcase__button:hover {
	background: rgba(132, 207, 40, 0.08);
	color: #20241f;
}

.local-company-showcase__founder {
	min-height: 100%;
}

.local-company-showcase__cards {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.local-company-showcase__card {
	padding: 2rem 1.6rem;
	border-radius: 1.5rem;
	box-shadow: none;
}

.local-company-showcase__card--vision {
	background: #F2FFD7;
}

.local-company-showcase__card--mission {
	background: #EDFFE6;
}

.local-company-showcase__card--story {
	background: #F4F4F4;
}

.local-company-showcase__card h3 {
	color: #20241f;
	font-size: 1.85rem;
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.03em;
}

.local-company-showcase__card p {
	margin-top: 0.8rem;
	color: #3d3d3d;
	font-size: 0.99rem;
	line-height: 1.45;
}

/* ==========================================================================
   17. FAQ Home
   ========================================================================== */

.faq-home-section {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.faq-home-section__inner {
	display: grid;
	grid-template-columns: minmax(16rem, 22rem) minmax(0, 1fr);
	gap: clamp(2rem, 4vw, 4rem);
	align-items: start;
}

.faq-home-section__intro {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
	padding-top: 0.25rem;
}

.faq-home-section__badge,
.faq-home-section__intro h2,
.faq-home-item summary,
.faq-home-item__content p {
	margin: 0;
}

.faq-home-section__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 2rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: #ecf8d8;
}

.faq-home-section__badge span {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #84cf28;
	flex: 0 0 auto;
}

.faq-home-section__badge p {
	color: #84cf28;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
	margin: 0;
}

.faq-home-section__intro h2 {
	max-width: 25.6875rem;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: 3rem;
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.055em;
	text-wrap: pretty;
}

.faq-home-section__list {
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
}

.faq-home-item {
	border: 1px solid #e5e4e4;
	border-radius: 1.9rem;
	background: #f7f7f5;
	overflow: hidden;
}

.faq-home-item[open] {
	background: #ffffff;
}

.faq-home-item summary {
	position: relative;
	list-style: none;
	cursor: pointer;
	padding: 1.6rem 4.75rem 1.6rem 2rem;
	color: #20241f;
	font-size: 1.25rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.03em;
}

.faq-home-item summary::-webkit-details-marker {
	display: none;
}

.faq-home-item summary::before,
.faq-home-item summary::after {
	content: "";
	position: absolute;
	right: 2rem;
	top: 50%;
	width: 1rem;
	height: 2px;
	border-radius: 999px;
	background: #20241f;
	transform: translateY(-50%);
	transition: transform var(--czn-transition), opacity var(--czn-transition);
}

.faq-home-item summary::after {
	transform: translateY(-50%) rotate(90deg);
}

.faq-home-item[open] summary::after {
	opacity: 0;
	transform: translateY(-50%) rotate(90deg) scaleX(0.2);
}

.faq-home-item__content {
	padding: 0 2rem 1.5rem;
}

.faq-home-item__content p {
	max-width: 58rem;
	color: #3d3d3d;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
}

/* ==========================================================================
   18. Other Brands Showcase
   ========================================================================== */

.other-brands-showcase {
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background: #ffffff;
}

.other-brands-showcase__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 2.75rem);
}

.other-brands-showcase__intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}

.other-brands-showcase__badge,
.other-brands-showcase__intro h2,
.other-brands-showcase__intro p,
.brand-card__content h3,
.brand-card__content p {
	margin: 0;
}

.other-brands-showcase__badge {
	display: inline-flex;
	width: fit-content;
	align-items: center;
	justify-content: flex-start;
	gap: 0.5rem;
	min-height: 2rem;
	padding: 0.5rem 0.875rem;
	border-radius: 999px;
	background: #ecf8d8;
	box-shadow: inset 0 0 0 1px rgba(131, 207, 39, 0.08);
}

.other-brands-showcase__badge::before {
	content: "";
	width: 0.5625rem;
	height: 0.5625rem;
	border-radius: 50%;
	background: var(--wp--preset--color--green-primary);
	flex: 0 0 auto;
}

.other-brands-showcase__badge span {
	display: none;
}

.other-brands-showcase__badge p {
	margin: 0;
	color: var(--wp--preset--color--green-primary);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	line-height: 1;
}

.other-brands-showcase__intro h2 {
	max-width: 12ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.5rem, 4vw, 3.8rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.05em;
	text-wrap: pretty;
}

.other-brands-showcase__intro p {
	max-width: 54rem;
	color: #3d3d3d;
	font-size: 1.04rem;
	line-height: 1.55;
	text-wrap: balance;
}

.other-brands-showcase__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.2rem;
}

.brand-card {
	display: grid;
	grid-template-columns: minmax(11rem, 12.5rem) minmax(0, 1fr);
	min-height: 19.9rem;
	border: 1px solid #e5e4e4;
	border-radius: 1.6rem;
	overflow: hidden;
	background: #ffffff;
}

.brand-card__media {
	position: relative;
	min-height: 100%;
	background: #f4f4f4;
}

.brand-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.brand-card__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.75rem 1.45rem 1.55rem;
}

.brand-card__logo {
	display: block;
	width: auto;
	height: auto;
	max-width: 17rem;
	max-height: 3rem;
	object-fit: contain;
}

.brand-card__logo--robopunkt {
	max-width: 16.5rem;
}

.brand-card__logo--aquapunkt {
	max-width: 17rem;
}

.brand-card__content h3 {
	color: #20241f;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.03em;
}

.brand-card__content p {
	color: #3d3d3d;
	font-size: 0.97rem;
	line-height: 1.45;
}

.brand-card__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.35rem;
	margin-top: auto;
	padding: 0.85rem 1.35rem;
	border: 2px solid #84cf28;
	border-radius: 999px;
	background: transparent;
	color: #20241f;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-decoration: none;
	text-transform: uppercase;
}

.brand-card__button:hover {
	background: rgba(132, 207, 40, 0.08);
	color: #20241f;
}

/* ==========================================================================
   19. Contact Page
   ========================================================================== */

.contact-page-hero {
	padding-top: clamp(3rem, 6vw, 5rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
}

.contact-page-intro {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.contact-page-badge {
	align-self: center;
}

.contact-map-showcase {
	box-shadow: var(--czn-shadow-sm);
	overflow: hidden;
}

.contact-address-card {
	height: 100%;
	box-shadow: 0 8px 24px rgba(0,0,0,.06);
}

.contact-map-surface {
	position: relative;
	min-height: 100%;
	border-radius: 20px;
	background: #f1f1ef url("../images/contact-map.png") center center / cover no-repeat;
	border: 1px solid rgba(32,36,31,.06);
	overflow: hidden;
}

.contact-map-surface::before {
	content: none;
}

.contact-map-pin {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 40px;
	height: 40px;
	transform: translate(-50%, -50%);
	background: url("../images/contact-pin.png") center center / contain no-repeat;
}

.contact-map-pin::after {
	content: none;
}

.contact-section {
	position: relative;
	overflow: hidden;
	padding-top: clamp(4rem, 7vw, 5.5rem);
	padding-bottom: clamp(4rem, 7vw, 5.5rem);
	background:
		radial-gradient(circle at left top, rgba(131, 207, 39, 0.1), transparent 26%),
		radial-gradient(circle at right center, rgba(32, 36, 31, 0.04), transparent 24%),
		#fff;
}

.contact-copy-column {
	max-width: 32.4375rem;
}

.contact-copy-intro {
	align-items: flex-start;
	gap: 1rem;
}

.contact-copy-intro .wp-block-heading {
	max-width: 32.4375rem;
	font-size: clamp(2.75rem, 4vw, 3rem) !important;
	line-height: 1.1 !important;
	letter-spacing: 0 !important;
	text-wrap: pretty;
}

.contact-section-badge {
	width: fit-content;
	min-height: 2rem;
	padding: 0.5rem 0.875rem;
	border-radius: 999px;
	background: #ecf8d8;
	box-shadow: inset 0 0 0 1px rgba(131, 207, 39, 0.08);
	gap: 0.5rem;
	align-items: center;
	justify-content: flex-start;
}

.contact-section-badge::before {
	content: "";
	width: 0.5625rem;
	height: 0.5625rem;
	border-radius: 50%;
	background: var(--wp--preset--color--green-primary);
	flex: 0 0 auto;
}

.contact-section-badge p,
.contact-copy-lead,
.contact-list-heading,
.contact-reviews-title,
.contact-reviews-copy,
.contact-reviews-rating,
.contact-reviews-stars {
	margin: 0;
}

.contact-copy-lead {
	max-width: 32.4375rem;
	color: #20241f;
	font-size: 1.125rem;
	font-weight: 400;
	line-height: 1.4;
}

.contact-copy-column .wp-block-separator {
	margin: 0;
	opacity: 1;
	border-color: rgba(32, 36, 31, 0.08) !important;
}

.contact-list-heading {
	font-size: 0.8125rem;
	font-weight: 800;
	line-height: 1.4;
}

.contact-quick-links,
.contact-benefits-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.95rem;
}

.contact-quick-links li,
.contact-benefits-list li {
	position: relative;
	min-height: 1.75rem;
	padding-left: 2.4rem;
	line-height: 1.5;
	color: var(--wp--preset--color--text-primary);
}

.contact-quick-links li::before,
.contact-benefits-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 1.5rem;
	height: 1.5rem;
	transform: translateY(-50%);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}

.contact-link-item--phone::before {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M21 16.42v3a2 2 0 0 1-2.18 2A19.8 19.8 0 0 1 3.58 5.18 2 2 0 0 1 5.57 3h3a2 2 0 0 1 2 1.72c.12.9.33 1.78.61 2.63a2 2 0 0 1-.45 2.11L9.46 10.73a16 16 0 0 0 3.81 3.81l1.27-1.27a2 2 0 0 1 2.11-.45c.85.28 1.73.49 2.63.61A2 2 0 0 1 21 16.42Z' stroke='%2383CF27' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.contact-link-item--mail::before {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Crect x='3' y='5' width='18' height='14' rx='3' stroke='%2383CF27' stroke-width='1.8'/%3E%3Cpath d='m6 8 5.1 4.08a1.5 1.5 0 0 0 1.88 0L18 8' stroke='%2383CF27' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.contact-benefits-list li::before {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Ccircle cx='12' cy='12' r='9' stroke='%2383CF27' stroke-width='1.8'/%3E%3Cpath d='m8.2 12.2 2.5 2.5 5.1-5.4' stroke='%2383CF27' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.contact-quick-links a {
	color: var(--wp--preset--color--text-primary);
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.4;
	text-decoration: none;
	transition: color var(--czn-transition);
}

.contact-quick-links a:hover {
	color: var(--wp--preset--color--green-primary);
}

.contact-benefits-list li {
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.4;
}

.contact-reviews-card {
	max-width: 32.5rem;
	margin-top: clamp(2rem, 4vw, 4rem);
	gap: 1rem;
	border: 1px solid rgba(32, 36, 31, 0.08);
	box-shadow: 0 22px 44px rgba(19, 24, 19, 0.04);
}

.contact-reviews-score {
	align-items: center;
	gap: 1rem;
}

.contact-reviews-stars {
	color: #f8b400;
	letter-spacing: 0.14em;
	line-height: 1;
}

.contact-reviews-rating {
	line-height: 1;
}

.contact-reviews-title {
	max-width: 22ch;
	font-size: 1.75rem;
	line-height: 1.3;
}

.contact-reviews-copy {
	max-width: 31rem;
	color: #505650;
	font-size: 1rem;
	line-height: 1.5;
}

.contact-reviews-actions {
	margin-top: 0.5rem;
}

.contact-reviews-actions .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	min-height: 3.5rem;
	padding: 0.875rem 1.5rem !important;
	border: 2px solid #3a3f39 !important;
	border-radius: 999px;
	background: transparent !important;
	box-shadow: none;
	font-size: 0.875rem !important;
	font-weight: 800 !important;
	line-height: 1.5;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #20241f !important;
	transition: transform var(--czn-transition), box-shadow var(--czn-transition), border-color var(--czn-transition);
}

.contact-reviews-actions .wp-block-button__link,
.contact-reviews-actions .wp-block-button__link span,
.contact-reviews-actions .wp-block-button__link strong,
.contact-reviews-actions .wp-block-button__link em {
	color: #20241f !important;
}

.contact-reviews-actions .wp-block-button__link:hover {
	transform: translateY(-1px);
	border-color: #20241f !important;
	box-shadow: 0 12px 24px rgba(32, 36, 31, 0.08);
}

.contact-google-icon {
	display: inline-block;
	width: 1.125rem;
	height: 1.125rem;
	flex: 0 0 1.125rem;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23EA4335' d='M12.23 10.18v3.95h5.49c-.24 1.27-.98 2.34-2.05 3.06l3.31 2.57c1.93-1.78 3.04-4.39 3.04-7.49 0-.72-.06-1.42-.19-2.09h-9.6Z'/%3E%3Cpath fill='%2334A853' d='M6.52 14.28 5.77 14.85l-2.66 2.07A9.98 9.98 0 0 0 12 22c2.7 0 4.96-.89 6.61-2.41l-3.31-2.57c-.91.61-2.07.98-3.3.98-2.61 0-4.83-1.76-5.48-4.13Z'/%3E%3Cpath fill='%234285F4' d='M3.11 7.08A9.96 9.96 0 0 0 2 12c0 1.77.46 3.43 1.27 4.92l3.25-2.64A5.98 5.98 0 0 1 6 12c0-.79.15-1.55.42-2.25L3.11 7.08Z'/%3E%3Cpath fill='%23FBBC05' d='M12 5.98c1.47 0 2.78.51 3.82 1.5l2.87-2.87C16.95 2.98 14.69 2 12 2a9.98 9.98 0 0 0-8.89 5.08l3.31 2.67C7.17 7.74 9.39 5.98 12 5.98Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.contact-form-card,
.contact-form-card--project {
	min-height: 100%;
	border: 1px solid rgba(32, 36, 31, 0.08);
	box-shadow: 0 28px 54px rgba(19, 24, 19, 0.06);
	padding: 2.5rem !important;
}

.contact-section .wpcf7 {
	margin: 0;
	width: 100%;
}

.contact-section .wpcf7-form {
	display: grid;
	gap: 1rem;
}

.contact-section .wpcf7-form > p {
	margin: 0;
}

.contact-section .wpcf7-form br {
	display: none;
}

.contact-section .wpcf7-form label {
	display: grid;
	gap: 0.625rem;
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
	line-height: 1.2;
	color: rgba(32,36,31,.9);
}

.contact-section .wpcf7-form-control-wrap {
	display: block;
	margin-top: 0;
}

.contact-section .wpcf7 input[type="text"],
.contact-section .wpcf7 input[type="email"],
.contact-section .wpcf7 input[type="tel"],
.contact-section .wpcf7 textarea {
	width: 100%;
	border: 1px solid rgba(32,36,31,.08);
	border-radius: 16px;
	background: #fff;
	padding: 16px 18px;
	font: inherit;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.4;
	color: var(--wp--preset--color--text-primary);
	transition: border-color var(--czn-transition), box-shadow var(--czn-transition), background-color var(--czn-transition);
}

.contact-section .wpcf7 input::placeholder,
.contact-section .wpcf7 textarea::placeholder {
	color: #a4a4a4;
	opacity: 1;
}

.contact-section .wpcf7 textarea {
	min-height: 118px;
	height: 118px;
	resize: vertical;
}

.contact-section .wpcf7 input[type="text"]:focus,
.contact-section .wpcf7 input[type="email"]:focus,
.contact-section .wpcf7 input[type="tel"]:focus,
.contact-section .wpcf7 textarea:focus {
	border-color: var(--wp--preset--color--green-primary);
	box-shadow: 0 0 0 4px rgba(131, 207, 39, 0.12);
	outline: none;
	background: #fff;
}

.contact-section .wpcf7 .contact-form-note {
	margin: -0.1rem 0 0.2rem;
	font-size: 0.75rem;
	line-height: 1.5;
	color: #a4a4a4;
}

.contact-section .wpcf7 .wpcf7-list-item {
	margin: 0;
}

.contact-section .wpcf7 .wpcf7-list-item label {
	display: flex;
	gap: 0.65rem;
	align-items: flex-start;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0;
	text-transform: none;
	line-height: 1.4;
	color: #20241f;
}

.contact-section .wpcf7 input[type="checkbox"] {
	appearance: none;
	width: 1rem;
	height: 1rem;
	margin: 0.1rem 0 0;
	border: 1px solid rgba(32,36,31,.18);
	border-radius: 4px;
	background: #fff;
	flex: 0 0 1rem;
	position: relative;
	cursor: pointer;
}

.contact-section .wpcf7 input[type="checkbox"]:checked {
	border-color: var(--wp--preset--color--green-primary);
	background: var(--wp--preset--color--green-primary);
}

.contact-section .wpcf7 input[type="checkbox"]:checked::after {
	content: "";
	position: absolute;
	left: 0.28rem;
	top: 0.08rem;
	width: 0.22rem;
	height: 0.48rem;
	border: solid #20241f;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.contact-section .wpcf7 input[type="submit"] {
	width: 100%;
	appearance: none;
	border: 0;
	border-radius: 999px;
	background: var(--wp--preset--color--green-primary);
	color: var(--wp--preset--color--dark);
	padding: 18px 24px;
	font-family: var(--wp--preset--font-family--primary);
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.5;
	letter-spacing: 0;
	text-transform: uppercase;
	cursor: pointer;
	transition: background-color var(--czn-transition), transform var(--czn-transition), box-shadow var(--czn-transition);
}

.site-footer-contact-shell {
	background: #ffffff;
}

.contact-section .wpcf7 input[type="submit"]:hover {
	background: var(--wp--preset--color--green-dark);
	transform: translateY(-2px);
	box-shadow: var(--czn-shadow-sm);
}

.contact-section .wpcf7-spinner {
	margin: 10px 0 0 12px;
}

.contact-section .wpcf7-response-output {
	margin: 1rem 0 0;
	padding: 0.9rem 1rem;
	border-radius: 16px;
	font-size: 0.875rem;
}

/* ==========================================================================
   13. About Page
   ========================================================================== */

/* Hero */
.about-page-hero {
	padding-top: clamp(3rem, 5.5vw, 4.75rem);
	padding-bottom: clamp(3rem, 5.5vw, 4.75rem);
}

.about-hero-content {
	width: 100%;
	align-items: center;
	text-align: center;
	gap: clamp(1.75rem, 4vw, 2.5rem);
}

.about-hero-badge {
	margin: 0 auto;
	min-height: 32px;
	padding: 0.71875rem 1rem;
	gap: 0.5rem;
	border-radius: 999px;
}

.blog-archive-section__badge.section-label,
.projects-showcase__badge.section-label,
.contact-page-badge.section-label {
	justify-content: center;
	margin: 0 auto;
	min-height: 32px;
	padding: 0.71875rem 1rem;
	gap: 0.5rem;
	border-radius: 999px;
}

.about-hero-copy {
	max-width: 846px;
	margin: 0 auto;
	align-items: center;
}

.about-hero-copy .wp-block-heading,
.about-hero-copy p {
	max-width: 846px;
	margin-left: auto;
	margin-right: auto;
}

.about-hero-copy p {
	max-width: 760px;
}

.about-hero-media-wrap {
	width: 100%;
}

.about-hero-media-surface {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	aspect-ratio: 1280 / 360;
	min-height: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #ecece8;
	border: 1px solid rgba(32, 36, 31, 0.08);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.about-hero-media-label {
	margin: 0;
}

/* ==========================================================================
   14. Service Detail Page
   ========================================================================== */

.service-page-hero {
	padding-top: clamp(3rem, 5vw, 4.5rem);
	padding-bottom: clamp(7rem, 9vw, 8.5rem);
	background: #1f1f1d;
	color: #ffffff;
	overflow: visible;
}

.service-page-hero__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: clamp(1.5rem, 3vw, 2rem);
	max-width: 980px;
}

.service-page-hero__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	margin: 0 auto;
	padding: 0.75rem 1rem;
	border: 1px solid rgba(132, 207, 40, 0.42);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.02);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.service-page-hero__badge-dot {
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 999px;
	background: var(--wp--preset--color--green-primary);
	box-shadow: 0 0 0 6px rgba(132, 207, 40, 0.12);
	flex-shrink: 0;
}

.service-page-hero__badge p {
	margin: 0;
	color: var(--wp--preset--color--green-primary);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	line-height: 1;
}

.service-page-hero h1 {
	max-width: 846px;
	margin: 0;
	color: #ffffff;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.6rem, 4.4vw, 3.5rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: 0;
	text-align: center;
	text-wrap: balance;
}

.service-page-hero__lead {
	max-width: 846px;
	margin: 0;
	color: rgba(255, 255, 255, 0.88);
	font-size: clamp(1rem, 1.6vw, 1.25rem);
	font-weight: 400;
	line-height: 1.5;
	text-align: center;
	text-wrap: pretty;
}

.service-page-hero__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}

.service-page-hero__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.875rem;
	padding: 1rem 1.75rem;
	border-radius: 999px;
	border: 1px solid transparent;
	font-size: 0.95rem;
	font-weight: 800;
	letter-spacing: 0;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform var(--czn-transition), background-color var(--czn-transition), border-color var(--czn-transition), color var(--czn-transition), box-shadow var(--czn-transition);
}

.service-page-hero__button:hover,
.service-page-hero__button:focus-visible {
	transform: translateY(-2px);
	outline: none;
}

.service-page-hero__button--primary {
	background: var(--wp--preset--color--green-primary);
	color: #161616;
	box-shadow: 0 10px 24px rgba(132, 207, 40, 0.2);
}

.service-page-hero__button--primary:hover,
.service-page-hero__button--primary:focus-visible {
	background: var(--wp--preset--color--green-dark);
	color: #161616;
	box-shadow: 0 16px 28px rgba(132, 207, 40, 0.24);
}

.service-page-hero__button--secondary {
	border-color: rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.02);
	color: #ffffff;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.service-page-hero__button--secondary:hover,
.service-page-hero__button--secondary:focus-visible {
	border-color: rgba(255, 255, 255, 0.28);
	background: rgba(255, 255, 255, 0.06);
	color: #ffffff;
}

.service-page-hero-media-bridge {
	position: relative;
	z-index: 2;
	margin-top: clamp(-4.5rem, -6vw, -6.5rem);
	background: transparent;
}

.service-page-hero-media-bridge .service-page-hero__media-wrap {
	position: relative;
	z-index: 2;
}

.service-page-hero__media-wrap {
	width: 100%;
	margin-top: 0;
}

.service-page-hero__media {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	border-radius: 24px;
	overflow: hidden;
	background: #dadbd4;
	box-shadow: 0 20px 40px rgba(11, 11, 11, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.service-page-hero__media img {
	display: block;
	width: 100%;
	aspect-ratio: 1280 / 360;
	object-fit: cover;
	object-position: center;
}

.service-audience-section {
	padding-top: clamp(4rem, 6vw, 5.5rem);
	padding-bottom: clamp(4.5rem, 6vw, 6rem);
	background: #ffffff;
}

.service-audience-section__inner {
	display: grid;
	grid-template-columns: minmax(300px, 452px) minmax(0, 1fr);
	align-items: start;
	gap: clamp(2.25rem, 4vw, 3.5rem);
}

.service-audience-section__media {
	overflow: hidden;
	border-radius: 24px;
	background: #eef0e6;
	box-shadow: 0 8px 30px rgba(31, 31, 29, 0.06);
}

.service-audience-section__media img {
	display: block;
	width: 100%;
	aspect-ratio: 452 / 420;
	object-fit: cover;
	object-position: center;
}

.service-audience-section__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1.5rem;
	padding-top: 0.375rem;
}

.service-audience-section__content h2 {
	margin: 0;
	max-width: 11ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.25rem, 3.8vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: 0;
}

.service-audience-section__lead {
	margin: 0;
	color: #20241f;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.45;
}

.service-audience-section__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
	max-width: 34rem;
}

.service-audience-section__list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin: 0;
	color: #20241f;
	font-size: 1.125rem;
	font-weight: 500;
	line-height: 1.4;
}

.service-audience-section__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.125rem;
	height: 1.125rem;
	margin-top: 0.2rem;
	color: var(--wp--preset--color--green-primary);
	flex-shrink: 0;
}

.service-audience-section__icon svg {
	width: 100%;
	height: 100%;
	stroke: currentColor;
	stroke-width: 1.7;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.service-audience-section__note {
	width: min(100%, 604px);
	margin-top: 0.5rem;
	margin-left: -6rem;
	padding: 24px 32px;
	border-radius: 16px;
	background: #edffe6;
	box-shadow: 0 12px 28px rgba(132, 207, 40, 0.08);
}

.service-audience-section__note p {
	margin: 0;
	color: #20241f;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.4;
}

.service-benefits-section {
	padding-top: clamp(4.5rem, 6vw, 5.75rem);
	padding-bottom: clamp(4.5rem, 6vw, 5.75rem);
	background: #f8f8f6;
}

.service-benefits-section__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(2rem, 4vw, 3rem);
}

.service-benefits-section__intro {
	max-width: 628px;
	text-align: center;
}

.service-benefits-section__intro h2 {
	margin: 0;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.25rem, 3.8vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: 0;
	text-wrap: balance;
}

.service-benefits-section__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1.125rem;
	width: 100%;
}

.service-benefits-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	min-height: 226px;
	padding: 2rem 1.5rem 1.75rem;
	border-radius: 20px;
	background: #ffffff;
	box-shadow: 0 10px 30px rgba(32, 36, 31, 0.04);
	border: 1px solid rgba(32, 36, 31, 0.04);
}

.service-benefits-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	margin-bottom: 1.5rem;
	color: var(--wp--preset--color--green-primary);
	flex-shrink: 0;
}

.service-benefits-card__icon svg {
	width: 100%;
	height: 100%;
	stroke: currentColor;
	stroke-width: 1.55;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.service-benefits-card h3 {
	margin: 0;
	color: #20241f;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0;
	text-wrap: balance;
}

.service-benefits-card p {
	margin: 0.875rem 0 0;
	color: #a9aaa4;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.35;
	letter-spacing: 0;
	text-wrap: pretty;
}

.service-deliverables-section {
	padding-top: clamp(4.5rem, 6vw, 5.75rem);
	padding-bottom: clamp(4.5rem, 6vw, 5.75rem);
	background: #ffffff;
}

.service-deliverables-section__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 454px);
	align-items: center;
	gap: clamp(2.5rem, 4vw, 4rem);
}

.service-deliverables-section__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1.5rem;
	max-width: 35rem;
}

.service-deliverables-section__content h2 {
	margin: 0;
	max-width: 13.5ch;
	color: #20241f;
	font-family: var(--wp--preset--font-family--primary);
	font-size: clamp(2.25rem, 3.8vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: 0;
	text-wrap: balance;
}

.service-deliverables-section__lead {
	margin: 0;
	color: #20241f;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.45;
}

.service-deliverables-section__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
	max-width: 37rem;
}

.service-deliverables-section__list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin: 0;
	color: #20241f;
	font-size: 1.125rem;
	font-weight: 500;
	line-height: 1.4;
}

.service-deliverables-section__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.125rem;
	height: 1.125rem;
	margin-top: 0.2rem;
	color: var(--wp--preset--color--green-primary);
	flex-shrink: 0;
}

.service-deliverables-section__icon svg {
	width: 100%;
	height: 100%;
	stroke: currentColor;
	stroke-width: 1.7;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.service-deliverables-section__media {
	overflow: hidden;
	border-radius: 24px;
	background: #eef0e6;
	box-shadow: 0 8px 30px rgba(31, 31, 29, 0.06);
}

.service-deliverables-section__media img {
	display: block;
	width: 100%;
	aspect-ratio: 454 / 422;
	object-fit: cover;
	object-position: center;
}



/* Intro – 2-column text */
.about-intro-section {
	border-top: 0;
}

.about-intro-copy {
	gap: 1.5rem;
}

.about-intro-copy p {
	margin: 0;
}

/* Stats section */
.about-stats-section {
	border-top: 1px solid rgba(32, 36, 31, 0.07);
	border-bottom: 1px solid rgba(32, 36, 31, 0.07);
}

.about-stats-grid .about-stat-item {
	padding: 0;
}

.about-stat-item {
	position: relative;
}

.about-stat-item + .about-stat-item::before {
	content: none;
}

.about-stat-number {
	margin: 0;
}

/* Story / Vision / Mission */
.about-story-section {
	background: var(--wp--preset--color--white);
}

.about-story-layout,
.about-story-top-row {
	gap: 16px;
}

.about-story-layout {
	display: grid !important;
	grid-template-columns: minmax(280px, 360px) minmax(0, 1fr) !important;
	align-items: stretch;
	gap: 16px;
}

.about-story-layout > .wp-block-column:first-child {
	grid-column: 1;
}

.about-story-layout > .wp-block-column:last-child {
	grid-column: 2;
	min-width: 0;
}

.about-founder-card {
	position: relative;
	height: 100%;
	min-height: 420px;
	border-radius: 28px;
	overflow: hidden;
	background: #dbe6ef;
	box-shadow: 0 28px 60px rgba(18, 24, 28, 0.12);
	display: block;
}

.about-founder-media,
.about-founder-media img,
.about-founder-media--placeholder {
	display: block;
	width: 100%;
	height: 100%;
}

.about-founder-media {
	position: relative;
	margin: 0;
	display: block;
	height: 100%;
	min-height: 420px;
	border-radius: 28px;
	overflow: hidden;
}

.about-founder-media img {
	object-fit: cover;
	object-position: center top;
}

.about-founder-media--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	background: linear-gradient(180deg, #dbe6ef 0%, #bcc8d1 100%);
	color: rgba(22, 22, 22, 0.65);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
	text-transform: uppercase;
}

.about-founder-card::after {
	content: "";
	position: absolute;
	inset: 45% 0 0;
	background: linear-gradient(180deg, rgba(20, 25, 28, 0) 0%, rgba(20, 25, 28, 0.84) 72%, rgba(20, 25, 28, 0.96) 100%);
	pointer-events: none;
}

.about-founder-media::after {
	content: "";
	position: absolute;
	inset: 48% 0 0;
	background: linear-gradient(180deg, rgba(20, 25, 28, 0) 0%, rgba(20, 25, 28, 0.82) 70%, rgba(20, 25, 28, 0.96) 100%);
	pointer-events: none;
	z-index: 1;
}

.about-founder-overlay {
	position: absolute;
	left: 22px;
	right: 22px;
	bottom: 20px;
	z-index: 2;
	color: #fff;
	pointer-events: none;
}

.about-founder-name,
.about-founder-role {
	margin: 0;
}

.about-founder-name {
	font-size: clamp(1.6rem, 2vw, 2rem);
	font-weight: 700;
	line-height: 1.1;
}

.about-founder-role {
	margin-top: 0.35rem;
	color: rgba(255, 255, 255, 0.76);
	font-size: 0.95rem;
	line-height: 1.35;
}

.about-story-content {
	height: 100%;
	width: 100%;
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	grid-template-areas:
		"vision mission"
		"history history";
	gap: 16px;
	align-items: stretch !important;
}

.about-story-top-row {
	display: contents !important;
	width: 100%;
}

.about-story-top-row > .wp-block-column {
	min-width: 0;
}

.about-story-top-row > .wp-block-column:first-child {
	grid-area: vision;
}

.about-story-top-row > .wp-block-column:last-child {
	grid-area: mission;
}

.about-vision-card,
.about-mission-card,
.about-history-card--light {
	height: 100%;
	border: 1px solid rgba(131, 207, 39, 0.1);
	box-shadow: none;
}

.about-vision-card,
.about-mission-card {
	background: #f2ffd7;
}

.about-mission-card {
	background: #edffe6;
}

.about-history-card--light {
	background: #f5f5f5;
	border-color: rgba(32, 36, 31, 0.04);
	grid-area: history;
	width: 100%;
	align-self: stretch;
	display: flex;
}

.about-vision-card .wp-block-heading,
.about-mission-card .wp-block-heading,
.about-history-card--light .wp-block-heading {
	margin: 0;
}

.about-vision-card p:not(.wp-block-heading),
.about-mission-card p:not(.wp-block-heading),
.about-history-card--light p:not(.wp-block-heading) {
	margin: 0;
}

/* Approach / CTA section */
.about-approach-section {
	background: #fff;
}

.about-approach-layout {
	gap: clamp(2rem, 5vw, 4.5rem);
}

.about-approach-copy {
	max-width: 31rem;
}

.about-approach-copy .wp-block-heading,
.about-approach-copy p {
	margin: 0;
}

.about-approach-stats {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 2.75rem 3.5rem;
}

.about-approach-stats--plain {
	background: transparent;
	border: 0;
	padding: 0 !important;
}

.about-approach-stat--plain {
	background: transparent !important;
	padding: 0 !important;
	box-shadow: none;
	border: 0;
}

.about-approach-stat-number {
	margin: 0;
}

.about-approach-stat--plain p:last-child {
	margin: 0;
}

.about-approach-stat--plain .has-text-primary-color {
	max-width: 17rem;
}

/* Stats dividers */
@media (min-width: 782px) {
	.about-stats-grid > .wp-block-column + .wp-block-column {
		border-left: 1px solid rgba(32,36,31,0.08);
		padding-left: var(--wp--preset--spacing--50);
	}
}

/* Responsive */
@media (max-width: 768px) {
	.about-story-layout {
		display: block !important;
	}

	.about-story-content {
		display: grid !important;
		grid-template-columns: 1fr;
		grid-template-areas:
			"vision"
			"mission"
			"history";
	}

	.about-story-top-row {
		display: grid !important;
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.about-story-top-row > .wp-block-column:first-child,
	.about-story-top-row > .wp-block-column:last-child {
		grid-area: auto;
	}

	.about-hero-copy {
		max-width: 100%;
	}

	.about-hero-copy .wp-block-heading {
		max-width: 34rem;
	}

	.about-hero-copy p {
		max-width: 32rem;
	}

	.about-hero-media-surface {
		aspect-ratio: 16 / 7;
		min-height: 240px !important;
	}

	.service-page-hero {
		padding-top: 2.75rem;
		padding-bottom: 5.5rem;
	}

	.service-page-hero-media-bridge {
		margin-top: -3.5rem;
	}

	.service-page-hero__inner {
		gap: 1.25rem;
	}

	.service-page-hero h1 {
		max-width: 12ch;
		font-size: clamp(2.35rem, 8vw, 3rem);
	}

	.service-page-hero__lead {
		max-width: 38rem;
	}

	.service-page-hero__actions {
		width: 100%;
		flex-direction: column;
		align-items: stretch;
	}

	.service-page-hero__button {
		width: 100%;
	}

	.service-page-hero__media {
		border-radius: 20px;
	}

	.service-page-hero__media img {
		aspect-ratio: 16 / 8.8;
	}

	.service-audience-section {
		padding-top: 3.5rem;
		padding-bottom: 4rem;
	}

	.service-audience-section__inner {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.service-audience-section__media {
		max-width: 34rem;
	}

	.service-audience-section__content h2 {
		max-width: 11ch;
	}

	.service-audience-section__list {
		max-width: 100%;
	}

	.service-audience-section__note {
		margin-left: 0;
	}

	.service-benefits-section {
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.service-benefits-section__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.service-benefits-card {
		min-height: 0;
	}

	.service-deliverables-section {
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.service-deliverables-section__inner {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.service-deliverables-section__content {
		max-width: 100%;
	}

	.service-deliverables-section__media {
		max-width: 34rem;
	}

	.about-stats-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.about-approach-stats {
		gap: 2rem 2.25rem;
	}

	.about-story-layout,
	.about-story-top-row,
	.about-approach-layout {
		gap: 1rem;
	}
}

@media (max-width: 480px) {
	.about-hero-badge {
		padding: 0.55rem 0.9rem;
	}

	.about-hero-copy .wp-block-heading {
		max-width: 17rem;
	}

	.about-hero-copy p {
		max-width: 19rem;
	}

	.about-hero-media-surface {
		aspect-ratio: 16 / 8;
		min-height: 180px !important;
		border-radius: 20px !important;
	}

	.service-page-hero {
		padding-top: 2.25rem;
		padding-bottom: 4.75rem;
	}

	.service-page-hero-media-bridge {
		margin-top: -2.75rem;
	}

	.service-page-hero__badge {
		padding: 0.65rem 0.9rem;
	}

	.service-page-hero h1 {
		font-size: 2.25rem;
		max-width: 10ch;
	}

	.service-page-hero__lead {
		font-size: 1rem;
		line-height: 1.6;
	}

	.service-page-hero__button {
		min-height: 3.5rem;
		padding: 0.95rem 1.2rem;
		font-size: 0.82rem;
	}

	.service-page-hero__media img {
		aspect-ratio: 4 / 3;
	}

	.service-audience-section__media {
		border-radius: 20px;
	}

	.service-audience-section__media img {
		aspect-ratio: 4 / 4.1;
	}

	.service-audience-section__content {
		gap: 1.25rem;
	}

	.service-audience-section__content h2 {
		font-size: 2.25rem;
	}

	.service-audience-section__lead {
		font-size: 1rem;
	}

	.service-audience-section__list li {
		font-size: 1rem;
	}

	.service-audience-section__note {
		padding: 1.25rem 1.125rem;
		border-radius: 14px;
	}

	.service-audience-section__note p {
		font-size: 0.95rem;
	}

	.service-benefits-section__intro h2 {
		font-size: 2.25rem;
	}

	.service-benefits-section__grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.service-benefits-card {
		padding: 1.75rem 1.125rem 1.5rem;
		border-radius: 18px;
	}

	.service-benefits-card__icon {
		margin-bottom: 1.25rem;
	}

	.service-benefits-card h3 {
		font-size: 1.125rem;
	}

	.service-benefits-card p {
		font-size: 0.95rem;
	}

	.service-deliverables-section__content h2 {
		font-size: 2.25rem;
	}

	.service-deliverables-section__lead {
		font-size: 1rem;
	}

	.service-deliverables-section__list li {
		font-size: 1rem;
	}

	.service-deliverables-section__media {
		border-radius: 20px;
	}

	.service-deliverables-section__media img {
		aspect-ratio: 4 / 4.1;
	}

	.about-stats-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.about-approach-stats {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 1.5rem 1.25rem;
	}
}

/* ==========================================================================
   14. Footer
   ========================================================================== */

.site-footer {
	border-top: 1px solid rgba(0,0,0,.06);
}

.footer-brand-logo {
	margin: 0;
}

.footer-brand-logo img {
	display: block;
	width: min(218px, 100%);
	height: auto;
}

.footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-links li {
	padding: 4px 0;
}

.footer-links a {
	color: var(--wp--preset--color--text-primary);
	text-decoration: none;
	font-size: 0.875rem;
	transition: color var(--czn-transition);
}

.footer-links a:hover {
	color: var(--wp--preset--color--green-primary);
}

/* ==========================================================================
   15. Realization Arrow Buttons
   ========================================================================== */

.arrow-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--wp--preset--color--green-primary);
	color: var(--wp--preset--color--dark);
	text-decoration: none;
	transition: background-color var(--czn-transition), transform var(--czn-transition);
	flex-shrink: 0;
}

.arrow-btn:hover {
	background: var(--wp--preset--color--green-dark);
	transform: scale(1.05);
}

/* ==========================================================================
   16. Section Spacing Helpers
   ========================================================================== */

.section-inner {
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1.5rem, 5vw, 5rem);
	padding-right: clamp(1.5rem, 5vw, 5rem);
}

/* ==========================================================================
   17. Responsive
   ========================================================================== */

@media (max-width: 768px) {
	.site-header {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}

	.homepage-hero {
		min-height: 640px;
		background-position: center center;
	}

	.homepage-hero__inner {
		min-height: 640px;
		padding-top: 7rem;
		padding-bottom: 7rem;
	}

	.homepage-hero__content {
		align-items: flex-start;
		text-align: left;
	}

	.homepage-hero__actions {
		justify-content: flex-start;
	}

	.homepage-hero__scroll {
		bottom: 2.5rem;
	}

	.services-showcase {
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.services-showcase__intro h2 {
		max-width: 11ch;
		font-size: clamp(2.25rem, 6vw, 3rem);
	}

	.services-showcase__tabs {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.services-showcase__panel {
		grid-template-columns: 1fr;
		gap: 1.75rem;
	}

	.services-showcase__media {
		min-height: 18rem;
	}

	.services-showcase__content h3,
	.services-showcase__copy {
		max-width: 100%;
	}

	.video-showcase {
		padding-top: 3.5rem;
		padding-bottom: 1.25rem;
	}

	.video-showcase__intro h2 {
		font-size: clamp(2.2rem, 6vw, 3rem);
	}

	.video-showcase__frame {
		border-radius: 1rem;
	}

	.process-section {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.process-card {
		padding: 2.5rem 1.5rem 2.75rem;
		border-radius: 1.5rem;
	}

	.process-card__intro h2 {
		font-size: clamp(2.15rem, 6vw, 2.85rem);
	}

	.process-workflow {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.75rem 1rem;
	}

	.process-workflow__connector {
		display: none;
	}

	.process-workflow__step h3 {
		max-width: 13ch;
		font-size: 1.28rem;
	}

	.process-card__actions {
		margin-top: 2.25rem;
	}

	.projects-showcase {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.projects-showcase__intro h2 {
		font-size: clamp(2.2rem, 6vw, 3rem);
	}

	.projects-showcase__filters {
		flex-direction: column;
		align-items: stretch;
	}

	.projects-showcase__filter-group--media {
		margin-left: 0;
		justify-content: flex-start;
	}

	.projects-showcase__grid {
		grid-template-columns: 1fr;
	}

	.project-card,
	.project-card--featured,
	.project-card--stacked {
		grid-row: auto;
		min-height: 22rem;
	}

	.cta-gradient-section {
		padding-bottom: 3.5rem;
	}

	.cta-gradient-section__inner {
		grid-template-columns: minmax(26rem, 1fr) max-content;
		gap: 1.25rem;
	}

	.cta-gradient-section__actions {
		justify-content: flex-end;
		gap: 0.7rem;
	}

	.experience-showcase {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.experience-showcase__inner {
		grid-template-columns: 1fr;
		gap: 1.75rem;
	}

	.experience-showcase__media {
		min-height: 24rem;
	}

	.experience-showcase__content h2 {
		max-width: 11ch;
		font-size: clamp(2.3rem, 6vw, 3.2rem);
	}

	.experience-showcase__card--vision,
	.experience-showcase__card--work {
		margin-left: 0;
		margin-right: 0;
	}

	.latest-posts-section {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.latest-posts-section__intro h2 {
		font-size: clamp(2.3rem, 6vw, 3.2rem);
	}

	.blog-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.local-company-showcase {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.local-company-showcase__inner {
		grid-template-columns: 1fr 1fr;
		gap: 1rem;
	}

	.local-company-showcase__intro {
		grid-column: 1 / -1;
		padding-right: 0;
	}

	.local-company-showcase__intro h2 {
		max-width: 10ch;
		font-size: clamp(2.4rem, 6vw, 3.4rem);
	}

	.local-company-showcase__intro p {
		max-width: 34rem;
	}

	.faq-home-section {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.faq-home-section__inner {
		grid-template-columns: 1fr;
		gap: 1.75rem;
	}

	.faq-home-section__intro h2 {
		max-width: 25.6875rem;
		font-size: clamp(2.4rem, 5vw, 3rem);
	}

	.other-brands-showcase {
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.other-brands-showcase__intro h2 {
		font-size: clamp(2.3rem, 6vw, 3.2rem);
	}

	.other-brands-showcase__grid {
		grid-template-columns: 1fr;
	}

	.testimonials-section__inner {
		grid-template-columns: 1fr;
		margin-top: 0;
		padding-top: 2rem;
	}

	.testimonials-section {
		--testimonial-card-width: 18.75rem;
	}

	.testimonials-section__intro {
		padding-bottom: 0;
	}

	.testimonials-section__intro h2 {
		max-width: 14ch;
	}

	.testimonials-section__reviews {
		margin-right: -1rem;
		padding-right: 1rem;
	}

	.wp-block-columns.is-not-stacked-on-mobile {
		flex-direction: column !important;
	}

	.wp-block-column {
		flex-basis: 100% !important;
	}

	.contact-form-card,
	.contact-reviews-card,
	.contact-address-card,
	.contact-map-showcase {
		padding: 40px !important;
	}

	.contact-map-surface {
		min-height: 280px;
	}

	.contact-copy-column,
	.contact-reviews-card {
		max-width: 100%;
	}

	.contact-copy-lead {
		max-width: 100%;
		font-size: 1.0625rem !important;
	}

	.contact-quick-links a {
		font-size: clamp(1.2rem, 5vw, 1.5rem);
	}

	.contact-benefits-list li {
		font-size: 1.0625rem;
	}

	.contact-reviews-card {
		margin-top: 1rem;
	}

	.contact-reviews-title {
		font-size: 1.375rem !important;
	}

	.contact-reviews-actions .wp-block-button__link {
		width: 100%;
	}

	.about-approach-stats {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.about-vision-card,
	.about-mission-card,
	.about-history-card,
	.about-history-card--light {
		padding: 1.75rem !important;
	}
}

@media (max-width: 480px) {
	.site-header .wp-block-buttons {
		display: none; /* hide CTA button on very small screens */
	}

	.homepage-hero {
		min-height: 590px;
	}

	.homepage-hero__inner {
		min-height: 590px;
		padding-top: 6.5rem;
		padding-bottom: 5.5rem;
	}

	.homepage-hero__content {
		gap: 1.125rem;
	}

	.homepage-hero__content h1 {
		max-width: 11ch;
		font-size: clamp(2.3rem, 11vw, 3.1rem);
	}

	.homepage-hero__lead {
		font-size: 0.98rem;
		line-height: 1.5;
	}

	.homepage-hero__actions {
		width: 100%;
		gap: 0.75rem;
	}

	.homepage-hero__button {
		width: 100%;
		min-height: 3.5rem;
		padding: 0.95rem 1.2rem;
		font-size: 0.82rem;
	}

	.homepage-hero__scroll {
		display: none;
	}

	.services-showcase {
		padding-top: 3.25rem;
		padding-bottom: 3.5rem;
	}

	.services-showcase__intro {
		gap: 0.85rem;
	}

	.services-showcase__intro h2 {
		font-size: clamp(2rem, 10vw, 2.65rem);
	}

	.services-showcase__intro > p {
		font-size: 0.95rem;
		line-height: 1.55;
	}

	.services-showcase__tabs {
		grid-template-columns: 1fr;
		gap: 0.75rem;
	}

	.services-showcase__tab {
		min-height: 5.15rem;
		gap: 0.65rem;
		padding: 0.95rem 0.9rem;
	}

	.services-showcase__tab-label {
		font-size: 0.96rem;
	}

	.services-showcase__tab.is-active::after {
		bottom: -0.42rem;
	}

	.services-showcase__media {
		min-height: 14rem;
	}

	.services-showcase__content {
		gap: 0.8rem;
		padding-top: 0;
	}

	.services-showcase__content h3 {
		font-size: clamp(1.8rem, 8vw, 2.35rem);
	}

	.services-showcase__copy {
		font-size: 0.95rem;
		line-height: 1.55;
	}

	.services-showcase__cta {
		width: 100%;
		font-size: 0.74rem;
	}

	.video-showcase {
		padding-top: 3rem;
		padding-bottom: 1rem;
	}

	.video-showcase__intro {
		gap: 0.85rem;
	}

	.video-showcase__intro h2 {
		font-size: clamp(2rem, 10vw, 2.7rem);
	}

	.video-showcase__intro p {
		font-size: 0.95rem;
		line-height: 1.55;
	}

	.video-showcase__frame {
		border-radius: 0.9rem;
	}

	.video-showcase__play {
		width: 3.8rem;
		height: 3.8rem;
	}

	.video-showcase__play svg {
		width: 1.35rem;
		height: 1.35rem;
	}

	.process-section {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.process-card {
		padding: 2rem 1.1rem 2.25rem;
		border-radius: 1.25rem;
	}

	.process-card__intro {
		gap: 0.85rem;
	}

	.process-card__intro h2 {
		font-size: clamp(2rem, 10vw, 2.6rem);
	}

	.process-workflow {
		grid-template-columns: 1fr;
		gap: 1.5rem;
		margin-top: 2rem;
	}

	.process-workflow__step {
		gap: 0.7rem;
	}

	.process-workflow__label {
		font-size: 0.82rem;
	}

	.process-workflow__step h3 {
		max-width: 100%;
		font-size: 1.18rem;
	}

	.process-card__actions {
		margin-top: 2rem;
	}

	.process-card__cta {
		width: 100%;
		font-size: 0.76rem;
	}

	.projects-showcase {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.projects-showcase__intro {
		gap: 0.85rem;
	}

	.projects-showcase__intro h2 {
		font-size: clamp(2rem, 10vw, 2.8rem);
	}

	.projects-showcase__intro p {
		font-size: 0.95rem;
		line-height: 1.55;
	}

	.projects-showcase__filter-group {
		gap: 0.65rem;
	}

	.projects-showcase__filter {
		width: 100%;
		font-size: 0.86rem;
	}

	.projects-showcase__grid {
		gap: 0.9rem;
	}

	.project-card,
	.project-card--featured,
	.project-card--stacked {
		min-height: 17rem;
		border-radius: 1.1rem;
	}

	.project-card__content {
		left: 1rem;
		right: 5rem;
		bottom: 1rem;
	}

	.project-card__content h3 {
		font-size: 1.5rem;
	}

	.project-card__arrow {
		right: 1rem;
		bottom: 1rem;
		width: 3.4rem;
		height: 3.4rem;
		border-radius: 1rem;
	}

	.cta-gradient-section {
		padding-bottom: 3rem;
	}

	.cta-gradient-section__inner {
		grid-template-columns: 1fr;
		padding: 1.5rem 1rem;
		border-radius: 1.1rem;
	}

	.cta-gradient-section__content {
		gap: 0.85rem;
	}

	.cta-gradient-section__content h2 {
		max-width: 100%;
		font-size: clamp(2rem, 9vw, 2.75rem);
	}

	.cta-gradient-section__content p {
		font-size: 0.95rem;
		line-height: 1.5;
	}

	.cta-gradient-section__actions {
		width: 100%;
		gap: 0.75rem;
	}

	.cta-gradient-section__button {
		width: 100%;
		min-height: 3.35rem;
		font-size: 0.76rem;
	}

	.experience-showcase {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.experience-showcase__media {
		min-height: 18rem;
		border-radius: 1.2rem;
	}

	.experience-showcase__content {
		gap: 1rem;
	}

	.experience-showcase__content h2 {
		max-width: 100%;
		font-size: clamp(2rem, 10vw, 2.85rem);
	}

	.experience-showcase__lead {
		font-size: 0.96rem;
		line-height: 1.55;
	}

	.experience-showcase__cards {
		gap: 0.75rem;
	}

	.experience-showcase__card {
		padding: 1.1rem 1rem;
		border-radius: 0.95rem;
	}

	.experience-showcase__card h3 {
		font-size: 1.3rem;
	}

	.experience-showcase__card p {
		font-size: 0.92rem;
	}

	.latest-posts-section {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.latest-posts-section__intro {
		gap: 0.85rem;
	}

	.latest-posts-section__intro h2 {
		max-width: 100%;
		font-size: clamp(2rem, 10vw, 2.85rem);
	}

	.blog-list {
		grid-template-columns: 1fr;
		gap: 0.9rem;
	}

	.blog-entry-card__tag {
		left: 0.75rem;
		bottom: 0.75rem;
		font-size: 0.78rem;
	}

	.blog-entry-card__body {
		padding: 0.95rem 0.9rem 1.1rem;
		gap: 0.75rem;
	}

	.blog-entry-card h3 {
		font-size: 1.18rem;
	}

	.blog-entry-card__excerpt {
		font-size: 0.92rem;
	}

	.blog-entry-card__cta {
		font-size: 0.8rem;
	}

	.local-company-showcase {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.local-company-showcase__inner {
		grid-template-columns: 1fr;
	}

	.local-company-showcase__intro {
		gap: 1rem;
	}

	.local-company-showcase__intro h2 {
		max-width: 100%;
		font-size: clamp(2rem, 10vw, 3rem);
	}

	.local-company-showcase__intro p {
		max-width: 100%;
		font-size: 0.96rem;
		line-height: 1.55;
	}

	.local-company-showcase__button {
		width: 100%;
		font-size: 0.76rem;
	}

	.local-company-showcase__cards {
		gap: 0.8rem;
	}

	.local-company-showcase__card {
		padding: 1.4rem 1rem;
		border-radius: 1rem;
	}

	.local-company-showcase__card h3 {
		font-size: 1.45rem;
	}

	.local-company-showcase__card p {
		font-size: 0.92rem;
	}

	.faq-home-section {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.faq-home-section__intro {
		gap: 0.85rem;
	}

	.faq-home-section__intro h2 {
		max-width: 100%;
		font-size: clamp(2.1rem, 10vw, 2.6rem);
	}

	.faq-home-section__list {
		gap: 0.75rem;
	}

	.faq-home-item {
		border-radius: 1.35rem;
	}

	.faq-home-item summary {
		padding: 1.2rem 3.75rem 1.2rem 1.2rem;
		font-size: 1.05rem;
	}

	.faq-home-item summary::before,
	.faq-home-item summary::after {
		right: 1.3rem;
	}

	.faq-home-item__content {
		padding: 0 1.2rem 1.2rem;
	}

	.faq-home-item__content p {
		font-size: 0.94rem;
		line-height: 1.55;
	}

	.other-brands-showcase {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.other-brands-showcase__intro {
		gap: 0.85rem;
	}

	.other-brands-showcase__intro h2 {
		max-width: 100%;
		font-size: clamp(2rem, 10vw, 2.85rem);
	}

	.other-brands-showcase__intro p {
		font-size: 0.95rem;
		line-height: 1.55;
	}

	.brand-card {
		grid-template-columns: 1fr;
		min-height: 0;
		border-radius: 1.2rem;
	}

	.brand-card__media {
		min-height: 15rem;
	}

	.brand-card__content {
		padding: 1.2rem 1rem 1.1rem;
		gap: 0.85rem;
	}

	.brand-card__logo {
		max-width: 14rem;
		max-height: 2.6rem;
	}

	.brand-card__content h3 {
		font-size: 1.12rem;
	}

	.brand-card__content p {
		font-size: 0.92rem;
	}

	.brand-card__button {
		width: 100%;
		font-size: 0.76rem;
	}

	.testimonials-section {
		--testimonial-card-width: 17.75rem;
		padding-bottom: 3rem;
	}

	.testimonials-section__intro h2 {
		font-size: clamp(2rem, 9vw, 2.45rem);
	}

	.testimonials-section__google-link {
		width: 100%;
		font-size: 0.72rem;
	}

	.testimonial-card {
		padding: 0.95rem;
	}

	.contact-section,
	.contact-page-hero,
	.about-page-hero,
	.about-intro-section,
	.about-stats-section,
	.about-story-section,
	.about-approach-section {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}

	.contact-section-badge {
		padding: 0.45rem 0.8rem;
	}

	.contact-copy-intro .wp-block-heading {
		font-size: 36px !important;
	}

	.contact-quick-links li,
	.contact-benefits-list li {
		padding-left: 2.1rem;
	}

	.contact-quick-links li::before,
	.contact-benefits-list li::before {
		width: 1.25rem;
		height: 1.25rem;
	}

	.contact-benefits-list li {
		font-size: 1rem;
	}

	.contact-reviews-score {
		gap: 0.75rem;
	}

	.contact-reviews-stars {
		font-size: 1.35rem !important;
	}

	.contact-reviews-rating {
		font-size: 1.75rem !important;
	}

	.contact-reviews-card,
	.contact-form-card {
		padding: 1.5rem !important;
	}
}

@media (max-width: 900px) {
	.blog-archive-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 768px) {
	.cta-gradient-section__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.cta-gradient-section__button {
		width: 100%;
	}

	.blog-archive-section {
		padding-top: 3.5rem;
		padding-bottom: 3.75rem;
	}

	.blog-archive-section__intro h1 {
		font-size: clamp(2.3rem, 9vw, 3rem);
		max-width: 12ch;
	}

	.blog-archive-section__intro p {
		font-size: 1rem;
	}

	.blog-archive-grid {
		grid-template-columns: 1fr;
	}

	.blog-archive-pagination {
		gap: 0.5rem;
	}

	.blog-archive-pagination__item .page-numbers {
		min-width: 2.75rem;
		min-height: 2.75rem;
		padding: 0.55rem 0.8rem;
	}

	.blog-archive-pagination__item.is-current .page-numbers {
		padding: calc(0.55rem - 1px) calc(0.8rem - 1px);
	}

	.blog-cta-section {
		padding-bottom: 3.75rem;
	}

	.blog-cta-section__inner {
		padding: 2.75rem 1.5rem;
	}

	.blog-cta-section__content h2 {
		font-size: 1.75rem;
	}
}

@media (max-width: 480px) {
	.blog-archive-section__filters {
		gap: 0.625rem;
	}

	.blog-archive-section__filter {
		min-height: 2.7rem;
		padding: 0.7rem 0.95rem;
		font-size: 0.9rem;
	}

	.blog-archive-section__filter.is-active {
		padding: calc(0.7rem - 1px) calc(0.95rem - 1px);
	}

	.blog-archive-card__body {
		padding: 0.95rem 0.95rem 1.05rem;
	}

	.blog-archive-card__tag {
		left: 0.85rem;
		bottom: 0.85rem;
		font-size: 0.84rem;
	}

	.blog-archive-card__date,
	.blog-archive-card__excerpt,
	.blog-archive-card__cta {
		font-size: 0.9rem;
	}

	.blog-cta-section__inner {
		padding: 2.25rem 1.125rem;
		border-radius: 20px;
	}

	.blog-cta-section__content h2 {
		font-size: 1.55rem;
	}

	.blog-cta-section__content p {
		font-size: 0.95rem;
	}

	.blog-cta-section__button {
		min-width: 100%;
	}
}

/* ==========================================================================
   18. Accessibility
   ========================================================================== */

:focus-visible {
	outline: 3px solid var(--wp--preset--color--green-primary);
	outline-offset: 3px;
	border-radius: 4px;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

/* ==========================================================================
   19. WordPress Core Block Overrides
   ========================================================================== */

/* Remove default list indentation in nav/footer */
.wp-block-navigation ul,
.wp-block-navigation ol {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Separator color fix */
.wp-block-separator.has-alpha-channel-opacity {
	opacity: 1;
	border-color: rgba(0,0,0,.10) !important;
}

/* Query loop cards spacing */
.wp-block-query .wp-block-post-template {
	gap: var(--wp--preset--spacing--50) !important;
}

/* Pagination */
.wp-block-query-pagination {
	margin-top: var(--wp--preset--spacing--60);
}

.wp-block-query-pagination a,
.wp-block-query-pagination .page-numbers {
	border-radius: var(--czn-radius-pill);
	padding: 8px 16px;
	font-weight: 600;
}

.wp-block-query-pagination a:hover {
	background: var(--wp--preset--color--green-primary);
	color: var(--wp--preset--color--dark);
}

/* Cover block overlay */
.wp-block-cover__image-background {
	object-fit: cover;
}


/* ==========================================================================
   Oferta Modal
   ========================================================================== */

.oferta-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 9999;
}

.oferta-modal.is-open {
	display: block;
}

.oferta-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(22, 22, 22, 0.55);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	animation: oferta-fade-in 0.2s ease forwards;
}

.oferta-modal__inner {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px 16px;
	overflow-y: auto;
}

.oferta-modal__card {
	position: relative;
	background: #fff;
	border-radius: var(--czn-radius-lg);
	padding: 28px 40px 36px;
	width: 100%;
	max-width: 760px;
	box-shadow: var(--czn-shadow-lg);
	animation: oferta-slide-up 0.22s ease forwards;
}

.oferta-modal__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	color: var(--wp--preset--color--black);
	transition: background var(--czn-transition), color var(--czn-transition);
}

.oferta-modal__close:hover {
	background: var(--wp--preset--color--bg-light);
}

.oferta-modal__label {
	margin: 0 0 20px;
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--black);
	font-family: var(--wp--preset--font-family--primary, inherit);
}

.oferta-modal__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}

.oferta-modal__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	border: 1px solid rgba(0, 0, 0, 0.09);
	border-radius: var(--czn-radius-md);
	text-decoration: none;
	color: var(--wp--preset--color--black);
	font-weight: 600;
	font-size: 0.9375rem;
	font-family: var(--wp--preset--font-family--primary, inherit);
	transition: border-color var(--czn-transition), background var(--czn-transition), color var(--czn-transition);
}

.oferta-modal__item:hover {
	border-color: var(--wp--preset--color--green-primary);
	background: var(--wp--preset--color--green-light);
	color: var(--wp--preset--color--black);
}

.oferta-modal__item:hover .oferta-modal__icon {
	color: var(--wp--preset--color--green-dark);
}

.oferta-modal__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--wp--preset--color--black);
	transition: color var(--czn-transition);
}

.oferta-modal__item:last-child:nth-child(odd) {
	grid-column: 1 / -1;
	max-width: calc(50% - 6px);
}

@keyframes oferta-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes oferta-slide-up {
	from { opacity: 0; transform: translateY(16px); }
	to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 600px) {
	.oferta-modal__grid {
		grid-template-columns: 1fr;
	}

	.oferta-modal__item:last-child:nth-child(odd) {
		grid-column: auto;
		max-width: 100%;
	}

	.oferta-modal__card {
		padding: 24px 20px 28px;
	}
}


/* ==========================================================================
   Single Post (single.html)
   ========================================================================== */

/* Back link */
.single-back-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wp--preset--color--black);
	text-decoration: none;
	margin-bottom: 2rem;
	transition: color var(--czn-transition);
}

.single-back-link:hover {
	color: var(--wp--preset--color--green-dark);
}

/* Post intro — centered column */
.single-post-intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1.5rem;
}

/* Force featured image to full width in flex column */
.single-post-intro .wp-block-post-featured-image,
.single-post-intro .single-post-featured {
	width: 100%;
	align-self: stretch;
}

/* Category badge — rendered via render_block filter (plain text, no link) */
.single-post-category-wrap {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11.5px 16px;
	border-radius: 20px;
	background: rgba(132, 207, 40, 0.149); /* #84CF2826 */
	font-family: var(--wp--preset--font-family--primary);
	font-size: 12px;
	font-weight: 800;
	line-height: 1.5;
	letter-spacing: 0;
	text-transform: uppercase;
	color: var(--wp--preset--color--green-primary);
}

.single-post-category-wrap::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--wp--preset--color--green-primary);
	flex-shrink: 0;
}

/* Title — wp:post-title with class single-post-title */
.single-post-title {
	font-family: var(--wp--preset--font-family--primary) !important;
	font-size: clamp(2rem, 5vw, 3rem) !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	letter-spacing: 0 !important;
	color: var(--wp--preset--color--black);
	margin: 0 !important;
	max-width: 720px;
}

/* Meta row */
.single-post-meta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	flex-wrap: wrap;
	width: 100%;
}

.single-post-meta__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding: 0 2rem;
}

.single-post-meta__sep {
	width: 1px;
	height: 36px;
	background: rgba(32, 36, 31, 0.15);
	flex-shrink: 0;
}

.single-post-meta__label {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--wp--preset--color--text-muted);
	letter-spacing: 0.02em;
}

.single-post-meta__value,
.single-post-meta__item .wp-block-post-author-name,
.single-post-meta__item .wp-block-post-date,
.single-post-meta__item .wp-block-post-date time {
	font-size: 1rem;
	font-weight: 700;
	color: var(--wp--preset--color--black);
	line-height: 1.1;
	margin: 0;
}

/* Featured image — wp:post-featured-image renders a <figure> */
.wp-block-post-featured-image.single-post-featured,
.single-post-featured {
	border-radius: var(--czn-radius-md);
	overflow: hidden;
	margin-top: 0.5rem;
}

.single-post-featured img,
.wp-block-post-featured-image.single-post-featured img {
	width: 100%;
	height: auto;
	display: block;
}

/* ── Two-column layout ────────────────────────────────────────────────────── */
.single-post-layout {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 3rem;
	align-items: start;
}

/* Sidebar */
.single-post-sidebar {
	position: sticky;
	top: calc(var(--wp-admin--admin-bar--height, 0px) + 100px);
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}

/* TOC */
.single-toc__label,
.single-share__label {
	font-size: 0.6875rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wp--preset--color--text-muted);
	margin: 0 0 0.75rem;
}

.single-toc__nav {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.single-toc__nav a {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--wp--preset--color--black);
	text-decoration: none;
	padding: 5px 0 5px 12px;
	border-left: 2px solid rgba(32, 36, 31, 0.1);
	line-height: 1.4;
	transition: color var(--czn-transition), border-color var(--czn-transition);
}

.single-toc__nav a:hover,
.single-toc__nav a.is-active {
	color: var(--wp--preset--color--green-dark);
	border-left-color: var(--wp--preset--color--green-primary);
}

/* Social share */
.single-share__icons {
	display: flex;
	gap: 10px;
}

.single-share__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1.5px solid rgba(32, 36, 31, 0.15);
	color: var(--wp--preset--color--black);
	text-decoration: none;
	transition: border-color var(--czn-transition), background var(--czn-transition), color var(--czn-transition);
}

.single-share__icon:hover {
	border-color: var(--wp--preset--color--green-primary);
	background: var(--wp--preset--color--green-light);
	color: var(--wp--preset--color--black);
}

/* Main content column */
.single-post-content {
	min-width: 0;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
	.single-post-layout {
		grid-template-columns: 1fr;
	}

	.single-post-sidebar {
		position: static;
		flex-direction: row;
		flex-wrap: wrap;
		gap: 1.5rem;
		padding-bottom: 1.5rem;
		border-bottom: 1px solid rgba(32, 36, 31, 0.1);
	}
}

@media (max-width: 600px) {
	.single-post-meta {
		flex-direction: column;
		gap: 0.75rem;
	}

	.single-post-meta__sep {
		display: none;
	}

	.single-post-meta__item {
		padding: 0;
	}

	.single-post-sidebar {
		flex-direction: column;
	}
}
