/*
Theme Name: Synergia Africa
Theme URI: https://synergiafrica.com/
Author: Codex
Description: Premium eco-clinical WordPress theme for Synergia Africa, a sustainable medical cannabis cultivator in the Democratic Republic of Congo.
Version: 1.0.17
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: synergia-africa
Tags: full-site-editing, block-patterns, block-styles, wide-blocks
*/

:root {
	--color-forest-deep: #08140e;
	--color-forest: #0b1c13;
	--color-forest-light: #122b1d;
	--color-cream: #f4f6f0;
	--color-sage: #a0afa0;
	--color-sun: #d4a359;
	--color-sun-soft: rgba(212, 163, 89, 0.16);
	--color-charcoal: #08140e;
	--color-white: #ffffff;
	--color-line: rgba(255, 255, 255, 0.08);
	--font-heading: "Playfair Display", Georgia, serif;
	--font-body: "Inter", Arial, sans-serif;
	--font-logo: "Cinzel", Georgia, serif;
	--max-width: 1180px;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--color-forest-deep);
	color: var(--color-cream);
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.7;
}

body::before {
	content: none;
}

.site-loader {
	display: none;
}

.site-loader::after {
	content: "";
	display: block;
	width: 180px;
	height: 2px;
	margin: 8px auto 0;
	background: linear-gradient(90deg, transparent, var(--color-cream), transparent);
	animation: loader-sweep 1100ms ease-in-out infinite;
}

.site-loader__brand {
	margin: 0;
	font-family: var(--font-logo);
	font-size: clamp(1.35rem, 3vw, 2.5rem);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.site-loader__text {
	margin: 0;
	color: rgba(250, 249, 246, 0.72);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.is-loaded .site-loader {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

a {
	color: inherit;
	text-decoration: none;
}

h1,
h2,
h3,
p {
	margin-top: 0;
}

h1,
h2,
h3 {
	font-family: var(--font-heading);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.05;
}

h1 {
	font-size: clamp(3rem, 6vw, 6.7rem);
	max-width: 950px;
}

h2 {
	font-size: clamp(2.2rem, 4vw, 4.8rem);
}

h3 {
	font-size: 1.45rem;
}

.wp-site-blocks,
.entry-content,
.wp-block-group {
	margin-top: 0;
}

.wp-block-group > :last-child,
.wp-block-buttons > :last-child {
	margin-bottom: 0;
}

.hero-grid > .wp-block-group__inner-container,
.hero-facts > .wp-block-group__inner-container,
.section-inner > .wp-block-group__inner-container,
.about-intro > .wp-block-group__inner-container,
.values-grid > .wp-block-group__inner-container,
.location-grid > .wp-block-group__inner-container,
.section-heading > .wp-block-group__inner-container,
.capability-grid > .wp-block-group__inner-container,
.cultivation > .wp-block-group__inner-container,
.split-copy > .wp-block-group__inner-container,
.quality-grid > .wp-block-group__inner-container,
.quality-items > .wp-block-group__inner-container,
.standards-grid > .wp-block-group__inner-container,
.process-list > .wp-block-group__inner-container,
.process-item > .wp-block-group__inner-container,
.insight-grid > .wp-block-group__inner-container,
.contact-grid > .wp-block-group__inner-container,
.contact-details > .wp-block-group__inner-container {
	display: contents;
}

.site-header {
	position: fixed;
	top: 20px;
	left: 50%;
	z-index: 20;
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 28px;
	align-items: center;
	width: min(calc(100% - 32px), 1180px);
	padding: 14px 18px;
	background: rgba(8, 20, 14, 0.84);
	border: 1px solid rgba(212, 163, 89, 0.14);
	border-radius: 8px;
	backdrop-filter: blur(18px);
	transform: translateX(-50%);
}

.site-logo {
	color: var(--color-cream);
	font-family: var(--font-logo);
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1;
	text-transform: uppercase;
	white-space: nowrap;
}

.site-logo a {
	color: inherit;
	text-decoration: none;
}

.site-logo span {
	display: inline-block;
	padding-top: 2px;
}

.site-logo img {
	display: block;
	width: 156px;
	height: auto;
	max-height: 54px;
	object-fit: contain;
}

.language-switcher {
	--switch-position: 0%;
	position: relative;
	display: inline-flex;
	align-items: center;
	width: 92px;
	height: 40px;
	padding: 4px;
	border: 1px solid rgba(13, 42, 24, 0.14);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	box-shadow: inset 0 1px 3px rgba(13, 42, 24, 0.08);
}

.language-switcher:before {
	content: "";
	position: absolute;
	top: 4px;
	left: 4px;
	width: calc(50% - 4px);
	height: calc(100% - 8px);
	border-radius: 999px;
	background: var(--color-forest);
	box-shadow: 0 8px 18px rgba(13, 42, 24, 0.22);
	transform: translateX(var(--switch-position));
	transition: transform 180ms ease-in-out;
}

.language-switcher:has(a[hreflang="fr"].is-active),
.language-switcher.is-fr-active {
	--switch-position: 100%;
}

.language-switcher a {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 1 1 50%;
	min-width: 0;
	min-height: 32px;
	padding: 0;
	border-radius: 999px;
	color: rgba(30, 33, 31, 0.68);
	font-size: 0.74rem;
	font-weight: 900;
	line-height: 1;
	text-decoration: none;
	transition: color 180ms ease-in-out;
}

.language-switcher a:hover,
.language-switcher a:focus,
.language-switcher a.is-active {
	color: var(--color-white);
}

.language-switcher a:not(.is-active):hover,
.language-switcher a:not(.is-active):focus {
	color: var(--color-forest);
}

.floating-language-switcher {
	position: fixed;
	right: 18px;
	bottom: 18px;
	z-index: 50;
}

.floating-language-switcher .language-switcher {
	background: rgba(250, 249, 246, 0.94);
	box-shadow: 0 14px 34px rgba(13, 42, 24, 0.18);
	backdrop-filter: blur(14px);
}

.menu-toggle {
	display: none;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid rgba(212, 163, 89, 0.24);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.06);
	cursor: pointer;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
}

.menu-toggle-line {
	display: block;
	width: 18px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-cream);
	transition: transform 180ms ease-in-out, opacity 180ms ease-in-out;
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.nav-menu,
.primary-nav .wp-block-navigation__container {
	display: flex;
	justify-content: center;
	gap: 22px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.nav-menu a,
.primary-nav .wp-block-navigation-item__content,
.primary-nav a {
	color: rgba(250, 249, 246, 0.74);
	font-size: 0.86rem;
	font-weight: 600;
	text-decoration: none;
	transition: color 180ms ease-in-out;
}

.nav-menu a:hover,
.nav-menu a:focus,
.primary-nav .wp-block-navigation-item__content:hover,
.primary-nav .wp-block-navigation-item__content:focus,
.primary-nav a:hover,
.primary-nav a:focus {
	color: var(--color-sun);
}

.site-header > .wp-block-buttons {
	justify-content: flex-end;
	margin: 0;
}

.header-cta,
.button,
.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 22px;
	border: 1px solid transparent;
	border-radius: 999px;
	font-weight: 700;
	line-height: 1.2;
	transition: transform 180ms ease-in-out, background-color 180ms ease-in-out, border-color 180ms ease-in-out;
}

.header-cta {
	font-size: 0.86rem;
	border-radius: 4px;
}

.header-cta,
.header-cta .wp-block-button__link {
	background: transparent;
	border-color: var(--color-sun);
	color: var(--color-sun);
}

.header-cta .wp-block-button__link {
	min-height: 46px;
	padding: 0 22px;
	border-color: var(--color-sun);
}

.header-cta.wp-block-button {
	background: transparent;
}

.site-header > .wp-block-buttons .header-cta {
	min-height: 0;
	padding: 0;
	border: 0;
	background: transparent;
}

.site-header > .wp-block-buttons .header-cta .wp-block-button__link {
	border-radius: 4px;
}

.button:hover,
.button:focus,
.wp-block-button__link:hover,
.wp-block-button__link:focus,
.header-cta:hover,
.header-cta:focus {
	transform: translateY(-2px);
}

.header-cta:hover,
.header-cta:focus,
.header-cta .wp-block-button__link:hover,
.header-cta .wp-block-button__link:focus {
	background: var(--color-sun);
	color: #08140e;
}

.button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 32px;
}

.button-solid,
.button-solid .wp-block-button__link {
	background: var(--color-white);
	color: var(--color-forest);
	border-radius: 4px;
}

.button-ghost,
.button-ghost .wp-block-button__link {
	background: rgba(255, 255, 255, 0.03);
	border-color: rgba(212, 163, 89, 0.44);
	color: var(--color-cream);
	border-radius: 4px;
}

.wp-block-button.button-solid,
.wp-block-button.button-ghost {
	background: transparent;
}

.section {
	padding: 120px 24px;
}

.section:not(.hero),
.split-section {
	content-visibility: auto;
	contain-intrinsic-size: auto 900px;
}

.section-inner {
	width: min(100%, var(--max-width));
	margin: 0 auto;
}

.hero {
	min-height: 100vh;
	padding: 8rem 24px 6rem;
	background:
		radial-gradient(circle at 108% -10%, var(--color-sun-soft) 0%, rgba(8, 20, 14, 0) 42%),
		linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px),
		var(--color-forest);
	background-size: auto, 50px 50px, 50px 50px, auto;
	color: var(--color-cream);
	overflow: hidden;
	position: relative;
}

.hero::before {
	content: "";
	position: absolute;
	top: -10%;
	right: -12%;
	width: min(860px, 70vw);
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle, var(--color-sun-soft) 0%, rgba(13, 42, 24, 0) 68%);
	pointer-events: none;
}

.hero::after {
	content: none;
}

.hero-grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(340px, 0.9fr);
	gap: clamp(42px, 5vw, 72px);
	align-items: center;
}

.hero-copy {
	position: relative;
	z-index: 2;
	max-width: 900px;
	padding: 0;
}

.hero-copy .eyebrow {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	margin-bottom: 2rem;
	padding: 9px 13px;
	padding: 0 0 0 14px;
	border: 0;
	border-left: 2px solid var(--color-sun);
	border-radius: 0;
	background: transparent;
	color: rgba(250, 249, 246, 0.72);
}

.hero-copy h1 {
	max-width: 820px;
	margin-bottom: 1.5rem;
	font-weight: 300;
	font-size: clamp(2.7rem, 5vw, 4.9rem);
	line-height: 1.12;
}

.hero-copy h1 em {
	font-style: italic;
	font-weight: 300;
}

.hero-text {
	max-width: 52ch;
	margin-bottom: 0;
	color: var(--color-sage);
	font-size: clamp(1rem, 1.25vw, 1.16rem);
}

.hero-facts {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	max-width: 420px;
	margin-top: 3.25rem;
	padding-left: 0;
	border-left: 0;
	background: transparent;
}

.hero-facts span {
	padding: 8px 12px;
	border: 1px solid rgba(250, 249, 246, 0.28);
	border-radius: 999px;
	color: rgba(250, 249, 246, 0.86);
	font-size: 0.8rem;
	font-weight: 800;
}

.hero-facts p {
	position: relative;
	margin: 0;
	padding: 0 0 0 24px;
	background: transparent;
	color: rgba(250, 249, 246, 0.86);
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1.35;
}

.hero-facts p::before {
	content: "";
	position: absolute;
	top: 6px;
	left: 0;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: var(--color-sun);
	box-shadow: 0 0 10px rgba(212, 163, 89, 0.66);
}

.eyebrow,
.section-kicker {
	margin-bottom: 18px;
	font-size: 0.77rem;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.section-kicker {
	display: inline-block;
	padding-left: 14px;
	border-left: 2px solid var(--color-sun);
	color: var(--color-sage);
}

.hero-visual,
.split-photo,
.lab-photo {
	--parallax-x: 0px;
	--parallax-y: 0px;
	min-height: 520px;
	border: 1px solid rgba(250, 249, 246, 0.24);
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	transition: box-shadow 180ms ease;
}

.hero-visual {
	align-self: center;
	aspect-ratio: 3 / 2;
	min-height: auto;
	width: 100%;
	margin: 0;
	padding: 10px;
	border-color: var(--color-line);
	border-radius: 12px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
		rgba(255, 255, 255, 0.02);
	box-shadow: 0 20px 44px rgba(0, 0, 0, 0.42);
}

.hero-visual::after {
	content: "GACP / GMP / QA";
	position: absolute;
	right: 1.5rem;
	bottom: 1.5rem;
	max-width: 220px;
	padding: 12px 14px;
	border: 1px solid rgba(212, 163, 89, 0.28);
	border-radius: 4px;
	background: rgba(8, 20, 14, 0.86);
	color: rgba(250, 249, 246, 0.9);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	line-height: 1.35;
	text-transform: uppercase;
	backdrop-filter: blur(10px);
}

.split-photo {
	aspect-ratio: 16 / 9;
}

.lab-photo {
	aspect-ratio: 3 / 2;
}

.hero-visual img,
.split-photo img,
.lab-photo img {
	display: block;
	width: 100%;
	height: 100%;
	min-height: inherit;
	object-fit: cover;
}

.hero-visual img {
	height: auto;
	min-height: 0;
	object-fit: contain;
	border-radius: 8px;
}

.hero-visual::before,
.split-photo::before,
.lab-photo::before {
	content: none;
}

.hero-visual:hover,
.split-photo:hover,
.lab-photo:hover {
	box-shadow: 0 28px 70px rgba(13, 42, 24, 0.28);
}

.leaf-mark {
	position: absolute;
	inset: auto 24px 24px auto;
	width: 180px;
	height: 180px;
	border: 1px solid rgba(250, 249, 246, 0.5);
	border-radius: 50%;
	background: rgba(13, 42, 24, 0.18);
	backdrop-filter: blur(6px);
	animation: leaf-orbit 9s ease-in-out infinite;
}

.leaf-mark::after {
	content: "";
	position: absolute;
	inset: 18px;
	border: 1px solid rgba(250, 249, 246, 0.36);
	border-radius: 50%;
}

.about {
	background: var(--color-forest-deep);
	color: var(--color-cream);
}

.about-intro {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.75fr);
	gap: 56px;
	align-items: start;
	margin-bottom: 56px;
}

.about-intro p {
	font-size: 1.06rem;
}

.values-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin-bottom: 56px;
}

.values-grid article,
.values-grid > .wp-block-group,
.values-grid > .wp-block-group__inner-container > .wp-block-group {
	padding: 28px;
	border-left: 3px solid var(--color-sun);
	background: rgba(255, 255, 255, 0.03);
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.values-grid article:hover,
.values-grid > .wp-block-group:hover,
.values-grid > .wp-block-group__inner-container > .wp-block-group:hover,
.location-card:hover,
.capability-card:hover,
.insight-grid article:hover,
.insight-grid > .wp-block-group:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 46px rgba(13, 42, 24, 0.12);
}

.values-grid h3 {
	margin-bottom: 12px;
	font-size: 1.28rem;
}

.values-grid p {
	margin-bottom: 0;
}

.location-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.location-card {
	min-height: 230px;
	padding: 28px;
	border: 1px solid var(--color-line);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.03);
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.location-card span {
	display: block;
	margin-bottom: 46px;
	color: var(--color-sage);
	font-weight: 800;
}

.location-card > p:first-child {
	display: block;
	margin-bottom: 46px;
	color: var(--color-sage);
	font-weight: 800;
}

.capabilities {
	background: var(--color-forest-light);
	color: var(--color-cream);
}

.section-heading {
	display: grid;
	grid-template-columns: minmax(0, 0.58fr) minmax(0, 1fr);
	gap: 42px;
	align-items: end;
	margin-bottom: 46px;
}

.section-heading .section-kicker {
	margin-bottom: 10px;
}

.capability-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	border-top: 1px solid var(--color-line);
	border-left: 1px solid var(--color-line);
}

.capability-card {
	min-height: 300px;
	padding: 28px;
	border-right: 1px solid var(--color-line);
	border-bottom: 1px solid var(--color-line);
	background: rgba(255, 255, 255, 0.03);
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.capability-card span,
.capability-card > p:first-child,
.process-item strong,
.insight-grid article p,
.insight-grid > .wp-block-group > p:first-child {
	color: var(--color-sage);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.capability-card span,
.capability-card > p:first-child {
	display: block;
	margin-bottom: 72px;
}

.cultivation {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	background: var(--color-forest);
	color: var(--color-cream);
}

.split-copy {
	padding: clamp(72px, 8vw, 130px);
}

.feature-list {
	display: grid;
	gap: 12px;
	padding-left: 20px;
	margin: 32px 0 0;
}

.split-photo {
	min-height: 680px;
	border: 0;
	border-radius: 0;
}

figure.split-photo,
figure.hero-visual,
figure.lab-photo {
	margin: 0;
}

.photo-placeholder {
	position: absolute;
	right: 28px;
	bottom: 28px;
	padding: 10px 14px;
	border: 1px solid rgba(255, 255, 255, 0.4);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.82);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
}

.quality {
	background: var(--color-forest-light);
	color: var(--color-cream);
}

.quality-grid {
	display: grid;
	grid-template-columns: minmax(300px, 0.72fr) minmax(360px, 1fr);
	gap: clamp(32px, 5vw, 72px);
	align-items: start;
	min-width: 0;
}

.quality h2 {
	font-size: clamp(2rem, 3.4vw, 4.2rem);
}

.quality-items {
	display: grid;
	gap: clamp(16px, 2vw, 22px);
	min-width: 0;
}

.quality-items h3 {
	font-size: clamp(1.18rem, 1.8vw, 1.45rem);
}

.quality-items p {
	overflow-wrap: break-word;
}

.lab-photo {
	width: 100%;
	min-height: clamp(240px, 30vw, 320px);
	margin-top: 28px;
	border-color: var(--color-line);
}

.quality-items article,
.quality-items > .wp-block-group,
.quality-items > .wp-block-group__inner-container > .wp-block-group {
	padding-bottom: 24px;
	border-bottom: 1px solid var(--color-line);
}

.standards {
	background: var(--color-forest-deep);
	color: var(--color-cream);
}

.standards-grid {
	display: grid;
	grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1fr);
	gap: 78px;
	align-items: start;
}

.process-list {
	display: grid;
	gap: 0;
	border-top: 1px solid var(--color-line);
}

.process-item {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 22px;
	padding: 28px 0;
	border-bottom: 1px solid var(--color-line);
}

.process-item p {
	margin-bottom: 0;
	font-size: 1.05rem;
}

.process-item span {
	font-weight: 900;
}

.insights {
	background: var(--color-forest);
	color: var(--color-cream);
}

.insights .section-kicker,
.insights .insight-grid article p,
.insights .insight-grid > .wp-block-group > p:first-child {
	color: rgba(250, 249, 246, 0.7);
}

.insights .section-kicker,
.contact .section-kicker {
	border-left-color: var(--color-sun);
}

.insight-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.insight-grid article,
.insight-grid > .wp-block-group,
.insight-grid > .wp-block-group__inner-container > .wp-block-group {
	min-height: 270px;
	padding: 28px;
	border: 1px solid rgba(250, 249, 246, 0.16);
	border-radius: 8px;
	background: rgba(250, 249, 246, 0.06);
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.insight-grid article:hover,
.insight-grid > .wp-block-group:hover,
.insight-grid > .wp-block-group__inner-container > .wp-block-group:hover {
	border-color: rgba(250, 249, 246, 0.34);
	background: rgba(250, 249, 246, 0.1);
}

.insight-grid h3 {
	margin-bottom: 18px;
}

.insight-grid span {
	color: rgba(250, 249, 246, 0.72);
}

.insight-grid > .wp-block-group > p:last-child {
	color: rgba(250, 249, 246, 0.72);
}

.contact {
	background: var(--color-charcoal);
	color: var(--color-white);
}

.contact-grid {
	display: grid;
	grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 0.7fr);
	gap: 70px;
	align-items: start;
}

.contact-details {
	display: grid;
	gap: 14px;
	margin-top: 32px;
	color: rgba(250, 249, 246, 0.86);
	font-size: 1.1rem;
	font-weight: 700;
}

.contact-copy {
	max-width: 520px;
	color: rgba(250, 249, 246, 0.72);
}

.contact-form {
	display: grid;
	gap: 12px;
	padding: 30px;
	border: 1px solid rgba(250, 249, 246, 0.16);
	border-radius: 8px;
	background: rgba(250, 249, 246, 0.05);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.18);
}

.contact-form label {
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
}

.contact-form input,
.contact-form textarea {
	width: 100%;
	padding: 14px 15px;
	border: 1px solid rgba(250, 249, 246, 0.2);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.08);
	color: var(--color-white);
	font: inherit;
}

.contact-form textarea {
	resize: vertical;
}

.contact-form .button-solid {
	margin-top: 10px;
	border: 0;
	cursor: pointer;
	font: inherit;
	font-weight: 800;
}

.site-footer {
	padding: 28px 24px;
	background: #151816;
	color: rgba(250, 249, 246, 0.68);
	text-align: center;
}

.site-footer p {
	margin: 0;
	font-size: 0.9rem;
}

.has-cinematic-motion .cinematic-reveal {
	opacity: 0;
	transform: translateY(34px) scale(0.985);
	filter: blur(10px);
	transition:
		opacity 760ms ease var(--reveal-delay, 0ms),
		transform 760ms cubic-bezier(0.2, 0.85, 0.2, 1) var(--reveal-delay, 0ms),
		filter 760ms ease var(--reveal-delay, 0ms);
}

.has-cinematic-motion .cinematic-reveal.is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
	filter: blur(0);
}

@keyframes atmospheric-drift {
	from {
		transform: translate3d(-1.5%, -1%, 0) scale(1);
	}

	to {
		transform: translate3d(1.5%, 1%, 0) scale(1.04);
	}
}

@keyframes cinematic-sweep {
	0%,
	30% {
		transform: translateX(-70%);
	}

	70%,
	100% {
		transform: translateX(70%);
	}
}

@keyframes photo-glint {
	0%,
	55% {
		opacity: 0;
		transform: translateX(-90%);
	}

	68% {
		opacity: 0.35;
	}

	90%,
	100% {
		opacity: 0;
		transform: translateX(90%);
	}
}

@keyframes leaf-orbit {
	0%,
	100% {
		transform: translate3d(0, 0, 0) rotate(0deg);
	}

	50% {
		transform: translate3d(-10px, 8px, 0) rotate(2deg);
	}
}

@keyframes loader-sweep {
	0% {
		opacity: 0.25;
		transform: scaleX(0.35);
	}

	50% {
		opacity: 1;
		transform: scaleX(1);
	}

	100% {
		opacity: 0.25;
		transform: scaleX(0.35);
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 1ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 1ms !important;
	}

	.has-cinematic-motion .cinematic-reveal {
		opacity: 1;
		filter: none;
		transform: none;
	}
}

@media (max-width: 1180px) {
	.site-header {
		grid-template-columns: 1fr auto;
		gap: 12px 16px;
	}

	.menu-toggle {
		display: inline-flex;
		grid-column: 2;
		grid-row: 1;
	}

	.site-header.is-menu-open .menu-toggle-line:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}

	.site-header.is-menu-open .menu-toggle-line:nth-child(2) {
		opacity: 0;
	}

	.site-header.is-menu-open .menu-toggle-line:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
	}

	.primary-nav {
		grid-column: 1 / -1;
		grid-row: 2;
		display: none;
		width: 100%;
		overflow: visible;
		padding: 14px 0 0;
		border-top: 1px solid rgba(212, 163, 89, 0.16);
	}

	.site-header.is-menu-open .primary-nav {
		display: block;
	}

	.site-header.is-menu-open .primary-nav.wp-block-navigation {
		display: flex;
	}

	.nav-menu,
	.primary-nav .wp-block-navigation__container {
		display: grid;
		width: 100%;
		min-width: 0;
		gap: 6px;
	}

	.nav-menu a,
	.primary-nav .wp-block-navigation-item__content,
	.primary-nav a {
		display: flex;
		align-items: center;
		min-height: 44px;
		padding: 0 4px;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: rgba(250, 249, 246, 0.78);
		font-size: 0.96rem;
	}

	.header-cta {
		display: none;
		grid-column: 1 / -1;
		grid-row: 3;
		width: 100%;
	}

	.site-header > .wp-block-buttons {
		display: none;
		grid-column: 1 / -1;
		grid-row: 3;
		width: 100%;
		justify-content: stretch;
	}

	.site-header.is-menu-open .header-cta {
		display: inline-flex;
	}

	.site-header.is-menu-open > .wp-block-buttons {
		display: flex;
	}

	.site-header > .wp-block-buttons .header-cta,
	.site-header > .wp-block-buttons .header-cta .wp-block-button__link {
		width: 100%;
	}

	.hero-grid,
	.about-intro,
	.quality-grid,
	.contact-grid,
	.cultivation,
	.section-heading,
	.standards-grid {
		grid-template-columns: 1fr;
	}

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

	.hero-copy h1,
	.hero-text,
	.hero-facts {
		max-width: 100%;
	}

	.hero-visual,
	.split-photo {
		min-height: 360px;
	}

	.hero-visual {
		margin-left: 0;
		border-radius: 8px;
	}

	.location-grid,
	.values-grid {
		grid-template-columns: 1fr;
	}

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

@media (max-width: 640px) {
	.site-header {
		top: 12px;
		width: calc(100% - 20px);
		padding: 12px;
	}

	.site-logo {
		font-size: 0.98rem;
	}

	.site-logo img {
		width: 126px;
		max-height: 44px;
	}

	.header-cta {
		min-height: 40px;
		padding: 0 14px;
		font-size: 0.78rem;
	}

	.site-header > .wp-block-buttons .header-cta {
		min-height: 0;
		padding: 0;
	}

	.site-header > .wp-block-buttons .header-cta .wp-block-button__link {
		min-height: 40px;
		padding: 0 14px;
		font-size: 0.78rem;
	}

	.nav-menu a,
	.primary-nav .wp-block-navigation-item__content,
	.primary-nav a {
		min-height: 42px;
		font-size: 0.9rem;
	}

	.section {
		padding: 82px 18px;
	}

	.hero {
		padding-top: 170px;
	}

	.button-row {
		flex-direction: column;
	}

	.hero-facts {
		grid-template-columns: 1fr;
		margin-top: 24px;
		padding-left: 16px;
	}

	.hero-facts p {
		padding: 0 0 0 24px;
	}

	.hero-facts p::before {
		top: 4px;
		left: 0;
	}

	.button {
		width: 100%;
	}

	.wp-block-button,
	.wp-block-button__link {
		width: 100%;
	}

	.split-copy {
		padding: 82px 18px;
	}

	.contact-form {
		padding: 20px;
	}

	.capability-grid,
	.insight-grid {
		grid-template-columns: 1fr;
	}

	.capability-card,
	.insight-grid article {
		min-height: auto;
	}

	.capability-card span {
		margin-bottom: 34px;
	}

	.process-item {
		grid-template-columns: 1fr;
		gap: 8px;
	}
}
